/* ============================================================
   Yieldestate · Liquid Glass design system
   Apple visionOS / iOS Liquid Glass-inspired — brand palette
   ============================================================ */

:root{
  /* Paper background — clean white */
  --paper:#ffffff;
  --paper-2:#f6f7fb;
  --paper-3:#eceef5;

  /* Ink (text) */
  --ink:#0a0a0a;
  --ink-2:rgba(10,10,10,.72);
  --ink-3:rgba(10,10,10,.52);
  --ink-4:rgba(10,10,10,.30);

  /* Brand accents — single navy */
  --navy:#14213d;
  --navy-2:#1f2e57;
  --navy-soft:#d6dbe7;
  --navy-glow:rgba(20,33,61,.35);

  /* Legacy tokens (mapped to navy so any leftover refs still work) */
  --mint:var(--navy);
  --mint-2:var(--navy-2);
  --mint-soft:var(--navy-soft);
  --terracotta:var(--navy);
  --terracotta-2:var(--navy-2);
  --amber:var(--navy);

  /* Glass tokens — cool white-tinted glass over paper */
  --glass-bg:rgba(255,255,255,.55);
  --glass-bg-strong:rgba(255,255,255,.75);
  --glass-border:rgba(10,10,10,.08);
  --glass-border-strong:rgba(10,10,10,.16);
  --glass-highlight:rgba(255,255,255,.8);
  --glass-shadow:0 30px 60px -24px rgba(20,33,61,.18), 0 8px 20px -8px rgba(20,33,61,.10);
  --glass-inner-highlight: inset 0 1px 0 0 rgba(255,255,255,.85), inset 0 -1px 0 0 rgba(10,10,10,.04);
  /* hairline tokens (retained for any references) */
  --hair:rgba(10,10,10,.08);
  --hair-strong:rgba(10,10,10,.16);

  /* Chromatic edges — navy refraction (subtle) */
  --chroma-1: linear-gradient(135deg, rgba(20,33,61,.45), rgba(20,33,61,0) 35%, rgba(20,33,61,0) 65%, rgba(20,33,61,.45));
  --chroma-2: conic-gradient(from 220deg, rgba(255,255,255,.5), rgba(20,33,61,.35), rgba(255,255,255,.3), rgba(20,33,61,.35), rgba(255,255,255,.5));

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --maxw:1240px;

  /* Radii */
  --r-sm:14px;
  --r:22px;
  --r-lg:34px;
  --r-xl:48px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:'SF Pro Display','Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',sans-serif;
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  letter-spacing:-.01em;line-height:1.5;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--mint-soft);color:var(--ink)}

.serif{font-family:'New York','Times New Roman',serif;letter-spacing:-.025em}
.mono{font-family:'SF Mono','JetBrains Mono',ui-monospace,Menlo,Consolas,monospace}
.tabular{font-variant-numeric:tabular-nums}

/* ============================================================
   Paper background — clean white with subtle navy wash
   ============================================================ */
.cosmos{
  position:fixed;inset:0;z-index:-3;overflow:hidden;
  background:
    radial-gradient(80% 60% at 50% 0%, #f8faff 0%, transparent 60%),
    radial-gradient(60% 80% at 100% 100%, #eef1f8 0%, transparent 60%),
    var(--paper);
}
.cosmos::before,
.cosmos::after{
  content:"";position:absolute;border-radius:50%;filter:blur(160px);opacity:.22;mix-blend-mode:multiply;
  will-change:transform;
}
.cosmos::before{
  width:900px;height:900px;left:-10%;top:-20%;
  background:radial-gradient(circle, rgba(20,33,61,.5) 0%, transparent 60%);
  animation:cosmos-drift-1 28s var(--ease) infinite alternate;
}
.cosmos::after{
  width:800px;height:800px;right:-15%;top:30%;
  background:radial-gradient(circle, rgba(20,33,61,.35) 0%, transparent 60%);
  animation:cosmos-drift-2 32s var(--ease) infinite alternate;
}
.cosmos > .aurora-3{
  position:absolute;width:700px;height:700px;left:30%;bottom:-15%;
  background:radial-gradient(circle, rgba(20,33,61,.25) 0%, transparent 60%);
  border-radius:50%;filter:blur(180px);opacity:.3;mix-blend-mode:multiply;
  animation:cosmos-drift-3 36s var(--ease) infinite alternate;
}
@keyframes cosmos-drift-1{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(180px,120px,0) scale(1.1)}
}
@keyframes cosmos-drift-2{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-160px,80px,0) scale(1.08)}
}
@keyframes cosmos-drift-3{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(140px,-100px,0) scale(1.12)}
}

/* Grain layer — very subtle on white */
.cosmos-grain{
  position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.18;mix-blend-mode:multiply;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(10,10,10,.05) 1px, transparent 1px);
  background-size:3px 3px;
}

/* ============================================================
   The "Liquid Glass" panel — the core element
   ============================================================ */
.glass{
  position:relative;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:var(--r);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  backdrop-filter:blur(28px) saturate(180%);
  box-shadow:var(--glass-shadow), var(--glass-inner-highlight);
  overflow:hidden;
  isolation:isolate;
}
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:0;
  background:linear-gradient(180deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 35%, rgba(255,255,255,0) 65%, rgba(255,255,255,.04) 100%);
}
.glass::after{
  /* Specular highlight — the moving sheen */
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;
  background:radial-gradient(420px 220px at var(--mx,30%) var(--my,15%), rgba(255,255,255,.16), transparent 60%);
  opacity:.85;mix-blend-mode:overlay;transition:opacity .4s var(--ease);
}
.glass.is-strong{background:var(--glass-bg-strong);border-color:var(--glass-border-strong)}

/* Glass with chromatic edge (refraction) */
.glass.chroma{position:relative}
.glass.chroma::before{
  background:
    linear-gradient(180deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 35%, rgba(255,255,255,0) 65%, rgba(255,255,255,.04) 100%);
}
.glass.chroma > .chroma-edge{
  position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;z-index:2;
  padding:1px;
  background:var(--chroma-1);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  opacity:.85;
}
.glass.chroma > .chroma-edge.conic{
  background:var(--chroma-2);
  opacity:.55;
  animation:chroma-spin 18s linear infinite;
}
@keyframes chroma-spin{
  to{filter:hue-rotate(360deg)}
}

