:root {
  --bg-base:      #060c14;
  --bg-surface:   #0a1220;
  --bg-card:      #111128;
  --bg-elevated:  #111f30;
  --bg-highlight: #162540;
  --border:       rgba(32,90,150,0.22);
  --border-hi:    rgba(32,90,150,0.48);
  --accent:       #1a8cff;
  --accent-dim:   rgba(26,140,255,0.13);
  --green:        #00e676;
  --green-dim:    rgba(0,230,118,0.10);
  --red:          #ff3d57;
  --red-dim:      rgba(255,61,87,0.10);
  --amber:        #ffab00;
  --amber-dim:    rgba(255,171,0,0.10);
  --purple:       #c476ff;
  --purple-dim:   rgba(196,118,255,0.10);
  --teal:         #00bcd4;
  --text-a:       #cdd8e5;
  --text-b:       #5a7a9a;
  --text-c:       #1e3a5a;
  --text-hi:      #e8f0f8;
  --mono:         'IBM Plex Mono', monospace;
  --sans:         'Barlow Semi Condensed', sans-serif;
  /* Theme tokens */
  --bg-primary:   #0a0a1a;
  --bg-secondary: #0d0d20;
  --text-primary: #e0e0e0;
  --text-secondary: #888;
  --accent-green: #00ff88;
  --border-color: #1a1a35;
  --row-border:   var(--row-border);
  --overlay-bg:   var(--overlay-bg);
}
[data-theme="light"] {
  --bg-primary:   #f4f5f7;
  --bg-secondary: #ffffff;
  --bg-card:      #ffffff;
  --text-primary: #1a1a2e;
  --text-secondary: #555577;
  --accent-green: #00aa55;
  --border-color: #dde0ee;
  /* Override core palette */
  --bg-base:      #f4f5f7;
  --bg-surface:   #ffffff;
  --bg-elevated:  #eef0f6;
  --bg-highlight: #e4e7f0;
  --border:       rgba(100,110,160,0.22);
  --border-hi:    rgba(100,110,160,0.48);
  --text-a:       #1a1a2e;
  --text-b:       #555577;
  --text-c:       #8888aa;
  --text-hi:      #0a0a1a;
  --green:        #009955;
  --green-dim:    rgba(0,153,85,0.10);
  --red:          #d42040;
  --red-dim:      rgba(212,32,64,0.10);
  --amber:        #cc8800;
  --amber-dim:    rgba(204,136,0,0.10);
  --accent-dim:   rgba(26,140,255,0.10);
  --row-border:   rgba(100,110,160,0.10);
  --overlay-bg:   rgba(244,245,247,0.92);
}
*{margin:0;padding:0;box-sizing:border-box;transition:background-color 0.25s,color 0.25s,border-color 0.25s;}
body{background:var(--bg-base);color:var(--text-a);font-family:var(--sans);font-size:13px;height:100vh;overflow:hidden;display:flex;flex-direction:column;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:var(--bg-base);}
::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:2px;}

/* ─── TOP BAR ───────────────────────────────────────────── */
.topbar{display:flex;align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border);height:44px;padding:0 14px;gap:18px;flex-shrink:0;}
.logo{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--accent);letter-spacing:2px;white-space:nowrap;}
.logo span{color:var(--text-b);}
.acct-stats{display:flex;gap:16px;align-items:center;}
.stat{display:flex;flex-direction:column;gap:1px;}
.stat-lbl{font-size:9px;color:var(--text-b);letter-spacing:1px;text-transform:uppercase;}
.stat-val{font-family:var(--mono);font-size:13px;color:var(--text-hi);font-weight:500;}
.stat-val.pos{color:var(--green);}
.stat-val.neg{color:var(--red);}
.divider{width:1px;height:26px;background:var(--border);}
.mode-tabs{display:flex;gap:2px;margin-left:auto;}
.mtab{padding:5px 12px;font-size:11px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;color:var(--text-b);background:transparent;border:1px solid transparent;border-radius:3px;cursor:pointer;transition:all 0.15s;font-family:var(--sans);white-space:nowrap;}
.mtab:hover{color:var(--text-a);background:var(--bg-card);}
.mtab.active{color:var(--accent);background:var(--accent-dim);border-color:rgba(26,140,255,0.28);}
.mtab.sw.active{color:var(--teal);background:rgba(0,188,212,0.1);border-color:rgba(0,188,212,0.28);}
.mtab.dt.active{color:var(--amber);background:var(--amber-dim);border-color:rgba(255,171,0,0.28);}
.mtab.op.active{color:var(--purple);background:var(--purple-dim);border-color:rgba(196,118,255,0.28);}
.mtab.rk.active{color:var(--red);background:var(--red-dim);border-color:rgba(255,61,87,0.28);}
.mtab.ap.active{color:#00e676;background:rgba(0,230,118,0.1);border-color:rgba(0,230,118,0.28);}
.mtab.pf.active{color:#c476ff;background:rgba(196,118,255,0.1);border-color:rgba(196,118,255,0.28);}
.topright{display:flex;align-items:center;gap:10px;margin-left:14px;}
.mkt-status{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:1px;}
.sdot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.35;}}
.clock{font-family:var(--mono);font-size:12px;color:var(--text-b);}
.hdr-pill{height:22px;padding:0 9px;background:transparent;border:1px solid var(--border-hi);border-radius:11px;color:var(--text-b);cursor:pointer;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:0.5px;white-space:nowrap;line-height:22px;}
.hdr-pill:hover{background:var(--bg-elevated);color:var(--text-a);border-color:var(--accent);}
.alert-cnt{width:16px;height:16px;background:var(--red);border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;}

