/* =========================================================
   JEWISH (the movie), site-wide stylesheet
   Shared across all v2/*.html pages
   ========================================================= */

/* Self-hosted Nunito (SIL OFL) -- PROMPT_0078, replaces Google Fonts */
@font-face{font-family:'Nunito';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/nunito/nunito-400-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/nunito/nunito-400-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/nunito/nunito-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/nunito/nunito-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/nunito/nunito-600-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/nunito/nunito-600-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/nunito/nunito-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/nunito/nunito-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/nunito/nunito-700-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/nunito/nunito-700-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/nunito/nunito-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/nunito/nunito-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/nunito/nunito-800-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/nunito/nunito-800-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/nunito/nunito-800-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/nunito/nunito-800-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/nunito/nunito-900-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/nunito/nunito-900-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/nunito/nunito-900-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Nunito';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/nunito/nunito-900-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

:root {
  --cream:        #FFF9F2;
  --cream-tint:   #FBF1E2;
  --cream-deeper: #F5E9D4;
  --cream-shade:  #EFDFC2;
  --title:        #B8541A;
  --title-deep:   #8E3F12;
  --ink:          #6B4423;
  --ink-soft:     #8A6A4A;
  --ink-faint:    #B49B7A;
  --accent:       #F4B400;
  --accent-deep:  #D89A00;
  --accent-tint:  rgba(244, 180, 0, 0.14);
  --accent-glow:  rgba(244, 180, 0, 0.28);
  --band-rose:           #F4B5A8;
  --band-rose-fill:      #FCE9E5;
  --band-rose-deep:      #C97062;
  --band-peach:          #FFD9B5;
  --band-peach-fill:     #FFF0DF;
  --band-peach-deep:     #D88B47;
  --band-pistachio:      #C9DDB8;
  --band-pistachio-fill: #EEF5E7;
  --band-pistachio-deep: #6B8E5A;
  --band-sky:            #BFD7E8;
  --band-sky-fill:       #EAF4FA;
  --band-sky-deep:       #5A8AA8;
  --band-wine:           #D89A9A;
  --band-wine-fill:      #F6E6E6;
  --band-wine-deep:      #A04848;
  --band-fill:           var(--cream-tint);
  --band-deep:           var(--title);
  --band-border:         rgba(184, 84, 26, 0.16);
  --border:        rgba(184, 84, 26, 0.16);
  --border-strong: rgba(184, 84, 26, 0.30);
  --shadow-sm:     0 4px 12px -6px rgba(184, 84, 26, 0.18);
  --shadow-md:     0 18px 40px -20px rgba(184, 84, 26, 0.32),
                   0 6px 14px -8px  rgba(184, 84, 26, 0.18);
  --shadow-lg:     0 32px 70px -32px rgba(184, 84, 26, 0.38),
                   0 12px 24px -14px rgba(184, 84, 26, 0.22);
  --radius:    14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
}
@media (prefers-color-scheme: dark) { :root { color-scheme: light; } }

body[data-band="film"]     { --band-fill: var(--band-wine-fill);      --band-deep: var(--band-wine-deep);      --band-border: rgba(160, 72, 72, 0.22); }
body[data-band="music"]    { --band-fill: var(--band-peach-fill);     --band-deep: var(--band-peach-deep);     --band-border: rgba(216, 139, 71, 0.22); }
body[data-band="cast"]     { --band-fill: var(--band-pistachio-fill); --band-deep: var(--band-pistachio-deep); --band-border: rgba(107, 142, 90, 0.22); }
body[data-band="crossing"] { --band-fill: var(--band-sky-fill);       --band-deep: var(--band-sky-deep);       --band-border: rgba(90, 138, 168, 0.22); }
body[data-band="contact"]  { --band-fill: var(--band-rose-fill);      --band-deep: var(--band-rose-deep);      --band-border: rgba(201, 112, 98, 0.22); }

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: 'Nunito', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
}

/* ===== Skip link & a11y ===== */
.skip-link {
  position: absolute; left: 1rem; top: -100px;
  background: var(--cream); color: var(--title);
  padding: 0.6rem 0.9rem; border-radius: 10px;
  font-weight: 700; text-decoration: none;
  border: 2px solid var(--title); z-index: 100;
  transition: top 160ms ease;
}
.skip-link:focus { top: 1rem; outline: none; }
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ===== Top navigation ===== */
.site-nav {
  position: sticky; top: 0; z-index: 40;
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  background: rgba(255, 249, 242, 0.82);
  border-bottom: 1px solid var(--border);
}
.site-nav-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0.9rem 1.5rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem;
}
.brand {
  font-weight: 900; font-size: 1.15rem;
  letter-spacing: -0.01em; color: var(--title);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 0.55rem;
}
.brand .brand-dot {
  display: inline-block; width: 7px; height: 7px;
  background: var(--accent); border-radius: 50%;
  box-shadow: 0 0 0 4px var(--accent-tint);
}
.brand .brand-sub {
  font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft);
  border-left: 1px solid var(--border-strong);
  padding-left: 0.7rem; margin-left: 0.25rem;
}
.site-nav ol {
  list-style: none; margin: 0; padding: 0;
  display: flex; gap: 0.15rem;
  align-items: center;
}
.site-nav li { flex-shrink: 0; }
.site-nav a.nav-link {
  display: inline-block;
  padding: 0.6rem 0.85rem;
  font-weight: 700; font-size: 0.78rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft); text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color 160ms ease, border-color 160ms ease;
  white-space: nowrap;
}
.site-nav a.nav-link:hover { color: var(--title); }
.site-nav a.nav-link.active { color: var(--title); border-bottom-color: var(--accent); }

