/* ============================================================
   JSICP '26 IMPACT REPORT — teal brand re-skin
   Structure preserved from the original report; tokens remapped
   to the JSICP '26 design system (teal wash + electric cyan).
   Loads AFTER colors_and_type.css (which provides @font-face +
   --teal-*, --jsicp-gradient*, --font-* brand tokens).
   ============================================================ */

:root{
  /* page base / surfaces */
  --night:#0F2124;
  --night-2:#152A2D;
  --panel:rgba(255,255,255,.055);
  --panel-2:rgba(255,255,255,.08);

  /* text on dark */
  --ink:#FFFFFF;
  --muted:rgba(255,255,255,.74);
  --faint:rgba(255,255,255,.46);

  /* electric-cyan accent (was gold) */
  --gold:#38F2EC;
  --gold-2:#7CF1EC;
  --gold-dim:rgba(56,242,236,.30);
  --line:rgba(255,255,255,.16);
  --line-soft:rgba(255,255,255,.10);

  /* mint light-band */
  --cream:#CFEFEC;
  --cream-2:#AEDFDC;
  --cream-ink:#0F2124;
  --cream-muted:#1B4C54;
  --good:#9DD4D9;

  --radius:16px;

  /* type — Acumin display headers, Sharp Slab quotes, Founders body */
  --serif:var(--font-display);      /* headlines + big numbers → Acumin */
  --quote:var(--font-serif);        /* pull quotes → Sharp Slab */
  --sans:var(--font-sans);          /* body → Founders Grotesk Text */
  --mono:var(--font-sans);          /* de-mono'd per feedback — small text now Founders */
  --label:var(--font-accent);       /* eyebrows / chrome → Sharp Sans */
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--teal-900);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:var(--night)}
img{max-width:100%}
a{color:var(--gold);text-decoration:none}
a:hover{opacity:.85;text-decoration:none}

/* ---------- atmosphere: the topographic teal wash ---------- */
.bg-wash{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:url('assets/bg-topo-pattern.png') center/cover no-repeat,
             var(--jsicp-gradient-deep);
}
.bg-wash::after{ /* gentle vignette to keep edges deep */
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 100% at 50% 0%, transparent 40%, rgba(15,33,36,.55) 100%);
}

