/* ═══════════════════════════════════════════════════════════════
   THE TERMI PROTOCOL — shared design system
   Black, matching the main app: #09090B ground, white text, mono accent.
   JetBrains Mono — light/spaced display headings, labels & reading text · Inter (UI chrome).
   ═══════════════════════════════════════════════════════════════ */

:root{
  --bg:#09090B;--bg-s:#111113;--bg-c:#151518;--bg-e:#1A1A1E;
  --t1:#FAFAFA;--t2:#A1A1AA;--t3:#71717A;--t4:#52525B;
  --border:rgba(255,255,255,.08);--border-h:rgba(255,255,255,.14);--border-s:rgba(255,255,255,.20);
  --accent:#FAFAFA;--accent-2:#A1A1AA;--accent-soft:rgba(250,250,250,.08);--accent-m:rgba(250,250,250,.05);
  --warn:#fbbf24;
  --r-sm:8px;--r:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;
  --shadow:0 6px 22px rgba(0,0,0,.5);--shadow-lg:0 12px 40px rgba(0,0,0,.6);
  --f-display:'JetBrains Mono',ui-monospace,'SFMono-Regular',monospace;
  --f-sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,'SFMono-Regular',monospace;
  --f-code:'JetBrains Mono',ui-monospace,monospace;
  --ease:cubic-bezier(.16,1,.3,1);--dur:200ms;--dur-s:420ms;
  --w:1200px;--w-n:760px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--f-sans);background:var(--bg);color:var(--t1);line-height:1.6;overflow-x:clip;-webkit-font-smoothing:antialiased;font-weight:400;letter-spacing:-.011em;
  background-image:radial-gradient(1100px 560px at 82% -12%,rgba(255,255,255,.028),transparent 62%);}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea{font:inherit}
::selection{background:rgba(255,255,255,.18);color:var(--t1)}

/* ─── Typography ─── */
.t-display{font-family:var(--f-display);font-weight:500;line-height:1.16;letter-spacing:.04em;color:var(--t1)}
.t-h1{font-size:clamp(2.9rem,6.4vw,5.2rem)}
.t-h2{font-size:clamp(2rem,4.2vw,3.4rem)}
.t-h3{font-size:clamp(1.4rem,2.4vw,1.8rem)}
.t-body{font-family:var(--f-mono);letter-spacing:0;font-size:clamp(.9rem,1.15vw,1rem);line-height:1.65}
.t-body-lg{font-family:var(--f-mono);letter-spacing:0;font-size:clamp(.98rem,1.3vw,1.1rem);line-height:1.6}
.t-small{font-size:.875rem}
.t-label{font-family:var(--f-mono);font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--t3);line-height:1}
.mono{font-family:var(--f-mono)}

/* ─── Layout ─── */
.wrap{max-width:var(--w);margin:0 auto;padding:0 24px}
.wrap-n{max-width:var(--w-n);margin:0 auto;padding:0 24px}
.section{padding:clamp(64px,10vw,120px) 0}
.section-alt{background:var(--bg-s)}
.text-center{text-align:center}
.mb-s{margin-bottom:12px}.mb-m{margin-bottom:clamp(24px,3vw,32px)}.mb-l{margin-bottom:clamp(40px,6vw,64px)}
.sh{margin-bottom:clamp(40px,6vw,64px)}
.divider{width:44px;height:2px;background:var(--accent);border-radius:1px;margin:16px 0 20px;opacity:.5}
.text-center .divider{margin-left:auto;margin-right:auto}

/* ─── Buttons / Pills ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:var(--r);font-weight:600;font-size:.9rem;transition:all var(--dur) var(--ease)}
.btn-p{background:var(--accent);color:#09090B}.btn-p:hover{background:#fff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.45)}
.btn-o{border:1px solid var(--border-h);color:var(--t1);background:transparent}.btn-o:hover{border-color:var(--border-s);color:var(--t1);background:var(--accent-m)}
.btn-lg{padding:14px 34px;font-size:.95rem}
.pill{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;border-radius:100px;font-size:.78rem;font-weight:500;background:var(--accent-m);color:var(--t2);border:1px solid var(--border)}
.pill-a{background:var(--accent-m);color:var(--t2);border-color:var(--border-h);font-family:var(--f-mono);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.pill .dot,.pill-a .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(255,255,255,.45);display:inline-block}
.pulse{animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ─── Header (shared, injected by site.js) ─── */
.header{position:sticky;top:0;z-index:100;padding:13px 0;background:rgba(9,9,11,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid transparent;transition:border-color var(--dur)}
.header.scrolled{border-bottom-color:var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--f-mono);font-size:.98rem;font-weight:700;letter-spacing:.02em;color:var(--t1);display:flex;align-items:center;gap:9px;line-height:1}
.logo-mark{color:var(--accent)}
.logo-text{white-space:nowrap}
.logo.typing .logo-mark{animation:blink .8s step-end infinite}
.nav{display:flex;align-items:center;gap:2px}
.nav a{padding:8px 13px;border-radius:var(--r-sm);font-size:.85rem;font-weight:500;color:var(--t3);transition:color var(--dur),background var(--dur)}
.nav a:hover,.nav a.active{color:var(--t1);background:var(--accent-m)}
.nav-cta{background:var(--accent)!important;color:#09090B!important;padding:8px 20px!important;border-radius:var(--r)!important;font-weight:600!important;margin-left:8px}
.nav-cta:hover{background:#fff!important}
.hamburger{display:none;width:38px;height:38px;align-items:center;justify-content:center;border-radius:var(--r-sm)}
.hamburger span{width:17px;height:1.5px;background:var(--t1);display:block;position:relative;transition:all var(--dur)}
.hamburger span::before,.hamburger span::after{content:'';width:17px;height:1.5px;background:var(--t1);position:absolute;left:0;transition:all var(--dur)}
.hamburger span::before{top:-5px}.hamburger span::after{top:5px}
.hamburger.open span{background:transparent}.hamburger.open span::before{top:0;transform:rotate(45deg)}.hamburger.open span::after{top:0;transform:rotate(-45deg)}
@media(max-width:860px){
  .hamburger{display:flex}
  .nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;flex-direction:column;align-items:stretch;background:var(--bg-s);padding:80px 24px 40px;border-left:1px solid var(--border);transition:right 300ms var(--ease);z-index:99}
  .nav.open{right:0}
  .nav a{padding:14px 16px;font-size:.95rem;border-radius:0;border-bottom:1px solid var(--border)}
  .nav-cta{margin-top:20px;text-align:center;border-bottom:none!important}
}

/* ─── Hero ─── */
.hero{padding:clamp(56px,9vw,120px) 0 clamp(44px,6vw,84px)}
.hero-grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,4vw,52px);align-items:center}
.hero-text{max-width:580px}
.hero-text h1{margin-bottom:18px;font-size:clamp(1.9rem,2.3vw + .8rem,3.2rem);line-height:1.18;text-wrap:balance}
.hero-text h1 em{font-style:normal;display:block;color:var(--t2)}
.hero-visual{position:relative;border-radius:var(--r-2xl);overflow:hidden;background:var(--bg-s);border:1px solid var(--border);aspect-ratio:16/10}
.hero-visual-ph{width:100%;height:100%;position:absolute;inset:0;overflow:hidden}
.hero-visual-ph canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.85}
.hero-badge{position:absolute;bottom:16px;left:16px;background:rgba(9,9,11,.78);backdrop-filter:blur(12px);padding:7px 13px;border-radius:var(--r);color:var(--t2);font-family:var(--f-mono);font-size:.72rem;font-weight:500;letter-spacing:.06em;border:1px solid var(--border)}
@media(min-width:900px){.hero-grid{grid-template-columns:1fr 1.18fr}}

