/* ============================================================
   Agentist — homepage styles (v2)
   Brand derived from the pitch deck + agentist.dev:
   Inter / JetBrains Mono · white + toned surfaces · indigo→violet
   dark console windows as the only imagery · hairline structure
   ============================================================ */

:root{
  --bg:#ffffff;
  --surface:#f7f8fb;
  --surface-2:#eef1f6;
  --ink:#0b0e14;
  --muted:#52617a;
  --faint:#8593a8;
  --hairline:#e4e9f0;
  --indigo:#5b5bd6;
  --violet:#7c3aed;

  --code-bg:#0e141d;
  --code-head:#0a0f17;
  --code-border:#1e2735;
  --c-kw:#c792ea; --c-str:#f8a572; --c-fn:#82aaff; --c-com:#5b6a82;
  --c-ty:#6cd0c4; --c-txt:#c7d1e0; --c-pu:#8593a8;

  --ok:#2fae6a; --wait:#d9962b; --run:#5b5bd6; --fail:#d9534f;

  --maxw:1180px;
  --header-h:64px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; overflow-x:clip; }
body{ overflow-x:clip; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  line-height:1.6; -webkit-font-smoothing:antialiased;
}
a{ color:inherit; text-decoration:none; }
code{ font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace; }
h1,h2,h3{ text-wrap:balance; }
p{ text-wrap:pretty; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* ---------- shared atoms ---------- */
.kicker{
  font-family:'JetBrains Mono',monospace;
  font-size:13px; font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  color:var(--indigo);
}
.grad{
  background:linear-gradient(96deg,var(--indigo) 8%,var(--violet) 92%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 20px; border-radius:10px;
  font-weight:600; font-size:15px;
  border:1px solid var(--hairline); background:var(--bg); color:var(--ink);
  cursor:pointer; transition:border-color .15s, color .15s, filter .15s;
}
.btn:hover{ border-color:var(--indigo); color:var(--indigo); }
.btn.primary{ background:var(--indigo); border-color:var(--indigo); color:#fff; }
.btn.primary:hover{ filter:brightness(1.08); color:#fff; }
.pill{
  display:inline-flex; align-items:center; gap:9px;
  font-family:'JetBrains Mono',monospace; font-size:12.5px; font-weight:500;
  padding:6px 14px; border-radius:999px;
  border:1px solid var(--hairline); background:var(--surface); color:var(--muted);
  white-space:nowrap;
}
.pill .dot{ width:7px; height:7px; border-radius:50%; background:var(--indigo); }

/* ---------- header ---------- */
/* ── SHARED MASTHEAD SPEC — keep byte-identical with co.css ──────────────── */
header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid transparent; transition:border-color .2s;
}
header.scrolled{ border-bottom-color:var(--hairline); }
.header-inner{
  max-width:1200px; margin:0 auto; padding:0 28px;
  height:72px; display:flex; align-items:center; gap:32px;
}
.brand{ display:flex; align-items:center; }
.brand img{ height:22px; display:block; }
header nav{ display:flex; gap:30px; font-size:14px; font-weight:500; color:var(--muted); }
header nav a{ white-space:nowrap; transition:.15s; }
header nav a:hover{ color:var(--ink); }
.header-spacer{ flex:1; }
header .btn, header .btn-sm{ padding:9px 18px; font-size:14px; border-radius:8px; }
@media(max-width:860px){ header nav{ display:none; } }
/* ── end shared masthead ──────────────────────────────────────────────────── */
.header-install{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'JetBrains Mono',monospace; font-size:13px;
  background:var(--code-bg); color:#c7d1e0;
  border:1px solid var(--code-border); border-radius:9px; padding:8px 14px;
}
.header-install .dollar{ color:#6b7990; }
@media(max-width:1060px){ .header-install{ display:none; } }
@media(max-width:860px){ header nav{ display:none; } }

/* ---------- hero (stacked: statement, then the product, wide) ---------- */
.hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--hairline); }
.hero::before{
  content:""; position:absolute; inset:-30% 0 auto 0; height:560px; pointer-events:none;
  background:
    radial-gradient(700px 320px at 30% 0%, color-mix(in srgb,var(--indigo) 10%,transparent), transparent 70%),
    radial-gradient(560px 300px at 78% 4%, color-mix(in srgb,var(--violet) 8%,transparent), transparent 70%);
}
.hero-inner{
  position:relative; max-width:var(--maxw); margin:0 auto; padding:84px 28px 88px;
  text-align:center;
}
.hero h1{
  font-size:clamp(40px,4.4vw,62px); line-height:1.05; letter-spacing:-.026em;
  font-weight:800; margin:0 auto 22px; max-width:16em;
}
.hero .lead{
  font-size:18.5px; line-height:1.62; color:var(--muted); margin:0 auto 30px; max-width:620px; text-wrap:balance;
}
.hero .lead strong{ color:var(--ink); font-weight:600; }
.hero-cta{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; justify-content:center; margin-bottom:26px; }
.hero-pills{ display:flex; gap:9px; flex-wrap:wrap; justify-content:center; margin-bottom:56px; }
.hero-console{ max-width:1020px; margin:0 auto; text-align:left; }
[data-hero]{ display:none; }
[data-hero].on{ display:block; }
@media(max-width:760px){
  .hero-inner{ padding:56px 20px 60px; }
  .hero-pills{ margin-bottom:36px; }
}

/* ---------- section scaffolding ---------- */
section.band{ padding:104px 0; border-bottom:1px solid var(--hairline); }
section.band.tone{ background:var(--surface); }
.band-head{ margin-bottom:64px; }
.band-head .kicker{ display:block; margin-bottom:18px; }
.band-head h2{
  font-size:clamp(34px,3.6vw,50px); line-height:1.08; letter-spacing:-.022em;
  font-weight:800; margin:0; max-width:24ch;
}
.band-head .sub{ font-size:18px; color:var(--muted); margin:20px 0 0; max-width:760px; text-wrap:balance; }
@media(max-width:760px){ section.band{ padding:72px 0; } }

/* ---------- the argument ---------- */
.argument{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.argument .arg{
  padding:34px 30px 38px 0; border-top:1px solid var(--hairline);
}
.argument .arg + .arg{ padding-left:30px; border-left:1px solid var(--hairline); }
.arg .n{
  font-family:'JetBrains Mono',monospace; font-size:13px; color:var(--faint);
  letter-spacing:.12em; display:block; margin-bottom:18px;
}
.arg h3{ font-size:20px; font-weight:700; letter-spacing:-.012em; margin:0 0 10px; }
.arg p{ font-size:15.5px; color:var(--muted); margin:0; line-height:1.62; text-wrap:balance; }
.arg p strong{ color:var(--ink); font-weight:600; }
.argument-close{
  margin-top:72px; padding-top:44px; border-top:1px solid var(--hairline);
  font-size:clamp(26px,3vw,38px); font-weight:800; letter-spacing:-.02em; line-height:1.18;
}
@media(max-width:700px){ .argument-close br{ display:none; } }
@media(max-width:860px){
  .argument{ grid-template-columns:1fr; }
  .argument .arg + .arg{ padding-left:0; border-left:none; }
  .argument .arg{ padding-right:0; }
}

/* ---------- the loop (wedge) ---------- */
.cap{ display:grid; grid-template-columns:.85fr 1.15fr; gap:64px; align-items:center; padding:72px 0; }
.cap + .cap{ border-top:1px solid var(--hairline); }
.cap.flip .cap-copy{ order:2; }
.cap.flip .cap-vg{ order:1; }
.cap-copy .cap-k{
  display:flex; align-items:baseline; gap:14px; margin-bottom:20px;
}
.cap-copy .cap-k .num{
  font-family:'JetBrains Mono',monospace; font-size:14px; color:var(--faint); letter-spacing:.1em;
}
.cap-copy .cap-k .role{
  font-family:'JetBrains Mono',monospace; font-size:12.5px; color:var(--indigo);
  letter-spacing:.14em; text-transform:uppercase; white-space:nowrap;
}
.cap-copy h3{ font-size:clamp(26px,2.6vw,34px); font-weight:800; letter-spacing:-.02em; line-height:1.12; margin:0 0 16px; }
.cap-copy p{ font-size:16.5px; color:var(--muted); margin:0 0 14px; line-height:1.64; text-wrap:balance; }
.cap-copy p strong{ color:var(--ink); font-weight:600; }
.cap-copy .cap-note{
  font-family:'JetBrains Mono',monospace; font-size:13px; color:var(--faint); margin-top:22px; text-wrap:balance;
}
.cap-copy .cap-note b{ color:var(--muted); font-weight:500; }
@media(max-width:980px){
  .cap{ grid-template-columns:1fr; gap:36px; padding:56px 0; }
  .cap.flip .cap-copy{ order:1; }
  .cap.flip .cap-vg{ order:2; }
}

/* ---------- loop composition band ---------- */
.loop-band{
  margin-top:24px; border:1px solid var(--hairline); border-radius:18px;
  background:var(--surface); padding:48px 52px;
}
.loop-flow{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; justify-content:center; }
.loop-node{
  flex:1; min-width:150px; text-align:center;
  border:1px solid var(--hairline); border-radius:12px; background:var(--bg);
  padding:18px 16px;
}
.loop-node b{ display:block; font-size:17px; font-weight:700; letter-spacing:-.01em; }
.loop-node span{ font-size:12.5px; color:var(--muted); display:block; margin-top:3px; }
.loop-node.accent{ border-color:var(--indigo); box-shadow:inset 0 0 0 1px var(--indigo); }
.loop-node:focus-visible{ outline:2px solid var(--indigo); outline-offset:2px; }
.loop-arrow{ color:var(--faint); font-size:19px; flex:none; }
.loop-return{
  text-align:center; margin-top:18px;
  font-family:'JetBrains Mono',monospace; font-size:13px; color:var(--faint);
}
.loop-return b{ color:var(--indigo); font-weight:500; }
.loop-cap{
  text-align:center; max-width:760px; margin:30px auto 0;
  font-size:17px; color:var(--muted); line-height:1.64; text-wrap:balance;
}
.loop-cap strong{ color:var(--ink); font-weight:600; }
@media(max-width:760px){ .loop-band{ padding:32px 24px; } }

/* ---------- harness grid ---------- */
.harness-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--hairline); }
.hx{
  padding:28px 28px 30px 0; border-bottom:1px solid var(--hairline);
  display:block; position:relative; transition:color .15s;
}
.hx:nth-child(4n+2), .hx:nth-child(4n+3), .hx:nth-child(4n){ padding-left:28px; border-left:1px solid var(--hairline); }
.hx b{ display:flex; align-items:center; gap:8px; font-size:15.5px; font-weight:700; letter-spacing:-.005em; margin-bottom:6px; }
.hx b::after{ content:"→"; font-size:13px; color:var(--faint); opacity:0; transform:translateX(-4px); transition:.15s; }
.hx:hover b{ color:var(--indigo); }
.hx:hover b::after{ opacity:1; transform:none; }
.hx span{ font-size:13.5px; color:var(--muted); line-height:1.55; display:block; }
.harness-foot{
  margin-top:44px; display:flex; align-items:baseline; gap:18px; flex-wrap:wrap;
  font-size:15.5px; color:var(--muted);
}
.harness-foot a{ color:var(--indigo); font-weight:600; }
.harness-foot a:hover{ text-decoration:underline; }
@media(max-width:1000px){
  .harness-grid{ grid-template-columns:repeat(2,1fr); }
  .hx{ padding-left:0 !important; border-left:none !important; }
  .hx:nth-child(2n){ padding-left:28px !important; border-left:1px solid var(--hairline) !important; }
}
@media(max-width:600px){
  .harness-grid{ grid-template-columns:1fr; }
  .hx:nth-child(2n){ padding-left:0 !important; border-left:none !important; }
}

/* ---------- build it (two paths) ---------- */
.paths{ display:grid; grid-template-columns:1.12fr .88fr; gap:28px; align-items:stretch; }
.path{
  border:1px solid var(--hairline); border-radius:18px; background:var(--bg);
  padding:38px 40px; display:flex; flex-direction:column;
}
.path .path-k{
  font-family:'JetBrains Mono',monospace; font-size:12.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--indigo); margin-bottom:16px;
}
.path h3{ font-size:24px; font-weight:800; letter-spacing:-.016em; margin:0 0 12px; }
.path p{ font-size:15.5px; color:var(--muted); margin:0 0 14px; line-height:1.62; }
.path p strong{ color:var(--ink); font-weight:600; }
.path .path-cta{ margin-top:auto; padding-top:18px; display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.path .fine{ font-size:13px; color:var(--faint); }
@media(max-width:920px){ .paths{ grid-template-columns:1fr; } }

/* ---------- code card (deck motif) ---------- */
.code-card{
  background:var(--code-bg); border:1px solid var(--code-border); border-radius:14px;
  overflow:hidden; box-shadow:0 24px 50px -28px rgba(11,14,20,.4);
  margin:20px 0 6px;
}
.code-card .code-head{
  background:var(--code-head); border-bottom:1px solid var(--code-border);
  padding:11px 16px; display:flex; align-items:center; justify-content:space-between;
  font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:.12em; color:#6b7990;
}
.copy-glyph{ width:16px; height:16px; border:1.5px solid #3a475a; border-radius:4px; position:relative; }
.copy-glyph::after{
  content:''; position:absolute; width:10px; height:10px; border:1.5px solid #3a475a;
  border-radius:3px; top:-4px; left:-4px; background:var(--code-head);
}
.code-card pre{
  margin:0; padding:18px 20px;
  font-family:'JetBrains Mono',monospace; font-size:13px; line-height:1.66;
  color:var(--c-txt); overflow-x:auto;
}
.kw{ color:var(--c-kw); } .str{ color:var(--c-str); } .fn{ color:var(--c-fn); }
.com{ color:var(--c-com); } .ty{ color:var(--c-ty); } .pu{ color:var(--c-pu); }

.install-line{
  display:inline-flex; align-items:center; gap:12px;
  font-family:'JetBrains Mono',monospace; font-size:13.5px;
  background:var(--code-bg); color:#c7d1e0; border:1px solid var(--code-border);
  border-radius:10px; padding:11px 16px;
}
.install-line .dollar{ color:#6b7990; }
.install-line .soon{ font-size:11px; color:#6b7990; letter-spacing:.08em; }

/* ============================================================
   Console windows — designed as real product UI:
   Inter for chrome & copy, mono only for commands, code & data.
   ============================================================ */
.vg{
  background:var(--code-bg); border:1px solid var(--code-border); border-radius:14px;
  overflow:hidden; box-shadow:0 30px 70px -32px rgba(11,14,20,.5);
  color:#c4cdda; font-family:'Inter',system-ui,sans-serif; font-size:13px;
  line-height:1.55; text-align:left;
}
.vg .mono{ font-family:'JetBrains Mono',ui-monospace,monospace; }
.vg code{ font-family:'JetBrains Mono',ui-monospace,monospace; }

/* window chrome */
.vg-bar{
  display:flex; align-items:center; gap:7px; padding:11px 16px;
  background:var(--code-head); border-bottom:1px solid var(--code-border);
}
.vg-bar i{ width:11px; height:11px; border-radius:50%; background:#2a3543; display:block; }
.vg-bar .t{
  font-family:'JetBrains Mono',monospace; color:#6f7d92; font-size:12px; margin-left:12px; white-space:nowrap;
}
.vg-bar .r{
  margin-left:auto; font-family:'JetBrains Mono',monospace; font-size:11.5px; color:#6f7d92;
  display:inline-flex; align-items:center; gap:7px;
}
.vg-bar .r .live{ width:7px; height:7px; border-radius:50%; background:var(--ok); }

/* app layout: sidebar + main */
.vg-grid{ display:grid; grid-template-columns:198px 1fr; }
.vg-nav{
  border-right:1px solid var(--code-border); background:#0b1018;
  padding:14px 10px 16px; display:flex; flex-direction:column; gap:2px;
}
.vg-nav .nav-sec{
  margin:12px 12px 6px; font-size:10.5px; letter-spacing:.09em; text-transform:uppercase;
  color:#54617a; font-weight:600;
}
.vg-nav .nav-sec:first-child{ margin-top:2px; }
.vg-nav a{
  display:flex; align-items:center; gap:10px; padding:7px 12px; border-radius:8px;
  color:#8b97a9; font-size:13.5px; font-weight:500; cursor:default; white-space:nowrap;
}
.vg-nav a[data-tab]{ cursor:pointer; }
.vg-nav a[data-tab]:hover{ color:#dbe3ee; background:#121925; }
.vg-nav a.on, .vg-nav a[data-tab].on:hover{ color:#fff; background:#161e2b; }
.vg-view{ display:none; }
.vg-view.on{ display:block; }
.vg-nav a .bdg{
  margin-left:auto; font-size:11px; font-weight:600;
  background:rgba(124,140,255,.16); color:#9fb0ff; border-radius:10px; padding:1px 8px;
}
.vg-nav a .live{ margin-left:auto; width:7px; height:7px; border-radius:50%; background:var(--ok); }
.vg-nav .nav-foot{
  margin-top:auto; padding:12px 12px 0; border-top:1px solid #141c29;
  font-family:'JetBrains Mono',monospace; font-size:10.5px; color:#54617a; line-height:1.7;
}
.vg-nav .nav-foot b{ color:#5fcf9a; font-weight:500; }
@media(max-width:700px){
  .vg-grid{ grid-template-columns:1fr; }
  .vg-nav{ flex-direction:row; overflow-x:auto; border-right:none; border-bottom:1px solid var(--code-border); padding:8px 10px; }
  .vg-nav .nav-sec, .vg-nav .nav-foot{ display:none; }
}

/* main pane */
.vg-main{ padding:20px 24px 22px; position:relative; min-width:0; }
.vg-pagehead{
  display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; margin-bottom:16px;
}
.vg-pagehead h4{
  margin:0; font-size:15.5px; font-weight:600; color:#eef2f8; letter-spacing:-.01em;
}
.vg-pagehead .sub{ font-size:12.5px; color:#6f7d92; }
.vg-pagehead .right{
  margin-left:auto; font-family:'JetBrains Mono',monospace; font-size:11px; color:#6f7d92; white-space:nowrap;
}

/* the suspended-run alert — the problem, stated by the UI */
.vg-suspend{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  background:rgba(217,154,43,.08); border:1px solid rgba(217,154,43,.32); border-radius:10px;
  padding:11px 15px; font-size:13px; color:#bfa066; margin-bottom:14px;
}
.vg-suspend .txt{ flex:1 1 auto; min-width:260px; }
.vg-suspend b{ color:#f0d49a; font-weight:600; }
.vg-suspend .tm{
  margin-left:auto; font-family:'JetBrains Mono',monospace; font-size:11px; color:#8a7a52; white-space:nowrap;
}

/* approval card */
.vg-card{
  background:#111927; border:1px solid #1f2a3a; border-radius:11px;
  padding:16px 18px; margin:0 0 12px;
}
.appr-id{ display:flex; align-items:center; gap:12px; margin-bottom:13px; }
.appr-id .ap-av{
  width:34px; height:34px; border-radius:50%; flex:none;
  background:linear-gradient(135deg,var(--indigo),var(--violet));
  color:#fff; display:grid; place-items:center; font-weight:700; font-size:14px;
}
.appr-id .who-l{ min-width:0; }
.appr-id .who-l b{ display:block; color:#eef2f8; font-size:13.5px; font-weight:600; line-height:1.35; }
.appr-id .who-l span{ display:block; color:#6f7d92; font-size:12px; line-height:1.4; }
.appr-id > .tag{ margin-left:auto; flex:none; }
.appr-id .when{ flex:none; font-family:'JetBrains Mono',monospace; font-size:11px; color:#54617a; }

.ap-lbl{
  font-size:10.5px; letter-spacing:.09em; text-transform:uppercase;
  color:#54617a; font-weight:600; margin:14px 0 6px;
}
.ap-cmd code{
  display:block; background:#0a0f17; border:1px solid #1c2531; border-radius:7px;
  padding:9px 13px; color:#f0d49a; font-size:12.5px; overflow-x:auto; white-space:nowrap;
}
.ap-why{ font-size:13px; color:#93a1b4; line-height:1.55; margin:10px 0 0; }
.ap-diff{
  font-family:'JetBrains Mono',monospace; font-size:11.5px;
  background:#0a0f17; border:1px solid #1c2531; border-radius:7px;
  padding:9px 13px; margin:12px 0 0; display:flex; flex-direction:column; gap:3px;
}
.d-minus{ color:#f08379; } .d-plus{ color:#5fcf9a; }
.ap-acts{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; margin-top:15px; }
.ap-alt{ color:#5f6c80; font-size:11.5px; margin-left:4px; }
.ap-meta{
  margin-top:13px; padding-top:11px; border-top:1px solid #1a2433;
  font-family:'JetBrains Mono',monospace; font-size:11px; color:#5f6c80;
}
.ap-meta code{ color:#8b97a9; background:none; border:none; padding:0; font-size:11px; }
.ap-resolved{ color:#5fcf9a; font-weight:600; font-size:13px; }

/* buttons */
.vg-btn{
  border:1px solid #2a3543; border-radius:8px; padding:7px 16px; color:#9aa6b8;
  font-size:12.5px; font-weight:600; cursor:pointer; background:#141c29;
  font-family:'Inter',sans-serif; transition:.15s;
}
.vg-btn:hover{ border-color:#3a4a61; color:#dbe3ee; }
.vg-btn.y{ background:var(--indigo); border-color:var(--indigo); color:#fff; }
.vg-btn.y:hover{ filter:brightness(1.1); }
.vg-btn:disabled{ cursor:default; }

/* status tags */
.tag{ font-size:10.5px; padding:2px 9px; border-radius:10px; font-weight:600; white-space:nowrap; }
.tag.ok{ background:rgba(58,166,117,.16); color:#5fcf9a; }
.tag.run{ background:rgba(124,140,255,.18); color:#9fb0ff; }
.tag.wait{ background:rgba(217,154,43,.16); color:#e0b35e; }
.tag.no{ background:rgba(229,83,75,.14); color:#f08379; }

/* list rows (queue items) */
.inbox-row{
  display:flex; align-items:center; gap:12px; padding:11px 14px;
  border:1px solid #1a2433; border-radius:10px; background:#0f1622; font-size:12.5px;
}
.inbox-row .av2{
  width:26px; height:26px; border-radius:50%; flex:none;
  background:#1c2738; color:#9fb0ff; display:grid; place-items:center;
  font-weight:700; font-size:11px;
}
.inbox-row .who{ color:#dbe3ee; font-weight:600; flex:none; }
.inbox-row .act{ color:#8b97a9; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.inbox-row .m{ margin-left:auto; color:#54617a; flex:none; font-family:'JetBrains Mono',monospace; font-size:11px; }

/* journal table */
.tbl-scroll{ overflow-x:auto; }
.vg-tbl{ width:100%; border-collapse:collapse; font-size:12.5px; }
.vg-tbl th{
  text-align:left; color:#54617a; font-weight:600; padding:7px 10px;
  border-bottom:1px solid var(--code-border); text-transform:uppercase; font-size:10.5px; letter-spacing:.07em;
}
.vg-tbl td{ padding:9px 10px; border-bottom:1px solid #131a24; color:#aeb9c9; white-space:nowrap; }
.vg-tbl td.mono{ font-family:'JetBrains Mono',monospace; font-size:11.5px; color:#7d8aa0; }
.vg-tbl td b{ color:#dbe3ee; font-weight:600; }
.vg-tbl tr.flash td{ animation:rowflash 1.6s ease-out; }
@keyframes rowflash{ 0%{ background:rgba(124,140,255,.22); } 100%{ background:transparent; } }
.vg-foot{
  margin-top:12px; font-size:12px; color:#6f7d92;
  display:flex; align-items:baseline; gap:8px;
}
.vg-foot b{ color:#5fcf9a; font-weight:600; }
.vg-foot .m{ margin-left:auto; font-family:'JetBrains Mono',monospace; font-size:11px; color:#54617a; }

/* coach compare */
.coach-cmp{ display:grid; grid-template-columns:1fr 1fr; gap:11px; margin:0 0 4px; }
.coach-cell{ background:#0f1622; border:1px solid #1a2433; border-radius:10px; padding:13px 15px; }
.coach-cell .lbl{
  color:#54617a; font-size:10.5px; text-transform:uppercase; letter-spacing:.08em;
  font-weight:600; margin-bottom:8px;
}
.coach-cell .sev{ font-weight:700; color:#eef2f8; font-size:13.5px; }
.coach-cell p{ margin:6px 0 0; font-size:12.5px; color:#8b97a9; line-height:1.55; }
.coach-cell.fix{ border-color:rgba(124,140,255,.38); background:#111a2c; }
.coach-cell.fix .sev{ color:#9fb0ff; }
.vg-acts{ margin-top:14px; display:flex; gap:9px; flex-wrap:wrap; align-items:center; }
.vg-status{ font-size:12.5px; color:#5fcf9a; margin-top:12px; display:none; }
.vg-status.on{ display:block; }
.vg-note{ color:#6f7d92; font-size:12px; margin-top:12px; }

.vg-toast{
  position:absolute; bottom:14px; right:16px; background:#0e1620; border:1px solid #2d3a4d;
  border-radius:8px; padding:8px 13px; font-size:12px; color:#c4cdda;
  opacity:0; transform:translateY(6px); transition:.25s; pointer-events:none; z-index:5;
}
.vg-toast.show{ opacity:1; transform:none; }

/* ---------- closing band ---------- */
.close-band{ padding:120px 0; text-align:center; }
.close-band .kicker{ display:block; margin-bottom:18px; }
.close-band h2{
  font-size:clamp(34px,3.8vw,52px); font-weight:800; letter-spacing:-.024em; line-height:1.06; margin:0 0 18px;
}
.close-band p{ font-size:18px; color:var(--muted); max-width:560px; margin:0 auto 34px; text-wrap:balance; }
.close-cta{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

footer{ border-top:1px solid var(--hairline); padding:60px 0 44px; background:var(--surface); }
footer .foot-grid{ max-width:var(--maxw); margin:0 auto; padding:0 28px; display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:40px; }
.foot-brand img{ height:20px; display:block; margin-bottom:14px; }
.foot-brand p{ font-size:14px; color:var(--muted); margin:0 0 14px; max-width:42ch; line-height:1.6; }
.foot-brand .dom{ font-size:12.5px; color:var(--faint); font-family:'JetBrains Mono',monospace; }
.foot-col h4{ font-size:11.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--faint); font-weight:700; margin:0 0 14px; }
.foot-col a{ display:block; font-size:14px; color:var(--muted); margin-bottom:9px; }
.foot-col a:hover{ color:var(--indigo); }
@media(max-width:760px){ footer .foot-grid{ grid-template-columns:1fr 1fr; gap:28px 24px; } .foot-brand{ grid-column:1 / -1; } }

/* ---------- reveal animation (gated: html.rv-live is added by JS inside a rAF,
   so content is visible by default unless rendering is actually live) ---------- */
@media (prefers-reduced-motion: no-preference){
  html.rv-live .rv{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1); }
  html.rv-live .rv.in{ opacity:1; transform:none; }
  html.rv-live .rv.d1{ transition-delay:.1s; } html.rv-live .rv.d2{ transition-delay:.2s; } html.rv-live .rv.d3{ transition-delay:.3s; }
  html.rv-live .rv-big{ transform:translateY(40px) scale(.98); transition-duration:.95s; }
  html.rv-live .rv-big.in{ transform:none; }
}