/* Mobile menu trigger — hidden on desktop */
.nav-toggle {
  display: none;
  align-items: center;
  gap: 0.5rem;
  font: inherit;
  font-weight: 800;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--title);
  background: var(--cream-tint);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  padding: 0.55rem 0.95rem;
  cursor: pointer;
  line-height: 1;
}
.nav-toggle:hover { background: var(--cream-deeper); }
.nav-toggle:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--accent-tint);
  border-color: var(--accent-deep);
}
.nav-toggle .nav-toggle-bars {
  display: inline-flex; flex-direction: column; gap: 3px;
  width: 18px;
}
.nav-toggle .nav-toggle-bars span {
  display: block; height: 2px; width: 100%;
  background: currentColor; border-radius: 2px;
}

@media (max-width: 820px) {
  .site-nav-inner {
    padding: 0.7rem 1rem;
    gap: 0.6rem;
    flex-wrap: wrap;
  }
  .brand .brand-sub { display: none; }
  .nav-toggle { display: inline-flex; }
  .site-nav ol {
    order: 3;
    flex-basis: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    margin-top: 0.35rem;
    padding: 0.4rem 0;
    border-top: 1px solid var(--border);
  }
  .site-nav a.nav-link {
    display: block;
    padding: 0.85rem 0.4rem;
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    border-bottom: 1px solid var(--border);
  }
  .site-nav a.nav-link.active {
    color: var(--title);
    border-bottom-color: var(--accent);
  }
  .site-nav li:last-child a.nav-link { border-bottom: 0; }
  .site-nav-inner > .btn { order: 4; flex-basis: 100%; justify-content: center; }
  /* Collapsed by default on mobile */
  .site-nav[data-open="false"] ol,
  .site-nav[data-open="false"] > .site-nav-inner > .btn {
    display: none;
  }
  .site-nav[data-open="true"] .nav-toggle .label-open { display: none; }
  .site-nav[data-open="false"] .nav-toggle .label-close { display: none; }
}
@media (min-width: 821px) {
  .nav-toggle { display: none !important; }
  .site-nav-inner > .btn { display: inline-flex; }
}

/* ===== Section scaffolding ===== */
section { position: relative; padding: 5rem 1.5rem; }
section.tight { padding: 3.5rem 1.5rem; }
section.banded {
  background: var(--band-fill);
  border-top: 1px solid var(--band-border);
  border-bottom: 1px solid var(--band-border);
}
section.banded .eyebrow,
section.banded .num {
  color: var(--band-deep);
}
section.banded .eyebrow::before {
  background: var(--band-deep);
}
section.banded .arc {
  background: var(--band-deep);
  opacity: 0.72;
}
.container { max-width: 1100px; margin: 0 auto; }
.wide { max-width: 1280px; margin: 0 auto; }
.narrow { max-width: 720px; margin: 0 auto; }

.eyebrow {
  font-weight: 700; font-size: 0.78rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-deep); margin: 0 0 0.9rem;
  display: inline-flex; align-items: center; gap: 0.6em;
}
.eyebrow::before {
  content: ""; width: 22px; height: 2px;
  background: var(--accent); border-radius: 2px;
}
.eyebrow.center { justify-content: center; }

/* All H1 default to Nunito Black (900) site-wide (PROMPT_0082) */
h1 { font-weight: 900; }

h1.page-title, h2.section-title {
  font-weight: 900;
  font-size: clamp(2.2rem, 5vw, 4rem);
  line-height: 1; letter-spacing: -0.02em;
  color: var(--title);
  margin: 0 0 1.5rem;
  text-wrap: balance;
}
h1.page-title { font-size: clamp(2.6rem, 6vw, 5rem); }
h3 {
  font-weight: 900;
  font-size: clamp(1.3rem, 2vw, 1.65rem);
  line-height: 1.15; letter-spacing: -0.01em;
  color: var(--title);
  margin: 0 0 0.5rem;
}
p { line-height: 1.7; text-wrap: pretty; margin: 0 0 1rem; }
p.lede {
  font-size: clamp(1.15rem, 1.5vw, 1.3rem);
  font-weight: 600;
  color: var(--ink);
}

/* Marigold arc divider */
.arc {
  display: block; margin: 0 auto;
  width: 64px; height: 8px;
  border-radius: 999px 999px 0 0 / 14px 14px 0 0;
  background: var(--accent);
  opacity: 0.85;
}

/* Hairline rule */
.rule {
  height: 1px; border: 0; margin: 0;
  background: var(--border);
}

