/* ==========================================================================
   AMERICAN RAIDERS — EDITORIAL THEME v2
   Dark stage · Old Glory accents · Anton / Fraunces / Instrument Sans / JetBrains Mono
   ========================================================================== */

/* ---------- Design Tokens ---------- */
:root {
    /* Color — navy stage (matching v1 brand: navy + red + white), editorial treatment */
    --canvas:        #111C33;  /* navy-dark — the stage */
    --canvas-2:      #162238;  /* mid-navy */
    --surface:       #1A2744;  /* primary navy — panels, cards */
    --surface-2:     #243352;  /* navy-light — hover */
    --surface-3:     #2D3E61;  /* navy-lighter — nested */
    --ruler:         rgba(255,255,255,0.08);
    --ruler-strong:  rgba(255,255,255,0.18);

    --ink:           #FFFFFF;
    --ink-90:        rgba(255,255,255,0.9);
    --ink-70:        rgba(255,255,255,0.7);
    --ink-60:        rgba(255,255,255,0.6);   /* meta-safe on navy (~5.5:1) */
    --ink-55:        rgba(255,255,255,0.55);
    --ink-45:        rgba(255,255,255,0.45);
    --ink-35:        rgba(255,255,255,0.35);  /* decorative only */

    --on-light:      #111C33;
    --on-light-70:   rgba(17,28,51,0.72);

    /* Brand colors — matching the v1 live site exactly */
    --red:           #C41E3A;  /* v1 brand red */
    --red-hot:       #DC2443;
    --red-bright:    #FF4259;  /* text-safe red on navy (~5:1) */
    --red-deep:      #A81830;  /* v1 red-hover */
    --navy:          #1A2744;
    --navy-dark:     #111C33;
    --navy-light:    #243352;
    --blue:          #002868;
    --blue-bright:   #3F5C9E;
    --gold:          #D4B56A;   /* slightly warmer gold, reads better on navy */
    --gold-deep:     #9C813F;
    --cream:         #F5EEDF;

    /* Type */
    --f-display:   'Anton', 'Bebas Neue', 'Oswald', sans-serif;
    --f-editorial: 'Fraunces', 'Instrument Serif', 'Georgia', serif;
    --f-ui:        'Instrument Sans', 'Instrument Serif', ui-sans-serif, system-ui, sans-serif;
    --f-mono:      'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;

    /* Fluid type scale */
    --fs-xs:   clamp(0.72rem, 0.68rem + 0.2vw, 0.78rem);
    --fs-sm:   clamp(0.82rem, 0.78rem + 0.22vw, 0.92rem);
    --fs-base: clamp(0.95rem, 0.92rem + 0.25vw, 1.08rem);
    --fs-lg:   clamp(1.08rem, 1.02rem + 0.3vw, 1.25rem);
    --fs-xl:   clamp(1.3rem,  1.2rem  + 0.5vw, 1.65rem);
    --fs-2xl:  clamp(1.7rem,  1.55rem + 1vw,   2.4rem);
    --fs-3xl:  clamp(2.3rem,  2rem    + 1.5vw, 3.4rem);
    --fs-4xl:  clamp(3rem,    2.5rem  + 2.5vw, 5rem);
    --fs-5xl:  clamp(4rem,    3rem    + 4.5vw, 7.5rem);
    --fs-hero: clamp(4.5rem,  3.5rem  + 6vw,   11rem);
    --fs-mega: clamp(7rem,    5rem    + 10vw,  18rem);

    /* Spacing */
    --s-1:  0.25rem;
    --s-2:  0.5rem;
    --s-3:  0.75rem;
    --s-4:  1rem;
    --s-5:  1.5rem;
    --s-6:  2rem;
    --s-7:  3rem;
    --s-8:  4rem;
    --s-9:  6rem;
    --s-10: 8rem;
    --s-11: 10rem;
    --s-12: 14rem;

    /* Layout */
    --content-max: 1360px;
    --content-tight: 960px;
    --gutter: clamp(1.2rem, 2vw, 2.4rem);
    --section-y: clamp(4rem, 3rem + 5vw, 8rem);

    /* Motion */
    --dur-1:  120ms;
    --dur-2:  240ms;
    --dur-3:  420ms;
    --dur-4:  700ms;
    --dur-5:  1400ms;
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

    /* Elevation */
    --sh-1: 0 1px 0 var(--ruler);
    --sh-2: 0 14px 32px -16px rgba(0,0,0,0.6);
    --sh-3: 0 30px 60px -20px rgba(0,0,0,0.8);

    --radius: 2px;
    --radius-lg: 6px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    background: var(--canvas);
}
body {
    font-family: var(--f-ui);
    font-size: var(--fs-base);
    line-height: 1.55;
    color: var(--ink);
    background: var(--canvas);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    min-height: 100vh;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
svg { flex-shrink: 0; }
a { color: inherit; text-decoration: none; }
button { font: inherit; background: none; border: 0; color: inherit; cursor: pointer; }
ul, ol { list-style: none; }
input, textarea, select { font: inherit; color: inherit; }
::selection { background: var(--red); color: var(--ink); }

.skip-link {
    position: absolute;
    left: -10000px; top: 8px;
    background: var(--ink); color: var(--on-light);
    padding: var(--s-3) var(--s-4);
    z-index: 999;
    font-family: var(--f-ui); font-weight: 600;
}
.skip-link:focus { left: 8px; }

:focus-visible { outline: 2px solid var(--red-bright); outline-offset: 3px; }

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--f-display);
    font-weight: 400;
    letter-spacing: 0.01em;
    line-height: 0.95;
    text-transform: uppercase;
    color: var(--ink);
}
p { color: var(--ink-70); max-width: 70ch; }
strong, b { color: var(--ink); font-weight: 600; }
em, i {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    letter-spacing: 0;
    text-transform: none;
}

.display    { font-family: var(--f-display); text-transform: uppercase; line-height: 0.92; }
.editorial  { font-family: var(--f-editorial); font-style: italic; font-weight: 300; text-transform: none; letter-spacing: -0.01em; }
.meta       { font-family: var(--f-mono); font-size: var(--fs-xs); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-55); }

.eyebrow {
    font-family: var(--f-mono);
    font-size: 0.72rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--ink-55);
    display: inline-flex;
    align-items: center;
    gap: var(--s-3);
}
.eyebrow::before {
    content: ''; width: 28px; height: 1px;
    background: var(--red-bright); display: inline-block;
}
.eyebrow.eyebrow-gold::before { background: var(--gold); }
.eyebrow.eyebrow-blue::before { background: var(--blue-bright); }

/* ---------- Layout primitives ---------- */
.container {
    width: 100%;
    max-width: var(--content-max);
    margin: 0 auto;
    padding-left: var(--gutter);
    padding-right: var(--gutter);
}
.container-tight {
    max-width: var(--content-tight);
    margin-inline: auto;
    padding-inline: var(--gutter);
}
.section { padding-block: var(--section-y); position: relative; }
.section + .section { border-top: 1px solid var(--ruler); }

/* ---------- Grain overlay ---------- */
.grain::before {
    content: '';
    position: absolute; inset: 0;
    pointer-events: none;
    opacity: 0.22;
    mix-blend-mode: overlay;
    background-image:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
    background-size: 260px;
    z-index: 0;
}

/* ---------- Brand rule — minimal gold line with faded edges ---------- */
.flag-strip {
    display: block;
    width: var(--w, 120px);
    height: 2px;
    background: linear-gradient(to right,
        transparent 0,
        var(--gold) 8%,
        var(--gold) 92%,
        transparent 100%);
    opacity: 0.85;
    border-radius: 1px;
}

