/* ============================================================
   STOCKDD TERMINAL v3.0 — Bloomberg Box Style
   IBM Plex Mono · Strict grid · Numbered function blocks
   ============================================================ */

:root {
  --bg0:      #000000;
  --bg1:      #080b0f;
  --bg2:      #0c1018;
  --bg3:      #10151e;
  --bg4:      #141a24;
  --bg-hover: #1a2232;
  --border:   #1e2c42;
  --border2:  #263450;
  --accent:   #ff9500;   /* Bloomberg orange */
  --accent2:  #00bfff;   /* cyan highlight */
  --green:    #00e676;
  --red:      #ff3d57;
  --yellow:   #ffd600;
  --purple:   #aa88ff;
  --pink:     #ff5588;
  --teal:     #00ccaa;
  --text1:    #dce8f5;
  --text2:    #8fa8c0;
  --text3:    #4a6070;
  --font:     'IBM Plex Mono', 'Courier New', monospace;
  --sans:     'IBM Plex Sans', sans-serif;

  --topbar-h:   44px;
  --mq-h:       22px;
  --cmd-h:      36px;
  --nav-h:      30px;
  --status-h:   24px;
  --chrome:     calc(var(--topbar-h) + var(--mq-h) + var(--cmd-h) + var(--nav-h) + var(--status-h));
  --content-h:  calc(100vh - var(--chrome));
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;background:var(--bg0);color:var(--text1);font-family:var(--font);font-size:11px;overflow:hidden}

/* ── SCROLLBARS ─────────────────────────────────────── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--bg1)}
::-webkit-scrollbar-thumb{background:var(--border2)}

/* ── BOOT ────────────────────────────────────────────── */
#boot-screen{
  position:fixed;inset:0;background:#000;
  display:flex;align-items:center;justify-content:center;z-index:9999
}
.boot-inner{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  width:560px
}
.boot-logo{
  font-family:var(--sans);font-size:80px;font-weight:700;
  letter-spacing:4px;color:var(--accent);
  text-shadow:0 0 60px rgba(255,149,0,0.4)
}
.boot-logo span{color:var(--accent2)}
.boot-tagline{font-size:11px;letter-spacing:5px;color:var(--text2)}
.boot-version{font-size:10px;color:var(--text3);letter-spacing:2px}
.boot-bar-wrap{width:100%;height:2px;background:var(--bg3)}
.boot-bar{width:100%;height:2px;background:var(--bg3);overflow:hidden}
.boot-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));animation:bfill 2.8s ease forwards}
@keyframes bfill{0%{width:0}60%{width:65%}80%{width:82%}100%{width:100%}}
.boot-status{font-size:10px;color:var(--text3);letter-spacing:2px}
.boot-log{font-size:9px;color:var(--text3);width:100%;min-height:60px;border-top:1px solid var(--border);padding-top:8px;line-height:1.8}

/* ── TOP BAR ─────────────────────────────────────────── */
#topbar{
  height:var(--topbar-h);background:var(--bg0);
  border-bottom:2px solid var(--accent);
  display:flex;align-items:center;padding:0 10px;gap:12px
}
.tb-brand{display:flex;align-items:center;gap:6px;white-space:nowrap}
.tb-logo{font-family:var(--sans);font-weight:700;font-size:20px;color:var(--accent);letter-spacing:2px}
.tb-dd{color:var(--accent2)}
.tb-sep{color:var(--border2);font-size:16px}
.tb-subtitle{font-size:9px;letter-spacing:3px;color:var(--text3)}
.tb-clocks{display:flex;gap:8px;flex:1;overflow:hidden}
.tb-clock-item{
  display:flex;flex-direction:column;align-items:center;
  padding:2px 8px;border:1px solid var(--border);
  background:var(--bg2);min-width:76px
}
.tbc-city{font-size:8px;color:var(--text3);letter-spacing:1px}
.tbc-time{font-size:12px;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}
.tb-mkt-pills{display:flex;gap:6px;overflow:hidden}
.tb-mkt-pill{
  display:flex;flex-direction:column;align-items:center;
  padding:2px 8px;border:1px solid var(--border);background:var(--bg2);cursor:pointer;
  min-width:80px
}
.tb-mkt-pill:hover{border-color:var(--accent)}
.tb-mkt-pill .sym{font-size:9px;color:var(--text3)}
.tb-mkt-pill .val{font-size:11px;font-weight:600}
.tb-mkt-pill .chg{font-size:10px;font-weight:700}
.tb-actions{display:flex;align-items:center;gap:8px;white-space:nowrap}
.tb-pill{font-size:10px;padding:2px 8px;border:1px solid;font-weight:700;letter-spacing:1px}
.tb-pill.green{border-color:var(--green);color:var(--green);background:rgba(0,230,118,0.06)}
.tb-btn{
  background:var(--bg3);border:1px solid var(--border2);color:var(--text2);
  padding:4px 10px;font-family:var(--font);font-size:10px;cursor:pointer;letter-spacing:0.5px;
  transition:.12s
}
.tb-btn:hover{background:var(--border2);color:var(--text1)}

