/* =========================================================
   GRIND MACHINE — site shared tokens + components
   Linear/Vercel aesthetic, dark monochrome + accent
   Mirrors the landing page exactly.
   ========================================================= */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{
  --bg:#0a0a0a;
  --bg-2:#0e0e0e;
  --panel:#121212;
  --panel-2:#181818;
  --line:#1f1f1f;
  --line-2:#2a2a2a;
  --fg:#ededed;
  --fg-dim:#8a8a8a;
  --fg-faint:#4a4a4a;
  --fg-ghost:#2f2f2f;
  --accent:#b4ff39;          /* default lime — landing accent */
  --accent-fg:#0a0a0a;
  --up:#3dffa2;
  --down:#ff4d6d;
  --warn:#ffd43b;
  --blue:#4d9fff;
  --violet:#b48cff;
  --radius:4px;
  --radius-lg:8px;
  --font:"Geist",ui-sans-serif,system-ui,sans-serif;
  --font-mono:"Geist Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
  --nav-h:56px;
  --wrap:1320px;
  --pad:clamp(20px,4vw,48px);
  color-scheme:dark;
}
/* per-page accent (set on <html data-page-accent="…">). Each rule
 * overrides BOTH --page-accent (used by section heads, sec-kicker,
 * pipeline dots, etc.) AND --accent (used by .btn-primary and the
 * shared lime hero glow) so the page's primary color is cohesive
 * across every UI element. Without the --accent override buttons
 * would stay lime even when the section accents flipped. */
html[data-page-accent="amber"]   { --page-accent:var(--warn);   --page-accent-soft:rgba(255,212,59,.10);  --accent:var(--warn) }
html[data-page-accent="indigo"]  { --page-accent:var(--violet); --page-accent-soft:rgba(180,140,255,.10); --accent:var(--violet) }
html[data-page-accent="red"]     { --page-accent:var(--down);   --page-accent-soft:rgba(255,77,109,.10);  --accent:var(--down) }
html[data-page-accent="blue"]    { --page-accent:var(--blue);   --page-accent-soft:rgba(77,159,255,.10);  --accent:var(--blue) }
html[data-page-accent="emerald"] { --page-accent:var(--up);     --page-accent-soft:rgba(61,255,162,.10);  --accent:var(--up) }
html[data-page-accent="green"]   { --page-accent:var(--accent); --page-accent-soft:rgba(180,255,57,.10) }
html                              { --page-accent:var(--accent);--page-accent-soft:rgba(180,255,57,.08) }

body{
  background:var(--bg);color:var(--fg);
  font-family:var(--font);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  letter-spacing:-.01em;
  font-feature-settings:"ss01","cv11";
}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}
:focus-visible{outline:1px solid var(--accent);outline-offset:2px;border-radius:2px}

h1,h2,h3,h4,h5,h6{margin:0;font-weight:500;letter-spacing:-.025em}
.mono{font-family:var(--font-mono);letter-spacing:-.01em}
.dim{color:var(--fg-dim)}
.faint{color:var(--fg-faint)}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--pad)}
.row{display:flex;align-items:center;gap:12px}
section{padding:clamp(64px,8vw,120px) 0;position:relative}
hr.hair{height:1px;background:var(--line);border:0;margin:0}

.dot-bg{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle, var(--line-2) 1px, transparent 1px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 20%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 20%, transparent 80%);
  opacity:.5;
}

/* page-accent radial glow — drops in behind page hero */
.glow{
  position:absolute;left:50%;top:-260px;transform:translateX(-50%);
  width:1100px;height:760px;border-radius:50%;pointer-events:none;
  background:radial-gradient(closest-side, var(--page-accent-soft), transparent 70%);
  opacity:.9;z-index:0;
}

/* =========================================================
   nav
   ========================================================= */
nav.topbar{
  position:sticky;top:0;z-index:60;height:var(--nav-h);
  background:color-mix(in srgb,var(--bg) 75%,transparent);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-row{height:100%;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.015em}
.brand-img{height:26px;width:auto;display:block}
.auth-logo-img{height:26px;width:auto;display:block}
@media (max-width:560px){.brand-img{height:22px}.auth-logo-img{height:22px}}
.brand-mark{
  width:24px;height:24px;border-radius:5px;position:relative;overflow:hidden;
  background:conic-gradient(from 220deg at 50% 50%, var(--accent), #7ac41f 40%, var(--accent) 80%);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.3), 0 0 0 1px #1a1a1a;
}
.brand-mark::after{
  content:"";position:absolute;inset:3px;border-radius:3px;background:#0a0a0a;
  clip-path:polygon(30% 0,100% 0,100% 70%,70% 100%,0 100%,0 30%);
}
.brand-mark::before{
  content:"";position:absolute;left:50%;top:50%;width:8px;height:8px;
  transform:translate(-50%,-50%);background:var(--accent);z-index:2;border-radius:1px;
}
.nav-links{display:flex;gap:4px;font-size:13px;color:var(--fg-dim)}
.nav-links a{padding:6px 10px;border-radius:6px;transition:color .15s,background .15s}
.nav-links a:hover,.nav-links a.on{color:var(--fg);background:var(--panel)}
.nav-right{display:flex;align-items:center;gap:8px}
@media (max-width:820px){.nav-links{display:none}}

.lang{
  display:inline-flex;background:var(--panel);border:1px solid var(--line);
  border-radius:6px;padding:2px;font-family:var(--font-mono);font-size:11px;
}
.lang button{padding:4px 8px;border-radius:4px;color:var(--fg-dim);letter-spacing:.04em}
.lang button.on{background:var(--line-2);color:var(--fg)}

.btn{
  display:inline-flex;align-items:center;gap:6px;
  height:32px;padding:0 12px;border-radius:6px;
  font-size:13px;font-weight:500;
  border:1px solid transparent;
  transition:background .15s,border-color .15s,color .15s,transform .1s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-ghost{color:var(--fg-dim)}
.btn-ghost:hover{color:var(--fg);background:var(--panel)}
.btn-secondary{background:var(--panel);color:var(--fg);border-color:var(--line-2)}
.btn-secondary:hover{background:var(--panel-2);border-color:var(--fg-faint)}
.btn-primary{background:var(--accent);color:var(--accent-fg);font-weight:600}
.btn-primary:hover{filter:brightness(1.08)}
.btn-lg{height:40px;padding:0 16px;font-size:14px;border-radius:7px}
.btn .arrow{transition:transform .15s}
.btn:hover .arrow{transform:translateX(2px)}

/* =========================================================
   page hero
   ========================================================= */
.page-hero{padding:clamp(72px,10vw,128px) 0 clamp(40px,5vw,72px);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero .dot-bg{opacity:.35}
.ph-inner{position:relative;z-index:1;max-width:880px}
.ph-inner.center{margin-inline:auto;text-align:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 12px 4px 10px;border:1px solid var(--line-2);
  border-radius:100px;background:var(--panel);
  font-family:var(--font-mono);font-size:11px;color:var(--fg-dim);
  letter-spacing:.04em;text-transform:uppercase;margin-bottom:24px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--page-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--page-accent) 22%,transparent)}
.page-hero h1{
  font-size:clamp(40px,6.4vw,84px);line-height:1.0;letter-spacing:-.04em;
  font-weight:500;max-width:18ch;text-wrap:balance;
}
.ph-inner.center h1{margin-inline:auto}
.page-hero h1 .k{color:var(--page-accent)}
.page-hero h1 .slash{color:var(--fg-faint);font-weight:300}
.page-hero p.lede{
  font-size:clamp(15px,1.2vw,18px);color:var(--fg-dim);
  max-width:64ch;line-height:1.5;margin:24px 0 0;
}
.ph-inner.center p.lede{margin-inline:auto}
.page-hero .hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:32px}
.ph-inner.center .hero-cta{justify-content:center}

/* =========================================================
   section heads (1:1 with landing)
   ========================================================= */
.sec-head{
  display:grid;
  grid-template-columns:auto 1fr;
  /* Two rows: kicker on top-left, then h2 (left) + sub (right) on the
   * second row. align-items:start makes both columns share the same
   * top edge of the title row — works for short h2 + long sub
   * (Customizable Filters) AND long h2 + short sub uniformly. */
  grid-template-areas:
    "kicker spacer"
    "title  sub";
  align-items:start;
  column-gap:48px;row-gap:14px;
  padding-bottom:48px;border-bottom:1px solid var(--line);
}
@media (max-width:820px){
  .sec-head{
    grid-template-columns:1fr;
    grid-template-areas:"kicker" "title" "sub";
    column-gap:0;row-gap:14px;
  }
  /* On mobile, indent the sec-head text in the three sections whose
   * cards have visible horizontal padding, so the kicker/h2/sub start
   * at the same X as card content (not flush with the .wrap padding). */
  #platform  .sec-head{padding-left:32px;padding-right:32px}
  #detectors .sec-head{padding-left:28px;padding-right:28px}
  #scripts   .sec-head{padding-left:26px;padding-right:26px}
}
.sec-kicker{
  grid-area:kicker;align-self:start;
  font-family:var(--font-mono);font-size:11px;color:var(--fg-dim);
  letter-spacing:.06em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.sec-kicker::before{content:"";width:20px;height:1px;background:var(--page-accent)}
.sec-head h2{
  grid-area:title;
  font-size:clamp(32px,4.5vw,56px);line-height:1.02;letter-spacing:-.035em;
  font-weight:500;max-width:22ch;margin:0;
}
.sec-head h2 .k{color:var(--page-accent)}
.sec-head .sec-sub{grid-area:sub;color:var(--fg-dim);max-width:54ch;line-height:1.5;font-size:15px;justify-self:start;margin:0}
/* Stacked variant: kicker / title / sub on three rows of one column,
 * so the subtitle reads as a paragraph belonging to the list/cards
 * below rather than sharing a row with the heading. */
.sec-head--stacked{
  grid-template-columns:1fr;
  grid-template-areas:"kicker" "title" "sub";
  column-gap:0;row-gap:14px;
}
.sec-head--stacked .sec-sub{justify-self:start;max-width:64ch;margin-top:8px}

/* Split variant: same 1fr 1fr column geometry as the .split below it,
 * so the subtitle in the right cell of the sec-head sits directly
 * above the right column of the split (where the list lives). */
.sec-head--split{
  grid-template-columns:1fr 1fr;
  column-gap:64px;
  grid-template-areas:
    "kicker spacer"
    "title  sub";
}

/* Trading-bot Strategies: align sub-title with the second card column
 * (Pump/Dump) so it reads as a paragraph above that card's text. The
 * 28px padding-left mirrors the .feat horizontal padding. */
[data-block="strategies"] .sec-head{grid-template-columns:1fr 1fr;column-gap:0}
[data-block="strategies"] .sec-head .sec-sub{padding-left:28px}
/* Stretch split columns to equal height so .bot-mock fills the same
 * vertical extent as the check-list on the left. Default .split has
 * align-items:start which would leave the mock auto-sized. */
[data-block="customization"] .split{align-items:stretch}
[data-block="customization"] .bot-mock{height:100%}
/* Analytics Metrics: align sub-title with the right column of the
 * .cols-2-list below so it reads as a paragraph above "Filter by
 * Strategy" (first li in #metrics-right). column-gap:48px mirrors
 * the .cols-2-list gap exactly, and padding-left:26px = 14px
 * ::before bullet + 12px flex gap on .check-list li, so the sub
 * starts at the same X as the li text (not the pulse dot). */
[data-block="metrics"] .sec-head{grid-template-columns:1fr 1fr;column-gap:48px}
[data-block="metrics"] .sec-head .sec-sub{padding-left:26px}

/* Analytics Telegram Sync: stretch the left column to the height of
 * the bullet list on the right, drop the kicker+h2 down a touch with
 * a padding-top so h2 sits next to the first <li>, then push the
 * sub-title to the bottom with margin-top:auto so its last line
 * sits next to the last <li>. The selector chain matches the
 * specificity of `.tg-grid-v2 .tg-left h2 { margin:8px 0 0 }` so the
 * margin override actually wins. */
[data-block="telegram-sync"] .tg-grid-v2{align-items:stretch}
[data-block="telegram-sync"] .tg-grid-v2 .tg-left{padding-top:28px;padding-bottom:6px}
[data-block="telegram-sync"] .tg-grid-v2 .tg-left .sec-sub{
  margin-top:auto;margin-bottom:78px;max-width:52ch;
}
@media (max-width:820px){
  /* On mobile, collapse the per-block split sec-head layouts (1fr 1fr
   * with explicit grid-template-areas) back to a single 1fr stack.
   * Without this the kicker / h2 / sub cells stay locked in their
   * desktop columns and read as left-shifted on narrow screens. The
   * .sec-head--split modifier has the same specificity as the base
   * .sec-head { grid-template-columns:1fr } mobile rule but is later
   * in the file, so the base rule alone doesn't win — we need the
   * explicit override here too. */
  [data-block="strategies"] .sec-head,
  [data-block="metrics"] .sec-head,
  .sec-head--split{
    grid-template-columns:1fr;
    grid-template-areas:"kicker" "title" "sub";
    column-gap:0;
  }
  [data-block="strategies"] .sec-head .sec-sub,
  [data-block="metrics"] .sec-head .sec-sub{padding-left:0}

  /* When .cols-2-list collapses to a single column, the last <li>
   * of the FIRST <ul> sits directly above the first <li> of the
   * SECOND <ul> — but the default .check-list li:last-child rule
   * strips its border-bottom, so visually the two items merge with
   * no separator. Re-add the border for that mid-list boundary; only
   * the very last <li> of the very last <ul> stays borderless. */
  .cols-2-list .check-list li:last-child{
    border-bottom:1px solid var(--line);
  }
  .cols-2-list .check-list:last-child li:last-child{
    border-bottom:0;
  }
}

/* Trading-bot hero two-card live demo: live SPREAD signal on the left,
 * trade lifecycle state machine on the right. Uses the existing
 * .hero-card-real styling for both cells. */
.bot-demo{
  margin-top:48px;
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  font-family:var(--font-mono);min-width:0;
}
.bot-demo > div{min-width:0;display:flex}
.bot-demo > div > .hero-card-real{flex:1 1 auto;width:100%}
@media (max-width:1000px){.bot-demo{grid-template-columns:1fr}}

/* Trade card sections (mirrors monitor TradeCard structure).
 * Layout: head, KV row, orders block, TPs block — separated by
 * comfortable margins. PnL chip sits in the bottom-right corner,
 * not stretched across the card. */
.hcr-trade{gap:0 !important}
.hcr-trade .hcr-row{
  display:flex;flex-wrap:wrap;gap:6px 16px;
  font-size:11px;
  margin-top:14px;
}
.hcr-tr-sec{display:flex;flex-direction:column;gap:6px;margin-top:18px}
.hcr-tr-sec + .hcr-tr-sec{margin-top:14px}
.hcr-tr-lbl{
  display:flex;align-items:center;gap:6px;
  font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--fg-dim);
}
.hcr-tr-lbl.cancel{color:var(--fg-faint)}
.hcr-tr-lbl svg{flex-shrink:0}
.hcr-tr-list{display:flex;flex-direction:column;gap:3px}
.hcr-order-row{
  display:grid;
  grid-template-columns:auto 1fr 1fr auto;
  gap:10px;align-items:baseline;
  font-size:11px;color:var(--fg-dim);
  padding:4px 0;
}
.hcr-order-row .num{
  color:var(--fg-faint);font-family:var(--font-mono);font-size:10.5px;
  min-width:24px;
}
.hcr-order-row .lbl{color:var(--fg-faint);font-size:10px;letter-spacing:.04em}
.hcr-order-row .v{color:var(--fg);font-variant-numeric:tabular-nums}
.hcr-order-row .st-ok{color:var(--up)}
.hcr-order-row .st-cancel{color:var(--down)}
.hcr-tr-pnl{
  display:inline-flex;align-items:center;gap:10px;
  align-self:flex-end;
  padding:0;
  background:transparent;border:0;
  font-family:var(--font-mono);
  margin-top:24px;  /* fixed gap below the last TP row */
}
.hcr-tr-pnl .dk{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint)}
.hcr-tr-pnl .dv{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}
.hcr-tr-pnl .dv.up{color:var(--up)}
.hcr-tr-pnl .dv.down{color:var(--down)}
.hcr-tr-pnl .dv.fg{color:var(--fg)}

