/* ============================================================
   propSPACE — Website V2 (post-signups) shared design system.
   Tokens + components lifted from the live root index.html (the
   brand source of truth) and extended for a 3-page site:
   multi-page nav, expanded leaderboard, and the developers page.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
:root{
  --accent:#39FF14;--accent-glow:rgba(57,255,20,0.55);--accent-soft:rgba(57,255,20,0.15);--accent-dim:rgba(57,255,20,0.08);
  --under:#FF5050;--amber:#FFB454;--amber-text:#FFC58A;
  --blue:#007AC1;
  --bg-page:#0A0A0F;--bg-deep:#06060A;
  --text-1:#fff;--text-2:rgba(255,255,255,0.7);--text-3:rgba(255,255,255,0.55);--text-4:rgba(255,255,255,0.28);
  --surface-1:rgba(255,255,255,0.04);--surface-2:rgba(255,255,255,0.08);
  --border-1:rgba(255,255,255,0.08);--border-2:rgba(255,255,255,0.16);
  --font-d:'Bricolage Grotesque',system-ui,sans-serif;
  --font-m:'JetBrains Mono',ui-monospace,monospace;
}
html{background:#06060a}
body{
  font-family:var(--font-d);background:var(--bg-page);color:var(--text-1);position:relative;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip;
}
a{color:inherit;text-decoration:none}

/* Page-level colour wash — sits behind nav + hero. */
.page-bg{position:absolute;top:0;left:0;right:0;height:900px;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 42% at 50% -2%,rgba(57,255,20,0.16),transparent 62%),
    radial-gradient(ellipse 62% 46% at 2% 40%,rgba(0,122,193,0.15),transparent 62%),
    radial-gradient(ellipse 64% 50% at 100% 52%,rgba(245,132,38,0.13),transparent 62%);}
em{font-style:normal;color:var(--accent);text-shadow:0 0 28px rgba(57,255,20,0.55)}

/* ===== Shared ===== */
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:0.26em;
  text-transform:uppercase;color:var(--accent);
}
.eyebrow .dot,.feat-head .sec-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* ===== Primary CTA (now links out to functionSPACE) ===== */
.cta{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  height:64px;padding:0 36px;border-radius:18px;border:none;cursor:pointer;
  font-family:var(--font-d);font-weight:700;font-size:18px;letter-spacing:-0.01em;
  background:var(--accent);color:#000;
  box-shadow:0 0 34px rgba(57,255,20,0.5),0 0 90px rgba(57,255,20,0.22),0 -1px 0 rgba(255,255,255,0.3) inset;
  transition:transform 0.15s ease, box-shadow 0.15s ease;
}
.cta:hover{transform:translateY(-2px);box-shadow:0 0 44px rgba(57,255,20,0.7),0 0 120px rgba(57,255,20,0.3),0 -1px 0 rgba(255,255,255,0.3) inset}
.cta .arrow{font-family:var(--font-m);font-weight:700;font-size:20px}
/* ghost / secondary CTA */
.cta.ghost{background:transparent;color:var(--text-1);border:1px solid var(--border-2);box-shadow:none}
.cta.ghost:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
/* inline text link */
.txt-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-m);font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-3);transition:color .15s ease}
.txt-link:hover{color:var(--accent)}
.txt-link .arrow{font-weight:700}

/* ===== Nav ===== */
/* Full-width sticky bar: transparent at the top, glassy once scrolled (.scrolled added by nav.js). */
.site-nav{position:sticky;top:0;z-index:50;border-bottom:1px solid transparent;transition:background .25s ease,box-shadow .25s ease,border-color .25s ease}
.site-nav.scrolled{background:rgba(8,8,14,0.72);-webkit-backdrop-filter:saturate(140%) blur(14px);backdrop-filter:saturate(140%) blur(14px);border-bottom-color:var(--border-1);box-shadow:0 8px 30px rgba(0,0,0,0.35)}
.site-nav.scrolled .nav{padding-top:14px;padding-bottom:14px}
.nav{position:relative;z-index:20;display:flex;align-items:center;justify-content:space-between;padding-top:24px;padding-bottom:24px;gap:20px;transition:padding .25s ease}
.brand-lockup{display:flex;align-items:flex-end;gap:14px}
.brand{font-family:var(--font-d);font-weight:700;font-size:30px;letter-spacing:0.01em;line-height:1;text-transform:uppercase;color:var(--accent);text-shadow:0 0 18px rgba(57,255,20,0.3)}
.brand .lc{text-transform:none;color:var(--text-1);text-shadow:none}
.nav-powered{display:inline-flex;align-items:center;gap:7px;padding-bottom:4px;font-family:var(--font-m);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-4);font-weight:600}
.nav-powered img{height:11px;width:auto;opacity:0.72;display:block}
/* nav links + live pill live together on the right */
.nav-right{display:flex;align-items:center;gap:22px}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-family:var(--font-m);font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-3);transition:color .15s ease}
.nav-links a:hover{color:var(--text-1)}
.nav-links a.active{color:var(--accent)}
.nav-pill{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;
  background:var(--surface-1);border:1px solid var(--border-1);
  font-family:var(--font-m);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-3);font-weight:600;
}
.nav-pill .live{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 1.8s infinite}