/* ── MARQUEE ─────────────────────────────────────────── */
#marquee-bar{
  height:var(--mq-h);background:var(--bg1);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;overflow:hidden;gap:0
}
.mq-label{
  font-size:9px;font-weight:700;letter-spacing:2px;color:#000;
  background:var(--accent);padding:0 8px;height:100%;display:flex;align-items:center;
  white-space:nowrap;flex-shrink:0
}
.mq-track{flex:1;overflow:hidden;position:relative}
#mq-inner{
  display:inline-block;white-space:nowrap;
  font-size:10px;color:var(--text2);
  animation:mqscroll 90s linear infinite
}
@keyframes mqscroll{from{transform:translateX(100vw)}to{transform:translateX(-200%)}}

/* ── COMMAND BAR ─────────────────────────────────────── */
#cmdbar{
  height:var(--cmd-h);background:var(--bg0);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 8px;gap:10px;position:relative
}
.cmd-prompt{display:flex;align-items:center;flex:1;max-width:480px;gap:0}
.cmd-gt{color:var(--accent);font-size:14px;padding:0 6px;font-weight:700}
#cmd-input{
  flex:1;background:var(--bg2);border:1px solid var(--border2);border-left:none;
  color:var(--accent2);font-family:var(--font);font-size:12px;
  padding:4px 10px;outline:none;caret-color:var(--accent)
}
#cmd-input::placeholder{color:var(--text3)}
#cmd-suggestions{
  position:absolute;top:100%;left:8px;width:480px;
  background:var(--bg3);border:1px solid var(--accent2);z-index:200;display:none
}
.cmd-sug-item{padding:5px 10px;cursor:pointer;display:flex;justify-content:space-between;font-size:11px}
.cmd-sug-item:hover{background:var(--bg-hover)}
.cmd-fkeys{display:flex;gap:4px;flex-wrap:nowrap;overflow:hidden}
.fkey{
  font-size:9px;color:var(--text3);padding:2px 7px;
  border:1px solid var(--border);cursor:pointer;white-space:nowrap;transition:.1s
}
.fkey em{color:var(--accent);font-style:normal;margin-right:3px;font-weight:700}
.fkey:hover{color:var(--accent);border-color:var(--accent)}

/* ── NAV TABS ────────────────────────────────────────── */
#navtabs{
  height:var(--nav-h);background:var(--bg1);
  border-bottom:1px solid var(--border);
  display:flex;gap:1px;padding:0 4px;align-items:flex-end
}
.tab{
  background:var(--bg0);border:1px solid var(--border);border-bottom:none;
  color:var(--text3);padding:4px 14px;font-family:var(--font);font-size:10px;
  cursor:pointer;letter-spacing:0.5px;transition:.1s;height:26px
}
.tab:hover{color:var(--text1)}
.tab.active{
  background:var(--bg2);color:var(--accent);
  border-color:var(--accent);border-bottom:2px solid var(--bg2);
  margin-bottom:-1px;font-weight:600
}

/* ── CONTENT ─────────────────────────────────────────── */
#content{height:var(--content-h);overflow:hidden;background:var(--bg1)}
.panel{display:none;height:100%;overflow:hidden;padding:6px;gap:6px}
.panel.active{display:block}
.panel.active.grid-panel{display:grid}

