/* ============================================================================
   NOOP site , design system + home. Built from the app's StrandDesign tokens.
   Contrast first: ink on canvas is ~13:1; green (#03E095) is FILL/accent only,
   green text on light uses #0F9D62. Light default, dark via [data-theme=dark].
   ========================================================================== */

:root {
  --canvas:#F6F8FB; --raised:#FFFFFF; --inset:#ECEEF3; --hairline:#E3E7EE; --hairline-2:#D5DAE3;
  --ink:#16203A; --ink-2:#4C5564; --ink-3:#5E6878;
  --focus-ring:0 0 0 3px rgba(3,224,149,.5), 0 0 0 1px rgba(10,40,30,.45);
  --green:#03E095; --green-ink:#0F9D62; --green-deep:#0A7E5A;
  --blue:#234F9E; --amber:#C2762A;
  --rec-a:#C0392B; --rec-b:#D9682A; --rec-c:#C99A00; --rec-d:#6FB23A; --rec-e:#0F9D62;
  --shadow-sm:0 1px 2px rgba(20,30,50,.06), 0 2px 6px rgba(20,30,50,.05);
  --shadow-md:0 10px 30px -10px rgba(20,30,50,.18), 0 2px 8px rgba(20,30,50,.06);
  --shadow-lg:0 40px 80px -30px rgba(20,40,70,.40), 0 6px 18px rgba(20,40,70,.10);
  --radius:18px; --radius-sm:12px;
  --wrap:1120px; --gut:24px;
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI",system-ui,Roboto,Helvetica,Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
html[data-theme="dark"] {
  --canvas:#0F1217; --raised:#1C2024; --inset:#23272C; --hairline:#2A2F36; --hairline-2:#333A42;
  --ink:#F4F6F8; --ink-2:#C8CFD8; --ink-3:#8A94A4;
  --green-ink:#03E095; --green-deep:#03E095; --blue:#60A0E0;
  --shadow-md:0 10px 30px -10px rgba(0,0,0,.5); --shadow-lg:0 40px 90px -30px rgba(0,0,0,.7);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--font);background:var(--canvas);color:var(--ink);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background .4s var(--ease), color .4s var(--ease);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---- type ---- */
h1,h2,h3{margin:0;letter-spacing:-.022em;line-height:1.05;font-weight:800;color:var(--ink)}
h1{font-size:clamp(38px,5.6vw,68px)}
h2{font-size:clamp(28px,3.8vw,46px)}
h3{font-size:clamp(19px,2vw,24px);letter-spacing:-.01em}
.lede{font-size:clamp(17px,1.5vw,20px);color:var(--ink-2);line-height:1.55;font-weight:400}
.eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green-ink)}
.grad{background:linear-gradient(96deg,var(--green-ink),#0e9bb0);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- layout ---- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut)}
section{padding:clamp(72px,10vw,128px) 0}
.center{text-align:center}
.section-head{max-width:680px;margin:0 auto 56px}
.center .section-head{margin-inline:auto}
.section-head .lede{margin:16px 0 0}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:600;
  padding:12px 22px;border-radius:12px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn--green{background:var(--green);color:#04231A;font-weight:700;box-shadow:0 8px 20px -8px rgba(3,224,149,.65)}
.btn--green:hover{box-shadow:0 12px 26px -8px rgba(3,224,149,.8);transform:translateY(-1px)}
.btn--ghost{background:var(--raised);color:var(--ink);border-color:var(--hairline-2)}
.btn--ghost:hover{border-color:var(--ink-3)}
.btn--lg{padding:15px 28px;font-size:16px;border-radius:13px}

/* ---- chips ---- */
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{font-size:13px;font-weight:600;color:var(--ink-2);background:var(--raised);
  border:1px solid var(--hairline);padding:7px 14px;border-radius:30px}
.chip b{color:var(--ink)}
.chip--green{background:rgba(3,224,149,.10);border-color:rgba(3,224,149,.30);color:var(--green-deep)}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;transition:background .3s, border-color .3s, backdrop-filter .3s}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:20px;height:64px;
  max-width:var(--wrap);margin:0 auto;padding:0 var(--gut)}
.nav.scrolled{background:color-mix(in srgb,var(--canvas) 82%,transparent);backdrop-filter:saturate(1.6) blur(14px);
  border-bottom:1px solid var(--hairline)}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:19px;letter-spacing:.01em}
.brand img{width:26px;height:26px}
.nav-links{display:flex;gap:26px;font-size:14.5px;font-weight:500;color:var(--ink-2)}
.nav-links a{transition:color .15s}.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:12px}
.tgl{width:34px;height:34px;border-radius:9px;border:1px solid var(--hairline-2);background:var(--raised);
  display:grid;place-items:center;cursor:pointer;color:var(--ink-2);font-size:15px}
.tgl:hover{color:var(--ink)}

/* ---- hero ---- */
.hero{position:relative;padding-top:clamp(40px,6vw,72px);overflow:hidden}
.hero::before{content:"";position:absolute;inset:-10% -10% auto auto;width:760px;height:620px;
  background:radial-gradient(closest-side,rgba(3,224,149,.16),transparent 70%);
  filter:blur(10px);z-index:-1;pointer-events:none}
.hero::after{content:"";position:absolute;left:-12%;top:24%;width:560px;height:520px;
  background:radial-gradient(closest-side,rgba(35,79,158,.10),transparent 70%);z-index:-1;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,64px);align-items:center}
.hero h1{margin:18px 0 0}
.hero .lede{margin:22px 0 0;max-width:460px}
.hero-cta{display:flex;gap:13px;margin:30px 0 26px;flex-wrap:wrap}
.hero-visual{position:relative;display:flex;justify-content:center}

