/* ===== Cards / grid ===== */
.grid{display:grid;gap:12px}
.g2{grid-template-columns:repeat(2,1fr)} .g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--cardgrad);border:1px solid var(--line);border-radius:14px;padding:15px;position:relative;
  box-shadow:var(--shadow);overflow:hidden;transition:border-color .18s ease,box-shadow .18s ease}
.card:hover{border-color:rgba(232,163,61,.22);box-shadow:0 8px 26px rgba(0,0,0,.18)}
.card::before{content:"";position:absolute;top:0;inset-inline:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.28}
.card h3{font-size:11px;color:var(--muted);font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:7px;
  letter-spacing:.5px;text-transform:uppercase}
.card h3 .x{margin-inline-start:auto;font-size:10.5px;color:var(--gold);cursor:pointer;text-transform:none;font-weight:700}
.hic{display:inline-flex;align-items:center;color:var(--gold);flex-shrink:0}
.hic svg{width:15px;height:15px}
/* dashboard density: tighter view padding + smaller margins */
#v-dash .grid{margin-bottom:10px !important}
#v-dash{padding-bottom:0}

/* hero gold */
.hero{background:linear-gradient(135deg,#1c2233,#10141f);border:1px solid var(--line);
  border-radius:var(--r);padding:26px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.hero::before{content:"";position:absolute;top:0;inset-inline:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.hero::after{content:"";position:absolute;inset-inline-end:-50px;top:-50px;width:240px;height:240px;
  background:radial-gradient(circle,var(--glow),transparent 70%)}
.hero .lbl{font-size:12.5px;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:8px}
.hero .px{font-size:50px;font-weight:900;color:var(--gold);line-height:1.05;margin:8px 0;letter-spacing:-1.5px;
  text-shadow:0 0 30px var(--glow)}
.hero .chg{font-size:17px;font-weight:800}
.hero .rng{font-size:12.5px;color:var(--muted);margin-top:10px}
.up{color:var(--up)} .down{color:var(--down)} .flat{color:var(--flat)}
.bg-up{background:rgba(34,211,154,.14)} .bg-down{background:rgba(255,83,102,.14)}

.stat{background:var(--cardgrad);border:1px solid var(--line);border-radius:var(--r);padding:18px;
  position:relative;overflow:hidden;box-shadow:var(--shadow);transition:transform .18s,border-color .18s}
.stat:hover{transform:translateY(-3px);border-color:var(--gold)}
.stat::before{content:"";position:absolute;top:0;inset-inline-start:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--gold),transparent)}
.stat .v{font-size:30px;font-weight:900;margin:4px 0;letter-spacing:-.5px}
.stat .l{font-size:11.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  display:flex;align-items:center;gap:7px}
.stat .s{font-size:11px;color:var(--muted)}

/* news */
.nrow{display:flex;gap:12px;padding:13px 8px;border-radius:10px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .18s ease}
.nrow:hover{background:var(--card2)}
.nrow:last-child{border-bottom:0}
.nrow .ax{width:5px;border-radius:4px;flex-shrink:0}
.ax.up{background:var(--up)} .ax.down{background:var(--down)} .ax.flat{background:var(--flat)}
.nrow .body{flex:1;min-width:0}
.nrow .tt{font-size:14px;font-weight:600;line-height:1.45;margin-bottom:5px}
.nrow .meta{display:flex;gap:10px;font-size:11.5px;color:var(--muted);align-items:center;flex-wrap:wrap}
.pill{font-size:11px;font-weight:800;padding:2px 9px;border-radius:20px}
.sc{font-variant-numeric:tabular-nums}

/* bars */
.bar{margin-bottom:11px}
.bar .top{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:4px}
.bar .trk{height:8px;background:var(--bg2);border-radius:6px;overflow:hidden}
.bar .fil{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gold2),var(--gold))}