/* ── BLOOMBERG BOX ───────────────────────────────────── */
.bb-box{
  background:var(--bg2);border:1px solid var(--border);
  margin-bottom:6px;overflow:hidden;display:flex;flex-direction:column;
  min-height:0
}
.bb-col .bb-box{flex:1;min-height:0}
.bb-body{overflow-y:auto;flex:1;min-height:0}
.bb-resize-handle{
  height:5px;cursor:row-resize;background:transparent;
  position:relative;flex-shrink:0;z-index:5;
  transition:background 0.15s;
}
.bb-resize-handle::after{
  content:'';position:absolute;left:30%;right:30%;top:2px;
  height:1px;background:var(--border);border-radius:1px;
  transition:background 0.15s,height 0.15s;
}
.bb-resize-handle:hover::after,.bb-resize-handle.active::after{
  background:var(--accent);height:2px;top:1px;
}
.bb-resize-handle:hover,.bb-resize-handle.active{
  background:rgba(255,149,0,0.08);
}
@media(max-width:899px){
  .bb-resize-handle{display:none}
}
.bb-hdr{
  font-family:var(--font);font-size:10px;font-weight:600;
  letter-spacing:1px;color:var(--accent2);
  background:var(--bg3);border-bottom:1px solid var(--border);
  padding:4px 8px;display:flex;align-items:center;gap:6px;
  white-space:nowrap;overflow:hidden;flex-shrink:0
}
.bb-hdr b{color:var(--accent);font-weight:700;min-width:18px}

/* ── GRIDS ───────────────────────────────────────────── */
.bb-grid-4{display:grid;grid-template-columns:1fr 1fr 2fr 1fr;gap:6px;height:100%}
.bb-grid-3{display:grid;grid-template-columns:2fr 2fr 1fr;gap:6px;height:100%}
.bb-grid-stocks{display:grid;grid-template-columns:280px 1fr 260px;gap:6px;height:100%}
.bb-grid-crypto{display:grid;grid-template-columns:1fr 300px 280px;gap:6px;height:100%}
.crypto-news-col{align-self:stretch;min-height:0}
.crypto-news-col .bb-box{flex:1;min-height:0}
.crypto-news-col .news-item{cursor:pointer;transition:background .15s}
.crypto-news-col .news-item:hover{background:rgba(255,149,0,.07)}
.bb-grid-chart{display:grid;grid-template-columns:1fr 260px;gap:6px;height:100%}
.bb-grid-screener{height:100%}
.bb-col{display:flex;flex-direction:column;min-height:0;overflow:hidden}
.span2{grid-column:span 2}
.span3{grid-column:span 3}
.flex-chart canvas{flex:1}
.ml-auto{margin-left:auto}
.dim{color:var(--text3)}

/* ── DATA TABLE ──────────────────────────────────────── */
.data-table{width:100%;border-collapse:collapse;font-size:10.5px}
.data-table th{
  background:var(--bg3);color:var(--accent);text-align:left;
  padding:4px 6px;border-bottom:1px solid var(--border);
  font-size:9px;letter-spacing:1px;white-space:nowrap;
  position:sticky;top:0;z-index:2;font-weight:600
}
.data-table td{
  padding:3px 6px;border-bottom:1px solid rgba(30,44,66,0.6);
  white-space:nowrap;cursor:pointer;font-variant-numeric:tabular-nums
}
.data-table tr:hover td{background:var(--bg-hover)}
.data-table tr:nth-child(even) td{background:rgba(0,0,0,0.15)}

