/* ══════════════════════════════════════════════════════════════════
   Design system: neutral-cool graphite (near-black ground, desaturated
   charcoal surfaces, neutral near-white text) + teal chrome accent
   (#008170) and deep-green accent edges (#005B41). Gain-green (#3BEB8A)
   is reserved for data/proof moments only. Inter + JetBrains Mono.
   Surfaces are near-neutral by design — the blue-navy set read as a
   generic admin dashboard; graphite reads professional and lets the
   teal/green accents separate cleanly.
   Shared by all pages — palette lives here and only here.
   ════════════════════════════════════════════════════════════════ */
:root {
  --bg:        #0F0F0F;   /* near-black page ground */
  --bg-2:      #1B1E24;   /* graphite surface (cards, nav) — was navy #232D3F */
  --bg-3:      #16181D;   /* darker graphite, mid-step between bg and bg-2 */
  --bg-hover:  #262A31;   /* lightened graphite for hover */
  --border:    #2A2E36;   /* neutral graphite hairline */
  --border-2:  #005B41;   /* deep-green accent border (featured/proof edges) */
  --text:      #EAECEF;   /* neutral near-white — ~13:1 on bg-2 */
  --text-2:    #A2A8B0;   /* muted neutral gray — 7.0:1 on bg-2 */
  --text-3:    #8A9099;   /* dim neutral gray — 5.2:1 on bg-2, 5.5:1 on bg-3, 6.0:1 on bg (clears AA) */
  --signal:    #008170;   /* THE chrome accent: pulse dot, CTA, secondary highlights */
  --pos:       #3BEB8A;   /* gain-green — Monte-Carlo profit / form success ONLY */
  --neg:       #EF4444;   /* stop / reject / loss only */
  --r-sm: 4px; --r: 6px; --r-lg: 8px; --r-xl: 12px;
  --sans: 'Inter', system-ui, -apple-system, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --max: 1140px;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body {
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  font-size:15px;
  letter-spacing:-0.011em;
  overflow-x:hidden;
}
h1,h2,h3,h4 { letter-spacing:-0.025em; line-height:1.08; font-weight:700; text-wrap:balance; }
p { text-wrap:pretty; }
a { color:inherit; text-decoration:none; }
code, .mono { font-family:var(--mono); font-variant-numeric:tabular-nums; }
.pos { color:var(--pos); }
:focus-visible { outline:2px solid var(--text); outline-offset:3px; border-radius:var(--r-sm); }

.skip-link { position:absolute; left:-9999px; top:0; z-index:100; background:var(--text); color:var(--bg); padding:10px 16px; border-radius:var(--r); font-size:13.5px; font-weight:600; }
.skip-link:focus { left:12px; top:12px; }
.wrap { max-width:var(--max); margin:0 auto; padding:0 24px; }
section { padding:88px 0; position:relative; }
.page-first { padding-top:140px; }   /* first section on a sub-page: clears the fixed 60px nav */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:11px; font-weight:500;
  text-transform:uppercase; letter-spacing:0.12em;
  color:var(--text-3); margin-bottom:18px;
}
.sec-title { font-size:clamp(26px,3.4vw,38px); margin-bottom:14px; }
.sec-sub { color:var(--text-2); font-size:16px; max-width:640px; line-height:1.6; }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; transition-duration:.001ms!important; }
  html { scroll-behavior:auto; }
  /* signal-travel sits at resting state: plain nodes, green hairline connectors */
  .pipe-node, .pipe-icon, .pipe-flow::after { animation:none!important; }
  .hero-tag .dot { animation:none!important; }
}
@media (pointer:coarse){
  .btn { padding:12px 18px; }
  .wl-input { padding:12px 14px; }
  .faq summary { padding:18px; }
  .nav-toggle { width:44px; height:44px; }
}