/* ===== HUD dashboard ===== */
.astrip{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;margin-bottom:10px}
@media(max-width:1250px){.astrip{grid-template-columns:repeat(4,1fr)}}
@media(max-width:620px){.astrip{grid-template-columns:repeat(2,1fr)}}
.acard{background:var(--cardgrad);border:1px solid var(--line);border-radius:11px;
  padding:11px 13px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow);position:relative;overflow:hidden;min-width:0}
.acard::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:3px;background:var(--gold)}
.acard .aic{font-size:15px;font-weight:800;flex-shrink:0;color:var(--gold);line-height:1;display:inline-flex;align-items:center;
  width:28px;height:28px;justify-content:center;border-radius:8px;background:rgba(226,59,59,.10)}
.acard .aic svg{width:17px;height:17px}
.acard .ab{flex:1;min-width:0}
.acard .asym{font-weight:800;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acard .apair{font-size:9.5px;color:var(--muted);white-space:nowrap}
.acard .apx{font-weight:800;font-size:13.5px;font-variant-numeric:tabular-nums;white-space:nowrap;
  display:inline-block;padding:1px 5px;border-radius:5px;transition:color .35s}
@keyframes flashup{0%{background:rgba(38,208,124,.5)}100%{background:transparent}}
@keyframes flashdn{0%{background:rgba(255,77,94,.5)}100%{background:transparent}}
.acard .apx.flashup{animation:flashup 1.1s ease-out;color:var(--up)}
.acard .apx.flashdn{animation:flashdn 1.1s ease-out;color:var(--down)}
/* big AI confidence ring */
.bigring{text-align:center;padding:6px 0 2px}
.bigring .rwrap{position:relative;width:190px;height:190px;margin:0 auto}
.bigring svg{transform:rotate(-90deg)}
.bigring .rc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.bigring .rv{font-size:52px;font-weight:900;line-height:1;color:var(--gold);text-shadow:0 0 26px var(--glow)}
.bigring .ro{font-size:12px;color:var(--muted);margin-top:2px}
.bigring .rl{font-size:13.5px;font-weight:800;color:var(--gold);margin-top:8px}
.metrics{margin-top:14px}
.metric{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.metric .mn{font-size:12.5px;color:var(--txt2);min-width:120px}
.metric .mt2{flex:1;height:6px;background:#1a2130;border-radius:5px;overflow:hidden}
.metric .mf{height:100%;background:linear-gradient(90deg,var(--gold2),var(--gold))}
.metric .mv{font-size:12px;font-weight:800;color:var(--gold);min-width:30px;text-align:end}
/* donut panel (sessions/news-dist/signals) */
.dwrap{display:flex;align-items:center;gap:16px}
.donut{position:relative;width:118px;height:118px;flex-shrink:0}
.donut svg{transform:rotate(-90deg)}
.donut .dc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut .dv{font-size:24px;font-weight:900}
.donut .dl{font-size:10px;color:var(--muted)}
.dleg{flex:1;display:flex;flex-direction:column;gap:8px}
.dleg .dr{display:flex;align-items:center;gap:8px;font-size:12.5px}
.dleg .dr .sw{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.dleg .dr .dn{flex:1;color:var(--txt2)}
.dleg .dr .dx{font-weight:800}
.sigq{margin-top:15px;padding-top:13px;border-top:1px solid var(--line)}
.sigq-l{display:flex;justify-content:space-between;font-size:10.5px;font-weight:700;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}
.sigq-l span:last-child{color:var(--txt2);font-weight:800;font-variant-numeric:tabular-nums}
.sigq-bar{height:6px;border-radius:4px;background:var(--line);overflow:hidden}
.sigq-bar i{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,#ff7a7a,var(--gold))}
/* news stats header */
.nstats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:12px}
/* modern icon-led stat card (SVG icon badge + value + label · smooth hover lift) */
.nstat{background:var(--cardgrad);border:1px solid var(--line);border-radius:13px;padding:13px 15px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;display:flex;align-items:center;gap:12px;
  transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.nstat:hover{border-color:rgba(232,163,61,.32);box-shadow:0 8px 24px rgba(0,0,0,.2);transform:translateY(-2px)}
.nsic{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--card2);border:1px solid var(--line)}
.nsic .hic svg{width:20px;height:20px}
.nsic.up .hic{color:var(--up)}.nsic.down .hic{color:var(--down)}.nsic.gold .hic{color:var(--gold)}
.nsic.up{background:rgba(38,208,124,.1);border-color:rgba(38,208,124,.26)}
.nsic.down{background:rgba(255,84,112,.1);border-color:rgba(255,84,112,.26)}
.nsic.gold{background:rgba(232,163,61,.1);border-color:rgba(232,163,61,.26)}
.nsbody{min-width:0}
.nstat .nsv{font-size:23px;font-weight:900;line-height:1.05}
.nstat .nsv.up{color:var(--up)}.nstat .nsv.down{color:var(--down)}
.nstat .nsl{font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-top:2px}
.nsxtra{font-size:11px;color:var(--muted);font-weight:600}
@media(max-width:1100px){.nstats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.nstats{grid-template-columns:repeat(2,1fr)}}
/* pro news card */
/* institutional-grade news card — restrained lift on hover (no gimmicky slide), tabular nums, precise hierarchy */
.ncard{display:flex;gap:0;background:var(--cardgrad);border:1px solid var(--line);border-radius:12px;
  margin-bottom:9px;overflow:hidden;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.ncard:hover{border-color:rgba(232,163,61,.4);box-shadow:0 7px 24px rgba(0,0,0,.22);transform:translateY(-2px)}
.ncard .nbar{width:3px;flex-shrink:0}
.nbar.up{background:var(--up)} .nbar.down{background:var(--down)} .nbar.flat{background:var(--flat)}
.ncard .nmain{flex:1;min-width:0;padding:14px 16px}
.ncard .ntop{display:flex;align-items:center;gap:8px;margin-bottom:7px;flex-wrap:wrap}
.ncard .ntt{font-size:14.5px;font-weight:700;line-height:1.5;margin-bottom:7px;letter-spacing:-.1px}
.ncard .nmeta{display:flex;gap:14px;font-size:11.5px;color:var(--muted);align-items:center;flex-wrap:wrap;font-variant-numeric:tabular-nums}
.ncard .scoredot{display:inline-flex;align-items:center;gap:5px;font-weight:800}
.scorepill{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:13.5px;font-weight:900;flex-shrink:0;align-self:center;margin:0 14px;font-variant-numeric:tabular-nums}
.scorepill.hi{background:rgba(255,77,94,.16);color:var(--down)} .scorepill.md{background:rgba(232,163,61,.16);color:var(--gold)} .scorepill.lo{background:rgba(38,208,124,.14);color:var(--up)}
/* modal */
.modal{position:fixed;inset:0;z-index:300;background:rgba(4,6,12,.8);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:24px}
.modal.on{display:flex}
.modal .mbox{max-width:560px;width:100%;background:var(--cardgrad);border:1px solid var(--gold);
  border-radius:16px;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.6);animation:fade .25s;max-height:85vh;overflow-y:auto}
.modal .mclose{float:inline-end;background:var(--card2);border:1px solid var(--line);color:var(--txt);
  width:32px;height:32px;border-radius:9px;cursor:pointer;font-size:16px}
.modal .mtt{font-size:18px;font-weight:800;line-height:1.5;margin:6px 40px 14px 0}
.modal .mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.modal .mg{background:var(--card2);border-radius:10px;padding:12px;text-align:center}
.modal .mg .mgl{font-size:10px;color:var(--muted);text-transform:uppercase}
.modal .mg .mgv{font-size:17px;font-weight:900;margin-top:3px}
.modal .minsight{background:rgba(226,59,59,.08);border-inline-start:3px solid var(--gold);border-radius:9px;
  padding:13px 15px;font-size:13.5px;line-height:1.7;color:var(--txt2);margin-bottom:10px}
/* ===== top intelligence cards (6, with sparkline) ===== */
.icards{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:12px}
.icard{background:var(--cardgrad);border:1px solid var(--line);border-radius:var(--r2);padding:12px 13px;
  position:relative;overflow:hidden;box-shadow:var(--shadow);min-height:132px;display:flex;flex-direction:column;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.icard:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(226,59,59,.18);border-color:rgba(226,59,59,.45)}
.icard::before{content:"";position:absolute;top:0;inset-inline:0;height:2px;background:var(--gold);opacity:.6}
.icard .ih{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.4px;color:var(--muted)}
.icard .ih .ico{display:inline-flex}
.icard .ih .ibg{display:inline-grid;place-items:center;width:27px;height:27px;border-radius:8px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;box-shadow:0 4px 11px rgba(226,59,59,.30)}
.icard .ih .ibg svg{width:15px;height:15px}
.icard .igauge{margin-top:auto;display:flex;justify-content:center;align-items:flex-end;padding-top:4px}
.icard .igauge .sring,.icard .igauge .rgauge{display:block}
.icard .iv{font-size:21px;font-weight:900;margin:5px 0 1px;letter-spacing:-.5px;line-height:1}
.icard .is{font-size:11px;font-weight:700}
@media(max-width:1300px){.icards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.icards{grid-template-columns:repeat(2,1fr)}}
/* AI market intelligence panel */
/* ===== AI Intelligence Center (reference design) ===== */
.airow{display:grid;grid-template-columns:300px 1fr;gap:10px;margin-bottom:10px;align-items:stretch}
.airow .aicard{margin:0}
.sesscard{display:flex;flex-direction:column}
.sesscard #dFeedSess{flex:1;display:flex;flex-direction:column;justify-content:center}
@media(max-width:1150px){.airow{grid-template-columns:1fr}}
.aicenter{display:grid;grid-template-columns:minmax(170px,280px) 1fr;gap:8px 28px;align-items:center}
.aicenter .ai-art{align-self:center;display:flex;justify-content:center}
.aicenter .ai-art .ai-svg{width:100%;max-width:212px;height:auto;display:block}
.aicenter .ai-rows{align-self:center}
/* metric rows as separate cards + red accent bar (dark reference) */
.ai-row{display:flex;align-items:center;gap:12px;padding:9px 15px 9px 12px;margin-bottom:7px;
  background:var(--card2);border:1px solid var(--line);border-radius:12px;position:relative;transition:.15s}
.ai-row:last-child{margin-bottom:0}
.ai-row:hover{border-color:rgba(226,59,59,.4)}
.ai-row::after{content:"";position:absolute;inset-inline-end:7px;top:10px;bottom:10px;width:3px;border-radius:3px;background:var(--gold);opacity:.85}
.ai-row .ai-ic{width:39px;height:39px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  background:rgba(226,59,59,.09);border:1px solid var(--line);color:#e23b3b}
.ai-row .ai-ic svg{width:18px;height:18px}
.ai-row .ai-lbl{flex:1;min-width:0}
.ai-row .ai-lbl .ai-t{font-weight:800;font-size:13px;color:var(--txt);line-height:1.2;text-transform:uppercase;letter-spacing:.4px}
.ai-row .ai-lbl .ai-s{font-size:10.5px;color:var(--muted);margin-top:2px}
.ai-row .ai-val{font-weight:900;font-size:18px;color:#e23b3b;letter-spacing:.5px;font-variant-numeric:tabular-nums;white-space:nowrap;margin-inline-end:11px}
/* glowing CTA with sub-label */
.aicenter .ai-cta{grid-column:1 / -1;display:flex;align-items:center;gap:14px;width:100%;margin-top:9px;
  padding:11px 22px;border:1.5px solid rgba(226,59,59,.45);border-radius:14px;cursor:pointer;color:#e23b3b;font-family:inherit;transition:.15s;
  background:linear-gradient(180deg,rgba(226,59,59,.10),rgba(226,59,59,.03));box-shadow:0 0 24px rgba(226,59,59,.10)}
.aicenter .ai-cta:hover{border-color:#e23b3b;background:linear-gradient(180deg,rgba(226,59,59,.17),rgba(226,59,59,.05));box-shadow:0 0 34px rgba(226,59,59,.2)}
.aicenter .ai-cta .ai-chip{width:26px;height:26px;flex-shrink:0}
.aicenter .ai-cta .ai-cta-txt{flex:1;text-align:center;line-height:1.3}
.aicenter .ai-cta .ai-cta-t{display:block;font-weight:900;font-size:16px;letter-spacing:.5px;text-transform:uppercase}
.aicenter .ai-cta .ai-cta-s{display:block;font-size:11px;color:var(--muted);font-weight:600;margin-top:2px}
.aicenter .ai-cta .ai-arr{font-size:19px;font-weight:900;flex-shrink:0}
/* header LIVE badge */
.aihead{display:flex;align-items:center;gap:8px}
.aihead .ai-live{margin-inline-start:auto;display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:800;letter-spacing:.6px;
  color:#e23b3b;border:1px solid rgba(226,59,59,.4);border-radius:20px;padding:3px 10px}
.aihead .ai-live i{width:6px;height:6px;border-radius:50%;background:#e23b3b;box-shadow:0 0 6px #e23b3b;animation:lvp 2s infinite}
@media(max-width:720px){.aicenter{grid-template-columns:1fr}.aicenter .ai-art .ai-svg{max-width:210px}}
/* AI artwork animation — alive neural core */
.ai-svg .ai-rot{transform-box:fill-box;transform-origin:center;animation:airot 26s linear infinite}
.ai-svg .ai-orbit{transform-box:fill-box;transform-origin:center;animation:airot 30s linear infinite}
@keyframes airot{to{transform:rotate(360deg)}}
.ai-svg .ai-pulse{transform-box:fill-box;transform-origin:center;animation:aipulse 3.2s ease-in-out infinite}
@keyframes aipulse{0%,100%{opacity:.12;transform:scale(.9)}50%{opacity:.42;transform:scale(1.08)}}
.ai-svg .ai-nodes circle{animation:ainode 2.6s ease-in-out infinite}
.ai-svg .ai-nodes circle:nth-child(2n){animation-delay:.9s}
.ai-svg .ai-nodes circle:nth-child(3n){animation-delay:1.5s}
@keyframes ainode{0%,100%{opacity:.45}50%{opacity:1}}
/* ── A11Y: comprehensive reduced-motion + keyboard focus ring ── */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.run{animation:none!important}}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible,[role=button]:focus-visible,.nav .it:focus-visible,.it:focus-visible,.chip:focus-visible,.pcw:focus-visible,.pctool:focus-visible,.pctf button:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:6px}
/* trading-safety: live feed stale/down → LIVE badges stop pulsing green (never mislead a trader) + reconnecting pill */
body.feed-stale .chlive i,body.feed-stale .chlive2 i,body.feed-stale .ai-live i,body.feed-stale .pclive2 i,body.feed-stale .live .d,body.feed-stale .gdot{background:#f5a623!important;box-shadow:none!important;animation:none!important}
body.feed-stale::after{content:attr(data-stale-msg);position:fixed;bottom:14px;left:50%;transform:translateX(-50%);background:#f5a623;color:#1a1205;font-size:12px;font-weight:800;padding:7px 15px;border-radius:20px;z-index:300;box-shadow:0 5px 18px rgba(0,0,0,.32);white-space:nowrap;pointer-events:none}
/* upcoming events mini */
.evrow{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--line);font-size:12px}
.evrow:last-child{border-bottom:0}
.evrow .et{font-variant-numeric:tabular-nums;color:var(--txt2);width:42px;font-weight:700}
.evrow .ecur{font-weight:800;color:var(--gold);width:34px}
.evrow .een{flex:1;min-width:0;color:var(--txt2);line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.evrow .eimp{font-size:9px;font-weight:800;padding:2px 7px;border-radius:5px}
.eimp.h{background:rgba(255,77,94,.18);color:var(--down)} .eimp.m{background:rgba(245,158,11,.18);color:#f59e0b} .eimp.l{background:rgba(38,208,124,.15);color:var(--up)}
.evday{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:9px 0 3px;padding-top:9px;border-top:1px dashed var(--line)}
.evday:first-child{border-top:none;padding-top:1px;margin-top:0}
/* ===== terminal: right feed + bottom alerts ===== */
.dashwrap{display:grid;grid-template-columns:1fr 310px;gap:10px;align-items:start}
.dashmain{min-width:0}
.feedcol{position:sticky;top:90px}
@media(max-width:1200px){.dashwrap{grid-template-columns:1fr}.feedcol{position:static}}
@media(max-width:760px){#v-dash .grid[style*="grid-template-columns"]{grid-template-columns:1fr !important}}
.feedcard{background:var(--cardgrad);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);overflow:hidden;margin-bottom:16px}
.feedcard .fh{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px;
  font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--gold)}
.feedcard .fh .live{margin-inline-start:auto;display:flex;align-items:center;gap:5px;color:var(--up);font-size:10px}
.feedcard .fh .live .d{width:6px;height:6px;border-radius:50%;background:var(--up);animation:pulse2 1.6s infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.3}}
.feedcard .ftabs{display:flex;gap:6px;padding:10px 14px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.feedcard .fton{font:inherit;font-size:10.5px;font-weight:700;padding:5px 12px;border-radius:20px;border:1px solid var(--line);
  background:transparent;color:var(--muted);cursor:pointer;transition:.15s;white-space:nowrap}
.feedcard .fton:hover{color:var(--txt);border-color:var(--gold)}
.feedcard .fton.on{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;border-color:transparent;
  box-shadow:0 3px 9px rgba(226,59,59,.28)}
.feeditem{padding:13px 16px;border-bottom:1px solid var(--line);display:flex;gap:11px;cursor:pointer;transition:background .15s}
.feeditem:hover{background:var(--card2)} .feeditem:last-child{border-bottom:0}
.feeditem .fi{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}
.feeditem .fi svg{width:18px;height:18px}
.fi.critical,.fi.high{background:rgba(255,77,94,.15);color:#ff4d5e} .fi.medium{background:rgba(245,158,11,.15);color:#f59e0b} .fi.low{background:rgba(38,208,124,.13);color:#12a05f}
.feeditem .fb{flex:1;min-width:0}
.feeditem .ftag{font-size:9px;font-weight:800;text-transform:uppercase;padding:2px 7px;border-radius:5px;letter-spacing:.3px}
.ftag.critical,.ftag.high{background:rgba(255,77,94,.18);color:var(--down)} .ftag.medium{background:rgba(226,59,59,.18);color:var(--gold)} .ftag.low{background:rgba(38,208,124,.15);color:var(--up)}
.feeditem .ftt{font-size:12.5px;font-weight:600;line-height:1.45;margin:5px 0 4px}
.feeditem .fm{font-size:10.5px;color:var(--muted);display:flex;justify-content:space-between}
.feedcard .fv{padding:11px;text-align:center;font-size:11.5px;font-weight:700;color:var(--gold);cursor:pointer;border-top:1px solid var(--line)}
.sdot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--muted);margin-inline-end:6px;vertical-align:middle}
.sdot.on{background:var(--up);box-shadow:0 0 6px var(--up);animation:pulse2 1.6s infinite}
#dFeedSess .sess{padding:9px 0;border-bottom:1px solid var(--line)}
#dFeedSess .sess:last-child{border-bottom:none;padding-bottom:0}
#dFeedSess .sess.on{position:relative}
#dFeedSess .sess-r{display:flex;align-items:center;justify-content:space-between;gap:8px}
#dFeedSess .sess-n{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--txt)}
#dFeedSess .sess-b{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}
#dFeedSess .sess-b.up{color:var(--up)} #dFeedSess .sess-b.flat{color:var(--muted)}
#dFeedSess .sess-m{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:9.5px;color:var(--muted);margin:5px 0 6px;font-variant-numeric:tabular-nums}
#dFeedSess .sess-m b{color:var(--txt2);font-weight:800}
#dFeedSess .sess-bar{height:4px;border-radius:3px;background:var(--line);overflow:hidden}
#dFeedSess .sess-bar i{display:block;height:100%;border-radius:3px;background:var(--up);transition:width .6s ease}
/* volatility gauge */
.volg{text-align:center;padding:6px 0}
.volg .vlbl{font-size:22px;font-weight:900;margin-bottom:4px}

/* ════ DASHBOARD THEME (user request) — pure-black canvas + translucent "half-black" glass boxes.
   Scoped to #v-dash + dark mode only (rest of the app + light theme untouched). Every dashboard box
   uses var(--cardgrad)+var(--line), so overriding those tokens re-tints all of them at once. ════ */
html:not([data-theme="light"]) #v-dash{
  background:#000;                        /* background = black 100% */
  --cardgrad:rgba(255,255,255,.045);      /* box = faint translucent dark on pure black (a true rgba(0,0,0,.5) would be invisible on black) */
  --card:rgba(255,255,255,.045);
  --card2:rgba(255,255,255,.075);         /* inner fills / hovers stay visible */
  --line:rgba(255,255,255,.09);           /* faint hairline so boxes are clearly outlined */
}
html:not([data-theme="light"]) #v-dash .card,
html:not([data-theme="light"]) #v-dash .icard,
html:not([data-theme="light"]) #v-dash .feedcard,
html:not([data-theme="light"]) #v-dash .stat,
html:not([data-theme="light"]) #v-dash .nstat{
  box-shadow:0 10px 30px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.05);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
}

/* ════ KPI CARDS — authoritative dashboard layout (id-scoped → beats charts-page.css's .icard row
   sizing where .ic-r took 48% + .iv ellipsis-clipped the gold price to "...,325.80"). Value NEVER clips. ════ */
#v-dash .icard{flex-direction:row;align-items:stretch;gap:10px;min-height:118px}
#v-dash .icard .ic-l{display:flex;flex-direction:column;flex:1 1 auto;min-width:0}
#v-dash .icard .ic-r{display:flex;align-items:center;justify-content:flex-end;flex:0 0 auto;width:auto;max-width:108px;overflow:visible}
#v-dash .icard .iv{font-size:20px;white-space:nowrap;overflow:visible;text-overflow:clip;font-variant-numeric:tabular-nums}
#v-dash .icard .ih .ihl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
#v-dash .icard .kspark{width:104px;height:46px;display:block}
#v-dash .icard .igauge{margin:0}
#v-dash .icard .is{white-space:nowrap;overflow:visible;text-overflow:clip}   /* sub-line must not ellipsis-clip the real change figure (charts-page.css clipped it) */
/* ════ chart/map row: bounded chart height + don't stretch the shorter card → kills the blank gap below the world map ════ */
#v-dash .dashmain>.grid:not(.g3){align-items:start}
/* signals card: grow the list so the CTA anchors to the bottom (removes the ~243px dead space when the calendar is taller) */
#v-dash #dSig{display:flex;flex-direction:column;height:100%}
#v-dash #dSig .siglist{flex:1 1 auto}
/* ════ CHART CARD — was hardcoded navy #0B1728 + navy chrome (#1B2A3C / #0a1422 / #7F8CA8) so it stood out as
   "not black like the others". Re-tint to match the black glass boxes (id-scoped → beats .card.chcard). ════ */
html:not([data-theme="light"]) #v-dash .chcard{
  background:rgba(255,255,255,.045);
  border-color:rgba(255,255,255,.09);
  --c-bd:rgba(255,255,255,.10);   /* navy border var → neutral hairline (chhead/chdiv/chtf/chset all follow) */
  --c-2:#9298a6;                  /* bluish muted text → neutral grey */
}
html:not([data-theme="light"]) #v-dash .chcard .chico,
html:not([data-theme="light"]) #v-dash .chcard .chtf,
html:not([data-theme="light"]) #v-dash .chcard .chset{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.10)}
html:not([data-theme="light"]) #v-dash .chcard .chtip{background:rgba(12,12,16,.96);border-color:rgba(255,255,255,.12)}