/* ==========================================================================
   SITE HEADER
   ========================================================================== */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    background: transparent;
    transition: background var(--dur-3) var(--ease-out),
                backdrop-filter var(--dur-3) var(--ease-out),
                border-color var(--dur-3) var(--ease-out);
    border-bottom: 1px solid transparent;
}
.site-header.scrolled,
.site-header.menu-open,
body.is-page .site-header {
    background: rgba(17,28,51,0.88);
    backdrop-filter: saturate(160%) blur(18px);
    -webkit-backdrop-filter: saturate(160%) blur(18px);
    border-bottom-color: var(--ruler);
}
.header-top-strip {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--s-4);
    padding: 6px var(--gutter);
    background: var(--canvas);
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-55);
    border-bottom: 1px solid var(--ruler);
}
.header-top-strip .star { color: var(--gold); width: 10px; height: 10px; }

.header-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    min-height: 76px;
    padding-inline: var(--gutter);
    gap: var(--s-6);
    max-width: var(--content-max);
    margin-inline: auto;
}
.site-logo {
    display: inline-flex;
    align-items: center;
    gap: var(--s-3);
    color: var(--ink);
    text-decoration: none;
    transition: opacity var(--dur-2) var(--ease-out);
}
.site-logo:hover { opacity: 0.9; }
.logo-img {
    height: 40px; width: auto;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.4));
}
.logo-text {
    font-family: var(--f-display);
    font-size: 14px;
    letter-spacing: 0.09em;
    line-height: 1;
    text-transform: uppercase;
    color: var(--ink);
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.logo-text strong { font-weight: 400; color: var(--ink); }
.logo-text em {
    font-family: var(--f-editorial);
    font-weight: 300;
    font-style: italic;
    font-size: 15px;
    letter-spacing: 0;
    color: var(--ink);
    text-transform: none;
}

/* Primary nav — desktop */
.primary-nav { display: flex; justify-content: center; }
.primary-nav .nav-list {
    display: flex;
    align-items: center;
    gap: clamp(0.6rem, 1.2vw, 1.8rem);
}
.primary-nav .menu-item > a {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    font-family: var(--f-ui);
    font-size: 0.82rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-90);
    padding: var(--s-2);
    line-height: 1;
    transition: color var(--dur-2) var(--ease-out);
}
.primary-nav .menu-item > a::after {
    content: '';
    position: absolute;
    left: var(--s-2); right: var(--s-2);
    bottom: calc(var(--s-2) - 4px);
    height: 1px;
    background: var(--red);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--dur-2) var(--ease-out);
}
.primary-nav .menu-item > a:hover { color: var(--ink); }
.primary-nav .menu-item > a:hover::after { transform: scaleX(1); }
.primary-nav .caret { font-size: 0.8em; opacity: 0.7; }
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-parent > a { color: var(--ink); }
.primary-nav .current-menu-item > a::after,
.primary-nav .current-menu-parent > a::after { transform: scaleX(1); }

/* Submenu */
.primary-nav .sub-menu {
    position: absolute;
    top: 100%; left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 220px;
    background: var(--surface);
    border: 1px solid var(--ruler);
    border-top: 2px solid var(--red);
    padding: var(--s-3);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--dur-2), transform var(--dur-2), visibility var(--dur-2);
    box-shadow: var(--sh-3);
}
.primary-nav .menu-item.has-children { position: relative; }
.primary-nav .menu-item.has-children:hover .sub-menu,
.primary-nav .menu-item.has-children:focus-within .sub-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.primary-nav .sub-menu .menu-item > a {
    display: block;
    padding: var(--s-2) var(--s-3);
    font-size: 0.82rem;
    letter-spacing: 0.05em;
    color: var(--ink-70);
}
.primary-nav .sub-menu .menu-item > a::after { display: none; }
.primary-nav .sub-menu .menu-item > a:hover {
    color: var(--ink);
    background: var(--surface-2);
}

/* CTA button in nav */
.primary-nav .menu-item-cta .btn-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--s-2);
    padding: 0.65rem 1.1rem;
    background: var(--red);
    color: var(--ink);
    font-family: var(--f-ui);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border: 1px solid var(--red);
    border-radius: var(--radius);
    transition: background var(--dur-2), transform var(--dur-2), box-shadow var(--dur-2);
}
.primary-nav .menu-item-cta .btn-cta:hover {
    background: var(--red-hot);
    transform: translateY(-1px);
    box-shadow: 0 10px 30px -10px var(--red);
}
.primary-nav .menu-item-cta .btn-icon {
    width: 14px; height: 14px;
    display: inline-flex;
    align-items: center;
    transition: transform var(--dur-2) var(--ease-out);
}
.primary-nav .menu-item-cta .btn-cta:hover .btn-icon {
    transform: translate(2px, -2px);
}