/* ── NAV ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:50; height:60px;
  display:flex; align-items:center;
  background:rgba(15,15,15,0.72); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav .wrap { display:flex; align-items:center; justify-content:space-between; width:100%; }
.brand { display:flex; align-items:center; gap:9px; font-weight:700; font-size:15px; letter-spacing:-0.02em; }
.brand .mark {
  width:22px; height:22px; border-radius:var(--r); flex-shrink:0;
  background:var(--text);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:12px; font-weight:700; color:var(--bg);
}
.nav-links { display:flex; align-items:center; gap:24px; }
.nav-links a { font-size:13.5px; color:var(--text-2); transition:color .15s; }
.nav-links a:hover { color:var(--text); }
.nav-links a[aria-current="page"] { color:var(--text); }
.btn {
  display:inline-flex; align-items:center; gap:7px;
  font-size:13.5px; font-weight:500; font-family:var(--sans);
  padding:8px 16px; border-radius:var(--r); cursor:pointer; border:1px solid transparent;
}
.btn { transition:background .15s, border-color .15s, transform .1s, box-shadow .3s var(--ease); }
.btn-primary { background:var(--signal); color:#FFFFFF; box-shadow:0 0 0 rgba(0,129,112,0); }   /* white on #008170 = 4.8:1 AA */
.btn-primary:hover { background:var(--border-2); box-shadow:0 6px 24px rgba(0,129,112,.35); }   /* white on #005B41 = 8.2:1; teal glow-ramp */
.nav-links a.btn-primary { color:#FFFFFF; }                 /* fix: .nav-links a used to outrank .btn-primary */
.btn-ghost { background:transparent; color:var(--text); border-color:var(--border-2); }
.btn-ghost:hover { background:var(--bg-hover); border-color:var(--text-3); }
.btn:active { transform:translateY(1px); }
.nav-toggle { display:none; }

/* ── HERO ── */
.hero { padding:150px 0 70px; position:relative; overflow:hidden; }
#heroHook { position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero .wrap { position:relative; z-index:1; display:grid; grid-template-columns:minmax(0,600px); gap:48px; align-items:center; }
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:12px; color:var(--text-2);
  border:1px solid var(--border); border-radius:9999px;
  padding:5px 13px; margin-bottom:24px;
}
.hero-tag .dot { width:6px; height:6px; border-radius:50%; background:var(--signal); box-shadow:0 0 7px var(--signal); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(0,129,112,.45);} 50%{opacity:.85;box-shadow:0 0 0 6px rgba(0,129,112,0);} }
.hero h1 { font-size:clamp(34px,5vw,56px); font-weight:800; color:var(--text-2); }
.hero h1 .key { color:var(--text); }
.hero-sub { margin-top:22px; font-size:17px; color:var(--text-2); max-width:520px; line-height:1.65; }
.hero-cta { margin-top:30px; display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.hero-note { margin-top:18px; font-family:var(--mono); font-size:11.5px; color:var(--text-3); }
/* hero-hook caption: revealed by the hook IIFE after the sweep (instant under reduced motion) */
.hook-cap { margin-top:14px; font-family:var(--mono); font-size:12px; color:var(--text-2); opacity:0; transform:translateY(8px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.hook-cap.in { opacity:1; transform:none; }
.hook-cap a { color:var(--text); text-decoration:underline; }

/* hero pipeline preview */
.pipe {
  background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:22px; position:relative; overflow:hidden;
}
.pipe-node {
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; border-radius:var(--r-lg);
  background:var(--bg-3); border:1px solid var(--border);
}
/* signal-travel: one teal signal walks WS→EN→G→API on a shared 2.8s clock,
   then rests ~0.7s before looping. Node N lights (ring + icon tint), hands
   off to connector N (top→bottom sweep), which delivers to node N+1.
   .pipe children are node(1) flow(2) node(3) flow(4) node(5) flow(6) node(7),
   so delays go by nth-child. Reduced-motion kills all of it (see media block). */
.pipe-node { animation:node-lit 2.8s var(--ease) infinite; }
.pipe-node .pipe-icon { animation:icon-lit 2.8s var(--ease) infinite; }
.pipe > :nth-child(1), .pipe > :nth-child(1) .pipe-icon { animation-delay:0s; }
.pipe > :nth-child(3), .pipe > :nth-child(3) .pipe-icon { animation-delay:.7s; }
.pipe > :nth-child(5), .pipe > :nth-child(5) .pipe-icon { animation-delay:1.4s; }
.pipe > :nth-child(7), .pipe > :nth-child(7) .pipe-icon { animation-delay:2.1s; }
@keyframes node-lit {
  0%   { border-color:var(--border); box-shadow:0 0 0 0 rgba(0,129,112,0); }
  6%   { border-color:var(--signal); box-shadow:0 0 0 3px rgba(0,129,112,.18), 0 0 14px rgba(0,129,112,.25); }
  16%  { border-color:var(--signal); box-shadow:0 0 0 2px rgba(0,129,112,.10), 0 0 10px rgba(0,129,112,.15); }
  30%, 100% { border-color:var(--border); box-shadow:0 0 0 0 rgba(0,129,112,0); }
}
@keyframes icon-lit {
  0%   { background:var(--bg-hover); color:var(--text-2); }
  6%   { background:rgba(0,129,112,.22); color:var(--text); }
  16%  { background:rgba(0,129,112,.14); color:var(--text); }
  30%, 100% { background:var(--bg-hover); color:var(--text-2); }
}
.pipe-icon {
  width:34px; height:34px; border-radius:var(--r); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:11px; font-weight:700;
  background:var(--bg-hover); color:var(--text-2);   /* resting; icon-lit tints toward teal */
}
.pipe-node .nm { font-size:13.5px; font-weight:600; }
.pipe-node .sb { font-size:11.5px; color:var(--text-3); margin-top:1px; }
.pipe-flow { width:2px; height:14px; margin:5px auto; background:var(--border-2); position:relative; overflow:hidden; }
.pipe-flow::after {
  content:''; position:absolute; inset:0;
  background:var(--signal); opacity:0;
  transform:scaleY(0); transform-origin:top;
  animation:flow-travel 2.8s var(--ease) infinite;
}
.pipe > :nth-child(2)::after { animation-delay:.35s; }
.pipe > :nth-child(4)::after { animation-delay:1.05s; }
.pipe > :nth-child(6)::after { animation-delay:1.75s; }
/* sweep reaches the bottom exactly as the next node's delay fires (+0.35s) */
@keyframes flow-travel {
  0%    { transform:scaleY(0); opacity:1; }
  12.5% { transform:scaleY(1); opacity:1; }
  24%   { transform:scaleY(1); opacity:0; }
  100%  { transform:scaleY(1); opacity:0; }
}

/* ── BAND ── */
.band { border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--bg-2); padding:30px 0; }
.band-head { font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:0.14em; color:var(--text-3); text-align:center; margin-bottom:20px; }
.band-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.band-item { text-align:center; }
.band-val { font-family:var(--mono); font-size:20px; font-weight:700; letter-spacing:-0.03em; }
.band-lbl { font-size:11px; color:var(--text-3); margin-top:4px; text-transform:uppercase; letter-spacing:0.05em; }

/* ── CARDS / PROBLEM ── */
.card { background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r-xl); padding:24px; transition:border-color .2s, transform .25s var(--ease), box-shadow .25s var(--ease); }
.card:hover { border-color:var(--border-2); }
.card.rv, .ps-card.rv, .gate.rv, .mod.rv { transition:opacity .5s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease), border-color .2s; }
/* hover-lift folded into the .lift primitive (see INTERACTION PRIMITIVES) */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.ps-card { padding:28px; border-radius:var(--r-xl); border:1px solid var(--border); transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .2s; }
.ps-card.problem { background:linear-gradient(135deg,var(--bg-2),rgba(239,68,68,0.04)); }
.ps-card.solution { background:linear-gradient(135deg,var(--bg-2),rgba(234,236,239,0.03)); }
.ps-icon { width:42px; height:42px; border-radius:var(--r-lg); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.ps-card.problem .ps-icon { background:rgba(239,68,68,0.12); color:var(--neg); }
.ps-card.solution .ps-icon { background:var(--bg-3); color:var(--text); }
.ps-card h3 { font-size:17px; margin-bottom:8px; }
.ps-card p { font-size:14px; color:var(--text-2); line-height:1.65; }
.card .k { font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-3); margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.card h3 { font-size:18px; margin-bottom:8px; }
.card p { font-size:14px; color:var(--text-2); line-height:1.6; }
.card .metric { margin-top:16px; padding-top:14px; border-top:1px solid var(--border); font-family:var(--mono); font-size:12.5px; color:var(--text-3); }
.card .metric b { color:var(--text); font-weight:600; }

/* ── GATES ── */
.gates-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.gates-grid > div { min-width:0; }
.gate { display:flex; gap:14px; padding:18px; background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r-lg); transition:border-color .2s, transform .25s var(--ease), box-shadow .25s var(--ease); min-width:0; }
.gate:hover { border-color:var(--border-2); }
.gate > div { min-width:0; }
.gate-num { width:38px; height:38px; flex-shrink:0; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:13px; font-weight:700; background:var(--bg-3); color:var(--text-2); }
.gate-name { font-size:14.5px; font-weight:600; margin-bottom:4px; }
.gate-desc { font-size:13px; color:var(--text-2); line-height:1.55; }

