/* ================================================================
   BTC ADAPTIVE TRAINER v8 — STYLESHEET
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@400;700;900&display=swap');

:root {
  --bg:#080c10; --bg2:#0d1117; --bg3:#111820; --border:#1e2d3d;
  --amber:#f0a500; --green:#00cc6a; --red:#ff3355; --cyan:#00d4ff;
  --purple:#a855f7; --gold:#e6b800; --muted:#3a5068;
  --text:#c8d8e8; --text2:#7a9ab8; --shadow:rgba(0,0,0,.5);
  --canvas-bg:#080c10; --grid-line:rgba(30,45,61,.55);
  --price-lbl:#4a6880; --bull:#00cc6a; --bull-dim:rgba(0,204,106,.5);
  --bear:#ff3355; --bear-dim:rgba(255,51,85,.5);
  --font:'Share Tech Mono',monospace; --head:'Orbitron',sans-serif;
}
body.light {
  --bg:#f0f4f8; --bg2:#e4eaf1; --bg3:#d6dfe9; --border:#adbfce;
  --amber:#c47a00; --green:#007a40; --red:#cc1133; --cyan:#006fa8;
  --purple:#7c3aed; --gold:#b08800; --muted:#8a9fb8;
  --text:#1a2430; --text2:#4a6070; --shadow:rgba(0,0,0,.12);
  --canvas-bg:#f8fbff; --grid-line:rgba(100,130,160,.18);
  --price-lbl:#6a88a0; --bull:#007a40; --bull-dim:rgba(0,122,64,.5);
  --bear:#cc1133; --bear-dim:rgba(204,17,51,.5);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;display:flex;flex-direction:column;transition:background .25s,color .25s}

/* ── MODALS ─────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.82);display:none;align-items:center;justify-content:center;z-index:200}
.modal-overlay.show{display:flex}
.modal-box{background:var(--bg2);border:1px solid var(--amber);padding:26px 30px;min-width:400px;max-width:620px;box-shadow:0 0 40px rgba(240,165,0,.15)}
.modal-box h2{font-family:var(--head);color:var(--amber);font-size:11px;letter-spacing:3px;margin-bottom:16px;text-align:center}
.modal-close-btn{display:block;margin:16px auto 0;background:transparent;border:1px solid var(--muted);color:var(--text2);font-family:var(--font);font-size:11px;padding:5px 22px;cursor:pointer;letter-spacing:1px}
.modal-close-btn:hover{border-color:var(--red);color:var(--red)}

#autotune-progress-wrap{width:100%;height:4px;background:var(--bg3);border:1px solid var(--border);margin-bottom:12px}
#autotune-progress-fill{height:100%;background:var(--amber);width:0;transition:width .15s;box-shadow:0 0 8px var(--amber)}
#autotune-status{color:var(--text2);font-size:11px;text-align:center;letter-spacing:1px;margin-bottom:10px;min-height:16px}
#autotune-best{color:var(--green);font-size:11px;text-align:center;letter-spacing:1px;min-height:16px}
#wf-box{border-color:var(--cyan)} #wf-box h2{color:var(--cyan)}
.wf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:4px}
.wf-col h3{font-family:var(--head);font-size:9px;letter-spacing:2px;margin-bottom:10px}
.wf-col.train h3{color:var(--amber)} .wf-col.test h3{color:var(--cyan)}
.wf-row{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid var(--border);font-size:12px}
.wf-row:last-child{border-bottom:none} .wf-row .wk{color:var(--text2)}
.wf-verdict{margin-top:14px;padding:10px;border:1px solid var(--border);text-align:center;font-size:12px;line-height:1.8}

/* Cache manager */
.cache-tabs{display:flex;gap:0;margin-bottom:12px}
.ctab{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-family:var(--head);font-size:9px;letter-spacing:1px;padding:6px;cursor:pointer}
.ctab.active{border-color:var(--cyan);color:var(--cyan);background:rgba(0,212,255,.08)}
.ctab-content{display:none} .ctab-content.active{display:block}
.cache-note{color:var(--text2);font-size:11px;text-align:center;margin-bottom:10px;letter-spacing:.5px}
.cache-table{width:100%;border-collapse:collapse;font-size:12px}
.cache-table th{text-align:left;padding:4px 6px;color:var(--amber);font-family:var(--head);font-size:9px;letter-spacing:1px;border-bottom:1px solid var(--border)}
.cache-table td{padding:5px 6px;border-bottom:1px solid var(--border)}
.cache-empty{text-align:center;color:var(--muted);padding:12px!important}
.cache-actions{display:flex;gap:8px;margin-top:14px;justify-content:center}