/* Spread card on /trading-bot — fixed margins between sections,
 * no auto-stretch (cards are sized by content now). */
#bot-spread .hero-card-real{gap:0 !important}
#bot-spread .hcr-meta{margin-top:14px}
#bot-spread .hcr-kvs{margin-top:14px}
#bot-spread .hcr-table{margin-top:18px}
#bot-spread .hcr-coin{margin-top:24px;padding-top:18px}

/* Trading-bot Customization split right column: subtitle above the
 * check-list, both stacked vertically. */
.exec-right{display:flex;flex-direction:column;gap:20px}
.exec-sub{
  color:var(--fg-dim);font-size:15px;line-height:1.5;margin:0;
  max-width:54ch;
  padding-bottom:20px;border-bottom:1px solid var(--line);
}

/* =========================================================
   feature grid (cards) — split-divider style of landing
   ========================================================= */
.feat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-block:1px solid var(--line);
}
.feat-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.feat-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.feat-grid.cols-5{grid-template-columns:repeat(5,1fr)}
.feat{
  padding:32px 28px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;min-height:240px;
  transition:background .2s;position:relative;
}
.feat:hover{background:var(--panel)}
.feat:last-child{border-right:0}
@media (max-width:900px){
  .feat-grid,.feat-grid.cols-2,.feat-grid.cols-4,.feat-grid.cols-5{grid-template-columns:1fr}
  .feat{border-right:0;border-bottom:1px solid var(--line)}
  .feat:last-child{border-bottom:0}
}
@media (min-width:901px){
  .feat-grid.cols-3 .feat:nth-child(3n){border-right:0}
  .feat-grid.cols-2 .feat:nth-child(2n){border-right:0}
  .feat-grid.cols-4 .feat:nth-child(4n){border-right:0}
  .feat-grid.cols-5 .feat:nth-child(5n){border-right:0}
  /* row borders for rows beyond 1 */
  .feat-grid.cols-3 .feat:nth-child(n+4),
  .feat-grid.cols-2 .feat:nth-child(n+3),
  .feat-grid.cols-4 .feat:nth-child(n+5){border-top:1px solid var(--line)}
  .feat-grid.cols-5 .feat:nth-child(n+6){border-top:1px solid var(--line)}
}
.feat .num{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
.feat .ico{
  width:36px;height:36px;border-radius:8px;
  display:grid;place-items:center;
  background:color-mix(in srgb,var(--page-accent) 12%,transparent);
  color:var(--page-accent);
  border:1px solid color-mix(in srgb,var(--page-accent) 30%,transparent);
}
.feat .ico.amber  { background:color-mix(in srgb,var(--warn)   12%,transparent); color:var(--warn);   border-color:color-mix(in srgb,var(--warn)   30%,transparent)}
.feat .ico.indigo { background:color-mix(in srgb,var(--violet) 12%,transparent); color:var(--violet); border-color:color-mix(in srgb,var(--violet) 30%,transparent)}
.feat .ico.green  { background:color-mix(in srgb,var(--up)     12%,transparent); color:var(--up);     border-color:color-mix(in srgb,var(--up)     30%,transparent)}
.feat .ico.red    { background:color-mix(in srgb,var(--down)   12%,transparent); color:var(--down);   border-color:color-mix(in srgb,var(--down)   30%,transparent)}
.feat .ico.blue   { background:color-mix(in srgb,var(--blue)   12%,transparent); color:var(--blue);   border-color:color-mix(in srgb,var(--blue)   30%,transparent)}
.feat h3{font-size:19px;line-height:1.18;letter-spacing:-.02em;font-weight:500}
.feat p{color:var(--fg-dim);font-size:13.5px;line-height:1.55;margin:0}
.feat ul.feats{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:8px}
.feat ul.feats li{
  display:flex;gap:10px;align-items:flex-start;
  color:var(--fg-dim);font-size:13px;line-height:1.5;
}
.feat ul.feats li::before{
  content:"";flex:none;width:14px;height:14px;margin-top:3px;
  background:
    radial-gradient(circle, var(--accent) 2.5px, transparent 3px),
    radial-gradient(circle, transparent 5px, var(--line-2) 5.5px, transparent 6.5px);
}

/* alternate panel backdrop */
section.alt{background:var(--bg-2)}
section.alt::before{
  content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px, transparent 1px);background-size:100% 100%;opacity:0;pointer-events:none;
}

/* =========================================================
   filters columns (screener page)
   ========================================================= */
.cols-2-list{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-top:48px}
@media (max-width:820px){.cols-2-list{grid-template-columns:1fr;gap:24px}}
.check-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.check-list li{
  display:flex;gap:12px;align-items:flex-start;
  color:var(--fg-dim);font-size:14.5px;line-height:1.5;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.check-list li:last-child{border-bottom:0}
.check-list li::before{
  content:"";flex:none;width:14px;height:14px;margin-top:3px;
  background:
    radial-gradient(circle, var(--page-accent) 2.5px, transparent 3px),
    radial-gradient(circle, transparent 5px, var(--line-2) 5.5px, transparent 6.5px);
}
.check-list li strong{color:var(--fg);font-weight:500}

/* =========================================================
   pipeline (re-used)
   ========================================================= */
.pipeline-wrap{padding-top:48px}
.pipeline{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;background:var(--bg-2);position:relative;
}
.pipeline.steps-6{grid-template-columns:repeat(6,1fr)}
.p-step{
  padding:28px 22px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;position:relative;z-index:1;
  background:var(--bg-2);transition:background .2s;min-height:200px;
}
.p-step:hover{background:var(--panel)}
.p-step:last-child{border-right:0}
.p-step .n-circle{
  width:30px;height:30px;border-radius:50%;background:var(--bg);border:1px solid var(--line-2);
  display:grid;place-items:center;font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);font-weight:500;
}
.p-step.active .n-circle{
  background:var(--page-accent);color:#0a0a0a;border-color:var(--page-accent);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--page-accent) 20%,transparent)
}
.p-step h5{font-size:15px;font-weight:500;letter-spacing:-.015em}
.p-step p{color:var(--fg-dim);font-size:12.5px;line-height:1.5;margin:0}
@media (max-width:900px){.pipeline,.pipeline.steps-6{grid-template-columns:1fr 1fr}.p-step{border-right:0;border-bottom:1px solid var(--line)}}

/* =========================================================
   detail-section (split with checklist)
   ========================================================= */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:32px}}

/* =========================================================
   final cta + footer
   ========================================================= */
.final{
  padding:clamp(80px,12vw,140px) 0;text-align:center;
  border-top:1px solid var(--line);position:relative;overflow:hidden;
}
.final .dot-bg{opacity:.5}
.final-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:28px}
.final h2{
  font-size:clamp(40px,7vw,96px);line-height:.95;letter-spacing:-.045em;
  font-weight:500;margin:0;max-width:18ch;text-wrap:balance;
}
.final h2 .k{color:var(--page-accent)}
.final p{color:var(--fg-dim);font-size:16px;max-width:54ch;line-height:1.5;margin:0}
.final-cta{display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center}

footer{border-top:1px solid var(--line);padding:56px 0 32px;font-size:13px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
.foot-brand{max-width:280px;color:var(--fg-dim);line-height:1.55;font-size:13px}
.foot-brand .brand{margin-bottom:16px}
.foot-col h6{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;color:var(--fg-faint);text-transform:uppercase;margin:0 0 16px;font-weight:500}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-col a{color:var(--fg-dim);transition:color .15s}
.foot-col a:hover{color:var(--fg)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;color:var(--fg-faint);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap;gap:16px}
.foot-socials{display:flex;gap:14px;align-items:center}
.foot-social{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line-2);background:var(--bg-2);
  color:var(--fg-dim);transition:color .15s,border-color .15s,background .15s;
}
.foot-social:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 6%,var(--bg-2))}

/* =========================================================
   product / mock mini-screens
   ========================================================= */
.mock{
  margin-top:56px;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  overflow:hidden;font-family:var(--font-mono);font-size:12px;
  box-shadow:0 1px 0 0 color-mix(in srgb,var(--fg) 4%,transparent) inset,
             0 30px 80px -40px rgba(0,0,0,.85);
}
.mock-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:10px 14px;border-bottom:1px solid var(--line);background:var(--panel);
}
.mock-head .dots{display:flex;gap:6px}
.mock-head .dots i{width:10px;height:10px;border-radius:50%;background:var(--line-2);display:block}
.mock-head .dots i.g{background:var(--up)}
.mock-head .title{font-size:11px;color:var(--fg-dim);letter-spacing:.04em}
.mock-head .title b{color:var(--fg);font-weight:500}
.mock-head .stat{display:flex;gap:16px;align-items:center;font-size:10.5px;color:var(--fg-dim);letter-spacing:.04em}
.mock-head .live-d{width:6px;height:6px;background:var(--up);border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle;box-shadow:0 0 0 3px color-mix(in srgb,var(--up) 22%,transparent);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.mock-tabs{display:flex;border-bottom:1px solid var(--line);background:var(--panel-2);overflow:auto;scrollbar-width:none}
.mock-tabs::-webkit-scrollbar{display:none}
.mock-tabs button{
  padding:9px 14px;font-family:var(--font-mono);font-size:11px;
  color:var(--fg-dim);letter-spacing:.03em;
  border-right:1px solid var(--line);transition:color .15s,background .15s;white-space:nowrap;
}
.mock-tabs button.on{color:var(--fg);background:var(--bg-2);box-shadow:inset 0 -1px 0 var(--page-accent)}
.mock-tabs button:hover:not(.on){color:var(--fg)}
.mock-body{padding:0}

/* feed rows (re-used) */
.feed-row{
  display:grid;
  grid-template-columns:54px 76px 1fr auto 80px;
  gap:12px;align-items:center;
  padding:10px 14px;border-bottom:1px solid var(--line);
  font-size:12px;min-width:0;
}
.feed-row:last-child{border-bottom:0}
.feed-row .time{color:var(--fg-faint);font-size:10.5px}
.feed-row .kind{
  font-size:10px;letter-spacing:.04em;color:var(--fg-dim);
  padding:2px 6px;border:1px solid var(--line-2);border-radius:3px;text-align:center;
}
.feed-row .kind.pd{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,transparent)}
.feed-row .kind.rsi{color:var(--violet);border-color:color-mix(in srgb,var(--violet) 40%,transparent)}
.feed-row .kind.sp{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 40%,transparent)}
.feed-row .kind.fr{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.feed-row .kind.vl{color:var(--up);border-color:color-mix(in srgb,var(--up) 40%,transparent)}
.feed-row .kind.dp{color:#f59e0b;border-color:color-mix(in srgb,#f59e0b 40%,transparent)}
.feed-row .sym{color:var(--fg);font-weight:500;min-width:0}
.feed-row .sym .q{color:var(--fg-faint)}
.feed-row .ev{color:var(--fg-dim);font-size:11px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.feed-row .ch{text-align:right;font-weight:500}
.feed-row .ch.up{color:var(--up)}
.feed-row .ch.down{color:var(--down)}

/* table mock (analytics) */
.tbl{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:11.5px}
.tbl thead th{
  text-align:left;font-weight:500;color:var(--fg-faint);letter-spacing:.06em;
  padding:10px 14px;background:var(--panel-2);border-bottom:1px solid var(--line);
  font-size:10px;text-transform:uppercase;
}
.tbl thead th.r{text-align:right}
.tbl tbody td{padding:11px 14px;border-bottom:1px solid var(--line);color:var(--fg);}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr:hover td{background:var(--panel)}
.tbl td.dim{color:var(--fg-dim)}
.tbl td.r{text-align:right}
.tbl td .u{color:var(--up)}
.tbl td .d{color:var(--down)}
.tbl td .pill{
  display:inline-block;padding:2px 6px;border-radius:3px;border:1px solid var(--line-2);
  font-size:10px;color:var(--fg-dim);letter-spacing:.04em;
}
.tbl td .pill.long{color:var(--up);border-color:color-mix(in srgb,var(--up) 40%,transparent)}
.tbl td .pill.short{color:var(--down);border-color:color-mix(in srgb,var(--down) 40%,transparent)}
.tbl td .pill.spread{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 40%,transparent)}
.tbl td .pill.pump{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 40%,transparent)}
.tbl td .pill.rsi{color:var(--violet);border-color:color-mix(in srgb,var(--violet) 40%,transparent)}

/* config mock (bot) */
.config{display:grid;grid-template-columns:240px 1fr;min-height:380px}
@media (max-width:760px){.config{grid-template-columns:1fr}}
.config .nav{border-right:1px solid var(--line);background:var(--panel-2);padding:12px 0}
.config .nav .it{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 16px;font-size:11px;color:var(--fg-dim);letter-spacing:.02em;cursor:pointer;
}
.config .nav .it.on{color:var(--fg);background:var(--bg-2);border-left:2px solid var(--page-accent);padding-left:14px}
.config .nav .it .t{display:flex;align-items:center;gap:8px}
.config .nav .it .pill{font-size:9px;color:var(--fg-faint);border:1px solid var(--line);padding:1px 5px;border-radius:3px}
.config .pane{padding:20px 24px;display:flex;flex-direction:column;gap:14px}
.config .pane h6{font-family:var(--font);font-size:14px;font-weight:500;color:var(--fg);letter-spacing:-.01em}
.config .pane .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.config .pane .field{display:flex;flex-direction:column;gap:4px}
.config .pane .field label{font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
.config .pane .field .val{
  font-family:var(--font-mono);font-size:13px;color:var(--fg);
  background:var(--panel);border:1px solid var(--line-2);border-radius:5px;
  padding:7px 10px;display:flex;justify-content:space-between;align-items:center;
}
.config .pane .field .val .u{color:var(--up)}
.config .pane .field .val small{color:var(--fg-faint);font-size:10px}
.config .pane .toggle{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;background:var(--panel);border:1px solid var(--line);border-radius:5px;
  font-size:12px;color:var(--fg);
}
.config .pane .toggle .sw{
  width:30px;height:18px;border-radius:99px;background:var(--page-accent);position:relative;
}
.config .pane .toggle .sw::after{
  content:"";position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#0a0a0a;
}
.config .pane .toggle.off .sw{background:var(--line-2)}
.config .pane .toggle.off .sw::after{right:auto;left:2px}

/* =========================================================
   Trading-bot Customization mock (.bot-mock)
   Mirrors dashboard_dev BotDirectionSection: header strip with
   strategy-status pill + Save button, three accent-colored tabs
   (PUMP/DUMP, SPREAD, RSI), then "Settings" + "Filters" panels
   with inputs animated by JS (typing + caret + filled glow).
   ========================================================= */
.bot-mock{
  --bm-accent:var(--page-accent);
  --bm-bg:rgba(255,255,255,0.022);
  --bm-bg-2:rgba(255,255,255,0.038);
  --bm-line:rgba(255,255,255,0.07);
  --bm-line-2:rgba(255,255,255,0.11);
  width:100%;
  border:1px solid var(--bm-line-2);border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,255,255,0.018),transparent 60%),var(--bg-2);
  font-family:var(--font);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.bot-mock[data-accent="green"] {--bm-accent:var(--up)}
.bot-mock[data-accent="blue"]  {--bm-accent:var(--blue)}
.bot-mock[data-accent="indigo"]{--bm-accent:var(--violet)}

/* Header strip: title + side + ACTIVE pill on the left, Save button right. */
.bm-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 16px;border-bottom:1px solid var(--bm-line);
  background:rgba(255,255,255,0.014);
}
.bm-htitle{display:flex;align-items:center;gap:10px;min-width:0}
.bm-htxt{font-size:13.5px;font-weight:600;letter-spacing:-.005em;color:var(--fg);margin:0}
.bm-side{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;
  color:var(--bm-accent);
  padding:2px 7px;border-radius:4px;
  background:color-mix(in srgb,var(--bm-accent) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--bm-accent) 30%,transparent);
}
.bm-status{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;font-weight:600;
  color:var(--up);
  padding:2px 6px;border-radius:4px;
  background:color-mix(in srgb,var(--up) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--up) 22%,transparent);
}
.bm-save{
  appearance:none;border:1px solid color-mix(in srgb,var(--up) 28%,transparent);
  background:color-mix(in srgb,var(--up) 16%,transparent);
  color:var(--up);font-size:12px;font-weight:600;
  padding:6px 14px;border-radius:7px;cursor:pointer;
  transition:background .15s,border-color .15s;
}
.bm-save:hover{background:color-mix(in srgb,var(--up) 24%,transparent)}