/* ---------- layout ---------- */
.wrap{max-width:1180px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.band{position:relative;padding:120px 0;z-index:2}
.band--tight{padding:88px 0}
.band--deep{background:linear-gradient(180deg,rgba(15,33,36,.42),rgba(15,33,36,.74))}
.band--flat{background:linear-gradient(170deg,#17444A 0%,#0E2A2E 100%)}
/* solid teal shades — the page is mostly solid color; contour is rare */
.band--s1{background:linear-gradient(165deg,#1C5154 0%,#123A3D 100%)}
.band--s2{background:linear-gradient(165deg,#123638 0%,#0C2729 100%)}
.band--s3{background:linear-gradient(165deg,#23696A 0%,#184E50 100%)}
.band--cream{background:linear-gradient(180deg,var(--cream),var(--cream-2));color:var(--cream-ink)}
.band--aqua{background:linear-gradient(155deg,#B4E2DC 0%,#8FCEC9 100%);color:var(--cream-ink)}
.band--aqua.band--edge,.band--cream.band--edge{border-top-color:rgba(15,33,36,.14)}
.band--edge{border-top:1px solid var(--line)}
.center{text-align:center}

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--label);font-size:12px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:14px;margin-bottom:26px;font-weight:700;
}
.eyebrow::before,.eyebrow.rule-r::after{content:"";width:42px;height:1px;background:var(--gold-dim)}
.band--cream .eyebrow{color:var(--teal-700)}
.band--cream .eyebrow::before,.band--cream .eyebrow.rule-r::after{background:rgba(30,106,103,.4)}
h1,h2,h3,.serif{font-family:var(--serif)}
h2{font-size:clamp(34px,4.6vw,58px);font-weight:500;line-height:1.1;letter-spacing:-.02em;margin-bottom:22px}
h2 em,h1 em{font-style:normal;color:var(--gold-2)}
.band--cream h2 em{color:var(--teal-600)}
h3{font-size:clamp(21px,2.2vw,27px);font-weight:600;line-height:1.25}
.lede{font-size:clamp(17px,1.45vw,20px);color:var(--muted);max-width:62ch;font-weight:300}
.band--cream .lede{color:var(--cream-muted)}
.center .lede{margin:0 auto}
.kicker-note{font-family:var(--label);font-weight:700;font-size:11.5px;letter-spacing:.07em;color:var(--white-64);text-transform:uppercase}
.band--cream .kicker-note{color:var(--cream-muted)}

/* ---------- header ---------- */
header.site{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  background:rgba(15,33,36,.66);border-bottom:1px solid var(--line);
  transition:transform .4s ease;
}
.site-in{max-width:1180px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:26px}
.brand{display:flex;align-items:center;gap:14px;white-space:nowrap}
.brand img.twi{height:30px;width:auto;display:block}
.brand .divider{width:1px;height:24px;background:var(--line)}
.brand .mark{font-family:var(--serif);font-size:18px;color:var(--ink);font-weight:600;letter-spacing:.01em}
.brand .sub{font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--gold);text-transform:uppercase}
nav.top{margin-left:auto;display:flex;gap:24px;align-items:center}
nav.top a{font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
nav.top a:hover{color:var(--gold);opacity:1}
.btn{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--label);font-weight:700;
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;
  padding:14px 28px;border-radius:999px;border:1px solid var(--gold-dim);
  color:var(--gold);transition:.3s;white-space:nowrap;
}
.btn:hover{background:rgba(56,242,236,.1);border-color:var(--gold);opacity:1}
.btn--solid{background:var(--gold);color:var(--teal-900);border:none}
.btn--solid:hover{background:var(--gold-2);color:var(--teal-900);opacity:1}
.band--cream .btn{color:var(--teal-700);border-color:rgba(30,106,103,.4)}
.band--cream .btn:hover{background:rgba(30,106,103,.08)}
.progress{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--teal-500),var(--gold));width:100%;transform-origin:0 50%;transform:scaleX(0);z-index:60}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;position:relative;padding:150px 0 90px;overflow:hidden;
  background:linear-gradient(180deg,rgba(15,33,36,.12),rgba(15,33,36,.5))}
.hero-glow{position:absolute;left:50%;top:36%;width:1100px;height:1100px;transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(56,242,236,.18) 0%, rgba(56,242,236,.06) 34%, transparent 62%);
  pointer-events:none;animation:breathe 9s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.9}50%{transform:translate(-50%,-50%) scale(1.12);opacity:1}}
.hero h1{font-size:clamp(46px,8vw,108px);font-weight:600;line-height:1.02;letter-spacing:-.03em;max-width:13ch}
.hero h1 .q{color:var(--gold-2);font-style:normal}
.hero-attrib{margin-top:26px;font-family:var(--label);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hero-attrib b{color:var(--gold);font-weight:700}
.hero-sub{margin-top:34px;max-width:60ch;font-size:clamp(17px,1.5vw,20px);color:var(--muted)}
.hero-sub strong{color:var(--ink);font-weight:500}
.hero-ctas{margin-top:44px;display:flex;gap:16px;flex-wrap:wrap}
.tickline{margin-top:72px;border-top:1px solid var(--line);padding-top:26px;display:flex;flex-wrap:wrap;gap:14px 0;align-items:center}
.tick{display:flex;align-items:baseline;gap:9px;padding:0 26px;border-right:1px solid var(--line-soft)}
.tick:first-child{padding-left:0}
.tick:last-child{border-right:none}
.tick .n{font-family:var(--serif);font-size:clamp(26px,2.4vw,36px);color:var(--gold);font-weight:500}
.tick .l{font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--white-80)}
.scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--faint);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollcue::after{content:"";width:1px;height:44px;background:linear-gradient(180deg,var(--gold),transparent);animation:drip 2.2s ease-in-out infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- stat cards ---------- */
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px}
.stat{
  background:var(--panel);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;position:relative;overflow:hidden;transition:.35s;
}
.stat::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 140px at 18% -10%,rgba(56,242,236,.1),transparent 60%);pointer-events:none}
.stat:hover{background:var(--panel-2);border-color:var(--gold-dim)}
.stat .n{font-family:var(--serif);font-size:clamp(40px,3.8vw,56px);font-weight:500;color:var(--gold);line-height:1;letter-spacing:-.02em}
.stat .n small{font-size:.5em;color:var(--gold-2);font-weight:400}
.stat .t{margin-top:12px;font-size:14.5px;color:var(--muted);line-height:1.5}
.stat .t b{color:var(--ink);font-weight:500}

/* ---------- prose / story ---------- */
.story{display:grid;grid-template-columns:1.1fr .9fr;gap:70px;align-items:start}
.story p{margin-bottom:22px;color:var(--muted);font-size:17.5px}
.story p strong{color:var(--ink);font-weight:500}
.story p:first-of-type::first-letter{
  font-family:var(--serif);float:left;font-size:74px;line-height:.78;padding:8px 12px 0 0;color:var(--gold);font-weight:500;
}
.sidequote{
  border-left:2px solid var(--gold);padding:8px 0 8px 28px;position:sticky;top:120px;
}
.sidequote .q{font-family:var(--quote);font-style:italic;font-size:clamp(22px,2.1vw,28px);line-height:1.4;color:var(--ink);font-weight:500}
.sidequote .a{margin-top:18px;font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}