/* ─── TICKER TAPE ────────────────────────────────────────── */
.ticker-tape{background:var(--bg-surface);border-bottom:1px solid var(--border);height:28px;overflow:hidden;display:flex;align-items:center;flex-shrink:0;}
.tape-label{padding:0 10px;font-size:9px;font-weight:700;letter-spacing:2px;color:var(--accent);border-right:1px solid var(--border);height:100%;display:flex;align-items:center;background:var(--bg-surface);z-index:2;white-space:nowrap;}
.tape-track{overflow:hidden;flex:1;}
.tape-scroll{display:flex;animation:tape-move 55s linear infinite;white-space:nowrap;}
@keyframes tape-move{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.ti{display:flex;align-items:center;gap:7px;padding:0 16px;border-right:1px solid var(--border);height:28px;}
.ti-name{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--text-a);}
.ti-price{font-family:var(--mono);font-size:11px;color:var(--text-hi);}
.ti-chg{font-family:var(--mono);font-size:10px;}
.up{color:var(--green);}
.dn{color:var(--red);}

/* ─── MAIN ───────────────────────────────────────────────── */
.main{display:flex;flex:1;overflow:hidden;}
.tab{display:none;flex:1;overflow:hidden;}
.tab.active{display:grid;}

/* ─── INSTITUTIONAL ──────────────────────────────────────── */
#t-inst.active{grid-template-columns:236px 1fr 276px;grid-template-rows:1fr 200px;gap:1px;background:var(--border);}
/* ─── MACRO ──────────────────────────────────────────────── */
#t-macro.active{grid-template-columns:300px 1fr 290px;grid-template-rows:1fr 190px;gap:1px;background:var(--border);}
/* ─── SWING ──────────────────────────────────────────────── */
#t-swing.active{grid-template-columns:256px 1fr 272px;grid-template-rows:1fr 180px;gap:1px;background:var(--border);}
/* ─── DAY TRADE ──────────────────────────────────────────── */
#t-day.active{grid-template-columns:214px 1fr 252px;grid-template-rows:56% 44%;gap:1px;background:var(--border);}
/* ─── OPTIONS ────────────────────────────────────────────── */
#t-opt.active{grid-template-columns:1fr 310px;grid-template-rows:1fr 200px;gap:1px;background:var(--border);}
/* ─── RISK ───────────────────────────────────────────────── */
#t-risk.active{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr auto;gap:1px;background:var(--border);}
/* ─── AUTO ───────────────────────────────────────────────── */
#t-auto.active{display:flex;flex-direction:column;flex:1;overflow:hidden;}
#t-auto.active .panel.span3c{flex:1;display:flex;flex-direction:column;}
#t-port.active{display:flex;flex-direction:column;flex:1;overflow:hidden;}
#ap-output { font-size: 11px; }
#ap-output .tm-section { padding: 12px 14px; margin-bottom: 10px; border-radius: 4px; }
/* ─── EARNINGS ───────────────────────────────────────────── */
#t-earn.active{grid-template-columns:1fr 1fr;grid-template-rows:1fr 180px;gap:1px;background:var(--border);}