/* Tabs row */
.bm-tabs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-bottom:1px solid var(--bm-line);
  background:rgba(0,0,0,0.16);
}
.bm-tab{
  appearance:none;background:transparent;border:0;border-right:1px solid var(--bm-line);
  padding:11px 12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;
  color:var(--fg-dim);
  position:relative;transition:color .2s,background .2s;
}
.bm-tab:last-child{border-right:0}
.bm-tab:hover{color:var(--fg);background:rgba(255,255,255,0.02)}
.bm-tab.on{color:var(--fg);background:rgba(255,255,255,0.025)}
.bm-tab.on::after{
  content:"";position:absolute;left:14%;right:14%;bottom:-1px;height:2px;
  background:var(--bm-accent);border-radius:2px 2px 0 0;
}
.bm-tdot{
  width:6px;height:6px;border-radius:50%;
  background:var(--up); /* default green */
}
.bm-tdot.green {background:var(--up)}
.bm-tdot.blue  {background:var(--blue)}
.bm-tdot.indigo{background:var(--violet)}

/* Body: stack of sections, each with its own SECTION-LABEL rule line.
 * justify-content:space-between distributes Settings / Filters /
 * Token Lists evenly across the card height (the .split is stretched
 * to match the check-list, which leaves whatever room is left over). */
.bm-body{
  flex:1 1 auto;
  display:flex;flex-direction:column;
  padding:16px 16px 18px;gap:18px;
  justify-content:space-between;
}
.bm-section{display:flex;flex-direction:column;gap:10px}
.bm-sec-lbl{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--fg-faint);font-weight:600;
}
.bm-sec-lbl .bm-rule{flex:1;height:1px;background:var(--bm-line)}

.bm-grid{display:grid;gap:10px}
.bm-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}

/* One field = label on top, value box below (h-10 like the real one). */
.bm-field{display:flex;flex-direction:column;gap:5px;min-width:0}
.bm-fl{
  font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--fg-faint);font-weight:500;
}
.bm-fv{
  position:relative;height:36px;padding:0 11px;
  border:1px solid var(--bm-line);border-radius:7px;
  background:var(--bm-bg);
  display:flex;align-items:center;gap:4px;
  font-size:13px;color:var(--fg);font-weight:500;
  transition:border-color .15s,background .15s;
}
.bm-fv-text{
  font-variant-numeric:tabular-nums;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.bm-fv-sfx{
  position:absolute;right:11px;top:50%;transform:translateY(-50%);
  font-size:10.5px;color:var(--fg-faint);font-weight:500;pointer-events:none;
}
.bm-caret{
  display:inline-block;width:1.5px;height:14px;
  background:var(--bm-accent);
  margin-left:1px;opacity:0;
}
/* Field state: active = currently typing, filled = done. */
.bm-field{position:relative}
.bm-field.active .bm-fv{
  border-color:color-mix(in srgb,var(--bm-accent) 55%,transparent);
  background:color-mix(in srgb,var(--bm-accent) 6%,var(--bm-bg));
  box-shadow:0 0 0 3px color-mix(in srgb,var(--bm-accent) 12%,transparent);
}
.bm-field.active .bm-caret{opacity:1;animation:bm-caret-blink .9s steps(2) infinite}
.bm-field.filled .bm-fv{border-color:var(--bm-line-2);background:var(--bm-bg-2)}
@keyframes bm-caret-blink{50%{opacity:0}}

/* Select-style fields (Order Type, Margin Type): chevron + animated
 * dropdown that pops out below the field while the cursor "scans"
 * options. */
.bm-field--select .bm-fv{padding-right:30px;cursor:default}
.bm-field--select .bm-caret{display:none}
.bm-chev{
  position:absolute;right:11px;top:50%;transform:translateY(-50%);
  color:var(--fg-faint);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
  transition:transform .2s ease,color .2s ease;
}
.bm-field--select.open .bm-chev{transform:translateY(-50%) rotate(180deg);color:var(--bm-accent)}
.bm-dropdown{
  position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:5;
  border:1px solid var(--bm-line-2);border-radius:7px;
  background:rgba(18,18,20,0.96);
  box-shadow:0 8px 24px rgba(0,0,0,0.45);
  padding:4px;
  display:flex;flex-direction:column;gap:1px;
  opacity:0;transform:translateY(-4px);pointer-events:none;
  transition:opacity .15s ease,transform .15s ease;
}
.bm-field--select.open .bm-dropdown{opacity:1;transform:translateY(0);pointer-events:auto}
.bm-opt{
  appearance:none;border:0;background:transparent;
  text-align:left;padding:7px 10px;border-radius:5px;
  font:inherit;font-size:12.5px;font-weight:500;
  color:var(--fg-dim);cursor:pointer;
  transition:background .12s,color .12s;
}
.bm-opt.hover{
  color:var(--fg);
  background:color-mix(in srgb,var(--bm-accent) 14%,transparent);
}
.bm-opt.picked{
  color:var(--bm-accent);
  background:color-mix(in srgb,var(--bm-accent) 18%,transparent);
}

/* Token Lists: White List card matching dashboard's TokenListCard.
 * Header row (title + count + toggle) over an input + pill row. */
.bm-listcard{
  border:1px solid var(--bm-line);border-radius:9px;overflow:hidden;
  background:var(--bm-bg);
  transition:border-color .15s,background .15s;
}
.bm-listcard.active{
  border-color:color-mix(in srgb,var(--bm-accent) 50%,transparent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--bm-accent) 10%,transparent);
}
.bm-listcard.filled{border-color:var(--bm-line-2)}
.bm-list-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 12px;background:rgba(255,255,255,0.018);
  border-bottom:1px solid var(--bm-line);
}
.bm-list-title{font-size:12.5px;color:var(--fg);font-weight:600;letter-spacing:-.005em}
.bm-list-meta{display:flex;align-items:center;gap:10px}
.bm-list-count{
  font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);
  letter-spacing:.04em;
}
.bm-list-body{padding:10px;display:flex;flex-direction:column;gap:8px}
.bm-list-input{
  position:relative;height:34px;padding:0 11px;
  border:1px solid var(--bm-line);border-radius:7px;
  background:rgba(255,255,255,0.02);
  display:flex;align-items:center;
  font-size:12px;color:var(--fg);font-weight:500;
  transition:border-color .15s,background .15s;
}
.bm-list-input.focused{
  border-color:color-mix(in srgb,var(--bm-accent) 55%,transparent);
  background:color-mix(in srgb,var(--bm-accent) 6%,rgba(255,255,255,0.02));
  box-shadow:0 0 0 3px color-mix(in srgb,var(--bm-accent) 12%,transparent);
}
.bm-list-input-text{font-variant-numeric:tabular-nums}
.bm-list-input-ph{
  position:absolute;left:11px;top:50%;transform:translateY(-50%);
  color:var(--fg-faint);font-size:12px;
  pointer-events:none;transition:opacity .15s;
}
.bm-list-input.has-text .bm-list-input-ph{opacity:0}
.bm-list-caret{
  display:inline-block;width:1.5px;height:13px;
  background:var(--bm-accent);
  margin-left:1px;opacity:0;
}
.bm-list-input.focused .bm-list-caret{opacity:1;animation:bm-caret-blink .9s steps(2) infinite}

.bm-list-pills{display:flex;flex-wrap:wrap;gap:5px;min-height:0}
.bm-list-pills:empty{display:none}
.bm-pill{
  display:inline-flex;align-items:center;gap:5px;
  height:22px;padding:0 7px 0 9px;border-radius:6px;
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.02em;
  color:var(--up);
  background:color-mix(in srgb,var(--up) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--up) 22%,transparent);
  opacity:0;transform:scale(.85);
  transition:opacity .18s ease,transform .18s ease;
}
.bm-pill.in{opacity:1;transform:scale(1)}
.bm-pill-x{
  appearance:none;border:0;background:transparent;
  color:color-mix(in srgb,var(--up) 70%,transparent);
  font-size:13px;line-height:1;cursor:pointer;padding:0;
}
.bm-pill-x:hover{color:#fff}

.bm-tg{
  position:relative;flex:none;width:30px;height:16px;border-radius:99px;
  background:rgba(255,255,255,0.08);
  border:1px solid var(--bm-line-2);
  transition:background .25s,border-color .25s;
  cursor:pointer;
}
.bm-tg-knob{
  position:absolute;top:1px;left:1px;
  width:12px;height:12px;border-radius:50%;
  background:#fff;
  transition:left .25s ease, background .25s;
}
.bm-tg.on{
  background:color-mix(in srgb,var(--bm-accent) 36%,transparent);
  border-color:color-mix(in srgb,var(--bm-accent) 55%,transparent);
}
.bm-tg.on .bm-tg-knob{left:15px;background:var(--bm-accent)}

@media (max-width:560px){
  .bm-grid-2{grid-template-columns:1fr}
  .bm-tab{font-size:10px;padding:10px 8px;letter-spacing:.04em}
}

/* card-grid simpler boxed cards */
.box-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding-top:48px}
.box-grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.box-grid,.box-grid.cols-2{grid-template-columns:1fr}}
.box{
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);
  padding:24px;display:flex;flex-direction:column;gap:12px;transition:border-color .2s;
}
.box:hover{border-color:var(--line-2);background:var(--panel)}
.box h4{font-size:16px;font-weight:500;letter-spacing:-.015em}
.box p{color:var(--fg-dim);font-size:13px;line-height:1.55;margin:0}

/* KPI strip (analytics) */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.kpi-strip .kpi{padding:18px 20px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.kpi-strip .kpi:last-child{border-right:0}
.kpi-strip .kpi .l{font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
.kpi-strip .kpi .v{font-family:var(--font-mono);font-size:22px;color:var(--fg);letter-spacing:-.01em}
.kpi-strip .kpi .v.u{color:var(--up)}
.kpi-strip .kpi .v.d{color:var(--down)}
.kpi-strip .kpi .delta{font-family:var(--font-mono);font-size:11px;color:var(--fg-dim)}
.kpi-strip .kpi .delta.u{color:var(--up)}
.kpi-strip .kpi .delta.d{color:var(--down)}
@media (max-width:760px){.kpi-strip{grid-template-columns:1fr 1fr}.kpi-strip .kpi:nth-child(2n){border-right:0}}

/* tg-msg mini (used in scripts pages) */
.tg-card{
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;
  padding:14px;max-width:380px;
  display:flex;flex-direction:column;gap:10px;
  font-family:var(--font);font-size:13px;
}
.tg-card .head{display:flex;align-items:center;gap:10px;padding:0 4px 12px;border-bottom:1px solid var(--line)}
.tg-card .ava{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--page-accent),#7ac41f);
  display:grid;place-items:center;color:#0a0a0a;font-weight:700;font-size:12px;
  font-family:var(--font-mono);
}
.tg-card .who{display:flex;flex-direction:column;line-height:1.2}
.tg-card .who b{font-size:12.5px;font-weight:500}
.tg-card .who span{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-dim)}
.tg-card .menu{margin-left:auto;color:var(--fg-faint);font-family:var(--font-mono)}
.tg-card .msg{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:11px 13px;font-size:12.5px;color:var(--fg);
}
.tg-card .msg b{color:var(--fg);font-weight:600}
.tg-card .msg .title-s{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;font-weight:400}
.tg-card .msg .kv{display:grid;grid-template-columns:auto 1fr;gap:3px 10px;margin-top:8px;font-family:var(--font-mono);font-size:11px}
.tg-card .msg .kv span:nth-child(odd){color:var(--fg-faint)}
.tg-card .msg .kv span:nth-child(even){color:var(--fg);text-align:right}
.tg-card .msg .kv .u{color:var(--up)}
.tg-card .msg .time-s{font-family:var(--font-mono);color:var(--fg-faint);font-size:10px;margin-top:6px}

/* ============================================================
   LANDING-SPECIFIC STYLES (was _index.css)
   ============================================================ */
/* =========================================================
   GRIND MACHINE — landing-only styles
   Layered on top of _shared.css. Re-used selectors:
     .feed-row, .pipeline / .p-step, .final-* , .tg-card, .nav,
     .btn, .lang, .brand, .foot-* , .glow, .dot-bg, .sec-kicker, .sec-head
   New: hero, ticker, terminal, chart-card, trio, modules, scripts, tg-grid
   ========================================================= */

/* density (kept as a tweak knob) */
html[data-density="compact"]{--nav-h:52px}
html[data-density="compact"] section{padding:clamp(48px,6vw,88px) 0}