/* ── MINI ROWS (bloomberg lists) ─────────────────────── */
.bb-row{
  display:grid;grid-template-columns:1fr auto auto;
  padding:3px 8px;border-bottom:1px solid rgba(30,44,66,0.5);
  font-size:11px;gap:6px;cursor:pointer
}
.bb-row:hover{background:var(--bg-hover)}
.bb-row .name{color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bb-row .val{font-weight:600;text-align:right;min-width:72px;font-variant-numeric:tabular-nums}
.bb-row .chg{font-weight:700;text-align:right;min-width:56px}

/* ── COLORS ──────────────────────────────────────────── */
.green,.up{color:var(--green)!important}
.red,.dn{color:var(--red)!important}
.yellow{color:var(--yellow)!important}
.orange,.accent{color:var(--accent)!important}
.cyan{color:var(--accent2)!important}
.purple{color:var(--purple)!important}

/* ── LIVE DOT ────────────────────────────────────────── */
.ldot{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block;animation:blink 1.4s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

/* ── INLINE TABS ─────────────────────────────────────── */
.inl-tabs{display:flex;gap:2px}
.inl-tabs span{
  font-size:9px;color:var(--text3);padding:2px 7px;
  border:1px solid var(--border);cursor:pointer;transition:.1s;letter-spacing:.5px
}
.inl-tabs span:hover,.inl-tabs span.active{color:var(--accent);border-color:var(--accent);background:rgba(255,149,0,.06)}
.bct,.btab,.bper,.cfilt,.nfilt,.ecofilt,.per,.ctype{
  font-size:9px;color:var(--text3);padding:2px 7px;
  border:1px solid var(--border);cursor:pointer;transition:.1s;letter-spacing:.5px
}
.bct:hover,.btab:hover,.bper:hover,.cfilt:hover,.nfilt:hover,.ecofilt:hover,.per:hover,.ctype:hover,
.bct.active,.btab.active,.bper.active,.cfilt.active,.nfilt.active,.ecofilt.active,.per.active,.ctype.active{
  color:var(--accent);border-color:var(--accent);background:rgba(255,149,0,.06)
}

/* ── EQUITY DETAIL ───────────────────────────────────── */
.eq-placeholder{
  color:var(--text3);text-align:center;padding:30px 20px;
  line-height:2.2;font-size:11px;letter-spacing:1px
}
.eq-header{padding:10px 10px 6px;border-bottom:1px solid var(--border)}
.eq-price-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.eq-price{font-size:36px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text1)}
.eq-change{font-size:18px;font-weight:600}
.eq-name{font-size:10px;color:var(--text2);letter-spacing:1px;margin-bottom:4px}
.eq-stats{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--border);margin:6px;
}
.eq-stat{background:var(--bg3);padding:5px 8px}
.eq-stat .lbl{font-size:9px;color:var(--text3);letter-spacing:.5px}
.eq-stat .val{font-size:11px;font-weight:600;margin-top:1px}
.keystats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border);margin:6px
}
.ks-item{background:var(--bg3);padding:5px 8px}
.ks-item .lbl{font-size:9px;color:var(--text3);letter-spacing:.5px}
.ks-item .val{font-size:11px;font-weight:600}

/* ── NEWS ────────────────────────────────────────────── */
.news-scroll{overflow-y:auto;max-height:none;flex:1;min-height:0}
.news-item{
  border-left:3px solid var(--border2);border-bottom:1px solid var(--border);
  padding:6px 10px;cursor:pointer;transition:.12s
}
.news-item:hover{border-left-color:var(--accent);background:var(--bg-hover)}
.news-item.breaking{border-left-color:var(--red);animation:nflash 2s infinite}
@keyframes nflash{0%,100%{opacity:1}50%{opacity:.85}}
.news-meta{display:flex;gap:8px;font-size:9px;color:var(--text3);margin-bottom:3px;flex-wrap:wrap}
.news-tag{padding:1px 5px;background:var(--bg3);border:1px solid var(--border);font-size:9px;letter-spacing:.5px}
.news-brk{color:var(--red);font-weight:700}
.news-title{font-size:11px;color:var(--text1);line-height:1.45;font-weight:500}
.news-sum{font-size:10px;color:var(--text2);margin-top:3px;line-height:1.4}

/* ── BONDS SPECIFIC ──────────────────────────────────── */
.bbond-row{
  display:grid;grid-template-columns:1fr 52px 52px 52px 52px;
  padding:3px 8px;border-bottom:1px solid rgba(30,44,66,.5);
  font-size:11px;gap:4px;align-items:center
}
.bbond-row:hover{background:var(--bg-hover)}
.bond-mat{font-size:9px;color:var(--accent2);font-weight:700}