/* ─── PANEL ──────────────────────────────────────────────── */
.panel{background:var(--bg-card);display:flex;flex-direction:column;overflow:hidden;}
.ph{display:flex;align-items:center;padding:0 11px;height:30px;border-bottom:1px solid var(--border);gap:7px;flex-shrink:0;background:var(--bg-elevated);}
.ph-title{font-size:10px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-b);}
.badge{font-family:var(--mono);font-size:9px;padding:1px 5px;border-radius:2px;font-weight:600;}
.b-demo{background:var(--amber-dim);color:var(--amber);}
.b-live{background:var(--green-dim);color:var(--green);}
.b-api{background:var(--accent-dim);color:var(--accent);}
.ph-actions{margin-left:auto;display:flex;gap:5px;}
.pbtn{width:20px;height:18px;background:transparent;border:1px solid var(--border);border-radius:2px;color:var(--text-b);cursor:pointer;font-size:9px;display:flex;align-items:center;justify-content:center;transition:all 0.1s;}
.pbtn:hover{background:var(--bg-highlight);color:var(--text-a);border-color:var(--border-hi);}
.api-dot{width:6px;height:6px;border-radius:50%;background:var(--amber);}
.api-dot.ok{background:var(--green);}
.api-dot.err{background:var(--red);}
.pc{flex:1;overflow-y:auto;overflow-x:hidden;}
.pf{height:20px;border-top:1px solid var(--border);display:flex;align-items:center;padding:0 11px;gap:8px;font-size:9px;color:var(--text-b);font-family:var(--mono);flex-shrink:0;background:var(--bg-elevated);}

/* ─── WATCHLIST ──────────────────────────────────────────── */
.wl-hdr,.wl-row{display:grid;grid-template-columns:50px 1fr 68px 56px 46px;padding:4px 9px;gap:3px;align-items:center;}
.wl-hdr{border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-elevated);z-index:1;}
.wl-hdr span{font-size:9px;font-weight:700;letter-spacing:1px;color:var(--text-b);text-transform:uppercase;}
.wl-row{border-bottom:1px solid var(--row-border);cursor:pointer;transition:background 0.1s;padding:5px 9px;}
.wl-row:hover{background:var(--bg-elevated);}
.wl-row.sel{background:var(--accent-dim);border-left:2px solid var(--accent);}
.wt{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent);}
.wn{font-size:10px;color:var(--text-b);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.wp{font-family:var(--mono);font-size:12px;font-weight:500;text-align:right;}
.wc{font-family:var(--mono);font-size:11px;text-align:right;}
.sig{font-size:9px;font-weight:700;padding:2px 4px;border-radius:2px;text-align:center;letter-spacing:0.3px;}
.s-buy{background:var(--green-dim);color:var(--green);}
.s-sell{background:var(--red-dim);color:var(--red);}
.s-hold{background:rgba(90,122,154,0.13);color:var(--text-b);}
.s-watch{background:var(--amber-dim);color:var(--amber);}

/* ─── SEARCH BAR ─────────────────────────────────────────── */
.sbar{display:flex;align-items:center;gap:7px;padding:0 9px;height:30px;border-bottom:1px solid var(--border);flex-shrink:0;}
.sbar input{flex:1;background:transparent;border:none;outline:none;font-family:var(--mono);font-size:12px;color:var(--text-a);}
.sbar input::placeholder{color:var(--text-c);}

/* ─── INNER TABS ─────────────────────────────────────────── */
.itabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;}
.itab{padding:5px 11px;font-size:10px;font-weight:600;letter-spacing:0.4px;color:var(--text-b);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.12s;}
.itab:hover{color:var(--text-a);}
.itab.on{color:var(--accent);border-bottom-color:var(--accent);}

/* ─── FW TABS ────────────────────────────────────────────── */
.fw-tabs{display:flex;overflow-x:auto;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;}
.fw-tab{padding:7px 12px;font-size:10px;font-weight:600;letter-spacing:0.4px;color:var(--text-b);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all 0.12px;}
.fw-tab:hover{color:var(--text-a);}
.fw-tab.on{color:var(--accent);border-bottom-color:var(--accent);}
.fw-pane{display:none;padding:11px;}
.fw-pane.on{display:block;}
.fw-hdr{display:flex;align-items:center;gap:9px;margin-bottom:11px;padding-bottom:9px;border-bottom:1px solid var(--border);}
.fw-num{width:26px;height:26px;background:var(--accent-dim);border:1px solid rgba(26,140,255,0.28);border-radius:3px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent);}
.fw-inst{font-size:9px;color:var(--text-b);letter-spacing:1px;}
.fw-role{font-size:12px;font-weight:600;color:var(--text-hi);}