/* ── MODULES ── */
.mods { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.mod { background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r-xl); padding:24px; position:relative; transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .2s; }
.mod.big { grid-column:span 2; border-color:var(--border-2); }   /* featured: deep-green edge */
.mod-tag { font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-3); margin-bottom:12px; }
.mod h3 { font-size:17px; margin-bottom:8px; }
.mod p { font-size:13.5px; color:var(--text-2); line-height:1.65; }
.mod-detail { margin-top:16px; border-top:1px solid var(--border); padding-top:14px; }
.mod-row { display:flex; justify-content:space-between; align-items:baseline; padding:5px 0; font-size:12.5px; }
.mod-row .k { color:var(--text-3); }
.mod-row .v { font-family:var(--mono); color:var(--text); font-weight:500; }

/* ── TECH PILLS ── */
.tech { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.pill { display:inline-flex; align-items:center; gap:8px; padding:7px 14px; border-radius:9999px; background:var(--bg-2); border:1px solid var(--border); font-family:var(--mono); font-size:12px; color:var(--text-2); }
.pill .d { width:7px; height:7px; border-radius:50%; }

/* ── IS / ISN'T ── */
.role { display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--border); border-radius:var(--r-xl); overflow:hidden; margin-top:24px; }
.role-col { padding:26px; }
.role-col+.role-col { border-left:1px solid var(--border); }
.role-col h4 { font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:14px; }
.role-col.is h4 { color:var(--text); }
.role-col.isnt h4 { color:var(--neg); }
.role-col ul { list-style:none; }
.role-col li { font-size:14px; color:var(--text-2); padding:6px 0 6px 20px; position:relative; line-height:1.5; }
.role-col.is li::before { content:'✓'; position:absolute; left:0; color:var(--pos); font-weight:700; }
.role-col.isnt li::before { content:'✕'; position:absolute; left:0; color:var(--text-3); }