/* ── FOREX ───────────────────────────────────────────── */
.fx-cell{
  padding:5px 3px;text-align:center;font-size:10px;
  font-weight:700;cursor:pointer;transition:.1s
}
.fx-cell:hover{filter:brightness(1.2)}
#fx-heatmap{
  display:grid;gap:1px;
  grid-template-columns:repeat(9,1fr);
  padding:4px;background:var(--border)
}
.fx-hdr-cell{
  background:var(--bg3);color:var(--text3);
  font-size:9px;padding:3px;text-align:center;font-weight:700
}

/* ── CRYPTO ──────────────────────────────────────────── */
.stat-grid-4{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--border);padding:0;margin:6px
}
.sg-item{background:var(--bg3);padding:5px 8px}
.sg-item .lbl{font-size:9px;color:var(--text3);letter-spacing:.5px}
.sg-item .val{font-size:11px;font-weight:600;margin-top:1px}
.spark-cell{width:80px;height:26px}

/* ── SECTORS ─────────────────────────────────────────── */
.sector-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);padding:0;margin:4px
}
.sec-cell{
  padding:5px 6px;text-align:center;
  font-size:10px;cursor:pointer;transition:.1s
}
.sec-cell:hover{filter:brightness(1.15)}
.sec-name{font-size:9px;color:rgba(255,255,255,.7)}
.sec-chg{font-size:12px;font-weight:700;margin-top:1px}

/* ── CHART ───────────────────────────────────────────── */
.chart-toolbar2{
  display:flex;align-items:center;gap:4px;padding:4px 8px;
  border-bottom:1px solid var(--border);flex-wrap:wrap
}
.csep{color:var(--border2);margin:0 4px}
.ckbox{font-size:10px;color:var(--text2);display:flex;align-items:center;gap:3px;cursor:pointer}
.ckbox input{accent-color:var(--accent);cursor:pointer}
.chart-infobar{
  display:flex;gap:14px;padding:4px 8px;font-size:10px;
  color:var(--text2);border-bottom:1px solid var(--border);
  flex-wrap:wrap
}
.chart-canvas-wrap{position:relative;flex:1;min-height:220px}
.chart-canvas-wrap canvas{position:absolute;inset:0;width:100%!important;height:100%!important}
.vol-canvas{width:100%!important}
.indicators-row{display:flex;gap:4px;padding:4px}
.ind-pane{flex:1;background:var(--bg3);border:1px solid var(--border);padding:4px}
.ind-label{font-size:9px;color:var(--accent);letter-spacing:1px;margin-bottom:2px}
.chart-master-box{height:100%;display:flex;flex-direction:column}
.chart-inp{
  background:var(--bg3);border:1px solid var(--border2);color:var(--accent2);
  font-family:var(--font);font-size:12px;padding:3px 8px;outline:none;width:100px
}

/* ── OPTIONS ─────────────────────────────────────────── */
.options-tbl .calls-hdr{background:rgba(255,152,0,.1);color:var(--accent);text-align:center}
.options-tbl .puts-hdr{background:rgba(0,191,255,.1);color:var(--accent2);text-align:center}
.options-tbl .strike-hdr{background:var(--bg3);color:var(--yellow);text-align:center;font-weight:700}
.options-tbl .strike-col{background:rgba(255,214,0,.05);color:var(--yellow);font-weight:700;text-align:center}
.itm-call td{background:rgba(255,152,0,.04)}
.itm-put td{background:rgba(0,191,255,.04)}
#options-expiries{display:flex;gap:3px;padding:6px 8px;flex-wrap:wrap}
.exp-btn{
  font-size:9px;padding:2px 8px;border:1px solid var(--border);
  background:var(--bg3);color:var(--text2);cursor:pointer
}
.exp-btn.active,.exp-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── PORTFOLIO ───────────────────────────────────────── */
.port-pnl-pos td,.port-pnl-neg td{transition:0s}
#port-summary,#port-risk{padding:8px}
.port-stat-row{
  display:flex;justify-content:space-between;
  padding:4px 0;border-bottom:1px solid var(--border);font-size:11px
}
.port-stat-row .lbl{color:var(--text2)}
.port-stat-row .val{font-weight:600}