/* ---------- why / research callouts ---------- */
.whygrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px}
.why{border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;background:rgba(255,255,255,.03);transition:.35s}
.why:hover{transform:translateY(-4px);border-color:var(--gold-dim);background:rgba(56,242,236,.06)}
.why .big{font-family:var(--serif);font-size:clamp(40px,4vw,58px);color:var(--gold);font-weight:500;line-height:1}
.why .cap{margin-top:14px;color:var(--muted);font-size:14.5px;line-height:1.55}
.srcnote{margin-top:26px;font-size:13px;color:var(--white-64);font-family:var(--sans);letter-spacing:0}

/* ---------- big quote band ---------- */
.bigquote{max-width:900px;margin:0 auto;text-align:center}
.bigquote .mark-open{font-family:var(--quote);font-size:120px;line-height:0;color:var(--gold-dim);display:block;height:54px}
.bigquote .q{font-family:var(--quote);font-style:italic;font-weight:500;font-size:clamp(24px,3vw,38px);line-height:1.45}
.bigquote .a{margin-top:28px;font-family:var(--label);font-weight:700;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}

/* ---------- momentum chart ---------- */
.chart-card{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:42px;margin-top:48px}
.chart-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:26px}
.chart-head .kpi .n{font-family:var(--serif);font-size:44px;color:var(--gold);line-height:1;font-weight:500}
.chart-head .kpi .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-top:8px}
#momentum{width:100%;height:auto;display:block}
.legend-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--gold);margin-right:8px;vertical-align:1px}
.surge-callouts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.surge{border-top:1px solid var(--line);padding-top:18px}
.surge .n{font-family:var(--serif);font-size:30px;color:var(--gold);font-weight:500}
.surge .l{font-size:13.5px;color:var(--muted);margin-top:6px;line-height:1.5}

