*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f3ee;--surface:#ffffff;--surface2:#ece9e3;
  --border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.14);
  --text:#0c0d12;--fg:#0c0d12;--muted:#52596b;--faint:#959ca8;
  --buy:#059669;--sell:#dc2626;--gold:#b45309;--accent:#4f46e5;--congress:#7c3aed;
  --buy-bg:rgba(5,150,105,.08);--sell-bg:rgba(220,38,38,.08);
  --gold-bg:rgba(180,83,9,.08);--accent-bg:rgba(79,70,229,.08);--congress-bg:rgba(124,58,237,.08);
  --card:#ffffff;
  --radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;
  --chart-tick:#8892a4;--chart-grid:rgba(0,0,0,.05);
  --overlay-bg:rgba(245,243,238,.9);
}
[data-theme="dark"]{
  --bg:#0b0e14;--surface:#131720;--surface2:#1a2030;
  --border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.13);
  --text:#e8ecf2;--fg:#e8ecf2;--muted:#9aa3b5;--faint:#5a6880;
  --buy:#22d3a0;--sell:#f06060;--gold:#f0c040;--accent:#6c8aff;--congress:#c084fc;
  --buy-bg:rgba(34,211,160,.1);--sell-bg:rgba(240,96,96,.1);
  --gold-bg:rgba(240,192,64,.1);--accent-bg:rgba(108,138,255,.1);--congress-bg:rgba(192,132,252,.1);
  --card:#131720;
  --chart-grid:rgba(255,255,255,.04);
  --overlay-bg:rgba(11,14,20,.88);
}
body{font-family:'Syne',sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}
.app{max-width:1200px;margin:0 auto;padding:32px 20px 80px}

/* Header */
.hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:6px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.dot{width:10px;height:10px;border-radius:50%;background:var(--buy);box-shadow:0 0 12px var(--buy);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.logo-text{font-family:'DM Serif Display',serif;font-size:26px;letter-spacing:-.5px}
.logo-sub{font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:2px}
.period-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-md);font-size:12px;color:var(--muted)}
.period-badge strong{color:var(--gold);font-weight:500}

/* Nav link */
.nav-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);text-decoration:none;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-md);transition:all .15s;background:var(--surface)}
.nav-link:hover{color:var(--text);border-color:var(--border2)}