/* Inner content placeholder so chroma/specular stay below text */
.glass > *{position:relative;z-index:3}

/* ============================================================
   Sticky glass nav
   ============================================================ */
.nav-shell{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);
  z-index:80;width:min(960px, calc(100% - 32px));
}
.nav-glass{
  display:flex;align-items:center;gap:8px;padding:8px 10px 8px 18px;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(10,10,10,.08);
  border-radius:999px;
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  backdrop-filter:blur(24px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85);
}
.nav-brand{display:flex;align-items:center;gap:10px;padding:4px 10px;font-size:14px;font-weight:600;letter-spacing:-.005em;color:var(--ink)}
.nav-brand .mark{
  width:22px;height:22px;border-radius:7px;
  background:linear-gradient(180deg,var(--navy-2),var(--navy));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.4), 0 0 12px rgba(20,33,61,.4);
}
.nav-brand .logo{
  height:36px;width:auto;display:block;
}
.nav-links{display:flex;align-items:center;justify-content:center;gap:2px;margin-left:8px;flex:1}
.nav-links a{
  padding:8px 14px;border-radius:999px;font-size:13.5px;color:var(--ink-2);
  transition:color .2s var(--ease),background .25s var(--ease);
}
.nav-links a:hover{color:var(--ink);background:rgba(10,10,10,.05)}
.nav-links a.active{color:var(--ink);background:rgba(10,10,10,.07)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;padding:9px 16px;
  border-radius:999px;font-size:13.5px;font-weight:600;
  background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;
  box-shadow:0 6px 18px -6px rgba(20,33,61,.5), inset 0 1px 0 rgba(255,255,255,.18);
  transition:transform .2s var(--ease),box-shadow .25s var(--ease);
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 12px 28px -8px rgba(20,33,61,.6)}
.nav-cta .arrow{transition:transform .25s var(--spring)}
.nav-cta:hover .arrow{transform:translateX(3px)}

/* Hamburger — hidden on desktop, shown < 640px */
.nav-burger{
  display:none;flex:none;width:40px;height:40px;border-radius:999px;
  align-items:center;justify-content:center;
  background:rgba(255,255,255,.6);border:1px solid rgba(10,10,10,.10);
  -webkit-backdrop-filter:blur(18px) saturate(180%);backdrop-filter:blur(18px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  transition:background .25s var(--ease),transform .2s var(--ease);
}
.nav-burger:hover{background:rgba(255,255,255,.85)}
.nav-burger:active{transform:scale(.94)}
.nav-burger span{
  position:relative;display:block;width:17px;height:1.6px;border-radius:2px;background:var(--ink);
  transition:transform .35s var(--spring),opacity .2s var(--ease);
}
.nav-burger span::before,.nav-burger span::after{
  content:"";position:absolute;left:0;width:100%;height:100%;border-radius:2px;background:inherit;
  transition:transform .35s var(--spring),opacity .2s var(--ease);
}
.nav-burger span::before{top:-5.5px}
.nav-burger span::after{top:5.5px}
body.menu-open .nav-burger span{transform:rotate(45deg)}
body.menu-open .nav-burger span::before{top:0;transform:rotate(0)}
body.menu-open .nav-burger span::after{top:0;transform:rotate(90deg)}

/* Mobile drawer */
.nav-drawer{
  position:fixed;inset:0;z-index:79;display:flex;align-items:flex-start;justify-content:center;
  padding:96px 16px 0;opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease);
}
.nav-drawer::before{
  content:"";position:absolute;inset:0;background:rgba(246,247,251,.55);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
}
.nav-drawer .panel{
  position:relative;width:100%;max-width:420px;padding:14px;border-radius:var(--r-lg);
  background:rgba(255,255,255,.82);border:1px solid rgba(10,10,10,.10);
  -webkit-backdrop-filter:blur(28px) saturate(180%);backdrop-filter:blur(28px) saturate(180%);
  box-shadow:0 30px 60px -24px rgba(20,33,61,.28), inset 0 1px 0 rgba(255,255,255,.85);
  transform:translateY(-14px) scale(.98);opacity:0;
  transition:transform .4s var(--spring),opacity .3s var(--ease);
}
body.menu-open .nav-drawer{opacity:1;pointer-events:auto}
body.menu-open .nav-drawer .panel{transform:none;opacity:1}
.nav-drawer a{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-radius:var(--r);font-size:18px;font-weight:500;color:var(--ink);
  transition:background .2s var(--ease);
}
.nav-drawer a:hover,.nav-drawer a:active{background:rgba(10,10,10,.05)}
.nav-drawer a + a{margin-top:2px}
.nav-drawer a .arrow{color:var(--ink-3);font-size:15px}
.nav-drawer .drawer-cta{
  margin-top:8px;justify-content:center;gap:8px;color:#fff;font-weight:600;
  background:linear-gradient(180deg,var(--navy-2),var(--navy));
  box-shadow:0 10px 24px -8px rgba(20,33,61,.5), inset 0 1px 0 rgba(255,255,255,.18);
}
.nav-drawer .drawer-cta:hover{background:linear-gradient(180deg,var(--navy-2),var(--navy))}
.nav-drawer .drawer-cta .arrow{color:rgba(255,255,255,.7)}

/* Scroll progress bar */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:100%;z-index:90;transform-origin:0 50%;
  transform:scaleX(0);
  background:linear-gradient(90deg,var(--navy-2),var(--navy));
  box-shadow:0 0 12px var(--navy-glow);
  transition:transform .1s linear;
}