/* ---------- reach: map + world ---------- */
.reach{display:grid;grid-template-columns:1.25fr .75fr;gap:60px;align-items:start;margin-top:56px}
.mapcard{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:36px;margin-top:50px}
.mapcap{margin-top:20px;text-align:center;font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--white-64)}
.geo .lit,.geo .hlc,.geo .mkg,.geo .halo,.geo .mk,.geo .nation{pointer-events:none}
.geo .base path{cursor:default}
.geotip{position:fixed;pointer-events:none;z-index:80;transform:translate(-50%,-145%);background:var(--teal-900);border:1px solid var(--gold-dim);color:var(--ink);font-family:var(--label);font-weight:700;font-size:12px;letter-spacing:.02em;padding:8px 13px;border-radius:9px;white-space:nowrap;opacity:0;transition:opacity .12s;box-shadow:0 10px 26px rgba(0,0,0,.45)}
.geotip .gt-n{color:var(--gold)}
.geo{width:100%;height:auto;display:block}
.geo .base path{fill:#163E42;stroke:rgba(255,255,255,.14);stroke-width:.6;transition:fill .3s}
.geo .base path:hover{fill:#1E6A67}
.geo .nation{fill:none;stroke:rgba(56,242,236,.30);stroke-width:1}
.geo .lit{stroke:rgba(15,33,36,.55);stroke-width:.7;opacity:0;transition:opacity .8s ease}
.geo.on .lit{opacity:1}
.geo .lit:hover{filter:brightness(1.18)}
.t1f{fill:#1E6A67}.t2f{fill:#33A29E}.t3f{fill:#38F2EC}
.geo .hlc{fill:rgba(56,242,236,.72);stroke:#7CF1EC;stroke-width:.7;opacity:0;transition:opacity .9s ease}
.geo.on .hlc{opacity:1}
.mkg{opacity:0;transition:opacity .8s ease}
.geo.on .mkg{opacity:1}
.mk{fill:#7CF1EC}
.halo{fill:none;stroke:rgba(56,242,236,.6);stroke-width:1.4;transform-box:fill-box;transform-origin:center;animation:halo 2.8s ease-in-out infinite}
@keyframes halo{0%,100%{transform:scale(.45);opacity:.9}70%{transform:scale(1.25);opacity:0}85%{opacity:0}}
.maplegend{margin-top:22px;display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.maplegend span i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:7px;vertical-align:-1px}
.prov{margin-top:26px;display:flex;gap:10px;flex-wrap:wrap}
.chip{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:9px 16px;border-radius:999px;
  border:1px solid var(--line);color:var(--muted);background:rgba(255,255,255,.03);
}
.chip b{color:var(--gold);font-weight:500}
.worldlist{display:flex;flex-direction:column;gap:0}
.country{display:flex;align-items:center;gap:16px;padding:15px 6px;border-bottom:1px solid var(--line-soft);transition:.3s;opacity:0;transform:translateX(18px)}
.worldlist.on .country{opacity:1;transform:none}
.country:hover{background:rgba(56,242,236,.05);padding-left:14px}
.country .flag{font-family:var(--label);font-weight:700;font-size:10.5px;letter-spacing:.08em;color:var(--gold);background:rgba(56,242,236,.08);border:1px solid var(--line-soft);border-radius:6px;width:36px;padding:4px 0;text-align:center;flex:none}
.country .nm{font-size:15.5px;color:var(--ink);font-weight:400}
.country .cities{margin-left:auto;font-family:var(--sans);font-size:12.5px;letter-spacing:0;color:var(--white-64);text-align:right}
.reach-line{margin-top:30px;font-family:var(--quote);font-style:italic;font-size:20px;color:var(--gold-2)}

/* ---------- who: donut + roles ---------- */
.who{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center;margin-top:50px}
.who>.donut-wrap{order:2}
.donut-wrap{position:relative;max-width:380px;margin:0 auto}
#donut{display:block;width:100%;height:auto;aspect-ratio:1/1}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.donut-center .n{font-family:var(--serif);font-size:42px;color:var(--ink);line-height:1;font-weight:500}
.donut-center .l{font-family:var(--label);font-weight:700;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--white-64);margin-top:8px;max-width:14ch}
.donut-cap{text-align:center;margin-top:20px;font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--white-64)}
.donut-cap b{color:var(--gold);font-family:var(--serif);font-size:16px;font-weight:500}
.charttip{position:absolute;pointer-events:none;transform:translate(-50%,-130%);background:var(--teal-900);border:1px solid var(--gold-dim);color:var(--ink);font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.02em;padding:7px 12px;border-radius:8px;white-space:nowrap;opacity:0;transition:opacity .14s;z-index:5}
.ring-center{position:absolute;top:0;left:0;width:100%;aspect-ratio:1/1;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.ring-center .rn{font-family:var(--serif);font-size:48px;font-weight:500;color:var(--ink);line-height:1;letter-spacing:-.02em}
.ring-center .rl{font-family:var(--label);font-weight:700;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--white-64);margin-top:7px}
.band--light .ring-center .rn{color:var(--teal-800)}
.band--light .ring-center .rl{color:var(--teal-800)}
.ring-center .rc-lbl{font-family:var(--quote);font-style:italic;font-weight:500;font-size:20px;line-height:1.2;text-align:center;color:var(--white-80)}
.band--light .ring-center .rc-lbl{color:var(--teal-800)}
.leg{display:flex;flex-direction:column;gap:14px}
.legrow{display:grid;grid-template-columns:14px 1fr auto;gap:14px;align-items:center;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
.legrow i{width:12px;height:12px;border-radius:4px}
.legrow .nm{font-size:15.5px;color:var(--ink)}
.legrow .nm small{display:block;color:var(--faint);font-size:12.5px;margin-top:2px}
.legrow .pc{font-family:var(--serif);font-size:24px;color:var(--gold);font-weight:500}
.alsoroles{margin-top:26px;color:var(--muted);font-size:14.5px;line-height:1.7}
.discbars{display:flex;flex-direction:column;gap:26px}
.dbar{display:grid;grid-template-columns:58px 1fr;gap:18px;align-items:center}
.dbar .dv{font-family:var(--serif);font-size:30px;font-weight:500;color:var(--gold);line-height:1;text-align:right}
.dbar .dl{display:block;font-size:15px;color:var(--ink);margin-bottom:9px}
.dbar .dl small{color:var(--faint);font-size:12.5px}
.dbar .track{height:9px}
.alsoroles b{color:var(--ink);font-weight:500}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;margin-top:70px;position:relative}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--teal-900),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--teal-900),transparent)}
.mq-track{display:flex;gap:54px;width:max-content;animation:mq 46s linear infinite}
.mq-track span{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);white-space:nowrap}
.mq-track span::after{content:"✦";margin-left:54px;color:var(--gold-dim)}
@keyframes mq{to{transform:translateX(-50%)}}