/* ===== Hero ===== */
.hero{position:relative;padding-bottom:40px}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 0.95fr;gap:28px;align-items:center;padding:36px 0 28px}
.hero-copy{max-width:560px}
.prize-banner{
  display:inline-flex;align-items:center;gap:10px;margin:22px 0 18px;padding:8px 16px;border-radius:999px;
  background:rgba(57,255,20,0.07);border:1px solid rgba(57,255,20,0.28);
  font-family:var(--font-m);font-size:12px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);
}
.hero h1{
  font-family:var(--font-d);font-weight:800;font-size:clamp(46px,6.4vw,82px);line-height:0.94;letter-spacing:-0.035em;margin-bottom:20px;
}
.hero-sub{font-size:19px;line-height:1.55;color:var(--text-2);max-width:480px;margin:0 0 30px}
.hero-sub strong{color:#fff;font-weight:700}
.cta-row{display:flex;flex-direction:row;gap:16px;align-items:center;flex-wrap:wrap}

/* Phone shells (hero trio + reused elsewhere) */
.phone-shell{
  position:relative;z-index:2;width:300px;height:628px;overflow:hidden;flex-shrink:0;border-radius:58px;
  background:linear-gradient(165deg,#1e1e2c,#0c0c14);
  box-shadow:0 40px 80px rgba(0,0,0,0.72),0 0 0 1px rgba(255,255,255,0.05);
}
.phone-shell::before{content:"";position:absolute;left:50%;top:14px;transform:translateX(-50%);width:78px;height:22px;background:#000;border-radius:12px;z-index:20}
.phone-shell::after{content:"";position:absolute;inset:0;border-radius:58px;box-shadow:inset 0 0 0 10px rgba(8,8,14,0.92),inset 0 0 0 10.5px rgba(255,255,255,0.09);pointer-events:none;z-index:10}
.phone-shell iframe{width:458px;height:960px;border:0;transform:scale(0.655);transform-origin:top left;display:block}
.phone-shell.lg{width:340px;height:712px}
.phone-shell.lg::before{top:16px;width:89px;height:25px}
.phone-shell.lg::after{box-shadow:inset 0 0 0 11px rgba(8,8,14,0.92),inset 0 0 0 11.5px rgba(255,255,255,0.09)}
.phone-shell.lg iframe{transform:scale(0.742)}
.phone-shell.md{width:268px;height:561px}
.phone-shell.md::before{top:12px;width:70px;height:19px}
.phone-shell.md::after{box-shadow:inset 0 0 0 9px rgba(8,8,14,0.92),inset 0 0 0 9.5px rgba(255,255,255,0.09)}
.phone-shell.md iframe{transform:scale(0.585)}
.phone-shell.sm{width:224px;height:469px}
.phone-shell.sm::before{top:10px;width:58px;height:16px}
.phone-shell.sm::after{box-shadow:inset 0 0 0 8px rgba(8,8,14,0.92),inset 0 0 0 8.5px rgba(255,255,255,0.09)}
.phone-shell.sm iframe{transform:scale(0.489)}

/* Hero trio */
.hero-trio-wrap{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.trio{position:relative;z-index:1;display:flex;justify-content:center;align-items:center;perspective:1800px;min-height:540px}
.trio .phone-shell{filter:drop-shadow(0 30px 60px rgba(0,0,0,0.6))}
.trio .phone-left{transform:translate(56px,30px) rotateY(14deg) rotateZ(-6deg);z-index:1}
.trio .phone-right{transform:translate(-56px,30px) rotateY(-14deg) rotateZ(6deg);z-index:1}
.trio .phone-center{z-index:3;margin:0 -18px}
.trio-atmo{position:absolute;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(ellipse 60% 40% at 50% 30%,rgba(57,255,20,0.12) 0%,transparent 65%),
  radial-gradient(ellipse 40% 30% at 18% 70%,rgba(0,107,182,0.18) 0%,transparent 60%),
  radial-gradient(ellipse 40% 30% at 82% 75%,rgba(239,124,0,0.14) 0%,transparent 60%)}

/* ===== Competition / status section ===== */
.competition{position:relative;padding:74px 0 86px;background:var(--bg-page)}
.comp-glow{position:absolute;width:640px;height:640px;right:-220px;top:10px;border-radius:50%;background:radial-gradient(circle,rgba(57,255,20,0.10),transparent 70%);pointer-events:none;z-index:0}
.comp-glow.amb{right:auto;left:-250px;top:auto;bottom:-90px;width:620px;height:620px;background:radial-gradient(circle,rgba(255,180,84,0.22),transparent 66%)}
.comp-head{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:38px}
.comp-head .htext{max-width:560px}
.comp-head h2{font-family:var(--font-d);font-weight:800;font-size:clamp(38px,5vw,60px);letter-spacing:-0.035em;line-height:0.95;margin-top:12px}
.comp-blurb{max-width:500px;text-align:right;font-size:17px;line-height:1.55;color:var(--text-2)}
.comp-blurb b{color:#fff;font-weight:700}
.comp-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.3fr 1fr;gap:26px;align-items:stretch}

/* leaderboard card */
.lb-card{background:var(--surface-1);border:1px solid var(--border-1);border-radius:24px;padding:8px 8px 12px;display:flex;flex-direction:column}
.lb-cap{display:flex;justify-content:space-between;align-items:center;padding:18px 18px 10px}
.lb-cap .l{font-family:var(--font-m);font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-3)}
.lb-cap .r{font-family:var(--font-m);font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent)}
.lb{display:flex;flex-direction:column;flex:1}
.lb-row{display:grid;grid-template-columns:46px 1fr auto 72px;align-items:center;gap:14px;padding:14px;border-radius:14px;border-bottom:1px solid var(--border-1);flex:1 1 0}
.lb-row:last-child{border-bottom:none}
.lb-row .rk{font-family:var(--font-m);font-size:15px;font-weight:600;color:var(--text-3);letter-spacing:0.04em}
.lb-row .rk.sp{font-size:10px;font-weight:700;line-height:1.15;letter-spacing:0.1em;text-transform:uppercase}
.lb-row .nm{font-family:var(--font-d);font-weight:700;font-size:17px;color:#fff;line-height:1.1;min-width:0}
.lb-row .nm small{display:block;font-family:var(--font-m);font-size:9px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-4);margin-top:4px}
.lb-row .rt{font-family:var(--font-m);font-weight:700;font-size:15px;color:var(--accent);letter-spacing:-0.01em;text-align:right}
.lb-row .pz{font-family:var(--font-m);font-weight:700;font-size:16px;color:#fff;text-align:right}
.lb-row.top{background:radial-gradient(ellipse 90% 100% at 0% 50%,rgba(57,255,20,0.12),transparent 72%);box-shadow:inset 2px 0 0 var(--accent)}
.lb-row.top .rk,.lb-row.top .pz{color:var(--accent)}
.lb-row.dim .rk,.lb-row.dim .nm,.lb-row.dim .rt,.lb-row.dim .pz,.lb-row.dim .wn,.lb-row.dim .po,.lb-row.dim .wp,.lb-row.dim .pn{color:var(--text-4)}
.lb-row.spoon{background:rgba(255,180,84,0.05)}
.lb-row.spoon .rt{color:var(--under)}
.lb-row.spoon .nm small{color:var(--amber-text)}
.lb-row.spoon .pz{color:var(--amber-text)}
/* extra stat columns (Wins / Positions / Win %) + PnL */
.lb-row .wn,.lb-row .po,.lb-row .wp{font-family:var(--font-m);font-size:14px;font-weight:600;color:var(--text-2);text-align:right;letter-spacing:-0.01em}
.lb-row .pn{font-family:var(--font-m);font-size:15px;font-weight:700;color:#fff;text-align:right;letter-spacing:-0.01em}
.lb-row .pn.pos{color:var(--accent)}
.lb-row .pn.neg{color:var(--under)}
/* header row */
.lb-row.lb-head{flex:0 0 auto;border-bottom:1px solid var(--border-1)}
.lb-row.lb-head>div{font-family:var(--font-m)!important;font-size:10px!important;font-weight:700!important;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-4)!important;line-height:1.2!important}

/* format + grand prize column */
.comp-side{display:flex;flex-direction:column;gap:16px}
.grand{position:relative;overflow:hidden;background:radial-gradient(ellipse 100% 100% at 50% 0%,rgba(57,255,20,0.12),transparent 70%),var(--surface-1);border:1px solid rgba(57,255,20,0.4);border-radius:24px;padding:26px;box-shadow:0 0 30px rgba(57,255,20,0.12);display:flex;flex-direction:column;gap:8px}
.grand .l{font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
.grand .v{font-family:var(--font-m);font-weight:700;font-size:clamp(42px,12vw,56px);letter-spacing:-0.04em;line-height:1;color:var(--accent);text-shadow:0 0 28px rgba(57,255,20,0.4)}
.grand .v small{font-size:18px;color:var(--text-3);margin-left:6px;letter-spacing:0}
.grand p{font-size:14px;color:var(--text-2);line-height:1.5}
.prize-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pcard{background:var(--surface-1);border:1px solid var(--border-1);border-radius:16px;padding:16px 14px;display:flex;flex-direction:column;gap:5px}
.pcard .r{font-family:var(--font-m);font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-3)}
.pcard .a{font-family:var(--font-m);font-weight:700;font-size:27px;letter-spacing:-0.03em;line-height:1;color:#fff}
.pcard.spoon{border-color:rgba(255,180,84,0.3)}
.pcard.spoon .r,.pcard.spoon .a{color:var(--amber-text)}
.fmt-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;flex:1}
.fmt{background:var(--surface-1);border:1px solid var(--border-1);border-radius:18px;padding:20px;display:flex;flex-direction:column;justify-content:center}
.fmt .v{font-family:var(--font-m);font-weight:700;font-size:38px;letter-spacing:-0.03em;line-height:1;color:#fff}
.fmt.g .v{color:var(--accent)}
.fmt .k{font-family:var(--font-m);font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-3);margin-top:8px}

/* ===== Mechanics deep-dive (Home #mechanics) ===== */
.mechanics{position:relative;padding:64px 0 16px;background:transparent;scroll-margin-top:110px}
.mech-head{text-align:center;margin-bottom:44px}
.mech-head .sec-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-m);font-size:11px;letter-spacing:0.26em;color:var(--accent);font-weight:700;text-transform:uppercase}
.mech-head h2{font-family:var(--font-d);font-weight:800;font-size:clamp(34px,4.4vw,52px);letter-spacing:-0.03em;margin-top:8px;line-height:1}
.mech-head p{margin-top:14px;color:var(--text-3);font-size:16px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.55}

.mode{position:relative;display:grid;grid-template-columns:0.9fr 1.1fr;gap:48px;align-items:center;padding:56px 0}
.mode + .mode{border-top:1px solid var(--border-1)}
.mechanics .mode:last-child{padding-bottom:16px}
.mode.rev{direction:rtl}
.mode.rev>*{direction:ltr}
.mode-phone{display:flex;justify-content:center;align-items:center;position:relative}
.mode-phone::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;z-index:0;pointer-events:none;
  background:radial-gradient(circle,rgba(57,255,20,0.12),transparent 68%)}
