/* ============================================================
   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-online{font-size:9px;color:var(--green);letter-spacing:1px;display:flex;align-items:center;gap:4px}
.tb-online .pulse-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse-online 2s infinite}
@keyframes pulse-online{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(0,230,118,.7)}50%{opacity:.7;box-shadow:0 0 0 4px rgba(0,230,118,0)}}
.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}
#panel-stocks.active,#panel-politics.active{overflow-y:auto;overflow-x:hidden}

/* ── 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-grid-politics{display:grid;grid-template-columns:280px 1fr 260px;gap:6px;height:100%}
.bb-grid-politics>.bb-col{overflow:hidden}
.bb-grid-politics .bb-box{background:var(--bg2);border:1px solid var(--border);position:relative;z-index:1;overflow:hidden}
.bb-grid-politics .bb-hdr{position:sticky;top:0;z-index:2;background:var(--bg3)}
#pol-trade-rankings{max-height:420px;overflow-y:auto;background:var(--bg2)}
#pol-watchlist{max-height:200px;overflow-y:auto;background:var(--bg2)}
#pol-filings-list{max-height:300px;overflow-y:auto;background:var(--bg2)}
#pol-detail{max-height:400px;overflow-y:auto;background:var(--bg2)}
.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-overview{display:grid;grid-template-columns:1fr 1fr 1.5fr 1fr 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}
.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}
.bb-col.eq-col-flow{overflow:visible}
.bb-col.eq-col-flow .bb-box{flex:none;min-height:auto;overflow:visible}
.bb-col.eq-col-flow .flex-chart{min-height:240px}
.bb-col.eq-col-flow .flex-chart canvas{min-height:180px}
.bb-grid-stocks>.bb-col:not(.eq-col-flow){position:sticky;top:0;align-self:start;max-height:var(--content-h);overflow-y:auto}
.span2{grid-column:span 2}
.span3{grid-column:span 3}
.flex-chart canvas{flex:1}
.eq-news-wide{max-height:320px}
.analyst-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;font-size:10px}
.analyst-row{display:flex;justify-content:space-between;padding:4px 8px;border-bottom:1px solid rgba(30,44,66,.4)}
.analyst-row:last-child{border-bottom:none}
.analyst-row .a-firm{color:var(--text1);font-weight:500}
.analyst-row .a-rating{font-weight:700;letter-spacing:.5px}
.analyst-row .a-target{color:var(--accent2);font-weight:600}
.analyst-summary{display:flex;gap:16px;padding:8px;border-bottom:1px solid var(--border);flex-wrap:wrap;font-size:10px}
.analyst-bar{height:8px;border-radius:2px;display:flex;overflow:hidden;margin:6px 8px}
.analyst-bar div{height:100%}
.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-post{background:var(--accent)}
.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:#080b0f;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%}

.short-row{cursor:pointer;transition:background .15s}
.short-row:hover{background:var(--bg-hover) !important}
.stab{font-size:9px;color:var(--text3);cursor:pointer;padding:2px 6px;border:1px solid transparent;transition:all .15s}
.stab:hover{color:var(--accent2)}
.stab.active{color:var(--accent2);border-color:var(--accent2);background:rgba(0,191,255,.08)}

/* ── EQUITY QUICK TICKERS ───────────────────────────── */
.eq-placeholder{padding:20px;text-align:center;color:var(--text2);font-size:12px}
.eq-quick-tickers{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.eq-quick{font-size:11px;font-weight:700;color:var(--accent);padding:4px 10px;border:1px solid var(--border);border-radius:3px;cursor:pointer;transition:all .15s;letter-spacing:.5px}
.eq-quick:hover{background:rgba(255,149,0,.12);border-color:var(--accent);color:#fff}
.eq-quick.cse{color:var(--accent2);border-color:rgba(0,191,255,.3)}
.eq-quick.cse:hover{background:rgba(0,191,255,.12);border-color:var(--accent2);color:#fff}

/* ── DIAGNOSTICS OVERLAY ────────────────────────────── */
.diag-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:#080b0f;display:flex;flex-direction:column}
.diag-panel{display:flex;flex-direction:column;height:100%}
.diag-header{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#0e1420;border-bottom:2px solid var(--accent)}
.diag-title{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:1.5px}
.diag-summary{padding:10px 14px;background:#0a0e16;border-bottom:1px solid var(--border);display:flex;gap:20px;flex-wrap:wrap;font-size:11px}
.diag-body{flex:1;overflow-y:auto;padding:10px 14px}
.diag-module{margin-bottom:14px;border:1px solid var(--border);border-radius:4px;overflow:hidden}
.diag-mod-hdr{padding:6px 10px;background:#0e1420;font-size:11px;font-weight:700;letter-spacing:1px;color:var(--accent);display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.diag-mod-hdr .diag-badge{font-size:9px;padding:1px 6px;border-radius:3px;font-weight:600}
.diag-ok{background:rgba(0,230,118,.15);color:#00e676}
.diag-warn{background:rgba(255,214,0,.15);color:#ffd600}
.diag-err{background:rgba(255,61,87,.15);color:#ff3d57}
.diag-item{display:grid;grid-template-columns:1fr 120px 140px 60px;padding:3px 10px;border-bottom:1px solid rgba(30,44,66,.4);font-size:10px;gap:6px;align-items:center}
.diag-item:last-child{border-bottom:none}
.diag-item .di-name{color:var(--text2);font-weight:500}
.diag-item .di-src{color:var(--text3)}
.diag-item .di-time{color:var(--text3)}
.diag-item .di-status{text-align:center;font-weight:700;font-size:9px}
.diag-check{color:#00e676}
.diag-cross{color:#ff3d57}
.diag-dash{color:#ffd600}
.diag-calc{padding:6px 10px;font-size:10px;color:var(--text3);border-top:1px solid rgba(30,44,66,.4);line-height:1.5}

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

/* ═══════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Screens ≤ 768px
   ═══════════════════════════════════════════════════════ */
@media(max-width:768px){
  :root{
    --topbar-h:38px;
    --mq-h:18px;
    --cmd-h:40px;
    --nav-h:32px;
    --status-h:20px;
  }
  html,body{font-size:10px;overflow-x:hidden;overflow-y:auto;height:auto}
  #terminal{display:flex!important;flex-direction:column;height:100vh;overflow:hidden}

  /* ── BOOT ────────── */
  .boot-inner{width:90vw;max-width:400px}
  .boot-logo{font-size:42px}
  .boot-tagline{font-size:9px;letter-spacing:3px}

  /* ── TOP BAR ─────── */
  #topbar{padding:0 6px;gap:6px;flex-wrap:nowrap}
  .tb-brand{flex-shrink:0}
  .tb-logo{font-size:14px}
  .tb-sep,.tb-subtitle{display:none}
  .tb-clocks{display:none}
  .tb-mkt-pills{display:none}
  .tb-actions{gap:4px}
  .tb-pill{font-size:8px;padding:1px 5px}
  .tb-btn{font-size:9px;padding:3px 6px}

  /* ── MARQUEE ─────── */
  #marquee-bar{height:var(--mq-h)}
  .mq-label{font-size:8px;padding:0 5px}
  #mq-inner{font-size:9px}

  /* ── COMMAND BAR ─── */
  #cmdbar{padding:0 4px;gap:4px;z-index:100}
  .cmd-prompt{max-width:none;flex:1}
  .cmd-gt{font-size:12px;padding:0 3px}
  #cmd-input{font-size:16px;padding:6px 8px}
  #cmd-suggestions{width:calc(100vw - 8px);left:4px;z-index:9000;max-height:60vh;overflow-y:auto;
    -webkit-overflow-scrolling:touch;box-shadow:0 8px 24px rgba(0,0,0,0.6)}
  .cmd-sug-item{padding:12px 10px;font-size:12px;border-bottom:1px solid var(--border);
    -webkit-tap-highlight-color:rgba(255,149,0,0.15)}
  .cmd-sug-item:active{background:var(--bg-hover)}
  .cmd-fkeys{display:none}

  /* ── NAV TABS ────── */
  #navtabs{
    height:var(--nav-h);overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;flex-wrap:nowrap;
    gap:0;padding:0 2px;scrollbar-width:none
  }
  #navtabs::-webkit-scrollbar{display:none}
  .tab{
    font-size:8px;padding:3px 8px;white-space:nowrap;
    flex-shrink:0;height:auto;letter-spacing:0
  }

  /* ── CONTENT ─────── */
  #content{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;height:auto;flex:1}
  .panel{padding:3px;gap:3px;height:auto!important;overflow:visible!important}
  .panel.active{display:block!important}
  .panel.active.grid-panel{display:block!important}

  /* ── GRIDS → SINGLE COLUMN ── */
  .bb-grid-4,
  .bb-grid-overview,
  .bb-grid-3,
  .bb-grid-stocks,
  .bb-grid-crypto,
  .bb-grid-chart,
  .bb-grid-screener,
  .bb-grid-politics{
    display:flex!important;flex-direction:column;gap:3px;height:auto!important
  }
  .bb-col{min-height:auto;overflow:visible}
  .bb-col .bb-box{flex:none;min-height:auto}
  .span2,.span3{grid-column:auto}

  /* ── BOXES ───────── */
  .bb-box{margin-bottom:3px;min-height:auto!important}
  .bb-body{overflow-y:visible;max-height:none}
  #pol-trade-rankings,#pol-watchlist,#pol-filings-list,#pol-detail{max-height:none;overflow-y:visible}
  .flex-chart{height:250px!important;min-height:250px;max-height:250px;overflow:hidden}
  .flex-chart canvas{max-height:220px!important}
  .bb-hdr{font-size:9px;padding:3px 6px;gap:4px}
  .bb-hdr b{min-width:14px;font-size:9px}

  /* ── DATA TABLE ──── */
  .data-table{font-size:9.5px}
  .data-table th{font-size:8px;padding:3px 4px}
  .data-table td{padding:2px 4px;font-size:9px}
  .data-table thead th{position:sticky;top:0;z-index:2}

  /* ── ROWS ─────────── */
  .bb-row{font-size:10px;padding:3px 6px;gap:4px}
  .bb-row .val{min-width:58px;font-size:10px}
  .bb-row .chg{min-width:46px;font-size:10px}

  /* ── EQUITY DETAIL ── */
  .eq-price{font-size:24px}
  .eq-change{font-size:14px}
  .eq-stats{grid-template-columns:repeat(3,1fr)}
  .eq-stat .lbl{font-size:8px}
  .eq-stat .val{font-size:10px}
  .keystats-grid{grid-template-columns:repeat(2,1fr)}
  .ks-item .lbl{font-size:8px}
  .ks-item .val{font-size:10px}
  .eq-news-wide{max-height:none}
  .analyst-grid{grid-template-columns:1fr}
  .analyst-summary{gap:8px;font-size:9px;flex-direction:column}

  /* ── CHART ────────── */
  .chart-toolbar2{padding:3px 6px;gap:3px}
  .chart-infobar{padding:3px 6px;gap:8px;font-size:9px}
  .chart-canvas-wrap{min-height:200px}
  .chart-inp{width:70px;font-size:11px}

  /* ── SECTORS ──────── */
  .sector-grid{grid-template-columns:repeat(2,1fr)}
  .sec-chg{font-size:11px}

  /* ── BONDS ────────── */
  .bbond-row{grid-template-columns:1fr auto auto auto;font-size:10px;gap:3px}
  .bbond-row:nth-child(n) > *:nth-child(5){display:none}

  /* ── FOREX ────────── */
  #fx-heatmap{grid-template-columns:repeat(5,1fr);font-size:9px}
  .fx-cell{padding:4px 2px;font-size:9px}

  /* ── CRYPTO ────────── */
  .stat-grid-4{grid-template-columns:repeat(2,1fr)}
  .spark-cell{width:50px;height:20px}

  /* ── BREADTH ──────── */
  .breadth-grid{grid-template-columns:repeat(2,1fr)}
  .breadth-cell .val{font-size:12px}

  /* ── OPTIONS ──────── */
  #options-expiries{padding:4px 6px;gap:2px}
  .exp-btn{font-size:8px;padding:2px 5px}

  /* ── SCREENER ─────── */
  .screener-filters{gap:6px;padding:6px}
  .sf-g label{font-size:8px}
  .sf-g select{font-size:9px;padding:2px 4px}
  .scr-run,.scr-reset{font-size:9px;padding:4px 10px}

  /* ── PORTFOLIO ────── */
  .port-stat-row{font-size:10px}

  /* ── ALERTS ────────── */
  .alert-row{font-size:10px;gap:4px;padding:4px 6px}
  .session-row{font-size:10px;gap:6px;padding:4px 6px}

  /* ── EARNINGS ──────── */
  .earn-row{grid-template-columns:60px 1fr auto auto;font-size:9px;gap:4px}
  .earn-row > *:last-child{display:none}

  /* ── NEWS ─────────── */
  .news-item{padding:5px 8px}
  .news-meta{font-size:8px}
  .news-title{font-size:10px}

  /* ── STATUS BAR ──── */
  #statusbar{font-size:8px;padding:0 4px;gap:4px}
  .sb-i{gap:3px;font-size:8px}

  /* ── NEWS READER ─── */
  .nr-toolbar{padding:4px 8px;gap:4px;flex-wrap:wrap}
  .nr-title{font-size:10px}
  .nr-btn{font-size:9px;padding:2px 6px}
  .nr-url{font-size:8px;padding:2px 8px}

  /* ── DIAGNOSTICS ─── */
  .diag-header{padding:6px 8px}
  .diag-title{font-size:10px}
  .diag-summary{padding:6px 8px;gap:10px;font-size:10px}
  .diag-body{padding:6px 8px}
  .diag-item{grid-template-columns:1fr auto auto;font-size:9px;gap:4px}
  .diag-item .di-src{display:none}
  .diag-module-hdr{font-size:9px}

  /* ── CONVERTER ───── */
  .conv-result{font-size:16px}
  #conv-rates-table{columns:1;font-size:9px}

  /* ── MISC ─────────── */
  .small-inp{font-size:9px;padding:2px 4px}
  .small-btn{font-size:9px;padding:2px 6px}
  .conv-sel{font-size:9px}
  .inl-tabs span,.bct,.btab,.bper,.cfilt,.nfilt,.ecofilt,.per,.ctype{font-size:8px;padding:2px 5px}
  .eq-quick{font-size:10px;padding:3px 8px}

  /* ── TRADE BAL / IPO / MNA ── */
  .tb-econ-row{font-size:10px}
  .ipo-row{font-size:9px;flex-wrap:wrap}
  .mna-row{font-size:10px}

  /* ── SHORT INT ───── */
  .short-row td{font-size:9px;padding:2px 3px}
  .stab{font-size:8px;padding:1px 4px}

  /* ── POLITICAL DESK ── */
  .pol-grid{display:flex!important;flex-direction:column;gap:3px;height:auto!important}

  /* ── ANALYTICS OVERLAY ── */
  .diag-overlay{overflow-y:auto}
}

/* ═══════════════════════════════════════════════════════
   VERY SMALL SCREENS ≤ 480px
   ═══════════════════════════════════════════════════════ */
@media(max-width:480px){
  .tb-logo{font-size:12px}
  .boot-logo{font-size:34px}
  .eq-price{font-size:20px}
  .eq-change{font-size:12px}
  .eq-stats{grid-template-columns:repeat(2,1fr)}
  .sector-grid{grid-template-columns:repeat(2,1fr)}
  #fx-heatmap{grid-template-columns:repeat(4,1fr)}
  .tab{font-size:7px;padding:2px 6px}
}
