*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#070910;--s1:#0c0e18;--s2:#111520;--s3:#161a28;
  --ln:rgba(255,255,255,.07);--lnh:rgba(255,255,255,.13);
  --g:#00d68f;--gd:rgba(0,214,143,.1);--gg:rgba(0,214,143,.25);
  --r:#f5445c;--rd:rgba(245,68,92,.1);
  --y:#f0b90b;--b:#3b9eff;--bd:rgba(59,158,255,.12);--bg2:rgba(59,158,255,.25);
  --p:#9d7ff4;--pd:rgba(157,127,244,.1);
  --tx:#dde1f0;--txd:#6070a0;--txm:#2d3555;
  --mono:'JetBrains Mono',monospace;--disp:'Syne',sans-serif;
}
html{font-size:14px;background:#070910;width:100%;height:100%}
body{margin:0;padding:0;background:#070910;color:var(--tx);font-family:var(--mono);min-height:100vh;width:100%;display:flex;flex-direction:column;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(var(--ln) 1px,transparent 1px),linear-gradient(90deg,var(--ln) 1px,transparent 1px);background-size:52px 52px;opacity:.4}
body>*{position:relative;z-index:1}

/* LOGIN */
#loginScreen{position:fixed;inset:0;background:var(--bg);z-index:999;display:flex;align-items:center;justify-content:center}
#loginScreen::before{content:'';position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(var(--ln) 1px,transparent 1px),linear-gradient(90deg,var(--ln) 1px,transparent 1px);background-size:52px 52px;opacity:.4}
.login-box{background:var(--s1);border:1px solid var(--ln);padding:40px;width:360px;position:relative;z-index:1}
.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:32px;justify-content:center}
.login-title{font-family:var(--disp);font-weight:800;font-size:1.4rem;letter-spacing:4px;color:#fff}
.login-sub{font-size:.52rem;letter-spacing:2px;color:var(--txd);text-transform:uppercase;text-align:center;margin-top:4px;margin-bottom:32px}
.login-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.login-label{font-size:.52rem;letter-spacing:2px;color:var(--txd);text-transform:uppercase}
.login-input{background:var(--s2);border:1px solid var(--ln);color:var(--tx);font-family:var(--mono);font-size:.85rem;padding:11px 14px;outline:none;width:100%;transition:border-color .15s}
.login-input:focus{border-color:rgba(0,214,143,.5)}
.login-btn{width:100%;background:var(--g);color:#000;font-family:var(--mono);font-size:.65rem;letter-spacing:3px;padding:12px;border:none;cursor:pointer;font-weight:700;text-transform:uppercase;margin-top:8px;transition:all .15s}
.login-btn:hover{background:#00ffaa;box-shadow:0 0 18px var(--gg)}
.login-btn:disabled{background:var(--txm);color:var(--txd);cursor:default}
.login-err{font-size:.6rem;color:var(--r);text-align:center;margin-top:10px;min-height:18px;letter-spacing:1px}
.login-saving{font-size:.55rem;color:var(--txd);text-align:center;margin-top:12px;letter-spacing:1px}

/* NAV */
nav{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;border-bottom:1px solid var(--ln);background:rgba(7,9,16,.97);backdrop-filter:blur(20px);position:sticky;top:0;z-index:200}
.nav-logo{display:flex;align-items:center;gap:14px}
.logo-txt{font-family:var(--disp);font-weight:800;font-size:1.15rem;letter-spacing:3px;color:#fff}
.logo-divider{width:1px;height:20px;background:var(--ln)}
.logo-sub{font-size:.57rem;letter-spacing:2px;color:var(--txd);text-transform:uppercase;line-height:1.5}
.nav-right{display:flex;align-items:center;gap:16px}
.st-badge{display:flex;align-items:center;gap:8px;font-size:.62rem;letter-spacing:1.5px;color:var(--txd);text-transform:uppercase}
.st-dot{width:7px;height:7px;border-radius:50%;background:var(--txm);flex-shrink:0;transition:all .3s}
.st-dot.ok{background:var(--g);box-shadow:0 0 10px var(--g)}
.st-dot.loading{background:var(--y);animation:blk .7s ease-in-out infinite}
.st-dot.err{background:var(--r)}
@keyframes blk{0%,100%{opacity:1}50%{opacity:.2}}

/* MODE BAR */
.mode-bar{display:flex;align-items:center;border-bottom:1px solid var(--ln);background:var(--s1);padding:0 32px;position:sticky;top:56px;z-index:190}
.mode-tab{display:flex;align-items:center;gap:9px;padding:13px 22px;font-size:.62rem;letter-spacing:2.5px;color:var(--txd);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;text-transform:uppercase;font-family:var(--mono);user-select:none}
.mode-tab:hover{color:var(--tx)}
.mode-tab.human.active{color:var(--g);border-bottom-color:var(--g)}
.mode-tab.ai.active{color:var(--b);border-bottom-color:var(--b)}
.mode-dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.5;transition:all .2s}
.mode-tab.active .mode-dot{opacity:1;box-shadow:0 0 8px currentColor}

/* LAYOUT */
main{flex:1;width:100%;max-width:1440px;margin:0 auto;padding:28px 32px;display:flex;flex-direction:column;gap:20px}
.mode-page{display:none}
.mode-page.active{display:flex;flex-direction:column;gap:20px}

/* CARDS */
.card{background:var(--s1);border:1px solid var(--ln)}
.card-hd{padding:16px 22px;border-bottom:1px solid var(--ln);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.card-ttl{font-size:.58rem;letter-spacing:3px;color:var(--txd);text-transform:uppercase;display:flex;align-items:center;gap:10px}
.card-ttl::before{content:'';width:16px;height:1px;background:var(--g);flex-shrink:0}
.card-ttl.b::before{background:var(--b)}
.card-body{padding:20px 22px}

/* FORMS */
.field{display:flex;flex-direction:column;gap:5px;min-width:0}
.label{font-size:.54rem;letter-spacing:1.5px;color:var(--txd);text-transform:uppercase}
input,select,textarea{background:var(--s2);border:1px solid var(--ln);color:var(--tx);font-family:var(--mono);font-size:.78rem;padding:9px 12px;outline:none;width:100%;transition:border-color .15s;-webkit-appearance:none;appearance:none;min-width:0}
input:focus,select:focus,textarea:focus{border-color:rgba(0,214,143,.5)}
select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236070a0'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}
select option{background:var(--s2)}
.date-selects{display:grid;grid-template-columns:68px 1fr 72px;gap:5px}
.sym-row select{flex:1;min-width:0}
.sym-add-row input{flex:1;min-width:0;font-size:.72rem;padding:8px 10px}
.date-selects select{font-size:.68rem;padding:8px 24px 8px 8px}

/* BUTTONS */
.btn{font-family:var(--mono);font-size:.63rem;letter-spacing:2px;padding:10px 16px;border:none;cursor:pointer;transition:all .15s;text-transform:uppercase;font-weight:700;width:100%}
.btn-g{background:var(--g);color:#000}.btn-g:hover{background:#00ffaa;box-shadow:0 0 18px var(--gg)}
.btn-g:disabled,.btn-b:disabled,.btn-p:disabled{background:var(--txm)!important;color:var(--txd)!important;cursor:default!important;box-shadow:none!important}
.btn-b{background:var(--b);color:#000}.btn-b:hover{background:#6fb8ff;box-shadow:0 0 18px var(--bg2)}
.btn-p{background:transparent;color:var(--p);border:1px solid rgba(157,127,244,.3)}.btn-p:hover{background:var(--pd);border-color:rgba(157,127,244,.6)}
.btn-o{background:transparent;border:1px solid var(--ln);color:var(--txd);width:auto}.btn-o:hover{border-color:var(--lnh);color:var(--tx)}
.btn-r{color:var(--r)}.btn-r:hover{border-color:rgba(245,68,92,.4)!important;color:var(--r)!important}
.btn-y{color:var(--y)}.btn-y:hover{border-color:rgba(240,185,11,.4)!important;color:var(--y)!important}
.btn-cancel{background:transparent;border:1px solid rgba(245,68,92,.3);color:var(--r);font-family:var(--mono);font-size:.58rem;letter-spacing:1.5px;padding:7px 12px;cursor:pointer;text-transform:uppercase;transition:all .15s;display:none}
.btn-cancel.visible{display:inline-block}
.btn-cancel:hover{background:var(--rd);border-color:rgba(245,68,92,.6)}

/* FETCH GRID */
.fetch-grid{display:grid;grid-template-columns:minmax(220px,240px) 1fr 1fr 1fr 140px;gap:12px;align-items:end}
@media(max-width:900px){.fetch-grid{grid-template-columns:1fr}}
.tf-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--ln)}
.tf-chip{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--s2);border:1px solid var(--ln);font-size:.65rem}
.tf-name{color:var(--txd);letter-spacing:1px}
.tf-val{color:var(--txm)}.tf-val.ok{color:var(--g)}
.tf-actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}

/* CONFIG / RM GRID */
.cfg-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--ln)}
.cfg-field{display:flex;align-items:center;gap:8px}
.cfg-field input{width:80px}
.cfg-field .label{white-space:nowrap;margin:0}
.rm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--ln)}