/* ── FOUNDER / MONTE CARLO ── */
.founder-layout { display:grid; grid-template-columns:340px 1fr; gap:18px; align-items:stretch; margin-top:34px; }
.mc-card { background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r-xl); padding:22px; display:flex; flex-direction:column; }   /* proof card: deep-green edge */
.mc-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:6px; flex-wrap:wrap; gap:8px; }
.mc-title { font-size:15px; font-weight:700; }
.mc-sub { font-size:12.5px; color:var(--text-3); font-family:var(--mono); }
.mc-canvas-wrap { position:relative; flex:1; min-height:280px; margin:10px 0 14px; }
.mc-canvas-wrap canvas { width:100%; height:100%; display:block; }
.mc-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; border-top:1px solid var(--border); padding-top:14px; }
.mc-stat .v { font-family:var(--mono); font-size:19px; font-weight:700; }
.mc-stat .l { font-size:10.5px; color:var(--text-3); text-transform:uppercase; letter-spacing:0.05em; margin-top:2px; }

/* ── MAKE-THE-CALL demo (Lightweight Charts, vendored) ── */
.demo-tabs { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.demo-tabs .btn { padding:7px 14px; font-size:12.5px; }
#mcChart { position:absolute; inset:0; }
.mc-overlay { position:absolute; inset:0; z-index:5; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; padding:20px; text-align:center; background:rgba(15,15,15,0.78); border-radius:var(--r); }
.mc-overlay[hidden] { display:none; }
.btn[hidden] { display:none !important; }   /* .btn's display beats the UA [hidden] rule otherwise */
.mc-q { font-size:16px; font-weight:600; max-width:440px; line-height:1.4; }
.mc-choices { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
@media (max-width:520px){
  .mc-q { font-size:14.5px; }
  .demo-tabs .btn { padding:6px 10px; font-size:11.5px; }
}

/* ── PROOF: monument + verified badges + live-save highlight (tokens only) ── */
.monument { font-family:var(--mono); font-weight:700; letter-spacing:-0.035em; font-size:clamp(34px,7vw,66px); line-height:1.02; margin:10px 0 0; }
.monument .mm-dot { color:var(--text-3); font-weight:400; margin:0 6px; }
.monument .pos { color:var(--pos); }
.monument-sub { display:inline-flex; align-items:center; gap:8px; margin-top:16px; font-family:var(--mono); font-size:13px; letter-spacing:0.08em; text-transform:uppercase; color:var(--pos); }
.monument-dollar { margin:14px 0 0; font-size:16px; color:var(--text-2); line-height:1.55; max-width:640px; }
.monument-dollar .num { font-family:var(--mono); font-weight:700; font-size:19px; color:var(--pos); }
.proof-badges { display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.vbadge { display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:9999px; background:var(--bg-2); border:1px solid var(--border); font-family:var(--mono); font-size:12px; color:var(--text-2); }
.vbadge svg { color:var(--pos); flex-shrink:0; }
.save-card { display:flex; gap:26px; align-items:center; margin-top:26px; padding:26px 30px; border-radius:var(--r-xl); background:linear-gradient(135deg,var(--bg-2),rgba(59,235,138,0.05)); border:1px solid var(--border-2); }
.save-num { font-family:var(--mono); font-weight:700; font-size:clamp(40px,7vw,62px); line-height:1; letter-spacing:-0.03em; color:var(--pos); flex-shrink:0; }
.save-body { flex:1; min-width:0; }
.save-lead { font-size:16px; font-weight:600; margin-bottom:6px; }
.save-lead span { color:var(--pos); font-family:var(--mono); }
.save-body p { font-size:14px; color:var(--text-2); line-height:1.6; }
.save-bar { margin-top:14px; display:flex; flex-direction:column; gap:8px; max-width:440px; }
.save-row { display:flex; align-items:center; gap:10px; }
.save-row-lbl { font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-3); width:58px; flex-shrink:0; text-align:right; }
.save-track { position:relative; flex:1; height:10px; border-radius:9999px; background:var(--bg-3); overflow:hidden; }
.save-fill { height:100%; border-radius:9999px; }
.save-fill.loss { background:var(--neg); opacity:0.72; }
.save-cut { font-family:var(--mono); font-size:10px; color:var(--pos); flex-shrink:0; }

/* ── TECH: "no server in the middle" placement diagram (tokens only) ── */
.placement { display:flex; align-items:stretch; gap:16px; margin-top:30px; padding:24px; border-radius:var(--r-xl); background:var(--bg-2); border:1px solid var(--border-2); }
.pl-side { flex:1; display:flex; flex-direction:column; align-items:center; text-align:center; gap:9px; padding:22px 16px; border-radius:var(--r-lg); background:var(--bg-3); border:1px solid var(--border); }
.pl-side.you { border-color:var(--border-2); }
.pl-ico { width:46px; height:46px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; background:var(--bg-2); color:var(--pos); }
.pl-name { font-weight:700; font-size:15px; }
.pl-chip { font-family:var(--mono); font-size:11px; color:var(--text-3); line-height:1.4; }
.pl-side.you .pl-chip { color:var(--pos); }
.pl-link { flex:0 0 auto; min-width:158px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; }
.pl-arrow { color:var(--signal); display:flex; }
.pl-link-lbl { font-family:var(--mono); font-size:10px; color:var(--text-2); text-transform:uppercase; letter-spacing:0.07em; text-align:center; }
.pl-ghost { display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px; color:var(--neg); border:1px dashed var(--neg); border-radius:9999px; padding:4px 10px; opacity:0.8; }
.pl-ghost .t { text-decoration:line-through; }
.pl-cap { margin-top:14px; font-size:13px; color:var(--text-3); max-width:660px; line-height:1.6; }

/* ── CALCULATOR: hero payoff comparison + collapsible bring-your-own-trades ── */
.calc-hero { display:flex; align-items:center; gap:16px; padding:18px 20px; margin-bottom:18px; border-radius:var(--r-lg); background:linear-gradient(135deg,var(--bg-3),rgba(59,235,138,0.05)); border:1px solid var(--border-2); flex-wrap:wrap; }
.ch-side { flex:1; min-width:104px; text-align:center; }
.ch-lbl { font-family:var(--mono); font-size:10.5px; text-transform:uppercase; letter-spacing:0.07em; color:var(--text-3); margin-bottom:5px; }
.ch-num { font-family:var(--mono); font-weight:700; font-size:clamp(26px,5vw,42px); line-height:1; letter-spacing:-0.02em; color:var(--text-2); }
.ch-num.pos { color:var(--pos); }
.ch-arrow { color:var(--signal); flex:0 0 auto; display:flex; align-items:center; }
.ch-delta { flex:0 0 auto; font-family:var(--mono); font-size:12px; font-weight:700; color:var(--pos); background:rgba(59,235,138,0.12); border:1px solid var(--border-2); border-radius:9999px; padding:6px 13px; white-space:nowrap; }
.ch-cap { flex-basis:100%; text-align:center; font-family:var(--mono); font-size:10.5px; color:var(--text-3); margin-top:2px; }
.calc-byot { margin-top:20px; border-top:1px solid var(--border); padding-top:14px; }
.calc-byot summary { cursor:pointer; list-style:none; display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-3); }
.calc-byot summary:hover { color:var(--text-2); }
.calc-byot summary::-webkit-details-marker { display:none; }
.calc-byot summary svg { color:var(--signal); flex-shrink:0; }
.calc-byot summary::after { content:'+'; margin-left:auto; color:var(--signal); font-size:15px; font-weight:700; line-height:1; transition:transform .2s var(--ease); }
.calc-byot[open] summary::after { transform:rotate(45deg); }
.calc-byot > *:not(summary) { margin-top:12px; }

/* ── HOME: value-band icons + optional proof nod ── */
.band-ico { display:flex; justify-content:center; margin-bottom:10px; color:var(--pos); }
.proof-nod { text-align:center; margin-top:24px; font-family:var(--mono); font-size:13px; color:var(--text-2); }
.proof-nod b { color:var(--pos); font-weight:700; }
.proof-nod a { color:var(--signal); text-decoration:none; white-space:nowrap; }
.proof-nod a:hover { text-decoration:underline; }

/* ── HOW: intro flow · gate clusters · setup stepper · module icons ── */
.flow3 { display:flex; align-items:stretch; gap:12px; margin-top:34px; }
.flow-step { flex:1; }
.flow-arrow { flex:0 0 auto; display:flex; align-items:center; color:var(--signal); }
.cluster-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:34px; }
.cluster { display:flex; flex-direction:column; }
.cluster-head { display:flex; gap:13px; align-items:flex-start; margin-bottom:16px; }
.cluster-ico { width:40px; height:40px; flex-shrink:0; border-radius:var(--r); background:var(--bg-3); border:1px solid var(--border-2); color:var(--signal); display:flex; align-items:center; justify-content:center; }
.cluster-out { font-size:16px; font-weight:700; letter-spacing:-0.01em; line-height:1.25; }
.cluster-sub { font-family:var(--mono); font-size:10.5px; text-transform:uppercase; letter-spacing:0.07em; color:var(--text-3); margin-top:5px; }
.cluster-gates { list-style:none; display:flex; flex-direction:column; gap:11px; }
.cluster-gates li { display:flex; gap:10px; align-items:flex-start; font-size:13px; color:var(--text-2); line-height:1.5; }
.cluster-gates .g { flex-shrink:0; font-family:var(--mono); font-size:10px; font-weight:700; color:var(--signal); background:var(--bg-3); border:1px solid var(--border); border-radius:var(--r-sm); padding:2px 6px; margin-top:1px; }
.cluster-gates b { color:var(--text); font-weight:600; }
.stepper { margin-top:34px; max-width:760px; }
.step { display:flex; gap:16px; position:relative; padding-bottom:22px; }
.step:last-child { padding-bottom:0; }
.step:not(:last-child)::before { content:''; position:absolute; left:17px; top:38px; bottom:2px; width:2px; background:var(--border-2); }
.step-num { width:36px; height:36px; flex-shrink:0; border-radius:9999px; background:var(--bg-3); border:1px solid var(--border-2); color:var(--signal); display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-weight:700; font-size:14px; position:relative; z-index:1; }
.step-name { font-weight:600; font-size:15px; }
.step-desc { font-size:13.5px; color:var(--text-2); line-height:1.55; margin-top:3px; }
.mod-ico { color:var(--signal); margin-bottom:12px; }
@media (max-width:880px){
  .flow3 { flex-direction:column; }
  .flow-arrow { transform:rotate(90deg); align-self:center; }
  .cluster-grid { grid-template-columns:1fr; }
}