/* ============ HERO ============ */
.hero{padding:clamp(56px,8vw,112px) 0 clamp(40px,5vw,64px);position:relative;overflow:hidden}
.hero .dot-bg{opacity:.4}
.hero-inner{position:relative;z-index:1}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 12px 4px 10px;border:1px solid var(--line-2);
  border-radius:100px;background:var(--panel);
  font-family:var(--font-mono);font-size:11px;color:var(--fg-dim);
  letter-spacing:.02em;margin-bottom:28px;
}
.hero-eyebrow .live{
  width:6px;height:6px;border-radius:50%;background:var(--up);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--up) 22%,transparent);
  animation:gm-pulse 1.8s infinite;
}
@keyframes gm-pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{
  font-size:clamp(40px,7vw,92px);
  line-height:.98;letter-spacing:-.04em;
  font-weight:500;max-width:18ch;
  text-wrap:balance;
}
.hero h1 .slash{color:var(--fg-faint);font-weight:300}
.hero h1 .k{color:var(--accent)}
.hero p.lede{
  font-size:clamp(15px,1.2vw,18px);color:var(--fg-dim);
  max-width:56ch;line-height:1.5;margin:24px 0 0;
}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:32px}

.hero-metrics{
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-top:56px;border-block:1px solid var(--line);
}
.hero-metrics > div{
  padding:20px 16px;border-right:1px dashed var(--line-2);
  display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center;
}
.hero-metrics > div:last-child{border-right:0}
.hero-metrics .v{font-size:clamp(28px,3vw,42px);font-weight:500;letter-spacing:-.03em;font-family:var(--font-mono)}
.hero-metrics .v small{font-size:.5em;color:var(--fg-faint);margin-left:4px;letter-spacing:0}
.hero-metrics .l{font-family:var(--font-mono);font-size:11px;color:var(--fg-dim);letter-spacing:.05em}
@media (max-width:720px){
  .hero-metrics{grid-template-columns:1fr 1fr}
  .hero-metrics > div{padding:16px !important;border-right:1px dashed var(--line-2);border-bottom:1px dashed var(--line-2)}
  .hero-metrics > div:nth-child(2n){border-right:0}
  .hero-metrics > div:nth-last-child(-n+2){border-bottom:0}
}

/* ============ TERMINAL + CHART ============ */
.terminal-block{
  margin-top:48px;display:grid;grid-template-columns:1.1fr .9fr;gap:16px;
}
@media (max-width:1000px){.terminal-block{grid-template-columns:1fr}}
.terminal{
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  font-family:var(--font-mono);font-size:12px;overflow:hidden;
  box-shadow:0 1px 0 0 color-mix(in srgb,var(--fg) 4%,transparent) inset,
             0 20px 60px -30px rgba(0,0,0,.8);
}
.t-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:10px 14px;border-bottom:1px solid var(--line);background:var(--panel);
}
.t-head .dots{display:flex;gap:6px}
.t-head .dots i{width:10px;height:10px;border-radius:50%;background:var(--line-2);display:block}
.t-head .dots i.g{background:var(--up)}
.t-head .title{font-size:11px;color:var(--fg-dim);letter-spacing:.04em}
.t-head .title b{color:var(--fg);font-weight:500}
.t-head .stat{display:flex;gap:16px;align-items:center;font-size:10.5px;color:var(--fg-dim);letter-spacing:.04em}
.t-head .stat .live-d{
  width:6px;height:6px;background:var(--up);border-radius:50%;
  display:inline-block;vertical-align:middle;margin-right:6px;
  animation:gm-pulse 1.8s infinite;box-shadow:0 0 0 3px color-mix(in srgb,var(--up) 22%,transparent)
}
.t-tabs{display:flex;border-bottom:1px solid var(--line);background:var(--panel-2)}
.t-tabs button{
  padding:9px 14px;font-family:var(--font-mono);font-size:11px;
  color:var(--fg-dim);letter-spacing:.03em;
  border-right:1px solid var(--line);transition:color .15s,background .15s;
}
.t-tabs button.on{color:var(--fg);background:var(--bg-2);box-shadow:inset 0 -1px 0 var(--accent)}
.t-tabs button:hover:not(.on){color:var(--fg)}
.t-body{overflow:hidden;position:relative}
#feed{display:flex;flex-direction:column}

/* override feed-row column widths for landing's tighter terminal */
.terminal .feed-row{
  grid-template-columns:54px 64px 1fr auto 72px;
}
/* On phones the auto-sized .ev column ate into the 1fr .sym column,
 * so signal text ("MEXC F · DEX · base", "RSI 28 · oversold long",
 * "+15.4% · 30s") visibly overlapped USDT suffixes on tickers. Drop
 * the .ev column on small viewports — the type badge already conveys
 * the signal kind, change% stays on the right. */
@media (max-width:720px){
  .terminal .feed-row{grid-template-columns:50px 56px 1fr 60px;gap:8px;padding:10px 12px}
  .terminal .feed-row .ev{display:none}
}
.terminal .feed-row.new{animation:gm-slideIn .45s cubic-bezier(.2,.8,.2,1)}
@keyframes gm-slideIn{
  from{opacity:0;transform:translateY(-6px);background:color-mix(in srgb,var(--accent) 10%,transparent)}
  to{opacity:1;transform:none;background:transparent}
}

/* Hero card host — single full monitor-style card on the right side.
 * Re-renders synchronously every time a new signal scrolls into the
 * left-side feed, so the visitor sees the same end-to-end flow they
 * get on the real /monitor pages. */
.hero-cards{
  display:flex;flex-direction:column;font-family:var(--font-mono);min-width:0;gap:10px;height:100%;
}
.hero-card-real{
  flex:1 1 0;min-width:0;min-height:0;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  padding:14px 16px;display:flex;flex-direction:column;
  /* Distribute the inner sections evenly so head/meta/kvs/(table)/coin
   * all sit at equal vertical intervals — first child pinned to top,
   * last to bottom, gaps in between auto-balanced by space-between. */
  justify-content:space-between;gap:8px;
  animation:hcr-in .35s ease-out;
}
.hero-card-real.compact{padding:10px 12px;gap:6px}
/* Stops the entry animation from re-firing on partial DOM updates
 * (used by the trading-bot trade card which reuses the same node
 * across lifecycle phases). */
.hero-card-real.no-anim{animation:none}
/* Reserves the lower half-slot when only one compact card is on
 * screen, so the visible card keeps its top-half size and doesn't
 * jump when the second card lands. No border, no animation. */
.hero-card-real.placeholder{
  background:transparent;border:1px solid transparent;
  padding:0;animation:none;pointer-events:none;
}
/* Hide hero-cards on mobile — placed AFTER the base .hero-cards rule
 * above so the cascade actually wins inside the media query. The
 * stack didn't fit cleanly in the single-column flow on phones. */
@media (max-width:1000px){
  .hero-cards{display:none}
}
@keyframes hcr-in{
  from{opacity:0;transform:translateY(-3px)}
  to{opacity:1;transform:none}
}