/* ─── TABLES ─────────────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:10px;}
.tbl th{text-align:right;padding:3px 7px;font-size:9px;letter-spacing:0.8px;color:var(--text-b);border-bottom:1px solid var(--border);font-weight:700;background:var(--bg-elevated);}
.tbl th:first-child{text-align:left;}
.tbl td{padding:5px 7px;border-bottom:1px solid var(--row-border);text-align:right;}
.tbl td:first-child{text-align:left;color:var(--accent);font-weight:600;}
.tbl tr:hover td{background:var(--bg-elevated);}
.sh{color:var(--green);}
.sm{color:var(--amber);}
.sl{color:var(--red);}

/* ─── INFO BLOCK ─────────────────────────────────────────── */
.ib{background:var(--bg-elevated);border:1px solid var(--border);border-radius:3px;padding:9px;margin:0 0 8px;}
.ib-title{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-b);margin-bottom:6px;}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:5px 14px;}
.kv-i{display:flex;flex-direction:column;gap:1px;}
.kv-k{font-size:9px;color:var(--text-b);letter-spacing:0.4px;}
.kv-v{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--text-hi);}

/* ─── FACTOR BARS ────────────────────────────────────────── */
.fbar{margin:6px 0;}
.fbar-lbl{display:flex;justify-content:space-between;font-size:10px;margin-bottom:2px;}
.fbar-lbl span:first-child{color:var(--text-b);}
.fbar-lbl span:last-child{font-family:var(--mono);color:var(--text-a);}
.fbar-trk{height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden;}
.fbar-fill{height:100%;border-radius:2px;transition:width 0.5s ease;}

/* ─── POSITIONS ──────────────────────────────────────────── */
.pos-hdr,.pos-row{display:grid;grid-template-columns:50px 50px 62px 62px 62px 52px 1fr;padding:4px 9px;gap:3px;align-items:center;font-family:var(--mono);font-size:11px;}
.pos-hdr{border-bottom:1px solid var(--border);background:var(--bg-elevated);}
.pos-hdr span{font-size:9px;font-weight:700;letter-spacing:1px;color:var(--text-b);text-transform:uppercase;}
.pos-hdr span:not(:first-child){text-align:right;}
.pos-row{border-bottom:1px solid var(--row-border);}
.pos-row div:not(:first-child){text-align:right;}
.ptk{color:var(--accent);font-weight:700;}
.plong{color:var(--green);font-size:9px;}
.pshort{color:var(--red);font-size:9px;}

/* ─── SIGNAL ITEMS ───────────────────────────────────────── */
.sig-item{display:flex;align-items:flex-start;gap:9px;padding:7px 11px;border-bottom:1px solid var(--row-border);cursor:pointer;transition:background 0.1s;}
.sig-item:hover{background:var(--bg-elevated);}
.sig-ico{width:26px;height:26px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;}
.ico-buy{background:var(--green-dim);}
.ico-sell{background:var(--red-dim);}
.ico-watch{background:var(--amber-dim);}
.ico-info{background:var(--accent-dim);}
.sig-body{flex:1;}
.sig-title{font-size:11px;font-weight:600;color:var(--text-hi);margin-bottom:2px;}
.sig-desc{font-size:10px;color:var(--text-b);line-height:1.4;}
.sig-meta{display:flex;gap:7px;margin-top:3px;}
.stag{font-size:9px;padding:1px 4px;border-radius:2px;background:var(--accent-dim);color:var(--accent);font-family:var(--mono);}
.stime{font-family:var(--mono);font-size:9px;color:var(--text-b);}

/* ─── RISK METRICS GRID ──────────────────────────────────── */
.rm-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.rm{background:var(--bg-card);padding:11px;}
.rm-lbl{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-b);margin-bottom:5px;}
.rm-val{font-family:var(--mono);font-size:18px;font-weight:600;color:var(--text-hi);}
.rm-val.neg{color:var(--red);}
.rm-val.pos{color:var(--green);}
.rm-sub{font-family:var(--mono);font-size:9px;color:var(--text-b);margin-top:1px;}

/* ─── MACRO ROWS ─────────────────────────────────────────── */
.mrow{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--row-border);}
.mrow:last-child{border-bottom:none;}
.mkey{font-size:11px;color:var(--text-b);}
.mval{font-family:var(--mono);font-size:11px;font-weight:500;}

/* ─── REGIME BADGE ───────────────────────────────────────── */
.regime{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:3px;font-size:11px;font-weight:700;letter-spacing:0.8px;margin:6px 0;}
.r-gold{background:var(--green-dim);color:var(--green);border:1px solid rgba(0,230,118,0.28);}
.r-hot{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(255,171,0,0.28);}
.r-stag{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,61,87,0.28);}
.r-def{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(196,118,255,0.28);}