.keys-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 20px;margin-top:4px}
.kk{font-family:var(--head);font-size:10px;letter-spacing:1px;color:var(--amber);padding:2px 8px;border:1px solid var(--border);background:var(--bg3);text-align:center}
.kd{font-size:12px;color:var(--text2);align-self:center}

/* ── LOADER ─────────────────────────────────────────────────── */
#loader{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:300;gap:22px}
#loader h2{font-family:var(--head);color:var(--amber);letter-spacing:5px;font-size:18px;animation:pulse 1.5s ease-in-out infinite}
#loader-bar-wrap{width:440px;height:3px;background:var(--bg3);border:1px solid var(--border)}
#loader-bar{height:100%;background:var(--amber);width:0;transition:width .3s;box-shadow:0 0 14px var(--amber)}
#loader-msg{color:var(--text2);font-size:13px;letter-spacing:1px}

/* ── HEADER ─────────────────────────────────────────────────── */
#header{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;box-shadow:0 2px 8px var(--shadow);flex-wrap:nowrap;overflow:hidden}
#header h1{font-family:var(--head);font-size:13px;font-weight:900;letter-spacing:3px;color:var(--amber);text-shadow:0 0 18px rgba(240,165,0,.4);white-space:nowrap}
.price-big{font-family:var(--head);font-size:20px;font-weight:700;color:var(--green);transition:color .2s}
.price-big.down{color:var(--red)}
.header-stat{display:flex;flex-direction:column;align-items:flex-start;gap:1px}
.header-stat .lbl{color:var(--text2);font-size:9px;letter-spacing:1px;text-transform:uppercase}
.header-stat .val{color:var(--text);font-size:12px}
.spacer{flex:1;min-width:4px} .hdr-sep{color:var(--muted);font-size:10px}
.hdr-select{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:11px;padding:4px 7px;cursor:pointer;outline:none}
.hdr-select:hover{border-color:var(--amber)}
.hdr-date{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:11px;padding:4px 7px;outline:none;color-scheme:dark}
body.light .hdr-date{color-scheme:light}
.hdr-badge{font-family:var(--font);font-size:10px;letter-spacing:1px;color:var(--text2);white-space:nowrap}
.saved-badge{color:var(--green);opacity:0;transition:opacity .3s}
.saved-badge.show{opacity:1}
.db-badge,.ws-badge{padding:3px 8px;border:1px solid var(--muted);font-family:var(--head);font-size:8px;letter-spacing:1px;cursor:default}
.db-badge.db-ok{border-color:var(--green);color:var(--green)}
.db-badge.db-err{border-color:var(--red);color:var(--red)}
.ws-badge.ws-on{border-color:var(--green);color:var(--green)}
.ws-badge.ws-off{border-color:var(--muted);color:var(--muted)}
.badge{padding:4px 9px;border-radius:2px;font-size:9px;letter-spacing:1px;font-family:var(--head);font-weight:700;white-space:nowrap}
.badge-live{background:rgba(0,204,106,.12);color:var(--green);border:1px solid var(--green)}
.badge-replay{background:rgba(240,165,0,.12);color:var(--amber);border:1px solid var(--amber)}
#lev-badge{font-family:var(--head);font-size:9px;font-weight:900;padding:4px 9px;border:1px solid var(--purple);color:var(--purple);background:rgba(168,85,247,.10);letter-spacing:1px;white-space:nowrap}
#lev-badge.high{border-color:var(--red);color:var(--red);background:rgba(255,51,85,.10)}
#alert-badge{background:rgba(240,165,0,.2);border:1px solid var(--amber);color:var(--amber);animation:blink .8s step-end infinite}
#theme-toggle{display:flex;align-items:center;gap:5px;cursor:pointer;user-select:none;padding:4px 9px;border:1px solid var(--border);background:var(--bg3);white-space:nowrap}
#theme-toggle:hover{border-color:var(--amber)}
.theme-icon{font-size:13px} .theme-label{font-family:var(--head);font-size:8px;letter-spacing:1px;color:var(--text2)}