/* ── Sticky, shrink-on-scroll header (opt-in via .sticky-hdr) ──────── */
.hdr.sticky-hdr{position:sticky;top:0;z-index:50;margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px;background:var(--bg);transition:padding .25s ease,background .25s ease,box-shadow .25s ease}
.hdr.sticky-hdr.scrolled{padding-top:8px;padding-bottom:8px;background:var(--overlay-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 6px 24px rgba(0,0,0,.07);border-bottom-color:var(--border2)}
.hdr.sticky-hdr .logo-text{transition:font-size .25s ease}
.hdr.sticky-hdr.scrolled .logo-text{font-size:18px}
.hdr.sticky-hdr .logo-sub{max-height:20px;overflow:hidden;transition:opacity .2s ease,max-height .25s ease,margin .25s ease}
.hdr.sticky-hdr.scrolled .logo-sub{opacity:0;max-height:0;margin-top:0}

/* Tabs */
.tabs{display:flex;gap:4px;background:var(--surface);border-radius:10px;padding:4px;border:1px solid var(--border);flex-wrap:wrap;margin-bottom:8px;margin-top:28px}
.tab{padding:8px 16px;border-radius:7px;border:none;background:transparent;color:var(--muted);font-family:'Syne',sans-serif;font-size:13px;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.tab:hover{color:var(--text);background:var(--surface2)}
.tab.active{background:var(--accent-bg);color:var(--accent);border:1px solid rgba(108,138,255,.2)}
.tab.active.ctab{background:var(--congress-bg);color:var(--congress);border:1px solid rgba(192,132,252,.2)}
.divider{width:1px;background:var(--border2);margin:4px 0}
.tabnote{font-size:12px;color:var(--muted);padding:6px 4px 14px;letter-spacing:.02em}

/* Metrics */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px}
.mlabel{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.mval{font-family:'DM Serif Display',serif;font-size:26px;line-height:1}
.msub{font-size:12px;color:var(--muted);margin-top:6px}
.mval.buy{color:var(--buy)}.mval.sell{color:var(--sell)}.mval.gold{color:var(--gold)}.mval.acc{color:var(--accent)}.mval.cong{color:var(--congress)}

/* Signal bar */
.sbar-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 20px;margin-bottom:24px}
.sbar-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.sbar-title{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.track{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden;margin-bottom:8px}
.fill{height:100%;border-radius:4px;transition:width .8s ease}
.blabels{display:flex;justify-content:space-between;font-size:11px;color:var(--faint)}

/* Grid */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.g2-feedrow{align-items:start}
@media(max-width:680px){.g2{grid-template-columns:1fr}}

/* Expandable boxes */
.tbl-wrap{transition:max-height .35s ease}
.feed{transition:max-height .35s ease}
.expand-toggle{width:100%;margin-top:12px;padding:9px;border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'Syne',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}
.expand-toggle:hover{border-color:var(--border2);color:var(--text);background:var(--surface2)}

/* Card */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.ctitle{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.chart-box{position:relative;height:200px}

/* Table */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{color:var(--muted);font-size:11px;letter-spacing:1px;text-transform:uppercase;text-align:left;padding:0 10px 10px 0;border-bottom:1px solid var(--border);font-weight:400}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
tbody tr:last-child{border-bottom:none}
tbody tr:hover td{background:rgba(255,255,255,.025)}
tbody td{padding:10px 10px 10px 0;vertical-align:middle}
td.co{font-weight:500}
td.mono{font-family:'DM Mono',monospace;font-size:11px;color:var(--faint)}
td.buy-c{color:var(--buy);font-family:'DM Mono',monospace;font-size:12px}
td.sell-c{color:var(--sell);font-family:'DM Mono',monospace;font-size:12px}
td.dp{color:var(--buy);font-family:'DM Mono',monospace;font-size:12px;font-weight:500}
td.dn{color:var(--sell);font-family:'DM Mono',monospace;font-size:12px;font-weight:500}
.ic{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--accent-bg);color:var(--accent);font-size:11px;font-weight:500}
.pD{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;background:rgba(59,130,246,.15);color:#60a5fa}
.pR{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;background:rgba(239,68,68,.15);color:#f87171}
.pI{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;background:var(--surface2);color:var(--muted)}

/* Feed */
.feed{display:flex;flex-direction:column}
.fi{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.fi:last-child{border-bottom:none}
.fbadge{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:10px;font-weight:500;flex-shrink:0}
.fbadge.buy{background:var(--buy-bg);color:var(--buy)}
.fbadge.sell{background:var(--sell-bg);color:var(--sell)}
.fbadge.cong{background:var(--congress-bg);color:var(--congress)}
.fb{flex:1;min-width:0}
.fc{font-weight:500;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fr2{font-size:11px;color:var(--muted)}
.fright{text-align:right;flex-shrink:0}
.famt{font-family:'DM Mono',monospace;font-size:13px;font-weight:500}
.famt.buy{color:var(--buy)}.famt.sell{color:var(--sell)}
.fdate{font-size:11px;color:var(--muted)}

/* Patterns */
.pat{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}
.pat.cluster{background:var(--gold-bg);color:var(--gold);border:1px solid rgba(240,192,64,.2)}
.pat.large{background:var(--buy-bg);color:var(--buy);border:1px solid rgba(34,211,160,.2)}
.pat.warn{background:var(--sell-bg);color:var(--sell);border:1px solid rgba(240,96,96,.2)}
.pat.cong{background:var(--congress-bg);color:var(--congress);border:1px solid rgba(192,132,252,.2)}
.prow{padding:12px 0;border-bottom:1px solid var(--border)}
.prow:last-child{border-bottom:none}
.ptxt{font-size:13px;color:var(--muted);line-height:1.6;margin-top:6px}

/* AI box */
.ai-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:16px}
.ai-lbl{font-size:11px;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.ai-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite}
.ai-txt{font-size:14px;line-height:1.8}
.ai-txt p{margin-bottom:12px}.ai-txt p:last-child{margin-bottom:0}
.hl{color:var(--buy);font-weight:500}.hls{color:var(--sell);font-weight:500}.hlg{color:var(--gold);font-weight:500}.hlc{color:var(--congress);font-weight:500}

/* Chips */
.chip{padding:5px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'Syne',sans-serif;font-size:12px;cursor:pointer;transition:all .15s}
.chip:hover{border-color:var(--border2);color:var(--text)}
.chip.active{background:var(--surface2);border-color:var(--border2);color:var(--text)}

/* Congress info */
.cinfo{background:var(--congress-bg);border:1px solid rgba(192,132,252,.15);border-radius:10px;padding:14px 16px;margin-bottom:20px;font-size:12px;color:var(--muted);line-height:1.6}
.cinfo strong{color:var(--congress)}

/* Panel */
.panel{display:none}.panel.active{display:block}

/* Modal */
.mbg{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s;pointer-events:none}
.mbg.open{opacity:1;pointer-events:all}
.mbox{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-xl);width:100%;max-width:780px;max-height:88vh;overflow-y:auto;transform:translateY(14px);transition:transform .2s}
.mbg.open .mbox{transform:translateY(0)}
.mhdr{display:flex;align-items:flex-start;justify-content:space-between;padding:22px 24px 14px;gap:16px;position:sticky;top:0;background:var(--surface);border-bottom:1px solid var(--border);z-index:1}
.mtitle{font-family:'DM Serif Display',serif;font-size:21px;line-height:1.2}
.msub{font-size:12px;color:var(--muted);margin-top:4px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.mclose{width:32px;height:32px;border-radius:50%;border:1px solid var(--border2);background:transparent;color:var(--muted);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;line-height:1}
.mclose:hover{background:var(--surface2);color:var(--text)}
.mbody{padding:20px 24px 28px}
.mm{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:18px}
.mmcard{background:var(--surface2);border-radius:10px;padding:14px}
.mml{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.mmv{font-family:'DM Serif Display',serif;font-size:20px}
.mmv.buy{color:var(--buy)}.mmv.sell{color:var(--sell)}.mmv.gold{color:var(--gold)}.mmv.acc{color:var(--accent)}.mmv.cong{color:var(--congress)}
.msect{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin:18px 0 10px}
.txrow{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.txrow:last-child{border-bottom:none}
.txbadge{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:9px;font-family:'DM Mono',monospace;font-weight:500;flex-shrink:0}
.txbadge.buy{background:var(--buy-bg);color:var(--buy)}.txbadge.sell{background:var(--sell-bg);color:var(--sell)}
.txbody{flex:1;min-width:0}
.txname{font-weight:500;font-size:13px;cursor:pointer;transition:color .1s}
.txname:hover{color:var(--accent);text-decoration:underline}
.txrole{font-size:11px;color:var(--muted)}
.txright{text-align:right;flex-shrink:0}
.txvol{font-family:'DM Mono',monospace;font-size:13px;font-weight:500}
.txvol.buy{color:var(--buy)}.txvol.sell{color:var(--sell)}
.txdt{font-size:11px;color:var(--faint)}
.txpx{font-size:11px;color:var(--muted);font-family:'DM Mono',monospace}
.srclink{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--accent);text-decoration:none;margin-top:16px;padding:7px 14px;border:1px solid rgba(108,138,255,.3);border-radius:8px;transition:all .15s}
.srclink:hover{background:var(--accent-bg)}
.mdesc{font-size:13px;color:var(--muted);line-height:1.7;padding:12px 14px;background:var(--surface2);border-radius:8px;margin-bottom:4px}
.avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:15px;flex-shrink:0}

/* Source */
.srcnote{font-size:11px;color:var(--faint);text-align:center;margin-top:40px}
.srcnote a{color:var(--muted);text-decoration:none}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--faint);border-radius:2px}

/* Newsletter */
.nl-banner{background:linear-gradient(135deg,rgba(108,138,255,.12) 0%,rgba(192,132,252,.08) 100%);border:1px solid rgba(108,138,255,.2);border-radius:var(--radius-lg);padding:32px;margin-bottom:32px;text-align:center}
.nl-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:var(--accent-bg);border:1px solid rgba(108,138,255,.3);border-radius:20px;font-size:11px;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
.nl-title{font-family:'DM Serif Display',serif;font-size:22px;margin-bottom:8px;line-height:1.3}
.nl-sub{font-size:13px;color:var(--muted);margin-bottom:22px;line-height:1.6;max-width:480px;margin-left:auto;margin-right:auto}
.nl-form{display:flex;gap:8px;max-width:420px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.nl-input{flex:1;min-width:200px;padding:10px 16px;border-radius:8px;border:1px solid var(--border2);background:var(--surface);color:var(--text);font-family:'Syne',sans-serif;font-size:13px;outline:none;transition:border-color .15s}
.nl-input:focus{border-color:var(--accent)}
.nl-input::placeholder{color:var(--faint)}
.nl-btn{padding:10px 20px;border-radius:var(--radius-md);border:none;background:var(--accent);color:#fff;font-family:'Syne',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.nl-btn:hover{opacity:.85;transform:translateY(-1px)}
.nl-ok{display:none;color:var(--buy);font-size:13px;margin-top:12px;font-weight:500}
.nl-fine{font-size:11px;color:var(--faint);margin-top:12px}

/* Footer */
.footer{border-top:1px solid var(--border);margin-top:48px;padding-top:28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;margin-bottom:24px}
.footer-col-title{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:13px;color:var(--faint);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--text)}
.footer-bottom{font-size:11px;color:var(--faint);text-align:center;padding-bottom:20px}

/* Legal pages */
.legal-page{max-width:760px}
.legal-h1{font-family:'DM Serif Display',serif;font-size:32px;margin-bottom:8px;letter-spacing:-.5px}
.legal-lead{font-size:14px;color:var(--muted);margin-bottom:40px}
.legal-section{margin-bottom:32px}
.legal-section h2{font-size:15px;font-weight:600;color:var(--text);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.legal-section p,.legal-section li{font-size:13px;color:var(--muted);line-height:1.8;margin-bottom:8px}
.legal-section ul{padding-left:18px}
.legal-section a{color:var(--accent);text-decoration:none}
.legal-section a:hover{text-decoration:underline}
.placeholder{background:var(--surface2);border:1px dashed var(--border2);border-radius:6px;padding:4px 10px;display:inline-block;color:var(--gold);font-size:12px;font-family:'DM Mono',monospace}

/* Trader page */
.page-title{font-family:'DM Serif Display',serif;font-size:30px;letter-spacing:-.5px;margin-bottom:6px}
.page-sub{font-size:13px;color:var(--muted);margin-bottom:32px}
.search-bar{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.search-input{flex:1;min-width:200px;padding:9px 14px;border-radius:8px;border:1px solid var(--border2);background:var(--surface);color:var(--text);font-family:'Syne',sans-serif;font-size:13px;outline:none;transition:border-color .15s}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--faint)}
.trader-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:14px;margin-bottom:32px}
.trader-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;cursor:pointer;transition:border-color .15s,transform .15s}
.trader-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.trader-card-hdr{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.trader-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
.trader-name{font-weight:500;font-size:14px;line-height:1.3}
.trader-meta{font-size:11px;color:var(--muted);margin-top:2px}
.trader-stats{display:flex;gap:18px}
.tstat{display:flex;flex-direction:column;gap:2px}
.tstat-val{font-family:'DM Mono',monospace;font-size:15px;font-weight:500}
.tstat-lbl{font-size:10px;color:var(--faint);letter-spacing:.5px;text-transform:uppercase}
.ticker-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:12px}
.ticker-tag{padding:2px 8px;border-radius:4px;font-family:'DM Mono',monospace;font-size:11px;background:var(--surface2);color:var(--muted);border:1px solid var(--border)}
.ticker-tag.congress{background:var(--congress-bg);color:var(--congress);border-color:rgba(192,132,252,.2)}
.empty-state{text-align:center;padding:60px 20px;color:var(--faint);font-size:13px}

/* Performance placeholder */
.perf-box{background:var(--surface2);border:1px dashed var(--border2);border-radius:10px;padding:20px;text-align:center;margin-top:4px}
.soon-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;background:var(--gold-bg);color:var(--gold);border:1px solid rgba(240,192,64,.2);border-radius:20px;font-size:10px;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.perf-box p{font-size:12px;color:var(--faint);line-height:1.6}
.perf-preview{display:flex;gap:10px;justify-content:center;margin-top:14px;flex-wrap:wrap}
.perf-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 16px;text-align:center;min-width:90px}
.perf-item-val{font-family:'DM Serif Display',serif;font-size:18px;color:var(--faint)}

/* Period filter buttons */
.period-btn{padding:7px 13px;border-radius:16px;border:none;background:transparent;color:var(--muted);font-size:11px;font-weight:500;cursor:pointer;font-family:'Syne',sans-serif;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
.period-btn:hover:not(.active){color:var(--fg)}
.period-btn.active{background:var(--surface2);color:var(--fg)}

/* Performance (perf.js) */
.perf-row{padding:10px 0;border-bottom:1px solid var(--border)}
.perf-row:last-of-type{border-bottom:none}
.perf-badge{padding:2px 8px;border-radius:4px;font-family:'DM Mono',monospace;font-size:12px;font-weight:600}
.perf-badge.pos{background:rgba(34,211,160,.12);color:var(--buy)}
.perf-badge.neg{background:rgba(240,96,96,.12);color:var(--sell)}
.perf-chart-wrap{height:64px}
.perf-item-lbl{font-size:10px;color:var(--faint);margin-top:3px;text-transform:uppercase;letter-spacing:.5px}

/* Button system */
.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-md);border:none;background:var(--accent);color:#fff;font-family:'Syne',sans-serif;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;transition:opacity .15s,transform .15s}
.btn-primary:hover{opacity:.85;transform:translateY(-1px)}
.btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.18);background:transparent;color:var(--fg);font-family:'Syne',sans-serif;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;transition:border-color .15s}
.btn-secondary:hover{border-color:rgba(255,255,255,.35)}
.btn-congress{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius-md);border:1px solid rgba(192,132,252,.32);background:rgba(192,132,252,.12);color:#c084fc;font-family:'Syne',sans-serif;font-size:12px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s}
.btn-congress:hover{background:rgba(192,132,252,.24)}