/* Header row */
.hcr-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hcr-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.hcr-dot.up{background:var(--up);box-shadow:0 0 6px var(--up)}
.hcr-dot.down{background:var(--down);box-shadow:0 0 6px var(--down)}
.hcr-kind{
  font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 7px;border-radius:4px;border:1px solid;
}
.hcr-kind.sp{color:#8b5cf6;background:color-mix(in srgb,#8b5cf6 10%,transparent);border-color:color-mix(in srgb,#8b5cf6 25%,transparent)}
.hcr-kind.pd{color:#10b981;background:color-mix(in srgb,#10b981 10%,transparent);border-color:color-mix(in srgb,#10b981 25%,transparent)}
.hcr-kind.dp{color:#f59e0b;background:color-mix(in srgb,#f59e0b 10%,transparent);border-color:color-mix(in srgb,#f59e0b 25%,transparent)}
.hcr-kind.rsi{color:#67e8f9;background:color-mix(in srgb,#67e8f9 10%,transparent);border-color:color-mix(in srgb,#67e8f9 25%,transparent)}
.hcr-kind.fr{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:color-mix(in srgb,var(--accent) 25%,transparent)}
.hcr-tkr{font-size:14px;font-weight:600;color:var(--fg);letter-spacing:-.01em}
.hcr-tkr .q{color:var(--fg-faint);font-weight:400;font-size:11.5px;margin-left:1px}
.hcr-pct{font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}
.hcr-pct.up{color:var(--up)}
.hcr-pct.down{color:var(--down)}
.hcr-spc{flex:1}
.hcr-chip{
  font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 7px;border-radius:4px;border:1px solid;
  color:#10b981;background:color-mix(in srgb,#10b981 10%,transparent);
  border-color:color-mix(in srgb,#10b981 25%,transparent);
}
.hcr-time{font-size:10px;color:var(--fg-faint)}

/* Meta row — last price left, source|network right (same 3-col vibe
 * as the real monitor card meta row). */
.hcr-meta{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.hcr-last{display:inline-flex;align-items:baseline;gap:6px;font-size:12px}
.hcr-last .dk{font-size:9.5px;letter-spacing:.08em;color:var(--fg-faint);text-transform:uppercase}
.hcr-last .dv{font-size:13px;font-weight:500;color:var(--fg);font-variant-numeric:tabular-nums}
.hcr-sub{font-size:10.5px;color:var(--fg-dim);letter-spacing:.04em;text-align:right}

/* KV row — Start/Current, MIN/MAX, Direction */
.hcr-kvs{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:11px}
.hcr-kv{display:inline-flex;align-items:baseline;gap:5px}
.hcr-kv .dk{font-size:9.5px;letter-spacing:.08em;color:var(--fg-faint);text-transform:uppercase}
.hcr-kv .dv{color:var(--fg-dim);font-variant-numeric:tabular-nums}
.hcr-kv .dv.fg{color:var(--fg)}
.hcr-kv .dv.up,.hcr-kv .dv.hi{color:var(--up)}
.hcr-kv .dv.dn,.hcr-kv .dv.lo{color:var(--down)}

/* SPREAD price-pair table */
.hcr-table{width:100%;font-size:11px;border-collapse:collapse}
.hcr-table thead th{
  font-weight:400;color:var(--fg-faint);padding-bottom:4px;text-align:left;
  letter-spacing:.04em;font-size:9.5px;text-transform:uppercase;
}
.hcr-table tbody td{padding:2px 0;color:var(--fg-dim);font-variant-numeric:tabular-nums}
.hcr-table tbody td.fg{color:var(--fg)}
.hcr-table tbody td.up,.hcr-table tbody td.hi{color:var(--up)}
.hcr-table tbody td.dn,.hcr-table tbody td.lo{color:var(--down)}

/* COIN block — divider above + 3-col metrics grid */
.hcr-coin{padding-top:12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.hcr-coin.compact{padding-top:8px;gap:0}
.hcr-coin-grid{
  display:grid;
  /* Three content-sized columns spread across the full row so the
   * right-most column lands under the source|network text + the
   * timestamp in the header (both are right-aligned). */
  grid-template-columns:max-content max-content max-content;
  justify-content:space-between;
  column-gap:14px;row-gap:8px;
}
.hcr-coin-grid.compact{
  /* Single-row 3-cell strip for compact (paired) cards. */
  grid-template-columns:repeat(3,max-content);
  row-gap:0;
}
.hcr-coin-kv{display:flex;align-items:baseline;gap:6px;min-width:0;font-size:11px}
.hcr-coin-kv .dk{flex-shrink:0;font-size:9.5px;letter-spacing:.08em;color:var(--fg-faint);text-transform:uppercase}
.hcr-coin-kv .dv{color:var(--fg-dim);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}

@media (max-width:1280px){
  .hcr-coin-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hcr-coin-grid.compact{grid-template-columns:repeat(3,max-content)}
}

/* ============ TRIO (3 products) ============ */
.trio{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-bottom:1px solid var(--line);
}
.trio > article{
  padding:36px 32px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:16px;
  position:relative;overflow:hidden;
  transition:background .2s;
}
.trio > article:last-child{border-right:0}
.trio > article:hover{background:var(--panel)}
@media (max-width:900px){.trio{grid-template-columns:1fr}.trio > article{border-right:0;border-bottom:1px solid var(--line)}}

.trio .num{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.04em}
.trio h3{font-size:22px;letter-spacing:-.02em;font-weight:500;line-height:1.1}
.trio p.desc{color:var(--fg-dim);font-size:14px;line-height:1.55;margin:0}
.trio ul.features{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:10px}
.trio ul.features li{
  display:flex;gap:10px;align-items:flex-start;
  color:var(--fg-dim);font-size:13px;line-height:1.5;
}
.trio ul.features li::before{
  content:"";flex:none;width:14px;height:14px;margin-top:3px;
  background:
    radial-gradient(circle, var(--accent) 2.5px, transparent 3px),
    radial-gradient(circle, transparent 5px, var(--line-2) 5.5px, transparent 6.5px);
  background-size:100% 100%;background-position:center;
}
.trio .viz{
  margin-top:auto;height:160px;
  border:1px solid var(--line-2);border-radius:var(--radius);
  background:var(--bg-2);position:relative;overflow:hidden;
  font-family:var(--font-mono);font-size:11px;
}
.trio .more-cta{padding-top:16px}
.trio a.more{
  display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-size:13px;font-weight:500;
}
.trio a.more .arrow{transition:transform .15s}
.trio > article:hover a.more .arrow{transform:translateX(3px)}

.viz-scr{padding:14px;display:flex;flex-direction:column;gap:10px;height:100%;justify-content:center}
.viz-scr .line{display:grid;grid-template-columns:52px 1fr auto;gap:10px;align-items:center;color:var(--fg-dim)}
.viz-scr .line .sym{color:var(--fg)}
.viz-scr .line .bar{height:4px;background:var(--line);border-radius:1px;position:relative;overflow:hidden}
.viz-scr .line .bar i{position:absolute;inset:0;background:var(--accent);border-radius:inherit;transform-origin:left;animation:gm-grow 1.2s ease-out both}
@keyframes gm-grow{from{transform:scaleX(0)}}
.viz-scr .line .v{color:var(--up)}
.viz-scr .line .v.d{color:var(--down)}

.viz-bot{padding:14px;display:flex;flex-direction:column;gap:10px;justify-content:center;height:100%}
.viz-bot .step{display:flex;align-items:center;gap:10px;color:var(--fg-dim);font-size:12px}
.viz-bot .step .n{width:18px;height:18px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;font-size:10px;color:var(--fg-dim);font-family:var(--font-mono)}
.viz-bot .step.done .n{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}
.viz-bot .step.done{color:var(--fg)}
.viz-bot .step.now .n{border-color:var(--accent);color:var(--accent);animation:gm-ring 1.6s infinite}
@keyframes gm-ring{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 45%,transparent)}50%{box-shadow:0 0 0 5px color-mix(in srgb,var(--accent) 0%,transparent)}}
.viz-bot .step .arrow{margin-left:auto;color:var(--fg-faint);font-family:var(--font-mono)}

.viz-dash{padding:10px;display:flex;flex-direction:column;gap:8px;height:100%}
.viz-dash .mini{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.viz-dash .mini > div{border:1px solid var(--line);border-radius:3px;padding:6px 8px;font-size:10px;color:var(--fg-dim);display:flex;flex-direction:column;gap:2px}
.viz-dash .mini .v{color:var(--fg);font-family:var(--font-mono);font-size:13px}
.viz-dash .mini .v.u{color:var(--up)}
.viz-dash .chart-mini{flex:1;min-height:0;background:var(--bg)}
.viz-dash .chart-mini svg{width:100%;height:100%;display:block}

/* ============ MODULES (5 detectors) ============ */
.modules{
  display:grid;grid-template-columns:repeat(6,1fr);gap:0;
  border-bottom:1px solid var(--line);
}
.mod{
  padding:32px 28px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;min-height:280px;
  position:relative;overflow:hidden;
  transition:background .2s;
}
.mod:hover{background:var(--panel)}
.mod:nth-child(1),.mod:nth-child(2),.mod:nth-child(3){grid-column:span 2}
.mod:nth-child(3){border-right:0}
.mod:nth-child(4){grid-column:span 3;border-top:1px solid var(--line)}
.mod:nth-child(5){grid-column:span 3;border-top:1px solid var(--line);border-right:0}
@media (max-width:900px){
  .mod{grid-column:span 6 !important;border-right:0;border-top:1px solid var(--line)}
  .mod:first-child{border-top:0}
}
.mod .tag{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.05em;color:var(--fg-dim);
}
.mod .tag .pill{
  padding:2px 6px;border-radius:3px;border:1px solid var(--line-2);color:var(--fg-dim);
  font-size:10px;letter-spacing:.06em;
}
.mod.pd .tag .pill{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,transparent)}
.mod.rsi .tag .pill{color:var(--violet);border-color:color-mix(in srgb,var(--violet) 40%,transparent)}
.mod.sp .tag .pill{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 40%,transparent)}
.mod.vl .tag .pill{color:var(--up);border-color:color-mix(in srgb,var(--up) 40%,transparent)}
.mod.fr .tag .pill{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.mod h4{font-size:20px;line-height:1.15;letter-spacing:-.02em;font-weight:500}
.mod p{color:var(--fg-dim);font-size:13.5px;line-height:1.55;margin:0;max-width:44ch}
.mod .svg-wrap{margin-top:auto;padding-top:16px;border-top:1px dashed var(--line-2)}
.mod .svg-wrap svg{width:100%;height:72px;display:block}

/* ============ TELEGRAM (left/right grid) ============ */
.tg-grid-v2{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start;padding-top:8px}
.tg-grid-v2 .tg-left{display:flex;flex-direction:column;gap:12px}
.tg-grid-v2 .tg-left h2{font-size:clamp(28px,3.4vw,44px);line-height:1.05;letter-spacing:-.025em;max-width:16ch;font-weight:500;margin:8px 0 0}
.tg-grid-v2 .tg-right{padding-top:8px}
@media (max-width:900px){.tg-grid-v2{grid-template-columns:1fr;gap:32px}}
.tg-list{list-style:none;padding:0;margin:24px 0 32px;display:flex;flex-direction:column;gap:0}
.tg-list li{
  display:flex;gap:12px;align-items:flex-start;
  color:var(--fg-dim);font-size:14.5px;line-height:1.5;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.tg-list li:last-child{border-bottom:0}
.tg-list li::before{
  content:"";flex:none;width:14px;height:14px;margin-top:3px;
  background:
    radial-gradient(circle, var(--accent) 2.5px, transparent 3px),
    radial-gradient(circle, transparent 5px, var(--line-2) 5.5px, transparent 6.5px);
}

/* ============ SCRIPTS ============ */
.scripts{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.script{
  padding:28px 26px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;min-height:240px;
  transition:background .2s;
  color:inherit;
}
.script:hover{background:var(--panel)}
.script:last-child{border-right:0}
@media (max-width:900px){.scripts{grid-template-columns:1fr 1fr}.script{border-right:0;border-bottom:1px solid var(--line)}.script:nth-child(2n){border-right:0}}
.script .k{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--fg-faint);text-transform:uppercase}
.script h5{font-size:18px;font-weight:500;letter-spacing:-.015em;line-height:1.15;margin:0}
.script p{color:var(--fg-dim);font-size:13px;line-height:1.55;margin:0;flex:1}
.script .more{color:var(--accent);font-family:var(--font-mono);font-size:11px;margin-top:auto;letter-spacing:.04em;display:flex;align-items:center;gap:6px}

.sc-custom{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:56px 24px 0;text-align:center}
.sc-custom p{color:var(--fg-dim);font-size:14px;max-width:62ch;line-height:1.55;margin:0}
.sc-custom .btn-ghost{border:1px solid var(--line-2);background:transparent;padding:0 18px;height:38px;color:var(--fg)}
.sc-custom .btn-ghost:hover{background:var(--panel);border-color:var(--line-2)}

/* ============ TELEGRAM MOCK PHONE (kept from original landing) ============ */
.tg-phone{
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:20px;
  padding:16px;max-width:400px;width:100%;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.04);
  display:flex;flex-direction:column;gap:10px;position:relative;
}
.tg-head{
  display:flex;align-items:center;gap:10px;padding:6px 4px 14px;
  border-bottom:1px solid var(--line);
}
.tg-head .ava{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#7ac41f);
  display:grid;place-items:center;color:var(--accent-fg);font-weight:700;font-size:14px;
  font-family:var(--font-mono);
}
.tg-head .who{display:flex;flex-direction:column}
.tg-head .who b{font-size:13.5px;font-weight:500}
.tg-head .who span{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-dim)}
.tg-head .menu{margin-left:auto;color:var(--fg-faint);font-family:var(--font-mono)}
.tg-msg{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:12px 14px;font-size:13px;color:var(--fg);max-width:90%;
  opacity:0;animation:gm-fadeIn .5s ease-out forwards;
}
.tg-msg:nth-child(2){animation-delay:.1s}
.tg-msg:nth-child(3){animation-delay:.5s}
.tg-msg:nth-child(4){animation-delay:1.1s}
.tg-msg:nth-child(5){animation-delay:1.7s}
@keyframes gm-fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.tg-msg b{color:var(--fg);font-weight:600}
.tg-msg.me{align-self:flex-end;background:color-mix(in srgb,var(--accent) 14%,var(--panel));border-color:color-mix(in srgb,var(--accent) 30%,var(--line))}
.tg-msg .time-s{font-family:var(--font-mono);color:var(--fg-faint);font-size:10px;margin-top:6px;display:flex;gap:6px}
.tg-msg .kv{display:grid;grid-template-columns:auto 1fr;gap:4px 10px;margin-top:8px;font-family:var(--font-mono);font-size:11px}
.tg-msg .kv span:nth-child(odd){color:var(--fg-faint)}
.tg-msg .kv span:nth-child(even){color:var(--fg);text-align:right}
.tg-msg .kv .u{color:var(--up)}
.tg-msg .title-s{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}

/* ============ landing-specific tweaks for shared bits ============ */
/* hero pipeline: full 6 cols on landing */
#pipeline-sec .pipeline{grid-template-columns:repeat(6,1fr)}
@media (max-width:900px){#pipeline-sec .pipeline{grid-template-columns:1fr 1fr}}

/* final on landing should be slightly bigger */
.final.landing-final h2{font-size:clamp(44px,8vw,120px)}

/* sec-kicker accent */
.sec-kicker::before{background:var(--accent)}

/* ============================================================
   PAGE-SPECIFIC STYLES — pricing.html (extracted from inline <style>)
   ============================================================ */
html[data-page="pricing"] {
  /* pricing-only tokens */
  .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2);margin-top:64px}
  @media (max-width:960px){.price-grid{grid-template-columns:1fr}}
  .pcard{padding:36px 32px;display:flex;flex-direction:column;gap:18px;border-right:1px solid var(--line);min-height:520px;position:relative;transition:background .2s}
  .pcard:last-child{border-right:0}
  @media (max-width:960px){.pcard{border-right:0;border-bottom:1px solid var(--line)}.pcard:last-child{border-bottom:0}}
  .pcard.feat{background:linear-gradient(180deg, color-mix(in srgb,var(--page-accent) 6%, var(--bg-2)) 0%, var(--bg-2) 60%);border-left:1px solid color-mix(in srgb,var(--page-accent) 22%, var(--line));border-right:1px solid color-mix(in srgb,var(--page-accent) 22%, var(--line))}
  .pcard:hover{background:var(--panel)}
  .pcard.feat:hover{background:linear-gradient(180deg, color-mix(in srgb,var(--page-accent) 9%, var(--panel)) 0%, var(--panel) 60%)}
  .pcard .badge{position:absolute;top:14px;right:14px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--page-accent);border:1px solid color-mix(in srgb,var(--page-accent) 35%,transparent);padding:3px 8px;border-radius:99px;background:color-mix(in srgb,var(--page-accent) 10%,transparent)}
  .pcard .num{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .pcard h3{font-size:24px;font-weight:500;letter-spacing:-.02em;margin-top:6px}
  .pcard .desc{color:var(--fg-dim);font-size:13.5px;line-height:1.55;min-height:44px}
  .pcard .price{display:flex;align-items:baseline;gap:8px;padding:8px 0 4px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:6px;padding-top:18px;padding-bottom:18px}
  .pcard .price .v{font-family:var(--font-mono);font-size:30px;letter-spacing:-.02em;color:var(--fg);font-weight:500}
  .pcard.feat .price .v{color:var(--page-accent)}
  .pcard .price .u{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .pcard ul.items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;flex:1}
  .pcard ul.items li{display:flex;gap:10px;align-items:flex-start;color:var(--fg-dim);font-size:13.5px;line-height:1.5}
  .pcard ul.items li::before{content:"";flex:none;width:14px;height:14px;margin-top:3px;background:radial-gradient(circle, var(--page-accent) 2.5px, transparent 3px),radial-gradient(circle, transparent 5px, var(--line-2) 5.5px, transparent 6.5px)}
  .pcard ul.items li strong{color:var(--fg);font-weight:500}
  .pcard .ctaw{margin-top:auto;padding-top:8px}
  .pcard .ctaw .btn{width:100%;justify-content:center}

  /* compare table */
  .compare{margin-top:88px;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  .compare table{width:100%;border-collapse:collapse;font-size:13.5px}
  .compare thead th{padding:18px 20px;background:var(--panel-2);border-bottom:1px solid var(--line);font-family:var(--font);font-weight:500;color:var(--fg);font-size:13px;text-align:left}
  .compare thead th:first-child{color:var(--fg-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}
  .compare thead th .sub{display:block;font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;font-weight:500;margin-top:2px}
  .compare thead th.feat-col{color:var(--page-accent)}
  .compare tbody td{padding:14px 20px;border-bottom:1px solid var(--line);color:var(--fg-dim);vertical-align:top}
  .compare tbody tr:last-child td{border-bottom:0}
  .compare tbody td:first-child{color:var(--fg);font-weight:500}
  .compare tbody td.feat-col{background:color-mix(in srgb,var(--page-accent) 4%,transparent)}
  .compare .check{color:var(--up)}
  .compare .dash{color:var(--fg-faint)}
  .compare tr.group td{background:var(--panel-2);color:var(--fg-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:10px 20px;font-weight:500}

  /* FAQ */
  .faq{margin-top:48px;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
  @media (max-width:820px){.faq{grid-template-columns:1fr}}
  .faq-item{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);padding:24px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s}
  .faq-item:hover{border-color:var(--line-2)}
  .faq-item h4{font-size:15px;font-weight:500;letter-spacing:-.015em;display:flex;align-items:flex-start;gap:10px;line-height:1.35}
  .faq-item h4::before{content:"Q.";font-family:var(--font-mono);font-size:11px;color:var(--page-accent);letter-spacing:.04em;flex:none;padding-top:3px}
  .faq-item p{color:var(--fg-dim);font-size:13.5px;line-height:1.6;margin:0;padding-left:24px}
  .faq-item p a{color:var(--page-accent);border-bottom:1px solid color-mix(in srgb,var(--page-accent) 40%,transparent)}

}
/* ============================================================
   PAGE-SPECIFIC STYLES — dev.html (extracted from inline <style>)
   ============================================================ */
html[data-page="dev"] {
  /* dev page extras */
  .stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2);margin-top:48px}
  @media (max-width:900px){.stack-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:560px){.stack-grid{grid-template-columns:1fr}}
  .stack-item{padding:22px 20px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:8px;min-height:130px}
  .stack-item:nth-child(4n){border-right:0}
  .stack-item:nth-last-child(-n+4){border-bottom:0}
  @media (max-width:900px){.stack-item:nth-child(4n){border-right:1px solid var(--line)}.stack-item:nth-child(2n){border-right:0}.stack-item:nth-last-child(-n+4){border-bottom:1px solid var(--line)}.stack-item:nth-last-child(-n+2){border-bottom:0}}
  .stack-item .lbl{font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.08em;text-transform:uppercase}
  .stack-item .vals{display:flex;flex-wrap:wrap;gap:6px}
  .stack-item .tag{font-family:var(--font-mono);font-size:11px;color:var(--fg);background:var(--panel);border:1px solid var(--line-2);padding:4px 8px;border-radius:4px;letter-spacing:.01em}
  .stack-item .tag.k{color:var(--page-accent);border-color:color-mix(in srgb,var(--page-accent) 35%,transparent);background:color-mix(in srgb,var(--page-accent) 8%,transparent)}

  /* exchanges row */
  .ex-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}
  .ex-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line-2);background:var(--bg-2);border-radius:99px;font-family:var(--font-mono);font-size:12px;color:var(--fg)}
  .ex-chip i{width:6px;height:6px;border-radius:50%;background:var(--up);box-shadow:0 0 0 3px color-mix(in srgb,var(--up) 22%,transparent)}
  .ex-chip.q{color:var(--fg-faint)}
  .ex-chip.q i{background:var(--fg-faint);box-shadow:0 0 0 3px color-mix(in srgb,var(--fg-faint) 22%,transparent)}

  /* case studies */
  .cases{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
  @media (max-width:900px){.cases{grid-template-columns:1fr}}
  .case{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);padding:24px;display:flex;flex-direction:column;gap:14px;transition:border-color .2s}
  .case:hover{border-color:var(--line-2);background:var(--panel)}
  .case .case-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}
  .case .case-head .meta{display:flex;flex-direction:column;gap:2px}
  .case .case-head .meta .who{font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .case .case-head .meta .when{font-family:var(--font-mono);font-size:11px;color:var(--fg-dim)}
  .case .case-head .stat{font-family:var(--font-mono);font-size:10px;color:var(--page-accent);border:1px solid color-mix(in srgb,var(--page-accent) 35%,transparent);padding:3px 8px;border-radius:4px;letter-spacing:.04em;text-transform:uppercase}
  .case h3{font-size:18px;font-weight:500;letter-spacing:-.02em;line-height:1.25}
  .case p{color:var(--fg-dim);font-size:13.5px;line-height:1.55;margin:0}
  .case .case-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:14px;border-top:1px solid var(--line);margin-top:auto}
  .case .case-stats .s{display:flex;flex-direction:column;gap:2px}
  .case .case-stats .s .l{font-family:var(--font-mono);font-size:9.5px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .case .case-stats .s .v{font-family:var(--font-mono);font-size:16px;color:var(--fg);letter-spacing:-.01em}
  .case .case-stats .s .v.u{color:var(--up)}
  .case .case-stats .s .v.k{color:var(--page-accent)}

  /* process timeline */
  .timeline{margin-top:48px;display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  @media (max-width:900px){.timeline{grid-template-columns:1fr 1fr}}
  @media (max-width:560px){.timeline{grid-template-columns:1fr}}
  .tl-step{padding:24px 20px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:10px;min-height:200px;position:relative}
  .tl-step:last-child{border-right:0}
  @media (max-width:900px){.tl-step{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.tl-step:nth-child(2n){border-right:0}}
  .tl-step .n{font-family:var(--font-mono);font-size:11px;color:var(--page-accent);letter-spacing:.06em}
  .tl-step h5{font-size:15px;font-weight:500;letter-spacing:-.015em}
  .tl-step p{color:var(--fg-dim);font-size:12.5px;line-height:1.55;margin:0}
  .tl-step .when{margin-top:auto;font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;padding-top:14px;border-top:1px dashed var(--line-2)}

  /* RFQ form */
  .rfq{margin-top:48px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);padding:32px;display:grid;grid-template-columns:1fr 1fr;gap:18px 24px}
  @media (max-width:760px){.rfq{grid-template-columns:1fr;padding:24px}}
  .rfq .full{grid-column:1/-1}
  .rfq label{display:flex;flex-direction:column;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.08em;text-transform:uppercase}
  .rfq input,.rfq textarea,.rfq select{
    background:var(--panel);border:1px solid var(--line-2);color:var(--fg);
    padding:10px 12px;border-radius:5px;font-family:var(--font);font-size:13.5px;
    transition:border-color .15s;
  }
  .rfq input:focus,.rfq textarea:focus,.rfq select:focus{outline:0;border-color:var(--page-accent)}
  .rfq textarea{min-height:96px;resize:vertical;font-family:var(--font)}
  .rfq .row-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
  .rfq .row-cta p{color:var(--fg-faint);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;margin:0;line-height:1.5}

}
/* ============================================================
   PAGE-SPECIFIC STYLES — blog.html (extracted from inline <style>)
   ============================================================ */
html[data-page="blog"] {
  /* category chips */
  .cats{display:flex;flex-wrap:wrap;gap:6px;margin-top:32px}
  .cat-btn{font-family:var(--font-mono);font-size:11px;color:var(--fg-dim);padding:6px 12px;border-radius:99px;border:1px solid var(--line-2);background:var(--bg-2);letter-spacing:.04em;text-transform:uppercase;transition:color .15s,border-color .15s,background .15s;cursor:pointer}
  .cat-btn:hover{color:var(--fg);border-color:var(--fg-faint)}
  .cat-btn.on{color:var(--page-accent);border-color:color-mix(in srgb,var(--page-accent) 40%,transparent);background:color-mix(in srgb,var(--page-accent) 10%,transparent)}

  /* featured post */
  .featured{margin-top:48px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);overflow:hidden;display:grid;grid-template-columns:1.4fr 1fr;min-height:360px;transition:border-color .2s}
  .featured:hover{border-color:var(--line-2)}
  @media (max-width:900px){.featured{grid-template-columns:1fr}}
  .featured .cover{position:relative;background:linear-gradient(135deg, color-mix(in srgb,var(--page-accent) 14%, var(--bg-2)) 0%, var(--bg-2) 70%);border-right:1px solid var(--line);overflow:hidden;min-height:240px}
  @media (max-width:900px){.featured .cover{border-right:0;border-bottom:1px solid var(--line)}}
  .featured .cover svg{position:absolute;inset:0;width:100%;height:100%}
  .featured .cover .pill{position:absolute;top:18px;left:18px;font-family:var(--font-mono);font-size:10px;color:var(--page-accent);background:color-mix(in srgb,var(--page-accent) 12%, var(--bg-2));border:1px solid color-mix(in srgb,var(--page-accent) 35%, transparent);padding:4px 9px;border-radius:99px;letter-spacing:.06em;text-transform:uppercase;z-index:2}
  .featured .body{padding:36px 32px;display:flex;flex-direction:column;gap:14px}
  .featured .meta{display:flex;gap:14px;font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;align-items:center}
  .featured .meta .read{color:var(--page-accent)}
  .featured h2{font-size:clamp(26px,2.6vw,36px);line-height:1.1;letter-spacing:-.025em;font-weight:500}
  .featured p{color:var(--fg-dim);font-size:14px;line-height:1.6;margin:0}
  .featured .author{display:flex;align-items:center;gap:10px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
  .featured .ava{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--page-accent),#7a5dd8);display:grid;place-items:center;color:#0a0a0a;font-family:var(--font-mono);font-size:11px;font-weight:600}
  .featured .author .who{font-size:12.5px;color:var(--fg)}
  .featured .author .role{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.04em;text-transform:uppercase}

  /* post grid */
  .post-grid{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  @media (max-width:900px){.post-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:640px){.post-grid{grid-template-columns:1fr}}
  .post{padding:24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:12px;min-height:280px;transition:background .2s;cursor:pointer}
  .post:hover{background:var(--panel)}
  .post .cat{font-family:var(--font-mono);font-size:10px;color:var(--page-accent);letter-spacing:.06em;text-transform:uppercase}
  .post .cat.green{color:var(--up)}
  .post .cat.amber{color:var(--warn)}
  .post .cat.blue{color:var(--blue)}
  .post .cat.red{color:var(--down)}
  .post h3{font-size:17px;font-weight:500;letter-spacing:-.015em;line-height:1.3;text-wrap:balance}
  .post p{color:var(--fg-dim);font-size:13px;line-height:1.55;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  .post .meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.04em;text-transform:uppercase}
  /* clean grid borders */
  @media (min-width:901px){
    .post-grid > .post:nth-child(3n){border-right:0}
    .post-grid > .post:nth-last-child(-n+3){border-bottom:0}
  }

  /* changelog rail */
  .changelog{display:grid;grid-template-columns:1fr 2fr;gap:64px;margin-top:48px}
  @media (max-width:900px){.changelog{grid-template-columns:1fr;gap:32px}}
  .changelog .left h4{font-size:18px;font-weight:500;letter-spacing:-.02em}
  .changelog .left p{color:var(--fg-dim);font-size:13.5px;line-height:1.6;margin-top:10px}
  .changelog .left a{color:var(--page-accent);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid color-mix(in srgb,var(--page-accent) 40%,transparent);display:inline-block;margin-top:18px;padding-bottom:2px}
  .cl-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  .cl-item{padding:20px 24px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:120px 1fr auto;gap:20px;align-items:start;transition:background .2s}
  .cl-item:hover{background:var(--panel)}
  .cl-item:last-child{border-bottom:0}
  @media (max-width:640px){.cl-item{grid-template-columns:1fr;gap:8px}}
  .cl-item .ver{font-family:var(--font-mono);font-size:13px;color:var(--page-accent);letter-spacing:-.01em}
  .cl-item .ver small{display:block;color:var(--fg-faint);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;margin-top:2px;font-weight:500}
  .cl-item .body h5{font-size:14px;font-weight:500;letter-spacing:-.015em}
  .cl-item .body ul{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
  .cl-item .body ul li{color:var(--fg-dim);font-size:12.5px;line-height:1.5;display:flex;gap:8px}
  .cl-item .body ul li::before{content:"";flex:none;width:5px;height:5px;border-radius:50%;background:var(--page-accent);margin-top:8px}
  .cl-item .tag{font-family:var(--font-mono);font-size:10px;color:var(--up);border:1px solid color-mix(in srgb,var(--up) 35%,transparent);background:color-mix(in srgb,var(--up) 10%,transparent);padding:3px 8px;border-radius:4px;letter-spacing:.04em;height:fit-content}
  .cl-item .tag.fix{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,transparent);background:color-mix(in srgb,var(--warn) 10%,transparent)}
  .cl-item .tag.brk{color:var(--down);border-color:color-mix(in srgb,var(--down) 35%,transparent);background:color-mix(in srgb,var(--down) 10%,transparent)}

  /* newsletter */
  .news{margin-top:48px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);padding:36px;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
  .news .info{flex:1;min-width:280px}
  .news h4{font-size:20px;font-weight:500;letter-spacing:-.02em}
  .news p{color:var(--fg-dim);font-size:13.5px;line-height:1.55;margin-top:8px}
  .news form{display:flex;gap:8px;flex:1;min-width:280px;max-width:480px}
  .news input{flex:1;background:var(--panel);border:1px solid var(--line-2);color:var(--fg);padding:10px 14px;border-radius:6px;font-family:var(--font);font-size:13.5px;transition:border-color .15s}
  .news input:focus{outline:0;border-color:var(--page-accent)}

}
/* ============================================================
   PAGE-SPECIFIC STYLES — support.html (extracted from inline <style>)
   ============================================================ */
html[data-page="support"] {
  /* contact channels */
  .channels{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  @media (max-width:900px){.channels{grid-template-columns:1fr}}
  .ch{padding:32px 28px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:14px;min-height:280px;text-decoration:none;color:inherit;transition:background .2s;position:relative}
  .ch:hover{background:var(--panel)}
  .ch:last-child{border-right:0}
  @media (max-width:900px){.ch{border-right:0;border-bottom:1px solid var(--line)}.ch:last-child{border-bottom:0}}
  .ch.feat{background:linear-gradient(180deg, color-mix(in srgb,var(--page-accent) 6%, var(--bg-2)) 0%, var(--bg-2) 60%);}
  .ch .ico{width:42px;height:42px;border-radius:9px;display:grid;place-items:center;background:color-mix(in srgb,var(--page-accent) 12%,transparent);color:var(--page-accent);border:1px solid color-mix(in srgb,var(--page-accent) 30%,transparent)}
  .ch .num{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .ch h3{font-size:19px;font-weight:500;letter-spacing:-.02em}
  .ch p{color:var(--fg-dim);font-size:13.5px;line-height:1.55;margin:0}
  .ch .meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .ch .meta .live{color:var(--up)}
  .ch .meta .live::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--up);box-shadow:0 0 0 3px color-mix(in srgb,var(--up) 22%,transparent);margin-right:6px;vertical-align:middle;animation:pulse 1.8s infinite}
  .ch .arrow-r{position:absolute;top:24px;right:24px;color:var(--fg-faint);transition:transform .15s,color .15s}
  .ch:hover .arrow-r{color:var(--page-accent);transform:translate(2px,-2px)}

  /* status grid */
  .status-rows{margin-top:48px;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  .status-rows .strow{display:grid;grid-template-columns:1.4fr 1fr auto;gap:24px;padding:18px 24px;border-bottom:1px solid var(--line);align-items:center}
  .status-rows .strow:last-child{border-bottom:0}
  @media (max-width:760px){.status-rows .strow{grid-template-columns:1fr;gap:8px}}
  .status-rows .name{display:flex;align-items:center;gap:12px}
  .status-rows .name .label{font-size:14px;color:var(--fg);font-weight:500}
  .status-rows .name .label small{display:block;color:var(--fg-faint);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;margin-top:2px;font-weight:500}
  .status-rows .bars{display:flex;gap:2px;height:24px;align-items:end}
  .status-rows .bars i{flex:1;background:var(--up);height:100%;border-radius:1px;opacity:.85;transition:opacity .15s}
  .status-rows .bars i.deg{background:var(--warn)}
  .status-rows .bars i.dn{background:var(--down)}
  .status-rows .bars i:hover{opacity:1}
  .status-rows .pct{font-family:var(--font-mono);font-size:13px;color:var(--up);text-align:right;letter-spacing:-.01em}
  .status-rows .pct.deg{color:var(--warn)}
  .status-rows .pct.dn{color:var(--down)}

  .status-foot{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;border-top:1px solid var(--line);background:var(--panel-2);font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;flex-wrap:wrap;gap:12px}
  .status-foot a{color:var(--page-accent);border-bottom:1px solid color-mix(in srgb,var(--page-accent) 40%,transparent)}

  /* docs grid */
  .docs{margin-top:48px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  @media (max-width:900px){.docs{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:560px){.docs{grid-template-columns:1fr}}
  .doc-cat{padding:24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:10px;min-height:220px;transition:background .2s}
  .doc-cat:hover{background:var(--panel)}
  .doc-cat .ico{width:32px;height:32px;border-radius:7px;display:grid;place-items:center;background:color-mix(in srgb,var(--page-accent) 10%,transparent);color:var(--page-accent);border:1px solid color-mix(in srgb,var(--page-accent) 25%,transparent);margin-bottom:4px}
  .doc-cat h4{font-size:14px;font-weight:500;letter-spacing:-.015em}
  .doc-cat ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}
  .doc-cat ul li a{color:var(--fg-dim);font-size:12.5px;line-height:1.5;display:block;padding:3px 0;transition:color .15s}
  .doc-cat ul li a:hover{color:var(--page-accent)}
  .doc-cat .count{margin-top:auto;padding-top:12px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  @media (min-width:901px){
    .docs > .doc-cat:nth-child(4n){border-right:0}
    .docs > .doc-cat:nth-last-child(-n+4){border-bottom:0}
  }

  /* search bar */
  .search-wrap{position:relative;max-width:560px;margin:32px 0 0}
  .search-wrap input{width:100%;background:var(--panel);border:1px solid var(--line-2);color:var(--fg);font-family:var(--font);font-size:14px;padding:14px 18px 14px 46px;border-radius:8px;transition:border-color .15s}
  .search-wrap input::placeholder{color:var(--fg-faint)}
  .search-wrap input:focus{outline:0;border-color:var(--page-accent)}
  .search-wrap .ico{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--fg-faint);pointer-events:none}
  .search-wrap .kbd{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);border:1px solid var(--line-2);padding:3px 8px;border-radius:4px;background:var(--bg)}

  /* SLA grid */
  .sla{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2)}
  @media (max-width:760px){.sla{grid-template-columns:1fr}}
  .sla .row{padding:24px 24px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:8px;min-height:140px}
  .sla .row:last-child{border-right:0}
  @media (max-width:760px){.sla .row{border-right:0;border-bottom:1px solid var(--line)}.sla .row:last-child{border-bottom:0}}
  .sla .lbl{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase}
  .sla .v{font-family:var(--font-mono);font-size:32px;color:var(--page-accent);letter-spacing:-.02em;line-height:1}
  .sla .desc{color:var(--fg-dim);font-size:12.5px;line-height:1.5;margin-top:auto}

  /* contact form */
  .contact{margin-top:48px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
  @media (max-width:900px){.contact{grid-template-columns:1fr;gap:32px}}
  .contact .info h4{font-size:18px;font-weight:500;letter-spacing:-.02em}
  .contact .info p{color:var(--fg-dim);font-size:13.5px;line-height:1.6;margin-top:10px}
  .contact .info ul{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:14px}
  .contact .info ul li{display:flex;gap:12px;align-items:flex-start;color:var(--fg-dim);font-size:13.5px;line-height:1.5}
  .contact .info ul li::before{content:"";flex:none;width:14px;height:14px;margin-top:3px;background:radial-gradient(circle, var(--page-accent) 2.5px, transparent 3px),radial-gradient(circle, transparent 5px, var(--line-2) 5.5px, transparent 6.5px)}
  .contact .info ul li strong{color:var(--fg);font-weight:500}

  .form{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg-2);padding:28px;display:flex;flex-direction:column;gap:14px}
  .form label{display:flex;flex-direction:column;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.08em;text-transform:uppercase}
  .form input,.form textarea,.form select{background:var(--panel);border:1px solid var(--line-2);color:var(--fg);padding:10px 12px;border-radius:5px;font-family:var(--font);font-size:13.5px;transition:border-color .15s}
  .form input:focus,.form textarea:focus,.form select:focus{outline:0;border-color:var(--page-accent)}
  .form textarea{min-height:110px;resize:vertical;font-family:var(--font)}
  .form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  @media (max-width:560px){.form .row2{grid-template-columns:1fr}}
  .form .submit-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding-top:6px}
  .form .submit-row p{color:var(--fg-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;margin:0;line-height:1.5}

}
/* ============================================================
   PAGE-SPECIFIC STYLES — 404.html (extracted from inline <style>)
   ============================================================ */
html[data-page="404"] {
  body{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}
  .err-wrap{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:120px 0}
  .err-wrap .dot-bg{opacity:.4}
  .err-wrap .glow{
    position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    width:900px;height:900px;border-radius:50%;pointer-events:none;
    background:radial-gradient(closest-side, rgba(180,255,57,.10), transparent 70%);
  }
  .err{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px;max-width:640px;padding:0 24px}
  .err .ticker{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-dim);letter-spacing:.16em;
    padding:6px 14px;border:1px solid var(--line-2);border-radius:99px;background:var(--panel);
    display:inline-flex;align-items:center;gap:10px;
  }
  .err .ticker .d{width:6px;height:6px;background:var(--down);border-radius:50%;box-shadow:0 0 0 3px color-mix(in srgb,var(--down) 22%,transparent);animation:pulse 1.6s infinite}
  .err h1{
    font-family:var(--font-mono);font-size:clamp(120px,20vw,260px);
    line-height:.92;letter-spacing:-.06em;font-weight:500;
    background:linear-gradient(180deg,var(--fg) 0%,#5a5a5a 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
    margin:0;
  }
  .err h2{font-size:clamp(28px,3.5vw,42px);font-weight:500;letter-spacing:-.025em;line-height:1.05;text-wrap:balance}
  .err h2 .k{color:var(--accent)}
  .err p{color:var(--fg-dim);font-size:15px;line-height:1.55;max-width:48ch;margin:0}
  .err .cta{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:8px}

  .err .quotes{
    margin-top:32px;
    background:var(--panel);border:1px solid var(--line-2);border-radius:8px;
    padding:14px 18px;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-dim);
    display:grid;grid-template-columns:repeat(3,1fr);gap:0;width:100%;
  }
  .err .quotes .q{display:flex;flex-direction:column;gap:4px;align-items:center;border-right:1px solid var(--line);padding:6px 8px}
  .err .quotes .q:last-child{border-right:0}
  .err .quotes .l{font-size:9.5px;letter-spacing:.08em;color:var(--fg-faint);text-transform:uppercase}
  .err .quotes .v{font-size:13px;color:var(--fg)}
  .err .quotes .v.u{color:var(--up)}
  .err .quotes .v.d{color:var(--down)}
}

/* =========================================================
   AUTH PAGES — login / register / verify-email
   Ported from dashboard_dev/src/index.css §AUTH PAGES (SPA),
   tokens remapped: --gm-bg → --bg, --gm-fg → --fg, etc.
   ========================================================= */
.auth-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font);
  font-size: 14px;
  letter-spacing: -0.01em;
}