/* ---- device frame (real screenshot) ---- */
.device{position:relative;width:clamp(230px,26vw,290px);aspect-ratio:1206/2622;border-radius:44px;
  padding:11px;background:linear-gradient(150deg,#3a4047,#202428 55%,#3a4047);
  box-shadow:var(--shadow-lg);overflow:hidden}
.device::before{content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:96px;height:26px;background:#05070a;border-radius:16px;z-index:3}
.device img{width:100%;height:100%;object-fit:cover;border-radius:34px;display:block}
.device-glow{position:absolute;inset:4% 6%;background:radial-gradient(closest-side,rgba(3,224,149,.34),transparent);
  filter:blur(40px);z-index:-1}
.float{animation:float 7s ease-in-out infinite}

/* ---- promise band ---- */
.promise{background:var(--ink);color:#fff;border-radius:28px;padding:clamp(40px,6vw,72px);
  text-align:center;position:relative;overflow:hidden}
html[data-theme="dark"] .promise{background:#1b2024;border:1px solid var(--hairline)}
.promise h2{color:#fff;max-width:760px;margin:0 auto}
.promise .lede{color:rgba(255,255,255,.72);max-width:560px;margin:18px auto 0}
.promise-row{display:flex;justify-content:center;gap:38px;flex-wrap:wrap;margin-top:38px}
.promise-row .stat b{display:block;font-size:34px;font-weight:800;color:var(--green)}
.promise-row .stat span{font-size:13.5px;color:rgba(255,255,255,.6)}

/* ---- data flow ---- */
.flow{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.flow-col{background:var(--raised);border:1px solid var(--hairline);border-radius:var(--radius);padding:28px}
.flow-col.theirs{opacity:.78}
.flow-col h3{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.flow-tag{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px}
.flow-tag.ours{background:rgba(3,224,149,.12);color:var(--green-deep)}
.flow-tag.theirs{background:var(--inset);color:var(--ink-3)}
.flow-steps{display:flex;flex-direction:column;gap:10px}
.flow-step{display:flex;align-items:center;gap:13px;background:var(--canvas);border:1px solid var(--hairline);
  border-radius:12px;padding:13px 15px;font-size:14.5px;font-weight:500}
.flow-step .ic{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:none;
  background:var(--inset);font-size:16px}
.flow-step.bad{color:var(--ink-3)}
.flow-step.good .ic{background:rgba(3,224,149,.14)}
.flow-arrow{height:14px;display:grid;place-items:center;color:var(--ink-3);font-size:13px}

/* ---- showcase ---- */
.showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.shot{background:var(--raised);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:24px 22px 0;overflow:hidden;box-shadow:var(--shadow-sm)}
.shot h3{font-size:19px}
.shot p{color:var(--ink-2);font-size:14.5px;margin:8px 0 20px}
.shot .shot-img{border-radius:20px 20px 0 0;overflow:hidden;box-shadow:0 -1px 0 var(--hairline)}
.shot .shot-img img{width:100%;height:300px;object-fit:cover;object-position:top center}

/* ---- compare ---- */
.cmp{width:100%;border-collapse:separate;border-spacing:0;background:var(--raised);
  border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.cmp th,.cmp td{padding:18px 20px;text-align:left;font-size:15px;border-bottom:1px solid var(--hairline)}
.cmp thead th{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);font-weight:700;background:var(--inset)}
.cmp thead th.us{color:var(--green-deep)}
.cmp tbody tr:last-child td{border-bottom:0}
.cmp td:first-child{font-weight:600;color:var(--ink)}
.cmp .us{font-weight:700;color:var(--ink)}
.cmp .yes{color:var(--green-deep);font-weight:700}
.cmp .no{color:var(--ink-3)}
.cmp-note{font-size:12.5px;color:var(--ink-3);margin-top:14px;text-align:center}

/* ---- download ---- */
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.dl{background:var(--raised);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:30px 26px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s}
.dl:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.dl .ic{font-size:30px}
.dl h3{margin:14px 0 4px}
.dl p{color:var(--ink-3);font-size:13.5px;margin:0 0 18px}

/* ---- footer ---- */
.foot{border-top:1px solid var(--hairline);padding:60px 0 50px;color:var(--ink-2);font-size:14.5px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.foot h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin:0 0 14px;font-weight:700}
.foot a{display:block;padding:5px 0;color:var(--ink-2)}.foot a:hover{color:var(--ink)}
.foot-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--ink)}
.foot-brand img{width:24px}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-top:44px;padding-top:24px;border-top:1px solid var(--hairline);font-size:13px;color:var(--ink-3)}

/* ---- reveal ---- */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.07s}.rv.d2{transition-delay:.14s}.rv.d3{transition-delay:.21s}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media (prefers-reduced-motion:reduce){.float{animation:none}.rv{opacity:1;transform:none;transition:none}}

/* ---- responsive ---- */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero .lede{margin-inline:auto}.hero-cta{justify-content:center}.hero .chips{justify-content:center}
  .hero-visual{order:-1}
  .showcase-grid,.dl-grid{grid-template-columns:1fr 1fr}
  .flow{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .nav-links{display:none}
  .showcase-grid,.dl-grid,.foot-grid{grid-template-columns:1fr}
  .promise-row{gap:24px}
}

/* ============================================================================
   PHOTOGRAPHY + SCIENCE , real imagery with our data overlaid, and the research
   page. Same tokens, same contrast discipline (text on photos always over a scrim).
   ========================================================================== */

/* full-bleed immersive moment (athlete photo + our ring) */
.moment{position:relative;min-height:560px;display:grid;place-items:center;text-align:center;color:#fff;overflow:hidden}
.moment-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;z-index:0;transform:scale(1.04)}
.moment-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,13,20,.42),rgba(9,13,20,.74))}
.moment-in{position:relative;z-index:1;max-width:780px;padding:90px 24px}
.moment h2{color:#fff}
.moment .lede{color:rgba(255,255,255,.85);margin:18px auto 0;max-width:580px}
.moment .statring{margin:0 auto 28px}
.moment .hero-cta{justify-content:center;margin-bottom:0}

/* conic ring stat */
.statring{--p:80;--ring:var(--green);width:132px;height:132px;border-radius:50%;
  background:conic-gradient(var(--ring) calc(var(--p)*1%), rgba(255,255,255,.18) 0);
  display:grid;place-items:center;position:relative;box-shadow:0 12px 40px -10px rgba(3,224,149,.5)}
.statring::before{content:"";position:absolute;inset:12px;border-radius:50%;background:rgba(10,14,20,.6)}
.statring .v{position:relative;font-size:40px;font-weight:800;color:#fff;line-height:1}
.statring .k{position:relative;font-size:10.5px;letter-spacing:.16em;color:rgba(255,255,255,.78);margin-top:4px}

/* feature split (photo + copy) */
.fsplit{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,5vw,64px);align-items:center}
.fsplit.rev .fsplit-media{order:2}
.fsplit-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/3}
.fsplit-media img{width:100%;height:100%;object-fit:cover}
.fsplit h2{margin:14px 0 0}.fsplit .lede{margin:18px 0 0}
.fsplit .mini{display:flex;gap:30px;margin-top:26px}
.fsplit .mini b{display:block;font-size:26px;font-weight:800;color:var(--ink)}
.fsplit .mini span{font-size:13px;color:var(--ink-3)}
.fsplit .btn{margin-top:24px}