/* Syne has compact line metrics — give buttons enough line-height so descenders (g, y, p, j) aren't clipped */
.tab,.chip,.period-btn,.nl-btn,.expand-toggle,.btn-primary,.btn-secondary,.btn-congress,.nav-link{line-height:1.5}

/* ─── Ticker Banner ─────────────────────────────────────────────────────────── */
.ticker-wrap{position:relative;overflow:hidden;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);height:38px;display:flex;align-items:center;margin:12px 0 0}
.ticker-wrap::before,.ticker-wrap::after{content:'';position:absolute;top:0;bottom:0;width:64px;z-index:2;pointer-events:none}
.ticker-wrap::before{left:0;background:linear-gradient(to right,var(--surface),transparent)}
.ticker-wrap::after{right:0;background:linear-gradient(to left,var(--surface),transparent)}
.ticker-track{display:flex;align-items:center;animation:ticker-scroll 55s linear infinite;white-space:nowrap}
.ticker-wrap:hover .ticker-track{animation-play-state:paused}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-item{display:inline-flex;align-items:center;gap:7px;padding:0 22px;font-size:12px;color:var(--muted);white-space:nowrap}
.t-dot{color:var(--faint)}
.t-badge{font-family:'DM Mono',monospace;font-size:10px;font-weight:600;padding:2px 6px;border-radius:3px;letter-spacing:.5px}
.t-badge.buy{background:var(--buy-bg);color:var(--buy)}
.t-badge.sell{background:var(--sell-bg);color:var(--sell)}
.t-co{color:var(--text);font-weight:500}
.t-role,.t-sep{color:var(--faint);font-size:11px}