/* ── LAYOUT ─────────────────────────────────────────────────── */
#main{display:grid;grid-template-columns:1fr 294px;grid-template-rows:1fr 170px 46px;flex:1;overflow:hidden;gap:1px;background:var(--border);min-height:0}
#chart-container{grid-row:1;grid-column:1;background:var(--bg);position:relative;overflow:hidden}
#chartCanvas{display:block}
#chart-alert-flash{position:absolute;inset:0;pointer-events:none;border:3px solid transparent}
#chart-alert-flash.flash-long{animation:flash-border-green .8s ease-out}
#chart-alert-flash.flash-short{animation:flash-border-red .8s ease-out}
#crosshair-info{position:absolute;top:10px;left:10px;background:var(--bg2);border:1px solid var(--border);padding:8px 14px;pointer-events:none;font-size:12px;line-height:1.9;display:none;box-shadow:0 2px 12px var(--shadow);z-index:5}
#crosshair-info.show{display:block}
#xhair-v{position:absolute;pointer-events:none;display:none;width:1px;top:0;bottom:0;background:rgba(200,216,232,.12)}
#xhair-h{position:absolute;pointer-events:none;display:none;height:1px;left:0;right:0;background:rgba(200,216,232,.12)}
#legend{position:absolute;top:10px;right:12px;display:flex;flex-direction:column;gap:4px;pointer-events:none}
.legend-item{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text2)}
.legend-line{width:16px;height:2px}
#bottom-panel{grid-row:2;grid-column:1;background:var(--bg);display:flex;flex-direction:column;border-top:1px solid var(--border);overflow:hidden}
.tab-bar{display:flex;flex-shrink:0;border-bottom:1px solid var(--border);height:26px}
.tab-btn{background:transparent;border:none;border-right:1px solid var(--border);color:var(--text2);font-family:var(--head);font-size:9px;letter-spacing:1px;padding:0 14px;cursor:pointer;transition:all .15s;white-space:nowrap}
.tab-btn:hover{color:var(--amber);background:rgba(240,165,0,.05)}
.tab-btn.active{color:var(--amber);border-bottom:2px solid var(--amber);background:rgba(240,165,0,.06)}
.tab-content{display:none;flex:1;position:relative;overflow:hidden}
.tab-content.active{display:flex} canvas{display:block}
.stats-grid{width:100%;padding:6px 8px;display:grid;grid-template-columns:repeat(4,1fr);gap:5px;overflow-y:auto}
.stat-box{background:var(--bg3);border:1px solid var(--border);padding:5px 8px;display:flex;flex-direction:column;gap:2px}
.stat-box .sb-lbl{color:var(--text2);font-size:9px;letter-spacing:1px;text-transform:uppercase}
.stat-box .sb-val{font-size:12px;font-weight:bold;color:var(--text)}

/* ── SIDEBAR ────────────────────────────────────────────────── */
#sidebar{grid-row:1/3;grid-column:2;background:var(--bg2);display:flex;flex-direction:column;padding:6px;gap:6px;overflow-y:auto;min-height:0}
::-webkit-scrollbar{width:4px;height:4px} ::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--muted);border-radius:2px}
.sidebar-section{border:1px solid var(--border);overflow:hidden;flex-shrink:0}
.section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 11px 7px;cursor:pointer;user-select:none;border-bottom:1px solid var(--border);transition:background .15s}
.section-header:hover{background:rgba(128,160,200,.07)}
.section-header h3{font-family:var(--head);font-size:8px;letter-spacing:2px;color:var(--amber);pointer-events:none}
.section-arrow{font-size:8px;color:var(--muted);transition:transform .2s;pointer-events:none}
.sidebar-section.collapsed .section-arrow{transform:rotate(-90deg)}
.section-body{padding:8px 11px}
.sidebar-section.collapsed .section-body{display:none}
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;border-bottom:1px solid var(--border)}
.stat-row:last-child{border-bottom:none}
.stat-row .lbl{color:var(--text2);font-size:11px} .stat-row .val{font-size:12px}
.val-green{color:var(--green)} .val-red{color:var(--red)} .val-amber{color:var(--amber)}
.val-cyan{color:var(--cyan)} .val-purple{color:var(--purple)} .val-gold{color:var(--gold)}

/* ── LIVE SIGNAL SECTION ────────────────────────────────────── */
.ls-body{padding:0!important}
.ws-dot{display:inline-block;width:8px;height:8px;border-radius:50%;border:1px solid var(--muted);background:transparent}
.ws-dot.ws-on{background:var(--green);border-color:var(--green);box-shadow:0 0 6px var(--green)}
.ws-dot.ws-off{background:var(--muted);border-color:var(--muted)}
.ws-dot.ws-err{background:var(--red);border-color:var(--red)}