/* ─── CALENDAR ───────────────────────────────────────────── */
.cal-item{display:flex;align-items:center;gap:9px;padding:5px 11px;border-bottom:1px solid var(--row-border);}
.cal-t{font-family:var(--mono);font-size:10px;color:var(--text-b);width:42px;flex-shrink:0;}
.cal-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.ch{background:var(--red);}
.cm{background:var(--amber);}
.cl{background:var(--text-c);}
.cal-ev{font-size:11px;color:var(--text-a);}
.cal-ac{font-family:var(--mono);font-size:10px;margin-left:auto;}
.cal-es{font-family:var(--mono);font-size:9px;color:var(--text-b);}

/* ─── SECTOR HEATMAP ─────────────────────────────────────── */
.sheat{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding:9px;}
.sc{padding:7px;border-radius:2px;cursor:pointer;transition:filter 0.12s;}
.sc:hover{filter:brightness(1.2);}
.sc-n{font-size:9px;font-weight:700;letter-spacing:0.4px;opacity:0.9;margin-bottom:3px;}
.sc-p{font-family:var(--mono);font-size:13px;font-weight:600;}

/* ─── YIELD CURVE ────────────────────────────────────────── */
.yc{padding:11px;}
.yc-chart{height:110px;display:flex;align-items:flex-end;gap:3px;margin:10px 0;}
.yc-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;}
.yc-bar{width:100%;border-radius:2px 2px 0 0;transition:height 0.4s ease;}
.yc-norm{background:linear-gradient(to top,var(--accent),rgba(26,140,255,0.3));}
.yc-inv{background:linear-gradient(to top,var(--red),rgba(255,61,87,0.3));}
.yc-lbl{font-family:var(--mono);font-size:8px;color:var(--text-b);}
.yc-val{font-family:var(--mono);font-size:9px;font-weight:500;}

/* ─── VIX STRIP ──────────────────────────────────────────── */
.vix-strip{display:flex;gap:2px;align-items:flex-end;height:55px;padding:3px 0;}
.vs-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;}
.vs-bar{width:100%;border-radius:2px 2px 0 0;}
.vs-lbl{font-family:var(--mono);font-size:8px;color:var(--text-b);}
.vs-val{font-family:var(--mono);font-size:9px;font-weight:600;}

/* ─── LEVELS ─────────────────────────────────────────────── */
.lvl{display:flex;align-items:center;padding:4px 11px;gap:9px;border-bottom:1px solid var(--row-border);}
.lvl-lbl{font-size:10px;color:var(--text-b);flex:1;}
.lvl-p{font-family:var(--mono);font-size:12px;font-weight:500;}
.lvl-t{font-size:9px;padding:1px 4px;border-radius:2px;font-weight:700;}
.lt-r{background:rgba(0,230,118,0.09);color:var(--green);}
.lt-s{background:rgba(255,61,87,0.09);color:var(--red);}
.lt-v{background:var(--accent-dim);color:var(--accent);}

/* ─── MARKET INTERNALS ───────────────────────────────────── */
.mi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.mi{background:var(--bg-card);padding:9px 11px;}
.mi-lbl{font-size:9px;letter-spacing:1px;color:var(--text-b);text-transform:uppercase;margin-bottom:3px;}
.mi-val{font-family:var(--mono);font-size:15px;font-weight:600;}
.mi-sub{font-size:9px;color:var(--text-b);margin-top:1px;}

/* ─── CHART PLACEHOLDER ──────────────────────────────────── */
.chart-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;color:var(--text-b);}
.chart-ph .ico{font-size:22px;opacity:0.25;}
.chart-ph .lbl{font-size:10px;letter-spacing:1px;opacity:0.4;}
.chart-ph .note{font-family:var(--mono);font-size:9px;color:var(--accent);opacity:0.55;padding:3px 7px;border:1px dashed rgba(26,140,255,0.28);border-radius:2px;}
.chart-ph .sub{font-size:10px;color:var(--text-b);text-align:center;max-width:280px;line-height:1.5;}