/* ── FAQ ── */
.faq { max-width:760px; margin-top:20px; }
.faq details { border:1px solid var(--border); border-radius:var(--r-lg); background:var(--bg-2); margin-bottom:10px; overflow:hidden; transition:border-color .2s, background .2s; }
.faq details:hover { border-color:var(--border-2); }
.faq details[open] { border-color:var(--border-2); background:linear-gradient(135deg,var(--bg-2),var(--bg-3)); box-shadow:inset 3px 0 0 var(--signal); }
.faq summary { cursor:pointer; padding:16px 18px; font-size:14.5px; font-weight:600; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:12px; transition:color .15s; }
.faq summary:hover { color:var(--text); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:'+'; font-family:var(--mono); color:var(--signal); font-size:18px; font-weight:700; line-height:1; flex-shrink:0; transition:transform .2s var(--ease); }
.faq details[open] summary::after { transform:rotate(45deg); }
.faq details p { padding:0 18px 16px; font-size:14px; color:var(--text-2); line-height:1.65; }
.faq-more { display:flex; align-items:center; gap:5px; margin-top:12px; font-family:var(--mono); font-size:11.5px; color:var(--signal); }
.faq-more svg { flex-shrink:0; }
/* category groupings */
.faq-group { margin-top:30px; }
.faq-cat { display:flex; align-items:center; gap:10px; }
.faq-cat svg { color:var(--signal); flex-shrink:0; }
.faq-cat h2 { font-size:15px; font-weight:700; letter-spacing:-0.01em; margin:0; }
.faq-cat-intro { font-size:13px; color:var(--text-3); margin:5px 0 14px 30px; }
/* top reassurance row */
.reassure { display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.rchip { display:flex; align-items:center; gap:11px; padding:13px 16px; border-radius:var(--r-lg); background:var(--bg-2); border:1px solid var(--border); flex:1; min-width:230px; }
.rchip svg { color:var(--pos); flex-shrink:0; }
.rchip span { font-size:13px; color:var(--text-2); font-weight:500; line-height:1.35; }

/* ── WAITLIST / CTA / FOOTER ── */
.cta-card { background:linear-gradient(135deg,var(--bg-2),var(--bg-3)); border:1px solid var(--border-2); border-radius:var(--r-xl); padding:46px; text-align:center; position:relative; overflow:hidden; }
.cta-card::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% -20%, rgba(234,236,239,0.06), transparent 60%); pointer-events:none; }
.cta-card h2 { font-size:clamp(24px,3.4vw,36px); position:relative; }
.cta-card p { color:var(--text-2); margin:14px auto 0; max-width:460px; position:relative; }
.cta-actions { margin-top:28px; display:flex; gap:12px; justify-content:center; flex-wrap:wrap; position:relative; }
.wl-form { margin-top:28px; display:flex; gap:10px; justify-content:center; flex-wrap:wrap; position:relative; }
.wl-input {
  background:var(--bg); border:1px solid var(--border-2); color:var(--text);
  font-family:var(--sans); font-size:14px; padding:9px 14px;
  border-radius:var(--r); width:min(320px, 100%);
}
.wl-input::placeholder { color:var(--text-3); }
.wl-hp { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; pointer-events:none; }
.wl-msg { margin-top:14px; font-size:13.5px; position:relative; min-height:1.4em; }
.wl-msg.ok { color:var(--pos); }
.wl-msg.err { color:#F87171; }   /* lightened from --neg: #EF4444 is 3.7:1 on bg-2, #F87171 is 5.0:1 */
.wl-msg a { color:var(--text); text-decoration:underline; }
.wl-note { margin-top:16px; font-family:var(--mono); font-size:11px; color:var(--text-3); position:relative; }
/* SMS consent row (shown only when a phone number is entered) */
.wl-consent { width:100%; max-width:520px; margin:4px auto 0; display:flex; gap:9px; align-items:flex-start; text-align:left; font-size:12px; color:var(--text-2); line-height:1.5; }
.wl-consent[hidden] { display:none; }
.wl-consent input[type="checkbox"] { margin-top:2px; width:15px; height:15px; flex-shrink:0; accent-color:var(--signal); }
.wl-consent a { color:var(--text); text-decoration:underline; }
/* Discord link-out */
.wl-or { max-width:320px; margin:24px auto 0; display:flex; align-items:center; gap:12px; font-family:var(--mono); font-size:11px; color:var(--text-3); text-transform:uppercase; letter-spacing:0.1em; }
.wl-or::before, .wl-or::after { content:''; height:1px; flex:1; background:var(--border); }
.wl-discord { margin-top:16px; position:relative; }
.wl-discord .btn svg { margin-right:8px; flex-shrink:0; }
.footer { border-top:1px solid var(--border); padding:34px 0; }
.footer .wrap { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; }
.footer .fl { display:flex; flex-wrap:wrap; gap:12px 22px; font-size:13px; color:var(--text-2); }
.footer .fl a:hover { color:var(--text); }
.footer .meta { font-family:var(--mono); font-size:11px; color:var(--text-3); }

/* ── INTERACTION PRIMITIVES (one hover language, one reveal accent, one number treatment) ── */
.lift { transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .2s; }
@media (hover:hover) and (pointer:fine){
  .lift:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(0,0,0,0.45); border-color:var(--border-2); }
}
.trace { position:relative; }
.trace::before { content:''; position:absolute; left:0; top:14px; bottom:14px; width:2px; border-radius:2px; background:var(--signal); transform:scaleY(0); transform-origin:top; transition:transform .5s var(--ease) .15s; }
.js .trace.in::before { transform:scaleY(1); }
.pausable:hover, .pausable:focus-within { animation-play-state:paused; }