/* ============================================================
   Wrap + typography
   ============================================================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:500;
  padding:6px 12px;background:rgba(255,255,255,.6);border:1px solid rgba(10,10,10,.08);border-radius:999px;
}
.eyebrow .pulse{width:6px;height:6px;border-radius:50%;background:var(--navy);box-shadow:0 0 12px var(--navy-glow)}

h1.display{
  font-size:clamp(56px,9vw,128px);
  line-height:.94;letter-spacing:-.035em;font-weight:600;margin:0;color:var(--ink);
  text-wrap:balance;
}
h1.display em{
  font-style:italic;
  color:var(--navy);
}
h2.title{
  font-size:clamp(40px,5.5vw,72px);
  line-height:1.02;letter-spacing:-.028em;font-weight:600;margin:0;color:var(--ink);
  text-wrap:balance;
}
h2.title em{
  font-style:italic;
  color:var(--navy);
}
h3.sub{font-size:clamp(22px,2.2vw,28px);line-height:1.15;letter-spacing:-.015em;font-weight:600;margin:0}

.lead{font-size:clamp(17px,1.4vw,20px);color:var(--ink-2);line-height:1.55;max-width:680px}
.muted{color:var(--ink-3)}

/* ============================================================
   Buttons (Liquid Glass family)
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:14px 22px;
  border-radius:999px;font-size:15px;font-weight:600;letter-spacing:-.005em;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);
  position:relative;isolation:isolate;
}
.btn .arrow{transition:transform .25s var(--spring)}
.btn:hover .arrow{transform:translateX(4px)}
.btn:hover{transform:translateY(-1px)}

.btn-primary{
  background:linear-gradient(180deg,var(--navy-2),var(--navy) 50%,#0c172d);color:#fff;
  box-shadow:0 14px 32px -10px rgba(20,33,61,.45), inset 0 1px 0 rgba(255,255,255,.18), inset 0 -1px 0 rgba(0,0,0,.3);
}
.btn-primary:hover{box-shadow:0 20px 44px -12px rgba(20,33,61,.6), inset 0 1px 0 rgba(255,255,255,.2)}

.btn-glass{
  background:rgba(255,255,255,.7);color:var(--ink);
  border:1px solid rgba(10,10,10,.12);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  backdrop-filter:blur(18px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 6px 16px -8px rgba(20,33,61,.15);
}
.btn-glass:hover{background:rgba(255,255,255,.9);border-color:rgba(10,10,10,.2)}

.btn-mint{
  background:linear-gradient(140deg,var(--navy-2),var(--navy));color:#fff;
  box-shadow:0 18px 40px -10px rgba(20,33,61,.5), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-mint:hover{box-shadow:0 24px 56px -12px rgba(20,33,61,.65)}

/* ============================================================
   Hero shell
   ============================================================ */
.hero{position:relative;padding:160px 0 96px;text-align:center;overflow:hidden}
.hero-orb{
  position:absolute;left:50%;top:60%;transform:translate(-50%,-50%);
  width:min(720px,80vw);aspect-ratio:1;border-radius:50%;
  background:
    radial-gradient(closest-side, rgba(20,33,61,.32), rgba(20,33,61,0) 70%),
    radial-gradient(closest-side at 30% 30%, rgba(20,33,61,.22), transparent 70%);
  filter:blur(80px);opacity:.5;pointer-events:none;z-index:0;mix-blend-mode:multiply;
  animation:orb-breathe 10s var(--ease) infinite alternate;
}
@keyframes orb-breathe{
  0%{transform:translate(-50%,-50%) scale(1)}
  100%{transform:translate(-50%,-50%) scale(1.08)}
}
.hero-inner{position:relative;z-index:2}
.hero-actions{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:36px}
.hero-meta{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:72px;
}
.chip{
  display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;
  background:rgba(255,255,255,.65);border:1px solid rgba(10,10,10,.08);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  backdrop-filter:blur(18px) saturate(180%);
  font-size:13px;color:var(--ink-2);
}
.chip{transition:transform .3s var(--spring),box-shadow .3s var(--ease),background .25s var(--ease)}
.chip:hover{transform:translateY(-2px);background:rgba(255,255,255,.85);box-shadow:0 12px 28px -14px rgba(20,33,61,.3)}
.chip .k{color:var(--ink-3)}
.chip .v{color:var(--ink);font-weight:500}
.chip i.dot{width:6px;height:6px;border-radius:50%;background:var(--navy);box-shadow:0 0 10px var(--navy-glow);animation:dot-pulse 2.6s var(--ease) infinite}
@keyframes dot-pulse{0%,100%{box-shadow:0 0 6px var(--navy-glow)}50%{box-shadow:0 0 16px var(--navy-glow)}}

/* ============================================================
   Floating glass shapes in hero
   ============================================================ */
.hero-floats{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-floats .float{
  position:absolute;border-radius:30%;
  background:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.6);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  box-shadow:0 20px 50px -20px rgba(20,33,61,.35), inset 0 1px 0 rgba(255,255,255,.9);
  opacity:.55;will-change:transform;
}
.hero-floats .f1{width:54px;height:54px;left:12%;top:24%;animation:float-a 14s var(--ease) infinite alternate}
.hero-floats .f2{width:34px;height:34px;left:82%;top:18%;border-radius:50%;animation:float-b 18s var(--ease) infinite alternate}
.hero-floats .f3{width:78px;height:78px;left:74%;top:62%;animation:float-c 22s var(--ease) infinite alternate}
.hero-floats .f4{width:26px;height:26px;left:22%;top:70%;border-radius:50%;animation:float-b 16s var(--ease) infinite alternate-reverse}
.hero-floats .f5{width:44px;height:44px;left:50%;top:8%;animation:float-a 20s var(--ease) infinite alternate-reverse}
@keyframes float-a{0%{transform:translate(0,0) rotate(0deg)}100%{transform:translate(24px,-34px) rotate(18deg)}}
@keyframes float-b{0%{transform:translate(0,0)}100%{transform:translate(-30px,28px)}}
@keyframes float-c{0%{transform:translate(0,0) rotate(0deg)}100%{transform:translate(-26px,-30px) rotate(-14deg)}}