/* ─── Marquee ─── */
.mq-w{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.mq-t{display:flex;gap:38px;padding:14px 0;white-space:nowrap}
.mq-t .mi{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:.8rem;color:var(--t4);flex-shrink:0;letter-spacing:.02em}
.mq-t .mi i{display:block;width:15px;height:15px;flex-shrink:0;background:var(--t4);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}
.ic-claude{-webkit-mask-image:url(../img/icons/claude.svg);mask-image:url(../img/icons/claude.svg)}
.ic-openai{-webkit-mask-image:url(../img/icons/openai.svg);mask-image:url(../img/icons/openai.svg)}
.ic-antigravity{-webkit-mask-image:url(../img/icons/antigravity.svg);mask-image:url(../img/icons/antigravity.svg)}
.ic-gemini{-webkit-mask-image:url(../img/icons/gemini.svg);mask-image:url(../img/icons/gemini.svg)}
.ic-grok{-webkit-mask-image:url(../img/icons/grok.svg);mask-image:url(../img/icons/grok.svg)}
.ic-copilot{-webkit-mask-image:url(../img/icons/githubcopilot.svg);mask-image:url(../img/icons/githubcopilot.svg)}
.ic-aider{-webkit-mask-image:url(../img/icons/aider.svg);mask-image:url(../img/icons/aider.svg)}
.ic-aws{-webkit-mask-image:url(../img/icons/aws.svg);mask-image:url(../img/icons/aws.svg)}
.ic-opencode{-webkit-mask-image:url(../img/icons/opencode.svg);mask-image:url(../img/icons/opencode.svg)}
.ic-ollama{-webkit-mask-image:url(../img/icons/ollama.svg);mask-image:url(../img/icons/ollama.svg)}
.ic-groq{-webkit-mask-image:url(../img/icons/groq.svg);mask-image:url(../img/icons/groq.svg)}
.ic-custom{-webkit-mask-image:url(../img/icons/custom.svg);mask-image:url(../img/icons/custom.svg)}
@media(prefers-reduced-motion:no-preference){.mq-t{animation:mq 52s linear infinite}}
@keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══ PROTOCOL FLAT LIST (roadmap centerpiece) ═══ */
.plist{border-top:1px solid var(--border)}
.plist-item{display:grid;grid-template-columns:52px 188px minmax(0,1fr) auto;gap:26px;align-items:center;width:100%;text-align:left;padding:22px 8px;border-bottom:1px solid var(--border);transition:background var(--dur)}
.plist-item:hover{background:rgba(255,255,255,.022)}
.plist-num{font-family:var(--f-mono);font-size:1.3rem;font-weight:600;color:var(--t4)}
.plist-thumb{position:relative;aspect-ratio:16/10;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--bg-c)}
.plist-thumb img{width:100%;height:100%;object-fit:cover;opacity:.74;transition:opacity var(--dur),transform var(--dur-s) var(--ease)}
.plist-item:hover .plist-thumb img{opacity:1;transform:scale(1.05)}
.plist-play{position:absolute;inset:0;display:grid;place-items:center}
.plist-play i{width:42px;height:42px;border-radius:50%;background:rgba(9,9,11,.55);border:1px solid var(--border-h);backdrop-filter:blur(6px);display:grid;place-items:center;transition:transform var(--dur),background var(--dur)}
.plist-play i::before{content:'';border-style:solid;border-width:7px 0 7px 12px;border-color:transparent transparent transparent var(--t1);margin-left:3px}
.plist-item:hover .plist-play i{transform:scale(1.14);background:rgba(9,9,11,.78)}
.plist-head{display:flex;align-items:center;gap:12px;margin-bottom:3px;flex-wrap:wrap}
.plist-city{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;font-size:clamp(1.5rem,2.4vw,1.9rem);line-height:1.05}
.plist-code{font-family:var(--f-mono);font-size:.72rem;font-weight:600;color:var(--t3);letter-spacing:.16em;text-transform:uppercase;margin-bottom:9px}
.plist-desc{font-family:var(--f-mono);font-size:.84rem;color:var(--t2);max-width:560px;line-height:1.55}
.plist-date{font-family:var(--f-mono);font-size:.8rem;color:var(--t3);white-space:nowrap;text-align:right;letter-spacing:.02em}
@media(max-width:860px){.plist-item{grid-template-columns:44px 132px minmax(0,1fr);gap:16px}.plist-date{display:none}.plist-desc{display:none}}
@media(max-width:520px){.plist-item{grid-template-columns:1fr;gap:12px}.plist-num{display:none}.plist-thumb{aspect-ratio:16/9}}
/* status badges */
.st{font-family:var(--f-mono);font-size:.68rem;font-weight:600;letter-spacing:.08em;padding:2px 10px;border-radius:100px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.st-live{color:#09090B;background:var(--accent)}
.st-live .dot{width:6px;height:6px;border-radius:50%;background:#09090B}
.st-next{color:var(--t1);border:1px solid var(--border-s)}
.st-plan{color:var(--t3);border:1px solid var(--border-h)}

/* ═══ VIDEO STAGE (fixed overlay — the page keeps its scroll position) ═══ */
#video-stage{display:none;position:fixed;inset:0;z-index:200;overflow-y:auto;background:rgba(9,9,11,.74);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
#video-stage.open{display:block;animation:vstageIn .3s var(--ease)}
@keyframes vstageIn{from{opacity:0}to{opacity:1}}
.vstage-inner{width:min(1080px,calc(100% - 32px));margin:clamp(20px,6vh,64px) auto;padding:clamp(20px,4vw,40px) 24px clamp(28px,5vw,48px);position:relative;background:linear-gradient(180deg,var(--bg-s),var(--bg));border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}
.vstage-close{position:absolute;top:clamp(14px,3vw,28px);right:24px;width:38px;height:38px;border-radius:50%;border:1px solid var(--border-h);background:rgba(9,9,11,.5);color:var(--t1);font-size:1.3rem;line-height:1;display:grid;place-items:center;z-index:3;transition:background var(--dur)}
.vstage-close:hover{background:rgba(9,9,11,.9)}
.vstage-media{position:relative;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);background:#000;margin-bottom:26px;box-shadow:var(--shadow-lg)}
.vstage-media video,.vstage-media img{width:100%;height:100%;object-fit:cover;display:block}
.vstage-soon{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:20px;background:linear-gradient(to top,rgba(9,9,11,.85),rgba(9,9,11,.35))}
.vstage-soon.show{display:flex}
.vstage-soon .mono{font-family:var(--f-mono);color:var(--t1);font-size:.92rem;letter-spacing:.16em;font-weight:600}
.vstage-soon p{color:var(--t3);font-size:.86rem;max-width:380px}
.vstage-code{font-family:var(--f-mono);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--t3);margin-bottom:8px}
.vstage-title{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;font-size:clamp(2rem,4vw,3rem);line-height:1.08;margin-bottom:12px}
.vstage-meta{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);margin-bottom:14px}
.vstage-desc{font-family:var(--f-mono);font-size:.95rem;color:var(--t2);line-height:1.65;max-width:720px}

/* ═══ CHRONICLE (news + bug-fix feed) ═══ */
.chron-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.chron-filter button{font-family:var(--f-mono);font-size:.78rem;font-weight:500;letter-spacing:.04em;padding:6px 15px;border-radius:9px;border:1px solid var(--border);color:var(--t3);transition:all var(--dur)}
.chron-filter button:hover{color:var(--t1);border-color:var(--border-h)}
.chron-filter button.active{color:#09090B;border-color:transparent;background:var(--accent)}
.chron{border-top:1px solid var(--border)}
.chron-item{display:grid;grid-template-columns:130px minmax(0,1fr);gap:26px;padding:24px 6px;border-bottom:1px solid var(--border);transition:background var(--dur)}
.chron-item:hover{background:rgba(255,255,255,.022)}
.chron-date{font-family:var(--f-mono);font-size:.78rem;color:var(--t4);letter-spacing:.05em;padding-top:5px;white-space:nowrap}
.chron-title{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;font-size:1.5rem;color:var(--t1);line-height:1.12;margin-bottom:7px}
.chron-blurb{font-family:var(--f-mono);font-size:.86rem;color:var(--t2);max-width:620px;line-height:1.6}
.chron-tag{display:inline-block;font-family:var(--f-mono);font-size:.62rem;font-weight:600;letter-spacing:.08em;padding:1px 8px;border-radius:5px;margin-left:10px;vertical-align:middle;transform:translateY(-2px)}
.tag-release{color:var(--t1);border:1px solid var(--border-s)}
.tag-bug{color:var(--warn);border:1px solid rgba(251,191,36,.4)}
.tag-news{color:var(--t3);border:1px solid var(--border-h)}
@media(max-width:600px){.chron-item{grid-template-columns:1fr;gap:6px}.chron-date{padding-top:0}}
.chron-feat{display:block;position:relative;border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--border);margin-bottom:14px;aspect-ratio:21/9;background:var(--bg-s)}
.chron-feat img{width:100%;height:100%;object-fit:cover;opacity:.6}
.chron-feat-body{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(20px,4vw,40px);background:linear-gradient(to top,rgba(9,9,11,.94) 8%,transparent 72%)}
.chron-feat-meta{font-family:var(--f-mono);font-size:.74rem;font-weight:600;color:var(--t3);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.chron-feat-title{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;font-size:clamp(1.8rem,4vw,3rem);color:var(--t1);line-height:1.08;max-width:24ch}

/* ═══ AGENT ROSTER — orbs for the 10 imageless agents ═══ */
.roster{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:560px){.roster{grid-template-columns:repeat(3,1fr)}.roster-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:920px){.roster{grid-template-columns:repeat(6,1fr)}.roster-4{grid-template-columns:repeat(4,1fr)}}
.rc{position:relative;padding:22px 14px 18px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg-c);text-align:center;transition:transform var(--dur) var(--ease),border-color var(--dur)}
.rc:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--ac) 45%,transparent)}
.orb{width:54px;height:54px;margin:0 auto 13px;border-radius:50%;display:grid;place-items:center;font-family:var(--f-mono);font-size:1.4rem;font-weight:600;color:#09090B;
  background:radial-gradient(circle at 50% 36%,var(--ac),color-mix(in srgb,var(--ac) 50%,#0a0a0c));
  box-shadow:0 0 22px color-mix(in srgb,var(--ac) 40%,transparent),inset 0 -6px 10px rgba(0,0,0,.34);
  border:1px solid color-mix(in srgb,var(--ac) 60%,transparent)}
.rc .hand{font-family:var(--f-mono);color:var(--ac);font-size:.9rem;font-weight:600;letter-spacing:.01em;margin-bottom:2px}
.rc .role{font-size:.74rem;color:var(--t3);line-height:1.3}
.rc .tier{position:absolute;top:9px;right:9px;font-family:var(--f-mono);font-size:.64rem;color:var(--t4);border:1px solid var(--border);border-radius:6px;padding:1px 7px;letter-spacing:.02em}
.tier-group{font-family:var(--f-mono);font-size:.74rem;color:var(--t3);font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin:28px 0 14px;display:flex;align-items:center;gap:12px}
.tier-group::after{content:'';flex:1;height:1px;background:var(--border)}

/* ─── Character (core) grid — real renders ─── */
.chg{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:640px){.chg{grid-template-columns:repeat(3,1fr)}}
@media(min-width:960px){.chg{grid-template-columns:repeat(6,1fr)}}
.chc{text-align:center;padding:16px 12px;border-radius:var(--r-lg);border:1px solid transparent;transition:border-color var(--dur),background var(--dur)}
.chc:hover{border-color:var(--border);background:var(--bg-c)}
.chc img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--r-lg);margin-bottom:12px;border:1px solid var(--border)}
.chc h4{font-size:.9rem;font-weight:700;margin-bottom:2px}.chc .hand{font-family:var(--f-mono);color:var(--t3);font-size:.8rem;font-weight:500}.chc p{font-size:.74rem;color:var(--t3);margin-top:2px}
.cd{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;vertical-align:middle}