/* ─── SETUP ITEMS ────────────────────────────────────────── */
.setup{padding:9px 11px;border-bottom:1px solid var(--row-border);cursor:pointer;transition:background 0.1s;}
.setup:hover{background:var(--bg-elevated);}
.setup-top{display:flex;align-items:center;gap:7px;margin-bottom:4px;}
.stk{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--accent);}
.stype{font-size:9px;font-weight:700;padding:1px 5px;border-radius:2px;letter-spacing:0.3px;}
.st-bo{background:var(--green-dim);color:var(--green);}
.st-pb{background:var(--amber-dim);color:var(--amber);}
.st-rv{background:var(--purple-dim);color:var(--purple);}
.st-er{background:var(--accent-dim);color:var(--accent);}
.s-metrics{display:flex;gap:14px;font-family:var(--mono);font-size:10px;color:var(--text-b);}
.s-metrics span{display:flex;flex-direction:column;gap:1px;}
.s-metrics span b{color:var(--text-a);font-size:11px;}

/* ─── OPTIONS CHAIN ──────────────────────────────────────── */
.oc-hdr,.oc-row{display:grid;grid-template-columns:repeat(6,1fr) 76px repeat(6,1fr);padding:3px 7px;font-family:var(--mono);font-size:10px;}
.oc-hdr{background:var(--bg-elevated);border-bottom:1px solid var(--border);}
.oc-hdr span{font-size:9px;font-weight:700;color:var(--text-b);text-align:center;}
.oc-row{border-bottom:1px solid var(--row-border);cursor:pointer;}
.oc-row:hover{background:var(--bg-elevated);}
.oc-row.atm{background:rgba(26,140,255,0.04);}
.oc-cell{text-align:center;color:var(--text-b);}
.oc-call{color:var(--green);}
.oc-put{color:var(--red);}
.oc-strike{font-weight:700;color:var(--text-a);text-align:center;background:rgba(26,140,255,0.08);border-radius:2px;}
.atm-strike{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(26,140,255,0.28);font-weight:700;text-align:center;border-radius:2px;font-family:var(--mono);font-size:10px;}

/* ─── TIME & SALES ───────────────────────────────────────── */
.ts-hdr,.ts-row{display:grid;grid-template-columns:58px 78px 58px 52px;padding:3px 8px;font-family:var(--mono);font-size:10px;gap:3px;}
.ts-hdr{border-bottom:1px solid var(--border);color:var(--text-b);font-size:9px;}
.ts-row{border-bottom:1px solid var(--row-border);}

/* ─── STATUS BAR ─────────────────────────────────────────── */
.stbar{height:21px;background:var(--bg-surface);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:18px;flex-shrink:0;}
.stitem{display:flex;align-items:center;gap:5px;font-size:9px;letter-spacing:0.4px;color:var(--text-b);}
.stitem.ok{color:var(--green);}
.stitem.warn{color:var(--amber);}
.stitem.err{color:var(--red);}
.sdot-sm{width:5px;height:5px;border-radius:50%;background:currentColor;}

/* ─── API NOTE ───────────────────────────────────────────── */
.api-note{margin-top:9px;padding:7px 9px;border:1px dashed rgba(26,140,255,0.28);border-radius:2px;font-size:9px;color:var(--accent);font-family:var(--mono);}

/* ─── FLASH ANIMATION ────────────────────────────────────── */
@keyframes fup{0%{background:rgba(0,230,118,0.15);}100%{background:transparent;}}
@keyframes fdn{0%{background:rgba(255,61,87,0.15);}100%{background:transparent;}}
.flash-up{animation:fup 0.7s ease;}
.flash-dn{animation:fdn 0.7s ease;}

/* ─── FOOTBALL FIELD ─────────────────────────────────────── */
.ff-row{margin:3px 0;}
.ff-lbl{display:flex;justify-content:space-between;font-size:9px;color:var(--text-b);margin-bottom:2px;}
.ff-trk{height:7px;background:var(--bg-elevated);border-radius:2px;position:relative;}
.ff-bar{position:absolute;height:100%;border-radius:2px;opacity:0.72;}
.ff-cursor{position:absolute;top:-4px;width:2px;height:15px;background:rgba(255,255,255,0.7);}

/* ─── EARN TAB ───────────────────────────────────────────── */
#t-earn.active{align-items:stretch;}
.earn-center{display:flex;align-items:center;justify-content:center;flex:1;}

/* ─── SPAN HELPERS ───────────────────────────────────────── */
.span2c{grid-column:span 2;}
.span3c{grid-column:span 3;}
.span2r{grid-row:span 2;}