.mode.rev .mode-phone::before{background:radial-gradient(circle,rgba(255,180,84,0.16),transparent 68%)}
.mode-phone .phone-shell{position:relative;z-index:1;transform:perspective(1800px) rotateY(-9deg) rotateX(3deg) rotateZ(-1.5deg);width:288px;height:604px;border-radius:55px}
/* Match the iframe scale to the 288px shell (458*0.629≈288) so the in-screen content
   isn't wider than the shell — otherwise the right edge gets clipped against the bezel. */
.mode-phone .phone-shell iframe{transform:scale(0.629)}
.mode-phone .phone-shell::after{border-radius:55px;box-shadow:inset 0 0 0 10px rgba(8,8,14,0.92),inset 0 0 0 10.5px rgba(255,255,255,0.09)}
.mode-phone .phone-shell::before{top:13px;width:72px;height:21px}
.mode.rev .mode-phone .phone-shell{transform:perspective(1800px) rotateY(9deg) rotateX(3deg) rotateZ(1.5deg)}
.mode-copy{max-width:520px}
.mode-lbl{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-m);font-size:10px;letter-spacing:0.24em;color:var(--accent);font-weight:700;text-transform:uppercase;margin-bottom:16px}
.mode-lbl::before{content:"";width:22px;height:1px;background:var(--accent)}
.mode.rev .mode-lbl{color:var(--amber-text)}
.mode.rev .mode-lbl::before{background:var(--amber)}
.mode-copy h3{font-family:var(--font-d);font-weight:800;font-size:clamp(34px,5vw,52px);letter-spacing:-0.04em;line-height:0.95;margin-bottom:14px}
.mode-lede{font-size:18px;line-height:1.5;color:var(--text-2);margin-bottom:28px}
.mode-lede b{color:#fff;font-weight:700}
.mode-steps{display:flex;flex-direction:column;gap:0}
.mode-step{display:grid;grid-template-columns:30px 1fr;gap:18px;align-items:start;padding:16px 0;border-top:1px solid var(--border-1)}
.mode-step:first-child{border-top:none}
.mode-step .n{font-family:var(--font-m);font-weight:700;font-size:15px;color:var(--accent);padding-top:2px}
.mode.rev .mode-step .n{color:var(--amber-text)}
.mode-step .t{font-size:15px;line-height:1.55;color:var(--text-2)}
.mode-step .t b{color:#fff;font-weight:700}

/* ===== Demo video showcase ===== */
.showcase{position:relative;padding:16px 0 8px;text-align:center}
.showcase .sec-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-m);font-size:11px;letter-spacing:0.26em;color:var(--accent);font-weight:700;text-transform:uppercase}
.showcase h2{font-family:var(--font-d);font-weight:800;font-size:clamp(34px,4.4vw,52px);letter-spacing:-0.03em;margin-top:8px;line-height:1}
.showcase p{margin-top:14px;color:var(--text-3);font-size:16px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.55}
.video-frame{position:relative;max-width:920px;margin:36px auto 0;border-radius:24px;overflow:hidden;border:1px solid var(--border-2);background:var(--bg-deep);box-shadow:0 40px 90px rgba(0,0,0,0.6),0 0 70px rgba(57,255,20,0.14)}
.video-frame video{display:block;width:100%;height:auto;border-radius:24px}
@media(max-width:560px){.showcase{padding:12px 0 4px}.video-frame{margin-top:24px;border-radius:18px}.video-frame video{border-radius:18px}}