.auth-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: 56px;
  display: flex;
  align-items: center;
  padding: 0 24px;
  background: color-mix(in srgb, var(--bg) 80%, transparent);
  backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--line);
}

.auth-logo {
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  color: var(--fg);
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.auth-body {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 96px 24px 40px;
}
@media (max-width: 639px) {
  .auth-body { padding: 80px 16px 32px; }
}

.auth-card {
  width: 100%;
  max-width: 420px;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 16px;
  padding: 40px;
  position: relative;
  z-index: 1;
}
@media (max-width: 639px) {
  .auth-card { padding: 24px 20px; border-radius: 12px; }
}

.auth-card h1 {
  margin: 0 0 6px;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--fg);
  text-align: left;
}

.auth-card .auth-sub {
  text-align: left;
  color: var(--fg-dim);
  font-size: 13.5px;
  margin: 0 0 28px;
  line-height: 1.5;
}

.auth-card .form-group {
  margin-bottom: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.auth-card .form-label {
  display: block;
  font-size: 12.5px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: -0.005em;
  color: var(--fg-dim);
  margin-bottom: 0;
  padding-left: 0;
}

.auth-card .form-input-wrap {
  position: relative;
}

.auth-card .form-input-wrap svg {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 15px;
  color: var(--fg-faint);
  pointer-events: none;
}

.auth-card .form-input {
  width: 100%;
  height: 42px;
  padding: 0 12px 0 38px;
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-radius: 8px;
  color: var(--fg);
  font-size: 13.5px;
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
}

.auth-card .form-input::placeholder {
  color: var(--fg-faint);
}

.auth-card .form-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(180, 255, 57, 0.08);
}