/* ─── Hero Cinema ───────────────────────────────────────────────────────────── */
.hero-cinema{min-height:calc(100vh - 110px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px 90px;position:relative;border-bottom:1px solid rgba(255,255,255,.05)}
.hero-cinema::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -10%,var(--accent-bg) 0%,transparent 65%);pointer-events:none}
.hc-inner{position:relative;z-index:1;max-width:840px;width:100%}
.hc-live-badge{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:36px;padding:6px 16px;border:1px solid var(--border);border-radius:20px;background:var(--surface)}
.hc-live-dot{width:6px;height:6px;border-radius:50%;background:var(--buy);box-shadow:0 0 8px var(--buy);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
.hc-headline{font-family:'DM Serif Display',serif;font-size:clamp(42px,6vw,78px);font-weight:400;line-height:1.08;color:var(--fg);margin:0 0 20px;letter-spacing:-.5px}
.hc-sub{font-size:15px;color:var(--muted);line-height:1.6;margin:0 0 44px;max-width:560px;margin-left:auto;margin-right:auto}
.hc-proof{display:inline-flex;align-items:center;gap:28px;margin-bottom:12px;padding:22px 40px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:center}
.hc-proof-stat{}
.hc-proof-main{display:inline-flex;align-items:center;gap:20px}
.hc-proof-val{font-family:'DM Mono',monospace;font-size:clamp(30px,4vw,50px);font-weight:700;color:var(--buy);line-height:1}
.hc-proof-val.dim{color:var(--muted)}
.hc-proof-val.acc{color:var(--accent)}
.hc-proof-lbl{font-size:10px;color:var(--faint);letter-spacing:1.5px;text-transform:uppercase;margin-top:6px}
.hc-proof-vs{font-size:15px;color:var(--faint)}
.hc-proof-divider{width:1px;height:44px;background:var(--border);flex-shrink:0}
@media(max-width:600px){.hc-proof-divider{display:none}.hc-proof{padding:18px 24px;gap:20px}}
.hc-disclaimer{font-size:11px;color:var(--faint);margin-bottom:40px}
.hc-cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hc-cta-primary{font-size:15px;padding:13px 32px}
.hc-scroll-indicator{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);animation:hc-bounce 1.4s ease-in-out infinite alternate;opacity:.5;cursor:default}
.hc-scroll-arrow{width:18px;height:18px;border-right:1.5px solid var(--faint);border-bottom:1.5px solid var(--faint);transform:rotate(45deg)}
@keyframes hc-bounce{from{transform:translateX(-50%) translateY(0);opacity:.4}to{transform:translateX(-50%) translateY(8px);opacity:.8}}