/* ============================================================
   Animated fee → USDC → SPV → rent flow rail  (SVG-driven)
   Nodes sit at 8% / 36% / 64% / 92%; the wire spans 8%→92% so
   it begins and ends exactly at the first and last orb centers.
   ============================================================ */
.flow-rail{margin:72px auto 0;max-width:720px;padding:0;position:relative}
.flow-track{position:relative;height:96px}

/* SVG wire spans the full track; orb radius ~31px keeps the line behind centers */
.flow-svg{
  position:absolute;left:0;top:0;width:100%;height:64px;overflow:visible;z-index:1;
}
.flow-svg .wire-base{
  stroke:rgba(20,33,61,.14);stroke-width:2;stroke-linecap:round;
  stroke-dasharray:2 8;
}
.flow-svg .wire-draw{
  stroke-width:2.5;stroke-linecap:round;
  stroke-dasharray:840;stroke-dashoffset:840;
  filter:drop-shadow(0 0 5px rgba(31,46,87,.4));
}
.flow-svg .wire-dot{
  fill:#fff;opacity:0;
  filter:drop-shadow(0 0 4px #fff) drop-shadow(0 0 10px var(--navy-2));
}

/* Nodes — absolutely placed so the wire truly threads their centers */
.flow-node{
  position:absolute;top:0;left:var(--x);transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:14px;width:auto;
}
.flow-node .fn-orb{
  position:relative;width:62px;height:62px;border-radius:20px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(155deg,#2e4076,var(--navy) 55%,#0d1830);
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,.32),
    inset 0 -2px 5px rgba(0,0,0,.3),
    0 12px 28px -12px rgba(20,33,61,.55);
  transition:transform .55s var(--spring),box-shadow .45s var(--ease);
}
/* glossy diagonal sheen */
.flow-node .fn-orb::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(152deg,rgba(255,255,255,.4) 0%,rgba(255,255,255,0) 42%);
  opacity:.85;
}
.flow-node .fn-orb svg{position:relative;z-index:1;opacity:.92;transition:opacity .35s var(--ease)}
.flow-node .fn-label{font-size:13px;color:var(--ink-3);font-weight:500;letter-spacing:-.005em;transition:color .4s var(--ease),font-weight .1s}

/* lit state — clean lift + soft brand glow as the wire reaches the node */
.flow-node.lit .fn-orb{
  transform:translateY(-8px) scale(1.07);
  background:linear-gradient(155deg,#3a4f8c,#28386a 55%,#101d3a);
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,.42),
    inset 0 -2px 5px rgba(0,0,0,.3),
    0 24px 44px -14px rgba(20,33,61,.7),
    0 0 28px -2px rgba(58,79,140,.5);
}
.flow-node.lit .fn-orb svg{opacity:1}
.flow-node.lit .fn-label{color:var(--ink);font-weight:600}

@media (max-width:560px){
  .flow-track{height:84px}
  .flow-svg{height:56px}
  .flow-node .fn-orb{width:52px;height:52px;border-radius:17px}
  .flow-node .fn-orb svg{width:18px;height:18px}
  .flow-node .fn-label{font-size:11.5px}
}

/* ============================================================
   Next-airdrop countdown timer
   ============================================================ */
.timer-panel{
  padding:48px 40px 44px;border-radius:var(--r-xl);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.timer-clock{
  display:inline-flex;align-items:flex-start;gap:6px;
  font-variant-numeric:tabular-nums;
}
.tc-block{display:inline-flex;flex-direction:column;align-items:center;gap:8px}
.tc-num{
  display:block;min-width:1.7em;padding:14px 18px;border-radius:20px;
  font-size:clamp(48px,9vw,108px);font-weight:600;line-height:1;letter-spacing:-.03em;
  color:#fff;background:linear-gradient(155deg,#2e4076,var(--navy) 55%,#0d1830);
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.28),
    inset 0 -3px 6px rgba(0,0,0,.32),
    0 24px 50px -18px rgba(20,33,61,.6);
}
.tc-lbl{
  font-family:'SF Mono','JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-3);font-weight:500;
}
.tc-sep{
  font-size:clamp(40px,7vw,84px);font-weight:600;line-height:1;color:var(--navy);
  padding-top:.16em;animation:tc-blink 1s steps(1) infinite;
}
@keyframes tc-blink{0%,49%{opacity:1}50%,100%{opacity:.25}}
/* subtle pulse on the whole clock as it ticks */
.timer-clock.tick .tc-num{animation:tc-pulse .4s var(--ease)}
@keyframes tc-pulse{0%{transform:translateY(0)}40%{transform:translateY(-3px)}100%{transform:translateY(0)}}
.timer-note{
  max-width:560px;margin:4px 0 0;color:var(--ink-2);font-size:15.5px;line-height:1.6;
}
.timer-note strong{color:var(--ink);font-weight:600}
@media (max-width:560px){
  .timer-panel{padding:36px 22px}
  .tc-num{padding:10px 12px;border-radius:16px}
}

/* ============================================================
   Section shell
   ============================================================ */
section.bay{position:relative;padding:120px 0;overflow:hidden}
.bay-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;margin-bottom:64px}
.bay-head .lead{margin:0 auto}

/* ============================================================
   Glass cards grid (flow / what we buy)
   ============================================================ */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.card{padding:28px;border-radius:var(--r-lg);min-height:260px;display:flex;flex-direction:column;gap:14px;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .35s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 44px 80px -30px rgba(20,33,61,.30), 0 12px 28px -10px rgba(20,33,61,.14), var(--glass-inner-highlight);border-color:var(--glass-border-strong)}