/* ---------- program timeline ---------- */
.timeline{margin-top:56px;position:relative;max-width:860px}
.timeline::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,var(--gold),var(--gold-dim) 70%,transparent)}
.tl{position:relative;padding:0 0 44px 56px}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:4px;top:7px;width:15px;height:15px;border-radius:50%;border:1px solid var(--gold);background:var(--teal-900)}
.tl::after{content:"";position:absolute;left:9px;top:12px;width:5px;height:5px;border-radius:50%;background:var(--gold)}
.tl h3{font-size:21px;color:var(--ink)}
.tl .fac{margin-top:6px;font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.tl p{margin-top:10px;color:var(--muted);font-size:15px;max-width:60ch}
details.objectives{margin-top:46px;border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.03);max-width:860px}
details.objectives summary{cursor:pointer;padding:22px 28px;font-family:var(--label);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);list-style:none;display:flex;justify-content:space-between;align-items:center}
details.objectives summary::after{content:"+";font-size:18px;transition:.3s}
details[open].objectives summary::after{transform:rotate(45deg)}
details.objectives .obj-body{padding:0 28px 26px;color:var(--muted);font-size:14.5px;line-height:1.8}

/* ---------- faculty ---------- */
.keynotes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:54px}
.keynote-sec{display:flex;align-items:center;gap:28px;margin-top:20px;padding:24px 32px;border:1px solid var(--line);border-radius:18px;background:var(--panel);transition:.35s;flex-wrap:wrap}
.keynote-sec:hover{border-color:var(--gold-dim);background:var(--panel-2)}
.keynote-sec .init{margin-bottom:0;flex:0 0 auto}
.keynote-sec .ks-meta{flex:0 0 auto;min-width:230px}
.keynote-sec h3{font-size:20px;color:var(--ink)}
.keynote-sec .role{margin-top:6px}
.keynote-sec p{flex:1 1 320px;font-size:13.5px;color:var(--muted);line-height:1.6;max-width:none}
.keynote-sec .init:empty{display:none}
.kcard{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:36px 30px;position:relative;overflow:hidden;transition:.35s}
.kcard:hover{transform:translateY(-5px);border-color:var(--gold-dim);background:var(--panel-2)}
.kcard::before{content:"";position:absolute;top:-60px;right:-60px;width:170px;height:170px;border-radius:50%;background:radial-gradient(circle,rgba(56,242,236,.16),transparent 70%)}
.kcard .init{width:64px;height:64px;border-radius:50%;border:1px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;color:var(--gold);background:rgba(56,242,236,.07);margin-bottom:22px;overflow:hidden}
.kcard .init img{width:100%;height:100%;object-fit:cover}
.kcard h3{font-size:22px;color:var(--ink)}
.kcard .role{margin-top:8px;font-family:var(--label);font-weight:700;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);line-height:1.7}
.kcard p{margin-top:14px;font-size:14px;color:var(--muted);line-height:1.65}
.kcard .init.sm,.keynote-sec .init{background:rgba(56,242,236,.07)}
.facgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.fcard{border:1px solid var(--line-soft);border-radius:14px;padding:22px;background:rgba(255,255,255,.03);transition:.3s}
.fcard:hover{border-color:var(--gold-dim);background:rgba(56,242,236,.05)}
.fcard .nm{font-family:var(--serif);font-size:17.5px;color:var(--ink);font-weight:500}
.fcard .rl{margin-top:7px;font-size:12.5px;color:var(--faint);line-height:1.55}
.facnote{margin-top:24px;font-size:13px;color:var(--white-64);font-family:var(--sans);letter-spacing:0}

/* ---------- progress bars ---------- */
.track{height:7px;border-radius:10px;background:rgba(255,255,255,.12);overflow:hidden}
.fill{height:100%;width:0;border-radius:10px;background:linear-gradient(90deg,var(--teal-600),var(--gold));transition:width 1.4s cubic-bezier(.25,.8,.25,1)}