/* ─── TRADE MODAL ────────────────────────────────────────── */
.tm-open-btn{width:100%;margin-top:11px;padding:8px 0;background:var(--accent-dim);border:1px solid var(--accent);border-radius:2px;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:2px;color:var(--accent);cursor:pointer;text-transform:uppercase;transition:background 0.1s;}
.tm-open-btn:hover{background:rgba(26,140,255,0.20);}
.tm-overlay{position:fixed;inset:0;background:var(--overlay-bg);z-index:999;display:none;align-items:center;justify-content:center;}
.tm-overlay.open{display:flex;}
.tm-box{background:var(--bg-surface);border:1px solid var(--border-hi);border-radius:3px;width:340px;font-family:var(--mono);}
.tm-head{padding:11px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.tm-head-title{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text-a);}
.tm-close{background:transparent;border:none;color:var(--text-b);cursor:pointer;font-size:16px;line-height:1;padding:0;}
.tm-close:hover{color:var(--text-a);}
.tm-body{padding:14px;}
.tm-row{margin-bottom:11px;}
.tm-lbl{font-size:9px;letter-spacing:1px;color:var(--text-b);font-weight:700;text-transform:uppercase;margin-bottom:4px;}
.tm-ticker-disp{font-size:20px;font-weight:700;color:var(--accent);letter-spacing:3px;}
.tm-toggle{display:flex;gap:1px;background:var(--bg-elevated);border-radius:2px;overflow:hidden;border:1px solid var(--border);}
.tm-toggle button{flex:1;padding:5px 0;background:transparent;border:none;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:1px;cursor:pointer;color:var(--text-b);transition:all 0.1s;}
.tm-toggle button.on{background:var(--accent-dim);color:var(--accent);}
.tm-toggle button.on.sell-on{background:rgba(255,61,87,0.12);color:var(--red);}
.tm-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:2px;padding:6px 9px;font-family:var(--mono);font-size:12px;color:var(--text-a);outline:none;box-sizing:border-box;}
.tm-input:focus{border-color:var(--accent);}
.tm-est{font-size:11px;color:var(--text-b);}
.tm-est strong{color:var(--accent);}
.tm-paper-warn{padding:8px 10px;background:rgba(26,140,255,0.07);border:1px solid rgba(26,140,255,0.22);border-radius:2px;font-size:11px;font-weight:700;color:var(--accent);text-align:center;letter-spacing:0.5px;margin-bottom:11px;}
.tm-actions{display:flex;gap:8px;}
.tm-btn-cancel{flex:1;padding:8px;background:transparent;border:1px solid var(--border);border-radius:2px;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:1px;color:var(--text-b);cursor:pointer;}
.tm-btn-cancel:hover{background:var(--bg-elevated);}
.tm-btn-confirm{flex:2;padding:8px;background:var(--accent-dim);border:1px solid var(--accent);border-radius:2px;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:1px;color:var(--accent);cursor:pointer;transition:background 0.1s;}
.tm-btn-confirm:hover{background:rgba(26,140,255,0.20);}
.tm-btn-confirm.sell-mode{background:rgba(255,61,87,0.10);border-color:var(--red);color:var(--red);}
.tm-btn-confirm.sell-mode:hover{background:rgba(255,61,87,0.20);}
.tm-btn-confirm:disabled{opacity:0.5;cursor:not-allowed;}
/* ─── TOAST ──────────────────────────────────────────────── */
.ws-toast{position:fixed;bottom:36px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--bg-elevated);border:1px solid var(--border-hi);border-radius:3px;padding:9px 20px;font-family:var(--mono);font-size:11px;color:var(--text-a);z-index:1001;opacity:0;transition:opacity 0.18s,transform 0.18s;pointer-events:none;white-space:nowrap;}
.ws-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.ws-toast.ok{border-color:var(--green);color:var(--green);}
.ws-toast.err{border-color:var(--amber);color:var(--amber);}