.card:hover .icon{transform:translateY(-2px) scale(1.04)}
.card .icon{transition:transform .4s var(--spring)}
.card:hover .chroma-edge{opacity:1}
.card .step-num{
  font-family:'SF Mono',monospace;font-size:12px;color:var(--ink-3);letter-spacing:.08em;
}
.card h3{margin:0;font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--ink)}
.card p{margin:0;color:var(--ink-2);font-size:15px;line-height:1.55}
.card .icon{
  width:48px;height:48px;border-radius:14px;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(180deg,var(--navy-2),var(--navy));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2),inset 0 -1px 0 rgba(0,0,0,.2),0 8px 20px -10px rgba(20,33,61,.5);
}
.card .icon.mint,.card .icon.terracotta,.card .icon.amber{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff}
.card .footer-tag{
  margin-top:auto;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;
  background:rgba(255,255,255,.65);border:1px solid rgba(10,10,10,.08);border-radius:999px;
  font-family:'SF Mono',monospace;font-size:11px;color:var(--ink-3);align-self:flex-start;
}

/* ============================================================
   Big stat / treasury panel
   ============================================================ */
.stat-panel{padding:48px;border-radius:var(--r-xl);}
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-bottom:1px solid rgba(10,10,10,.08)}
.stat-row:last-child{border-bottom:0}
.stat-row .k{color:var(--ink-2);font-size:15px}
.stat-row .v{font-family:'SF Mono',monospace;font-size:17px;color:var(--ink);font-weight:500}
.stat-row .v.mint{color:var(--navy)}
.stat-bar{height:10px;border-radius:999px;background:rgba(10,10,10,.06);overflow:hidden;display:flex;margin-top:24px;box-shadow:inset 0 1px 0 rgba(255,255,255,.4)}
.stat-bar span{display:block;height:100%;transform:scaleX(0);transform-origin:0 50%;transition:transform 1.1s var(--ease)}
.stat-bar span:nth-child(2){transition-delay:.12s}
.stat-bar span:nth-child(3){transition-delay:.24s}
.reveal.in .stat-bar span,.stat-bar.fill span{transform:scaleX(1)}
.stat-legend{display:flex;flex-wrap:wrap;gap:18px;margin-top:18px;font-size:12.5px;color:var(--ink-2)}
.stat-legend .sw{display:inline-flex;align-items:center;gap:8px}
.stat-legend .sw i{width:10px;height:10px;border-radius:3px}

/* ============================================================
   Animated treasury allocation donut
   ============================================================ */
.alloc-panel{padding:44px 48px;border-radius:var(--r-xl)}
.alloc-eyebrow{
  font-family:'SF Mono','JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:28px;
}
.alloc-chart-wrap{display:flex;align-items:center;gap:36px}

.donut{position:relative;flex:none;width:172px;height:172px}
.donut svg{width:100%;height:100%;transform:rotate(-90deg)}
.donut-track{fill:none;stroke:rgba(20,33,61,.08);stroke-width:13}
.donut-arc{
  fill:none;stroke-width:13;stroke-linecap:round;
  /* dasharray / dashoffset are computed and animated in glass.js (C = 2π·52 ≈ 326.73) */
}
.donut-center{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  text-align:center;pointer-events:none;
}
.donut-big{font-size:34px;font-weight:600;letter-spacing:-.03em;color:var(--ink);line-height:1}
.donut-sub{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:500}

.alloc-legend{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:column;gap:4px}
.alloc-legend li{
  display:flex;align-items:center;gap:12px;padding:13px 12px;border-radius:14px;
  cursor:default;transition:background .25s var(--ease),transform .25s var(--ease);
  border-bottom:1px solid rgba(10,10,10,.06);
}
.alloc-legend li:last-child{border-bottom:0}
.alloc-legend li:hover{background:rgba(20,33,61,.04);transform:translateX(2px)}
.alloc-legend .dotc{
  flex:none;width:12px;height:12px;border-radius:4px;background:var(--c);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--c) 18%, transparent);
}
.alloc-legend .lbl{flex:1;font-size:14.5px;color:var(--ink-2);line-height:1.3}
.alloc-legend .lbl em{font-style:normal;color:var(--ink-3);font-size:13px}
.alloc-legend .pct{font-family:'SF Mono','JetBrains Mono',monospace;font-size:16px;font-weight:500;color:var(--ink)}

/* hover a legend row → emphasise its arc, dim the others */
.alloc-chart-wrap.has-focus .donut-arc{opacity:.28}
.donut-arc.focus{opacity:1 !important;stroke-width:16}

@media (max-width:560px){
  .alloc-panel{padding:32px 26px}
  .alloc-chart-wrap{flex-direction:column;gap:24px}
  .donut{width:160px;height:160px}
}

/* ============================================================
   Two-column "what we buy"
   ============================================================ */
