/* ============================================================
   GameChanger — "The Power of Play"  (conversion-first concept)
   Direction: Editorial Documentary Calm (+ kinetic score-bar & gaming-native naming)
   Type:  Fraunces (display serif) · Hanken Grotesk (body/UI) · Space Mono (accent only)
   Color: 60 paper / 30 ink-navy / 10 accents — green = the Donate ask ONLY,
          terracotta = the corporate lane ONLY, amber = warm highlight.
   ============================================================ */
:root{
  --green:#00B073; --green-cta:#04a06b; --green-deep:#067a53; --green-ink:#063a28; --green-soft:#eafaf2;
  --terra:#d8603f; --terra-deep:#b94a2c; --terra-text:#9e3d1c; --amber:#f0a93b;
  --navy:#0e1b2a; --navy-2:#16273b; --navy-3:#1d3148; --ink:#1c1d22;
  --paper:#fbf8f3; --paper-2:#f3ece1; --line:#e7ddcd; --line-2:#d9cdb8;
  --muted:#6a6356; --muted-on-dark:#a7b7c5;
  --wrap:1180px; --r:14px; --r-lg:22px; --pill:50px;
  /* spacing scale (8px grid) */
  --s-1:8px; --s-2:16px; --s-3:24px; --s-4:32px; --s-5:48px; --s-6:64px; --s-7:96px; --s-8:128px;
  --shadow:0 2px 8px rgba(20,18,12,.06), 0 30px 64px -30px rgba(20,18,12,.34);
  --shadow-card:0 1px 2px rgba(20,18,12,.05), 0 18px 42px -24px rgba(20,18,12,.26);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
section[id],#give,[id]{scroll-margin-top:84px}
body{margin:0;font-family:"Hanken Grotesk",system-ui,sans-serif;color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.003em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-optical-sizing:auto;margin:0;letter-spacing:-.018em;line-height:1.04}
.display,h1{font-weight:500;font-variation-settings:"opsz" 88;line-height:1.03;letter-spacing:-.015em}
p{margin:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 24px}
.kicker{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--green-deep);font-weight:700}
.kicker.on-dark{color:#5fe0a8}
.kicker.terra{color:var(--terra-text)}  /* AA-safe small text on warm paper-2 */
.em{font-style:italic}
.hl{font-style:italic;color:var(--green-deep)}
.dark .hl,.on-dark .hl{color:#6ee6ad}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---- focus visibility (keyboard only; SC 2.4.7) ---- */
:focus:not(:focus-visible){outline:none}
:where(a,button,input,select,textarea,summary,[tabindex]):focus-visible{outline:3px solid var(--green-deep);outline-offset:2px;border-radius:6px}
.dark :focus-visible,.hero :focus-visible,.score :focus-visible,.closing :focus-visible,.give :focus-visible,.foot :focus-visible{outline-color:#6ee6ad}
.p-hero :focus-visible,.companies :focus-visible{outline-color:var(--amber)}

/* ---- duotone helper (applied to the consented photo library) ---- */
/* photos render fully natural — no tint/duotone (per user 2026-06-03) */
.duo{background:var(--navy-2)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:"Hanken Grotesk",sans-serif;font-weight:700;
  font-size:16px;line-height:1;border:0;border-radius:var(--pill);padding:16px 28px;cursor:pointer;
  transition:transform .14s cubic-bezier(.2,.8,.2,1),background .15s,box-shadow .15s,color .15s;white-space:nowrap}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-give{background:var(--green);color:#06281c;box-shadow:0 1px 0 rgba(255,255,255,.4) inset,0 12px 26px -12px rgba(0,176,115,.75)}
.btn-give:hover{background:#06bd7c;box-shadow:0 14px 32px -10px rgba(0,176,115,.9);transform:translateY(-2px)}
.btn-give.lg{font-size:17.5px;padding:18px 32px;width:100%}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-2)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--ink)}
.btn-ghost.on-dark{color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.4)}
.btn-ghost.on-dark:hover{box-shadow:inset 0 0 0 1.5px #fff}
/* corporate lane: terracotta, never green */
.btn-terra{background:var(--terra-deep);color:#fff;box-shadow:0 12px 26px -14px rgba(185,74,44,.8)}
.btn-terra:hover{background:#a23f23;transform:translateY(-2px)}
.btn-terra-outline{background:transparent;color:var(--terra-text);box-shadow:inset 0 0 0 1.6px var(--terra)}
.btn-terra-outline:hover{background:var(--terra);color:#fff}
.btn-terra-outline.on-dark{color:#f2b9a4;box-shadow:inset 0 0 0 1.6px var(--terra)}
.btn-terra-outline.on-dark:hover{background:var(--terra);color:#fff}

/* ---- header ---- */
.head{position:sticky;top:0;z-index:50;background:rgba(251,248,243,.82);backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line)}
.head-row{display:flex;align-items:center;gap:16px;height:68px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:30px;width:auto}
.brand .wink{height:18px;width:18px;image-rendering:pixelated;opacity:.85}
.nav{margin-left:auto;display:flex;align-items:center;gap:28px}
.nav a:not(.btn){font-family:"Hanken Grotesk";font-size:15px;font-weight:600;color:var(--ink);opacity:.78;transition:opacity .15s,color .15s}
.nav a:not(.btn):hover{opacity:1;color:var(--ink)}
.nav .btn{padding:10px 20px;font-size:14.5px}
.navtoggle{display:none;margin-left:auto;width:44px;height:44px;border:1px solid var(--line-2);border-radius:12px;
  background:#fff;font-size:18px;cursor:pointer;align-items:center;justify-content:center}
@media(max-width:900px){
  .nav{display:none;position:absolute;top:68px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:8px 24px 16px}
  .nav.open{display:flex}
  .nav a:not(.btn){padding:13px 0;border-bottom:1px solid var(--line)}
  .nav .btn{margin-top:12px}
  .navtoggle{display:inline-flex}
}

/* ---- generic section rhythm (varied padding = pacing) ---- */
.section{padding:var(--s-7) 0}
.section.gen{padding:var(--s-8) 0}     /* generous (story / founder) */
.section.tight{padding:var(--s-6) 0}   /* tight (score-bar / teaser) */
.dark{background:var(--navy);color:#fff}
.dark h1,.dark h2,.dark h3{color:#fff}
.muted-on-dark{color:var(--muted-on-dark)}
.sec-head{max-width:680px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(28px,3.5vw,44px);font-weight:560;margin-top:12px}
.sec-head p{margin-top:14px;color:var(--muted);font-size:17px;line-height:1.55}
.dark .sec-head p{color:var(--muted-on-dark)}

/* ---- hero ---- */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.18fr .92fr;min-height:min(88vh,800px);align-items:center}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 26%}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(96deg,rgba(8,15,24,.93) 40%,rgba(8,15,24,.7) 62%,rgba(8,15,24,.3) 82%,rgba(8,15,24,.05))}
.hero-copy{position:relative;z-index:2;padding:clamp(40px,5vw,76px) clamp(24px,3vw,40px) clamp(40px,5vw,76px) max(24px,calc((100vw - var(--wrap))/2 + 24px))}
.hero-copy .display{font-size:clamp(36px,5vw,64px);max-width:13ch}
.hero-copy .display .em{color:#6ee6ad}
.hero-copy .lede{margin-top:18px;font-size:clamp(16px,1.35vw,18.5px);color:#e6edf2;max-width:44ch;line-height:1.55}
.hero-statpair{margin-top:22px;display:flex;gap:30px}
.hero-statpair .s{font-family:"Space Mono",monospace}
.hero-statpair .s b{display:block;font-size:24px;font-weight:700;color:#6ee6ad;letter-spacing:-.03em}
.hero-statpair .s span{font-size:12px;letter-spacing:.04em;color:var(--muted-on-dark)}
.hero-film{margin-top:18px;display:inline-flex;align-items:center;gap:9px;font-size:14px;color:#cdd9e2;font-weight:600}
.hero-film:hover{color:#fff}
.hero-film .pl{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:9px;padding-left:2px}
.hero-widgetcol{position:relative;z-index:2;padding:clamp(28px,3vw,44px) max(24px,calc((100vw - var(--wrap))/2 + 24px)) clamp(28px,3vw,44px) clamp(16px,2vw,28px);display:flex;justify-content:flex-end}

/* ---- embedded donate widget (ink-navy card) ---- */
.give{position:relative;background:var(--navy-2);color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);
  box-shadow:var(--shadow);padding:22px;width:100%;max-width:430px;min-height:520px}
.give h2{font-family:"Hanken Grotesk",sans-serif;font-weight:800;font-size:18px;letter-spacing:-.01em;color:#fff}
.give .give-sub{font-size:13px;color:var(--muted-on-dark);margin-top:3px}
.seg{display:flex;background:rgba(255,255,255,.07);border-radius:var(--pill);padding:4px;margin-top:15px}
.seg button{flex:1;border:0;background:transparent;font-family:inherit;font-weight:700;font-size:13.5px;color:var(--muted-on-dark);
  padding:9px;border-radius:var(--pill);cursor:pointer;transition:.15s}
.seg button[aria-pressed="true"]{background:#fff;color:var(--navy);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.seg .save{font-family:"Space Mono",monospace;font-size:9.5px;color:#6ee6ad;margin-left:5px}
.seg button[aria-pressed="true"] .save{color:var(--green-deep)}
.wallets{display:flex;gap:8px;margin-top:15px}
.wallets a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;height:46px;border-radius:11px;font-weight:700;font-size:13px}
.w-apple{background:#fff;color:#000}
.w-google{background:#fff;color:#3c4043}
.w-paypal{background:#ffc439;color:#142c8e;font-style:italic;font-weight:800}
.give-or{text-align:center;font-size:11px;color:var(--muted-on-dark);margin:14px 0 12px;letter-spacing:.06em;position:relative}
.give-or::before,.give-or::after{content:"";position:absolute;top:50%;width:36%;height:1px;background:rgba(255,255,255,.14)}
.give-or::before{left:0}.give-or::after{right:0}
/* secured card-entry zone */
.cardzone{background:rgba(8,14,22,.5);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px}
.cardzone-lab{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted-on-dark);font-weight:600;margin-bottom:11px}
.cardzone-lab .lock{color:#6ee6ad}
.ladder{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ladder button{position:relative;border:1.5px solid rgba(255,255,255,.16);background:rgba(255,255,255,.04);border-radius:11px;padding:11px 5px 9px;
  cursor:pointer;font-family:inherit;text-align:center;transition:.14s;color:#fff}
.ladder button .amt{display:block;font-family:"Space Mono",monospace;font-weight:700;font-size:17px;font-variant-numeric:tabular-nums}
.ladder button .buys{display:block;font-size:9.5px;color:var(--muted-on-dark);margin-top:3px;line-height:1.2}
.ladder button:hover{border-color:var(--green)}
.ladder button[aria-pressed="true"]{border-color:var(--green);background:rgba(0,176,115,.16);box-shadow:0 0 0 1.5px var(--green) inset}
.ladder button[aria-pressed="true"] .amt{color:#6ee6ad}
.ladder .other .amt{font-size:13px;padding-top:2px}
.give-amount-row{margin-top:9px;display:none;align-items:center;gap:8px}
.give-amount-row.show{display:flex}
.give-amount-row span{font-family:"Space Mono",monospace;font-weight:700;font-size:17px;color:var(--muted-on-dark)}
.give-amount-row input{flex:1;border:1.5px solid rgba(255,255,255,.2);border-radius:11px;padding:11px 13px;font-family:"Space Mono",monospace;font-size:15px;background:rgba(8,14,22,.5);color:#fff;width:100%}
.give-amount-row input:focus{border-color:var(--green)}
.give .btn-give.lg{margin-top:14px}
.give-trust{margin-top:13px;display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:10.5px;color:var(--muted-on-dark);justify-content:center}
.give-trust .lock{color:#6ee6ad;font-weight:700}
.give-trust .dot{opacity:.4}

/* ---- impact menu ---- */
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:var(--s-5)}
.impact-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;text-align:left;
  cursor:pointer;font-family:inherit;transition:.16s;box-shadow:var(--shadow-card);display:flex;flex-direction:column;color:var(--ink)}
.impact-card:hover{transform:translateY(-4px);border-color:var(--green);box-shadow:var(--shadow)}
.impact-card .ph{aspect-ratio:16/10;overflow:hidden;background:var(--navy-2)}
.impact-card .ph img{width:100%;height:100%;object-fit:cover}
.impact-card .body{padding:20px 20px 22px}
.impact-card .price{font-family:"Space Mono",monospace;font-weight:700;font-size:24px;color:var(--green-deep);letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.impact-card .buys{font-family:"Fraunces",serif;font-size:19px;font-weight:540;margin-top:3px;display:block}
.impact-card .desc{font-size:13.5px;color:var(--muted);line-height:1.45;margin-top:8px}
.impact-card .pick{margin-top:14px;font-size:12.5px;font-weight:700;color:var(--green-deep)}
.impact-card .pick::after{content:" →"}
.impact-note{margin-top:22px;font-size:14px;color:var(--muted)}

/* ---- wedge ("Why play") ---- */
.wedge{position:relative;overflow:hidden;background:radial-gradient(130% 100% at 25% 0%,var(--navy-2),var(--navy) 65%)}
.wedge-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(30px,5vw,64px);align-items:center}
.wedge h2{font-size:clamp(30px,4.2vw,52px);font-weight:480}
.wedge p{margin-top:18px;color:var(--muted-on-dark);font-size:17px;max-width:48ch}
.wedge strong{color:#fff}
.wedge-evidence{margin-top:26px;display:flex;flex-direction:column;gap:14px;border-top:1px solid rgba(255,255,255,.12);padding-top:22px}
.ev-line{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}
.ev-line .ev-stat{font-family:"Space Mono",monospace;font-weight:700;font-size:20px;color:var(--amber);line-height:1;white-space:nowrap}
.ev-line .ev-txt{font-size:14px;color:#d8e1e8;line-height:1.45}
.ev-line .ev-txt cite{display:block;font-family:"Space Mono",monospace;font-style:normal;font-size:10px;color:#7e8c98;margin-top:4px;letter-spacing:.01em}
.wedge-photos{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:12px}
.wedge-photos figure{margin:0;border-radius:var(--r);overflow:hidden;position:relative;background:var(--navy-2);aspect-ratio:3/4}
.wedge-photos figure.wide{grid-column:span 2;aspect-ratio:16/9}
.wedge-photos img{width:100%;height:100%;object-fit:cover}
.wedge-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 13px 11px;font-size:11.5px;color:#fff;font-weight:600;
  background:linear-gradient(transparent,rgba(6,12,20,.82))}
.clin-quote{margin-top:26px;border-left:3px solid var(--green);padding:4px 0 4px 18px}
.clin-quote .q{font-family:"Fraunces",serif;font-size:18px;line-height:1.4;font-weight:440;color:#fff}
.clin-quote .who{margin-top:10px;font-size:12.5px;color:var(--muted-on-dark)}
.clin-quote .who b{color:#fff;font-weight:600}

/* ---- founder ("Our story") ---- */
.founder-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(30px,5vw,64px);align-items:center}
.founder-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--navy)}
.founder-media img{width:100%;height:100%;object-fit:cover}
.founder-media .play{position:absolute;inset:0;display:grid;place-items:center}
.founder-media .play span{width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,.94);color:var(--green-ink);
  display:grid;place-items:center;font-size:23px;padding-left:5px;box-shadow:0 10px 30px -8px rgba(0,0,0,.5);transition:.15s}
.founder-media:hover .play span{transform:scale(1.08);background:#fff}
.founder blockquote{font-family:"Fraunces",serif;font-size:clamp(23px,2.6vw,33px);font-weight:450;line-height:1.3;letter-spacing:-.015em;margin:0}
.founder .sig{margin-top:20px;font-family:"Space Mono",monospace;font-size:12.5px;letter-spacing:.03em;color:var(--muted);text-transform:uppercase}
.founder .sig b{color:var(--ink);font-weight:700}

/* ---- proof score-bar + transparency band ---- */
.score{background:var(--navy);color:#fff}
.score .lead{max-width:760px}
.score .lead h2{font-size:clamp(26px,3.2vw,40px);font-weight:520}
.score .lead p{margin-top:14px;color:var(--muted-on-dark);font-size:16.5px;max-width:60ch}
.score .lead b{color:#6ee6ad;font-weight:600}
.score-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:var(--s-5);border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);padding:var(--s-5) 0}
.score-bar .n{font-family:"Space Mono",monospace;font-weight:700;font-size:clamp(36px,5vw,56px);letter-spacing:-.04em;color:#fff;line-height:1;font-variant-numeric:tabular-nums}
.score-bar .l{margin-top:10px;font-size:13.5px;color:var(--muted-on-dark);line-height:1.4;max-width:24ch}
.score-badges{margin-top:var(--s-5);display:flex;flex-wrap:wrap;gap:12px 14px;align-items:center}
.badge-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--pill);padding:9px 16px;font-weight:600;color:#fff;font-size:13px}
.badge-chip .ic{color:#6ee6ad}
.badge-chip.award{background:var(--green-ink);border-color:transparent;color:#bff0d8}
a.badge-chip:hover{border-color:rgba(255,255,255,.4)}

/* ---- companies teaser (terracotta lane, subordinate) ---- */
.companies{position:relative;background:var(--paper-2);border-top:3px solid var(--terra);border-bottom:3px solid var(--terra)}
.companies-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,56px);align-items:center}
.companies h2{font-size:clamp(24px,3vw,38px);font-weight:540;color:var(--terra-deep)}
.companies .sub{margin-top:14px;font-size:16px;color:var(--muted);max-width:46ch}
.companies .cta-row{margin-top:24px}
.teaser-logos{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.teaser-logos .tile{background:#fff;border:1px solid var(--line);border-radius:12px;aspect-ratio:3/2;display:grid;place-items:center;padding:12px;min-width:0;overflow:hidden}
.teaser-logos .tile img{max-width:80%;max-height:40px;object-fit:contain;filter:grayscale(1);opacity:.78}

/* ---- closing: Continue Club + individuals router ---- */
.closing{background:linear-gradient(180deg,var(--navy),#0a141f);color:#fff}
.close-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(30px,5vw,60px);align-items:center}
.continue-card{position:relative;overflow:hidden}
.continue-card .kicker{color:#6ee6ad}
.continue-card h2{font-size:clamp(28px,3.6vw,46px);font-weight:500;margin-top:12px}
.continue-card p{margin-top:14px;color:var(--muted-on-dark);max-width:42ch;font-size:16.5px}
.continue-card .cta-row{margin-top:24px;display:flex;gap:14px;flex-wrap:wrap}
.continue-card .ghost-sub{font-family:"Space Mono",monospace;font-size:11px;color:#7e8c98;margin-top:14px;letter-spacing:.03em}
.player-select{background:var(--navy-2);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:24px}
.player-select .ps-head{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);font-weight:700}
.player-select h3{font-family:"Fraunces";font-size:20px;font-weight:520;color:#fff;margin:10px 0 14px}
.ps-row{display:flex;flex-direction:column;gap:2px}
.ps-row a{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 4px;border-top:1px solid rgba(255,255,255,.1);font-size:15px;font-weight:600;color:#fff;transition:.14s}
.ps-row a:hover{color:#6ee6ad;padding-left:8px}
.ps-row a .tag{font-family:"Space Mono",monospace;font-size:10px;color:var(--muted-on-dark);font-weight:400;letter-spacing:.04em}
.ps-row a .arr{margin-left:auto;color:var(--muted-on-dark)}

/* ---- footer ---- */
.foot{background:#0a141f;color:#aab8c4;padding:56px 0 28px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px}
.foot-brand img{height:28px}
.foot-brand p{margin-top:13px;font-size:13px;color:#7e8c98;max-width:34ch}
.foot h4{font-family:"Space Mono",monospace;color:#fff;font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin:0 0 12px;font-weight:700}
.foot a{display:block;color:#aab8c4;font-size:14px;padding:6px 0}
.foot a:hover{color:#6ee6ad}
.foot-note{margin-top:34px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;color:#7e8c98;
  display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between}
.foot-note a{display:inline;padding:0;text-decoration:underline}

/* ---- reveal (fail-safe: visible without JS) ---- */
.js .reveal{opacity:0;transform:translateY(14px)}
.js .reveal.in{opacity:1;transform:none;transition:opacity .55s cubic-bezier(.2,.7,.2,1),transform .55s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important}}

/* ---- cited facts ---- */
.factcite{font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.01em;color:var(--muted);display:block}
.factcite.on-dark{color:#7e8c98}
.factcite a{text-decoration:underline}

/* ============================================================
   PARTNERS PAGE  (corporate lane — terracotta + navy, NON-duotone imagery)
   ============================================================ */
.p-hero{background:linear-gradient(118deg,var(--navy) 38%,#2a1d18);color:#fff;position:relative;overflow:hidden}
.p-hero::after{content:"";position:absolute;right:-8%;top:-30%;width:55%;height:170%;background:radial-gradient(circle,rgba(216,96,63,.2),transparent 62%);pointer-events:none}
.p-hero-inner{position:relative;z-index:1;max-width:760px;padding:clamp(64px,9vw,120px) 0}
.p-hero .kicker{color:var(--amber)}
.p-hero h1{font-size:clamp(34px,5vw,62px);font-weight:460;margin-top:16px}
.p-hero h1 .em{color:var(--amber)}
.p-hero .lede{margin-top:20px;font-size:clamp(17px,1.6vw,20px);color:#e6d9d2;max-width:52ch}
.p-hero .cta-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.p-hero .cta-note{font-size:13px;color:#c9a99c}
.reach{background:var(--navy-2);color:#fff;border-top:1px solid rgba(255,255,255,.08)}
.reach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.reach .n{font-family:"Space Mono",monospace;font-weight:700;font-size:clamp(28px,3.2vw,44px);color:var(--amber);letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.reach .l{margin-top:8px;font-size:12.5px;color:var(--muted-on-dark);line-height:1.35}
.lanes{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:var(--s-5)}
.lane{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px;box-shadow:var(--shadow-card);color:var(--ink)}
.lane .lk{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra-deep);font-weight:700}
.lane h3{font-family:"Fraunces";font-size:22px;font-weight:540;margin-top:10px;color:var(--ink)}
.lane p{margin-top:10px;font-size:14.5px;color:var(--muted);line-height:1.5}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:var(--s-5);align-items:stretch}
.tier{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 24px;box-shadow:var(--shadow-card)}
.tier.feature{background:var(--navy);color:#fff;border-color:var(--navy)}
.tier .tname{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--terra-deep);font-weight:700}
.tier.feature .tname{color:var(--amber)}
.tier .floor{font-family:"Fraunces",serif;font-size:32px;font-weight:540;margin-top:8px}
.tier .floor span{font-size:14px;color:var(--muted)}
.tier.feature .floor span{color:var(--muted-on-dark)}
.tier ul{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.tier li{font-size:14px;line-height:1.4;padding-left:22px;position:relative;color:var(--muted)}
.tier.feature li{color:#cdd9e2}
.tier li::before{content:"▸";position:absolute;left:4px;color:var(--terra-deep)}
.tier.feature li::before{color:var(--amber)}
.tier .btn{margin-top:auto}
.tier .sp{margin-top:22px}
.logo-garden{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:var(--s-5)}
.logo-garden .tile{background:#fff;border:1px solid var(--line);border-radius:13px;aspect-ratio:3/2;display:grid;place-items:center;padding:14px;min-width:0;overflow:hidden}
.logo-garden .tile img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(1);opacity:.6;transition:.15s}
.logo-garden .tile:hover img{filter:none;opacity:1}
.cases{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:var(--s-5)}
.case{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-card)}
.case .ck{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--terra-deep);font-weight:700}
.case .cn{font-family:"Space Mono",monospace;font-size:34px;font-weight:700;color:var(--terra-deep);letter-spacing:-.03em;margin-top:14px;line-height:1}
.case h3{font-family:"Fraunces";font-size:20px;font-weight:540;margin-top:10px}
.case p{margin-top:10px;font-size:14.5px;color:var(--muted);line-height:1.5}
.case cite{display:block;font-family:"Space Mono",monospace;font-style:normal;font-size:10px;color:var(--muted);margin-top:12px;letter-spacing:.01em;line-height:1.4}
.lead{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:start}
.lead h2{font-size:clamp(28px,3.4vw,44px);font-weight:540}
.lead-form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-card)}
.lead-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lead-form label{display:block;font-size:12.5px;font-weight:700;color:var(--ink);margin:14px 0 5px}
.lead-form input,.lead-form select,.lead-form textarea{width:100%;border:1.5px solid var(--line-2);border-radius:11px;
  padding:12px 14px;font-family:inherit;font-size:15px;background:#fff;color:var(--ink)}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{border-color:var(--terra)}
.lead-form .btn{margin-top:18px;width:100%}
.lead-promise{font-size:13px;color:var(--muted);margin-top:12px;text-align:center}
.lead-done{margin-top:10px;text-align:center;color:var(--terra-deep);font-weight:700}

/* ============================================================
   INDIVIDUALS PAGE  (mission lane — green + paper, "Player Select" hub)
   ============================================================ */
.i-hero{background:var(--paper-2);border-bottom:1px solid var(--line)}
.i-hero-inner{max-width:760px;padding:clamp(52px,7vw,96px) 0}
.i-hero h1{font-size:clamp(32px,4.6vw,56px);font-weight:460;margin-top:14px}
.i-hero .lede{margin-top:18px;font-size:clamp(16px,1.5vw,19px);color:var(--muted);max-width:52ch}
.routes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.route{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-card);transition:.16s}
.route:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--green)}
.route .ph{aspect-ratio:16/10;overflow:hidden;background:var(--navy-2)}
.route .ph img{width:100%;height:100%;object-fit:cover}
.route .body{padding:24px;display:flex;flex-direction:column;flex:1}
.route .rk{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--green-deep);font-weight:700}
.route h2{font-family:"Fraunces";font-size:23px;font-weight:540;margin-top:8px}
.route p{margin-top:10px;font-size:14.5px;color:var(--muted);line-height:1.5;flex:1}
.route ul{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:9px}
.route li{font-size:13.5px;color:var(--muted);line-height:1.4;padding-left:18px;position:relative}
.route li::before{content:"▸";position:absolute;left:2px;color:var(--green-deep)}
.route .btn{margin-top:20px}
.i-fact{margin-top:var(--s-6);padding:24px;background:var(--paper-2);border-radius:var(--r-lg);font-size:15px;color:var(--muted);line-height:1.55;max-width:760px}

/* ---- responsive ---- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-media{position:relative;height:300px}
  .hero-media::after{background:linear-gradient(180deg,rgba(8,15,24,.35),rgba(8,15,24,.75))}
  .hero-copy{padding:36px 24px 8px}
  .hero-copy .display{max-width:none}
  .hero-widgetcol{padding:8px 24px 36px;justify-content:stretch}
  .give{max-width:none;min-height:0}
  .impact-grid,.wedge-grid,.founder-grid,.companies-grid,.close-grid,.lead,.lanes,.cases{grid-template-columns:1fr}
  .founder-media{order:-1}
  .score-bar{grid-template-columns:1fr;gap:24px;text-align:center}
  .score-bar .l{margin:6px auto 0}
  .reach-grid{grid-template-columns:1fr 1fr}
  .tiers{grid-template-columns:1fr}
  .logo-garden{grid-template-columns:repeat(3,1fr)}
  .routes{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .impact-grid{grid-template-columns:1fr}
  .wedge-photos{grid-template-columns:1fr 1fr}
  .teaser-logos{grid-template-columns:repeat(3,1fr)}
  .hero-statpair{gap:22px}
  .foot-top{grid-template-columns:1fr 1fr}
}