/* ===== Developers page ===== */
.dev-hero{position:relative;padding:48px 0 24px}
.dev-hero h1{font-family:var(--font-d);font-weight:800;font-size:clamp(44px,6vw,76px);line-height:0.94;letter-spacing:-0.035em;margin:18px 0 22px}
.dev-hero .lede{font-size:19px;line-height:1.55;color:var(--text-2);max-width:620px}
.dev-hero .lede b{color:#fff;font-weight:700}
.dev-sec{position:relative;padding:24px 0 72px}
.dev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:8px}
.dev-card{position:relative;background:var(--surface-1);border:1px solid var(--border-1);border-radius:22px;padding:30px;display:flex;flex-direction:column;gap:14px}
.dev-card.g{border-color:rgba(57,255,20,0.4);box-shadow:0 0 40px rgba(57,255,20,0.10)}
.dev-card .k{font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
.dev-card h3{font-family:var(--font-d);font-weight:700;font-size:25px;letter-spacing:-0.02em;line-height:1.05}
.dev-card p{font-size:15px;line-height:1.6;color:var(--text-2)}
.dev-card p b{color:#fff;font-weight:700}
.dev-card .ic{width:54px;height:54px;border-radius:14px;border:1px solid var(--border-2);background:var(--bg-deep);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.dev-card .ic svg{width:26px;height:26px}
/* conceptual "pricing" mini-diagram */
.price-strip{margin-top:6px;display:flex;flex-direction:column;gap:10px}
.price-bar{display:grid;grid-template-columns:74px 1fr 58px;align-items:center;gap:12px;font-family:var(--font-m);font-size:11px;color:var(--text-3);letter-spacing:0.04em}
.price-bar .track{height:8px;border-radius:4px;background:var(--surface-2);overflow:hidden}
.price-bar .track i{display:block;height:100%;border-radius:4px;background:var(--accent);box-shadow:0 0 14px rgba(57,255,20,0.5)}
.price-bar .mult{font-weight:700;color:var(--accent);text-align:right}

/* ===== Page header (leaderboard / dev share) ===== */
.page-head{position:relative;z-index:1;padding:40px 0 8px}
.page-head h1{font-family:var(--font-d);font-weight:800;font-size:clamp(40px,5.4vw,68px);letter-spacing:-0.035em;line-height:0.96;margin:16px 0 0}
.page-head .blurb{margin-top:18px;font-size:17px;line-height:1.55;color:var(--text-2);max-width:620px}
.page-head .blurb b{color:#fff;font-weight:700}

/* ===== Leaderboard page (full table) ===== */
.lb-page{position:relative;padding:24px 0 8px}
.lb-page .lb-row{grid-template-columns:54px minmax(0,1fr) 52px 52px 64px 104px}
.lb-foot-note{margin-top:18px;display:inline-flex;align-items:center;gap:10px;font-family:var(--font-m);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-4);font-weight:600}
.lb-foot-note .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 1.8s infinite}
.prize-block{position:relative;padding:8px 0 72px}
.prize-tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:14px}
.tier{background:var(--surface-1);border:1px solid var(--border-1);border-radius:20px;padding:24px 22px;display:flex;flex-direction:column;gap:8px}
.tier.g{border-color:rgba(57,255,20,0.4);box-shadow:0 0 36px rgba(57,255,20,0.10)}
.tier.spoon{border-color:rgba(255,180,84,0.3)}
.tier .r{font-family:var(--font-m);font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-3)}
.tier.g .r{color:var(--accent)}
.tier.spoon .r{color:var(--amber-text)}
.tier .a{font-family:var(--font-m);font-weight:700;font-size:34px;letter-spacing:-0.03em;line-height:1;color:#fff}
.tier.g .a{color:var(--accent);text-shadow:0 0 24px rgba(57,255,20,0.35)}
.tier.spoon .a{color:var(--amber-text)}
.tier .d{font-size:13px;line-height:1.5;color:var(--text-3)}

/* ===== Closing CTA ===== */
.closing{position:relative;overflow:hidden;text-align:center;padding:90px 0 100px}
.closing-atmo{position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 60% 70% at 50% 50%,rgba(57,255,20,0.12) 0%,transparent 65%)}
.closing-inner{position:relative;z-index:1}
.closing h2{font-family:var(--font-d);font-weight:800;font-size:clamp(34px,4.6vw,56px);letter-spacing:-0.03em;line-height:1;margin-bottom:16px}
.closing p{color:var(--text-2);font-size:17px;margin-bottom:34px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.55}
.closing .powered-line{display:inline-flex;align-items:center;gap:9px;margin-bottom:22px;font-family:var(--font-m);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-4);font-weight:600}
.closing .powered-line img{height:13px;width:auto;opacity:0.7}