/* ── SCREENER ────────────────────────────────────────── */
.screener-filters{
  display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;
  padding:8px 10px;border-bottom:1px solid var(--border)
}
.sf-g{display:flex;flex-direction:column;gap:3px}
.sf-g label{font-size:9px;color:var(--text3);letter-spacing:1px}
.sf-g select{
  background:var(--bg3);border:1px solid var(--border2);color:var(--text1);
  font-family:var(--font);font-size:10px;padding:3px 6px;outline:none
}
.scr-run{
  background:var(--accent);color:#000;border:none;
  padding:5px 16px;font-family:var(--sans);font-weight:700;
  font-size:10px;letter-spacing:1px;cursor:pointer
}
.scr-reset{
  background:var(--bg3);color:var(--text2);border:1px solid var(--border2);
  padding:5px 10px;font-family:var(--font);font-size:10px;cursor:pointer
}
.scr-run:hover{background:#ffa520}

/* ── ALERTS ──────────────────────────────────────────── */
.alert-row{
  display:flex;align-items:center;gap:8px;padding:5px 8px;
  border-bottom:1px solid var(--border);font-size:11px
}
.alert-row .alrt-sym{color:var(--accent);font-weight:700;min-width:60px}
.alert-row .alrt-cond{color:var(--text2);flex:1}
.alert-del{color:var(--red);cursor:pointer;font-size:13px;padding:0 4px}
.alert-del:hover{color:var(--red)}
.alrt-active{border-left:3px solid var(--green)}
.alrt-triggered{border-left:3px solid var(--red);animation:nflash 1s 3}
.session-row{
  display:flex;align-items:center;gap:10px;
  padding:5px 8px;border-bottom:1px solid var(--border);font-size:11px
}
.sess-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sess-open{background:var(--green);box-shadow:0 0 6px var(--green)}
.sess-pre{background:var(--yellow)}
.sess-closed{background:var(--text3)}

/* ── MISC INPUTS ─────────────────────────────────────── */
.small-inp{
  background:var(--bg3);border:1px solid var(--border2);color:var(--text1);
  font-family:var(--font);font-size:10px;padding:3px 6px;outline:none
}
.small-btn{
  background:var(--bg3);border:1px solid var(--border2);color:var(--text2);
  font-family:var(--font);font-size:10px;padding:3px 8px;cursor:pointer;transition:.1s
}
.small-btn:hover{background:var(--border2);color:var(--text1)}
.conv-sel{
  background:var(--bg3);border:1px solid var(--border2);color:var(--text1);
  font-family:var(--font);font-size:10px;padding:3px 4px;outline:none
}
.conv-row{display:flex;align-items:center;gap:6px;padding:8px}
.conv-arrow{color:var(--text3)}
.conv-result{
  font-size:22px;font-weight:700;color:var(--accent2);
  padding:8px 12px;border-top:1px solid var(--border);font-variant-numeric:tabular-nums
}
.converter-wrap{padding:0}
#conv-rates-table{font-size:10px;color:var(--text2);padding:4px 10px;columns:2;column-gap:16px}
.cv-rate-row{padding:2px 0;display:flex;justify-content:space-between;font-variant-numeric:tabular-nums}

/* ── BREADTH / MISC ──────────────────────────────────── */
.breadth-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);padding:0;margin:6px
}
.breadth-cell{background:var(--bg3);padding:6px 8px;text-align:center}
.breadth-cell .lbl{font-size:9px;color:var(--text3);letter-spacing:.5px}
.breadth-cell .val{font-size:14px;font-weight:700;margin-top:2px}
.vix-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:4px 8px;border-bottom:1px solid var(--border);font-size:11px
}
.fut-row{
  display:grid;grid-template-columns:1fr auto auto auto;
  padding:3px 8px;border-bottom:1px solid var(--border);font-size:11px;gap:8px
}