/* ═══ LEAGUE LADDER (Moscow / Arena) ═══ */
.leagues{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:520px){.leagues{grid-template-columns:repeat(4,1fr)}}
@media(min-width:880px){.leagues{grid-template-columns:repeat(7,1fr)}}
.league{text-align:center;padding:18px 8px;border-radius:var(--r);border:1px solid var(--border);background:var(--bg-c);transition:transform var(--dur),border-color var(--dur)}
.league:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--lc) 50%,transparent)}
.league-ico{font-size:1.5rem;color:var(--lc);line-height:1;margin-bottom:8px}
.league-name{font-family:var(--f-mono);font-size:.82rem;font-weight:600;color:var(--t1);letter-spacing:.02em}
.league-lv{font-family:var(--f-mono);font-size:.7rem;color:var(--t4)}

/* ═══ MODES / mini-cards ═══ */
.minis{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.minis{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.minis-3{grid-template-columns:repeat(3,1fr)}.minis-5{grid-template-columns:repeat(5,1fr)}}
.mini{padding:22px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg-c);transition:transform var(--dur) var(--ease),border-color var(--dur)}
.mini:hover{transform:translateY(-2px);border-color:var(--border-h)}
.mini .kbd{font-family:var(--f-mono);font-size:.76rem;color:var(--t3);border:1px solid var(--border-h);border-radius:6px;padding:1px 8px;float:right}
.mini h4{font-family:var(--f-sans);font-size:1rem;font-weight:700;margin-bottom:6px}
.mini .ico{font-size:1.3rem;margin-bottom:12px;color:var(--t1)}
.mini p{color:var(--t2);font-size:.84rem;line-height:1.55}