/* ===== Footer ===== */
.footer{padding:36px 0 48px;position:relative;z-index:1}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.powered-by{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-m);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-4);font-weight:600}
.powered-by img{height:12px;width:auto;opacity:0.65}
.footer-left{display:inline-flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-socials{display:inline-flex;align-items:center;gap:10px}
.footer-socials a{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;color:var(--text-4);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);transition:color .18s ease,background .18s ease,border-color .18s ease}
.footer-socials a:hover{color:var(--accent);background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.14)}
.footer-socials svg{width:15px;height:15px;fill:currentColor;display:block}
.footer-fine{font-family:var(--font-m);font-size:10px;letter-spacing:0.08em;color:var(--text-4);line-height:1.6;max-width:440px}

/* ===== Responsive ===== */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:8px}
  .hero-copy{max-width:640px}
  .comp-head{flex-direction:column;align-items:flex-start;gap:18px}
  .comp-blurb{text-align:left}
  .comp-grid{grid-template-columns:1fr}
  .mode{grid-template-columns:1fr;gap:36px}
  .mode.rev{direction:ltr}
  .dev-grid{grid-template-columns:1fr}
  .prize-tiers{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .trio .phone-left,.trio .phone-right{display:none}
  .trio{min-height:480px}
  .trio .phone-center{margin:0}
}
@media(max-width:620px){
  /* Two-row mobile nav: brand + Live pill on row 1, links as a full-width row below.
     display:contents promotes .nav-right's children to flex items of .nav so the
     links can wrap to their own line — no DOM change, desktop layout untouched. */
  .nav{flex-wrap:wrap;row-gap:12px}
  .nav-right{display:contents}
  .nav-pill{order:2}
  .nav-links{
    display:flex;order:3;flex-basis:100%;width:100%;
    justify-content:space-between;gap:6px;
    padding-top:12px;border-top:1px solid var(--border-1);
  }
  .nav-links a{text-align:center;padding:11px 4px;font-size:12px;letter-spacing:0.08em;white-space:nowrap}
}
@media(max-width:430px){
  /* keep brand + pill on one row on small phones */
  .brand{font-size:26px}
  .nav-pill{padding:7px 11px;font-size:9px;letter-spacing:0.12em}
}
@media(max-width:560px){
  .nav-powered{display:none}
  .lb-row{grid-template-columns:28px 1fr auto 58px;gap:8px;padding:13px 10px}
  .lb-page .lb-row{grid-template-columns:26px minmax(0,1fr) 28px 30px 44px 64px;gap:6px;padding:13px 8px}
  .lb-row .nm{font-size:14px}
  .lb-row .rt,.lb-row .pz{font-size:13px}
  .lb-row .wn,.lb-row .po,.lb-row .wp{font-size:12px}
  .lb-row .pn{font-size:12.5px}
  .lb-row.lb-head>div{font-size:9px!important;letter-spacing:0.04em}
  .prize-tiers{grid-template-columns:1fr}
  .cta{width:100%}
  .cta-row{align-items:stretch;flex-direction:column}
}
/* ===== Mobile reading polish (phones only) ===== */
@media(max-width:560px){
  .nav{padding-top:32px;padding-left:24px;padding-right:24px}
  .hero-grid{padding:24px 0 18px}
  .hero{padding-bottom:28px}
  .competition{padding:52px 0 60px}
  .comp-head{margin-bottom:26px}
  .mechanics{padding:44px 0 12px}
  .mode{padding:40px 0}
  .closing{padding:64px 0 72px}
  .hero-sub{font-size:17px;line-height:1.5}
  .comp-blurb{font-size:16px;line-height:1.5}
  .mode-lede{font-size:16px}
  .closing p{font-size:16px}
  .footer-socials{gap:12px}
  .footer-socials a{width:44px;height:44px;border-radius:12px}
  .footer-socials svg{width:18px;height:18px}
}