/* Mobile toggle */
.mobile-toggle {
    display: none;
    width: 44px; height: 44px;
    position: relative;
}
.mobile-toggle span {
    display: block;
    position: absolute;
    left: 10px; right: 10px;
    height: 1.5px;
    background: var(--ink);
    transition: transform var(--dur-2) var(--ease-out), opacity var(--dur-2);
}
.mobile-toggle span:nth-child(1) { top: 16px; }
.mobile-toggle span:nth-child(2) { top: 22px; }
.mobile-toggle span:nth-child(3) { top: 28px; }
.mobile-toggle.active span:nth-child(1) { top: 22px; transform: rotate(45deg); }
.mobile-toggle.active span:nth-child(2) { opacity: 0; }
.mobile-toggle.active span:nth-child(3) { top: 22px; transform: rotate(-45deg); }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero {
    position: relative;
    min-height: 100vh;
    min-height: 100svh;
    display: grid;
    grid-template-rows: 1fr auto;
    align-items: end;
    overflow: hidden;
    isolation: isolate;
    padding-top: 80px;
    color: var(--ink);
}
.hero-bg {
    position: absolute;
    inset: -6%;
    z-index: -3;
    background-size: cover;
    background-position: center 35%;
    animation: kenBurns 28s ease-in-out infinite alternate;
    will-change: transform;
}
@keyframes kenBurns {
    0%   { transform: scale(1.0)   translate(0, 0); }
    100% { transform: scale(1.12)  translate(-1%, -2%); }
}
.hero-veil {
    position: absolute; inset: 0;
    z-index: -2;
    background:
        radial-gradient(ellipse at 25% 18%, rgba(255,220,150,0.18) 0%, transparent 46%),
        radial-gradient(ellipse at 75% 80%, rgba(196,30,58,0.16) 0%, transparent 58%),
        linear-gradient(180deg, rgba(17,28,51,0.55) 0%, rgba(17,28,51,0.45) 40%, rgba(17,28,51,0.92) 100%);
}
.hero-grid {
    position: absolute; inset: 0;
    z-index: -1;
    background-image:
        linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: calc(100% / 12) 100%, 100% 8rem;
    opacity: 0.7;
    mask-image: linear-gradient(180deg, transparent 0%, black 40%, black 80%, transparent 100%);
}
.hero-body {
    position: relative;
    padding-inline: var(--gutter);
    padding-bottom: clamp(3rem, 4vw, 5rem);
    max-width: var(--content-max);
    margin-inline: auto;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s-5);
}
.hero-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--s-3);
    padding: 0.4rem 0.8rem;
    border: 1px solid var(--ruler-strong);
    background: rgba(255,255,255,0.04);
    backdrop-filter: blur(8px);
    color: var(--ink-90);
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    width: max-content;
    border-radius: var(--radius);
}
.hero-chip .star { color: var(--gold); width: 11px; height: 11px; }
.hero-chip .dot {
    width: 6px; height: 6px;
    background: var(--red);
    border-radius: 50%;
    box-shadow: 0 0 0 4px rgba(191,10,48,0.25);
    animation: pulse 2.2s ease-in-out infinite;
}
@keyframes pulse {
    0%,100% { opacity: 1; }
    50%     { opacity: 0.35; }
}
.hero-title {
    font-family: var(--f-display);
    font-size: var(--fs-hero);
    line-height: 0.82;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    display: grid;
    grid-template-columns: 1fr;
    color: var(--ink);
}
.hero-title .line-1 { display: block; }
.hero-title .line-2 {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    letter-spacing: -0.04em;
    text-transform: none;
    color: var(--cream);
    margin-top: -0.15em;
    padding-left: 0.4em;
}
.hero-title .line-2::before {
    content: '';
    display: inline-block;
    width: 0.8em; height: 1px;
    background: var(--red);
    vertical-align: 0.38em;
    margin-right: 0.3em;
}
.hero-mission {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-xl);
    line-height: 1.35;
    letter-spacing: -0.005em;
    color: var(--ink-90);
    max-width: 48ch;
}
.hero-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-3);
    margin-top: var(--s-3);
}
.hero-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin-top: var(--s-6);
    border-top: 1px solid var(--ruler-strong);
    padding-top: var(--s-5);
    max-width: 720px;
}
.hero-stat { padding-right: var(--s-5); border-right: 1px solid var(--ruler); }
.hero-stat:last-child { border-right: 0; }
.hero-stat-value {
    font-family: var(--f-display);
    font-size: clamp(2.4rem, 2rem + 2.5vw, 4rem);
    color: var(--ink);
    line-height: 0.95;
    display: inline-flex;
    align-items: baseline;
    gap: 0.05em;
}
.hero-stat-value .suffix { color: var(--red-bright); font-size: 0.7em; }
.hero-stat-label {
    font-family: var(--f-mono);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-55);
    margin-top: 0.4rem;
}
.hero-meta-ribbon {
    position: absolute;
    right: var(--gutter);
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
    transform-origin: right center;
    font-family: var(--f-mono);
    font-size: 0.66rem;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--ink-35);
    white-space: nowrap;
    pointer-events: none;
}
.scroll-indicator {
    position: absolute;
    bottom: 1.5rem; left: 50%;
    transform: translateX(-50%);
    font-family: var(--f-mono);
    font-size: 0.66rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--ink-55);
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-2);
}
.scroll-indicator::after {
    content: '';
    width: 1px;
    height: 40px;
    background: linear-gradient(to bottom, transparent, var(--ink-55));
    animation: scrollBar 2s ease-in-out infinite;
}
@keyframes scrollBar {
    0%,100% { transform: scaleY(1);   opacity: 0.5; }
    50%     { transform: scaleY(1.3); opacity: 1; }
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    padding: 0.95rem 1.5rem;
    font-family: var(--f-ui);
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 1px solid transparent;
    border-radius: var(--radius);
    cursor: pointer;
    transition: background var(--dur-2), color var(--dur-2), border-color var(--dur-2), transform var(--dur-2), box-shadow var(--dur-2);
    white-space: nowrap;
    text-decoration: none;
    line-height: 1;
}
.btn .btn-icon { display: inline-flex; transition: transform var(--dur-2) var(--ease-out); }
.btn-primary { background: var(--red); color: var(--ink); border-color: var(--red-bright); }
.btn-primary:hover { background: var(--red-hot); border-color: var(--red-hot); transform: translateY(-1px); box-shadow: 0 16px 36px -12px rgba(191,10,48,0.5); }
.btn-primary:hover .btn-icon { transform: translate(2px, -2px); }
.btn-outline { background: transparent; color: var(--ink); border-color: var(--ruler-strong); }
.btn-outline:hover { background: var(--ink); color: var(--on-light); border-color: var(--ink); }
.btn-outline:hover .btn-icon { transform: translateX(3px); }
.btn-ghost { background: transparent; color: var(--ink-70); padding-inline: 0.6rem; border: 0; }
.btn-ghost:hover { color: var(--ink); }
.btn-dark { background: var(--ink); color: var(--on-light); border-color: var(--ink); }
.btn-dark:hover { background: var(--red); color: var(--ink); border-color: var(--red-bright); }
.btn-gold { background: var(--gold); color: var(--on-light); border-color: var(--gold); }
.btn-gold:hover { background: var(--gold-deep); border-color: var(--gold-deep); color: var(--ink); }
.btn-lg { padding: 1.1rem 1.8rem; font-size: 0.88rem; }
.btn-sm { padding: 0.55rem 0.9rem; font-size: 0.72rem; }

/* ==========================================================================
   TICKER
   ========================================================================== */
.ticker {
    display: flex;
    overflow: hidden;
    border-top: 1px solid var(--ruler);
    border-bottom: 1px solid var(--ruler);
    background: var(--canvas-2);
    padding-block: 1.1rem;
    position: relative;
}
.ticker-track {
    display: flex;
    gap: 3rem;
    animation: marquee 32s linear infinite;
    white-space: nowrap;
    font-family: var(--f-display);
    font-size: clamp(1.2rem, 2vw, 2rem);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--ink-70);
    flex-shrink: 0;
}
.ticker-track > span { display: inline-flex; align-items: center; gap: 1rem; }
.ticker-track .dot {
    display: inline-block;
    width: 8px; height: 8px;
    background: var(--red);
    border-radius: 50%;
    flex-shrink: 0;
}
.ticker-track .emph {
    color: var(--gold);
    font-family: var(--f-editorial);
    font-style: italic;
    text-transform: none;
    letter-spacing: -0.02em;
}
@keyframes marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ==========================================================================
   VALUES SECTION
   ========================================================================== */
.values { background: var(--canvas); position: relative; overflow: hidden; }
.values-head {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s-4);
    margin-bottom: var(--s-8);
}
.values-kicker { display: flex; align-items: baseline; gap: var(--s-5); }
.values-title { font-size: var(--fs-4xl); color: var(--ink); }
.values-title em { color: var(--cream); }
.values-lede {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-xl);
    color: var(--ink-70);
    max-width: 56ch;
}
.values-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0;
    border-top: 1px solid var(--ruler);
}
.value {
    padding: var(--s-6) var(--s-5);
    border-right: 1px solid var(--ruler);
    border-bottom: 1px solid var(--ruler);
    display: grid;
    grid-template-rows: auto 1fr;
    gap: var(--s-4);
    transition: background var(--dur-2) var(--ease-out);
}
.value:hover { background: rgba(255,255,255,0.02); }
.value-glyph {
    font-family: var(--f-mono);
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    color: var(--red-bright);
}
.value-title {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: clamp(2rem, 2.4vw + 0.4rem, 3rem);
    line-height: 0.92;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    color: var(--ink);
}
.value-body {
    font-size: var(--fs-base);
    color: var(--ink-70);
    line-height: 1.55;
    max-width: 32ch;
}

/* ==========================================================================
   CSIT BAND
   ========================================================================== */
.csit-band {
    background: var(--canvas);
    position: relative;
    overflow: hidden;
    padding-block: var(--section-y);
    isolation: isolate;
}
.csit-band::before {
    content: '';
    position: absolute; inset: 0; z-index: -1;
    background:
        radial-gradient(ellipse at 80% 20%, rgba(63,92,158,0.28) 0, transparent 50%),
        radial-gradient(ellipse at 20% 80%, rgba(196,30,58,0.18) 0, transparent 55%);
}
.csit-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.35fr);
    gap: var(--s-8);
    align-items: center;
}
.csit-text { display: grid; gap: var(--s-5); }
.csit-title { font-size: var(--fs-4xl); color: var(--ink); line-height: 0.92; }
.csit-title em { color: var(--gold); }
.csit-quote {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-xl);
    color: var(--ink-90);
    line-height: 1.35;
    max-width: 48ch;
    padding-left: var(--s-4);
    border-left: 2px solid var(--red);
}
.csit-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-4) var(--s-8);
    padding-top: var(--s-4);
    border-top: 1px solid var(--ruler);
}
.csit-meta dt {
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--ink-55);
    margin-bottom: 0.25rem;
}
.csit-meta dd { font-family: var(--f-display); font-size: 1.2rem; color: var(--ink); }
.csit-globe {
    aspect-ratio: 2 / 1;
    max-width: 720px;
    width: 100%;
    justify-self: end;
    position: relative;
}
.csit-globe svg { width: 100%; height: 100%; display: block; }
.csit-globe::after {
    content: '';
    position: absolute; inset: -8%;
    background: radial-gradient(ellipse, rgba(63,92,158,0.25) 0%, transparent 62%);
    z-index: -1;
    pointer-events: none;
}