/* NEW: Spread/Slippage row */
.slip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--ln)}
.slip-hint{font-size:.5rem;color:var(--txm);letter-spacing:1px;margin-top:3px;line-height:1.5}

/* IMPORT */
.import-zone{border:1px dashed rgba(0,214,143,.3);padding:18px;text-align:center;cursor:pointer;transition:all .2s;background:rgba(0,214,143,.02)}
.import-zone:hover,.import-zone.drag{border-color:var(--g);background:var(--gd)}
.import-zone-txt{font-size:.65rem;color:var(--txd);letter-spacing:1px}
.import-zone-txt span{color:var(--g)}
.import-list{display:flex;flex-direction:column;gap:4px;margin-top:10px}
.import-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--s2);border:1px solid var(--ln);font-size:.62rem}
.import-item-name{color:var(--g)}
.import-item-meta{color:var(--txd);font-size:.55rem}

/* STRATEGY CARDS */
.strat-card{background:var(--s2);border:1px solid var(--ln);display:flex;flex-direction:column}
.strat-hd{padding:12px 16px;border-bottom:1px solid var(--ln);display:flex;align-items:center;justify-content:space-between;gap:8px}
.strat-name-wrap{display:flex;align-items:center;gap:10px;flex:1}
.strat-color-bar{width:3px;height:24px;border-radius:2px;flex-shrink:0}
.strat-name-input{background:transparent;border:none;border-bottom:1px solid var(--ln);color:var(--tx);font-family:var(--mono);font-size:.8rem;padding:3px 0;width:160px;outline:none;letter-spacing:1px;transition:border-color .15s}
.strat-name-input:focus{border-bottom-color:var(--g)}
.strat-body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:10px}
.code-tpl{display:flex;gap:4px;flex-wrap:wrap}
.tpl-btn{background:transparent;border:1px solid var(--ln);color:var(--txd);font-family:var(--mono);font-size:.54rem;letter-spacing:1px;padding:3px 9px;cursor:pointer;transition:all .12s}
.tpl-btn:hover{border-color:rgba(157,127,244,.5);color:var(--p)}
.tpl-btn.algov2{border-color:rgba(0,214,143,.4);color:var(--g)}.tpl-btn.algov2:hover{background:var(--gd);border-color:var(--g)}
textarea.code{font-size:.68rem;line-height:1.7;resize:vertical;min-height:200px;background:var(--bg);border:1px solid rgba(157,127,244,.12);color:#b8c4d8;padding:12px;tab-size:2;font-family:var(--mono);outline:none;width:100%}
textarea.code:focus{border-color:rgba(157,127,244,.35)}
.api-hint{padding:8px 10px;background:var(--bg);border:1px solid var(--ln);font-size:.54rem;line-height:1.9;color:var(--txd)}
.api-hint code{color:var(--p)}.api-hint .ret{color:var(--g)}

/* PROGRESS */
.progress-wrap{display:none;flex-direction:column;gap:4px;margin-top:6px}
.progress-wrap.visible{display:flex}
.progress-bar-bg{height:4px;background:var(--s3);border:1px solid var(--ln);overflow:hidden}
.progress-bar-fill{height:100%;background:var(--g);transition:width .1s linear;width:0%}
.progress-label{font-size:.54rem;color:var(--txd);letter-spacing:1px}
.console{background:var(--bg);border:1px solid var(--ln);padding:8px 12px;font-size:.6rem;color:var(--txd);max-height:90px;overflow-y:auto;line-height:1.8;white-space:pre-wrap}
.console .ok{color:var(--g)}.console .e{color:var(--r)}.console .i{color:var(--b)}
.run-row{display:flex;gap:8px;margin-top:6px}
.run-row .btn{font-size:.6rem;padding:9px 12px}
.compare-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(560px,1fr));gap:16px}