.auth-card .form-input-code {
  font-family: var(--font-mono);
  font-size: 18px;
  letter-spacing: 8px;
  text-align: center;
  padding-left: 12px;
}

.auth-card .form-input-code::placeholder {
  letter-spacing: 4px;
  font-size: 14px;
}

.auth-card .form-hint {
  font-size: 11.5px;
  color: var(--fg-faint);
  margin-top: 4px;
  padding-left: 0;
  line-height: 1.5;
}

.auth-error {
  padding: 10px 14px;
  border-radius: 8px;
  background: rgba(255, 77, 109, 0.06);
  border: 1px solid rgba(255, 77, 109, 0.25);
  color: var(--down);
  font-size: 12.5px;
  text-align: left;
  margin-bottom: 20px;
  display: none;
}
.auth-error.visible { display: block; }

.auth-success {
  padding: 10px 14px;
  border-radius: 8px;
  background: rgba(61, 255, 162, 0.06);
  border: 1px solid rgba(61, 255, 162, 0.25);
  color: var(--up);
  font-size: 12.5px;
  text-align: left;
  margin-bottom: 20px;
  display: none;
}
.auth-success.visible { display: block; }

.auth-submit {
  width: 100%;
  height: 44px;
  padding: 0;
  background: var(--accent);
  color: var(--accent-fg);
  font-size: 14px;
  font-weight: 600;
  font-family: inherit;
  letter-spacing: -0.01em;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
  margin-top: 4px;
}

.auth-submit:hover { background: #c8ff52; }
.auth-submit:active { transform: scale(0.98); }
.auth-submit:disabled { opacity: 0.5; cursor: not-allowed; }

.auth-footer-link,
.auth-resend {
  text-align: center;
  margin-top: 20px;
  font-size: 13px;
  color: var(--fg-faint);
}

.auth-footer-link a,
.auth-footer-link button,
.auth-resend button {
  background: none;
  border: none;
  color: var(--accent);
  font-weight: 500;
  cursor: pointer;
  font-size: 13px;
  font-family: inherit;
  text-decoration: none;
}

.auth-footer-link a:hover,
.auth-footer-link button:hover,
.auth-resend button:hover {
  text-decoration: underline;
}

.auth-resend button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  text-decoration: none;
}

/* =========================================================
   PHONE OVERRIDES (<=560px) — fit narrow viewports
   - Compact nav: smaller brand, lang toggle, ghost+primary buttons
   - Tighter hero h1 minimum size
   ========================================================= */
@media (max-width:560px){
  .nav-row{gap:8px}
  .brand{font-size:14px;white-space:nowrap}
  .brand-mark{width:20px;height:20px}
  .lang{padding:1px;font-size:10px}
  .lang button{padding:3px 6px}
  /* Compact buttons in the sticky topbar */
  nav.topbar .btn-lg{height:32px;padding:0 10px;font-size:12px;border-radius:6px}
  nav.topbar .btn-ghost{padding:0 6px;font-size:12px}
  nav.topbar .btn .arrow{display:none}
  /* Hero headline: drop the floor of the clamp so the first line
   * doesn't blow past the viewport on phones. */
  .hero h1{font-size:clamp(28px,8vw,64px);max-width:100%}
  .hero p.lede{font-size:14px;line-height:1.5}
  .hero-eyebrow{font-size:10.5px;padding:3px 10px}
}

/* =========================================================
   MOBILE ALIGNMENT OVERRIDES (<=820px)
   - Hero: eyebrow / h1 / lede / cta centered
   - #pipeline-sec sec-head: kicker/h2/sub centered
   - #telegram tg-left: kicker/h2/sub/cta + tg-list centered
   - footer: brand row, then 2-col (Scripts | Platform/Company),
     then copyright centered, then socials centered
   ========================================================= */
@media (max-width:820px){
  /* HERO — both wrappers (.hero-inner on landing, .ph-inner on every
   * other page) get centered on mobile so the hero block reads the
   * same way everywhere. */
  .hero-inner,
  .ph-inner{text-align:center}
  .hero-eyebrow{margin-left:auto;margin-right:auto}
  .hero h1,
  .ph-inner h1{margin-left:auto;margin-right:auto}
  .hero .lede,
  .ph-inner .lede{margin-left:auto;margin-right:auto;text-align:center}
  .ph-inner .eyebrow{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .ph-inner .hero-cta{justify-content:center}

  /* SECTION HEADS — center kicker / h2 / sub on every section on
   * mobile (was only #pipeline-sec before). The base .sec-head rule
   * already collapses to a single column at this breakpoint, so we
   * just need to center the items inside it. */
  .sec-head{justify-items:center;text-align:center}
  .sec-head .sec-kicker{justify-self:center;justify-content:center}
  .sec-head h2{margin-left:auto;margin-right:auto}
  .sec-head .sec-sub{justify-self:center;margin-left:auto;margin-right:auto;text-align:center}

  /* TELEGRAM */
  .tg-grid-v2 .tg-left{align-items:center;text-align:center}
  /* tg-kicker is a flex child of .tg-left; needs explicit align-self
   * because flex containers default to align-items:stretch otherwise. */
  .tg-grid-v2 .tg-left .sec-kicker{align-self:center;justify-content:center}
  .tg-grid-v2 .tg-left .sec-sub{margin-left:auto;margin-right:auto;text-align:center}
  /* Override the inline style="align-self:flex-start" on the CTA */
  #tg-cta{align-self:center !important}
  /* The bullet list itself is centered as a block, but each <li> is
   * left-aligned inside it so all bullets line up vertically (instead
   * of "shifting" with the length of the line above, the way they did
   * with justify-content:center). */
  .tg-list{max-width:380px;margin-left:auto;margin-right:auto}
  .tg-list li{justify-content:flex-start;text-align:left}
  /* On mobile the [data-block="telegram-sync"] desktop tweaks
   * (padding-top:28px on the column, margin-top:auto + 78px gap on
   * the sub) leave a visible empty band between sub and the bullet
   * list. Reset them so the section reads as a normal stacked block. */
  [data-block="telegram-sync"] .tg-grid-v2 .tg-left{padding-top:0;padding-bottom:0}
  [data-block="telegram-sync"] .tg-grid-v2 .tg-left .sec-sub{
    margin-top:8px;margin-bottom:0;
  }

  /* FOOTER — brand top, 2-col (Scripts | Platform/Company), then bottom */
  .foot-grid{
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "brand   brand"
      "scripts platform"
      "scripts company";
    column-gap:32px;
    row-gap:28px;
  }
  .foot-brand{
    grid-area:brand;max-width:none;
    display:flex;flex-direction:column;align-items:center;text-align:center;
  }
  .foot-brand p{margin-left:auto;margin-right:auto}
  /* Children inside .foot-grid: 1=brand, 2=Platform, 3=Scripts, 4=Company */
  .foot-grid > .foot-col:nth-child(2){grid-area:platform}
  .foot-grid > .foot-col:nth-child(3){grid-area:scripts}
  .foot-grid > .foot-col:nth-child(4){grid-area:company}
  /* Indent the columns so they don't sit flush against the .wrap edge
   * — gives Scripts / Platform / Company a comfortable left gutter,
   * matching the visual rhythm of the centered brand row above. */
  .foot-grid > .foot-col{padding-left:32px}
  /* Footer bottom: stack copyright + socials, both centered */
  .foot-bottom{flex-direction:column;align-items:center;justify-content:center;gap:14px}
  .foot-bottom > span{order:1;text-align:center}
  .foot-socials{order:2;justify-content:center}
}

/* In signals-grid-23 (screener), #strat-grid (trading-bot),
 * #views-grid (analytics Dashboard Modules) and #sc-feat-grid
 * (scripts WHAT IT DOES) cards: place the icon and the h3 on
 * the same row (icon left, title right) instead of stacking
 * vertically. */
.signals-grid-23 .feat,
#strat-grid .feat,
#views-grid .feat,
#sc-feat-grid .feat{
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-areas:
    "num num"
    "ico h3"
    "p   p";
  align-items:center;
  column-gap:12px;
  row-gap:10px;
  min-height:0;
}
.signals-grid-23 .feat .num,
#strat-grid .feat .num,
#views-grid .feat .num,
#sc-feat-grid .feat .num{grid-area:num}
.signals-grid-23 .feat .ico,
#strat-grid .feat .ico,
#views-grid .feat .ico,
#sc-feat-grid .feat .ico{grid-area:ico}
.signals-grid-23 .feat h3,
#strat-grid .feat h3,
#views-grid .feat h3,
#sc-feat-grid .feat h3{grid-area:h3;align-self:center;margin:0}
.signals-grid-23 .feat p,
#strat-grid .feat p,
#views-grid .feat p,
#sc-feat-grid .feat p{grid-area:p;margin-top:4px}
/* Anchor card rows to the top so num/ico/h3/p sit at the same Y
 * across the row regardless of paragraph length. Default
 * align-content:stretch was distributing the leftover 240px-min-height
 * space between rows, so cards with shorter copy had their icon/
 * title/paragraph pushed lower than the longer ones in the same row.
 * Free space now collects at the bottom of each card instead. */
#strat-grid .feat,
#views-grid .feat,
#sc-feat-grid .feat{align-content:start}

/* Scripts ARCHITECTURE pipeline: 5 cards in one row instead of 4 +
 * orphaned 5th. Per-step padding is shrunk a touch so the cards
 * still breathe at the narrower column width. */