/* Big signal badge */
.ls-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 10px 10px;gap:4px;border-bottom:1px solid var(--border);transition:background .3s,border-color .3s}
.ls-badge.ls-neutral{background:var(--bg3)}
.ls-badge.ls-buy{background:rgba(0,204,106,.12);border-bottom-color:var(--green)}
.ls-badge.ls-sell{background:rgba(255,51,85,.12);border-bottom-color:var(--red)}
#ls-icon{font-size:28px;font-family:var(--head);font-weight:900;transition:color .3s;color:var(--muted)}
.ls-badge.ls-buy  #ls-icon{color:var(--green);text-shadow:0 0 20px rgba(0,204,106,.6)}
.ls-badge.ls-sell #ls-icon{color:var(--red);  text-shadow:0 0 20px rgba(255,51,85,.6)}
#ls-label{font-family:var(--head);font-size:9px;letter-spacing:3px;color:var(--muted);transition:color .3s}
.ls-badge.ls-buy  #ls-label{color:var(--green)}
.ls-badge.ls-sell #ls-label{color:var(--red)}
.ls-age{font-size:10px;color:var(--muted);letter-spacing:.5px}
.ls-badge.ls-buy  .ls-age,.ls-badge.ls-sell .ls-age{color:var(--text2)}

/* Price row */
.ls-price-row{display:flex;align-items:center;justify-content:space-between;padding:7px 11px;border-bottom:1px solid var(--border)}
.ls-price{font-family:var(--head);font-size:15px;font-weight:700;color:var(--text)}
.ls-pchg{font-size:11px;color:var(--text2)} .ls-pchg.up{color:var(--green)} .ls-pchg.dn{color:var(--red)}
.ls-cd{font-size:10px;color:var(--muted);letter-spacing:.5px}

/* Suggest row */
.ls-suggest{padding:7px 11px;border-bottom:1px solid var(--border)}
.ls-srow{display:flex;gap:8px;align-items:center;padding:2px 0}
.ls-sk{color:var(--text2);font-size:10px;min-width:32px}
.ls-sv{font-size:11px;font-weight:bold;color:var(--text);flex:1}

/* RSI gauge */
.ls-gauge-wrap{padding:7px 11px 5px;border-bottom:1px solid var(--border)}
.ls-gaugelbl{font-size:10px;color:var(--text2);letter-spacing:1px;display:flex;justify-content:space-between;margin-bottom:4px}
.ls-gaugenum{color:var(--amber);font-weight:bold}
.ls-gauge-track{position:relative;height:6px;background:var(--bg3);border:1px solid var(--border);border-radius:3px;overflow:visible}
.ls-rsi-fill{height:100%;border-radius:3px;background:var(--amber);transition:width .4s,background .3s}
.ls-os-mark,.ls-ob-mark{position:absolute;top:-4px;width:1px;height:14px;background:rgba(200,216,232,.35)}

/* Trend bar */
.ls-trend-wrap{display:flex;align-items:center;gap:6px;padding:6px 11px;border-bottom:1px solid var(--border)}
.ls-trendk{font-size:10px;color:var(--text2);letter-spacing:.5px;white-space:nowrap}
.ls-trend{flex:1;text-align:center;font-family:var(--head);font-size:9px;letter-spacing:2px;padding:4px 6px;border:1px solid var(--border)}
.ls-trend-neutral{color:var(--muted);border-color:var(--muted)}
.ls-trend-bull{color:var(--green);border-color:var(--green);background:rgba(0,204,106,.08)}
.ls-trend-bear{color:var(--red);border-color:var(--red);background:rgba(255,51,85,.08)}
.ls-emavals{font-size:10px;color:var(--text2);white-space:nowrap}

/* ATR row */
.ls-atr-row{display:flex;align-items:center;gap:6px;padding:5px 11px;border-bottom:1px solid var(--border)}
.ls-atrval{font-size:11px;font-weight:bold;color:var(--text);flex:1}

