/* ===== Charts page (watchlist + TradingView) ===== */
.chpage{max-width:1280px;margin:0 auto}
.chwatch{display:flex;gap:9px;overflow-x:auto;padding-bottom:10px;margin-bottom:12px;scrollbar-width:thin}
.chw{display:flex;align-items:center;gap:9px;padding:8px 13px;background:var(--cardgrad);border:1px solid var(--line);border-radius:11px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:.14s}
.chw:hover{border-color:rgba(226,59,59,.4);transform:translateY(-1px)}
.chw.on{border-color:var(--gold);background:linear-gradient(135deg,rgba(226,59,59,.12),rgba(226,59,59,.04))}
.chw-ic{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:12px;font-weight:800;color:var(--gold);background:rgba(226,59,59,.10);flex-shrink:0}
.chw-ic svg{width:15px;height:15px}
.chw-b{display:flex;flex-direction:column;line-height:1.25}
.chw-s{font-size:12px;font-weight:800}
.chw-p{font-size:11px;color:var(--txt2);font-variant-numeric:tabular-nums}
.chw-c{font-size:11px;font-weight:800;font-variant-numeric:tabular-nums}
.chw-c.up{color:var(--up)} .chw-c.down{color:var(--down)}
.chcard2{padding:0;overflow:hidden}
.chcard2-h{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line)}
.chcard2-t{font-size:16px;font-weight:800}
.chlive2{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--up)}
.chlive2 i{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 6px var(--up);animation:lvp 2s infinite}

/* ════════════════════════════════════════════════════════════════
   VOLURR v2 — reference redesign
   ════════════════════════════════════════════════════════════════ */
/* ---- Block A: shell (sidebar density · brand · user card · right rail) ---- */
/* desktop-only sidebar offset — on mobile the sidebar is off-canvas (see @media≤900) */
@media(min-width:901px){.side{width:218px}.main{margin-inline-start:218px}}
.nav{padding:7px 9px}
.nav .it{padding:8px 11px;font-size:13px;gap:11px;margin-bottom:1px}
.nav .it .badge{padding:1px 7px;font-size:9.5px}
.nav .it .badge.vip{background:linear-gradient(135deg,var(--gold),var(--gold2))}
.brand .nm{font-size:18px;direction:ltr}
.brand .sub{font-size:8px;letter-spacing:1.3px;margin-top:5px}
/* collapse toggle: mirror the chevron in RTL so it points the correct way */
html[dir="rtl"] .collapse-btn{transform:scaleX(-1)}
html[dir="rtl"] .collapse-btn:hover{transform:scaleX(-1) scale(1.12)}
html[dir="rtl"] body.sidecollapsed .collapse-btn{transform:scaleX(-1) rotate(180deg)}
html[dir="rtl"] body.sidecollapsed .collapse-btn:hover{transform:scaleX(-1) rotate(180deg) scale(1.12)}
.sideuser .su-av{position:relative}
.sideuser .su-av .su-on{position:absolute;inset-inline-end:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;
  background:var(--up);border:2px solid var(--card);box-shadow:0 0 6px var(--up)}
.sideuser .su-rl{font-size:10px;color:var(--muted);font-weight:600;margin-top:2px}
.sideuser .su-vip{display:inline-block;margin-top:5px;font-size:8.5px;font-weight:800;letter-spacing:.5px;
  color:#fff;background:linear-gradient(135deg,var(--gold),var(--gold2));padding:2px 8px;border-radius:6px;
  box-shadow:0 2px 8px rgba(226,59,59,.3)}
body.sidecollapsed .sideuser .su-vip{display:none}
/* right quick-access rail removed (#railr deleted) — .main now fills the full width */
/* coming-soon placeholder (sidebar items still being built) */
.csoon{max-width:460px;margin:7vh auto;text-align:center;padding:30px;animation:fade .3s}
.csoon-ic{width:88px;height:88px;border-radius:24px;margin:0 auto 22px;display:grid;place-items:center;
  background:linear-gradient(145deg,rgba(226,59,59,.16),rgba(226,59,59,.03));border:1px solid rgba(226,59,59,.28);
  color:var(--gold);box-shadow:0 10px 30px rgba(226,59,59,.14)}