/* ─── BACKTEST ENGINE 🔬───────────────────────────────────── */
.bt-controls{display:flex;align-items:flex-end;gap:12px;padding:9px 11px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap;}
.bt-cg{display:flex;flex-direction:column;}
.bt-lbl{font-size:9px;color:var(--text-b);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:3px;}
.bt-inp,.bt-sel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:2px;padding:5px 8px;font-family:var(--mono);font-size:11px;color:var(--text-a);outline:none;color-scheme:dark;}
.bt-inp:focus,.bt-sel:focus{border-color:var(--accent);}
.bt-inp[type=text]{width:68px;text-transform:uppercase;}
.bt-inp[type=date]{width:128px;}
.bt-inp[type=date]::-webkit-calendar-picker-indicator{filter:invert(0.4) brightness(1.4);}
.bt-sel{width:270px;cursor:pointer;}
.bt-run{padding:6px 18px;background:var(--accent-dim);border:1px solid var(--accent);border-radius:2px;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--accent);cursor:pointer;white-space:nowrap;transition:background 0.1s;}
.bt-run:hover{background:rgba(26,140,255,0.20);}
.bt-run:disabled{opacity:0.45;cursor:not-allowed;}
.bt-status{font-size:9px;color:var(--text-b);font-family:var(--mono);max-width:220px;}
.bt-body{display:flex;flex:1;overflow:hidden;min-height:0;}
.bt-metrics{width:252px;flex-shrink:0;border-right:1px solid var(--border);padding:10px 11px;overflow-y:auto;}
.bt-chart-area{flex:1;display:flex;flex-direction:column;padding:9px 11px;min-width:0;}
.bt-chart-wrap{flex:1;position:relative;min-height:168px;}
.bt-chart-wrap canvas{position:absolute;inset:0;}
.bt-stat{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0;border-bottom:1px solid var(--row-border);}
.bt-stat-k{font-size:10px;color:var(--text-b);}
.bt-stat-v{font-family:var(--mono);font-size:11px;font-weight:600;}
.bt-sec{font-size:9px;font-weight:700;letter-spacing:1px;color:var(--text-b);text-transform:uppercase;margin:0 0 6px;}
.bt-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-c);font-size:10px;letter-spacing:1px;}
.fw-ai-out{margin-top:10px;padding:10px 12px;background:rgba(26,140,255,0.06);border-left:3px solid var(--accent);border-radius:2px;font-size:11px;color:var(--text-a);line-height:1.6;white-space:pre-wrap;font-family:var(--mono);}
.fw-ai-out .ai-buy{color:var(--green);font-weight:700;}
.fw-ai-out .ai-sell{color:var(--red);font-weight:700;}
.fw-ai-out .ai-hold{color:var(--amber);font-weight:700;}
.fw-ai-out .ai-head{color:var(--accent);font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:10px;display:block;margin-bottom:4px;}
.fw-ai-loading{display:flex;align-items:center;gap:8px;color:var(--accent);font-size:11px;padding:10px 0;}
.fw-ai-loading::before{content:'';display:inline-block;width:10px;height:10px;border:2px solid var(--accent);border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ─── MONEY OPTIMIZER ────────────────────────────────────── */
.opt-lbl{font-size:9px;font-weight:700;letter-spacing:1px;color:var(--text-b);text-transform:uppercase;margin-bottom:3px;}
.opt-result-head{display:flex;gap:12px;margin-bottom:8px;flex-wrap:wrap;}
.opt-kv{display:flex;flex-direction:column;gap:1px;}
.opt-kv-k{font-size:9px;color:var(--text-b);letter-spacing:0.4px;}
.opt-kv-v{font-family:var(--mono);font-size:14px;font-weight:700;}
.opt-verdict{padding:5px 9px;border-radius:2px;font-size:10px;font-weight:700;letter-spacing:0.4px;margin-bottom:8px;}
.opt-valid{background:var(--green-dim);color:var(--green);border:1px solid rgba(0,230,118,0.28);}
.opt-reject{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,61,87,0.28);}
.opt-bars{display:flex;flex-direction:column;gap:4px;}
.opt-bar-row{display:flex;align-items:center;gap:6px;}
.opt-bar-lbl{font-family:var(--mono);font-size:10px;color:var(--text-b);min-width:28px;text-align:right;}
.opt-bar-trk{flex:1;height:6px;background:var(--bg-highlight);border-radius:3px;overflow:hidden;}
.opt-bar-fill{height:100%;border-radius:3px;transition:width 0.4s ease;}
.opt-bar-val{font-family:var(--mono);font-size:9px;min-width:34px;text-align:right;}
/* AUTO-TRAINER */
.train-phase{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;}
.train-phase-num{width:24px;height:24px;border-radius:50%;border:2px solid var(--border-hi);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;font-weight:700;color:var(--text-c);background:var(--bg-elevated);}
.train-phase-lbl{font-size:8px;color:var(--text-c);letter-spacing:0.3px;text-align:center;white-space:nowrap;}
.train-phase.active .train-phase-num{border-color:var(--amber);color:var(--amber);background:rgba(255,170,0,0.1);}
.train-phase.active .train-phase-lbl{color:var(--amber);}
.train-phase.done .train-phase-num{border-color:var(--green);color:var(--green);background:rgba(0,230,118,0.08);}
.train-phase.done .train-phase-lbl{color:var(--green);}
.train-phase-connector{height:2px;flex:1;background:var(--border);align-self:center;margin:0 4px;margin-top:-14px;}