/* ==========================================================================
   LEADERSHIP WALL
   ========================================================================== */
.leadership { background: var(--canvas-2); position: relative; }
.leadership-head {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: end;
    gap: var(--s-5);
    margin-bottom: var(--s-8);
    padding-bottom: var(--s-6);
    border-bottom: 1px solid var(--ruler);
}
.leadership-title { font-size: var(--fs-4xl); color: var(--ink); }
.leadership-title em { color: var(--cream); }
.leadership-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0;
    border-top: 1px solid var(--ruler);
    border-left: 1px solid var(--ruler);
}
.leader-card {
    border-right: 1px solid var(--ruler);
    border-bottom: 1px solid var(--ruler);
    display: grid;
    grid-template-rows: auto 1fr;
    transition: background var(--dur-2) var(--ease-out);
}
.leader-card:hover { background: rgba(255,255,255,0.02); }
.leader-img {
    aspect-ratio: 2 / 3;
    overflow: hidden;
    position: relative;
    background: var(--surface);
}
.leader-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: contrast(1.04) saturate(1.05);
    transition: transform 1.2s var(--ease-out), filter var(--dur-3);
}
.leader-card:hover .leader-img img {
    filter: contrast(1.08) saturate(1.1) brightness(1.04);
    transform: scale(1.03);
}
.leader-img::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(11,11,13,0.9) 100%);
    pointer-events: none;
}
.leader-meta {
    padding: var(--s-4) var(--s-5);
    display: grid;
    gap: var(--s-1);
}
.leader-name {
    font-family: var(--f-ui);
    font-weight: 600;
    font-size: var(--fs-lg);
    color: var(--ink);
    letter-spacing: -0.005em;
    line-height: 1.1;
}
.leader-title {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    color: var(--ink-55);
    text-transform: uppercase;
}

/* ==========================================================================
   TEAM PAGE — varied section layouts (owners big, admin compact row, coaching grid)
   ========================================================================== */

/* Ownership — featured large pair */
.team-ownership {
    background: var(--canvas);
    border-bottom: 1px solid var(--ruler);
}
.team-owner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border: 1px solid var(--ruler);
}
.team-owner-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    background: var(--surface);
    border-right: 1px solid var(--ruler);
}
.team-owner-card:last-child { border-right: 0; }
.team-owner-img {
    aspect-ratio: 2/3;
    overflow: hidden;
    background: var(--canvas-2);
    position: relative;
}
.team-owner-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: contrast(1.04) saturate(1.05);
    transition: transform 1.2s var(--ease-out), filter var(--dur-3);
}
.team-owner-card:hover .team-owner-img img {
    transform: scale(1.02);
    filter: contrast(1.07) saturate(1.1) brightness(1.04);
}
.team-owner-meta {
    padding: var(--s-6) var(--s-5);
    display: grid;
    gap: var(--s-2);
    align-content: center;
}
.team-owner-name {
    font-family: var(--f-display);
    font-size: var(--fs-3xl);
    text-transform: uppercase;
    letter-spacing: 0.01em;
    color: var(--ink);
    line-height: 0.95;
}
.team-owner-title {
    font-family: var(--f-ui);
    font-weight: 500;
    font-size: var(--fs-base);
    color: var(--ink-70);
    max-width: 34ch;
}
.team-owner-home {
    color: var(--ink-55);
}

/* Admin — compact roster list */
.team-admin-section { background: var(--canvas-2); border-bottom: 1px solid var(--ruler); }
.team-admin-list {
    list-style: none;
    display: grid;
    gap: 0;
    border-top: 1px solid var(--ruler);
    padding: 0;
    margin: 0;
}
.team-admin-row {
    display: grid;
    grid-template-columns: 60px 72px 1fr auto;
    gap: var(--s-5);
    align-items: center;
    padding: var(--s-4) 0;
    border-bottom: 1px solid var(--ruler);
    transition: background var(--dur-2);
}
.team-admin-row:hover { background: rgba(255,255,255,0.02); }
.team-admin-num {
    font-family: var(--f-mono);
    font-size: 0.78rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--red-bright);
}
.team-admin-thumb {
    width: 72px; height: 72px;
    overflow: hidden;
    border-radius: 50%;
    border: 1px solid var(--ruler);
    display: block;
    background: var(--surface);
}
.team-admin-thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: grayscale(10%) contrast(1.04);
}
.team-admin-info { display: grid; gap: 2px; min-width: 0; }
.team-admin-name {
    font-family: var(--f-display);
    font-size: var(--fs-xl);
    text-transform: uppercase;
    letter-spacing: 0.01em;
    color: var(--ink);
    line-height: 1.05;
}
.team-admin-title {
    font-family: var(--f-ui);
    font-weight: 500;
    font-size: var(--fs-sm);
    color: var(--ink-70);
}
.team-admin-home {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-55);
    text-align: right;
}

@media (max-width: 960px) {
    .team-owner-grid { grid-template-columns: 1fr; }
    .team-owner-card { border-right: 0; border-bottom: 1px solid var(--ruler); }
    .team-owner-card:last-child { border-bottom: 0; }
    .team-owner-card { grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr); }
}
@media (max-width: 640px) {
    .team-owner-card { grid-template-columns: 1fr; }
    .team-owner-img { aspect-ratio: 3/2; }
    .team-owner-meta { padding: var(--s-5); }
    .team-admin-row { grid-template-columns: 48px 60px 1fr; row-gap: var(--s-1); }
    .team-admin-home { display: none; }
}

/* ==========================================================================
   ROADMAP
   ========================================================================== */
.roadmap { background: var(--canvas); position: relative; }
.roadmap-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--s-5);
    align-items: end;
    margin-bottom: var(--s-8);
}
.roadmap-list {
    display: grid; gap: 0;
    border-top: 1px solid var(--ruler);
}
.road-item {
    display: grid;
    grid-template-columns: minmax(200px, 240px) minmax(180px, 1fr) 3fr;
    gap: var(--s-6);
    padding: var(--s-6) 0;
    border-bottom: 1px solid var(--ruler);
    align-items: start;
    position: relative;
    transition: background var(--dur-2);
}
.road-item:hover { background: rgba(255,255,255,0.015); }
.road-marker {
    display: flex;
    align-items: center;
    gap: var(--s-3);
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-55);
}
.road-marker .dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--ink-35);
    flex-shrink: 0;
}
.road-item[data-state="active"]   .road-marker .dot { background: var(--red); box-shadow: 0 0 0 5px rgba(196,30,58,0.22); animation: pulse 2s infinite; }
.road-item[data-state="target"]   .road-marker .dot { background: var(--red-bright); box-shadow: 0 0 0 5px rgba(255,66,89,0.22); }
.road-item[data-state="flagship"] .road-marker .dot { background: var(--gold); box-shadow: 0 0 0 5px rgba(212,181,106,0.28); animation: pulse 2.6s infinite; }
.road-item[data-state="active"]   .road-marker { color: var(--ink); }
.road-item[data-state="target"]   .road-marker { color: var(--red-bright); }
.road-item[data-state="flagship"] .road-marker { color: var(--gold); }
.road-date {
    font-family: var(--f-mono);
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-70);
}
.road-body { display: grid; gap: var(--s-2); }
.road-title {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: var(--fs-2xl);
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: 0.01em;
    line-height: 1.02;
}
.road-item[data-state="target"]   .road-title { color: var(--red-bright); }
.road-item[data-state="flagship"] .road-title { color: var(--gold); }
.road-copy { color: var(--ink-70); max-width: 60ch; }