/* ─── Cards / bento / split / image frame ─── */
.img-f{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);background:var(--bg-s);transition:border-color var(--dur),transform var(--dur) var(--ease)}
.img-f:hover{border-color:var(--border-h);transform:translateY(-2px)}
.img-f img{width:100%;display:block;object-fit:cover}
.card{background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;transition:transform var(--dur) var(--ease),border-color var(--dur),box-shadow var(--dur)}
.card:hover{transform:translateY(-2px);border-color:var(--border-h);box-shadow:var(--shadow)}
.card-img{width:100%;overflow:hidden;background:var(--bg-e)}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--dur-s) var(--ease)}
.card:hover .card-img img{transform:scale(1.03)}
.card-b{padding:24px}
.card-b h3{font-family:var(--f-sans);font-weight:700;font-size:1.05rem;letter-spacing:-.02em;margin-bottom:6px}
.card-b p{color:var(--t2);font-size:.875rem;line-height:1.6}
.ratio-16-9{aspect-ratio:16/9}.ratio-16-10{aspect-ratio:16/10}.ratio-4-3{aspect-ratio:4/3}.ratio-1-1{aspect-ratio:1/1}.ratio-3-4{aspect-ratio:3/4}
.bento{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.bento{grid-template-columns:repeat(2,1fr)}.bento-w{grid-column:span 2}}
@media(min-width:960px){.bento-3{grid-template-columns:repeat(3,1fr)}}
.bento>.card{display:flex;flex-direction:column}.bento>.card .card-b{flex:1;display:flex;flex-direction:column}.bento>.card .card-b p{flex:1}
.split{display:grid;grid-template-columns:1fr;gap:clamp(32px,4vw,64px);align-items:center}
@media(min-width:768px){.split{grid-template-columns:1fr 1fr}}
.steps{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:768px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{text-align:center;padding:clamp(24px,4vw,40px) 20px;border-radius:var(--r-xl);border:1px solid var(--border);background:var(--bg-c);transition:border-color var(--dur),transform var(--dur) var(--ease)}
.step:hover{border-color:var(--border-h);transform:translateY(-2px)}
.step-n{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--bg-e);font-family:var(--f-mono);font-size:1.05rem;font-weight:600;color:var(--t1);border:1px solid var(--border);margin-bottom:16px}
.step h3{margin-bottom:8px;font-size:1rem;font-weight:700}.step p{color:var(--t2);font-size:.875rem;max-width:300px;margin:0 auto}
.fg{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
@media(min-width:640px){.fg{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.fg{grid-template-columns:repeat(3,1fr)}}
.fi{background:var(--bg-c);padding:clamp(24px,3vw,36px);transition:background var(--dur)}.fi:hover{background:var(--bg-e)}
.fi-i{width:38px;height:38px;border-radius:var(--r-sm);background:var(--bg-e);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--t1)}
.fi h4{font-size:.95rem;font-weight:700;margin-bottom:6px}.fi p{color:var(--t2);font-size:.82rem;line-height:1.55}

/* ─── Compare grid ─── */
.cg{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:768px){.cg{grid-template-columns:1fr 1fr}}
.cc{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);background:var(--bg-c);transition:border-color var(--dur),transform var(--dur) var(--ease)}
.cc:hover{transform:translateY(-2px);border-color:var(--border-h)}
.cc img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.cc-l{padding:16px 20px;display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--t2)}
.cc-l span{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}

/* ─── Showcase + benchmark ─── */
.showcase{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.showcase{grid-template-columns:1fr 1fr}}
.showcase-card{border-radius:var(--r-2xl);border:1px solid var(--border);background:var(--bg-c);padding:clamp(20px,3vw,32px);transition:border-color var(--dur),transform var(--dur) var(--ease);display:flex;flex-direction:column}
.showcase-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.showcase-window{background:#0D0D10;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:28px;overflow:hidden;flex:1;display:flex;flex-direction:column;justify-content:center}
.showcase-dots{display:flex;gap:6px;margin-bottom:20px}
.showcase-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15)}
.showcase-code{font-family:var(--f-code);font-size:clamp(.72rem,1vw,.82rem);line-height:1.8;color:var(--t2)}
.showcase-code .ln{color:var(--t4);margin-right:16px;user-select:none}
.showcase-code .gr{color:var(--t1)}.showcase-code .wh{color:var(--t1)}.showcase-code .str{color:var(--t3)}
.showcase-card .t-h3{font-family:var(--f-display);font-weight:500;font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.12;margin:10px 0;letter-spacing:.04em}
.showcase-card .t-body{color:var(--t2);font-size:.9rem;max-width:420px}
.bench-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.bench-label{font-family:var(--f-code);font-size:.78rem;color:var(--t2);min-width:140px}
.bench-bar{flex:1;height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.bench-fill{height:100%;border-radius:3px;background:var(--t4);transition:width 600ms var(--ease)}
.bench-fill.active{background:var(--accent)}
.bench-val{font-family:var(--f-code);font-size:.78rem;color:var(--t3);min-width:48px;text-align:right}
.bench-val.active{color:var(--accent)}

/* ─── Timeline ─── */
.tl-wrap{overflow-x:auto;padding:8px 0 16px;-webkit-overflow-scrolling:touch}
.tl-track{display:flex;gap:0;min-width:max-content;justify-content:center}
.tl-step{display:flex;flex-direction:column;align-items:center;position:relative;min-width:100px;flex:1}
.tl-time{font-family:var(--f-mono);font-size:.74rem;color:var(--t4);margin-bottom:8px}
.tl-icon{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.04);border:1.5px solid var(--tc);color:var(--tc);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;transition:transform var(--dur),box-shadow var(--dur)}
.tl-icon:hover{transform:scale(1.12);box-shadow:0 0 20px color-mix(in srgb,var(--tc) 30%,transparent)}
.tl-icon-done{background:var(--tc);color:#09090B;border-color:var(--tc);box-shadow:0 0 16px color-mix(in srgb,var(--tc) 40%,transparent)}
.tl-line{position:absolute;top:30px;left:calc(50% + 22px);width:calc(100% - 44px);height:1.5px;background:var(--border);z-index:0}
.tl-step-last .tl-line{display:none}
.tl-name{font-size:.75rem;font-weight:600;color:var(--t2);margin-top:8px;text-align:center;white-space:nowrap}
@media(max-width:768px){.tl-step{min-width:80px}.tl-icon{width:36px;height:36px}.tl-line{top:26px;left:calc(50% + 18px);width:calc(100% - 36px)}}

/* ─── Session stats ─── */
.ss-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:768px){.ss-grid{grid-template-columns:1fr}}
.ss-card{background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;transition:border-color var(--dur),transform var(--dur) var(--ease)}
.ss-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.ss-card h4{font-size:.95rem;font-weight:700;margin-bottom:16px;color:var(--t1)}
.ss-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-family:var(--f-code);font-size:.82rem;color:var(--t2);border-bottom:1px solid var(--border)}
.ss-row:last-child{border-bottom:none}
.ss-plus{color:var(--t1);font-weight:700;width:16px}.ss-minus{color:var(--t3);font-weight:700;width:16px}.ss-ok{color:var(--t1);font-weight:700;width:16px}
.ss-card-chart{display:flex;flex-direction:column}
.ss-card-chart .ss-bars{margin-top:auto;margin-bottom:auto}
.ss-bars{display:flex;gap:20px;align-items:flex-end;justify-content:center;height:142px}
.ss-bar-item{display:flex;flex-direction:column;align-items:center;gap:6px}
.ss-bar-col{width:48px;border-radius:6px 6px 2px 2px;opacity:.85}.ss-bar-item:hover .ss-bar-col{opacity:1}
.ss-bar-num{font-family:var(--f-mono);font-size:1.05rem;font-weight:600;color:var(--t1)}
.ss-bar-label{font-family:var(--f-mono);font-size:.72rem}
.ss-reasons{display:flex;flex-direction:column;gap:10px}
.ss-reason{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--t2)}.ss-reason span{color:var(--t1);font-weight:700}