/* ── ANALYST RATINGS ─────────────────────────────────── */
.rat-row{
  display:flex;align-items:center;gap:6px;padding:4px 8px;
  border-bottom:1px solid var(--border);font-size:10px
}
.rat-sym{color:var(--accent);font-weight:700;min-width:50px}
.rat-from{color:var(--text3);text-decoration:line-through;font-size:9px}
.rat-to{font-weight:600}
.rat-arrow{font-size:9px}
.rat-bank{color:var(--text3);font-size:9px;flex:1;text-align:right}
.rate-upgrade{color:var(--green)}
.rate-downgrade{color:var(--red)}
.rate-init{color:var(--accent2)}

/* ── IPO ─────────────────────────────────────────────── */
.ipo-row{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;border-bottom:1px solid var(--border);font-size:10px}
.ipo-name{color:var(--text1);font-weight:500;flex:1}
.ipo-size{color:var(--accent2);font-weight:700;min-width:60px;text-align:right}
.ipo-date{color:var(--text3);font-size:9px;min-width:80px;text-align:right}

/* ── STATUS BAR ──────────────────────────────────────── */
#statusbar{
  height:var(--status-h);background:var(--bg0);
  border-top:1px solid var(--border);
  display:flex;align-items:center;padding:0 8px;gap:8px
}
.sb-i{display:flex;gap:5px;font-size:9px;white-space:nowrap}
.sb-l{color:var(--text3);letter-spacing:.5px}
.sb-v{font-weight:600}
.sb-sep{color:var(--border2);font-size:14px}
.sb-ticker-wrap{flex:1;overflow:hidden;position:relative}
.sb-ticker-scroll{
  display:inline-block;white-space:nowrap;
  font-size:9px;color:var(--text2);
  animation:sbscroll 120s linear infinite
}
@keyframes sbscroll{from{transform:translateX(100vw)}to{transform:translateX(-200%)}}

/* ── LIGHT THEME ─────────────────────────────────────── */
body.light{
  --bg0:#f5f6f8;--bg1:#ededf0;--bg2:#ffffff;--bg3:#f0f2f5;
  --bg-hover:#e0e5ee;--border:#c8d0dc;--border2:#9aacbc;
  --text1:#0e1a28;--text2:#3d5068;--text3:#8899aa
}

/* ── EARNINGS CAL ────────────────────────────────────── */
.earn-row{
  display:grid;grid-template-columns:80px 1fr auto auto auto;
  padding:3px 8px;border-bottom:1px solid var(--border);
  font-size:10px;gap:6px;align-items:center
}
.earn-date{color:var(--text3)}
.earn-sym{color:var(--accent);font-weight:700}
.earn-exp{color:var(--text2)}
.earn-time{color:var(--text3);font-size:9px}

/* ── TRADE BALANCE ───────────────────────────────────── */
.tb-econ-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:4px 8px;border-bottom:1px solid var(--border);font-size:11px
}
.tb-econ-bar{flex:1;margin:0 10px;height:6px;background:var(--bg3);position:relative}
.tb-econ-fill{height:100%}

/* ── MNA DEALS ───────────────────────────────────────── */
.mna-row{padding:5px 8px;border-bottom:1px solid var(--border)}
.mna-names{font-size:11px;color:var(--text1);font-weight:500}
.mna-val{font-size:10px;color:var(--accent2);font-weight:700}
.mna-status{font-size:9px;color:var(--text3)}

/* ── NEWS READER ─────────────────────────────────────── */
.news-reader{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column}
.nr-header{border-bottom:2px solid var(--accent);padding:0}
.nr-toolbar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#0e1420;border-bottom:1px solid var(--border)}
.nr-title{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:1px}
.nr-btn{font-size:10px;color:var(--text2);cursor:pointer;padding:3px 10px;border:1px solid var(--border);transition:all .15s;letter-spacing:.5px}
.nr-btn:hover{color:var(--accent);border-color:var(--accent)}
.nr-close{color:var(--red)}
.nr-close:hover{background:rgba(255,61,87,.15);border-color:var(--red)}
.nr-url{font-size:9px;color:var(--text3);padding:3px 12px;background:#080c14;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nr-frame{flex:1;border:none;background:#fff;width:100%}

/* ── RESPONSIVE ──────────────────────────────────────── */
canvas{max-width:100%}
input[type=checkbox]{accent-color:var(--accent)}
