:root{
  --bg:#070a12; --bg2:#0e131f; --card:#121826; --card2:#172033; --cardhi:#1c2740;
  --line:#222d44; --line2:#2c3a57; --txt:#eaf0fb; --mut:#94a2bd; --mut2:#5c6a85;
  --accent:#f59e0b; --accent2:#fbbf24; --cyan:#22d3ee;
  --g5:#16c764; --g4:#3fd07a; --g3:#9bd647; --g2:#f0b429; --g1:#f0556d; --g0:#5c6a85;
  --up:#22d37a; --down:#f0556d;
  --grad:linear-gradient(135deg,#f59e0b,#fbbf24);
  --grad-up:linear-gradient(90deg,#16c764,#3fd07a);
  --radius:16px; --shadow:0 10px 34px rgba(0,0,0,.45);
}
/* ---------- light theme ---------- */
body.light{
  --bg:#f4f6fb; --bg2:#ffffff; --card:#ffffff; --card2:#f7f9fc; --cardhi:#eef2f8;
  --line:#e4e9f1; --line2:#d3dae6; --txt:#1a2233; --mut:#5d6a7e; --mut2:#8a96ad;
}
body.light{background:radial-gradient(1200px 600px at 80% -10%,#fff3e0 0%,transparent 55%),radial-gradient(1000px 500px at -10% 0%,#e9f2ff 0%,transparent 50%),var(--bg)}
body.light .topbar{background:rgba(255,255,255,.86)}
body.light .ribbon{background:#eef2f8}
body.light .btrack,body.light .meter,body.light .bar,body.light .sbar,body.light .rsbar-track,body.light .btrend svg{background:#eef2f8}
body.light .chips{background:rgba(244,246,251,.8)}
body.light .site-footer,body.light .ribbon{background:#eef2f8}
body.light .search input,body.light .results,body.light .tbtn,body.light .subtab,body.light .chip-link{background:#fff}
*{box-sizing:border-box}
html,body{margin:0;background:
  radial-gradient(1200px 600px at 80% -10%, #1a1145 0%, transparent 55%),
  radial-gradient(1000px 500px at -10% 0%, #06283a 0%, transparent 50%),
  var(--bg);
  background-attachment:fixed;color:var(--txt);
  font-family:Inter,system-ui,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.55}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#27324a;border-radius:8px}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;
  padding:13px 22px;background:rgba(7,10,18,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{font-size:19px;font-weight:800;display:flex;align-items:center;gap:9px;white-space:nowrap;letter-spacing:-.01em}
.brand b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.search{position:relative;flex:0 1 300px;min-width:140px}
.search input{width:100%;padding:11px 16px;border-radius:12px;border:1px solid var(--line);
  background:var(--bg2);color:var(--txt);font-size:14px;outline:none;transition:.15s}
.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6d73ff22}
.results{position:absolute;top:48px;left:0;right:0;background:var(--card);border:1px solid var(--line2);
  border-radius:12px;max-height:360px;overflow:auto;box-shadow:var(--shadow)}
.results .row{display:flex;justify-content:space-between;gap:10px;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--line)}
.results .row:last-child{border-bottom:0}.results .row:hover{background:var(--card2)}
.results .sym{font-weight:700}.results .nm{color:var(--mut);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.meta{margin-left:auto;text-align:right;font-size:12px;color:var(--mut);white-space:nowrap}
.meta b{color:var(--txt)}.meta .stale{color:var(--g2);font-weight:700}

/* ---------- layout ---------- */
main{max-width:1200px;margin:0 auto;padding:26px 22px 70px}
.loading{padding:80px;text-align:center;color:var(--mut)}
.err{padding:24px;background:#2a1620;border:1px solid #5a2030;border-radius:14px;color:#ffb4c0}
.crumb{color:var(--mut);font-size:13px;margin-bottom:14px}
.crumb a:hover{color:var(--txt)}
h1{font-size:26px;margin:0 0 4px;letter-spacing:-.02em}
h2{font-size:12.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--mut);margin:30px 0 14px;font-weight:700}
.sub{color:var(--mut);margin:0 0 20px}

/* ---------- cards base ---------- */
.card,.mcard,.scard,.panel{background:linear-gradient(180deg,var(--card2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius)}

/* ---------- market strip ---------- */
.mkt{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:16px;margin-bottom:6px}
.mcard{padding:18px;position:relative;overflow:hidden}
.mcard::before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:3px;background:var(--grad);opacity:.7}
.mcard .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--mut);margin-bottom:9px;font-weight:700}
.mcard .v{font-size:26px;font-weight:800;letter-spacing:-.02em}
.mcard .v small{font-size:14px;color:var(--mut);font-weight:600}
.regime-chip{display:inline-block;padding:6px 13px;border-radius:999px;font-weight:800;font-size:13px}
.bar{height:8px;border-radius:999px;background:#0a0f1a;overflow:hidden;margin-top:10px;border:1px solid var(--line)}
.bar>i{display:block;height:100%;background:var(--grad);border-radius:999px}
.note{color:var(--mut);font-size:12px;line-height:1.5}

/* ---------- sector heatmap cards ---------- */
.secgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.seccard{padding:15px;border-radius:14px;position:relative;overflow:hidden;border:1px solid var(--line)}
.seccard .nm{font-weight:700;font-size:14.5px;display:flex;justify-content:space-between;align-items:center;gap:8px}
.seccard .rsbadge{font-weight:800;font-size:13px;padding:3px 9px;border-radius:8px;color:#04130a}

/* ---------- scanner cards ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:16px}
.scard{padding:18px;cursor:pointer;transition:.18s;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}
.scard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;opacity:.85}
.scard.bull::before{background:var(--grad-up)}.scard.bear::before{background:linear-gradient(90deg,#f0556d,#b4445a)}
.scard:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.scard .top{display:flex;justify-content:space-between;align-items:start;gap:10px}
.scard .nm{font-weight:700;font-size:15.5px;letter-spacing:-.01em}
.scard .cnt{font-weight:800;font-size:26px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.scard .desc{color:var(--mut);font-size:12.5px;flex:1}
.tag{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:4px 9px;border-radius:7px;align-self:flex-start}
.tag.bull{background:#0d2a1b;color:#43d685}.tag.bear{background:#2c1620;color:#f0859a}

/* ---------- tables ---------- */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--card)}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{padding:11px 14px;text-align:right;white-space:nowrap}
th:first-child,td:first-child,th.l,td.l{text-align:left}
thead th{position:sticky;top:0;background:var(--card2);color:var(--mut);font-weight:700;
  font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;user-select:none;border-bottom:1px solid var(--line2)}
thead th:hover{color:var(--txt)}
tbody tr{border-bottom:1px solid var(--line);cursor:pointer;transition:background .1s}
tbody tr:last-child{border-bottom:0}tbody tr:hover{background:var(--card2)}
td .sym{font-weight:700}td .nm{color:var(--mut);font-size:12px}
.score{display:inline-block;min-width:40px;padding:3px 8px;border-radius:7px;font-weight:800;text-align:center;font-size:12px}
.g5{background:var(--g5);color:#04130a}.g4{background:var(--g4);color:#04130a}.g3{background:var(--g3);color:#0b1402}
.g2{background:var(--g2);color:#241a00}.g1{background:var(--g1);color:#fff}.g0{background:#27324a;color:#aab6cf}
.up{color:var(--up)}.down{color:var(--down)}
.chip{display:inline-block;padding:3px 9px;border-radius:7px;background:var(--bg2);border:1px solid var(--line);font-size:11px;color:var(--mut)}
.bo{color:var(--g4);font-weight:800}
/* inline meter inside table */
.tmeter{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.tmeter .bar{width:62px;margin:0}.tmeter .bar>i{background:currentColor}

/* ---------- meters / rs bars / ring / spark ---------- */
.meter-row{margin:9px 0}
.meter-top{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:5px;color:var(--mut)}
.meter-val{font-weight:800;color:var(--txt)}
.meter{height:9px;border-radius:999px;background:#0a0f1a;border:1px solid var(--line);overflow:hidden}
.meter>i{display:block;height:100%;border-radius:999px}
.meter>i.g5{background:var(--grad-up)}.meter>i.g4{background:var(--g4)}.meter>i.g3{background:var(--g3)}
.meter>i.g2{background:var(--g2)}.meter>i.g1{background:var(--g1)}.meter>i.g0{background:#3a4a6a}

.rsbars{display:flex;gap:12px;align-items:flex-end}
.rsbar{flex:1;text-align:center}
.rsbar-track{height:64px;background:#0a0f1a;border:1px solid var(--line);border-radius:7px;display:flex;align-items:flex-end;overflow:hidden}
.rsbar-track>i{display:block;width:100%;border-radius:6px 6px 0 0}
.rsbar-k{font-size:10.5px;color:var(--mut);margin-top:6px;font-weight:700}
.rsbar-v{font-size:12px;font-weight:800}

.ring{position:relative;width:96px;height:96px;flex:none}
.ring svg{transform:rotate(0)}
.ring-val{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:800;font-size:24px}
.ring-val small{font-size:9px;color:var(--mut);font-weight:700;letter-spacing:.08em;text-transform:uppercase}

.spark{width:100%;border-radius:12px;overflow:hidden}
.spark svg{display:block}

/* price chart */
.chartcard{padding:16px 18px 10px}
.charthead{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px;flex-wrap:wrap}
.charthead h3{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--mut);font-weight:700}
.charttools{display:flex;gap:7px}
.tbtn{background:var(--bg2);border:1px solid var(--line);color:var(--mut);padding:6px 13px;border-radius:9px;cursor:pointer;font-size:12px;font-weight:700;transition:.12s}
.tbtn:hover{color:var(--txt);border-color:var(--line2)}
.tbtn.active{background:var(--grad);color:#1a1200;border-color:transparent}
.chart{width:100%;min-height:200px}
.chart-ctrls{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.chart-ctrls .charttools{gap:5px}
.rsi-pane{width:100%;min-height:80px;margin-top:2px}
.rsi-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--mut);font-weight:700;margin:10px 0 0}
.chartlegend{display:flex;gap:16px;font-size:11px;color:var(--mut);margin-bottom:10px;flex-wrap:wrap}
.chartlegend i.dot{display:inline-block;width:12px;height:3px;border-radius:2px;margin-right:6px;vertical-align:middle}
/* screener filter panel + custom builder */
.screenpanel{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:16px 16px 13px;margin-bottom:16px}
.fgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(148px,1fr));gap:11px 14px}
.ffield{display:flex;flex-direction:column;gap:5px;font-size:10.5px;color:var(--mut);font-weight:700}
.ffield>span{text-transform:uppercase;letter-spacing:.04em}
.ffield.chk{flex-direction:row;align-items:center;gap:8px;text-transform:none;font-size:12.5px;color:var(--txt);align-self:end;padding-bottom:7px}
.fin,.fsel{background:var(--bg);border:1px solid var(--line2);color:var(--txt);border-radius:8px;padding:7px 9px;font-size:13px;font-weight:600;font-family:inherit;width:100%}
.fin:focus,.fsel:focus{outline:none;border-color:var(--accent)}
.factions{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.fcount{font-size:12px;color:var(--mut);font-weight:700;margin-left:auto}
.build-cta{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--bg2);border:1px solid var(--line2);border-radius:14px;padding:14px 18px;margin:4px 0 18px;flex-wrap:wrap}
.build-cta b{display:block;font-size:15px;color:var(--txt);margin-bottom:3px}
.build-cta span{font-size:12.5px;color:var(--mut)}
/* stale-data banner (manifest.stale) */
.stalebar{background:#3a2a08;color:#fde68a;border-bottom:1px solid var(--accent);padding:9px 16px;font-size:13px;font-weight:600;text-align:center}
body.light .stalebar{background:#fef3c7;color:#92400e}

/* ===== Market Pulse (premium analytics, report-style, amber) ===== */
.pulse-hero{display:grid;grid-template-columns:minmax(190px,.8fr) minmax(300px,1.25fr) minmax(220px,.85fr);gap:18px;align-items:center;
  background:linear-gradient(135deg,#2a1a04 0%,#7c4a05 48%,#b9740a 100%);border:1px solid #6b4708;border-radius:16px;
  padding:24px 28px;margin-bottom:18px;color:#fff;box-shadow:0 14px 36px rgba(0,0,0,.28)}
.ph-kicker{font-size:12px;font-weight:800;letter-spacing:.12em;color:#fde68a}
.ph-date{font-size:13px;color:rgba(255,255,255,.82);margin-top:7px}
.ph-meta{font-size:11.5px;color:rgba(255,255,255,.6);margin-top:9px;line-height:1.55}
.ph-verdict{background:rgba(255,255,255,.97);color:#1a1200;border-radius:14px;padding:16px 18px;box-shadow:0 10px 26px rgba(0,0,0,.22)}
.ph-vk{font-size:10.5px;font-weight:800;letter-spacing:.08em;color:#b45309}
.ph-vmain{font-size:19px;font-weight:800;line-height:1.3;margin-top:5px;color:#1a1200}
.ph-vsub{font-size:12.5px;color:#475569;margin-top:7px;line-height:1.5}
.ph-status{display:grid;gap:12px;justify-items:end}
.ph-badge{padding:8px 16px;border-radius:999px;font-size:13px;font-weight:800;letter-spacing:.04em;color:#1a1200;box-shadow:0 6px 18px rgba(0,0,0,.28)}
.ph-reads{display:flex;gap:10px}
.ph-read{background:rgba(0,0,0,.24);border-radius:10px;padding:8px 12px;text-align:center;min-width:66px}
.ph-read-v{font-size:18px;font-weight:800;color:#fff;line-height:1}
.ph-read-k{font-size:9.5px;color:rgba(255,255,255,.72);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:4px}
.ph-read-s{font-size:10px;color:#fde68a;margin-top:2px}
@media(max-width:860px){.pulse-hero{grid-template-columns:1fr}.ph-status{justify-items:start}.ph-reads{flex-wrap:wrap}}
.pulse-fgi{padding:22px 24px}
.pulse-sec-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);display:flex;gap:8px;align-items:center;margin-bottom:16px;border-bottom:1px solid var(--line);padding-bottom:12px}
.fgi-wrap{display:grid;grid-template-columns:38% 62%;gap:24px;align-items:start}
.fgi-gauge{text-align:center}
.fgi-lead{font-size:13px;font-weight:700;color:var(--mut);margin-bottom:10px}
.fgi-cards{display:grid;gap:9px}
.fgi-card{background:var(--bg2);border:1px solid var(--line);border-left:4px solid #e5e7eb;border-radius:10px;padding:11px 14px}
.fgi-top{display:flex;justify-content:space-between;align-items:center;gap:10px}
.fgi-nm{font-size:13px;font-weight:700;color:var(--txt)}
.fgi-cg{display:flex;align-items:center;gap:8px}
.fgi-sc{font-size:17px;font-weight:800}
.fgi-ctx{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;background:var(--bg);border:1px solid var(--line2);border-radius:999px;padding:2px 7px;color:var(--mut)}
.fgi-bar{height:6px;background:var(--bg);border-radius:999px;overflow:hidden;margin-top:8px}
.fgi-bar i{display:block;height:100%;border-radius:999px}
.fgi-read{font-size:11.5px;color:var(--mut);font-style:italic;margin-top:6px;line-height:1.5}
.pulse-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0}
@media(max-width:760px){.fgi-wrap,.pulse-grid2{grid-template-columns:1fr}}

/* ===== Marketing landing page ===== */
.lp-hero{text-align:center;padding:52px 24px 38px;margin:-8px -4px 26px;
  background:radial-gradient(1100px 380px at 50% -8%, rgba(245,158,11,.16), transparent 70%);border-bottom:1px solid var(--line)}
.lp-badge{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.05em;color:var(--accent);
  background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.4);border-radius:999px;padding:6px 14px}
.lp-h1{font-size:clamp(28px,5vw,46px);font-weight:800;letter-spacing:-.02em;line-height:1.12;margin:18px auto 0;max-width:880px;color:var(--txt)}
.lp-lead{font-size:clamp(14px,2vw,17px);color:var(--mut);max-width:700px;margin:16px auto 0;line-height:1.6}
.lp-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.btn.ghost{background:transparent;border:1px solid var(--line2)}
.lp-stats{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.lp-stat{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px 20px;min-width:118px}
.lp-stat-v{font-size:17px;font-weight:800;color:var(--txt)}
.lp-stat-k{font-size:10.5px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:5px}
.lp-section{margin:32px 0}
.lp-mkt-h{margin:34px 0 12px}
.trend-list{display:grid;gap:7px}
.trend-row{display:flex;align-items:center;gap:14px;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:11px 16px;cursor:pointer;transition:.12s}
.trend-row:hover{border-color:var(--accent);transform:translateX(2px)}
.trend-rank{font-size:14px;font-weight:800;color:var(--accent);min-width:26px;text-align:center}
.trend-id{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.trend-sym{font-weight:800;font-size:14px;color:var(--txt)}
.trend-nm{font-size:11.5px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trend-day{font-weight:700;font-size:13px;min-width:62px;text-align:right}
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.feature-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:20px}
.feature-ic{font-size:26px}
.feature-card h3{margin:10px 0 6px;font-size:15px;color:var(--txt)}
.feature-card p{font-size:13px;color:var(--mut);line-height:1.6}
.cta-band{text-align:center;background:linear-gradient(135deg,#2a1a04,#7c4a05);border:1px solid #6b4708;border-radius:18px;padding:38px 24px;margin:36px 0 8px}
.cta-band h2{color:#fff;font-size:24px}
.cta-band p{color:rgba(255,255,255,.82);max-width:580px;margin:10px auto 18px;font-size:13.5px;line-height:1.6}

/* ===== Dashboard home (reference-style) ===== */
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin:4px 0 18px}
.dash-h1{font-size:24px;font-weight:800;letter-spacing:-.01em}
.dash-sub{font-size:12.5px;color:var(--mut);margin-top:5px;display:flex;align-items:center;gap:7px}
.reg-dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.dash-idx{display:flex;gap:10px;flex-wrap:wrap}
.idx-pill{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:8px 14px;display:flex;flex-direction:column;gap:2px;min-width:118px}
.ip-n{font-size:10.5px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.ip-v{font-size:16px;font-weight:800}
.ip-c{font-size:12px;font-weight:700}
.screen-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:16px}
.sdcard{background:var(--bg2);border:1px solid var(--line);border-left:3px solid var(--line2);border-radius:12px;padding:14px 16px;cursor:pointer;transition:.12s}
.sdcard:hover{border-color:var(--accent);transform:translateY(-2px)}
.sdcard.bull{border-left-color:#16c764}.sdcard.bear{border-left-color:#f0556d}.sdcard.neutral{border-left-color:#f0b429}
.sd-nm{font-size:13px;font-weight:700;color:var(--txt);line-height:1.3;min-height:34px}
.sd-count b{font-size:24px;font-weight:800}
.sd-count span{font-size:11px;color:var(--mut);margin-left:5px}
.sd-cat{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.04em;margin-top:6px}
.card-h{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--mut);margin-bottom:14px}
.card-h .seeall{font-size:11px}
.idx-head{display:flex;align-items:baseline;gap:10px}
.idx-name{font-size:14px;font-weight:800;color:var(--txt)}
.idx-val{font-size:18px;font-weight:800}
.idx-chg{font-size:13px;font-weight:700}
.heat-lbl{font-size:11px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.heat-sm{grid-template-columns:repeat(auto-fill,minmax(118px,1fr))}
.heat-sm .htile{padding:8px 10px}
.heat-sm .ht-nm{font-size:11px}
.heat-sm .ht-v{font-size:13px}
.dash-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:16px 0}
.mv-list{display:grid;gap:1px}
.mv-row{display:flex;align-items:center;gap:10px;padding:7px 6px;border-radius:7px;cursor:pointer}
.mv-row:hover{background:var(--bg)}
.mv-row .sym{font-weight:700;font-size:13px;min-width:84px}
.mv-row .nm{flex:1;font-size:11.5px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mv-v{font-weight:700;font-size:12.5px;min-width:52px;text-align:right}
.breadth-row{display:flex;justify-content:space-between;gap:10px;margin-top:12px;font-size:12px;flex-wrap:wrap}
@media(max-width:820px){.dash-3{grid-template-columns:1fr}}
/* mini sparkline in table rows */
.msp{display:inline-block;width:84px;height:26px;vertical-align:middle}
.msp svg{display:block}

/* ---------- nav + ribbon ---------- */
.nav{display:flex;gap:2px;align-items:center;overflow-x:auto;flex:1 1 auto;min-width:0;scrollbar-width:thin}
.nav::-webkit-scrollbar{height:0}
.navlink{padding:8px 13px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--mut);white-space:nowrap;border-bottom:2px solid transparent}
.navlink:hover{color:var(--txt);background:var(--card2)}
.navlink.active{color:var(--txt);border-bottom-color:var(--accent)}
.ribbon{display:flex;gap:0;overflow-x:auto;background:#0a0f1a;border-bottom:1px solid var(--line);padding:0 8px;font-size:12px;position:sticky;top:57px;z-index:40}
.tick{display:flex;align-items:center;gap:7px;padding:8px 14px;border-right:1px solid var(--line);white-space:nowrap}
.tick b{font-weight:700;color:var(--mut)}
.tick span{font-weight:700}

/* ---------- hero band ---------- */
.hero-band{padding:26px 0 12px;border-bottom:1px solid var(--line);margin-bottom:22px}
.hero-band .pill{display:inline-block;background:var(--card2);border:1px solid var(--line);color:var(--accent2);font-weight:700;font-size:11px;padding:5px 11px;border-radius:999px;margin-bottom:14px}
.hero-band h1{font-size:34px;max-width:880px;line-height:1.12}
.hero-band .lead{color:var(--mut);font-size:15px;max-width:680px;margin:10px 0 18px}
.cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;padding:11px 20px;border-radius:11px;font-weight:700;border:1px solid var(--line2);color:var(--txt);background:var(--card2)}
.btn:hover{border-color:var(--accent)}
.btn.primary{background:var(--grad);color:#1a1200;border-color:transparent}

/* ---------- section headers ---------- */
.h2row{display:flex;justify-content:space-between;align-items:baseline;margin:30px 0 12px}
.h2row h2{margin:0}
.seeall{color:var(--accent2);font-weight:700;font-size:13px}
.seeall:hover{color:var(--accent)}

/* ---------- highlights ---------- */
.hl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.hl-col{background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.hl-head{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;margin-bottom:8px}
.hl-head a{color:var(--accent2);font-size:12px;font-weight:700}
.hl-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--line);cursor:pointer}
.hl-row:last-child{border-bottom:0}
.hl-row:hover{background:var(--card2)}
.hl-row .sym{font-weight:700;min-width:78px}

/* ---------- heatmap ---------- */
.heat{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.heat-lg{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
.htile{border:1px solid var(--line);border-radius:11px;padding:13px;cursor:pointer;transition:.12s}
.htile:hover{transform:translateY(-2px);border-color:var(--accent)}
.ht-nm{font-weight:700;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ht-v{font-size:19px;font-weight:800;margin:3px 0}
.ht-sub{font-size:11px;color:var(--txt);opacity:.8}

/* ---------- scan cards (footer + neutral) ---------- */
.scard-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:auto}
.cat-tag{font-size:10.5px;color:var(--mut);font-weight:600}
.tag.neutral{background:#1d2536;color:#9fb0cf}
.scard.neutral::before{background:linear-gradient(90deg,#5c6a85,#94a2bd)}

/* ---------- category chips ---------- */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 8px;position:sticky;top:90px;z-index:30;padding:8px 0;background:rgba(7,10,18,.7);backdrop-filter:blur(8px)}
.chip-link{padding:7px 13px;border-radius:999px;border:1px solid var(--line2);color:var(--mut);font-weight:700;font-size:12.5px;background:var(--card)}
.chip-link:hover{color:var(--txt);border-color:var(--accent)}

/* ---------- sub-tabs (movers) ---------- */
.subtabs{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 16px}
.subtab{padding:9px 16px;border-radius:10px;border:1px solid var(--line2);background:var(--card2);color:var(--mut);font-weight:700;cursor:pointer}
.subtab.active{background:var(--grad);color:#1a1200;border-color:transparent}

/* ---------- analytics boards + regime banner ---------- */
.regime-banner{display:flex;justify-content:space-between;gap:20px;align-items:center;padding:18px 22px;margin:6px 0 8px;flex-wrap:wrap}
.rb-label{font-size:22px;font-weight:800}
.boards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.board{background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.board-head{display:flex;justify-content:space-between;font-weight:700;margin-bottom:8px}
.board-head a{color:var(--accent2);font-size:12px}

/* ---------- how-it-works ---------- */
.how{margin-top:30px}
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.how-step{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:16px}
.how-step b{display:block;color:var(--accent2);margin-bottom:6px}
.how-step span{color:var(--mut);font-size:13px}

/* ---------- about / disclaimer band / empty ---------- */
.prose{max-width:780px;color:var(--txt)}
.prose h3{font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--mut);margin:22px 0 8px}
.prose p,.prose li{color:#cdd6e8;line-height:1.6}
.prose .disc{color:var(--mut);font-size:12.5px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px}
.disc-band{margin:34px 0 0;padding:14px 16px;background:var(--card);border:1px solid var(--line);border-radius:12px;color:var(--mut2);font-size:11.5px}
.empty{padding:40px;text-align:center;color:var(--mut);background:var(--card);border:1px solid var(--line);border-radius:var(--radius)}

@media(max-width:900px){ .nav{order:3;width:100%} .topbar{flex-wrap:wrap} }

/* ---------- bar-chart widget cards (home highlights) ---------- */
.wgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.wcard{background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.wc-head{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;margin-bottom:10px}
.wc-head a{color:var(--accent2);font-size:11px;font-weight:700}
.barchart{display:flex;flex-direction:column;gap:7px}
.barrow{display:grid;grid-template-columns:80px 1fr 58px;align-items:center;gap:8px;cursor:pointer}
.barrow:hover .bl{color:var(--txt)}
.bl{font-weight:700;font-size:12.5px;color:var(--mut);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btrack{height:14px;background:#0a0f1a;border:1px solid var(--line);border-radius:5px;overflow:hidden}
.btrack>i{display:block;height:100%}
.btrack>i.bp{background:var(--up)}.btrack>i.bn{background:var(--down)}
.bv{font-size:12px;font-weight:700;text-align:right}
/* ---------- breadth split bars (analytics) ---------- */
.sbars{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-bottom:8px}
.sbar-wrap{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.sbar-top{display:flex;justify-content:space-between;font-size:12.5px;font-weight:700;margin-bottom:7px}
.sbar{display:flex;height:12px;border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.sbar>i{display:block;height:100%}.sbar>i.up{background:var(--up)}.sbar>i.down{background:var(--down)}
/* category anchor offset under sticky chrome */
section[id^="cat-"]{scroll-margin-top:150px}
/* ---------- rich footer ---------- */
.site-footer{margin-top:50px;border-top:1px solid var(--line);background:#0a0f1a}
.foot-grid{max-width:1200px;margin:0 auto;padding:28px 22px 12px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:22px}
.fb-logo{font-size:18px;font-weight:800}.fb-logo b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.fb-tag{color:var(--mut);font-size:13px;margin-top:6px;max-width:280px}
.foot-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mut);margin:0 0 10px}
.foot-col a,.foot-col span{display:block;color:#aeb9cf;font-size:13px;padding:4px 0}
.foot-col a:hover{color:var(--accent2)}.foot-col span{color:var(--mut2)}
.site-footer .disclaimer{max-width:1200px;margin:0 auto}
.foot-copy{max-width:1200px;margin:0 auto;padding:12px 22px 30px;color:var(--mut2);font-size:12px;border-top:1px solid var(--line)}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ---------- mood + health gauges, breadth trend ---------- */
.mood-grid{display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:14px}
.mood-card{text-align:center;padding:18px 16px}
.gauge{position:relative}
.gauge-val{font-size:30px;font-weight:800;margin-top:-4px}
.gauge-val small{display:block;font-size:11px;font-weight:800;color:var(--mut);text-transform:uppercase;letter-spacing:.07em;margin-top:2px}
.mcomps{display:flex;flex-direction:column;gap:12px}
.mcomp .mc-top{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;font-weight:700;margin-bottom:5px}
.mcomp .note{margin-top:4px}
.btrend svg{display:block;border-radius:10px;background:#0a0f1a;border:1px solid var(--line)}
.btrend-lbl{display:flex;justify-content:space-between;font-size:11.5px;color:var(--mut);margin-top:7px;font-weight:700}
@media(max-width:760px){.mood-grid{grid-template-columns:1fr}}

/* ---------- sectors & rotation ---------- */
.sec-hero{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:18px 22px;margin:6px 0 8px}
.sec-hero-nm{font-size:24px;font-weight:800;letter-spacing:-.01em;margin-top:2px}
.wlink{cursor:pointer;color:var(--accent2);font-weight:600}
.wlink:hover{color:var(--accent)}
.watch{font-size:12px}
/* RS leader medals + coiled */
.medals{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.medal-card{padding:16px;cursor:pointer;border-left:3px solid var(--accent)}
.medal-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.medal-top{display:flex;align-items:center;gap:10px;margin-bottom:5px}
.medal{font-size:22px}.medal-sym{font-weight:800;font-size:17px;flex:1}
.medal-stats{display:flex;gap:20px;margin-top:12px}
.medal-stats .k{font-size:10.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.05em}
.medal-stats b{font-size:16px;font-weight:800}
.coiled-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:760px){.coiled-grid{grid-template-columns:1fr}}
/* theme button, watchlist star, breadth heatmap cells, industry chips */
.themebtn{background:var(--card2);border:1px solid var(--line);color:var(--txt);width:38px;height:38px;border-radius:10px;cursor:pointer;font-size:15px;flex:none}
.themebtn:hover{border-color:var(--accent)}
.star{background:transparent;border:1px solid var(--line2);color:var(--accent2);padding:6px 12px;border-radius:9px;cursor:pointer;font-weight:700;font-size:12.5px}
.star:hover{border-color:var(--accent)}
.star.on{background:#f59e0b22;color:var(--accent);border-color:var(--accent)}
.hcell{display:block;padding:7px 4px;border-radius:6px;text-align:center;font-weight:800;font-size:12px;color:var(--txt)}
.indchips{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 16px}

/* ---------- stock hero + panels ---------- */
.hero{display:flex;gap:22px;align-items:center;flex-wrap:wrap;padding:20px 22px;margin-bottom:16px}
.hero .idblock{flex:1;min-width:220px}
.hero .px{font-size:30px;font-weight:800;letter-spacing:-.02em}
.hero .nm{color:var(--mut);margin-top:2px}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:16px 0}
.tile{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:13px 15px}
.tile .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--mut);font-weight:700}
.tile .v{font-size:19px;font-weight:800;margin-top:4px;letter-spacing:-.01em}
.panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.panel{padding:18px}
.panel h3{margin:0 0 14px;font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--mut);font-weight:700}
.kv{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px dashed var(--line)}
.kv:last-child{border-bottom:0}.kv .k{color:var(--mut)}.kv .v{font-weight:700}
.pill{display:inline-block;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700;margin:3px 7px 3px 0;background:var(--bg2);border:1px solid var(--line);color:var(--mut)}
.pill.ok{background:#0d2a1b;color:#43d685;border-color:#1c5132}
.pill.no{background:#241a30;color:#b59ad0;border-color:#3a2c46}
.pill.link{cursor:pointer}.pill.link:hover{border-color:var(--accent);color:var(--txt)}

.disclaimer{max-width:1200px;margin:0 auto;padding:20px 22px 44px;color:var(--mut2);font-size:11.5px;border-top:1px solid var(--line)}

@media(max-width:760px){
  .mkt{grid-template-columns:1fr 1fr}.meta{display:none}main{padding:18px 14px 56px}
  h1{font-size:22px}.hero .px{font-size:24px}
}