/* ─── VS mockups ─── */
.vs-row{margin-bottom:48px}
.vs-label{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--t2);margin-bottom:16px}
.vs-dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.vs-pair{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:stretch}
@media(max-width:960px){.vs-pair{grid-template-columns:1fr;gap:12px}}
.vs-badge{display:flex;align-items:center;justify-content:center;width:48px;font-family:var(--f-mono);font-size:1rem;font-weight:600;color:var(--t4)}
@media(max-width:960px){.vs-badge{width:auto;padding:8px 0}}
.vs-card{border-radius:var(--r-xl);border:1px solid var(--border);overflow:hidden;background:var(--bg-c);display:flex;flex-direction:column;transition:transform var(--dur) var(--ease),border-color var(--dur)}
.vs-card:hover{transform:translateY(-2px);border-color:var(--border-h)}
.vs-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-e)}
.vs-header-neon{background:rgba(255,255,255,.04)}
.vs-tag{font-family:var(--f-mono);font-size:.72rem;font-weight:600;color:var(--t3);letter-spacing:.08em;text-transform:uppercase}
.vs-tag-neon{font-family:var(--f-mono);font-size:.72rem;font-weight:600;color:var(--t1);letter-spacing:.08em;text-transform:uppercase}
.vs-sub{font-size:.75rem;color:var(--t4)}.vs-sub-neon{font-size:.75rem;color:var(--t2)}
.vs-mock{flex:1;font-family:var(--f-code);font-size:.72rem;line-height:1.6;overflow:hidden}
.vs-statusbar-mock{padding:6px 16px;font-family:var(--f-code);font-size:.65rem;color:var(--t4);border-top:1px solid var(--border);background:var(--bg-e)}
.vs-points{padding:14px 20px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px 16px}
.vs-pt{font-size:.78rem;display:flex;align-items:center;gap:5px}.vs-pt span{font-weight:700}
.vs-pt-neg{color:var(--t4)}.vs-pt-neg span{color:var(--t3)}
.vs-pt-pos{color:var(--t2)}.vs-pt-pos span{color:var(--t1)}
.vs-mock-ide{display:grid;grid-template-columns:140px 1fr;grid-template-rows:1fr auto;min-height:280px}
.vs-ide-sidebar{padding:10px;border-right:1px solid var(--border);background:rgba(0,0,0,.2);grid-row:span 2}
.vs-tree-item{padding:2px 6px;color:var(--t4);font-size:.68rem;border-radius:3px;white-space:nowrap;overflow:hidden}
.vs-ti1{padding-left:16px}.vs-ti2{padding-left:26px}.vs-ti-active{background:rgba(255,255,255,.05);color:var(--t2)}
.vs-ide-editor{padding:10px 14px;color:var(--t3)}
.vs-ln{white-space:nowrap;overflow:hidden}.vs-ln span{color:var(--t4);margin-right:10px;display:inline-block;min-width:18px;text-align:right;user-select:none}
.vs-ide-chat{padding:8px 12px;border-top:1px solid var(--border);background:rgba(0,0,0,.15)}
.vs-chat-msg{font-size:.68rem;color:var(--t3);padding:6px 8px;background:rgba(255,255,255,.03);border-radius:6px;margin-bottom:6px}
.vs-chat-input{font-size:.68rem;color:var(--t4);padding:6px 8px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:6px;display:flex;justify-content:space-between;align-items:center}
.vs-mock-neon{position:relative;min-height:280px;display:flex;flex-direction:column}
.vs-neon-3d{flex:1;position:relative;overflow:hidden;background:linear-gradient(135deg,#16161a,#0d0d0f)}
.vs-neon-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:12px;gap:6px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent 60%)}
.vs-neon-status{font-family:var(--f-mono);font-size:.78rem;font-weight:600;color:var(--t1);letter-spacing:.05em;text-shadow:0 0 12px rgba(255,255,255,.2)}
.vs-neon-lines{font-family:var(--f-mono);font-size:.82rem;color:var(--t1)}.vs-neon-lines span{font-size:1.1rem;font-weight:600}.vs-neon-lines small{color:var(--t2);font-size:.72rem}
.vs-neon-progress{font-family:var(--f-mono);font-size:.82rem;color:var(--t1);background:var(--accent-soft);padding:3px 10px;border-radius:6px;display:inline-block;width:fit-content;border:1px solid var(--border-h)}
.vs-neon-checks{font-family:var(--f-mono);font-size:.68rem;color:var(--t2)}
.vs-neon-xp{padding:8px 14px;display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:.74rem;color:var(--t3);border-top:1px solid var(--border);background:rgba(0,0,0,.25)}
.vs-xp-track{flex:1;height:4px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.vs-xp-fill{width:82%;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px}
.vs-mock-term{padding:14px 16px;background:#0D0D10;color:var(--t3);min-height:280px}
.vs-term-line{margin-bottom:2px;color:var(--t2)}.vs-term-p{color:var(--t3);margin-right:6px}
.vs-term-out{color:var(--t4);margin-bottom:8px;padding-left:16px}
.vs-term-cursor{color:var(--t3);animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}
.vs-mock-neonterm{padding:14px 16px;background:#0D0D10;min-height:280px;display:flex;flex-direction:column;gap:10px}
.vs-nt-step{padding:8px 12px;border-radius:8px;background:rgba(255,255,255,.02);border:1px solid var(--border)}
.vs-nt-active{border-color:var(--border-h);background:rgba(255,255,255,.04)}
.vs-nt-badge{font-family:var(--f-mono);font-size:.74rem;font-weight:600;margin-bottom:4px}
.vs-nt-done{color:var(--t1)}.vs-nt-running{color:var(--t1)}
.vs-nt-detail{font-family:var(--f-code);font-size:.65rem;color:var(--t4);margin-bottom:6px}
.vs-nt-pass{color:var(--t1);font-weight:600;margin-right:4px}
.vs-nt-bar{height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.vs-nt-fill{height:100%;background:var(--accent);border-radius:2px}
.vs-nt-anim{background:linear-gradient(90deg,var(--accent-2),var(--accent));animation:ntPulse 2s ease infinite}
@keyframes ntPulse{0%,100%{opacity:.6}50%{opacity:1}}
.vs-nt-overall{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;background:rgba(255,255,255,.03);border:1px solid var(--border)}
.vs-nt-ol-label{font-family:var(--f-mono);font-size:.7rem;color:var(--t3)}
.vs-nt-ol-bar{flex:1;height:5px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.vs-nt-ol-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:3px}
.vs-nt-ol-pct{font-family:var(--f-mono);font-size:.82rem;font-weight:600;color:var(--t1)}
.vs-nt-agent{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--t2)}
.vs-nt-agent-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(255,255,255,.4);animation:agentPulse 2s ease infinite}
@keyframes agentPulse{0%,100%{transform:scale(.9);opacity:.7}50%{transform:scale(1.1);opacity:1}}

/* ─── Form / CTA ─── */
.form-g{margin-bottom:20px}
.form-l{display:block;font-size:.82rem;font-weight:500;margin-bottom:6px;color:var(--t2)}
.form-i{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--r);font-size:.95rem;background:var(--bg-c);color:var(--t1);transition:border-color var(--dur)}
.form-i:focus{outline:none;border-color:var(--border-s)}.form-i::placeholder{color:var(--t4)}
textarea.form-i{min-height:90px;resize:vertical}
.cta-b{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--r-2xl);padding:clamp(32px,5vw,56px);display:grid;grid-template-columns:1fr;gap:32px;align-items:center;position:relative;overflow:hidden}
.cta-b::before{content:'';position:absolute;top:-40%;right:-10%;width:420px;height:420px;background:radial-gradient(circle,rgba(255,255,255,.035),transparent 70%);pointer-events:none}
@media(min-width:768px){.cta-b{grid-template-columns:1fr auto}}
.cta-b-img{width:140px;border-radius:var(--r-lg);justify-self:center;border:1px solid var(--border)}
@media(min-width:768px){.cta-b-img{justify-self:end}}