/* Countdown display */
.countdown {
    display: grid;
    grid-template-columns: repeat(4, auto);
    gap: var(--s-5);
    margin-top: var(--s-6);
    padding-top: var(--s-5);
    border-top: 1px solid var(--ruler);
}
.countdown-unit {
    display: grid; gap: var(--s-2);
    font-feature-settings: 'tnum';
}
.countdown-value {
    font-family: var(--f-display);
    font-size: clamp(2.6rem, 4vw, 4.5rem);
    color: var(--ink);
    line-height: 0.9;
    letter-spacing: -0.01em;
}
.countdown-label {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-55);
}

/* ==========================================================================
   NEWS GRID
   ========================================================================== */
.news { background: var(--canvas); position: relative; }
.news-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--s-5);
    margin-bottom: var(--s-7);
    padding-bottom: var(--s-5);
    border-bottom: 1px solid var(--ruler);
}
.news-title { font-size: var(--fs-3xl); color: var(--ink); }
.news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--s-6);
}
.news-card {
    display: grid;
    gap: var(--s-4);
    text-decoration: none;
    color: inherit;
    transition: transform var(--dur-2) var(--ease-out);
}
.news-card:hover { transform: translateY(-3px); }
.news-img {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--surface);
}
.news-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform var(--dur-5) var(--ease-out);
}
.news-card:hover .news-img img { transform: scale(1.05); }
.news-date {
    font-family: var(--f-mono);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-55);
}
.news-heading {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: var(--fs-xl);
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: 0.01em;
    line-height: 1.1;
}
.news-card:hover .news-heading { color: var(--red-hot); }
.news-excerpt { color: var(--ink-70); font-size: var(--fs-base); }
.news-empty,
.ar-empty {
    display: grid;
    gap: var(--s-4);
    padding: var(--s-8) var(--s-5);
    border: 1px dashed var(--ruler-strong);
    background: var(--canvas-2);
    text-align: center;
    justify-items: center;
    max-width: 760px;
    margin: 0 auto;
}
.news-empty .eyebrow,
.ar-empty .eyebrow { justify-content: center; }
.news-empty p,
.ar-empty p { margin-inline: auto; }
.ar-empty-title {
    font-family: var(--f-display);
    font-size: var(--fs-3xl);
    text-transform: uppercase;
    color: var(--ink);
    line-height: 0.95;
    letter-spacing: 0.01em;
}
.ar-empty-title em { color: var(--cream); }
.ar-empty-body {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-lg);
    color: var(--ink-70);
    max-width: 56ch;
    line-height: 1.45;
}
.ar-empty-ctas {
    display: flex;
    gap: var(--s-3);
    justify-content: center;
    flex-wrap: wrap;
    padding-top: var(--s-2);
}

/* ==========================================================================
   CTA BAND
   ========================================================================== */
.cta-band { background: var(--canvas); position: relative; overflow: hidden; isolation: isolate; }
.cta-band::before {
    content: '';
    position: absolute; inset: -20%; z-index: -2;
    background:
        radial-gradient(ellipse at 50% 50%, rgba(196,30,58,0.2) 0%, transparent 55%),
        linear-gradient(180deg, var(--canvas) 0%, var(--canvas-2) 100%);
}
.cta-band::after {
    content: '';
    position: absolute; inset: 0; z-index: -1;
    background-image: linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: calc(100% / 12) 100%;
    mask-image: radial-gradient(ellipse at center, black 0%, transparent 80%);
}
.cta-inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s-5);
    text-align: center;
    justify-items: center;
}
.cta-title {
    font-size: var(--fs-5xl);
    color: var(--ink);
    line-height: 0.92;
    max-width: 12ch;
}
.cta-title em { color: var(--cream); }
.cta-body {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-xl);
    color: var(--ink-70);
    max-width: 48ch;
    line-height: 1.35;
}
.cta-buttons {
    display: flex; gap: var(--s-3);
    flex-wrap: wrap;
    justify-content: center;
}

/* ==========================================================================
   PAGE HERO
   ========================================================================== */
.page-hero {
    padding: calc(80px + var(--s-9)) var(--gutter) var(--s-8);
    max-width: var(--content-max);
    margin-inline: auto;
    position: relative;
}
.page-hero-inner { display: grid; gap: var(--s-5); max-width: 960px; }
.page-hero-kicker {
    font-family: var(--f-mono);
    font-size: 0.72rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--red-bright);
}
.page-hero-title {
    font-family: var(--f-display);
    font-size: var(--fs-5xl);
    line-height: 0.92;
    text-transform: uppercase;
    color: var(--ink);
}
.page-hero-title em {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    text-transform: none;
    color: var(--cream);
    letter-spacing: -0.02em;
}
.page-hero-lede {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-xl);
    color: var(--ink-70);
    max-width: 58ch;
    line-height: 1.4;
}
.page-hero .flag-strip { margin-top: var(--s-2); }
.page-hero + * { border-top: 1px solid var(--ruler); }

/* ==========================================================================
   ACCORDION
   ========================================================================== */
.accordion { display: grid; gap: 0; border-top: 1px solid var(--ruler); }
.accordion-item {
    border-bottom: 1px solid var(--ruler);
    padding: var(--s-5) 0;
    transition: background var(--dur-2) var(--ease-out);
}
.accordion-q {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--s-5);
    width: 100%;
    text-align: left;
    padding: 0;
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 400;
    font-size: var(--fs-xl);
    color: var(--ink);
    line-height: 1.2;
    cursor: pointer;
}
.accordion-q:hover { color: var(--red-hot); }
.accordion-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border: 1px solid var(--ruler-strong);
    flex-shrink: 0;
    transition: background var(--dur-2), transform var(--dur-3) var(--ease-out), border-color var(--dur-2);
}
.accordion-item[open] .accordion-toggle {
    background: var(--red);
    border-color: var(--red-bright);
    transform: rotate(45deg);
}
.accordion-a { padding-top: var(--s-4); color: var(--ink-70); max-width: 72ch; }

/* ==========================================================================
   FORM
   ========================================================================== */
.input, .textarea, .select {
    width: 100%;
    background: var(--surface);
    color: var(--ink);
    border: 1px solid var(--ruler-strong);
    padding: 0.85rem 1rem;
    font-family: var(--f-ui);
    font-size: var(--fs-base);
    border-radius: var(--radius);
    transition: border-color var(--dur-2);
}
.input:focus, .textarea:focus, .select:focus { outline: none; border-color: var(--red-bright); }
.input::placeholder, .textarea::placeholder { color: var(--ink-35); }
.textarea { min-height: 140px; resize: vertical; }
.field-label {
    display: block;
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-55);
    margin-bottom: var(--s-2);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer {
    background: var(--canvas);
    color: var(--ink);
    padding-top: var(--s-8);
    margin-top: var(--s-9);
    position: relative;
    border-top: 1px solid var(--ruler);
}
.footer-cta {
    border-top: 1px solid var(--ruler);
    border-bottom: 1px solid var(--ruler);
    background: var(--canvas-2);
    padding-block: var(--s-7);
}
.footer-cta .container { display: grid; gap: var(--s-4); }
.footer-cta-title {
    font-family: var(--f-display);
    font-size: var(--fs-3xl);
    color: var(--ink);
    text-transform: uppercase;
    line-height: 1;
}
.footer-cta-body {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-lg);
    color: var(--ink-70);
    max-width: 56ch;
}
.newsletter-form {
    display: flex;
    gap: var(--s-2);
    max-width: 480px;
    border: 1px solid var(--ruler-strong);
    background: var(--surface);
    border-radius: var(--radius);
    padding: 0.35rem 0.35rem 0.35rem 1rem;
    transition: border-color var(--dur-2);
}
.newsletter-form:focus-within { border-color: var(--red-bright); }
.newsletter-form input {
    flex: 1;
    background: transparent;
    border: 0;
    color: var(--ink);
    font-family: var(--f-ui);
    outline: none;
}
.newsletter-form input::placeholder { color: var(--ink-35); }
.newsletter-form button {
    background: var(--red);
    color: var(--ink);
    padding: 0.75rem 1.1rem;
    font-family: var(--f-ui);
    font-weight: 600;
    font-size: 0.8rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-radius: var(--radius);
    transition: background var(--dur-2);
}
.newsletter-form button:hover { background: var(--red-hot); }
.footer-main { padding-block: var(--s-7); border-bottom: 1px solid var(--ruler); }
.footer-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) repeat(3, minmax(0, 1fr));
    gap: var(--s-6);
}
.footer-col h3 {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    font-weight: 600;
    color: var(--ink-55);
    margin-bottom: var(--s-4);
    text-transform: uppercase;
}
.footer-col ul { display: grid; gap: var(--s-3); }
.footer-col li a {
    color: var(--ink-70);
    font-family: var(--f-ui);
    font-size: 0.92rem;
    transition: color var(--dur-2);
}
.footer-col li a:hover { color: var(--ink); }
.footer-brand { display: grid; gap: var(--s-4); }
.footer-logo { display: flex; align-items: center; gap: var(--s-3); }
.footer-logo img { height: 44px; }
.footer-mission {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    color: var(--ink-70);
    font-size: var(--fs-base);
    max-width: 42ch;
    line-height: 1.5;
}
.social-links { display: flex; gap: var(--s-3); }
.social-links a {
    width: 44px; height: 44px;
    border: 1px solid var(--ruler-strong);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-70);
    transition: background var(--dur-2), color var(--dur-2), border-color var(--dur-2);
}
.social-links a:hover { background: var(--ink); color: var(--on-light); border-color: var(--ink); }
.social-links svg { width: 18px; height: 18px; }
.footer-bottom {
    padding-block: var(--s-5);
}
.footer-bottom-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--s-4);
    align-items: center;
}
@media (max-width: 640px) {
    .footer-bottom-row { grid-template-columns: 1fr; }
}
.footer-bottom p {
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-60);
    max-width: none;
}
.footer-bottom a { color: var(--ink-70); }
.footer-bottom a:hover { color: var(--ink); }
.footer-tag {
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-60);
}
.footer-tag em {
    color: var(--cream);
    font-family: var(--f-editorial);
    font-style: italic;
    text-transform: none;
    letter-spacing: -0.01em;
}