/* science page */
.method{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.mcard{background:var(--raised);border:1px solid var(--hairline);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.mcard .mq{font-size:12.5px;color:var(--ink-3);font-weight:600;margin-bottom:6px}
.mcard h3{font-size:22px}
.mcard .meth{margin-top:16px;padding-top:16px;border-top:1px solid var(--hairline);font-size:13.5px;color:var(--ink-2);line-height:1.6}
.mcard .meth b{color:var(--ink)}
.honest{background:var(--inset);border:1px solid var(--hairline);border-radius:var(--radius);padding:30px}
.honest ul{margin:14px 0 0;padding-left:20px;color:var(--ink-2);font-size:15px;line-height:1.75}
.honest li b{color:var(--ink)}
.refs{columns:2;column-gap:40px}
.refs .ref{break-inside:avoid;margin-bottom:15px;padding-left:14px;border-left:2px solid var(--green);font-size:13.5px;color:var(--ink-2);line-height:1.55}
.refs .ref b{color:var(--ink)}
@media (max-width:920px){.fsplit{grid-template-columns:1fr}.fsplit.rev .fsplit-media{order:0}.method{grid-template-columns:1fr}.refs{columns:1}}

/* ============================================================================
   HERO CARDS (real nature/fitness backgrounds) + footer donations/crypto + mockups
   ========================================================================== */

/* hero as a card with a real photo background. Content sits over a scrim, white text. */
.herocard{position:relative;border-radius:26px;overflow:hidden;min-height:clamp(460px,54vw,620px);
  display:flex;align-items:center;color:#fff;margin-top:14px;box-shadow:var(--shadow-lg)}
.herocard .hc-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.03)}
.herocard .hc-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(8,12,18,.82) 0%,rgba(8,12,18,.6) 40%,rgba(8,12,18,.28) 100%)}
.herocard.center .hc-bg::after{background:radial-gradient(120% 90% at 50% 50%,rgba(8,12,18,.5),rgba(8,12,18,.8) 100%),linear-gradient(180deg,rgba(8,12,18,.45),rgba(8,12,18,.7))}
.herocard .hc-in{position:relative;z-index:1;width:100%;padding:clamp(34px,5vw,72px);max-width:var(--wrap);margin:0 auto}
.herocard.center .hc-in{text-align:center;max-width:840px}
.herocard .eyebrow{color:#6ff0bd;filter:none}
.herocard h1,.herocard h2{color:#fff}
.herocard .lede{color:rgba(255,255,255,.9)}
.herocard.center .lede{margin-left:auto;margin-right:auto}
.herocard .chip{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);color:#fff;backdrop-filter:blur(3px)}
.herocard .chip b{color:#fff}
.herocard .chip--green{background:rgba(3,224,149,.24);border-color:rgba(3,224,149,.5);color:#c2f7e1}
.herocard .btn--ghost{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.34);color:#fff;backdrop-filter:blur(3px)}
.herocard .btn--ghost:hover{border-color:#fff}
.herocard .hero-grid{align-items:center}
.herocard .device{box-shadow:0 40px 90px -30px rgba(0,0,0,.7)}
.herocard .statring{margin-bottom:24px}

/* a row of phone mockups (loads of mockups) */
.mockrow{display:flex;justify-content:center;align-items:flex-end;gap:clamp(12px,2vw,26px);flex-wrap:wrap}
.mockrow .device{width:clamp(180px,20vw,232px)}
.mockrow .device.lift{margin-bottom:26px}
.mockstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mockstrip .ms{border-radius:18px;overflow:hidden;border:1px solid var(--hairline);box-shadow:var(--shadow-sm);background:var(--raised)}
.mockstrip .ms img{width:100%;height:340px;object-fit:cover;object-position:top center;display:block}
@media (max-width:820px){.mockstrip{grid-template-columns:1fr 1fr}}

/* footer donations + crypto */
.foot-donate{margin:16px 0 0;font-size:13px;color:var(--ink-2);line-height:1.6;max-width:300px}
.foot-donate a{color:var(--green-deep);font-weight:700}
.foot-crypto{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.foot-crypto a{font-size:12px;font-weight:600;color:var(--ink-2);background:var(--inset);
  border:1px solid var(--hairline);padding:5px 12px;border-radius:20px}
.foot-crypto a:hover{color:var(--ink);border-color:var(--green)}

/* donate modal , reveal QR + address in place, no page navigation */
.dm-overlay{position:fixed;inset:0;z-index:200;background:rgba(10,14,20,.62);backdrop-filter:blur(5px);
  display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .25s var(--ease)}
.dm-overlay.open{display:flex;opacity:1}
.dm{position:relative;background:var(--raised);border:1px solid var(--hairline);border-radius:22px;max-width:440px;
  width:100%;box-shadow:var(--shadow-lg);overflow:hidden;transform:translateY(10px) scale(.98);transition:transform .25s var(--ease)}
.dm-overlay.open .dm{transform:none}
.dm-close{position:absolute;top:12px;right:14px;width:30px;height:30px;border-radius:8px;border:0;cursor:pointer;
  background:var(--inset);color:var(--ink-2);font-size:18px;line-height:1;display:grid;place-items:center}
.dm-close:hover{color:var(--ink)}
.dm-head{padding:24px 26px 0;text-align:center}
.dm-head h3{font-size:21px}
.dm-head p{color:var(--ink-2);font-size:13.5px;margin:8px 0 0;line-height:1.55}
.dm-tabs{display:flex;gap:8px;justify-content:center;padding:18px 26px 0}
.dm-tab{font-size:13px;font-weight:700;padding:8px 16px;border-radius:10px;border:1px solid var(--hairline-2);
  background:var(--canvas);color:var(--ink-2);cursor:pointer;transition:.15s}
.dm-tab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.dm-body{padding:20px 26px 6px;text-align:center}
.dm-qr{width:188px;height:188px;margin:0 auto;border-radius:14px;border:1px solid var(--hairline);padding:9px;background:#fff}
.dm-qr img{width:100%;height:100%;image-rendering:pixelated;display:block}
.dm-net{font-size:11px;color:var(--ink-3);margin:14px 0 6px;letter-spacing:.08em;text-transform:uppercase;font-weight:700}
.dm-addr{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:var(--ink);background:var(--inset);
  border:1px solid var(--hairline);border-radius:10px;padding:11px 12px;word-break:break-all;line-height:1.5}
.dm-copy{margin-top:14px;width:100%;justify-content:center}
.dm-foot{padding:14px 26px 22px;text-align:center;font-size:11.5px;color:var(--ink-3);line-height:1.5}
@media (max-width:520px){.dm-qr{width:158px;height:158px}}

/* ===== REVISION: full-bleed hero banner (no floating rounded card) ===== */
section.hero{padding:0}
.hero::before,.hero::after{display:none}
.herocard{border-radius:0;margin-top:0;box-shadow:none;min-height:clamp(430px,50vw,580px)}
.herocard .hc-bg{transform:scale(1.0)}
.herocard .hc-in{padding-top:clamp(48px,7vw,80px);padding-bottom:clamp(48px,7vw,80px)}

/* ===== REVISION: mobile menu (hamburger + drawer) ===== */
.nav-burger{display:none;width:42px;height:42px;border:1px solid var(--hairline-2);border-radius:11px;
  background:var(--raised);cursor:pointer;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px}
.mobile-menu{position:fixed;inset:0;z-index:130;background:var(--canvas);transform:translateX(100%);
  transition:transform .32s var(--ease);display:flex;flex-direction:column;padding:82px 26px 32px;overflow-y:auto}
.mobile-menu.open{transform:none}
.mobile-menu .mm-brand{position:absolute;top:20px;left:24px;display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px}
.mobile-menu .mm-brand img{width:24px}
.mobile-menu .mm-close{position:absolute;top:16px;right:20px;width:42px;height:42px;border-radius:11px;
  border:1px solid var(--hairline-2);background:var(--raised);font-size:22px;line-height:1;color:var(--ink-2);cursor:pointer}
.mobile-menu a.mm-link{font-size:23px;font-weight:700;color:var(--ink);padding:18px 2px;
  border-bottom:1px solid var(--hairline);letter-spacing:-.015em}
.mobile-menu a.mm-link:active{color:var(--green-deep)}
.mobile-menu .mm-cta{margin-top:28px;display:grid;gap:12px}
.mobile-menu .mm-cta .btn{width:100%;justify-content:center;font-size:16px;padding:15px}
body.mm-open{overflow:hidden}
@media (max-width:860px){
  .nav-links{display:none}
  .nav-right .btn{display:none}
  .nav-burger{display:flex}
  .herocard .hero-grid{grid-template-columns:1fr}
  .herocard .hero-visual{display:none}
}

/* ===== REVISION: viewport-tailored content utilities ===== */
.show-mobile{display:none}
@media (max-width:680px){
  .hide-mobile{display:none !important}
  .show-mobile{display:block !important}
  section{padding-top:clamp(52px,12vw,72px);padding-bottom:clamp(52px,12vw,72px)}
  h1{font-size:clamp(34px,9vw,44px)}
  h2{font-size:clamp(26px,7vw,34px)}
  .cmp th,.cmp td{padding:13px 12px;font-size:13.5px}
}

/* big stat band (environmental + tech) */
.statband{background:var(--ink);color:#fff;border-radius:0;position:relative;overflow:hidden}
html[data-theme="dark"] .statband{background:#10141a;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.statband .wrap{position:relative;z-index:1}
.bigstats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:44px}
.bigstat b{display:block;font-size:clamp(34px,4.4vw,52px);font-weight:800;letter-spacing:-.02em;line-height:1;
  background:linear-gradient(92deg,#03E095,#16B6C9);-webkit-background-clip:text;background-clip:text;color:transparent}
.bigstat span{display:block;font-size:13.5px;color:rgba(255,255,255,.66);margin-top:10px;line-height:1.5}
.statband h2{color:#fff;max-width:760px}
.statband .lede{color:rgba(255,255,255,.78);max-width:620px}
.statband .src{font-size:12px;color:rgba(255,255,255,.45);margin-top:30px}
.statband .src a{color:rgba(255,255,255,.7)}
@media (max-width:860px){.bigstats{grid-template-columns:1fr 1fr;gap:20px}}

/* tech pipeline steps */
.pipe{display:flex;align-items:stretch;gap:0;flex-wrap:wrap;margin-top:8px}
.pipe-step{flex:1;min-width:150px;background:var(--raised);border:1px solid var(--hairline);padding:22px 18px;text-align:center}
.pipe-step:not(:last-child){border-right:0}
.pipe-step .ic{font-size:22px}
.pipe-step b{display:block;margin:10px 0 4px;font-size:15px;color:var(--ink)}
.pipe-step span{font-size:12.5px;color:var(--ink-3);line-height:1.5}
.pipe-step.cloud{opacity:.5;text-decoration:line-through;text-decoration-color:var(--rec-a)}
@media (max-width:680px){.pipe-step{min-width:100%;border-right:1px solid var(--hairline) !important;border-bottom:0}.pipe-step:not(:last-child){border-bottom:0}}

/* ===== REVISION: uniform spacing after the full-bleed hero banner ===== */
/* every page's first content section gets the same generous top gap below the banner.
   excludes intentional full-bleed bands (style="padding:0") so they stay flush. */
.hero + section:not([style*="padding:0"]){padding-top:clamp(72px,9vw,112px) !important}

/* ===== REVISION: keep a 5-up phone mockrow on one line ===== */
.mockrow{gap:clamp(10px,1.5vw,20px)}
.mockrow .device{width:clamp(138px,14.6vw,186px)}
.mockrow .device.lift{margin-bottom:22px}

/* ===== REVISION: legible hero buttons + chips over photos (darker translucent) ===== */
.herocard .btn--ghost{background:rgba(12,16,22,.44);border-color:rgba(255,255,255,.5);color:#fff;backdrop-filter:blur(8px);font-weight:700}
.herocard .btn--ghost:hover{background:rgba(12,16,22,.62);border-color:#fff}
.herocard .chip{background:rgba(12,16,22,.42);border-color:rgba(255,255,255,.3);color:#fff;backdrop-filter:blur(6px);font-weight:600}
.herocard .chip b{color:#fff}
.herocard .chip--green{background:rgba(3,224,149,.3);border-color:rgba(3,224,149,.62);color:#e2fcf1}
.herocard .hero-cta{gap:14px}
.herocard .chips{gap:10px;max-width:560px}
.herocard.center .chips{margin-left:auto;margin-right:auto;justify-content:center}

/* ===== REVISION: animated data-flow on hero banners (subtle, technical) ===== */
.hero-fx{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;mix-blend-mode:screen;opacity:.85}
.herocard .hc-in{z-index:2}
.fx-stream{fill:none;stroke-width:1.4;stroke-linecap:round;stroke-dasharray:2 15}
.fx-s1{stroke:rgba(3,224,149,.55);animation:fxflow 6.5s linear infinite}
.fx-s2{stroke:rgba(111,168,232,.5);animation:fxflow 10s linear infinite}
.fx-s3{stroke:rgba(3,224,149,.4);animation:fxflow 8s linear infinite reverse}
.fx-s4{stroke:rgba(150,200,255,.35);animation:fxflow 12s linear infinite}
@keyframes fxflow{to{stroke-dashoffset:-340}}
.fx-node{transform-box:fill-box;transform-origin:center;animation:fxpulse 4.5s ease-in-out infinite}
@keyframes fxpulse{0%,100%{opacity:.2;transform:scale(.6)}50%{opacity:.75;transform:scale(1.3)}}
@media (prefers-reduced-motion:reduce){.fx-stream,.fx-node{animation:none}}

/* ===== REVISION: back-to-top button ===== */
.to-top{position:fixed;right:22px;bottom:22px;width:46px;height:46px;border-radius:50%;border:1px solid var(--hairline-2);
  background:var(--raised);color:var(--ink);box-shadow:var(--shadow-md);cursor:pointer;display:grid;place-items:center;
  font-size:19px;line-height:1;opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .25s var(--ease),transform .25s var(--ease),border-color .2s,color .2s;z-index:90}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{border-color:var(--green);color:var(--green-deep)}
@media (max-width:680px){.to-top{right:16px;bottom:16px;width:42px;height:42px}}

/* ===== REVISION: lock horizontal scroll (no right-scroll on mobile) ===== */
html{overflow-x:clip}
body{overflow-x:clip;position:relative}

/* ===== REVISION: slicker nav (animated underline + crisper scrolled state) ===== */
.nav-links a{position:relative;padding:6px 1px}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;
  background:linear-gradient(90deg,var(--green),#16B6C9);border-radius:2px;transition:right .26s var(--ease)}
.nav-links a:hover::after{right:0}
.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a[aria-current="page"]::after{right:0;opacity:.5}
.nav.scrolled{box-shadow:0 1px 0 var(--hairline),0 8px 26px -18px rgba(20,40,70,.28)}
.nav .btn--green{box-shadow:0 6px 18px -7px rgba(3,224,149,.7)}
.brand img{transition:transform .3s var(--ease)}.brand:hover img{transform:rotate(-20deg)}

/* ============================================================================
   REVISION 3 , Apple-grade global chrome: mega-menu header + rich footer +
   honest privacy notice. Single source in partials/{header,footer}.html,
   injected by tools/inject-chrome.py. Behaviour in js/site.js.
   ========================================================================== */

/* ---- headline balance: stop single-word orphans (e.g. a lone "you.") ---- */
h1,h2{text-wrap:balance}

/* ---- header sits above the dimming scrim; solid bar while a panel is open ---- */
.nav{z-index:90}
.nav.mega-open{background:var(--canvas);border-bottom:1px solid var(--hairline);backdrop-filter:none}
html[data-theme="dark"] .nav.mega-open{background:var(--raised)}

/* ---- top-level nav: dropdown buttons + plain links share one look ---- */
.nav-links{align-items:center;gap:22px}
.nav-item{position:relative;display:flex}
.nav-top{font:inherit;font-size:14.5px;font-weight:500;color:var(--ink-2);background:none;border:0;
  cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:6px 1px;position:relative;
  transition:color .15s;line-height:1}
.nav-top:hover,.nav-top[aria-expanded="true"]{color:var(--ink)}
.nav-top .caret{width:9px;height:9px;flex:none;opacity:.5;transition:transform .25s var(--ease),opacity .2s}
.nav-top[aria-expanded="true"] .caret{transform:rotate(180deg);opacity:.9}
.nav-top::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;
  background:linear-gradient(90deg,var(--green),#16B6C9);border-radius:2px;transition:right .26s var(--ease)}
.nav-top:hover::after,.nav-top[aria-expanded="true"]::after{right:0}
.nav-top[aria-current="page"]{color:var(--ink)}
.nav-top[aria-current="page"]::after{right:0;opacity:.5}

/* ---- the mega panel (floating, premium) ---- */
.mega{position:absolute;top:calc(100% + 15px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:540px;max-width:min(700px,92vw);background:var(--raised);border:1px solid var(--hairline);
  border-radius:18px;box-shadow:var(--shadow-lg);padding:20px;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;z-index:95}
.nav-item.open .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-item.mega-left .mega{left:0;transform:translateX(0) translateY(8px)}
.nav-item.mega-left.open .mega{transform:translateX(0) translateY(0)}
.nav-item.mega-right .mega{left:auto;right:0;transform:translateX(0) translateY(8px)}
.nav-item.mega-right.open .mega{transform:translateX(0) translateY(0)}
.mega::before{content:"";position:absolute;top:-7px;left:50%;width:13px;height:13px;margin-left:-6px;
  background:var(--raised);border-left:1px solid var(--hairline);border-top:1px solid var(--hairline);transform:rotate(45deg)}
.nav-item.mega-left .mega::before{left:30px}
.nav-item.mega-right .mega::before{left:auto;right:30px}
.mega-in{display:grid;grid-template-columns:1fr 1fr 1.1fr;gap:6px 18px}
.mega-col{display:flex;flex-direction:column;min-width:0}
.mega-h{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);
  margin:4px 0 6px;padding:0 10px}
.mega-link{display:block;padding:8px 10px;border-radius:11px;transition:background .15s}
.mega-link:hover{background:var(--inset)}
.mega-link b{display:block;font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.mega-link span{display:block;font-size:12px;color:var(--ink-3);margin-top:1px;line-height:1.4}
.mega-feature{position:relative;border-radius:14px;overflow:hidden;min-height:158px;display:flex;
  align-items:flex-end;padding:15px;color:#fff;isolation:isolate}
.mega-feature::before{content:"";position:absolute;inset:0;z-index:-2;background-image:var(--img);
  background-size:cover;background-position:center}
.mega-feature::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,12,20,.04),rgba(8,12,20,.82))}
.mega-feat-tag{position:absolute;top:11px;left:11px;font-size:10px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;background:rgba(255,255,255,.2);backdrop-filter:blur(6px);padding:4px 9px;border-radius:20px}
.mega-feat-title{font-size:15px;font-weight:700;line-height:1.25}
.mega-feature:hover .mega-feat-title{text-decoration:underline}

/* ---- dimming scrim under the open panel ---- */
.mega-scrim{position:fixed;inset:0;z-index:80;background:rgba(12,18,28,.30);opacity:0;visibility:hidden;
  transition:opacity .25s var(--ease),visibility .25s;backdrop-filter:blur(1.5px)}
.mega-scrim.show{opacity:1;visibility:visible}
@media (prefers-reduced-motion:reduce){.mega,.mega-scrim,.privacy-bar{transition:none}}

/* ---- Apple-style rich footer ---- */
.foot{border-top:1px solid var(--hairline);padding:44px 0 36px;color:var(--ink-2);font-size:14px}
.foot-fine{display:grid;gap:8px;padding-bottom:22px}
.foot-fine p{margin:0;font-size:11.5px;line-height:1.55;color:var(--ink-3);max-width:none}
.foot-fine b{color:var(--ink-2)}
.foot-rule{border:0;border-top:1px solid var(--hairline);margin:0}
.foot-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px 28px;padding:26px 0}
.foot-col h4{font-size:12px;text-transform:none;letter-spacing:0;color:var(--ink);font-weight:700;margin:0 0 9px}
.foot-col a{display:block;padding:4px 0;color:var(--ink-2);font-size:13px}
.foot-col a:hover{color:var(--ink)}
.foot-mid{display:flex;align-items:center;gap:16px;padding:22px 0 4px;flex-wrap:wrap}
.foot-mid .foot-brand{font-size:17px}
.foot-mid p{margin:0;color:var(--ink-3);font-size:12.5px;max-width:600px;line-height:1.55}
.foot-bottom{display:flex;align-items:center;gap:12px 18px;flex-wrap:wrap;padding-top:18px;
  border-top:1px solid var(--hairline);margin-top:14px;font-size:12.5px;color:var(--ink-3)}
.foot-copy{font-weight:500}
.foot-legal{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.foot-legal a{color:var(--ink-2)}.foot-legal a:hover{color:var(--ink)}
.foot-legal .sep{color:var(--hairline-2)}
.foot-locale{margin-left:auto;display:inline-flex;align-items:center;gap:7px;color:var(--ink-3);
  border:1px solid var(--hairline);border-radius:30px;padding:5px 12px;font-size:12px;white-space:nowrap}
.foot-bottom2{padding-top:12px;font-size:11.5px;color:var(--ink-3);line-height:1.5}
@media (max-width:860px){.foot-grid{grid-template-columns:1fr 1fr 1fr}.foot-locale{margin-left:0;order:9}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ---- first-visit privacy notice (no cookies => informational, not a wall) ---- */
.privacy-bar{position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--raised);
  border-top:1px solid var(--hairline);box-shadow:0 -12px 34px -20px rgba(20,40,70,.35);
  transform:translateY(110%);transition:transform .42s var(--ease)}
.privacy-bar.show{transform:none}
.privacy-bar .pb-in{max-width:var(--wrap);margin:0 auto;padding:13px var(--gut);display:flex;
  align-items:center;gap:15px;flex-wrap:wrap}
.privacy-bar .pb-ic{font-size:19px;flex:none}
.privacy-bar p{margin:0;font-size:12.8px;color:var(--ink-2);line-height:1.5;flex:1;min-width:230px}
.privacy-bar p b{color:var(--ink)}
.privacy-bar .pb-link{color:var(--green-deep);font-weight:600;white-space:nowrap}
.privacy-bar .pb-ok{flex:none}
@media (max-width:560px){.privacy-bar .pb-ic{display:none}.privacy-bar .pb-in{padding:12px 16px;gap:10px}}

/* ---- mobile drawer: collapsible sections mirror the mega menus ---- */
.mobile-menu .mm-section{border-bottom:1px solid var(--hairline)}
.mobile-menu .mm-sec-top{width:100%;display:flex;align-items:center;justify-content:space-between;
  background:none;border:0;cursor:pointer;font:inherit;font-size:22px;font-weight:700;color:var(--ink);
  padding:17px 2px;letter-spacing:-.015em}
.mobile-menu .mm-sec-top .mm-caret{font-size:15px;color:var(--ink-3);transition:transform .25s var(--ease)}
.mobile-menu .mm-section.open .mm-sec-top .mm-caret{transform:rotate(180deg)}
.mobile-menu .mm-sub{display:none;padding:0 2px 14px}
.mobile-menu .mm-section.open .mm-sub{display:block}
.mobile-menu .mm-sub a{display:block;padding:9px 0;font-size:16px;color:var(--ink-2)}
.mobile-menu .mm-sub a:active{color:var(--green-deep)}

/* ---- legal / prose pages (privacy, terms, sitemap) ---- */
.legal-hero{padding:clamp(56px,8vw,96px) 0 0}
.legal-hero .wrap{max-width:820px}
.legal-hero h1{font-size:clamp(34px,5vw,52px)}
.legal-hero .lede{margin:18px 0 0}
.legal-hero .updated{margin:16px 0 0;font-size:13px;color:var(--ink-3)}
.legal{max-width:820px;margin:0 auto;padding:clamp(40px,6vw,64px) var(--gut) clamp(64px,9vw,104px)}
.legal-tldr{background:var(--inset);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:24px 26px;margin-bottom:40px}
.legal-tldr h2{font-size:16px;margin-bottom:10px}
.legal-tldr p{margin:0;color:var(--ink-2);font-size:14.5px;line-height:1.7}
.legal-tldr ul{margin:10px 0 0;padding-left:20px;color:var(--ink-2);font-size:14.5px;line-height:1.7}
.legal h2{font-size:clamp(20px,2.4vw,26px);margin:40px 0 12px;scroll-margin-top:84px}
.legal h3{font-size:17px;margin:24px 0 8px}
.legal p,.legal li{color:var(--ink-2);font-size:15.5px;line-height:1.75}
.legal p{margin:0 0 14px}
.legal ul{margin:0 0 16px;padding-left:22px}
.legal li{margin-bottom:7px}
.legal a{color:var(--green-deep);font-weight:600}
.legal strong,.legal b{color:var(--ink)}
.legal code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;background:var(--inset);
  border:1px solid var(--hairline);border-radius:6px;padding:1px 6px;color:var(--ink)}
.legal hr{border:0;border-top:1px solid var(--hairline);margin:40px 0}
.legal-contact{background:var(--raised);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:24px 26px;margin-top:36px;box-shadow:var(--shadow-sm)}
.legal-contact b{display:block;margin-bottom:6px}
/* sitemap grid */
.sitemap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:8px}
.sitemap-col h2{font-size:15px;margin:0 0 12px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}
.sitemap-col a{display:block;padding:7px 0;color:var(--ink);font-weight:600;font-size:15px;border-bottom:1px solid var(--hairline)}
.sitemap-col a span{display:block;font-weight:400;font-size:12.5px;color:var(--ink-3);margin-top:2px}
.sitemap-col a:hover{color:var(--green-deep)}
@media (max-width:760px){.sitemap-grid{grid-template-columns:1fr}}

/* ============================================================================
   REVISION 4 , flicker fix + a11y (focus ring, contrast) + polish + mobile
   content-tailoring. Overrides REVISION 3 where they conflict (later wins).
   ========================================================================== */

/* ---- FLICKER FIX: the arrow becomes a transparent bridge that fills the gap
   between button and panel, so the hover region is continuous and the panel
   never flashes open/closed as the pointer crosses the gap. ---- */
.mega::before{content:"";position:absolute;top:-17px;left:0;right:0;width:auto;height:17px;
  margin-left:0;background:transparent;border:0;transform:none;border-radius:0}
.nav-item.mega-left .mega::before,.nav-item.mega-right .mega::before{left:0;right:0}

/* ---- A11Y BLOCKER: visible focus ring on every interactive chrome control ---- */
.nav-top:focus-visible,.mega-link:focus-visible,.mega-feature:focus-visible,.nav-plain:focus-visible,
.mm-sec-top:focus-visible,.mm-sub a:focus-visible,.mm-link:focus-visible,.mm-close:focus-visible,
.foot a:focus-visible,.foot-legal a:focus-visible,.pb-link:focus-visible,.tgl:focus-visible,
.nav-burger:focus-visible,.dm-close:focus-visible,.dm-tab:focus-visible,.to-top:focus-visible,
.btn:focus-visible,.brand:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:9px}
.pick .dl .btn:focus-visible{border-radius:13px}

/* ---- calmer top-level underline (drop the loud green->teal gradient + hardcode) ---- */
.nav-top::after,.nav-links a::after{background:var(--green-ink);height:2px}
.nav-top.nav-plain{padding-right:1px}

/* ---- richer featured tile (adds a context line) + consistent height ---- */
.mega-feature{justify-content:flex-end;gap:3px}
.mega-feat-title{font-size:15.5px;font-weight:700;line-height:1.2}
.mega-feat-sub{font-size:12px;line-height:1.4;color:rgba(255,255,255,.82);font-weight:400}
.mega-feat-tag{background:rgba(255,255,255,.28);border:1px solid rgba(255,255,255,.38)}
.mega-link span{color:var(--ink-2)}            /* lift small description contrast */
.mega-feature .mega-feat-title{text-decoration:none}
.mega-feature:hover .mega-feat-title{text-decoration:underline}

/* ---- footer: 6 columns (WHOOP-style), funding line, de-emphasised locale ---- */
.foot-grid{grid-template-columns:repeat(6,1fr)}
.foot-fund{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:12px;
  font-size:12.5px;color:var(--ink-3)}
.foot-fund a{color:var(--green-deep);font-weight:600}
.foot-legal{gap:18px}
.foot-locale{margin-left:auto;border:0;padding:0;color:var(--ink-3);font-size:12.5px;white-space:nowrap}
@media (max-width:980px){.foot-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.foot-grid{grid-template-columns:repeat(2,1fr);gap:20px}.foot-locale{margin-left:0}}

/* ---- legal pages: section affordance so the numbered run scans faster ---- */
.legal h2{border-top:1px solid var(--hairline);padding-top:30px}
.legal h2:first-of-type,.legal-tldr + h2{border-top:0;padding-top:0}

/* ============================================================================
   MOBILE CONTENT-TAILORING , a phone should be a short, simple read, not an
   endless scroll. Hide secondary mockups/sections, show one clean phone, trim.
   ========================================================================== */
.mob-only{display:none}
@media (max-width:680px){
  .desk-only{display:none !important}
  .mob-only{display:block !important}

  /* one clean phone instead of a cramped, overlapping row/strip */
  .mockrow{display:block;text-align:center;gap:0}
  .mockrow .device{display:none !important}
  .mockrow .device:first-child{display:inline-block !important;width:min(76vw,300px) !important;margin:0 auto !important}
  .mockrow .device.lift{margin-bottom:0 !important}
  .mockstrip{display:block;text-align:center}
  .mockstrip .ms{display:none !important}
  .mockstrip .ms:first-child{display:inline-block !important;width:min(76vw,300px) !important}

  /* tighter rhythm so fewer swipes reach the point */
  section{padding-top:clamp(40px,9vw,56px) !important;padding-bottom:clamp(40px,9vw,56px) !important}
  .hero + section:not([style*="padding:0"]){padding-top:clamp(44px,10vw,64px) !important}
  .section-head{margin-bottom:32px}
  .section-head .lede{font-size:15.5px}
}

/* ---- mobile drawer: richer sub-links (label + context) + +/x caret ---- */
.mobile-menu .mm-sub a{padding:10px 0}
.mobile-menu .mm-sub a b{display:block;font-size:16px;font-weight:600;color:var(--ink)}
.mobile-menu .mm-sub a span{display:block;font-size:13px;color:var(--ink-3);margin-top:1px;line-height:1.4}
.mobile-menu .mm-sec-top .mm-caret{font-size:22px;font-weight:300;line-height:1}
.mobile-menu .mm-section.open .mm-sec-top .mm-caret{transform:rotate(45deg)}

/* ============================================================================
   REVISION 4b , mobile horizontal-overflow hardening (scrollWidth == viewport)
   ========================================================================== */
/* the off-canvas drawer fades in place instead of translating off the right edge
   (position:fixed escapes overflow-x:clip, so translateX(100%) added scroll width) */
.mobile-menu{transform:none;opacity:0;visibility:hidden;left:0;right:0;width:auto;max-width:100vw;
  transition:opacity .28s var(--ease),visibility .28s var(--ease)}
.mobile-menu.open{transform:none;opacity:1;visibility:visible}
/* clip hero internals (animated FX + any visual) and stop grid/flex kids from forcing width */
.herocard{overflow:hidden}
.hero-grid,.hero-grid>*,.flow,.flow>*,.cmp-wrap,.mockstrip,.mockrow{min-width:0}
.hero-fx{max-width:100%}
@media (max-width:680px){
  .device{max-width:100%}
  .chips{max-width:100%}
}
.moment{overflow:hidden}
.statband{overflow:hidden}

/* ---- hero: hard single-column + viewport-bound on mobile (no clipped text) ---- */
.herocard{max-width:100%}
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr !important;gap:0}
  .herocard .hero-visual{display:none !important}
}
@media (max-width:680px){
  .herocard>.hc-in{padding-left:20px !important;padding-right:20px !important;max-width:100%}
  .hero-copy{max-width:100%}
  .hero-copy h1{font-size:clamp(30px,8.4vw,40px)}
  .herocard .chips{max-width:100% !important}
}

/* ---- HARD viewport clamp: nothing may exceed the viewport (kills the residual
   horizontal overflow that width:auto was inheriting from expanded content) ---- */
section,.herocard,.moment,.statband,.promise,.foot,.hero{max-width:100vw;overflow-x:clip}
.cmp-wrap,.cmp{max-width:100%;overflow-x:auto}

/* the hero-fx SVG paths extend past the viewBox; on small screens that expands
   the page width. Hide the decorative flow on mobile (kept on desktop). */
@media (max-width:680px){ .hero-fx{display:none !important} }

/* ROOT FIX: each banded section contains its own absolute/scaled decoration
   (position:relative) and clips it, so nothing attaches to <body> and expands
   the page. This is what kept body width > viewport on mobile. */
.herocard,.moment,.statband,.promise,.hero,.tech-sec{position:relative;overflow:hidden}

/* ============================================================================
   REVISION 5 , dropdowns rebuilt: list real PAGES grouped by type, and open via
   PURE CSS :hover/:focus-within (no JS timers => no flicker). Featured-image
   tiles removed (they 404'd via var(--img) resolving against the stylesheet).
   ========================================================================== */

/* transparent bridge fills the button->panel gap so hover is continuous */
.mega::before{content:"";position:absolute;top:-16px;left:0;right:0;width:auto;height:16px;
  margin:0;background:transparent;border:0;transform:none;border-radius:0}

/* clean panel sizing for page lists */
.mega{min-width:288px;max-width:min(560px,92vw);padding:14px}
.mega.mega-wide{min-width:520px}
.mega-in{grid-template-columns:1fr;gap:2px}
.mega-in.mega-2col{grid-template-columns:1fr 1fr;gap:4px 20px}
.mega-col{min-width:0}
.mega-link.mega-plain{padding:7px 10px;font-size:13.5px;font-weight:500;color:var(--ink-2)}
.mega-link.mega-plain:hover{color:var(--ink);background:var(--inset)}

/* OPEN on desktop via hover + keyboard focus (CSS only, flicker-proof) */
@media (hover:hover) and (min-width:861px){
  .nav-item:hover > .mega,
  .nav-item:focus-within > .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
  .nav-item.mega-left:hover > .mega,.nav-item.mega-left:focus-within > .mega{transform:translateX(0) translateY(0)}
  .nav-item.mega-right:hover > .mega,.nav-item.mega-right:focus-within > .mega{transform:translateX(0) translateY(0)}
  .nav:has(.nav-item:hover),.nav:has(.nav-item:focus-within){background:var(--canvas);border-bottom:1px solid var(--hairline);backdrop-filter:none}
  html[data-theme="dark"] .nav:has(.nav-item:hover),html[data-theme="dark"] .nav:has(.nav-item:focus-within){background:var(--raised)}
  .nav:has(.nav-item:hover) .mega-scrim,.nav:has(.nav-item:focus-within) .mega-scrim{opacity:1;visibility:visible}
  .nav-item:hover .caret,.nav-item:focus-within .caret{transform:rotate(180deg)}
}
/* OPEN on touch / explicit tap (JS toggles .open) */
.nav-item.open > .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-item.mega-left.open > .mega,.nav-item.mega-right.open > .mega{transform:translateX(0) translateY(0)}
.nav:has(.nav-item.open){background:var(--canvas);border-bottom:1px solid var(--hairline)}
html[data-theme="dark"] .nav:has(.nav-item.open){background:var(--raised)}
.nav:has(.nav-item.open) .mega-scrim{opacity:1;visibility:visible}
.nav-item.open .caret{transform:rotate(180deg)}

/* ============================================================================
   REVISION 6 , DEFINITIVE flicker fix. The dimming scrim is inside <nav> and
   painted ABOVE the nav buttons (z-80 > button z-auto): on hover it covered the
   button, :hover dropped, the panel closed, then the button was hovered again ,
   an infinite show/hide loop. Make the scrim click-through and start it below
   the 64px nav bar so it never sits over the buttons or the hover path.
   ========================================================================== */
.mega-scrim{top:64px;pointer-events:none}