/* ---------- outcomes ---------- */
.outgrid{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:stretch;margin-top:54px}
.outgrid>div:first-child{display:flex;flex-direction:column;justify-content:stretch;gap:0}
.outgrid>div:first-child .obar{flex:1;display:flex;flex-direction:column;justify-content:center;gap:14px;margin:0;padding:30px 0;border-top:1px solid var(--line)}
.outgrid>div:first-child .obar:first-child{border-top:0;padding-top:0}
.outgrid>div:first-child .obar:last-child{padding-bottom:0}
.outgrid>div:first-child .track{height:9px}
.obar{margin-bottom:30px}
.obar .top{display:flex;justify-content:space-between;align-items:baseline;gap:18px;margin-bottom:0}
.obar .top .l{font-size:16.5px;color:var(--ink);line-height:1.4}
.obar .top .l small{display:block;color:var(--white-64);font-size:12.5px;font-family:var(--sans);letter-spacing:0;margin-top:3px}
.obar .top .v{font-family:var(--serif);font-size:43px;color:var(--gold);line-height:1;font-weight:500}
.gauge-card{border:1px solid var(--line);border-radius:22px;padding:40px 36px;background:var(--panel);text-align:center}
.gauge-card .nps{font-family:var(--serif);font-size:64px;color:var(--gold);line-height:1;margin-top:-46px;font-weight:500}
.gauge-card .nl{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-top:10px}
.gauge-card p{margin-top:18px;font-size:14px;color:var(--muted);line-height:1.6}
.minis{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.mini{border:1px solid var(--line-soft);border-radius:14px;padding:20px;text-align:center;background:rgba(255,255,255,.03)}
.mini .n{font-family:var(--serif);font-size:30px;color:var(--ink);font-weight:500}
.mini .n em{color:var(--gold);font-style:normal}
.mini .l{font-size:12.5px;color:var(--faint);margin-top:6px;line-height:1.45}

/* ---------- voices (mint band) ---------- */
.voice-hero{max-width:940px;margin:50px auto 0;text-align:center}
.voice-hero .q{font-family:var(--quote);font-style:italic;font-weight:500;font-size:clamp(25px,3.2vw,40px);line-height:1.42;color:var(--cream-ink)}
.voice-hero .a{margin-top:26px;font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-700)}
.vgrid{column-count:3;column-gap:20px;margin-top:64px}
.vcard{break-inside:avoid;background:#FFFFFF;border:1px solid rgba(15,33,36,.1);border-radius:16px;padding:28px;margin-bottom:20px;box-shadow:0 14px 34px -22px rgba(15,33,36,.28);transition:.3s}
.vcard:hover{transform:translateY(-4px);box-shadow:0 22px 44px -22px rgba(15,33,36,.34)}
.vcard .q{font-family:var(--quote);font-size:17px;line-height:1.55;color:var(--cream-ink);font-weight:400}
.vcard .a{margin-top:16px;font-family:var(--label);font-weight:700;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-700)}
.stage-strip{margin-top:64px;border-top:1px solid rgba(15,33,36,.14);padding-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.stq .q{font-family:var(--quote);font-style:italic;font-size:17.5px;line-height:1.55;color:var(--cream-ink)}
.stq .a{margin-top:12px;font-family:var(--label);font-weight:700;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-muted)}
.privacy-note{margin-top:46px;text-align:center;font-family:var(--sans);font-size:12.5px;letter-spacing:0;color:var(--cream-muted)}

/* ---------- coalition ---------- */
.partners{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:46px;max-width:900px;margin-left:auto;margin-right:auto}
.pchip{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;padding:14px 24px;border:1px solid var(--line);border-radius:999px;color:var(--muted);transition:.3s;background:rgba(255,255,255,.03)}
.pchip:hover{color:var(--gold);border-color:var(--gold-dim);transform:translateY(-2px)}