/* ==========================================================================
   INTERIOR PAGES
   ========================================================================== */

/* About */
.about-lede {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    gap: var(--s-8);
    align-items: start;
}
.about-lede h2 {
    font-size: var(--fs-3xl);
    color: var(--ink);
    position: sticky;
    top: calc(80px + var(--s-5));
}
.about-lede h2 em { color: var(--cream); }
.about-lede-body {
    display: grid;
    gap: var(--s-5);
    font-size: var(--fs-lg);
    line-height: 1.6;
    color: var(--ink-90);
}
.about-lede-body p:first-of-type::first-letter {
    font-family: var(--f-editorial);
    font-weight: 400;
    font-size: 5rem;
    line-height: 0.9;
    float: left;
    margin: 0.1em 0.2em 0 0;
    color: var(--red-bright);
}

/* Donate */
.donate-breakdown {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0;
    border: 1px solid var(--ruler);
}
.donate-tile {
    padding: var(--s-6) var(--s-5);
    border-right: 1px solid var(--ruler);
    display: grid;
    gap: var(--s-3);
}
.donate-tile:last-child { border-right: 0; }
.donate-tile-num {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    color: var(--gold);
    text-transform: uppercase;
}
.donate-tile-title {
    font-family: var(--f-display);
    font-size: var(--fs-xl);
    text-transform: uppercase;
    color: var(--ink);
    letter-spacing: 0.02em;
}
.donate-tile-body {
    color: var(--ink-70);
    font-size: var(--fs-sm);
    line-height: 1.55;
    max-width: 32ch;
}
.donate-close {
    display: grid;
    gap: var(--s-5);
    padding-block: var(--s-7);
    max-width: 760px;
}
.donate-close blockquote {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 400;
    font-size: var(--fs-3xl);
    color: var(--ink);
    line-height: 1.2;
    letter-spacing: -0.015em;
    border-left: 2px solid var(--red);
    padding-left: var(--s-5);
}
.donate-close blockquote em { color: var(--gold); font-style: italic; }
.donate-amounts {
    display: flex;
    gap: var(--s-2);
    flex-wrap: wrap;
    padding-top: var(--s-5);
}
.donate-amount {
    display: inline-grid;
    grid-template-rows: auto auto;
    padding: 0.85rem 1.1rem;
    border: 1px solid var(--ruler-strong);
    transition: background var(--dur-2), border-color var(--dur-2);
    min-width: 100px;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}
.donate-amount:hover { background: var(--surface); border-color: var(--red-bright); }
.donate-amount strong {
    font-family: var(--f-display);
    font-size: 1.5rem;
    color: var(--ink);
    letter-spacing: 0.02em;
}
.donate-amount span {
    font-family: var(--f-mono);
    font-size: 0.66rem;
    letter-spacing: 0.15em;
    color: var(--ink-55);
    text-transform: uppercase;
}

/* Sponsor pitch */
.sponsor-pitch {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.5fr);
    gap: var(--s-8);
    align-items: start;
}
.sponsor-pitch h2 {
    font-size: var(--fs-4xl);
    color: var(--ink);
    line-height: 0.92;
}
.sponsor-pitch h2 em { color: var(--gold); }
.sponsor-list {
    display: grid;
    gap: var(--s-3);
    border-top: 1px solid var(--ruler);
}
.sponsor-benefit {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--s-4);
    padding: var(--s-4) 0;
    border-bottom: 1px solid var(--ruler);
}
.sponsor-benefit-icon {
    width: 44px; height: 44px;
    border: 1px solid var(--ruler-strong);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--red-bright);
}
.sponsor-benefit-icon svg { width: 22px; height: 22px; }
.sponsor-benefit h3 {
    font-family: var(--f-display);
    font-size: 1.15rem;
    text-transform: uppercase;
    color: var(--ink);
    margin-bottom: 0.25rem;
}
.sponsor-benefit p {
    color: var(--ink-70);
    font-size: var(--fs-sm);
    max-width: 60ch;
}
.sponsor-pkg-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--s-4);
    margin-top: var(--s-7);
}
.sponsor-pkg {
    border: 1px solid var(--ruler);
    padding: var(--s-5);
    display: grid;
    gap: var(--s-3);
    transition: transform var(--dur-2), border-color var(--dur-2);
}
.sponsor-pkg:hover { border-color: var(--red-bright); transform: translateY(-2px); }
.sponsor-pkg .tier {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    color: var(--gold);
    text-transform: uppercase;
}
.sponsor-pkg h3 {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: var(--fs-xl);
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: 0.01em;
}

/* ==========================================================================
   UNIFORMS — editorial sections (no cropping, tiles fit native aspect)
   ========================================================================== */

/* Shared section head */
.kit-head {
    display: grid;
    gap: var(--s-3);
    max-width: 780px;
    margin-bottom: var(--s-7);
}
.kit-head h2 {
    font-family: var(--f-display);
    font-size: var(--fs-4xl);
    line-height: 0.92;
    color: var(--ink);
}
.kit-head h2 em { color: var(--cream); }
.kit-head p {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-lg);
    color: var(--ink-70);
    max-width: 54ch;
    line-height: 1.45;
}

/* Shared tile */
.kit-item {
    display: grid;
    grid-template-rows: auto auto;
    gap: 0;
}
.kit-frame {
    display: block;
    background: var(--surface);
    border: 1px solid var(--ruler);
    padding: var(--s-3);
    overflow: hidden;
    cursor: zoom-in;
    filter: grayscale(6%) contrast(1.03);
    transition: filter var(--dur-3), border-color var(--dur-3);
    position: relative;
}
.kit-frame:hover {
    filter: grayscale(0%) contrast(1.07) brightness(1.04);
    border-color: var(--ruler-strong);
}
.kit-frame img {
    width: 100%;
    height: auto;
    display: block;
}
.kit-meta {
    display: grid;
    gap: 0.25rem;
    padding: var(--s-4) 0 var(--s-2);
}
.kit-num {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--red-bright);
}
.kit-meta h3 {
    font-family: var(--f-display);
    font-size: var(--fs-xl);
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--ink);
    line-height: 1.05;
}
.kit-meta p {
    color: var(--ink-60);
    font-size: var(--fs-sm);
    line-height: 1.45;
    max-width: 44ch;
}