/* ===== Buttons & links ===== */
.btn {
  font: inherit; font-weight: 700; font-size: 0.95rem;
  color: var(--ink); background: var(--accent);
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  padding: 0.85rem 1.3rem; cursor: pointer;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 0.5em;
  white-space: nowrap;
  transition: background 160ms ease, transform 80ms ease, box-shadow 160ms ease;
  box-shadow: 0 1px 0 rgba(184, 84, 26, 0.08);
}
.btn:hover { background: var(--accent-deep); border-color: var(--accent-deep); }
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--accent-tint); }
.btn[disabled] { opacity: 0.7; cursor: progress; }
.btn.ghost {
  background: transparent; color: var(--title);
  border-color: var(--border-strong);
  box-shadow: none;
}
.btn.ghost:hover {
  background: var(--cream-tint); border-color: var(--title); color: var(--title);
}
.btn .arrow {
  transition: transform 160ms ease;
}
.btn:hover .arrow { transform: translateX(3px); }

a.email-link {
  display: inline-flex; align-items: center; gap: 0.5em;
  font-weight: 700; color: var(--title);
  text-decoration: none;
  border-bottom: 2px solid var(--accent);
  padding-bottom: 2px;
  transition: color 160ms ease, border-color 160ms ease;
}
a.email-link:hover {
  color: var(--accent-deep);
  border-bottom-color: var(--accent-deep);
}

/* ===== Form ===== */
.form {
  display: flex; gap: 0.6rem;
  width: 100%; max-width: 460px;
  margin: 1.75rem auto 0;
  align-items: stretch;
}
.input {
  flex: 1; min-width: 0;
  font: inherit; font-weight: 500; font-size: 1rem;
  color: var(--ink); background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.95rem 1.1rem;
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease;
}
.input::placeholder { color: var(--ink-soft); opacity: 0.75; }
.input:hover { border-color: var(--border-strong); }
.input:focus-visible {
  border-color: var(--accent-deep);
  box-shadow: 0 0 0 4px var(--accent-tint);
}
.status {
  margin-top: 1.1rem; min-height: 1.4em;
  font-size: 0.95rem; font-weight: 700;
  color: var(--ink-soft);
}
.status[data-state="success"] { color: var(--title); }
.status[data-state="error"]   { color: var(--title); }
.status[data-state="idle"]    { opacity: 0; }
@media (max-width: 480px) { .form { flex-direction: column; } }

/* ===== Footer ===== */
footer.site-footer {
  padding: 3rem 1.5rem 3.5rem;
  background: var(--cream);
  border-top: 1px solid var(--border);
  margin-top: 2rem;
}
.footer-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; gap: 2.5rem;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  align-items: start;
}
@media (max-width: 820px) {
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .footer-inner { grid-template-columns: 1fr; }
}
.footer-brand {
  font-weight: 900; font-size: 1.4rem; letter-spacing: -0.01em;
  color: var(--title); margin: 0 0 0.5rem;
}
.footer-tag {
  color: var(--ink-soft); font-size: 0.92rem; line-height: 1.6;
  max-width: 28ch;
}
.footer-col h5 {
  margin: 0 0 0.85rem;
  font-weight: 700; font-size: 0.74rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft);
}
.footer-col ul {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: 0.5rem;
}
.footer-col a {
  color: var(--ink); font-weight: 600; font-size: 0.92rem;
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: border-color 160ms ease, color 160ms ease;
}
.footer-col a:hover {
  color: var(--title);
  border-bottom-color: var(--accent);
}
.footer-base {
  max-width: 1100px; margin: 2.5rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; flex-wrap: wrap;
  font-size: 0.82rem; color: var(--ink-soft);
}

/* ===== Page hero (small) ===== */
.page-hero {
  position: relative; isolation: isolate;
  padding: 5rem 1.5rem 3.5rem;
  text-align: left; overflow: hidden;
}
.page-hero .container { display: grid; gap: 1rem; }
.page-hero .glow-corner {
  position: absolute; pointer-events: none; z-index: -1;
  width: 520px; height: 520px;
  top: -160px; right: -120px;
  background: radial-gradient(circle at center,
    var(--accent-glow) 0%,
    rgba(244, 180, 0, 0.10) 38%,
    rgba(244, 180, 0, 0)   70%);
}
.page-hero h1.page-title { margin: 0; }
.page-hero p.lede { max-width: 60ch; margin: 0; }

/* Roman numerals header */
.numeral-row {
  font-weight: 900; font-size: clamp(0.85rem, 1.1vw, 1rem);
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 0.8em;
}
.numeral-row .num {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 2.25em; height: 2.25em; padding: 0 0.55em;
  background: var(--cream-tint);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--title); font-size: 0.95rem;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
}

@media (max-width: 640px) {
  section { padding: 3.5rem 1.25rem; }
}

/* --- Footer column heading (was h5, downgraded to p for semantic correctness, AUDIT_0043) --- */
.footer-col-heading {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 0.875rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--title);
  margin: 0 0 0.875rem 0;
}