/* logo soup */
.logo-soup{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:52px auto 0;max-width:1080px}
.psoup{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:18px;padding:34px 22px 26px;border-radius:16px;background:rgba(255,255,255,.46);border:1px solid rgba(15,33,36,.10);transition:transform .3s var(--ease-out),background .3s,border-color .3s}
.psoup:hover{transform:translateY(-3px);background:rgba(255,255,255,.74);border-color:rgba(15,33,36,.22)}
.psoup .lockup{height:74px;display:flex;align-items:center;justify-content:center;width:100%}
.psoup .lockup img{max-height:100%;max-width:84%;width:auto;object-fit:contain;opacity:.92}
.psoup .pname{font-family:var(--label);font-weight:700;font-size:12px;line-height:1.35;letter-spacing:.02em;color:var(--teal-800);text-align:center;text-wrap:balance}
@media(max-width:980px){.logo-soup{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.logo-soup{grid-template-columns:repeat(2,1fr);gap:12px}.psoup{padding:26px 14px 20px}.psoup .lockup{height:58px}}
.coal-more{margin:30px auto 0;max-width:62ch;text-align:center;color:var(--cream-muted);font-size:15px;line-height:1.6}
.coal-more b{color:var(--teal-800);font-weight:600}
.coal-stat{margin-top:54px;text-align:center}
.coal-stat .n{font-family:var(--serif);font-size:clamp(56px,7vw,92px);color:var(--gold);font-weight:500;line-height:1}
.coal-stat .l{margin-top:14px;color:var(--muted);font-size:16px;max-width:48ch;margin-left:auto;margin-right:auto}

/* ---------- next / cta ---------- */
.topics{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px;max-width:880px}
.topic{font-size:16px;font-weight:600;padding:12px 22px;border-radius:999px;border:1px solid var(--white-40);color:var(--white-90);background:rgba(255,255,255,.09)}
.cta-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.cta-card{border:1px solid var(--line);border-radius:20px;padding:36px 30px;background:var(--panel);display:flex;flex-direction:column;gap:14px;transition:.35s}
.cta-card:hover{transform:translateY(-5px);border-color:var(--gold-dim);background:var(--panel-2)}
.cta-card h3{font-size:21px;color:var(--ink)}
.cta-card p{font-size:14.5px;color:var(--muted);flex:1}
.cta-card .btn{align-self:flex-start}
.finale{text-align:center;padding-top:30px}
.finale h2{font-size:clamp(38px,5.4vw,72px)}
.finale-date{margin-top:26px;font-family:var(--label);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--white-64)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:70px 0 50px;position:relative;z-index:2;background:linear-gradient(180deg,rgba(30,106,103,.18),rgba(15,33,36,.5))}
.foot{display:grid;grid-template-columns:1.2fr .8fr;gap:60px}
.foot p{font-size:13.5px;color:var(--faint);line-height:1.75}
.foot .brandline{font-family:var(--serif);font-size:20px;color:var(--gold);margin-bottom:16px;font-weight:600}
.foot-links{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.foot-links a{font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.foot-links a:hover{color:var(--gold);opacity:1}
.smallprint{margin-top:50px;padding-top:24px;border-top:1px solid var(--line-soft);font-family:var(--sans);font-size:12.5px;letter-spacing:0;color:var(--white-64);line-height:1.8}

/* =====================================================================
   LIGHT BANDS — the page is mostly light solid teal shades.
   Shades: mint (lightest) · sky · sage · aqua (deepest light).
   .band--light carries the ink-on-light theme for all components.
   ===================================================================== */
.band--mint{background:linear-gradient(180deg,#D7F1EE 0%,#BCE4E0 100%)}
.band--sky{background:linear-gradient(165deg,#C7E9E5 0%,#A6D8D3 100%)}
.band--sage{background:linear-gradient(165deg,#A9DAD5 0%,#8ECCC6 100%)}
.band--light{color:var(--cream-ink)}
.band--light.band--edge{border-top-color:rgba(15,33,36,.14)}

/* text */
.band--light .eyebrow{color:var(--teal-800)}
.band--light .eyebrow::before,.band--light .eyebrow.rule-r::after{background:rgba(30,106,103,.45)}
.band--light h2 em,.band--light h1 em{color:var(--teal-800)}
.band--light .lede{color:var(--cream-muted)}
.band--light .kicker-note,.band--light .donut-cap{color:var(--teal-800)}
.band--light .srcnote,.band--light .facnote,.band--light .obar .top .l small,.band--light .country .cities,.band--light .coal-stat .l,.band--light .legrow .nm small{color:var(--cream-muted)}
.band--light .story p{color:#234A4E}
.band--light .story p strong,.band--light .alsoroles b,.band--light .stat .t b,.band--light .kcard h3,.band--light .fcard .nm,.band--light .cta-card h3,.band--light .tl h3,.band--light .legrow .nm{color:var(--cream-ink)}
.band--light .alsoroles,.band--light .stat .t,.band--light .why .cap,.band--light .kcard p,.band--light .cta-card p,.band--light .fcard .rl,.band--light .tl p,.band--light .surge .l{color:var(--cream-muted)}

/* accent numbers: electric cyan -> deep teal on light */
.band--light .stat .n,.band--light .why .big,.band--light .surge .n,.band--light .legrow .pc,.band--light .obar .top .v,.band--light .coal-stat .n,.band--light .chart-head .kpi .n,.band--light .mini .n em,.band--light .donut-cap b{color:var(--teal-800)}
.band--light .stat .n small{color:var(--teal-500)}
.band--light .dbar .dv{color:var(--teal-800)}
.band--light .dbar .dl{color:var(--cream-ink)}
.band--light .dbar .dl small{color:var(--cream-muted)}

/* cards: translucent-white-on-dark -> white-on-light */
.band--light .stat,.band--light .why,.band--light .kcard,.band--light .fcard,.band--light .keynote-sec,.band--light .cta-card,.band--light .chart-card,.band--light .mini,.band--light details.objectives{background:rgba(255,255,255,.58);border-color:rgba(15,33,36,.12)}
.band--light .stat:hover,.band--light .why:hover,.band--light .kcard:hover,.band--light .fcard:hover,.band--light .keynote-sec:hover,.band--light .cta-card:hover{background:rgba(255,255,255,.82);border-color:rgba(30,106,103,.4)}
.band--light .stat::after,.band--light .kcard::before{display:none}
.band--light .kcard .init,.band--light .keynote-sec .init{border-color:rgba(30,106,103,.4);background:rgba(30,106,103,.08);color:var(--teal-700)}
.band--light .keynote-sec h3{color:var(--cream-ink)}
.band--light .keynote-sec .role{color:var(--teal-800)}
.band--light .kcard .role{color:var(--teal-800)}
.band--light .keynote-sec p{color:var(--cream-muted)}

/* chips / pills / buttons */
.band--light .chip,.band--light .topic,.band--light .pchip{color:var(--ink-700);border-color:rgba(15,33,36,.2);background:rgba(255,255,255,.42)}
.band--light .chip b{color:var(--teal-800)}
.band--light .pchip:hover{color:var(--teal-900);border-color:rgba(15,33,36,.45);background:rgba(255,255,255,.72)}
.band--light .btn{color:var(--teal-800);border-color:rgba(30,106,103,.4)}
.band--light .btn:hover{background:rgba(30,106,103,.1)}

/* timeline */
.band--light .timeline::before{background:linear-gradient(180deg,var(--teal-600),rgba(30,106,103,.3) 70%,transparent)}
.band--light .tl::before{border-color:var(--teal-600);background:#D7F1EE}
.band--light .tl::after{background:var(--teal-600)}
.band--light .tl .fac{color:var(--teal-800)}
.band--light details.objectives summary{color:var(--teal-800)}
.band--light details.objectives .obj-body{color:var(--cream-muted)}

/* lines / dividers / tracks */
.band--light .legrow,.band--light .surge,.band--light .country,.band--light .marquee{border-color:rgba(15,33,36,.14)}
.band--light .track{background:rgba(15,33,36,.1)}

/* quotes */
.band--light .bigquote .q,.band--light .sidequote .q{color:var(--cream-ink)}
.band--light .bigquote .a{color:var(--teal-800)}
.band--light .sidequote .a{color:var(--teal-800)}
.band--light .bigquote .mark-open{color:rgba(15,33,36,.2)}
.band--light .reach-line{color:var(--teal-800)}

/* marquee on light */
.band--light .marquee::before{background:linear-gradient(90deg,#C7E9E5,transparent)}
.band--light .marquee::after{background:linear-gradient(270deg,#C7E9E5,transparent)}
.band--light .mq-track span{color:var(--teal-800)}
.band--light .mq-track span::after{color:rgba(30,106,103,.4)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.3,1)}
.reveal.on{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}.reveal.d4{transition-delay:.48s}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .statgrid{grid-template-columns:repeat(2,1fr)}
  .facgrid{grid-template-columns:repeat(3,1fr)}
  .keynotes,.whygrid,.surge-callouts,.cta-cards,.stage-strip{grid-template-columns:1fr 1fr}
  .vgrid{column-count:2}
  .story,.reach,.who,.outgrid,.foot{grid-template-columns:1fr;gap:48px}
  .sidequote{position:static}
  nav.top a.navlink{display:none}
}
@media (max-width:640px){
  body{font-size:16px}
  .band{padding:84px 0}
  .statgrid,.facgrid,.keynotes,.whygrid,.surge-callouts,.cta-cards,.stage-strip,.minis{grid-template-columns:1fr}
  .vgrid{column-count:1}
  .tick{padding:0 16px}
  .hero{padding-top:120px}
  .chart-card{padding:26px 18px}
  .scrollcue{display:none}
  .brand .mark,.brand .divider{display:none}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}


/* ---------- voices: tiered (v2) ---------- */
.vtier1{max-width:920px;margin:54px auto 0;display:flex;flex-direction:column;gap:22px}
.vhero{background:#FFFFFF;border:1px solid rgba(15,33,36,.1);border-radius:18px;padding:42px 48px;box-shadow:0 16px 40px -24px rgba(15,33,36,.3);text-align:center}
.vhero .q{font-family:var(--quote);font-style:italic;font-weight:500;font-size:20px;line-height:1.55;color:var(--cream-ink)}
.vhero .a{margin-top:20px;font-family:var(--label);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-700)}
.vtier2{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
.vfeat{background:#FFFFFF;border:1px solid rgba(15,33,36,.1);border-radius:16px;padding:30px 28px;box-shadow:0 14px 34px -22px rgba(15,33,36,.28);transition:.3s}
.vfeat:hover{transform:translateY(-4px);box-shadow:0 22px 44px -22px rgba(15,33,36,.34)}
.vfeat .q{font-family:var(--quote);font-size:15px;line-height:1.55;color:var(--cream-ink);font-weight:400}
.vfeat .a{margin-top:16px;font-family:var(--label);font-weight:700;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-700)}
.vtier3{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:20px}
.vmini{background:rgba(255,255,255,.66);border:1px solid rgba(15,33,36,.09);border-radius:13px;padding:20px 22px;transition:.3s}
.vmini:hover{background:#FFFFFF;transform:translateY(-3px)}
.vmini .q{font-family:var(--quote);font-size:13px;line-height:1.5;color:var(--cream-ink);font-weight:400}
.vmini .a{margin-top:12px;font-family:var(--label);font-weight:700;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-700)}
@media(max-width:860px){.vtier2{grid-template-columns:1fr}.vtier3{grid-template-columns:1fr}.vhero{padding:32px 28px}}