/* Section grid containers — align tiles at top so mixed aspects work cleanly */
.kit-pair,
.kit-strip,
.kit-sideline,
.kit-accessories {
    display: grid;
    gap: var(--s-6);
    align-items: start;
}
.kit-pair        { grid-template-columns: 1fr 1fr; }
.kit-strip       { grid-template-columns: repeat(3, 1fr); }
.kit-sideline    { grid-template-columns: 1fr 1fr; }
.kit-accessories { grid-template-columns: repeat(3, 1fr); }

/* Practice — force square frames so 03/04/05 captions line up on one row */
.kit-strip .kit-frame { aspect-ratio: 1 / 1; }
.kit-strip .kit-frame img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* Game-day feature section (no longer has a hero — just the pair) */
.kit-feature {
    position: relative;
    padding-block: var(--section-y);
    background: var(--canvas);
    isolation: isolate;
}
.kit-feature::before {
    content: '';
    position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(180deg, var(--canvas) 0%, var(--canvas-2) 100%);
}

/* Shop-page coming-soon placeholder tiles (used when no product photo yet) */
.shop-placeholder {
    aspect-ratio: 3 / 4;
    background:
        radial-gradient(ellipse at 30% 25%, rgba(255,255,255,0.05), transparent 55%),
        linear-gradient(170deg, var(--surface) 0%, var(--canvas-2) 100%);
    position: relative;
    display: grid;
    place-items: center;
    padding: 0;
}
.shop-placeholder::before {
    content: 'Coming Soon';
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-55);
}
.shop-placeholder::after {
    content: '';
    position: absolute;
    inset: 12% 12% auto 12%;
    height: 2px;
    background: var(--gold);
    opacity: 0.35;
    border-radius: 1px;
}

@media (max-width: 960px) {
    .kit-strip,
    .kit-accessories { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .kit-pair,
    .kit-strip,
    .kit-sideline,
    .kit-accessories { grid-template-columns: 1fr; }
}

/* Registration */
.register-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: var(--s-8);
    align-items: start;
}
.eligibility { display: grid; gap: var(--s-4); }
.eligibility h3 {
    font-family: var(--f-display);
    font-size: var(--fs-xl);
    text-transform: uppercase;
    color: var(--ink);
    letter-spacing: 0.02em;
}
.eligibility ul { display: grid; gap: var(--s-3); }
.eligibility li {
    display: grid;
    grid-template-columns: 22px 1fr;
    gap: var(--s-3);
    color: var(--ink-90);
    font-size: var(--fs-base);
    line-height: 1.5;
}
.eligibility li svg { color: var(--red-bright); width: 22px; height: 22px; margin-top: 2px; }

.steps {
    display: grid;
    gap: var(--s-5);
    counter-reset: step;
}
.step {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--s-5);
    padding: var(--s-5);
    background: var(--surface);
    border: 1px solid var(--ruler);
    position: relative;
    counter-increment: step;
}
.step::before {
    content: 'Step ' counter(step, decimal-leading-zero);
    position: absolute;
    top: var(--s-4); right: var(--s-5);
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    color: var(--ink-35);
    text-transform: uppercase;
}
.step-num {
    font-family: var(--f-display);
    font-size: clamp(3rem, 5vw, 5.5rem);
    color: var(--red-bright);
    line-height: 0.85;
    align-self: start;
}
.step-num::before {
    content: counter(step, decimal-leading-zero);
}
.step-body h3 {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: var(--fs-2xl);
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: 0.01em;
    margin-bottom: var(--s-2);
}
.step-body p {
    color: var(--ink-70);
    max-width: 60ch;
}

/* FAQ list */
.faq { display: grid; gap: 0; }

/* Contact */
.contact-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--s-8);
    align-items: start;
}
.contact-card {
    padding: var(--s-6);
    background: var(--surface);
    border: 1px solid var(--ruler);
    display: grid;
    gap: var(--s-4);
}
.contact-card h3 {
    font-family: var(--f-display);
    font-size: var(--fs-2xl);
    text-transform: uppercase;
    color: var(--ink);
    letter-spacing: 0.02em;
}
.contact-link {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--s-4);
    align-items: center;
    padding: var(--s-4) 0;
    border-bottom: 1px solid var(--ruler);
    color: inherit;
    text-decoration: none;
}
.contact-link:last-child { border-bottom: 0; }
.contact-link .icon {
    width: 48px; height: 48px;
    border: 1px solid var(--ruler-strong);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--red-bright);
}
.contact-link .icon svg { width: 22px; height: 22px; }
.contact-link-label {
    font-family: var(--f-mono);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    color: var(--ink-55);
    text-transform: uppercase;
    margin-bottom: 2px;
}
.contact-link-value {
    font-family: var(--f-ui);
    font-size: var(--fs-lg);
    color: var(--ink);
    font-weight: 500;
    transition: color var(--dur-2);
}
.contact-link:hover .contact-link-value { color: var(--red-hot); }
.subject-pills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-2);
    margin-top: var(--s-4);
}
.subject-pill {
    font-family: var(--f-mono);
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 0.85rem 1.1rem;
    border: 1px solid var(--ruler-strong);
    color: var(--ink-70);
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    transition: background var(--dur-2), color var(--dur-2), border-color var(--dur-2);
}
.subject-pill:hover, .subject-pill.active {
    background: var(--red);
    color: var(--ink);
    border-color: var(--red-bright);
}

/* ==========================================================================
   LIGHTBOX (image viewer)
   ========================================================================== */
.ar-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 0;
    border-top: 1px solid var(--ruler);
    border-left: 1px solid var(--ruler);
}
.ar-gallery-cell {
    aspect-ratio: 1;
    overflow: hidden;
    position: relative;
    background: var(--surface);
    border-right: 1px solid var(--ruler);
    border-bottom: 1px solid var(--ruler);
    cursor: zoom-in;
    display: block;
}
.ar-gallery-cell img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: grayscale(18%) contrast(1.05) brightness(0.96);
    transition: filter var(--dur-3) var(--ease-out),
                transform var(--dur-5) var(--ease-out);
}
.ar-gallery-cell:hover img,
.ar-gallery-cell:focus-visible img {
    filter: grayscale(0%) contrast(1.05) brightness(1);
    transform: scale(1.04);
}
.ar-gallery-cell::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(11,17,32,0.78) 100%);
    pointer-events: none;
    opacity: 0.6;
    transition: opacity var(--dur-2);
}
.ar-gallery-cell:hover::after { opacity: 0.9; }
.ar-gallery-caption {
    position: absolute;
    left: var(--s-4); bottom: var(--s-4);
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink);
    z-index: 2;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity var(--dur-2), transform var(--dur-2);
}
.ar-gallery-cell:hover .ar-gallery-caption,
.ar-gallery-cell:focus-visible .ar-gallery-caption {
    opacity: 1;
    transform: translateY(0);
}