ul.tick{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:12px}
ul.tick li{display:flex;gap:14px;color:var(--ink-2);font-size:15.5px;line-height:1.55}
ul.tick li .mk{
  flex:none;width:24px;height:24px;border-radius:8px;display:grid;place-items:center;
  font-size:12px;font-weight:700;margin-top:1px;
}
ul.tick li.yes .mk{background:var(--navy);color:#fff}
ul.tick li.no .mk{background:rgba(10,10,10,.08);color:var(--ink-3)}
ul.tick li strong{color:var(--ink);font-weight:600}

/* ------------------------------------------------------------
   Animated ownership diagram (fee → vault → SPV shares → rent back)
   ------------------------------------------------------------ */
.own-diagram{margin:0 auto 56px;max-width:860px}
.od-stage{position:relative;width:100%;aspect-ratio:1000/420}
.od-wires{position:absolute;inset:0;width:100%;height:100%;z-index:1;overflow:visible}
.od-path{stroke:rgba(20,33,61,.18);stroke-width:2;stroke-linecap:round;stroke-dasharray:5 7}
.od-rent{stroke:rgba(31,46,87,.28);stroke-width:1.6;stroke-dasharray:2 7;fill:none}
.od-tok{fill:#1f2e57;filter:drop-shadow(0 0 5px var(--navy-glow))}
.od-tok.fee{fill:#2a3c6e}
.od-rent-tok{fill:#3a4f8c;filter:drop-shadow(0 0 6px rgba(58,79,140,.6))}

/* nodes positioned to match SVG coordinates (viewBox 1000×420) */
.od-node{position:absolute;z-index:2;display:flex;justify-content:center}
.od-fee{left:50%;top:0;transform:translate(-50%,-4%)}
.od-vault{left:50%;top:30%;transform:translate(-50%,-12%);width:min(60%,300px)}
.od-spv{top:80%;transform:translate(-50%,-30%);width:min(30%,190px)}
.od-spv.s1{left:17%}
.od-spv.s2{left:50%}
.od-spv.s3{left:83%}

/* fee chip */
.od-chip{
  display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;font-size:13.5px;font-weight:600;
  box-shadow:0 10px 24px -8px rgba(20,33,61,.5),inset 0 1px 0 rgba(255,255,255,.2);
  animation:od-fee-bob 3s var(--ease) infinite;
}
.od-chip .od-coin{font-style:normal;font-size:15px;opacity:.85}
@keyframes od-fee-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* central vault */
.od-vault-card{
  width:100%;padding:20px 22px;border-radius:24px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  box-shadow:var(--glass-shadow),var(--glass-inner-highlight),0 0 0 1px rgba(20,33,61,.06);
  animation:od-vault-glow 4s var(--ease) infinite;
}
.od-vlogo{
  width:42px;height:42px;border-radius:13px;display:grid;place-items:center;margin-bottom:6px;
  background:linear-gradient(155deg,#2e4076,var(--navy));color:#fff;font-size:20px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 10px 22px -10px rgba(20,33,61,.6);
  overflow:hidden;
}
.od-vlogo img{width:24px;height:24px;object-fit:contain;display:block}
.od-vname{font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.od-vmeta{font-family:'SF Mono','JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.08em;color:var(--ink-3);text-transform:uppercase}
@keyframes od-vault-glow{
  0%,100%{box-shadow:var(--glass-shadow),var(--glass-inner-highlight),0 0 0 1px rgba(20,33,61,.06)}
  50%{box-shadow:var(--glass-shadow),var(--glass-inner-highlight),0 0 0 1px rgba(20,33,61,.18),0 0 30px -4px rgba(31,46,87,.3)}
}

/* SPV deed cards */
.od-deed{
  width:100%;padding:14px 14px 15px;border-radius:18px;
  background:rgba(255,255,255,.7);border:1px solid rgba(10,10,10,.08);
  -webkit-backdrop-filter:blur(16px) saturate(180%);backdrop-filter:blur(16px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 14px 28px -16px rgba(20,33,61,.3);
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;color:var(--navy);
  transition:transform .4s var(--spring),box-shadow .4s var(--ease);
  animation:od-deed-bob 5s var(--ease) infinite;
}
.od-spv.s2 .od-deed{animation-delay:-1.6s}
.od-spv.s3 .od-deed{animation-delay:-3.2s}
@keyframes od-deed-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.od-deed svg{color:var(--navy);margin-bottom:4px}
.od-deed-t{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.1}
.od-deed-s{font-size:11.5px;color:var(--ink-3)}

.od-rent-label{
  position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);z-index:2;
  font-family:'SF Mono','JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;
  color:var(--navy);opacity:.75;
}

/* gate the travelling tokens behind reveal so they don't run offscreen pre-scroll */
.own-diagram:not(.in) .od-tok,
.own-diagram:not(.in) .od-rent-tok{opacity:0}
.own-diagram.in .od-tok,
.own-diagram.in .od-rent-tok{opacity:1;transition:opacity .6s var(--ease)}

@media (max-width:640px){
  .od-stage{aspect-ratio:1000/520}
  .od-vname{font-size:14px}
  .od-deed-t{font-size:12px}
  .od-deed-s{font-size:10.5px}
  .od-vault{top:28%}
  .od-spv{top:82%}
}

/* ------------------------------------------------------------
   Animated "What we actually own" — staggered reveal + stamping marks
   ------------------------------------------------------------ */
/* hide the literal ✓ / × glyphs; we draw SVG marks instead */
#owns ul.tick li .mk{font-size:0;position:relative;overflow:visible}
#owns ul.tick li .mk::after{
  content:"";position:absolute;inset:0;background:no-repeat center/13px 13px;
}
#owns ul.tick li.yes .mk::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E");
}
#owns ul.tick li.no .mk::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239aa0ad' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M6 6l12 12M18 6L6 18'/%3E%3C/svg%3E");
}

/* each row starts offset; the card's .reveal.in releases them in sequence */
#owns ul.tick li{
  opacity:0;transform:translateX(-12px);
  padding:4px 6px;margin:0 -6px;border-radius:10px;
  transition:opacity .55s var(--ease),transform .55s var(--ease),background .2s var(--ease);
}
#owns ul.tick li .mk{
  transform:scale(.2) rotate(-25deg);
  transition:transform .5s var(--spring) .08s;
}
#owns .reveal.in ul.tick li{opacity:1;transform:none}
#owns .reveal.in ul.tick li .mk{transform:scale(1) rotate(0)}
/* stagger via per-item delay */
#owns ul.tick li:nth-child(1){transition-delay:.05s}
#owns ul.tick li:nth-child(1) .mk{transition-delay:.18s}
#owns ul.tick li:nth-child(2){transition-delay:.16s}
#owns ul.tick li:nth-child(2) .mk{transition-delay:.29s}
#owns ul.tick li:nth-child(3){transition-delay:.27s}
#owns ul.tick li:nth-child(3) .mk{transition-delay:.40s}
#owns ul.tick li:nth-child(4){transition-delay:.38s}
#owns ul.tick li:nth-child(4) .mk{transition-delay:.51s}

/* yes-mark gets a soft ring pop when it lands */
#owns ul.tick li.yes .mk{box-shadow:0 0 0 0 var(--navy-glow)}
#owns .reveal.in ul.tick li.yes .mk{animation:mk-pop .7s var(--ease) both}
#owns .reveal.in ul.tick li.yes:nth-child(1) .mk{animation-delay:.18s}
#owns .reveal.in ul.tick li.yes:nth-child(2) .mk{animation-delay:.29s}
#owns .reveal.in ul.tick li.yes:nth-child(3) .mk{animation-delay:.40s}
#owns .reveal.in ul.tick li.yes:nth-child(4) .mk{animation-delay:.51s}
@keyframes mk-pop{
  0%{box-shadow:0 0 0 0 rgba(20,33,61,.4)}
  60%{box-shadow:0 0 0 7px rgba(20,33,61,0)}
  100%{box-shadow:0 0 0 0 rgba(20,33,61,0)}
}

/* row hover micro-interaction */
#owns ul.tick li:hover{background:rgba(20,33,61,.04)}
#owns ul.tick li.no:hover .mk::after{transform:rotate(90deg);transition:transform .3s var(--spring)}

/* ============================================================
   FAQ accordions as glass
   ============================================================ */
.faq{display:flex;flex-direction:column;gap:10px}
details.faq-item{
  border-radius:var(--r);padding:0;background:rgba(255,255,255,.55);
  border:1px solid rgba(10,10,10,.08);
  -webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);
  overflow:hidden;transition:background .25s var(--ease),border-color .25s var(--ease);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}
details.faq-item[open]{background:rgba(255,255,255,.8);border-color:rgba(10,10,10,.16)}
details.faq-item summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:22px 26px;font-size:17px;font-weight:500;color:var(--ink);
}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item summary .plus{
  flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:16px;
  background:rgba(10,10,10,.05);border:1px solid rgba(10,10,10,.12);color:var(--ink-2);
  transition:transform .35s var(--spring),background .25s var(--ease),color .25s var(--ease);
}
details.faq-item[open] summary .plus{transform:rotate(45deg);background:var(--navy);color:#fff;border-color:var(--navy)}
details.faq-item > div{padding:0 26px 22px;color:var(--ink-2);font-size:15.5px;line-height:1.65;max-width:760px}

/* ============================================================
   Footer
   ============================================================ */
footer.foot-shell{padding:80px 0 56px;border-top:1px solid rgba(10,10,10,.08);margin-top:64px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;color:var(--ink-3);font-size:13px}
.foot .links{display:flex;gap:24px}
.foot .links a:hover{color:var(--ink)}

/* ============================================================
   Page head (docs / roadmap)
   ============================================================ */
.page-head{padding:160px 0 64px;text-align:center;position:relative;overflow:hidden}
.page-head .crumbs{display:inline-flex;align-items:center;gap:10px;font-family:'SF Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:24px}
.page-head .crumbs a:hover{color:var(--ink)}
.page-head .crumbs .sep{color:var(--ink-4)}

/* ============================================================
   Docs layout
   ============================================================ */
.doc-layout{display:grid;grid-template-columns:260px 1fr;gap:48px;padding:48px 0 96px;align-items:start}
aside.toc{
  position:sticky;top:120px;padding:20px;border-radius:var(--r);
  background:rgba(255,255,255,.6);border:1px solid rgba(10,10,10,.08);
  -webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 12px 24px -12px rgba(20,33,61,.12);
}
aside.toc h5{margin:0 0 14px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
aside.toc ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
aside.toc a{
  display:block;padding:8px 12px;border-radius:10px;color:var(--ink-2);font-size:13.5px;
  transition:color .2s var(--ease),background .25s var(--ease);
}
aside.toc a:hover{color:var(--ink);background:rgba(10,10,10,.05)}
aside.toc a.active{color:#fff;background:linear-gradient(180deg,var(--navy-2),var(--navy));font-weight:600}

article.doc{max-width:760px;display:flex;flex-direction:column;gap:24px}
.doc-section{
  padding:36px;border-radius:var(--r-lg);
  background:rgba(255,255,255,.6);border:1px solid rgba(10,10,10,.08);
  -webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 12px 24px -12px rgba(20,33,61,.12);
  scroll-margin-top:120px;
}
.doc-section h2{font-family:'SF Pro Display','Inter',sans-serif;font-size:28px;line-height:1.15;margin:0 0 10px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}
.doc-section h2 .num{font-family:'SF Mono',monospace;font-size:13px;color:var(--navy);margin-right:14px;letter-spacing:.04em;vertical-align:middle}
.doc-section h3{font-size:18px;font-weight:600;margin:24px 0 8px;color:var(--ink)}
.doc-section p{color:var(--ink-2);font-size:15.5px;line-height:1.7;margin:12px 0}
.doc-section strong{color:var(--ink);font-weight:600}
.doc-section code{font-family:'SF Mono',monospace;font-size:13px;background:rgba(10,10,10,.05);border:1px solid rgba(10,10,10,.10);padding:1px 6px;border-radius:6px;color:var(--ink)}
.doc-section ul{padding-left:0;margin:14px 0;list-style:none;display:flex;flex-direction:column;gap:10px}
.doc-section ul li{display:flex;gap:12px;color:var(--ink-2);font-size:15px;line-height:1.6}
.doc-section ul li::before{content:"";flex:none;width:6px;height:6px;border-radius:50%;background:var(--navy);margin-top:10px;box-shadow:0 0 8px var(--navy-glow)}
.callout{margin:20px 0;padding:18px 22px;border-radius:var(--r);background:rgba(20,33,61,.06);border:1px solid rgba(20,33,61,.18);border-left:3px solid var(--navy)}
.callout .label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);margin-bottom:6px;font-weight:600}
.callout p{margin:0;color:var(--ink-2)}
.callout.warn{background:rgba(10,10,10,.05);border-color:rgba(10,10,10,.18);border-left-color:var(--ink)}
.callout.warn .label{color:var(--ink)}

.kv-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:14.5px}
.kv-table th,.kv-table td{padding:12px 14px;text-align:left;border-bottom:1px solid rgba(10,10,10,.08)}
.kv-table th{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.kv-table td{color:var(--ink-2)}
.kv-table td.num{font-family:'SF Mono',monospace;color:var(--ink)}
.kv-table tr:last-child td{border-bottom:0}

/* ============================================================
   Roadmap timeline
   ============================================================ */
.timeline{position:relative;display:flex;flex-direction:column;gap:18px}
.phase{
  position:relative;padding:32px 32px 32px 80px;
  border-radius:var(--r-lg);background:rgba(255,255,255,.6);border:1px solid rgba(10,10,10,.08);
  -webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 12px 24px -12px rgba(20,33,61,.12);
  transition:transform .35s var(--ease),background .25s var(--ease),border-color .25s var(--ease);
}
.phase:hover{transform:translateY(-2px);background:rgba(255,255,255,.8);border-color:rgba(10,10,10,.16)}
.phase .orb{
  position:absolute;left:24px;top:32px;width:36px;height:36px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.85), transparent 60%), rgba(10,10,10,.05);
  border:1px solid rgba(10,10,10,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
.phase.done .orb{background:radial-gradient(circle at 30% 30%, #c8d0e0, var(--navy) 60%);box-shadow:0 0 22px var(--navy-glow),inset 0 1px 0 rgba(255,255,255,.4)}
.phase.now .orb{background:radial-gradient(circle at 30% 30%, #ffffff, #444 60%);box-shadow:0 0 22px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.4)}
.phase .qtr{font-family:'SF Mono',monospace;font-size:12px;letter-spacing:.08em;color:var(--ink-3);margin-bottom:6px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.phase .qtr .status{padding:3px 10px;border-radius:999px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.phase.done .qtr .status{background:var(--navy);color:#fff}
.phase.now .qtr .status{background:var(--ink);color:#fff}
.phase.next .qtr .status{background:rgba(10,10,10,.06);color:var(--ink-3)}
.phase h3{font-family:'SF Pro Display','Inter',sans-serif;font-size:26px;line-height:1.15;margin:6px 0 12px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}
.phase p.lead{color:var(--ink-2);font-size:15.5px;line-height:1.65;margin:0 0 16px;max-width:680px}
.phase ul.items{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 20px}
.phase ul.items li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-2);font-size:14px;line-height:1.55}
.phase ul.items li .mk{flex:none;width:16px;height:16px;border-radius:5px;display:grid;place-items:center;font-size:10px;font-weight:700;margin-top:2px;background:rgba(10,10,10,.06);color:var(--ink-3)}
.phase.done ul.items li .mk{background:var(--navy);color:#fff}
.phase.now ul.items li .mk{background:var(--ink);color:#fff}
.phase ul.items li strong{color:var(--ink);font-weight:600}

.legend-row{display:inline-flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.legend-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid rgba(10,10,10,.08);background:rgba(255,255,255,.6);border-radius:999px;font-family:'SF Mono',monospace;font-size:11px;color:var(--ink-2)}
.legend-pill i{width:8px;height:8px;border-radius:50%}
.legend-pill.done i{background:var(--navy);box-shadow:0 0 8px var(--navy-glow)}
.legend-pill.now i{background:var(--ink);box-shadow:0 0 8px rgba(0,0,0,.4)}
.legend-pill.next i{background:var(--ink-3)}

/* ============================================================
   Reveal motion
   ============================================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay]{transition-delay:var(--rd,0ms)}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:960px){
  .grid-4{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .doc-layout{grid-template-columns:1fr;gap:24px}
  aside.toc{position:static}
  aside.toc ul{flex-direction:row;flex-wrap:wrap}
  .phase ul.items{grid-template-columns:1fr}
  section.bay{padding:80px 0}
  .hero{padding:140px 0 72px}
  .stat-panel{padding:32px}
}
@media (max-width:640px){
  .nav-links{display:none}
  .nav-burger{display:flex;margin-left:auto}
  .nav-shell{left:12px;right:12px;transform:none;width:auto;top:12px}
  .nav-glass{padding:8px 8px 8px 16px;justify-content:space-between}
  .nav-cta{display:none}
  .grid-4{grid-template-columns:1fr}
  .hero-meta{gap:10px}
  .chip{font-size:12px;padding:8px 12px}
  .page-head{padding:130px 0 48px}
}
/* Burger only ever appears on mobile; keep hidden otherwise */
@media (min-width:641px){ .nav-burger,.nav-drawer{display:none} }

/* ============================================================
   Copy-CA toast
   ============================================================ */
.copy-toast{
  position:fixed;left:50%;bottom:32px;transform:translate(-50%,40px);z-index:100;
  display:flex;align-items:center;gap:12px;padding:14px 22px;
  background:rgba(255,255,255,.9);border:1px solid rgba(10,10,10,.10);
  -webkit-backdrop-filter:blur(24px) saturate(180%);backdrop-filter:blur(24px) saturate(180%);
  border-radius:999px;box-shadow:0 18px 48px -16px rgba(20,33,61,.35), inset 0 1px 0 rgba(255,255,255,.85);
  font-size:13.5px;color:var(--ink);font-weight:500;
  opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease),transform .35s var(--spring);
}
.copy-toast.in{opacity:1;transform:translate(-50%,0);pointer-events:auto}
.copy-toast .check{
  width:18px;height:18px;border-radius:50%;display:grid;place-items:center;
  background:var(--navy);color:#fff;font-size:12px;font-weight:700;
  box-shadow:0 0 12px var(--navy-glow);
}
.copy-toast .ca{font-family:'SF Mono','JetBrains Mono',monospace;font-size:12px;color:var(--ink-2)}

/* CTA flash when copied */
.cta-copied{
  animation:cta-flash .6s var(--ease);
}
@keyframes cta-flash{
  0%,100%{box-shadow:0 14px 32px -10px rgba(20,33,61,.45), inset 0 1px 0 rgba(255,255,255,.18), inset 0 -1px 0 rgba(0,0,0,.3)}
  40%{box-shadow:0 14px 32px -10px rgba(20,33,61,.7), 0 0 0 4px rgba(20,33,61,.18), inset 0 1px 0 rgba(255,255,255,.2), inset 0 -1px 0 rgba(0,0,0,.3)}
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .cosmos::before,.cosmos::after,.cosmos > .aurora-3{display:none}
  .stat-bar span{transform:scaleX(1)}
  .hero-floats,.flow-pulse{display:none}
}