/* Signal history */
.ls-hist-hdr{padding:5px 11px 3px;font-family:var(--head);font-size:8px;letter-spacing:2px;color:var(--muted);border-bottom:1px solid var(--border)}
.ls-hist{max-height:110px;overflow-y:auto}
.ls-hist-row{display:flex;align-items:center;gap:6px;padding:4px 11px;border-bottom:1px solid var(--border);font-size:11px}
.ls-hist-row:last-child{border-bottom:none}
.ls-hist-row .hdir{width:32px;font-weight:bold}
.ls-hist-row .hdir.long{color:var(--green)} .ls-hist-row .hdir.short{color:var(--red)}
.ls-hist-row .hprice{flex:1;color:var(--text)}
.ls-hist-row .htime{color:var(--muted);font-size:10px}
.ls-hist-row .htp{color:var(--green);font-size:10px}
.ls-hist-row .hsl{color:var(--red);font-size:10px}

/* ── SIDEBAR CONTROLS ───────────────────────────────────────── */
.capital-row{display:flex;align-items:center;gap:6px}
.capital-row label{color:var(--text2);font-size:14px;flex-shrink:0}
input[type="number"]{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--cyan);font-family:var(--font);font-size:14px;font-weight:bold;padding:5px 7px;outline:none;transition:border-color .15s;width:100%}
input[type="number"]:focus{border-color:var(--cyan)}
input[type="number"]::-webkit-inner-spin-button{opacity:.4}
.leverage-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:4px}
.lev-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-family:var(--font);font-size:11px;font-weight:bold;padding:5px 0;cursor:pointer;text-align:center;transition:all .15s}
.lev-btn:hover{border-color:var(--purple);color:var(--purple)}
.lev-btn.active{background:rgba(168,85,247,.18);border-color:var(--purple);color:var(--purple)}
.lev-btn.active.danger{background:rgba(255,51,85,.18);border-color:var(--red);color:var(--red)}
.lev-warning{margin-top:5px;color:var(--red);font-size:10px;text-align:center;display:none}
.lev-warning.show{display:block}
.dir-toggle{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.dir-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-family:var(--head);font-size:9px;letter-spacing:1px;padding:6px 0;cursor:pointer;text-align:center;transition:all .15s}
.dir-btn.active-long{border-color:var(--green);color:var(--green);background:rgba(0,204,106,.12)}
.dir-btn.active-both{border-color:var(--amber);color:var(--amber);background:rgba(240,165,0,.12)}
.dir-btn.active-short{border-color:var(--red);color:var(--red);background:rgba(255,51,85,.12)}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.settings-field{display:flex;flex-direction:column;gap:3px}
.settings-field label{color:var(--text2);font-size:10px;letter-spacing:.5px}
.settings-field input{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:12px;padding:4px 6px;outline:none;width:100%}
.settings-field input:focus{border-color:var(--amber)}
.open-pos-empty{color:var(--muted);font-size:11px;text-align:center;padding:8px 0;letter-spacing:1px}
.open-pos-card{border:2px solid var(--green);background:rgba(0,204,106,.04);padding:9px 9px 7px}
.open-pos-card.short-card{border-color:var(--red);background:rgba(255,51,85,.04)}
.opc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.opc-dir{font-family:var(--head);font-size:10px;font-weight:900;letter-spacing:2px;padding:3px 9px}
.opc-dir.long{color:var(--bg);background:var(--green)} .opc-dir.short{color:var(--bg);background:var(--red)}
.opc-pnl{font-family:var(--head);font-size:13px;font-weight:700}
.opc-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px 8px}
.opc-item{display:flex;flex-direction:column}
.opc-item .ok{color:var(--text2);font-size:9px;letter-spacing:.5px;text-transform:uppercase}
.opc-item .ov{font-size:11px;font-weight:bold;color:var(--text)}
.opc-progress-wrap{margin-top:7px;height:3px;background:var(--bg3);border-radius:2px;overflow:hidden}
.opc-progress-fill{height:100%;border-radius:2px;transition:width .3s}
input[type="range"]{width:100%;accent-color:var(--amber);margin:2px 0 7px;cursor:pointer;height:4px}
.param-label{display:flex;justify-content:space-between;color:var(--text2);font-size:11px;margin-bottom:1px}
.param-label .pv{color:var(--text);font-weight:bold;font-size:12px}
#btn-autotune{width:100%;margin-top:8px;background:rgba(168,85,247,.10);border:1px solid var(--purple);color:var(--purple);font-family:var(--head);font-size:9px;letter-spacing:2px;padding:7px;cursor:pointer;transition:all .15s}
#btn-autotune:hover{background:rgba(168,85,247,.22)}
#btn-walkforward{width:100%;margin-top:6px;background:rgba(0,212,255,.08);border:1px solid var(--cyan);color:var(--cyan);font-family:var(--head);font-size:9px;letter-spacing:2px;padding:7px;cursor:pointer;transition:all .15s}
#btn-walkforward:hover{background:rgba(0,212,255,.18)}
#autotune-result{margin-top:5px;font-size:10px;color:var(--text2);text-align:center;min-height:14px}
.ds-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.ds-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-family:var(--head);font-size:8px;letter-spacing:1px;padding:7px 4px;cursor:pointer;text-align:center;transition:all .15s}
.ds-btn:hover{border-color:var(--amber);color:var(--amber)} .ds-btn.btn-danger:hover{border-color:var(--red);color:var(--red)}
#trade-log{max-height:155px;overflow-y:auto;scrollbar-width:thin}
.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.log-header span{color:var(--text2);font-size:10px;letter-spacing:1px}
.export-btns{display:flex;gap:4px}
.export-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-family:var(--head);font-size:8px;letter-spacing:1px;padding:3px 8px;cursor:pointer;transition:all .12s}
.export-btn:hover{border-color:var(--amber);color:var(--amber)}
.trade-entry{display:flex;gap:4px;padding:3px 2px;border-bottom:1px solid var(--border);font-size:11px;align-items:center}
.trade-entry:last-child{border-bottom:none}
.trade-entry .dir{font-weight:bold;width:34px} .dir.long{color:var(--green)} .dir.short{color:var(--red)}
.trade-entry .rsn{width:28px;font-size:10px} .trade-entry .dt{color:var(--muted);font-size:10px;flex:1}
.trade-entry .lev-t{color:var(--purple);font-size:10px;width:26px;text-align:right}
.trade-entry .pnl{font-size:11px;width:70px;text-align:right}