/* ═══ FOOTER (shared, multi-col + socials) ═══ */
.footer{background:var(--bg);border-top:1px solid var(--border);padding:clamp(48px,7vw,72px) 0 28px}
.footer-top{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:32px}
@media(max-width:760px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.footer-top{grid-template-columns:1fr}}
.footer-brand .logo{margin-bottom:12px}
.footer-brand p{color:var(--t3);font-size:.86rem;max-width:280px;line-height:1.6}
.footer-col h5{font-family:var(--f-mono);font-size:.74rem;color:var(--t3);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.footer-col a{display:block;color:var(--t3);font-size:.88rem;padding:5px 0;transition:color var(--dur)}
.footer-col a:hover{color:var(--t1)}
.socials{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.socials a{width:36px;height:36px;border:1px solid var(--border);border-radius:9px;display:grid;place-items:center;color:var(--t2);transition:all var(--dur)}
.socials a:hover{color:var(--t1);border-color:var(--border-s);transform:translateY(-2px)}
.socials svg{width:17px;height:17px;fill:currentColor}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;align-items:center;border-top:1px solid var(--border);margin-top:36px;padding-top:22px}
.footer-bottom p{color:var(--t4);font-size:.82rem}
.footer-bottom .fb-links{display:flex;gap:20px;font-size:.82rem}
.footer-bottom a{color:var(--t3)}.footer-bottom a:hover{color:var(--t1)}

/* ═══ LEGAL prose ═══ */
.legal{max-width:780px;margin:0 auto;padding:clamp(48px,8vw,90px) 24px}
.legal h1{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;font-size:clamp(2.2rem,5vw,3.4rem);margin-bottom:10px}
.legal .updated{font-family:var(--f-mono);font-size:.78rem;color:var(--t4);margin-bottom:8px;letter-spacing:.08em;text-transform:uppercase}
.legal h2{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;font-size:clamp(1.4rem,2.6vw,1.9rem);margin:40px 0 12px;color:var(--t1)}
.legal h3{font-size:1.02rem;font-weight:700;margin:22px 0 8px;color:var(--t1)}
.legal p,.legal li{color:var(--t2);font-size:.96rem;line-height:1.75}
.legal p{margin-bottom:14px}
.legal ul{padding-left:22px;margin:6px 0 16px}.legal li{margin-bottom:6px}
.legal a{color:var(--t1);text-decoration:underline;text-underline-offset:3px}.legal strong{color:var(--t1)}
.legal .note{background:var(--bg-c);border:1px solid var(--border);border-left:3px solid var(--accent);padding:16px 20px;border-radius:10px;margin:22px 0;font-size:.88rem;color:var(--t3);line-height:1.6}

/* ─── Page hero (sub-pages) ─── */
.page-hero{padding:clamp(56px,9vw,110px) 0 clamp(32px,5vw,56px);border-bottom:1px solid var(--border)}
.page-hero h1{margin-bottom:14px}
.page-hero p{color:var(--t2);max-width:560px}

/* ─── Reveal anims ─── */
@media(prefers-reduced-motion:no-preference){
  .rv{opacity:0;transform:translateY(16px);transition:opacity 560ms var(--ease),transform 560ms var(--ease)}
  .rv.is-visible{opacity:1;transform:none}
  .rl{opacity:0;transform:translateX(-20px);transition:opacity 560ms var(--ease),transform 560ms var(--ease)}.rl.is-visible{opacity:1;transform:none}
  .rr{opacity:0;transform:translateX(20px);transition:opacity 560ms var(--ease),transform 560ms var(--ease)}.rr.is-visible{opacity:1;transform:none}
  .rs{opacity:0;transform:scale(.96);transition:opacity 560ms var(--ease),transform 560ms var(--ease)}.rs.is-visible{opacity:1;transform:none}
  .d1{transition-delay:80ms}.d2{transition-delay:160ms}.d3{transition-delay:240ms}.d4{transition-delay:320ms}.d5{transition-delay:400ms}.d6{transition-delay:480ms}
}
@media(prefers-reduced-motion:reduce){.rv,.rl,.rr,.rs{opacity:1;transform:none;transition:none}}

@media(max-width:430px){.wrap,.wrap-n{padding:0 16px}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.bento,.steps,.cg{gap:12px}}

/* ════════════════════════════════════════════════════════════════
   AUTH MODAL — Google / Apple / Email (Supabase)
   ════════════════════════════════════════════════════════════════ */
#auth-stage{display:none;position:fixed;inset:0;z-index:300;overflow-y:auto;background:rgba(9,9,11,.74);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
#auth-stage.open{display:flex;align-items:center;justify-content:center;padding:24px;animation:authIn .28s var(--ease)}
@keyframes authIn{from{opacity:0}to{opacity:1}}
.auth-card{position:relative;width:100%;max-width:420px;background:linear-gradient(180deg,var(--bg-c),var(--bg-s));border:1px solid var(--border-h);border-radius:var(--r-xl);padding:32px 30px 26px;box-shadow:var(--shadow-lg);animation:authRise .42s var(--ease)}
@keyframes authRise{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
.auth-close{position:absolute;top:14px;right:16px;width:34px;height:34px;border-radius:var(--r-sm);color:var(--t3);font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all var(--dur)}
.auth-close:hover{color:var(--t1);background:var(--accent-m)}
.auth-head{text-align:center;margin-bottom:22px}
.auth-mark{display:inline-block;color:var(--accent);font-size:1.4rem;line-height:1;margin-bottom:10px}
.auth-title{font-family:var(--f-display);font-weight:600;font-size:1.35rem;letter-spacing:.01em;margin-bottom:6px}
.auth-sub{color:var(--t3);font-size:.86rem;line-height:1.5;max-width:300px;margin:0 auto}
.auth-providers{display:flex;flex-direction:column;gap:10px}
.auth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:46px;border-radius:var(--r);font-family:var(--f-sans);font-weight:600;font-size:.9rem;border:1px solid var(--border-h);background:var(--bg-e);color:var(--t1);transition:all var(--dur) var(--ease)}
.auth-btn:hover{border-color:var(--border-s);background:#212127;transform:translateY(-1px)}
.auth-btn svg{flex:0 0 auto}
.auth-btn:disabled{opacity:.55;cursor:default;transform:none}
.auth-divider{display:flex;align-items:center;gap:14px;margin:18px 0;color:var(--t4);font-size:.74rem;font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.15em}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-form{display:flex;flex-direction:column;gap:12px}
.auth-field{display:flex;flex-direction:column;gap:6px}
.auth-field span{font-size:.74rem;font-weight:600;letter-spacing:.04em;color:var(--t3);text-transform:uppercase}
.auth-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r);font-size:.92rem;font-family:var(--f-sans);background:var(--bg);color:var(--t1);transition:border-color var(--dur),box-shadow var(--dur)}
.auth-input:focus{outline:none;border-color:var(--border-s);box-shadow:0 0 0 3px rgba(250,250,250,.06)}
.auth-input::placeholder{color:var(--t4)}
.auth-submit{width:100%;margin-top:4px}
.auth-msg{min-height:18px;text-align:center;font-size:.83rem;margin-top:12px;color:var(--t3)}
.auth-msg.err{color:#ff6b6b}
.auth-msg.ok{color:#5fd0a0}
.auth-toggle{text-align:center;font-size:.85rem;color:var(--t3);margin-top:8px}
.auth-toggle button{color:var(--t1);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.auth-toggle button:hover{color:#fff}
.auth-legal{text-align:center;font-size:.72rem;color:var(--t4);margin-top:16px;line-height:1.5}
.auth-legal a{color:var(--t3);text-decoration:underline;text-underline-offset:2px}

/* ════════════════════════════════════════════════════════════════
   ACCOUNT CHIP (header, logged-in)
   ════════════════════════════════════════════════════════════════ */
.acct{position:relative;margin-left:8px}
.acct-trigger{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;border-radius:100px;border:1px solid var(--border-h);background:var(--accent-m);color:var(--t1);transition:all var(--dur)}
.acct-trigger:hover{border-color:var(--border-s);background:var(--bg-e)}
.acct-av{width:26px;height:26px;border-radius:50%;object-fit:cover;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center}
.acct-av-mono{background:linear-gradient(135deg,#3a3a42,#26262c);color:var(--t1);font-family:var(--f-mono);font-size:.7rem;font-weight:700}
.acct-av-lg{width:38px;height:38px;font-size:.85rem}
.acct-name{font-size:.84rem;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-caret{color:var(--t3);transition:transform var(--dur)}
.acct.open .acct-caret{transform:rotate(180deg)}
.acct-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:228px;background:var(--bg-c);border:1px solid var(--border-h);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all var(--dur) var(--ease);z-index:120}
.acct.open .acct-menu{opacity:1;visibility:visible;transform:none}
.acct-id{display:flex;align-items:center;gap:11px;padding:10px 10px 12px;border-bottom:1px solid var(--border);margin-bottom:6px}
.acct-id-name{font-weight:600;font-size:.9rem;color:var(--t1)}
.acct-id-league{font-family:var(--f-mono);font-size:.74rem;font-weight:600;margin-top:2px}
.acct-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border-radius:var(--r-sm);font-size:.86rem;color:var(--t2);text-align:left;transition:all var(--dur)}
.acct-item span{color:var(--t4);font-size:.8rem;width:14px;text-align:center}
.acct-item:hover{background:var(--accent-m);color:var(--t1)}
.acct-signout:hover{color:#ff6b6b}

/* ════════════════════════════════════════════════════════════════
   LEADERBOARD
   ════════════════════════════════════════════════════════════════ */
.lb-hero{padding:clamp(40px,7vw,84px) 0 clamp(18px,3vw,30px)}
.lb-eyebrow{font-family:var(--f-mono);font-size:.74rem;font-weight:600;letter-spacing:.18em;color:var(--t3);text-transform:uppercase;margin-bottom:16px}
.lb-intro{color:var(--t2);font-family:var(--f-mono);font-size:clamp(.92rem,1.2vw,1.05rem);line-height:1.6;max-width:620px;margin-top:18px}
.lb-wrap{padding:0 0 clamp(60px,10vw,120px)}
.lb-controls{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;margin-bottom:22px}
.lb-tabs{display:flex;gap:4px;background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:4px;overflow-x:auto;max-width:100%}
.lb-tab{padding:8px 15px;border-radius:var(--r-sm);font-size:.82rem;font-weight:500;color:var(--t3);white-space:nowrap;transition:all var(--dur)}
.lb-tab:hover{color:var(--t1)}
.lb-tab.active{background:var(--accent);color:#09090B;font-weight:600}
.lb-metric{display:flex;gap:4px;background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:4px}
.lb-mbtn{padding:8px 16px;border-radius:var(--r-sm);font-size:.82rem;font-weight:500;color:var(--t3);transition:all var(--dur)}
.lb-mbtn.active{background:var(--accent-soft);color:var(--t1);font-weight:600}
.lb-controls.xp-mode .lb-tabs{opacity:.4;pointer-events:none}
.lb-board{display:flex;flex-direction:column;gap:6px}
.lb-row{display:grid;grid-template-columns:54px 1fr auto;align-items:center;gap:14px;padding:13px 18px;background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);transition:border-color var(--dur),transform var(--dur)}
.lb-row:not(.lb-head):hover{border-color:var(--border-h);transform:translateX(2px)}
.lb-head{background:transparent;border:none;padding:4px 18px;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--t4)}
.lb-head .lb-vals{text-align:right}
.lb-rank{font-family:var(--f-mono);font-size:1.05rem;font-weight:700;color:var(--t3);text-align:center}
.lb-row.rank-1 .lb-rank{color:#ffd24a}.lb-row.rank-2 .lb-rank{color:#cfd6d2}.lb-row.rank-3 .lb-rank{color:#c8884a}
.lb-row.rank-1{border-color:rgba(255,210,74,.35);background:linear-gradient(90deg,rgba(255,210,74,.06),var(--bg-c) 42%)}
.lb-row.rank-2{border-color:rgba(207,214,210,.26)}
.lb-row.rank-3{border-color:rgba(200,136,74,.26)}
.lb-player{display:flex;align-items:center;gap:13px;min-width:0}
.lb-av{width:38px;height:38px;border-radius:50%;object-fit:cover;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center}
.lb-av-mono{background:linear-gradient(135deg,#3a3a42,#26262c);color:var(--t1);font-family:var(--f-mono);font-size:.82rem;font-weight:700}
.lb-pmeta{min-width:0}
.lb-name{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.93rem;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-league{display:flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:.76rem;font-weight:600;margin-top:3px}
.lb-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex:0 0 auto}
.lb-vals{text-align:right}
.lb-metricval{font-family:var(--f-mono);font-size:1.02rem;font-weight:700;color:var(--t1);display:flex;align-items:baseline;gap:6px;justify-content:flex-end}
.lb-metricval span{font-size:.7rem;font-weight:500;color:var(--t4);letter-spacing:.04em}
.lb-sub2{font-family:var(--f-mono);font-size:.74rem;color:var(--t3);margin-top:3px}
.lb-tier{font-family:var(--f-mono);font-size:.62rem;font-weight:700;letter-spacing:.08em;padding:2px 6px;border-radius:5px}
.tier-pro{background:rgba(111,224,208,.14);color:#6fe0d0;border:1px solid rgba(111,224,208,.3)}
.tier-team{background:rgba(192,139,255,.14);color:#c08bff;border:1px solid rgba(192,139,255,.3)}
.lb-you{font-family:var(--f-mono);font-size:.6rem;font-weight:700;letter-spacing:.1em;padding:2px 6px;border-radius:5px;background:var(--accent);color:#09090B}
.lb-row.me{border-color:var(--border-s);background:linear-gradient(90deg,var(--accent-m),var(--bg-c) 50%)}
.lb-row.flash{animation:lbFlash 1.4s var(--ease)}
@keyframes lbFlash{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 2px rgba(250,250,250,.3)}}
.lb-state{padding:48px 24px;text-align:center;color:var(--t2);font-family:var(--f-mono);font-size:.92rem;line-height:1.7;background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r)}
.lb-state span{color:var(--t4);font-size:.84rem}
.lb-err span{color:#ff6b6b}
.lb-hint{margin-top:8px;padding:16px}
.lb-foot{text-align:center;color:var(--t4);font-size:.8rem;font-family:var(--f-mono);margin-top:26px}
.lb-foot a{color:var(--t3);text-decoration:underline;text-underline-offset:3px}
.lb-foot a:hover{color:var(--t1)}
@media(max-width:560px){
  .lb-row{grid-template-columns:36px 1fr auto;gap:10px;padding:11px 13px}
  .lb-av{width:34px;height:34px}
}
@media(max-width:860px){
  .acct{margin-top:20px;margin-left:0}
  .acct-trigger{width:100%;justify-content:flex-start}
  .acct-name{max-width:none}
  .acct-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;margin-top:8px;display:none;min-width:0}
  .acct.open .acct-menu{display:block}
}

/* ─── Leaderboard "your standing" card (top-right of the hero) ─── */
.lb-hero .wrap{position:relative}
.lb-me{position:absolute;top:6px;right:0;display:flex;align-items:center;gap:18px;background:var(--bg-c);border:1px solid var(--border-h);border-radius:var(--r-lg);padding:12px 16px;box-shadow:var(--shadow);max-width:350px}
.lb-me-id{display:flex;align-items:center;gap:11px}
.lb-me-name{display:flex;align-items:center;gap:7px;font-weight:600;font-size:.9rem;color:var(--t1)}
.lb-me-league{display:flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:.74rem;font-weight:600;margin-top:3px}
.lb-me-xp{min-width:118px}
.lb-me-xpnum{font-family:var(--f-mono);font-weight:700;font-size:.95rem;color:var(--t1);text-align:right}
.lb-me-bar{height:6px;border-radius:3px;background:var(--bg-e);overflow:hidden;margin:5px 0 4px}
.lb-me-bar i{display:block;height:100%;border-radius:3px;transition:width .5s var(--ease)}
.lb-me-next{font-family:var(--f-mono);font-size:.66rem;color:var(--t4);text-align:right}
.lb-me-share{align-self:center;padding:8px 13px;border-radius:var(--r-sm);font-size:.72rem;font-weight:600;font-family:var(--f-mono);color:var(--t1);background:var(--accent-m);border:1px solid var(--border-h);white-space:nowrap;transition:all var(--dur) var(--ease)}
.lb-me-share:hover{background:var(--bg-e);border-color:var(--border-s);transform:translateY(-1px)}
@media(max-width:760px){
  .lb-me{position:static;margin-top:22px;max-width:none;justify-content:space-between}
}

/* ─── Pricing ─── */
.pr-hero{padding:clamp(40px,7vw,84px) 0 clamp(16px,3vw,28px)}
.pr-wrap{padding:0 0 clamp(60px,10vw,120px)}
.pr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.pr-card{position:relative;background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 24px;display:flex;flex-direction:column}
.pr-card-feature{border-color:rgba(111,224,208,.4);box-shadow:0 0 0 1px rgba(111,224,208,.15),var(--shadow)}
.pr-badge{position:absolute;top:16px;right:18px;font-family:var(--f-mono);font-size:.66rem;font-weight:700;letter-spacing:.12em}
.pr-tier{font-family:var(--f-mono);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--t2)}
.pr-price{font-family:var(--f-display);font-weight:600;font-size:2.6rem;line-height:1;margin:14px 0 20px;color:var(--t1)}
.pr-price span{font-family:var(--f-sans);font-size:.95rem;font-weight:500;color:var(--t3)}
.pr-feats{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px;flex:1}
.pr-feats li{position:relative;padding-left:24px;font-size:.9rem;color:var(--t2);line-height:1.5}
.pr-feats li::before{content:'\2713';position:absolute;left:0;top:0;color:var(--t3);font-size:.8rem}
.pr-feats strong{color:var(--t1)}
.pr-btn{width:100%}
.pr-btn:disabled{opacity:.5;cursor:default}
@media(max-width:780px){.pr-grid{grid-template-columns:1fr;max-width:420px;margin-inline:auto}}

/* ═══ CLASSIFIED PROTOCOLS — name + date stay; what they do is a sealed, blurry cloud ═══ */
.locked{cursor:pointer}
/* thumbnail: blurred to abstraction, darkened, sealed */
.locked .plist-thumb img,.locked .rmp-thumb img{filter:blur(13px) saturate(.4) brightness(.4);transform:scale(1.14);opacity:.7}
.locked:hover .plist-thumb img,.locked:hover .rmp-thumb img{opacity:.84;transform:scale(1.18)}
.lock-seal-thumb{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;background:radial-gradient(120% 100% at 50% 38%,transparent,rgba(9,9,11,.6))}
.lock-seal-thumb .lk{font-size:1.35rem;line-height:1;filter:grayscale(1) brightness(1.5);opacity:.92}
.lock-seal-thumb .lbl{position:absolute;bottom:7px;left:0;right:0;text-align:center;font-family:var(--f-mono);font-size:.54rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--t2)}
/* description replaced by a blurry "cloud" of redacted bars + a readable seal chip */
.locked-cloud{position:relative}
.locked-cloud .cloud-txt{display:block;filter:blur(5px);opacity:.5;user-select:none;color:var(--t3);font-family:var(--f-mono);font-size:.84rem;letter-spacing:.05em;line-height:1.5;overflow:hidden}
.locked-cloud .cloud-seal{display:inline-flex;align-items:center;gap:7px;margin-top:11px;font-family:var(--f-mono);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--t2);border:1px solid var(--border-h);border-radius:7px;padding:3px 11px;white-space:nowrap}
.locked-cloud .cloud-seal .lk{filter:grayscale(1)}
/* roadmap: redacted feature bars + encrypted tag in place of the bullet list */
.rmp-bullets-locked{filter:blur(3px);opacity:.42;user-select:none;pointer-events:none}
.rmp-bullets-locked li{height:.6rem;border-radius:4px;background:linear-gradient(90deg,var(--t3),transparent)}
.rmp-bullets-locked li::before{display:none}
.rmp-bullets-locked li:nth-child(2){width:84%}.rmp-bullets-locked li:nth-child(3){width:66%}.rmp-bullets-locked li:nth-child(4){width:92%}
.rmp-tag-locked{color:var(--t3)}
/* decrypt easter egg — overlay injected on click, then removed */
.decrypt-fx{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:rgba(9,9,11,.88);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);font-family:var(--f-mono);text-align:center;padding:8px;animation:decFade .18s var(--ease)}
.decrypt-fx .dfx-line{font-size:.62rem;letter-spacing:.16em;color:#7CF6C8;text-transform:uppercase;word-break:break-all;line-height:1.35;max-width:96%}
.decrypt-fx .dfx-deny{color:#FF6B6B;letter-spacing:.22em}
.decrypt-fx .dfx-date{color:var(--t1);font-size:.58rem;letter-spacing:.2em}
.decrypt-fx .dfx-hint{color:#7CF6C8;font-size:.66rem;letter-spacing:.04em;text-transform:none;font-style:italic;opacity:.95}
.decrypt-fx.out{opacity:0;transition:opacity .34s}
@keyframes decFade{from{opacity:0}to{opacity:1}}
.shake{animation:shk .42s var(--ease)}
@keyframes shk{10%,90%{transform:translateX(-1px)}30%,70%{transform:translateX(2px)}50%{transform:translateX(-2px)}}
@media(prefers-reduced-motion:reduce){.shake{animation:none}.decrypt-fx{animation:none}}

/* ═══ BACKER PACKS (one-time, unlimited access) ═══ */
.packs{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:560px){.packs{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.packs{grid-template-columns:repeat(4,1fr)}}
.pack{display:flex;flex-direction:column;padding:24px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg-c);transition:transform var(--dur) var(--ease),border-color var(--dur)}
.pack:hover{transform:translateY(-3px);border-color:var(--border-h)}
.pack-pop{border-color:color-mix(in srgb,#6fe0d0 55%,transparent);box-shadow:var(--shadow)}
.pack-top{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:22px}
.pack-name{font-family:var(--f-mono);font-size:.8rem;font-weight:600;letter-spacing:.05em;color:var(--t2);text-transform:uppercase}
.pack-tag{font-family:var(--f-mono);font-size:.6rem;color:#0a1614;background:#6fe0d0;border-radius:5px;padding:2px 7px;letter-spacing:.04em;white-space:nowrap}
.pack-price{font-family:var(--f-mono);font-size:1.7rem;font-weight:700;color:var(--t1);margin:12px 0 2px}
.pack-sub{color:var(--t3);font-size:.74rem;margin-bottom:16px}
.pack-feat{list-style:none;margin:0 0 18px;padding:0;flex:1;display:flex;flex-direction:column;gap:8px}
.pack-feat li{color:var(--t2);font-size:.8rem;line-height:1.4;padding-left:19px;position:relative}
.pack-feat li::before{content:'\2713';position:absolute;left:0;color:#6fe0d0;font-weight:700}
.pack .btn{width:100%;margin-top:auto}