/* LOG ENTRIES */
.log-entry{background:var(--s2);border:1px solid var(--ln);margin-bottom:12px;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.log-hd{padding:14px 18px;border-bottom:1px solid var(--ln);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.log-title-row{display:flex;align-items:center;gap:10px}
.log-num{font-size:.54rem;letter-spacing:2px;color:var(--txd);background:var(--s3);padding:2px 8px;border:1px solid var(--ln)}
.log-name{font-family:var(--disp);font-size:1rem;font-weight:700}
.log-meta{font-size:.58rem;color:var(--txd);letter-spacing:1px}
.log-badges{display:flex;gap:6px;flex-wrap:wrap}
.lbadge{font-size:.52rem;letter-spacing:1px;padding:3px 8px;border:1px solid}
.lbadge.best{color:var(--y);border-color:rgba(240,185,11,.35);background:rgba(240,185,11,.08)}
.lbadge.g{color:var(--g);border-color:rgba(0,214,143,.3);background:var(--gd)}
.lbadge.r{color:var(--r);border-color:rgba(245,68,92,.25);background:var(--rd)}
.lbadge.b{color:var(--b);border-color:rgba(59,158,255,.25);background:rgba(59,158,255,.08)}
.lbadge.warn{color:var(--y);border-color:rgba(240,185,11,.3);background:rgba(240,185,11,.07)}

/* LOG STATS - 12 cols for new metrics */
.log-stats{display:grid;grid-template-columns:repeat(12,1fr);border-bottom:1px solid var(--ln)}
.lstat{padding:10px 12px;border-right:1px solid var(--ln);display:flex;flex-direction:column;gap:3px}
.lstat:last-child{border-right:none}
.lstat-l{font-size:.44rem;letter-spacing:1.5px;color:var(--txd);text-transform:uppercase}
.lstat-v{font-family:var(--disp);font-size:1rem;line-height:1;margin-top:2px}
.lstat-v.g{color:var(--g)}.lstat-v.r{color:var(--r)}.lstat-v.y{color:var(--y)}.lstat-v.b{color:var(--b)}.lstat-v.p{color:var(--p)}

/* LOG BODY */
.log-body{padding:14px 18px}
.log-details-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.log-equity{background:var(--bg);border:1px solid var(--ln);position:relative;height:90px}
.log-equity svg{display:block;width:100%;height:100%}
.eq-tooltip{position:absolute;pointer-events:none;background:var(--s1);border:1px solid var(--ln);padding:5px 9px;font-size:.54rem;font-family:var(--mono);color:var(--tx);white-space:nowrap;z-index:50;display:none;transform:translateX(-50%)}
.eq-tooltip .tt-date{color:var(--txd);font-size:.48rem;letter-spacing:1px}
.eq-tooltip .tt-val{font-weight:700;margin-top:1px}
.eq-tooltip .tt-val.pos{color:var(--g)}.eq-tooltip .tt-val.neg{color:var(--r)}
.eq-crosshair{position:absolute;top:0;bottom:0;width:1px;background:rgba(255,255,255,.15);pointer-events:none;display:none}
.log-code-preview{background:var(--bg);border:1px solid rgba(157,127,244,.15);padding:10px 12px;font-size:.6rem;color:#a0aac0;font-family:var(--mono);line-height:1.7;max-height:100px;overflow:hidden;position:relative}
.log-code-preview::after{content:'';position:absolute;bottom:0;left:0;right:0;height:30px;background:linear-gradient(transparent,var(--bg))}
.log-trade-counts{display:flex;gap:12px;margin-top:10px;flex-wrap:wrap}
.ltc{font-size:.62rem;padding:4px 10px;border:1px solid}
.ltc.long{color:var(--g);border-color:rgba(0,214,143,.3);background:var(--gd)}
.ltc.short{color:var(--r);border-color:rgba(245,68,92,.25);background:var(--rd)}
.ltc.win{color:var(--g);border-color:rgba(0,214,143,.25)}
.ltc.lose{color:var(--r);border-color:rgba(245,68,92,.2)}
.log-actions{display:flex;gap:8px;margin-top:12px}
.log-empty{text-align:center;padding:48px 20px;color:var(--txm);font-size:.65rem;letter-spacing:2px}
.log-collapsible{overflow:hidden;transition:max-height .25s ease}
.log-collapsible.collapsed{max-height:0!important}
.log-chevron{transition:transform .2s;display:inline-block}

/* WARNING BANNER */
.warn-banner{padding:6px 12px;background:rgba(240,185,11,.07);border:1px solid rgba(240,185,11,.25);font-size:.58rem;color:var(--y);letter-spacing:1px;margin-top:8px;display:flex;align-items:center;gap:8px}
.warn-banner::before{content:'⚠';font-size:.7rem}
.data-warn{font-size:.56rem;color:var(--y);padding:4px 10px;background:rgba(240,185,11,.07);border:1px solid rgba(240,185,11,.2);letter-spacing:1px;margin-top:6px;display:inline-block}

/* RANK TABLE */
.cmp-table{width:100%;border-collapse:collapse}
.cmp-table th{padding:10px 14px;font-size:.52rem;letter-spacing:2px;color:var(--txd);font-weight:400;text-align:left;border-bottom:1px solid var(--ln);text-transform:uppercase}
.cmp-table td{padding:12px 14px;font-size:.72rem;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}
.cmp-table tr:last-child td{border-bottom:none}
.cmp-table tr:hover td{background:rgba(255,255,255,.012)}
.rank-badge{font-family:var(--disp);font-size:.95rem;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1px solid;flex-shrink:0}
.rk1{color:var(--y);border-color:rgba(240,185,11,.4);background:rgba(240,185,11,.08)}
.rk2{color:var(--txd);border-color:var(--ln)}
.rk3{color:#6a5030;border-color:rgba(106,80,48,.3)}
.best-lbl{font-size:.5rem;letter-spacing:1px;padding:2px 7px;background:rgba(240,185,11,.1);color:var(--y);border:1px solid rgba(240,185,11,.25)}
.rank-filter-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px;padding:10px 14px;background:var(--s2);border-bottom:1px solid var(--ln)}
.rank-filter-row input[type=number]{width:72px;font-size:.65rem;padding:5px 8px}

/* FILTER / TRADE TABLE */
.table-hd{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.table-ttl{font-size:.58rem;letter-spacing:3px;color:var(--txd);text-transform:uppercase;display:flex;align-items:center;gap:10px}
.table-ttl::before{content:'';width:16px;height:1px;background:var(--g)}
.filter-row{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.f-btn{background:transparent;border:1px solid var(--ln);color:var(--txd);font-family:var(--mono);font-size:.58rem;letter-spacing:1px;padding:4px 10px;cursor:pointer;transition:all .12s}
.f-btn:hover{color:var(--tx)}
.f-btn.active{border-color:rgba(0,214,143,.4);color:var(--g);background:var(--gd)}
.strat-sel{font-size:.6rem;padding:5px 28px 5px 10px;width:auto}
table{width:100%;border-collapse:collapse}
thead tr{border-bottom:1px solid var(--ln)}
th{padding:0 12px 10px;font-size:.52rem;letter-spacing:1.5px;color:var(--txd);font-weight:400;text-align:left;white-space:nowrap;text-transform:uppercase}
td{padding:10px 12px;font-size:.7rem;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle;white-space:nowrap}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.015)}
.tag{font-size:.54rem;letter-spacing:.5px;padding:2px 7px;border:1px solid;display:inline-block}
.tag.LONG{color:var(--g);border-color:rgba(0,214,143,.3);background:var(--gd)}
.tag.SHORT{color:var(--r);border-color:rgba(245,68,92,.25);background:var(--rd)}
.tag.WIN{color:var(--g);border-color:rgba(0,214,143,.3);background:var(--gd)}
.tag.LOSE{color:var(--r);border-color:rgba(245,68,92,.25);background:var(--rd)}
.pp{color:var(--g);font-weight:600}.pn{color:var(--r);font-weight:600}
.tm{color:var(--txd)}.tg{color:var(--g);opacity:.75}.tr{color:var(--r);opacity:.75}
.empty-st{text-align:center;padding:40px;color:var(--txm);font-size:.62rem;letter-spacing:2px}
.paging{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0;border-top:1px solid var(--ln)}
.pg-info{font-size:.58rem;color:var(--txd)}

/* EQUITY CHART */
.chart-box{background:var(--bg);border:1px solid var(--ln);position:relative;height:160px;cursor:crosshair}
.chart-box svg{display:block;width:100%;height:100%;pointer-events:none}
.chart-tooltip{position:absolute;pointer-events:none;background:var(--s1);border:1px solid var(--lnh);padding:7px 11px;font-size:.54rem;font-family:var(--mono);z-index:50;display:none;min-width:120px;box-shadow:0 4px 16px rgba(0,0,0,.5)}
.chart-tooltip-date{color:var(--txd);font-size:.46rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}
.chart-tooltip-item{display:flex;justify-content:space-between;gap:12px;margin-top:2px}
.chart-tooltip-name{color:var(--txd);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chart-tooltip-val{font-weight:600}
.chart-vline{position:absolute;top:0;bottom:0;width:1px;background:rgba(255,255,255,.12);pointer-events:none;display:none}
.multi-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.leg-item{display:flex;align-items:center;gap:6px;font-size:.62rem;color:var(--txd)}
.leg-dot{width:20px;height:3px;border-radius:2px}
.eq-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.eq-ttl{font-size:.58rem;letter-spacing:3px;color:var(--txd);text-transform:uppercase;display:flex;align-items:center;gap:10px}
.eq-ttl::before{content:'';width:16px;height:1px;background:var(--g)}
.eq-val{font-family:var(--disp);font-size:1.8rem}
.eq-val.pos{color:var(--g)}.eq-val.neg{color:var(--r)}

/* TABS */
.tab-bar{display:flex;border-bottom:1px solid var(--ln)}
.tab{padding:10px 20px;font-size:.6rem;letter-spacing:2px;color:var(--txd);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;text-transform:uppercase;font-family:var(--mono)}
.tab:hover{color:var(--tx)}
.tab.active{color:var(--g);border-bottom-color:var(--g)}

/* AI PAGE */
.ai-brain-row{display:flex;border-bottom:1px solid var(--ln);overflow-x:auto}
.ai-brain-cell{padding:10px 16px;border-right:1px solid var(--ln);display:flex;flex-direction:column;gap:3px;min-width:88px;flex-shrink:0}
.ai-brain-cell:last-child{border-right:none}
.ai-brain-lbl{font-size:.42rem;letter-spacing:2px;color:var(--txm);text-transform:uppercase}
.ai-brain-val{font-family:var(--disp);font-size:.88rem;line-height:1.2;color:var(--tx);margin-top:2px}
.ai-brain-val.b{color:var(--b)}.ai-brain-val.g{color:var(--g)}.ai-brain-val.r{color:var(--r)}.ai-brain-val.y{color:var(--y)}.ai-brain-val.p{color:var(--p)}
.ai-log-wrap{background:var(--bg);max-height:320px;overflow-y:auto;padding:10px 14px;font-size:.62rem;font-family:var(--mono);line-height:1.85}
.ai-log-entry{display:flex;gap:10px;align-items:flex-start;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.025);animation:fadeIn .15s ease}
.ai-log-time{color:var(--txm);font-size:.52rem;white-space:nowrap;padding-top:1px;min-width:58px;flex-shrink:0}
.ai-log-icon{font-size:.65rem;width:14px;text-align:center;flex-shrink:0;padding-top:1px}
.ai-log-msg{flex:1;color:var(--txd)}
.ai-log-msg.think{color:#7aafd0}.ai-log-msg.action{color:var(--tx)}.ai-log-msg.success{color:var(--g)}
.ai-log-msg.warning{color:var(--y)}.ai-log-msg.error{color:var(--r)}.ai-log-msg.adjust{color:var(--p)}
.ai-log-msg.system{color:var(--txm);font-size:.56rem;font-style:italic}
.backend-badge{display:inline-flex;align-items:center;gap:6px;font-size:.52rem;letter-spacing:1.5px;color:var(--b);border:1px solid rgba(59,158,255,.3);padding:3px 9px;background:rgba(59,158,255,.06)}
.backend-badge .bdot{width:6px;height:6px;border-radius:50%;background:var(--b);animation:blk .8s ease-in-out infinite}

/* CODE MODAL */
#codeModal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:500;overflow:auto;padding:40px 20px}

/* Symbol Dropdown */
.sym-dd{position:relative;width:100%}
.sym-hd{display:flex;justify-content:space-between;align-items:center;background:var(--s2);border:1px solid var(--ln);color:var(--tx);font-family:var(--mono);font-size:.78rem;padding:9px 12px;cursor:pointer;user-select:none;transition:border-color .15s;min-height:38px}
.sym-hd:hover{border-color:rgba(0,214,143,.4)}
.sym-chev{font-size:.6rem;color:var(--txd);transition:transform .2s;flex-shrink:0;margin-left:6px}
.sym-panel{display:none;position:absolute;top:100%;left:0;right:0;background:var(--s1);border:1px solid var(--ln);border-top:none;z-index:600;box-shadow:0 8px 24px rgba(0,0,0,.6)}
.sym-panel.open{display:block}
#symList{max-height:200px;overflow-y:auto}
.sym-item{display:flex;align-items:center;padding:6px 12px;border-bottom:1px solid rgba(255,255,255,.04);gap:6px;transition:background .1s}
.sym-item:hover{background:var(--s2)}
.sym-item-name{flex:1;font-size:.72rem;color:var(--tx);cursor:pointer;letter-spacing:.5px;font-family:var(--mono)}
.sym-item-name:hover{color:var(--g)}
.sym-item-candles{font-size:.58rem;color:var(--g);font-family:var(--mono);white-space:nowrap;opacity:.8}
.sym-item-del{background:transparent;border:none;color:var(--txm);font-size:.65rem;cursor:pointer;padding:2px 5px;flex-shrink:0;line-height:1;transition:color .12s}
.sym-item-del:hover{color:var(--r)}
.sym-adder{display:flex;gap:4px;padding:7px 8px;border-top:1px solid var(--ln);background:var(--s2)}
.sym-adder input{flex:1;min-width:0;font-size:.68rem;padding:6px 8px;background:var(--bg);border:1px solid var(--ln);color:var(--tx);font-family:var(--mono)}
.sym-adder button{width:28px;flex-shrink:0;background:var(--g);color:#000;border:none;font-size:.85rem;font-weight:700;cursor:pointer;transition:background .15s}
.sym-adder button:hover{background:#00ffaa}