/* ── INTERACTIVE DEMOS (ticker, simulator, behavior demos) ── */
.ticker { border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--bg-2); overflow:hidden; padding:8px 0; }
.ticker-track { display:flex; gap:28px; width:max-content; font-family:var(--mono); font-size:12px; color:var(--text-2); animation:tickscroll 72s linear infinite; }
.ticker-track .tk { white-space:nowrap; color:var(--text-3); text-transform:uppercase; letter-spacing:0.1em; font-size:10.5px; align-self:center; }
.ticker-track a { display:inline-flex; align-items:center; white-space:nowrap; color:var(--text-2); padding:3px 8px; border-radius:var(--r-sm); transition:color .15s, background .15s; }
.ticker-track a:hover, .ticker-track a:focus-visible { color:var(--text); background:var(--bg-hover); }
.ticker-track .ev { color:var(--text-3); margin-right:6px; transition:color .15s; }
.ticker-track a:hover .ev, .ticker-track a:focus-visible .ev { color:var(--signal); }
@keyframes tickscroll { to { transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){
  .ticker-track { animation:none; width:auto; flex-wrap:wrap; }
  .ticker { overflow-x:auto; }
  .ticker-track .dup { display:none; }
}
.rule-stage { position:relative; margin-top:16px; height:60px; background:var(--bg-3); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.rule-gateline { position:absolute; left:58%; top:8px; bottom:8px; width:2px; background:var(--border-2); }
.rule-gateline::after { content:'GATE'; position:absolute; top:2px; left:8px; font-family:var(--mono); font-size:9px; letter-spacing:.1em; color:var(--text-3); }
.order-chip { position:absolute; left:12px; top:50%; margin-top:-15px; display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11.5px; color:var(--text-2); background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r); padding:6px 10px; opacity:0; transform:translateX(-20px); transition:transform .45s var(--ease), opacity .3s var(--ease); }
.rule-stage.play .order-chip { opacity:1; }
.rule-stage.reject { animation:ruleshake .3s var(--ease); }
@keyframes ruleshake { 25%{ transform:translateX(-4px); } 75%{ transform:translateX(4px); } }
.sim-readout { margin-top:10px; font-family:var(--mono); font-size:12px; color:var(--text-2); min-height:1.4em; }
.state-chip { display:inline-block; font-family:var(--mono); font-size:11px; padding:2px 8px; border-radius:9999px; margin-left:8px; }
.state-chip.ok { background:rgba(59,235,138,0.12); color:var(--pos); }
.state-chip.bad { background:rgba(239,68,68,0.12); color:var(--neg); }
.cfg.locked .cfg-input { opacity:.55; pointer-events:none; }
.cfg-actions { display:flex; align-items:center; gap:12px; margin-top:12px; flex-wrap:wrap; }
.cfg-actions .override { text-decoration:line-through; opacity:.6; cursor:not-allowed; }
.cfg-actions .cfg-reset { font-family:var(--mono); font-size:12px; color:var(--text-3); cursor:pointer; background:none; border:none; text-decoration:underline; padding:0; }
.cfg-actions .cfg-reset:hover { color:var(--text); }
.donut-row { display:flex; align-items:center; gap:18px; border-top:1px solid var(--border); padding-top:14px; margin-top:2px; flex-wrap:wrap; }
.donut-legend { font-family:var(--mono); font-size:11.5px; color:var(--text-2); display:flex; flex-direction:column; gap:4px; }
.donut-legend .sw { display:inline-block; width:9px; height:9px; border-radius:2px; margin-right:7px; }
.hist { display:flex; align-items:flex-end; gap:2px; height:90px; margin-top:14px; position:relative; border-bottom:1px solid var(--border); }
.hist .bar { flex:1; min-width:2px; border-radius:1px 1px 0 0; }
.hist .ref { position:absolute; top:-4px; bottom:-4px; width:1px; }
.hist-cap { font-family:var(--mono); font-size:10.5px; color:var(--text-3); margin-top:8px; }
.cov-row { display:flex; justify-content:space-between; align-items:center; gap:12px; padding:9px 0; border-bottom:1px solid var(--border); font-size:13px; color:var(--text-2); }
.cov-row:last-of-type { border-bottom:none; }
.cov-row .cv { font-family:var(--mono); font-size:12px; color:var(--text); text-align:right; }
.cov-row.off { opacity:.55; }
.cov-row.off .cv { color:var(--text-3); }
.trade-rows { font-family:var(--mono); font-size:11.5px; color:var(--text-2); margin-top:8px; }
.trade-rows div { padding:3px 6px; border-radius:var(--r-sm); display:flex; justify-content:space-between; gap:10px; }
.wl-file { font-size:12.5px; color:var(--text-2); margin:8px 0; }
.wl-error { font-family:var(--mono); font-size:12px; color:var(--neg); min-height:1.3em; margin-top:6px; }
.small-n { font-family:var(--mono); font-size:11.5px; color:var(--neg); margin-top:8px; }
.sim-head { display:flex; justify-content:space-between; align-items:baseline; gap:10px; flex-wrap:wrap; margin:12px 0 4px; }
.sim-k { font-family:var(--mono); font-size:11px; color:var(--text-3); text-transform:uppercase; letter-spacing:0.08em; }
/* ── #withwithout account-scale presets + scrub tooltip (chart upgrade) ── */
.scale-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:12px 0 4px; }
.scale-btns { display:flex; gap:8px; flex-wrap:wrap; }
.scale-btns .btn { padding:5px 12px; font-size:12.5px; }
.scale-btns .btn.active { background:var(--signal); color:#FFFFFF; border-color:var(--signal); }
.scale-note { font-family:var(--mono); font-size:11px; color:var(--text-3); margin:0 0 10px; }
.scrub-tip { position:absolute; z-index:2; pointer-events:none; transform:translate(-50%,-140%); background:var(--bg-3); border:1px solid var(--border); border-radius:var(--r-sm); padding:3px 7px; font-family:var(--mono); font-size:11px; color:var(--text); white-space:nowrap; opacity:0; transition:opacity .12s; }
.scrub-tip.show { opacity:1; }
.sim-val { font-family:var(--mono); font-size:13.5px; font-weight:700; }
.sim-slider { width:100%; accent-color:var(--signal); cursor:pointer; margin:2px 0 10px; }
.rule-demo { background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r-xl); padding:24px; }
.rule-btns { display:flex; flex-wrap:wrap; gap:10px; }
.rule-out { margin-top:16px; display:flex; align-items:center; gap:12px; padding:14px 16px; border-radius:var(--r-lg); background:var(--bg-3); border:1px solid var(--border); font-size:14px; color:var(--text-2); min-height:54px; }
.rule-out .x { width:26px; height:26px; flex-shrink:0; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:15px; background:rgba(239,68,68,0.12); color:var(--neg); opacity:0; transform:scale(.5); transition:opacity .25s var(--ease), transform .25s var(--ease); }
.rule-out.show .x { opacity:1; transform:scale(1); }
.rule-out.pause .x { background:rgba(0,129,112,0.15); color:var(--signal); }
.cfg-row { display:flex; justify-content:space-between; align-items:center; gap:12px; padding:9px 0; border-bottom:1px solid var(--border); font-size:13.5px; color:var(--text-2); }
.cfg-row:last-of-type { border-bottom:none; }
.cfg-input { background:var(--bg); border:1px solid var(--border-2); color:var(--text); font-family:var(--mono); font-size:13px; padding:6px 10px; border-radius:var(--r); width:130px; }
.cfg-lock { margin-top:12px; font-family:var(--mono); font-size:12px; color:var(--pos); opacity:0; transition:opacity .3s var(--ease); min-height:1.3em; }
.cfg-lock.show { opacity:1; }
.calc-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:18px; align-items:stretch; }
@media (max-width:880px){ .calc-grid { grid-template-columns:1fr; } }