.csoon-ic svg{width:42px;height:42px}
.csoon-t{font-size:24px;font-weight:900;margin-bottom:10px}
.csoon-tag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  color:var(--gold);background:var(--glow);border:1px solid rgba(226,59,59,.3);padding:5px 14px;border-radius:20px;margin-bottom:14px}
.csoon-d{color:var(--muted);font-size:14px;line-height:1.7}

/* ---- Block B: ticker clock · header · action icons · popovers ---- */
.tkclock{position:absolute;inset-inline-end:0;top:0;height:34px;display:flex;align-items:center;gap:10px;
  padding:0 18px;background:linear-gradient(90deg,transparent,#141a26 18%,#141a26);border-inline-start:1px solid var(--line)}
html[data-theme="light"] .tkclock{background:linear-gradient(90deg,transparent,#f3f5f9 18%,#f3f5f9)}
.tkclock .tkt{font-variant-numeric:tabular-nums;font-weight:800;font-size:13px;color:var(--txt);letter-spacing:.5px}
.tkclock .tkd{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap}
@media(max-width:680px){.tkclock .tkd{display:none}}
.ticker .run{gap:24px;padding-inline-end:160px}
.tki{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.tki b{color:var(--txt2);font-weight:800}
.tki .tkp{font-variant-numeric:tabular-nums;color:var(--txt);font-weight:700}
.tki .tksp{vertical-align:middle;opacity:.92}
/* header (topbar) */
.topbar{gap:16px}
.hdrL{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.hdr-title{font-size:19px;font-weight:800;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:8px}
.hdr-title .crown{font-size:16px}
.hdr-sub{font-size:11.5px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.hdr-status{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;line-height:1.2}
.hdr-mkt,.hdr-next{display:flex;align-items:center;gap:6px;font-size:12px;white-space:nowrap}
.hdr-status .hsl{color:var(--muted);font-weight:600}
.hdr-status .hsv{font-weight:800;color:var(--txt);font-variant-numeric:tabular-nums}
.hdr-mkt .dot{width:8px;height:8px;border-radius:50%}
@media(max-width:1050px){.hdr-status{display:none}}
.hdr-acts{display:flex;align-items:center;gap:6px;flex-shrink:0}
.ha{position:relative;width:38px;height:38px;border-radius:11px;border:1px solid var(--line);background:var(--card);
  color:var(--txt2);display:grid;place-items:center;cursor:pointer;transition:.14s;font-family:inherit;flex-shrink:0}
.ha svg{width:18px;height:18px}
.ha:hover{color:var(--gold);border-color:var(--gold);background:var(--glow)}
.ha-badge{position:absolute;top:-5px;inset-inline-end:-5px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;
  background:var(--gold);color:#fff;font-size:9.5px;font-weight:800;display:grid;place-items:center;box-shadow:0 2px 6px rgba(226,59,59,.4)}
.ha-lang{width:auto;padding:0 11px;gap:6px;display:flex;align-items:center}
.ha-lang b{font-size:12.5px;font-weight:800}
.ha-lang .caret{font-size:10px;opacity:.7}
@media(max-width:560px){#btnMail,#btnSearch{display:none}}
/* popovers (lang menu + bell) */
.popover{position:absolute;top:60px;inset-inline-end:20px;min-width:200px;background:var(--cardgrad);
  border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.45);z-index:80;
  display:none;overflow:hidden;animation:fade .18s}
.popover.on{display:block}
.langmenu .lm{display:flex;align-items:center;gap:10px;padding:11px 16px;cursor:pointer;font-size:13.5px;font-weight:600;transition:.12s}
.langmenu .lm:hover{background:var(--card2)}
.langmenu .lm.on{color:var(--gold);background:var(--glow)}
.langmenu .lm .fl{font-size:16px}
.langmenu .lm .ck{margin-inline-start:auto;color:var(--gold)}
.bellmenu{min-width:300px;max-width:340px}
.bellmenu .bm-h{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:space-between}
.bellmenu .bm-h a{color:var(--gold);font-size:11.5px;font-weight:700;cursor:pointer}
.bellmenu .bm-list{max-height:340px;overflow-y:auto}
.bellmenu .bm-i{display:flex;gap:11px;padding:11px 16px;border-bottom:1px solid var(--line);cursor:pointer;transition:.12s}
.bellmenu .bm-i:last-child{border-bottom:0}
.bellmenu .bm-i:hover{background:var(--card2)}
.bellmenu .bm-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}
.bellmenu .bm-ic svg{width:16px;height:16px}
.bellmenu .bm-b{flex:1;min-width:0}
.bellmenu .bm-t{font-size:12.5px;font-weight:600;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bellmenu .bm-m{font-size:10.5px;color:var(--muted);margin-top:3px}
/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--card2);
  border:1px solid var(--gold);color:var(--txt);padding:12px 22px;border-radius:12px;font-size:13.5px;font-weight:600;
  box-shadow:0 12px 34px rgba(0,0,0,.5);z-index:400;opacity:0;transition:.25s;pointer-events:none}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- Block C: KPI cards (text-left · visual-right) ---- */
.icards{gap:11px}
.icard{flex-direction:row;align-items:stretch;min-height:116px;gap:10px;padding:13px 15px}
.icard .ic-l{display:flex;flex-direction:column;min-width:0;flex:1 1 auto;z-index:2}
.icard .ic-r{display:flex;align-items:center;justify-content:flex-end;flex:0 0 auto;width:48%;max-width:128px;min-width:0;overflow:hidden}
.icard .ih{display:flex;align-items:center;gap:7px;font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin-bottom:auto}
.icard .ih .ihl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.icard .iv{font-size:22px;font-weight:900;letter-spacing:-.5px;line-height:1.05;margin:7px 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.icard .is{font-size:10.5px;font-weight:700;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.icard .is .up{color:var(--up)} .icard .is .down{color:var(--down)}
.kspark{width:100%;height:58px;display:block}
.icard .ic-r .igauge{margin:0}
@media(max-width:1300px){.icards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.icards{grid-template-columns:repeat(2,1fr)}.icard .ic-r{max-width:92px}}

/* ---- Block D: global AI map (big numbers + % per region) ---- */
.gmap .node{transition:opacity .25s}
.gmap .node .rc{font-size:15px;font-weight:900;line-height:1.1;margin-top:2px}
.gmap .node .rchg{font-size:10px;font-weight:800;margin-top:1px;text-shadow:0 1px 3px #000}
.gmap .node .rchg.up{color:var(--up)} .gmap .node .rchg.down{color:var(--down)}
html[data-theme="light"] .gmap .node .rchg{text-shadow:0 1px 3px rgba(255,255,255,.9)}
.gmap .node.dim{opacity:.28;filter:saturate(.5)}
.gmap .node.hl .pin{transform:scale(1.5)}
.mapsel{margin-inline-start:auto;background:var(--card2);border:1px solid var(--line);color:var(--txt2);
  font-family:inherit;font-size:11px;font-weight:700;padding:5px 9px;border-radius:8px;cursor:pointer;text-transform:none;letter-spacing:0}
.mapsel:focus{outline:none;border-color:var(--gold)}
#dMap .mstats .mstc{font-size:10.5px;font-weight:800;margin-top:3px}
#dMap .mstats .mstc.up{color:var(--up)} #dMap .mstats .mstc.down{color:var(--down)}

/* ---- Block E: heat 9 · signals donut · calendar · sessions ---- */
.g4dash{grid-template-columns:1fr 1.3fr 1fr 1.15fr}
@media(max-width:1250px){.g4dash{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.g4dash{grid-template-columns:1fr}}
/* compact AI center for the narrow dashboard column (minmax(0,1fr) lets it shrink to fit) */
.g4dash .aicenter{grid-template-columns:48px minmax(0,1fr);gap:6px 9px}
.g4dash .aicenter .ai-art .ai-svg{max-width:48px}
.g4dash .ai-rows{min-width:0}
.g4dash .ai-row{padding:6px 8px;gap:7px;margin-bottom:5px}
.g4dash .ai-row .ai-ic{width:26px;height:26px}
.g4dash .ai-row .ai-ic svg{width:13px;height:13px}
.g4dash .ai-row .ai-lbl{min-width:0}
.g4dash .ai-row .ai-t{font-size:9.5px;line-height:1.15}
.g4dash .ai-row .ai-s{display:none}
.g4dash .ai-row .ai-val{font-size:11.5px;margin-inline-end:4px}
.g4dash .ai-row::after{inset-inline-end:4px}
.g4dash .aicenter .ai-cta{margin-top:7px;padding:9px 12px;gap:8px}
.g4dash .aicenter .ai-cta .ai-cta-t{font-size:11.5px}
.g4dash .aicenter .ai-cta .ai-cta-s{display:none}
.g4dash .aicenter .ai-cta .ai-chip{width:20px;height:20px}
/* heat tiles + price */
.htile{padding:11px 8px}
.htile .hs{font-size:12.5px;color:var(--gold)}
.htile .hc{font-size:12.5px;margin-top:3px}
.htile .hp{font-size:11px;font-weight:700;color:var(--txt2);margin-top:3px;font-variant-numeric:tabular-nums}
.htile.pos .hp,.htile.neg .hp{color:var(--txt)}
/* signals: donut value + view-all button */
.donut .dv{font-size:26px}
.sigbtn{margin-top:13px;text-align:center;font-size:12px;font-weight:800;color:var(--gold);cursor:pointer;padding-top:11px;border-top:1px solid var(--line)}
.sigbtn:hover{opacity:.82}
/* calendar: flag + countdown */
.evrow .ecur{display:inline-flex;align-items:center;gap:4px}
.evrow .efl{font-size:13px;line-height:1}
.evrow .ecd{font-size:10px;font-weight:800;color:var(--gold);background:var(--glow);padding:2px 6px;border-radius:6px;flex-shrink:0;white-space:nowrap}
/* market sessions: mini map + OPEN/CLOSED rows */
#dSessMap{padding:12px 14px 2px}
.sessmap{position:relative;width:100%;height:94px;border-radius:10px;overflow:hidden;
  background:radial-gradient(ellipse at center,#0d1830,#080b14)}
html[data-theme="light"] .sessmap{background:radial-gradient(ellipse at center,#eef2f8,#e2e7ef)}
.sessmap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.45;filter:brightness(1.1) saturate(1.2)}
html[data-theme="light"] .sessmap img{opacity:.3}
.sessmap .smp{position:absolute;width:9px;height:9px;border-radius:50%;transform:translate(-50%,-50%);
  background:var(--muted);box-shadow:0 0 0 3px rgba(122,131,154,.25)}
.sessmap .smp.on{background:var(--up);box-shadow:0 0 0 3px rgba(38,208,124,.3),0 0 10px var(--up);animation:pulse2 1.8s infinite}
.sessr{display:flex;align-items:center;gap:9px;padding:9px 14px;border-bottom:1px solid var(--line)}
.sessr:last-of-type{border-bottom:0}
.sessr-n{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;flex:1;min-width:0;color:var(--txt)}
.sessr-h{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.sessr-b{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;padding:3px 8px;border-radius:6px;flex-shrink:0}
.sessr-b.open{color:var(--up);background:rgba(38,208,124,.13)}
.sessr-b.closed{color:var(--muted);background:var(--card2)}

/* ---- Block F: feed tags + alert-bar "view all" button ---- */
.fi.tg-urgent{background:rgba(255,77,94,.15);color:#ff4d5e}
.fi.tg-important{background:rgba(245,158,11,.15);color:#f59e0b}
.fi.tg-market{background:rgba(59,130,246,.15);color:#3b82f6}
.fi.tg-crypto{background:rgba(226,59,59,.13);color:var(--gold)}
.ftag.tg-urgent{background:rgba(255,77,94,.18);color:var(--down)}
.ftag.tg-important{background:rgba(245,158,11,.18);color:#f59e0b}
.ftag.tg-market{background:rgba(59,130,246,.16);color:#3b82f6}
.ftag.tg-crypto{background:rgba(226,59,59,.16);color:var(--gold)}

/* ---- enrichment: signals list+stats · heat sparkline · calendar values ---- */
#dSig .donut.donut-sm{width:100px;height:100px}
#dSig .dwrap{gap:12px}
#dSig .dleg{font-size:11.5px}
#dSig .donut.donut-sm .dv{font-size:23px}
.sigstats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:13px;padding-top:12px;border-top:1px solid var(--line)}
.sigstats .ss{text-align:center}
.sigstats .ssv{font-size:17px;font-weight:900;font-variant-numeric:tabular-nums;line-height:1}
.sigstats .ssl{font-size:9.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-top:4px}
.siglist{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.sigrow{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--card2);border:1px solid var(--line);border-radius:9px;font-size:11.5px}
.sigrow .sigdir{font-weight:800;flex-shrink:0;min-width:60px}
.sigrow .sigdir.up{color:var(--up)} .sigrow .sigdir.down{color:var(--down)} .sigrow .sigdir.flat{color:#f59e0b}
.sigrow .sigpx{font-weight:800;font-variant-numeric:tabular-nums}
.sigrow .sigtps{color:var(--muted);font-variant-numeric:tabular-nums;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sigrow .sigstat{font-size:9px;font-weight:800;text-transform:uppercase;padding:2px 7px;border-radius:5px;flex-shrink:0;background:var(--card);color:var(--muted)}
.sigrow .sigstat.up{color:var(--up);background:rgba(38,208,124,.12)} .sigrow .sigstat.down{color:var(--down);background:rgba(255,77,94,.12)}
/* heat tiles — taller, with sparkline + top-mover highlight */
.htile{position:relative;padding:10px 8px 11px}
.htile .hspark{height:18px;margin:5px 0 4px;opacity:.85}
.htile .hspark svg{width:100%;height:100%;display:block}
.htile.htop{box-shadow:0 0 0 1.5px var(--gold) inset,0 6px 16px rgba(226,59,59,.16)}
.htile .hbadge{position:absolute;top:5px;inset-inline-end:6px;font-size:11px;line-height:1}
/* calendar — gold-impact bar · A/F/P values · next highlight */
.evrow2{display:flex;align-items:stretch;gap:9px;padding:9px 4px;border-bottom:1px solid var(--line)}
.evrow2:last-child{border-bottom:0}
.evrow2.evnext{background:linear-gradient(90deg,var(--glow),transparent);border-radius:9px;padding-inline:8px}
.evrow2 .evgi{width:4px;border-radius:3px;flex-shrink:0}
.evrow2 .evgi.g3{background:var(--down)} .evrow2 .evgi.g2{background:#ff9f43} .evrow2 .evgi.g1{background:var(--flat)} .evrow2 .evgi.g0{background:var(--line)}
.evrow2 .evL{display:flex;flex-direction:column;gap:2px;flex-shrink:0;min-width:44px}
.evrow2 .evL .et{font-size:12px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--txt2)}
.evrow2 .evL .ecur{font-size:10px;font-weight:800;color:var(--gold);display:inline-flex;align-items:center;gap:3px}
.evrow2 .evL .efl{font-size:12px}
.evrow2 .evM{flex:1;min-width:0}
.evrow2 .een2{font-size:12.5px;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.evrow2 .evvals{font-size:10px;color:var(--muted);margin-top:3px;font-variant-numeric:tabular-nums}
.evrow2 .evvals .act{color:var(--up)}
.evrow2 .evR{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.evrow2 .nexttag{font-size:8.5px;font-weight:800;text-transform:uppercase;color:var(--gold);background:var(--glow);padding:1px 6px;border-radius:5px}