/* Lightbox */
.ar-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(11,17,32,0.96);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.ar-lightbox.active { display: flex; }
.ar-lightbox-stage {
    position: relative;
    max-width: 92vw;
    max-height: 86vh;
    display: grid;
    place-items: center;
}
.ar-lightbox-img {
    max-width: 92vw;
    max-height: 82vh;
    width: auto; height: auto;
    object-fit: contain;
    box-shadow: 0 40px 80px -20px rgba(0,0,0,0.85);
    opacity: 0;
    transition: opacity var(--dur-2) var(--ease-out);
}
.ar-lightbox-img.is-ready { opacity: 1; }
.ar-lightbox-btn {
    position: absolute;
    width: 52px; height: 52px;
    border: 1px solid var(--ruler-strong);
    background: rgba(26,39,68,0.8);
    color: var(--ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-family: var(--f-display);
    font-size: 1.5rem;
    line-height: 1;
    transition: background var(--dur-2), border-color var(--dur-2), transform var(--dur-2);
    border-radius: 0;
    z-index: 2;
}
.ar-lightbox-btn:hover {
    background: var(--red);
    border-color: var(--red-bright);
    transform: scale(1.04);
}
.ar-lightbox-close { top: var(--s-4); right: var(--s-4); position: fixed; }
.ar-lightbox-prev  { left: var(--s-4);  top: 50%; transform: translateY(-50%); position: fixed; }
.ar-lightbox-next  { right: var(--s-4); top: 50%; transform: translateY(-50%); position: fixed; }
.ar-lightbox-prev:hover,
.ar-lightbox-next:hover { transform: translateY(-50%) scale(1.04); }
.ar-lightbox-meta {
    position: fixed;
    bottom: var(--s-4); left: 50%;
    transform: translateX(-50%);
    font-family: var(--f-mono);
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-70);
    background: rgba(26,39,68,0.7);
    padding: 0.5rem 1rem;
    border: 1px solid var(--ruler-strong);
}
body.ar-lightbox-open { overflow: hidden; }
@media (max-width: 640px) {
    .ar-lightbox-btn { width: 44px; height: 44px; }
}

/* ==========================================================================
   UTILITIES
   ========================================================================== */
.section-note {
    font-family: var(--f-editorial);
    font-style: italic;
    font-weight: 300;
    font-size: var(--fs-lg);
    color: var(--ink-70);
}
.divider { height: 1px; background: var(--ruler); border: 0; margin: 0; }

[data-reveal] {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 900ms var(--ease-out), transform 900ms var(--ease-out);
    transition-delay: var(--reveal-delay, 0ms);
}
[data-reveal].is-in { opacity: 1; transform: translateY(0); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 960px) {
    .primary-nav {
        position: fixed;
        top: 0; right: 0;
        width: min(88vw, 420px);
        height: 100dvh;
        background: var(--canvas);
        border-left: 1px solid var(--ruler);
        padding: calc(80px + var(--s-6)) var(--s-5) var(--s-6);
        flex-direction: column;
        justify-content: flex-start;
        transform: translateX(100%);
        transition: transform var(--dur-3) var(--ease-out);
        overflow-y: auto;
    }
    .primary-nav.active { transform: translateX(0); }
    .primary-nav .nav-list {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        width: 100%;
    }
    .primary-nav .menu-item { border-bottom: 1px solid var(--ruler); }
    .primary-nav .menu-item > a {
        padding: var(--s-4) 0;
        font-family: var(--f-editorial);
        font-style: italic;
        font-weight: 400;
        font-size: var(--fs-2xl);
        text-transform: none;
        letter-spacing: -0.01em;
        color: var(--ink);
    }
    .primary-nav .menu-item > a::after { display: none; }
    .primary-nav .sub-menu {
        position: static;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: none;
        background: transparent;
        border: 0; border-top: 0;
        padding: 0 0 var(--s-3) var(--s-5);
        box-shadow: none;
    }
    .primary-nav .sub-menu .menu-item { border: 0; }
    .primary-nav .sub-menu .menu-item > a {
        padding: var(--s-2) 0;
        font-size: 1rem;
        font-family: var(--f-ui);
        font-style: normal;
        text-transform: uppercase;
        color: var(--ink-70);
        letter-spacing: 0.08em;
    }
    .primary-nav .menu-item-cta .btn-cta {
        width: 100%;
        justify-content: center;
        margin-top: var(--s-5);
    }
    .mobile-toggle { display: inline-block; }
    body.nav-open { overflow: hidden; }

    .hero { padding-top: 64px; }
    .hero-stats { grid-template-columns: 1fr 1fr; }
    .hero-stat:nth-child(2) { border-right: 0; }
    .hero-stat:last-child {
        grid-column: 1 / -1;
        border-top: 1px solid var(--ruler);
        padding-top: var(--s-4);
        margin-top: var(--s-2);
        border-right: 0;
    }
    .hero-meta-ribbon { display: none; }

    .values-grid { grid-template-columns: 1fr 1fr; }

    .csit-inner, .sponsor-pitch, .about-lede, .register-grid, .contact-grid {
        grid-template-columns: 1fr;
        gap: var(--s-6);
    }
    .csit-globe { max-width: 360px; justify-self: center; }
    .leadership-grid { grid-template-columns: repeat(2, 1fr); }
    .road-item { grid-template-columns: 1fr; gap: var(--s-3); padding: var(--s-5) 0; }
    .road-marker { gap: var(--s-3); }
    .footer-grid { grid-template-columns: 1fr; gap: var(--s-6); }
    .footer-bottom { grid-template-columns: 1fr; text-align: left; }
    .about-lede h2 { position: static; }
}

@media (max-width: 560px) {
    .header-top-strip { display: none; }
    .values-grid { grid-template-columns: 1fr; }
    .leadership-grid { grid-template-columns: 1fr 1fr; }
    .logo-text strong { font-size: 12px; }
    .logo-text em { font-size: 13px; }
    .hero-stats { grid-template-columns: 1fr; }
    .hero-stat {
        border-right: 0;
        border-bottom: 1px solid var(--ruler);
        padding-block: var(--s-3);
    }
    .hero-stat:last-child { border-bottom: 0; }
    .uniform-grid { grid-template-columns: 1fr; }
    .uniform-tile {
        border-right: 0;
        border-bottom: 1px solid var(--ruler);
    }
    .uniform-tile:last-child { border-bottom: 0; }
    .donate-breakdown { grid-template-columns: 1fr; }
    .donate-tile {
        border-right: 0;
        border-bottom: 1px solid var(--ruler);
    }
    .donate-tile:last-child { border-bottom: 0; }
    .step { grid-template-columns: 1fr; }
    .step::before { position: static; display: block; margin-bottom: var(--s-2); }
    .step-num { font-size: 3.5rem; }
    .countdown { grid-template-columns: repeat(2, auto); }

    /* Narrow-phone title scale fixes (prevent overflow previously masked by body overflow-x) */
    .hero-title        { font-size: clamp(2.8rem, 12vw, 4rem); line-height: 0.88; }
    .page-hero-title   { font-size: clamp(2.6rem, 11vw, 3.4rem); }
    .cta-title         { font-size: clamp(2.2rem, 9vw, 2.8rem); max-width: none; }
    .cta-title em      { display: block; }
    .values-title      { font-size: clamp(2rem, 9vw, 2.6rem); }
    .leadership-title  { font-size: clamp(2rem, 9vw, 2.6rem); }
    .csit-title        { font-size: clamp(2rem, 9vw, 2.6rem); }
    .footer-cta-title  { font-size: clamp(1.8rem, 8vw, 2.4rem); }
}

@media (max-width: 440px) {
    .leadership-grid { grid-template-columns: 1fr; max-width: 320px; margin-inline: auto; }
}

/* ==========================================================================
   TOUCH-DEVICE FALLBACKS (hover doesn't exist)
   ========================================================================== */
@media (hover: none) {
    /* Gallery captions on tiles — reveal by default on touch */
    .ar-gallery-caption { opacity: 1; transform: translateY(0); }
    /* Kit frames should hit full-color treatment (no hover on touch) */
    .kit-frame { filter: grayscale(0%) contrast(1.06) brightness(1.02); }
}

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .hero-bg { animation: none; }
    [data-reveal] { opacity: 1; transform: none; }
}

/* ==========================================================================
   PRINT
   ========================================================================== */
@media print {
    .site-header, .site-footer, .cta-band, .hero-veil, .hero-bg, .mobile-toggle { display: none !important; }
    body { background: #fff; color: #000; }
    h1, h2, h3 { color: #000; }
    a { color: #000; text-decoration: underline; }
}