[data-block="pipe"] .pipeline{grid-template-columns:repeat(5,1fr)}
[data-block="pipe"] .p-step{padding:24px 18px}
@media (max-width:1100px){
  [data-block="pipe"] .pipeline{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:720px){
  [data-block="pipe"] .pipeline{grid-template-columns:1fr 1fr}
}

/* Scripts pages: GET THE SCRIPT final h2 was using the landing-style
 * clamp(40px,7vw,96px) which felt outsized on the per-script pages
 * (where the same heading repeats five times across the site).
 * Scope-down to a section-h2-ish range. */
.page-script .final h2{font-size:clamp(34px,5vw,60px);max-width:22ch}
/* =========================================================
   SIGNALS GRID 2 + 3  (matches PROD signals-grid-2x3)
   Used on /screener for the 5 detection-module cards:
   row 1 has 2 wide cards, row 2 has 3 narrower cards.
   ========================================================= */
.signals-grid-23{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;
}
.signals-grid-23 > .feat{
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin:0;padding:28px 28px 32px;
}
/* Row 1: cards 1+2 each span 3 of 6 columns (50/50). */
.signals-grid-23 > .feat:nth-child(1){grid-column:span 3}
.signals-grid-23 > .feat:nth-child(2){grid-column:span 3;border-right:0}
/* Row 2: cards 3,4,5 each span 2 of 6 columns (33/33/33). */
.signals-grid-23 > .feat:nth-child(3){grid-column:span 2}
.signals-grid-23 > .feat:nth-child(4){grid-column:span 2}
.signals-grid-23 > .feat:nth-child(5){grid-column:span 2;border-right:0}
.signals-grid-23 > .feat:nth-child(3),
.signals-grid-23 > .feat:nth-child(4),
.signals-grid-23 > .feat:nth-child(5){border-bottom:0}
@media (max-width:820px){
  .signals-grid-23{grid-template-columns:1fr}
  .signals-grid-23 > .feat{
    grid-column:span 1 !important;
    border-right:0;border-bottom:1px solid var(--line);
  }
  .signals-grid-23 > .feat:last-child{border-bottom:0}
}

/* =========================================================
   ANALYTICS HERO MOCK — animated dashboard imitation
   Sidebar + scrollable Signals/Trading views. Used inside
   .mock.dash-mock on /analytics.
   ========================================================= */
.dash-mock{
  font-family:var(--font);
  --dm-bg:rgba(255,255,255,0.02);
  --dm-bg-2:rgba(255,255,255,0.04);
  --dm-line:rgba(255,255,255,0.06);
  --dm-line-2:rgba(255,255,255,0.10);
}
.dash-mock .mock-head{font-family:var(--font-mono)}
.dm-shell{display:grid;grid-template-columns:180px 1fr;height:500px}
@media (max-width:720px){
  .dm-shell{grid-template-columns:120px 1fr;height:440px}
}

/* ---- sidebar ---- */
.dm-sidebar{
  border-right:1px solid var(--dm-line);
  background:rgba(0,0,0,0.18);
  padding:14px 0;
  overflow:hidden;
}
.dm-grp{
  padding:14px 14px 6px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;
  color:var(--fg-faint);
}
.dm-grp:first-child{padding-top:0}
.dm-nav{
  display:flex;align-items:center;gap:10px;
  padding:7px 14px;
  font-size:12px;color:var(--fg-dim);
  border-left:2px solid transparent;
  transition:background .2s,color .2s,border-color .2s;
}
.dm-nav-ico{
  display:inline-flex;color:var(--fg-faint);
  transition:color .2s;
}
.dm-nav-l{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dm-nav-soon{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:.08em;
  color:var(--fg-faint);
  padding:2px 5px;border-radius:3px;
  background:rgba(255,255,255,0.05);
}
.dm-nav.on{
  color:var(--fg);
  background:linear-gradient(90deg, color-mix(in srgb,var(--up) 14%,transparent), transparent 90%);
  border-left-color:var(--up);
}
.dm-nav.on .dm-nav-ico{color:var(--up)}

/* ---- main scrollable area ---- */
.dm-main{
  position:relative;overflow:hidden;
  background:radial-gradient(ellipse at 100% 100%, color-mix(in srgb,var(--up) 4%,transparent), transparent 55%), var(--bg-2);
}
.dm-scroll{
  position:absolute;inset:0;
  padding:18px;
  display:flex;flex-direction:column;gap:14px;
  will-change:transform;
  font-family:var(--font);
}
.dm-scroll[hidden]{display:none}

/* ---- KPI tiles ---- */
.dm-kpi-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  flex:none;
}
.dm-kpi-row--7{grid-template-columns:repeat(4,1fr)}
.dm-kpi{
  border:1px solid var(--dm-line);border-radius:10px;
  background:var(--dm-bg);
  padding:14px 16px;
  display:flex;flex-direction:column;gap:4px;
  min-width:0;
}
.dm-kpi--big{
  background:radial-gradient(circle at 80% 30%, color-mix(in srgb,var(--up) 12%,transparent), transparent 60%), var(--dm-bg);
  border-color:color-mix(in srgb,var(--up) 18%,var(--dm-line-2));
}
.dm-kpi-l{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.10em;
  color:var(--fg-faint);text-transform:uppercase;
}
.dm-kpi-v{
  font-size:22px;font-weight:600;color:var(--fg);
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;
  margin:1px 0 0;
}
.dm-kpi-v small{font-size:13px;color:var(--fg-faint);font-weight:500;margin-left:1px}
.dm-kpi--big .dm-kpi-v{font-size:28px}
.dm-kpi-s{
  font-size:11px;color:var(--fg-dim);
}
.dm-kpi-s .up,.dm-kpi-v .up{color:var(--up)}
.dm-kpi-s .down,.dm-kpi-v .down{color:var(--down)}

/* ---- Cards (donut, bar, line, table, pnl) ---- */
.dm-card{
  border:1px solid var(--dm-line);border-radius:10px;
  background:var(--dm-bg);
  display:flex;flex-direction:column;
  flex:none;
}
.dm-card-head{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  border-bottom:1px solid var(--dm-line);
}
.dm-card-head--mono{font-family:var(--font-mono)}
.dm-card-title{
  font-size:13px;color:var(--fg);font-weight:600;letter-spacing:-.01em;
  display:inline-flex;align-items:center;gap:7px;
}
.dm-card-head--mono .dm-card-title{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.10em;
  color:var(--fg-dim);font-weight:500;text-transform:uppercase;
}
.dm-card-sub{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;
  color:var(--fg-faint);
}
.dm-card-spacer{flex:1}
.dm-card-legend{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;
  color:var(--fg-dim);
}
.dm-card-legend .dm-leg-l{color:var(--fg-dim)}
.dm-card-sub-row{
  padding:8px 14px;
  display:flex;flex-wrap:wrap;gap:14px;
  font-size:11px;color:var(--fg-dim);font-family:var(--font-mono);
}
.dm-card-sub-row b{color:var(--fg);font-weight:600}
.dm-card-sub-mini{
  font-family:var(--font-mono);font-size:9px;letter-spacing:.10em;color:var(--fg-faint);
}

/* "+ Expand" / "50 rows" pill on the right of card heads */
.dm-pill-btn{
  font-size:10px;color:var(--fg-dim);
  padding:3px 8px;border:1px solid var(--dm-line-2);border-radius:6px;
  background:rgba(255,255,255,0.02);
  margin-left:auto;
}
.dm-pill-grey{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;
  padding:2px 6px;border-radius:4px;
  background:rgba(255,255,255,0.04);color:var(--fg-faint);
}
.dm-pill-up{
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  padding:2px 6px;border-radius:4px;
  color:var(--up);
  background:color-mix(in srgb,var(--up) 14%,transparent);
}
.dm-line-pill{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.04em;
  padding:2px 7px;border-radius:4px;
  color:var(--fg-dim);
  background:rgba(255,255,255,0.04);
}
.dm-tabs-mini{
  display:inline-flex;border:1px solid var(--dm-line-2);border-radius:6px;
  overflow:hidden;background:rgba(0,0,0,0.2);
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.04em;
}
.dm-tabs-mini span{
  padding:3px 8px;color:var(--fg-faint);border-right:1px solid var(--dm-line-2);
}
.dm-tabs-mini span:last-child{border-right:0}
.dm-tabs-mini span.on{color:var(--fg);background:rgba(255,255,255,0.05)}

/* tiny dot used in legends + section labels */
.dm-dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  flex:none;
}
.dm-tdot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--up);flex:none;
  box-shadow:0 0 0 2px color-mix(in srgb,var(--up) 22%,transparent);
}
.dm-tdot.up{background:var(--up);box-shadow:0 0 0 2px color-mix(in srgb,var(--up) 22%,transparent)}
.dm-tdot.down{background:var(--down);box-shadow:0 0 0 2px color-mix(in srgb,var(--down) 22%,transparent)}

/* ---- Donut card ---- */
.dm-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.dm-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:900px){
  .dm-grid-3{grid-template-columns:1fr}
  .dm-grid-2{grid-template-columns:1fr}
  .dm-kpi-row,.dm-kpi-row--7{grid-template-columns:repeat(2,1fr)}
}
.dm-card--donut .dm-card-head .dm-card-title{font-size:12px}
.dm-donut-row{
  display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;
  padding:14px;
}
.dm-donut{
  width:104px;height:104px;border-radius:50%;
  position:relative;flex:none;
  /* `background` set inline via JS as a conic-gradient */
}
.dm-donut::after{
  content:"";position:absolute;inset:18px;border-radius:50%;
  background:var(--bg-2);
  box-shadow:inset 0 0 0 1px var(--dm-line);
}
.dm-donut-hole{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;z-index:1;
}
.dm-donut-hole strong{font-size:16px;color:var(--fg);font-weight:600;letter-spacing:-.01em}
.dm-donut-hole span{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.08em;color:var(--fg-faint);margin-top:1px}
.dm-legend{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:5px;
  font-size:10.5px;
}
.dm-legend li{
  display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;
}
.dm-leg-l{color:var(--fg);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10.5px}
.dm-leg-v{
  font-family:var(--font-mono);font-size:10px;color:var(--fg);
  display:inline-flex;gap:6px;align-items:baseline;
}
.dm-leg-pct{color:var(--fg-faint);font-size:9.5px}

/* ---- Bar chart by hour ---- */
.dm-card--bar{padding-bottom:10px}
.dm-bars{
  height:135px;padding:8px 12px 0;
  display:grid;grid-template-columns:repeat(24,1fr);gap:3px;align-items:end;
}
.dm-bar{
  position:relative;display:flex;flex-direction:column-reverse;
  border-radius:2px 2px 0 0;overflow:hidden;
}
.dm-bar .seg{display:block;width:100%}
.dm-bar .seg.rsi{background:var(--violet)}
.dm-bar .seg.pd {background:var(--warn)}
.dm-bar .seg.sp {background:var(--blue)}
.dm-bars-axis{
  display:flex;justify-content:space-between;
  padding:6px 14px 0;
  font-family:var(--font-mono);font-size:9.5px;color:var(--fg-faint);
}

/* ---- Signals over time line chart ---- */
.dm-card--line{padding-bottom:10px}
.dm-line-svg{
  width:calc(100% - 24px);height:135px;display:block;margin:0 12px;
  overflow:visible;
}
.dm-line-axis{
  display:flex;justify-content:space-between;
  padding:6px 14px 0;
  font-family:var(--font-mono);font-size:9.5px;color:var(--fg-faint);
}

/* ---- Table card (Deals / Trades) ---- */
.dm-card--table{padding-bottom:0}
.dm-table{
  width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:10.5px;
}
.dm-table thead th{
  text-align:left;padding:8px 10px;
  font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);
  background:rgba(255,255,255,0.018);
  border-bottom:1px solid var(--dm-line);font-weight:500;
}
.dm-table tbody td{
  padding:9px 10px;border-bottom:1px solid var(--dm-line);
  color:var(--fg);font-variant-numeric:tabular-nums;white-space:nowrap;
}
.dm-table tbody tr:last-child td{border-bottom:0}
.dm-table td.dim{color:var(--fg-faint)}
.dm-table td .up{color:var(--up);font-weight:600}
.dm-table td .down{color:var(--down);font-weight:600}
.dm-td-date{display:block;font-size:10.5px;color:var(--fg)}
.dm-td-time{display:block;font-size:9.5px;color:var(--fg-faint)}
.dm-tk{display:inline-block;color:var(--fg);font-weight:600;font-size:11px;margin-right:6px}
.dm-tk-net{
  font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;
  padding:1px 5px;border:1px solid var(--dm-line-2);border-radius:3px;
  color:var(--fg-faint);background:rgba(255,255,255,0.02);
}
.dm-pill{
  display:inline-block;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;
  padding:2px 7px;border-radius:4px;
}
.dm-pill--rsi{color:var(--violet);border:1px solid color-mix(in srgb,var(--violet) 35%,transparent);background:color-mix(in srgb,var(--violet) 12%,transparent)}
.dm-pill--sp{color:var(--blue);border:1px solid color-mix(in srgb,var(--blue) 35%,transparent);background:color-mix(in srgb,var(--blue) 12%,transparent)}
.dm-pill--pd{color:var(--warn);border:1px solid color-mix(in srgb,var(--warn) 35%,transparent);background:color-mix(in srgb,var(--warn) 12%,transparent)}
.dm-td-src{font-size:10px;color:var(--fg-dim)}
.dm-arrow.down{color:var(--down);font-family:var(--font-mono);font-size:10px;font-weight:600}
.dm-stat{display:inline-flex;align-items:center;gap:6px;font-size:10px;color:var(--fg-dim);font-family:var(--font-mono)}

/* ---- Trading section labels & PNL bars ---- */
.dm-section-lbl{
  display:flex;align-items:center;gap:10px;
  padding:6px 4px 0;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.10em;
  color:var(--fg);font-weight:600;
}
.dm-section-sub{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;
  color:var(--fg-faint);font-weight:500;
}
.dm-card--pnl .dm-card-title b{color:var(--fg);font-weight:600}
.dm-pnl-chart{
  position:relative;height:160px;padding:0 14px;
}
.dm-pnl-axis{
  position:absolute;left:14px;right:14px;top:50%;height:1px;
  background:var(--dm-line-2);
}
/* Two-row grid splits the chart at the center line: positive bars
 * live in row 1 with align-self:end (anchored to the bottom of row 1
 * = the center, growing UP), negative bars live in row 2 with
 * align-self:start (anchored to the top of row 2 = the center,
 * growing DOWN). The bar's inline `height:X%` is taken as a
 * percentage of its row, which is half the chart height. */
.dm-pnl-bars{
  position:relative;height:100%;
  display:grid;
  grid-template-columns:repeat(90,1fr);
  grid-template-rows:1fr 1fr;
  column-gap:1px;
}
.dm-pnl-bar{display:block}
.dm-pnl-bar.pos{
  grid-row:1;align-self:end;
  background:var(--up);
  border-radius:1px 1px 0 0;
}
.dm-pnl-bar.neg{
  grid-row:2;align-self:start;
  background:var(--down);
  border-radius:0 0 1px 1px;
}