/* ── reveal (scoped to .js so content stays visible without JavaScript) ── */
.js .rv { opacity:0; transform:translateY(16px); transition:opacity .55s var(--ease), transform .55s var(--ease); }
.js .rv.in { opacity:1; transform:none; }
.rv-d1 { transition-delay:.08s; } .rv-d2 { transition-delay:.16s; } .rv-d3 { transition-delay:.24s; }
.rv-d4 { transition-delay:.32s; } .rv-d5 { transition-delay:.4s; }   /* hero first-paint cascade tail */

/* ── responsive ── */
@media (max-width:880px){
  .nav-links { display:none; }
  .nav-links.open { display:flex; position:absolute; top:60px; left:0; right:0; flex-direction:column; background:var(--bg); border-bottom:1px solid var(--border); padding:18px 24px; gap:16px; }
  .nav-toggle { display:inline-flex; background:none; border:1px solid var(--border-2); color:var(--text); border-radius:var(--r); width:38px; height:34px; align-items:center; justify-content:center; cursor:pointer; }
  .hero .wrap { grid-template-columns:1fr; gap:36px; }
  .band-grid { grid-template-columns:1fr; gap:22px; }
  .grid-2 { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:1fr; }
  .grid-4 { grid-template-columns:1fr; }
  .gates-grid { grid-template-columns:1fr; }
  .mods { grid-template-columns:1fr; }
  .mod.big { grid-column:span 1; }
  .founder-layout { grid-template-columns:1fr; }
  .role { grid-template-columns:1fr; }
  .role-col+.role-col { border-left:none; border-top:1px solid var(--border); }
  .save-card { flex-direction:column; align-items:flex-start; gap:14px; }
  .placement { flex-direction:column; }
}
@media (max-width:520px){
  section { padding:60px 0; }
  .page-first { padding-top:120px; }
  .mc-stats { grid-template-columns:repeat(2,1fr); gap:16px; }
  .cta-card { padding:32px 22px; }
}