/* ============================================================
   Developers page — rebuild
   Stacked, scannable sections: each is a bold claim + one-line
   subhead, then optional detail. Scanning the headers alone
   tells the whole propSPACE-on-functionSPACE story.
   ============================================================ */
.dev-block{position:relative;padding:50px 0;border-top:1px solid var(--border-1)}
.dev-block:first-of-type{border-top:none}
.dev-head{max-width:700px;margin-bottom:30px}
.dev-head h2{font-family:var(--font-d);font-weight:800;font-size:clamp(30px,4.2vw,46px);letter-spacing:-0.03em;line-height:1.0;margin:12px 0 12px}
.dev-head .sub{font-size:18px;line-height:1.5;color:var(--text-2)}
.dev-head .sub b{color:#fff;font-weight:700}

/* App-on-engine stack visual */
.stack{display:flex;flex-direction:column;gap:8px;margin:0 0 34px;max-width:760px}
.layer{position:relative;border:1px solid var(--border-1);border-radius:18px;padding:20px 24px;background:var(--surface-1);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.layer .lt{font-family:var(--font-d);font-weight:700;font-size:20px;color:#fff;line-height:1}
.layer .ld{font-family:var(--font-m);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-3)}
.layer.engine{border-color:rgba(57,255,20,0.4);background:radial-gradient(ellipse 120% 100% at 0% 50%,rgba(57,255,20,0.10),transparent 70%),var(--surface-1);box-shadow:0 0 36px rgba(57,255,20,0.10)}
.layer.engine .lt{color:var(--accent)}
.stack .joint{align-self:center;font-family:var(--font-m);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-4);padding:2px 0}

/* propSPACE action -> functionSPACE mechanism mapping rows */
.tie-grid{display:flex;flex-direction:column;gap:12px}
.tie-row{display:grid;grid-template-columns:150px 1fr;align-items:center;gap:20px;background:var(--surface-1);border:1px solid var(--border-1);border-radius:16px;padding:18px 22px}
.tie-row .fs{font-size:14px;line-height:1.5;color:var(--text-2)}
.tie-row .fs b{color:#fff;font-weight:700}
.tie-row .tag{font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent)}

/* Benefits grid (compact, scannable) */
.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:6px}
.benefit{background:var(--surface-1);border:1px solid var(--border-1);border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:9px}
.benefit .bdot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}
.benefit h3{font-family:var(--font-d);font-weight:700;font-size:18px;letter-spacing:-0.01em;color:#fff;line-height:1.2}
.benefit p{font-size:13.5px;line-height:1.5;color:var(--text-3)}
.benefits-legend{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px 26px;margin-top:18px}
.benefits-legend .leg-item{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;color:var(--text-3)}
.benefits-legend .leg-dot{width:7px;height:7px;border-radius:50%;flex:none}
.benefits-legend .leg-dot.green{background:var(--accent);box-shadow:0 0 12px var(--accent)}
.benefits-legend .leg-dot.blue{background:#2E9BFF;box-shadow:0 0 12px #2E9BFF}
/* Mobile: stack the two legend entries (one per line), right-aligned */
@media(max-width:620px){
  .benefits-legend{flex-direction:column;align-items:flex-end;gap:8px;text-align:right}
  .benefits-legend .leg-item{align-items:flex-start}
  .benefits-legend .leg-dot{margin-top:4px}
}

/* "How it actually works" — deeper, still scannable via h3s */
.how-list{display:flex;flex-direction:column;gap:0;margin-top:4px}
.how-item{padding:28px 0;border-top:1px solid var(--border-1)}
.how-item:first-child{border-top:none;padding-top:8px}
.how-item .hk{font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.how-item h3{font-family:var(--font-d);font-weight:700;font-size:clamp(22px,3vw,28px);letter-spacing:-0.02em;line-height:1.1;margin-bottom:10px}
.how-item p{font-size:15px;line-height:1.6;color:var(--text-2);max-width:760px}
.how-item p b{color:#fff;font-weight:700}
.how-item .price-strip{margin-top:20px;max-width:440px}

/* SDK integration depths */
.depths{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:4px}
.depth-card{background:var(--surface-1);border:1px solid var(--border-1);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:11px}
.depth-card .lvl{font-family:var(--font-m);font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent)}
.depth-card h4{font-family:var(--font-d);font-weight:700;font-size:19px;letter-spacing:-0.01em;color:#fff}
.depth-card p{font-size:14px;line-height:1.55;color:var(--text-2);flex:1}
.depth-card code{font-family:var(--font-m);font-size:11px;color:var(--text-3);background:var(--bg-deep);border:1px solid var(--border-1);border-radius:9px;padding:9px 12px;letter-spacing:-0.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dev-docs-link{margin-top:24px}

/* Agent-native callout — prominent strip under the integration depths */
.agent-callout{display:flex;align-items:center;gap:22px;margin-top:24px;padding:22px 26px;
  background:linear-gradient(90deg,rgba(57,255,20,0.09),rgba(57,255,20,0.02));
  border:1px solid rgba(57,255,20,0.30);border-radius:20px}
.agent-callout .ac-badge{flex:none;align-self:flex-start;font-family:var(--font-m);font-size:10px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);
  border:1px solid rgba(57,255,20,0.42);border-radius:999px;padding:6px 12px;
  box-shadow:0 0 18px rgba(57,255,20,0.16)}
.agent-callout .ac-body{flex:1}
.agent-callout .ac-body h3{font-family:var(--font-d);font-weight:700;font-size:20px;letter-spacing:-0.01em;color:#fff;margin:0 0 5px}
.agent-callout .ac-body p{font-size:14px;line-height:1.55;color:var(--text-2);margin:0}
.agent-callout .ac-body code{font-family:var(--font-m);font-size:12px;color:var(--accent);background:var(--bg-deep);border:1px solid var(--border-1);border-radius:7px;padding:2px 7px}
.agent-callout .txt-link{flex:none}
@media(max-width:680px){.agent-callout{flex-direction:column;align-items:flex-start;gap:14px}}

/* Core idea: a 3-step ladder — binary -> forecast -> design-your-own-payoff */
.contrast{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:6px}
.contrast.three{grid-template-columns:repeat(3,1fr)}
.contrast-card{background:var(--surface-1);border:1px solid var(--border-1);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:14px}
.contrast-card.fs{border-color:rgba(57,255,20,0.4);box-shadow:0 0 36px rgba(57,255,20,0.10)}
.contrast-card.fs-lite{border-color:rgba(57,255,20,0.28)}
.contrast-card .clbl{font-family:var(--font-m);font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-3)}
.contrast-card.fs .clbl,.contrast-card.fs-lite .clbl{color:var(--accent)}
.contrast-card .ctitle{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.contrast-card .cbadge{font-family:var(--font-m);font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:#000;background:var(--accent);border-radius:999px;padding:3px 8px;line-height:1.3}
.contrast-card.fs-lite .cbadge{color:var(--accent);background:transparent;border:1px solid rgba(57,255,20,0.4)}
.contrast-card h3{font-family:var(--font-d);font-weight:700;font-size:21px;letter-spacing:-0.02em;line-height:1.12;color:#fff}
.contrast-foot{margin-top:16px;font-family:var(--font-m);font-size:11px;letter-spacing:0.04em;color:var(--text-3);line-height:1.5}
.contrast-foot b{color:var(--accent);font-weight:700}
.contrast-card p{font-size:14px;line-height:1.55;color:var(--text-2)}
.contrast-card p b{color:#fff;font-weight:700}
.diagram{height:128px;border-radius:14px;background:var(--bg-deep);border:1px solid var(--border-1);overflow:hidden;display:flex;align-items:flex-end;justify-content:center;padding:16px 18px}
.diagram svg{width:100%;height:100%;display:block}
.binary{display:flex;align-items:flex-end;justify-content:center;gap:22px;height:100%;width:100%}
.binary .b{width:64px;border-radius:8px 8px 0 0;background:var(--surface-2);border:1px solid var(--border-2);border-bottom:none;display:flex;align-items:flex-start;justify-content:center;padding-top:8px;font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:0.08em;color:var(--text-3)}
.binary .b.no{height:38%}
.binary .b.yes{height:90%}
/* forecast tier: accent outline curve (a forecast you state, not a payoff you shape) */
.diagram .forecast{fill:none;stroke:#39FF14;stroke-width:2.5;stroke-linecap:round}

/* Payoff shapes you can design (Line / Range in propSPACE) */
.shapes{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:20px}
/* "Not in propSPACE" section: the moved Any-curve shape-card + the sell-anytime tie-row, side by side */
.beyond-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start;margin-top:20px}
@media(max-width:720px){.beyond-grid{grid-template-columns:1fr}}
/* blue payoff-shape cards (bullseye / ramp) — accent word in blue to match the graph */
.shape-card.blue .st span{color:#2E9BFF}
.shape-card{background:var(--surface-1);border:1px solid var(--border-1);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:11px}
.shape-card .sd{height:78px;border-radius:10px;background:var(--bg-deep);border:1px solid var(--border-1);overflow:hidden}
.shape-card .sd svg{width:100%;height:100%;display:block}
.shape-card .st{font-family:var(--font-d);font-weight:700;font-size:15px;color:#fff;letter-spacing:-0.01em}
.shape-card .st span{color:var(--accent)}
.shape-card .sp{font-family:var(--font-m);font-size:10.5px;letter-spacing:0.03em;color:var(--text-3);line-height:1.45}

/* Developers-page responsive */
@media(max-width:920px){
  .benefits{grid-template-columns:1fr 1fr}
  .depths{grid-template-columns:1fr}
}
@media(max-width:920px){
  .contrast.three{grid-template-columns:1fr}
}
@media(max-width:720px){
  .contrast{grid-template-columns:1fr}
}
@media(max-width:560px){
  .dev-block{padding:38px 0}
  .benefits{grid-template-columns:1fr}
  .shapes{grid-template-columns:1fr}
  .tie-row{grid-template-columns:1fr;gap:8px;padding:18px 18px}
  .layer{padding:18px 18px}
  .dev-head .sub{font-size:16px}
  .how-item p{font-size:14.5px}
}