/* ─── Section Header ─────────────────────────────────────────────────────────── */
.section-hdr{display:flex;align-items:center;gap:10px;margin:28px 0 14px}
.section-hdr-line{flex:1;height:1px;background:var(--border)}
.section-hdr-label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--faint);white-space:nowrap}

/* ─── Top Signals Section ────────────────────────────────────────────────────── */
.top-signals{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px}
@media(max-width:680px){.top-signals{grid-template-columns:1fr}}
.top-signal-card{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--buy);border-radius:var(--radius-lg);padding:18px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative;overflow:hidden}
.top-signal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:50px;background:linear-gradient(to bottom,var(--buy-bg),transparent);pointer-events:none}
.top-signal-card.sell-card{border-top-color:var(--sell)}
.top-signal-card.sell-card::before{background:linear-gradient(to bottom,var(--sell-bg),transparent)}
.top-signal-card.cong-card{border-top-color:var(--congress)}
.top-signal-card.cong-card::before{background:linear-gradient(to bottom,var(--congress-bg),transparent)}
.top-signal-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15);border-color:var(--buy)}
.top-signal-card.sell-card:hover{border-color:var(--sell)}
.top-signal-card.cong-card:hover{border-color:var(--congress)}
.tsc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.tsc-market{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:5px}
.tsc-company{font-weight:600;font-size:14px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tsc-ticker{font-family:'DM Mono',monospace;font-size:11px;color:var(--faint);margin-bottom:14px}
.tsc-amount{font-family:'DM Serif Display',serif;font-size:24px;color:var(--buy);line-height:1;margin-bottom:5px}
.tsc-amount.sell{color:var(--sell)}.tsc-amount.cong{color:var(--congress)}
.tsc-sub{font-size:11px;color:var(--muted)}

/* ─── Metric card subtle glow ─────────────────────────────────────────────────── */
.metric:has(.mval.buy) {box-shadow:0 0 0 1px var(--buy-bg)      inset,0 2px 16px var(--buy-bg)}
.metric:has(.mval.sell){box-shadow:0 0 0 1px var(--sell-bg)     inset,0 2px 16px var(--sell-bg)}
.metric:has(.mval.gold){box-shadow:0 0 0 1px var(--gold-bg)     inset,0 2px 16px var(--gold-bg)}
.metric:has(.mval.acc) {box-shadow:0 0 0 1px var(--accent-bg)   inset,0 2px 16px var(--accent-bg)}
.metric:has(.mval.cong){box-shadow:0 0 0 1px var(--congress-bg) inset,0 2px 16px var(--congress-bg)}