/* ── CONTROLS BAR ───────────────────────────────────────────── */
#controls{grid-row:3;grid-column:1/3;background:var(--bg2);display:flex;align-items:center;gap:7px;padding:0 13px;border-top:1px solid var(--border);flex-shrink:0;box-shadow:0 -2px 8px var(--shadow)}
button{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:11px;padding:5px 12px;cursor:pointer;letter-spacing:1px;transition:all .15s;white-space:nowrap}
button:hover{border-color:var(--amber);color:var(--amber)} button.active{background:rgba(240,165,0,.12);border-color:var(--amber);color:var(--amber)}
button.btn-disabled{opacity:.3;pointer-events:none}
select{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:11px;padding:5px 7px;cursor:pointer;outline:none}
.ctrl-label{color:var(--text2);font-size:10px;letter-spacing:1px;white-space:nowrap}
#progress-bar{flex:1;height:5px;background:var(--bg3);border:1px solid var(--border);position:relative;cursor:pointer;border-radius:1px;min-width:60px}
#progress-fill{height:100%;background:var(--amber);width:0;transition:width .1s;box-shadow:0 0 6px rgba(240,165,0,.35)}
#candle-counter{color:var(--text2);font-size:10px;min-width:115px;text-align:right;white-space:nowrap}
#kb-hint{color:var(--muted);font-size:10px;white-space:nowrap;cursor:pointer;padding:4px 8px;border:1px solid var(--border);letter-spacing:.5px}
#kb-hint:hover{color:var(--text2);border-color:var(--muted)}

/* ── ANIMATIONS ─────────────────────────────────────────────── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.15}}
@keyframes flash-border-green{0%{border-color:rgba(0,204,106,.9)}100%{border-color:transparent}}
@keyframes flash-border-red{0%{border-color:rgba(255,51,85,.9)}100%{border-color:transparent}}
@keyframes ls-pulse-buy{0%,100%{box-shadow:0 0 0 0 rgba(0,204,106,.5)}50%{box-shadow:0 0 0 8px rgba(0,204,106,0)}}
@keyframes ls-pulse-sell{0%,100%{box-shadow:0 0 0 0 rgba(255,51,85,.5)}50%{box-shadow:0 0 0 8px rgba(255,51,85,0)}}
.blink{animation:blink 1.2s ease-in-out infinite}
.ls-badge.ls-buy{animation:ls-pulse-buy 2s ease-in-out infinite}
.ls-badge.ls-sell{animation:ls-pulse-sell 2s ease-in-out infinite}