/* ============================================================
   THINKCHART — design tokens & styles
   ============================================================ */
:root{
  /* dark (default) */
  --bg-0:#0a0c10;
  --bg-1:#0e1117;
  --bg-2:#11151c;
  --bg-3:#161b24;
  --bg-4:#1c222d;
  --bg-5:#222936;
  --line-1:rgba(255,255,255,.05);
  --line-2:rgba(255,255,255,.08);
  --line-3:rgba(255,255,255,.14);
  --t-1:#e7ebf3;
  --t-2:#a8b0bf;
  --t-3:#6a7383;
  --t-4:#454c59;
  --accent:#7c6cff;
  --accent-2:#5fa8ff;
  --accent-glow:rgba(124,108,255,.18);
  --up:#26d18b;
  --down:#ef5571;
  --warn:#f0b454;
  --info:#5fa8ff;
  --sh-1: 0 1px 0 rgba(255,255,255,.03) inset, 0 1px 2px rgba(0,0,0,.4);
  --sh-2: 0 8px 32px rgba(0,0,0,.45), 0 1px 0 rgba(255,255,255,.04) inset;
  --sh-3: 0 24px 60px rgba(0,0,0,.55), 0 1px 0 rgba(255,255,255,.05) inset;
  --r-1:6px; --r-2:10px; --r-3:14px; --r-4:18px;
  --font-sans:'Geist','SF Pro Text',system-ui,sans-serif;
  --font-mono:'Geist Mono','JetBrains Mono',monospace;
  --font-display:'Fraunces',serif;

  /* chart-only colors (read by chart.js) */
  --chart-bg:#0a0c10;
  --chart-text:#6a7383;
  --chart-grid-v:rgba(255,255,255,.025);
  --chart-grid-h:rgba(255,255,255,.04);
  --chart-border:rgba(255,255,255,.06);
}

[data-theme="light"]{
  /* warm off-white, Claude-style */
  --bg-0:#faf7f2;    /* page */
  --bg-1:#f4efe7;    /* sidebars / topbar */
  --bg-2:#fbf8f3;    /* panels, cards */
  --bg-3:#eee7da;    /* hover, dropdowns */
  --bg-4:#e2d9c8;    /* stronger hover, draw-tools active */
  --bg-5:#d4c8b3;    /* scrollbar */
  --line-1:rgba(60,40,15,.06);
  --line-2:rgba(60,40,15,.10);
  --line-3:rgba(60,40,15,.18);
  --t-1:#2c2519;     /* near-black warm */
  --t-2:#5f5645;
  --t-3:#8a8170;
  --t-4:#b8b0a0;
  --accent:#6f4be8;
  --accent-2:#3b82f6;
  --accent-glow:rgba(111,75,232,.14);
  --up:#0d9e6a;
  --down:#d83a55;
  --warn:#c98028;
  --info:#3b82f6;
  --sh-1: 0 1px 0 rgba(255,255,255,.6) inset, 0 1px 2px rgba(60,40,15,.08);
  --sh-2: 0 8px 32px rgba(60,40,15,.10), 0 1px 0 rgba(255,255,255,.5) inset;
  --sh-3: 0 24px 60px rgba(60,40,15,.18), 0 1px 0 rgba(255,255,255,.6) inset;

  --chart-bg:#faf7f2;
  --chart-text:#8a8170;
  --chart-grid-v:rgba(60,40,15,.04);
  --chart-grid-h:rgba(60,40,15,.07);
  --chart-border:rgba(60,40,15,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg-0);color:var(--t-1);font-family:var(--font-sans);font-size:13px;line-height:1.45;-webkit-font-smoothing:antialiased;overflow:hidden}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,select,textarea{font:inherit;color:inherit;background:none;border:0;outline:0}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg-5);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--line-3)}

body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 600px at 12% -10%, var(--accent-glow), transparent 60%),
    radial-gradient(700px 500px at 100% 110%, rgba(95,168,255,.05), transparent 60%);
}
[data-theme="light"] body::before{
  background:
    radial-gradient(900px 600px at 12% -10%, rgba(111,75,232,.06), transparent 60%),
    radial-gradient(700px 500px at 100% 110%, rgba(59,130,246,.04), transparent 60%);
}

.app{
  position:relative;z-index:1;
  display:grid;
  /* --right-w is the watchlist panel width; updated live by the drag handle.
     The 5px column is the draggable divider between chart and watchlist. */
  grid-template-columns:230px 1fr 5px var(--right-w, 340px);
  grid-template-rows:54px 1fr 30px;
  grid-template-areas:"topbar topbar topbar topbar" "side main resizer right" "status status status status";
  height:100vh;width:100vw;
}

/* topbar */
.topbar{grid-area:topbar;display:flex;align-items:center;gap:14px;padding:0 16px;background:linear-gradient(180deg,var(--bg-1),var(--bg-2));backdrop-filter:blur(14px);border-bottom:1px solid var(--line-1)}
.brand{display:flex;align-items:center;gap:10px;width:198px;flex-shrink:0;cursor:pointer;border-radius:9px;padding:3px 6px 3px 3px;margin:-3px;transition:background .15s,transform .12s}
.brand:hover{background:var(--bg-3)}
.brand:active{transform:scale(.97)}
.brand:focus-visible{outline:2px solid var(--accent);outline-offset:1px}
.brand-logo{width:28px;height:28px;border-radius:8px;display:block;flex-shrink:0;box-shadow:0 0 0 1px rgba(255,255,255,.06),0 4px 12px rgba(124,108,255,.30)}
.brand-name{font-family:var(--font-display);font-weight:500;font-size:18px;letter-spacing:-.02em}
.brand-name em{font-style:italic;color:var(--t-2);font-weight:400}

.pair-selector{display:flex;align-items:center;gap:10px;height:34px;padding:0 12px 0 10px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-2);min-width:200px;cursor:pointer;transition:all .15s;position:relative}
.pair-selector:hover{border-color:var(--line-3);background:var(--bg-4)}
.pair-icon{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#f0b454,#f59554);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10px;color:#0a0c10;box-shadow:0 0 0 1px rgba(0,0,0,.3) inset}
.pair-meta{flex:1;line-height:1.1}
.pair-symbol{font-weight:600;font-size:13px;letter-spacing:.01em}
.pair-name{font-size:10px;color:var(--t-3);margin-top:1px}

.pair-dropdown{
  position:absolute;top:100%;left:0;margin-top:6px;
  min-width:260px;max-height:320px;overflow-y:auto;
  background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:var(--r-2);box-shadow:var(--sh-2);
  z-index:50;padding:6px;display:none;
}
.pair-selector.open .pair-dropdown{display:block}
.pair-dd-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:6px;cursor:pointer}
.pair-dd-row:hover{background:var(--bg-3)}
.pair-dd-row.active{background:color-mix(in srgb, var(--accent) 16%, transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 40%, transparent)}
.pair-dd-row .sym{font-weight:500;font-size:12.5px}
.pair-dd-row .nm{font-size:10.5px;color:var(--t-3);margin-left:auto}

.tf-group{display:flex;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-2);overflow:hidden}
.tf-btn{height:32px;padding:0 11px;font-size:12px;font-weight:500;color:var(--t-2);font-family:var(--font-mono);border-right:1px solid var(--line-1);transition:all .12s}
.tf-btn:last-child{border-right:0}
.tf-btn:hover{color:var(--t-1);background:var(--bg-4)}
.tf-btn.active{color:var(--t-1);background:linear-gradient(180deg,rgba(124,108,255,.22),rgba(124,108,255,.08));box-shadow:0 0 0 1px rgba(124,108,255,.35) inset}

.search{flex:1;max-width:340px;display:flex;align-items:center;gap:8px;height:32px;padding:0 12px;background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);color:var(--t-3)}
.search:hover{border-color:var(--line-2)}
.search input{flex:1;font-size:12.5px;color:var(--t-1)}
.search input::placeholder{color:var(--t-3)}
.search kbd{font-family:var(--font-mono);font-size:10px;padding:2px 5px;border-radius:4px;background:var(--bg-4);color:var(--t-3);border:1px solid var(--line-2)}

.top-spacer{flex:1}
.topbar-actions{display:flex;align-items:center;gap:6px}
.icon-btn{width:32px;height:32px;border-radius:var(--r-2);display:flex;align-items:center;justify-content:center;color:var(--t-2);position:relative;transition:all .12s}
.icon-btn:hover{background:var(--bg-3);color:var(--t-1)}
.icon-btn .dot{position:absolute;top:7px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}

.tg-status{display:flex;align-items:center;gap:7px;height:32px;padding:0 11px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-2);font-size:11.5px;color:var(--t-2)}
.tg-status.off{opacity:.55}
.tg-pulse{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 8px var(--up);animation:pulse 2s ease-in-out infinite}
.tg-status.off .tg-pulse{background:var(--t-4);box-shadow:none;animation:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

.quick-alert{display:flex;align-items:center;gap:7px;height:32px;padding:0 13px 0 11px;background:linear-gradient(180deg,rgba(124,108,255,.25),rgba(124,108,255,.12));border:1px solid rgba(124,108,255,.4);border-radius:var(--r-2);color:var(--t-1);font-weight:500;font-size:12px;box-shadow:0 4px 14px rgba(124,108,255,.18),0 1px 0 rgba(255,255,255,.08) inset;transition:all .15s}
.quick-alert:hover{background:linear-gradient(180deg,rgba(124,108,255,.35),rgba(124,108,255,.18));border-color:rgba(124,108,255,.55)}

.profile{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;border:1px solid var(--line-3);cursor:pointer;letter-spacing:.02em}

/* sidebar */
.sidebar{grid-area:side;background:var(--bg-1);border-right:1px solid var(--line-1);padding:14px 10px;display:flex;flex-direction:column;overflow-y:auto}
.nav-group{margin-bottom:18px}
.nav-label{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--t-4);padding:0 10px;margin-bottom:6px}
.nav-item{display:flex;align-items:center;gap:11px;height:34px;padding:0 10px;border-radius:var(--r-2);color:var(--t-2);font-size:13px;font-weight:450;width:100%;cursor:pointer;margin-bottom:1px;position:relative;transition:all .12s}
.nav-item:hover{background:var(--bg-3);color:var(--t-1)}
.nav-item.active{background:var(--bg-3);color:var(--t-1);box-shadow:0 0 0 1px var(--line-2) inset}
.nav-item.active::before{content:'';position:absolute;left:-10px;top:8px;bottom:8px;width:2px;background:var(--accent);border-radius:0 2px 2px 0;box-shadow:0 0 8px var(--accent)}
.nav-item svg{width:16px;height:16px;stroke-width:1.6;flex-shrink:0}
.nav-item .badge{margin-left:auto;font-family:var(--font-mono);font-size:10px;padding:1px 6px;border-radius:4px;background:var(--bg-4);color:var(--t-2)}
.nav-item .badge.live{background:rgba(38,209,139,.15);color:var(--up)}
.sidebar-foot{margin-top:auto;padding:10px;display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2)}
.sidebar-foot .av{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#7c6cff,#5fa8ff);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.sidebar-foot .meta{flex:1;line-height:1.15;font-size:12px}
.sidebar-foot .meta small{color:var(--t-3);font-size:10.5px}

/* main */
.main{grid-area:main;background:var(--bg-0);display:flex;flex-direction:column;overflow:hidden;position:relative}
.chart-tabs{display:flex;align-items:center;height:36px;padding:0 12px;background:var(--bg-1);border-bottom:1px solid var(--line-1);gap:2px}
.chart-tab{display:flex;align-items:center;gap:8px;height:28px;padding:0 12px;border-radius:var(--r-1);font-size:12px;color:var(--t-3);transition:all .12s}
.chart-tab:hover{color:var(--t-1);background:var(--bg-3)}
.chart-tab.active{color:var(--t-1);background:var(--bg-3);box-shadow:0 0 0 1px var(--line-2) inset}
.chart-tab .close{color:var(--t-4);font-size:14px}
.chart-tab .close:hover{color:var(--t-1)}
.chart-tab.add{color:var(--t-3);padding:0 8px;width:28px;justify-content:center}
.chart-toolbar-right{margin-left:auto;display:flex;align-items:center;gap:4px}
.toolbar-btn{height:28px;padding:0 10px;border-radius:var(--r-1);font-size:12px;color:var(--t-2);display:flex;align-items:center;gap:6px;transition:all .12s}
.toolbar-btn:hover{background:var(--bg-3);color:var(--t-1)}
.toolbar-btn svg{width:13px;height:13px;stroke-width:1.7}

.workspace{flex:1;display:grid;grid-template-columns:46px 1fr;overflow:hidden;position:relative}
.draw-tools{background:var(--bg-1);border-right:1px solid var(--line-1);padding:8px 0;display:flex;flex-direction:column;gap:2px;align-items:center}
.draw-tool{width:32px;height:32px;border-radius:var(--r-1);display:flex;align-items:center;justify-content:center;color:var(--t-3);transition:all .12s}
.draw-tool:hover{background:var(--bg-3);color:var(--t-1)}
.draw-tool.active{background:var(--bg-4);color:var(--accent);box-shadow:0 0 0 1px rgba(124,108,255,.3) inset}
.draw-tool[disabled]{opacity:.35;cursor:not-allowed;pointer-events:none}
.draw-tool svg{width:16px;height:16px;stroke-width:1.5}
.draw-tools .divider{width:24px;height:1px;background:var(--line-2);margin:5px 0}

.chart-wrap{position:relative;background:var(--bg-0);overflow:hidden}
#chart{position:absolute;inset:0}
/* brief highlight when user clicks the logo / Charts nav to "go to charts" */
.chart-wrap.chart-focus-pulse{box-shadow:inset 0 0 0 2px var(--accent);transition:box-shadow .2s}

.ticker-overlay{position:absolute;top:14px;left:18px;z-index:10;display:flex;align-items:flex-start;gap:18px;right:18px;pointer-events:none}
.ticker-symbol{font-family:var(--font-display);font-weight:500;font-size:22px;letter-spacing:-.02em;color:var(--t-1)}
.ticker-tf{display:inline-block;margin-left:8px;font-family:var(--font-mono);font-size:11px;color:var(--t-3);vertical-align:middle;padding:2px 7px;border-radius:4px;background:var(--bg-3);border:1px solid var(--line-2)}
.ticker-price{font-family:var(--font-mono);font-weight:500;font-size:22px;letter-spacing:-.01em;text-align:right}
.ticker-price.up{color:var(--up)}
.ticker-price.down{color:var(--down)}
.ticker-change{font-family:var(--font-mono);font-size:11.5px;margin-top:2px;text-align:right}
.ticker-change.up{color:var(--up)}
.ticker-change.down{color:var(--down)}
.ohlc-tag{font-family:var(--font-mono);font-size:11px;color:var(--t-3);display:flex;gap:14px;margin-top:6px;flex-wrap:wrap}
.ohlc-tag span b{color:var(--t-1);font-weight:500;margin-left:4px}
.ohlc-tag .up{color:var(--up)}
.ohlc-tag .down{color:var(--down)}

/* replay bar — sits in a reserved strip BELOW the chart's x-axis so the
   time/date labels stay fully visible. When replay is active, .chart-wrap gets
   .replay-active which shrinks the chart to leave room at the bottom. */
.replay-bar{position:absolute;bottom:9px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:6px;padding:6px;background:color-mix(in srgb, var(--bg-2) 92%, transparent);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:12px;box-shadow:var(--sh-2);z-index:20}
.replay-bar.hidden{display:none}
/* Reserve a strip at the bottom of the chart-wrap for the time axis + replay bar.
   The chart shrinks up by 56px; its x-axis now renders above the floating bar. */
.chart-wrap.replay-active #chart{bottom:56px}
.replay-btn{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--t-2);transition:all .12s}
.replay-btn:hover{background:var(--bg-4);color:var(--t-1)}
.replay-btn.play{background:linear-gradient(180deg,rgba(124,108,255,.3),rgba(124,108,255,.15));color:var(--t-1);box-shadow:0 0 0 1px rgba(124,108,255,.35) inset}
.replay-divider{width:1px;height:18px;background:var(--line-2);margin:0 4px}
.replay-speed{font-family:var(--font-mono);font-size:11px;color:var(--t-2);padding:0 9px;height:30px;display:flex;align-items:center;gap:5px}
.replay-progress{width:200px;height:30px;display:flex;align-items:center;padding:0 8px}
.replay-track{flex:1;height:3px;border-radius:2px;background:var(--bg-5);position:relative;cursor:pointer}
.replay-fill{position:absolute;left:0;top:0;height:100%;width:38%;border-radius:2px;background:linear-gradient(90deg,var(--accent-2),var(--accent));box-shadow:0 0 8px var(--accent-glow);pointer-events:none}
.replay-fill::after{content:'';position:absolute;right:-5px;top:-3px;width:9px;height:9px;border-radius:50%;background:var(--t-1);box-shadow:0 0 0 2px var(--accent),0 0 10px var(--accent-glow)}
.replay-time{font-family:var(--font-mono);font-size:10px;color:var(--t-3);padding:0 8px;height:30px;display:flex;align-items:center}

/* right sidebar */
.right{grid-area:right;background:var(--bg-1);border-left:1px solid var(--line-1);display:flex;flex-direction:column;overflow-y:auto}

/* Draggable divider between chart and watchlist. A thin column that widens its
   hit-area on hover and shows a colored grip while dragging. */
.right-resizer{
  grid-area:resizer;
  cursor:col-resize;
  position:relative;
  background:var(--line-1);
  transition:background .12s;
  z-index:5;
}
.right-resizer::before{
  /* invisible wider hit-area so it's easy to grab */
  content:"";position:absolute;inset:0 -4px;
}
.right-resizer:hover,.right-resizer.dragging{background:var(--accent)}
/* While dragging, kill text selection and force the col-resize cursor app-wide */
body.col-resizing{cursor:col-resize !important;user-select:none !important}
body.col-resizing *{cursor:col-resize !important}

.panel{border-bottom:1px solid var(--line-1);padding:14px 14px 12px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.panel-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--t-2);display:flex;align-items:center;gap:7px}
.panel-title .live-dot{width:6px;height:6px;border-radius:50%;background:var(--up);box-shadow:0 0 6px var(--up);animation:pulse 2s infinite}
.panel-actions{display:flex;gap:2px}
.panel-actions button{width:22px;height:22px;border-radius:5px;color:var(--t-3);display:flex;align-items:center;justify-content:center}
.panel-actions button:hover{background:var(--bg-3);color:var(--t-1)}

.wl-tabs{display:flex;gap:4px;margin-bottom:8px;padding:2px;background:var(--bg-2);border-radius:6px}
.wl-tab{flex:1;padding:5px 8px;font-size:11px;font-weight:500;color:var(--t-3);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .12s}
.wl-tab:hover{color:var(--t-2)}
.wl-tab.active{background:var(--bg-4);color:var(--t-1);box-shadow:0 1px 2px rgba(0,0,0,.15)}

.wl-row{display:grid;grid-template-columns:1fr auto auto 0fr;align-items:center;gap:10px;padding:7px 6px;cursor:pointer;border-radius:6px;margin:0 -6px;transition:background .1s}
.wl-row:hover{background:var(--bg-3)}
.wl-row.active{background:var(--bg-3)}
.wl-sym{font-size:12.5px;font-weight:500;color:var(--t-1)}
.wl-name{font-size:10px;color:var(--t-3);margin-top:1px}
.wl-price{font-family:var(--font-mono);font-size:12px;color:var(--t-1);text-align:right}
.wl-chg{font-family:var(--font-mono);font-size:10.5px;text-align:right;font-weight:500;padding:2px 5px;border-radius:4px;min-width:54px}
.wl-chg.up{color:var(--up);background:rgba(38,209,139,.08)}
.wl-chg.down{color:var(--down);background:rgba(239,85,113,.08)}
/* Delete button: collapsed (0 width) until row hover, then reveals. Keeps the
   layout identical to before until you actually want to remove a pair. */
.wl-del{display:flex;align-items:center;justify-content:center;width:0;height:22px;padding:0;border:none;background:transparent;color:var(--t-3);border-radius:5px;cursor:pointer;overflow:hidden;opacity:0;transition:opacity .1s,color .1s,background .1s;flex-shrink:0}
.wl-row:hover .wl-del{width:22px;opacity:1}
.wl-del:hover{color:var(--down);background:rgba(239,85,113,.12)}
.wl-del:focus-visible{width:22px;opacity:1;outline:1px solid var(--down);outline-offset:1px}

.level-row{display:flex;align-items:center;gap:10px;padding:9px 8px;margin:0 -8px 4px;border-radius:8px;cursor:pointer;transition:background .1s}
.level-row:hover{background:var(--bg-3)}
.level-tag{width:38px;flex-shrink:0;font-family:var(--font-mono);font-size:9.5px;font-weight:600;text-align:center;padding:3px 0;border-radius:4px;letter-spacing:.04em}
.level-tag.supply{background:rgba(239,85,113,.12);color:#ff8b9d}
.level-tag.demand{background:rgba(38,209,139,.12);color:#5fe4a8}
.level-tag.flip{background:rgba(240,180,84,.12);color:var(--warn)}
.level-info{flex:1;min-width:0}
.level-pair{font-size:12px;font-weight:500;color:var(--t-1);display:flex;align-items:center;gap:6px}
.level-pair small{font-size:10px;color:var(--t-3);font-weight:400}
.level-zone{font-family:var(--font-mono);font-size:10.5px;color:var(--t-3);margin-top:2px}
.level-dist{font-family:var(--font-mono);font-size:11px;font-weight:500;text-align:right;color:var(--warn)}
.level-dist small{display:block;font-size:9.5px;color:var(--t-3);font-weight:400;margin-top:1px}

.alert-card{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:11px 12px;margin-bottom:7px;position:relative;cursor:pointer;transition:all .12s}
.alert-card:hover{border-color:var(--line-2)}
.alert-card.armed::before{content:'';position:absolute;left:0;top:14px;bottom:14px;width:2px;background:var(--accent);border-radius:0 2px 2px 0;box-shadow:0 0 6px var(--accent-glow)}
.alert-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;gap:8px}
.alert-pair{font-size:12px;font-weight:500;color:var(--t-1);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-state{font-family:var(--font-mono);font-size:9.5px;font-weight:600;padding:2px 6px;border-radius:4px;letter-spacing:.05em;flex-shrink:0}
.alert-state.armed{background:rgba(124,108,255,.15);color:#a496ff}
.alert-state.triggered{background:rgba(38,209,139,.12);color:var(--up)}
.alert-state.cooling{background:rgba(240,180,84,.12);color:var(--warn)}
.alert-state.expired{background:var(--bg-4);color:var(--t-3)}
.alert-state.paused{background:rgba(240,180,84,.15);color:var(--warn)}
.alert-card.paused{opacity:.65}
.alert-card.paused::before{content:'';position:absolute;left:0;top:14px;bottom:14px;width:2px;background:var(--warn);border-radius:0 2px 2px 0}
.ar-tf-badge{display:inline-block;font-family:var(--font-mono);font-size:9px;font-weight:600;padding:1px 5px;border-radius:3px;background:var(--bg-4);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);margin:0 4px;letter-spacing:.04em;vertical-align:middle}
.alert-detail{font-size:11.5px;color:var(--t-2);line-height:1.45}
.alert-detail b{color:var(--t-1);font-weight:500;font-family:var(--font-mono)}
.alert-foot{display:flex;align-items:center;justify-content:space-between;margin-top:7px;padding-top:7px;border-top:1px solid var(--line-1);font-size:10.5px;color:var(--t-3)}
.alert-foot .chans{display:flex;gap:6px}
.alert-foot .chans span{display:inline-flex;align-items:center;gap:3px;color:var(--t-3)}
.alert-foot .chans span.on{color:var(--accent-2)}

.structure-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;font-size:12px;border-bottom:1px dashed var(--line-1)}
.structure-row:last-child{border-bottom:0}
.structure-row .lbl{color:var(--t-3)}
.structure-row .val{font-family:var(--font-mono);font-weight:500;color:var(--t-1)}
.structure-row .val.up{color:var(--up)}
.structure-row .val.down{color:var(--down)}

.trade-row{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:10px 12px;margin-bottom:6px}
.trade-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px}
.trade-side{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.05em}
.trade-side.long{background:rgba(38,209,139,.15);color:var(--up)}
.trade-side.short{background:rgba(239,85,113,.15);color:var(--down)}
.trade-pair{font-size:12px;font-weight:500}
.trade-pnl{font-family:var(--font-mono);font-size:12px;font-weight:500}
.trade-pnl.up{color:var(--up)}
.trade-pnl.down{color:var(--down)}
.trade-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;font-size:10.5px}
.trade-meta .lbl{color:var(--t-3);font-size:9.5px;margin-bottom:1px;letter-spacing:.04em;text-transform:uppercase}
.trade-meta .val{font-family:var(--font-mono);color:var(--t-1);font-weight:500}
.trade-close{font-size:10.5px;color:var(--accent-2);margin-top:7px;cursor:pointer}
.trade-close:hover{color:#7cb6ff}

.qstat-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.qstat{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:9px 11px}
.qstat .lbl{font-size:9.5px;color:var(--t-3);letter-spacing:.06em;text-transform:uppercase}
.qstat .val{font-family:var(--font-mono);font-size:15px;font-weight:500;color:var(--t-1);margin-top:2px}
.qstat .val.up{color:var(--up)}
.qstat .val.down{color:var(--down)}
.qstat .sub{font-size:10px;color:var(--t-3);margin-top:1px}

/* status bar */
.statusbar{grid-area:status;background:var(--bg-1);border-top:1px solid var(--line-1);display:flex;align-items:center;padding:0 14px;gap:14px;font-family:var(--font-mono);font-size:10.5px;color:var(--t-3)}
.statusbar .seg{display:flex;align-items:center;gap:6px;height:100%}
.statusbar .seg b{color:var(--t-2);font-weight:500}
.statusbar .spacer{flex:1}
.statusbar .dot{width:6px;height:6px;border-radius:50%;background:var(--up);box-shadow:0 0 6px var(--up)}

/* modal */
.modal-veil{position:fixed;inset:0;z-index:100;background:rgba(8,10,14,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}
[data-theme="light"] .modal-veil{background:rgba(60,40,15,.32)}
.modal-veil.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{width:100%;max-width:980px;max-height:90vh;background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border:1px solid var(--line-2);border-radius:var(--r-4);box-shadow:var(--sh-3);display:flex;flex-direction:column;overflow:hidden;animation:rise .25s cubic-bezier(.2,.8,.3,1)}
@keyframes rise{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line-1)}
.modal-title{font-family:var(--font-display);font-size:20px;font-weight:500;letter-spacing:-.01em}
.modal-title em{font-style:italic;color:var(--t-3);font-weight:400;margin-left:6px}
.modal-close{margin-left:auto;width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--t-3)}
.modal-close:hover{background:var(--bg-3);color:var(--t-1)}
.modal-body{flex:1;overflow-y:auto;display:grid;grid-template-columns:330px 1fr}
.modal-body.single{grid-template-columns:1fr;padding:0}

.bt-form{padding:20px 22px;border-right:1px solid var(--line-1);display:flex;flex-direction:column;gap:16px}
.field-group{display:flex;flex-direction:column;gap:6px}
.field-label{font-size:11px;color:var(--t-3);letter-spacing:.04em;display:flex;align-items:center;justify-content:space-between}
.field-input{height:34px;padding:0 11px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-2);font-size:12.5px;color:var(--t-1);font-family:var(--font-mono);transition:border-color .12s;width:100%}
.field-input:hover{border-color:var(--line-3)}
.field-input:focus{border-color:rgba(124,108,255,.5);box-shadow:0 0 0 3px rgba(124,108,255,.12)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.chip-group{display:flex;gap:5px;flex-wrap:wrap}
.chip{height:28px;padding:0 11px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:7px;font-family:var(--font-mono);font-size:11px;color:var(--t-2);transition:all .12s}
.chip:hover{border-color:var(--line-3);color:var(--t-1)}
.chip.active{background:linear-gradient(180deg,rgba(124,108,255,.22),rgba(124,108,255,.08));color:var(--t-1);border-color:rgba(124,108,255,.4)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}
.toggle-row .lbl{font-size:12px;color:var(--t-1)}
.toggle-row .sub{font-size:10.5px;color:var(--t-3);margin-top:1px}
.toggle{width:32px;height:18px;border-radius:9px;background:var(--bg-4);position:relative;cursor:pointer;transition:background .15s}
.toggle.on{background:var(--accent)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--t-1);border-radius:50%;transition:left .15s}
.toggle.on::after{left:16px}

.bt-run{margin-top:auto;height:38px;background:linear-gradient(180deg,rgba(124,108,255,.4),rgba(124,108,255,.2));border:1px solid rgba(124,108,255,.5);border-radius:var(--r-2);color:var(--t-1);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 6px 20px rgba(124,108,255,.2),0 1px 0 rgba(255,255,255,.08) inset;transition:all .15s}
.bt-run:hover:not(:disabled){background:linear-gradient(180deg,rgba(124,108,255,.55),rgba(124,108,255,.3))}
.bt-run:disabled{opacity:.5;cursor:not-allowed}

.bt-results{padding:20px 22px;display:flex;flex-direction:column;gap:18px;overflow-y:auto}
.bt-empty{display:flex;align-items:center;justify-content:center;flex:1;color:var(--t-3);font-size:13px;text-align:center;padding:40px}
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.metric{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:12px 14px;position:relative;overflow:hidden}
.metric .lbl{font-size:10px;color:var(--t-3);letter-spacing:.06em;text-transform:uppercase}
.metric .val{font-family:var(--font-mono);font-size:20px;font-weight:500;color:var(--t-1);margin-top:4px;letter-spacing:-.01em}
.metric .val.up{color:var(--up)}
.metric .val.down{color:var(--down)}
.metric .delta{font-family:var(--font-mono);font-size:10.5px;color:var(--t-3);margin-top:2px}
.metric .delta.up{color:var(--up)}
.metric .delta.down{color:var(--down)}

.equity-card{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-3);padding:16px}
.equity-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:12px}
.equity-title{font-size:12px;font-weight:500;color:var(--t-2)}
.equity-val{font-family:var(--font-mono);font-size:18px;font-weight:500;color:var(--up)}
#equity-chart{width:100%;height:180px}

.trades-table{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-3);overflow:hidden}
.trades-head{display:grid;grid-template-columns:60px 1fr 90px 90px 90px 90px;padding:9px 14px;font-size:10px;color:var(--t-3);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line-1);background:var(--bg-1)}
.trades-row{display:grid;grid-template-columns:60px 1fr 90px 90px 90px 90px;padding:9px 14px;font-size:11.5px;border-bottom:1px solid var(--line-1);align-items:center}
.trades-row:last-child{border-bottom:0}
.trades-row:hover{background:var(--bg-3)}
.t-id{font-family:var(--font-mono);font-size:10.5px;color:var(--t-3)}
.t-time{font-family:var(--font-mono);font-size:11px;color:var(--t-2)}
.t-side{font-family:var(--font-mono);font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:4px;width:fit-content}
.t-side.long{background:rgba(38,209,139,.15);color:var(--up)}
.t-side.short{background:rgba(239,85,113,.15);color:var(--down)}
.t-rr{font-family:var(--font-mono);font-size:11px;color:var(--t-1)}
.t-pnl{font-family:var(--font-mono);font-size:11.5px;font-weight:500}
.t-pnl.up{color:var(--up)}
.t-pnl.down{color:var(--down)}

/* paper trade ticket */
.ticket-form{padding:24px;display:flex;flex-direction:column;gap:16px}
.ticket-side-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.side-btn{height:42px;border-radius:var(--r-2);font-weight:600;font-size:13px;letter-spacing:.02em;border:1px solid var(--line-2);background:var(--bg-3);color:var(--t-2);transition:all .12s}
.side-btn:hover{color:var(--t-1)}
.side-btn.long.active{background:linear-gradient(180deg,rgba(38,209,139,.25),rgba(38,209,139,.1));color:var(--up);border-color:rgba(38,209,139,.4)}
.side-btn.short.active{background:linear-gradient(180deg,rgba(239,85,113,.25),rgba(239,85,113,.1));color:var(--down);border-color:rgba(239,85,113,.4)}
.rr-display{padding:12px 14px;background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:12px;color:var(--t-3)}
.rr-display b{color:var(--t-1);font-size:14px}

/* journal */
.journal-list{padding:20px 22px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:60vh}
.journal-card{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:14px 16px}
.journal-head{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.journal-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.journal-tag{font-size:10px;font-family:var(--font-mono);padding:2px 7px;border-radius:4px;background:var(--bg-4);color:var(--t-2);letter-spacing:.04em}
.journal-tag.mistake{background:rgba(239,85,113,.12);color:#ff8b9d}

.toast{position:fixed;bottom:50px;left:50%;transform:translateX(-50%);background:var(--bg-3);border:1px solid var(--line-3);border-radius:var(--r-2);padding:10px 16px;font-size:12.5px;color:var(--t-1);box-shadow:var(--sh-2);z-index:200;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast.ok{border-color:rgba(38,209,139,.4)}
.toast.err{border-color:rgba(239,85,113,.4)}
.toast.warn{border-color:rgba(245,183,49,.5)}

@media (max-width:1400px){.app{grid-template-columns:200px 1fr 5px var(--right-w, 320px)}}
@media (max-width:1180px){
  .app{grid-template-columns:64px 1fr 5px var(--right-w, 300px)}
  .nav-item span:not(.badge){display:none}
  .nav-label{display:none}
  .sidebar-foot{display:none}
  .nav-item{justify-content:center;padding:0}
  .brand{width:auto}
  .brand-name{display:none}
}

/* ============================================================
   THEME TOGGLE
   ============================================================ */
.theme-toggle{position:relative}
.theme-toggle svg{position:absolute;top:50%;left:50%;transition:opacity .18s ease, transform .25s ease}
.theme-toggle .ico-sun{opacity:0;transform:translate(-50%,-50%) rotate(-90deg) scale(.6)}
.theme-toggle .ico-moon{opacity:1;transform:translate(-50%,-50%) rotate(0) scale(1)}
[data-theme="light"] .theme-toggle .ico-sun{opacity:1;transform:translate(-50%,-50%) rotate(0) scale(1)}
[data-theme="light"] .theme-toggle .ico-moon{opacity:0;transform:translate(-50%,-50%) rotate(90deg) scale(.6)}

/* ============================================================
   GENERIC VIEW MODAL CHROME (Alerts/Journal/Scanner/Analytics)
   ============================================================ */
.view-toolbar{display:flex;align-items:center;gap:8px;padding:14px 22px;border-bottom:1px solid var(--line-1);background:var(--bg-1)}
.view-filter-group{display:flex;gap:5px}
.filter-chip{height:28px;padding:0 12px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:7px;font-family:var(--font-mono);font-size:11px;color:var(--t-2);transition:all .12s;display:inline-flex;align-items:center;gap:6px}
.filter-chip:hover{border-color:var(--line-3);color:var(--t-1)}
.filter-chip.active{background:linear-gradient(180deg,var(--accent-glow),color-mix(in srgb, var(--accent-glow) 50%, transparent));color:var(--t-1);border-color:color-mix(in srgb, var(--accent) 40%, transparent)}

.view-content{padding:14px 22px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:62vh}
.view-empty{padding:40px 20px;text-align:center;font-size:13px;color:var(--t-3)}

.hidden{display:none !important}

/* ============================================================
   ALERTS LIST (full modal)
   ============================================================ */
.alert-row-full{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:12px 14px;display:grid;grid-template-columns:80px 1fr auto auto;gap:14px;align-items:center;transition:border-color .12s}
.alert-row-full:hover{border-color:var(--line-2)}
.alert-row-full .ar-state{font-family:var(--font-mono);font-size:9.5px;font-weight:600;padding:3px 8px;border-radius:4px;letter-spacing:.05em;text-align:center}
.alert-row-full .ar-state.armed{background:color-mix(in srgb, var(--accent) 16%, transparent);color:var(--accent)}
.alert-row-full .ar-state.triggered{background:color-mix(in srgb, var(--up) 14%, transparent);color:var(--up)}
.alert-row-full .ar-state.expired{background:var(--bg-4);color:var(--t-3)}
.alert-row-full .ar-state.paused{background:color-mix(in srgb, var(--warn) 16%, transparent);color:var(--warn)}
.alert-row-full.ar-paused{opacity:.65}
.ar-pause{color:var(--t-3)!important}.ar-pause:hover{color:var(--warn)!important}
.ar-resume{color:var(--warn)!important}.ar-resume:hover{color:var(--up)!important}
.alert-row-full .ar-meta{min-width:0}
.alert-row-full .ar-title{font-size:13px;font-weight:500;color:var(--t-1)}
.alert-row-full .ar-sub{font-size:11px;color:var(--t-3);margin-top:2px;font-family:var(--font-mono)}
.alert-row-full .ar-strength{font-family:var(--font-mono);font-size:11px;color:var(--t-2);text-align:right}
.alert-row-full .ar-strength small{display:block;font-size:9.5px;color:var(--t-3);margin-top:1px}
.alert-row-full .ar-actions{display:flex;gap:4px}
.alert-row-full .ar-actions button{width:26px;height:26px;border-radius:6px;color:var(--t-3);display:flex;align-items:center;justify-content:center;transition:all .12s}
.alert-row-full .ar-actions button:hover{background:var(--bg-3);color:var(--t-1)}
.alert-row-full .ar-actions button.danger:hover{color:var(--down)}

/* ============================================================
   JOURNAL
   ============================================================ */
.journal-row{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:13px 16px}
.journal-row .jr-head{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.journal-row .jr-side{font-family:var(--font-mono);font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.05em}
.journal-row .jr-side.long{background:color-mix(in srgb, var(--up) 16%, transparent);color:var(--up)}
.journal-row .jr-side.short{background:color-mix(in srgb, var(--down) 16%, transparent);color:var(--down)}
.journal-row .jr-sym{font-size:13px;font-weight:500;color:var(--t-1)}
.journal-row .jr-tf{font-family:var(--font-mono);font-size:10.5px;color:var(--t-3);padding:1px 6px;border-radius:4px;background:var(--bg-3)}
.journal-row .jr-pnl{margin-left:auto;font-family:var(--font-mono);font-size:13px;font-weight:500}
.journal-row .jr-pnl.up{color:var(--up)} .journal-row .jr-pnl.down{color:var(--down)}
.journal-row .jr-setup{font-size:12px;color:var(--t-2);margin-bottom:4px}
.journal-row .jr-notes{font-size:11.5px;color:var(--t-3);line-height:1.5;margin-top:6px;white-space:pre-wrap;word-wrap:break-word}
.journal-row .jr-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px;font-size:10.5px}
.journal-row .jr-meta-grid .lbl{color:var(--t-3);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}
.journal-row .jr-meta-grid .val{font-family:var(--font-mono);color:var(--t-1)}
.journal-row .jr-actions{margin-top:8px;display:flex;gap:6px}
.journal-row .jr-actions button{font-size:10.5px;color:var(--t-3);padding:3px 8px;border-radius:5px;background:var(--bg-3);border:1px solid var(--line-1)}
.journal-row .jr-actions button:hover{color:var(--t-1);border-color:var(--line-2)}
.journal-row .jr-actions button.danger:hover{color:var(--down);border-color:color-mix(in srgb, var(--down) 40%, transparent)}

.journal-form{padding:22px;display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--line-1);background:var(--bg-1)}
.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}

/* ============================================================
   SCANNER
   ============================================================ */
.scanner-head{display:grid;grid-template-columns:120px 110px 90px 110px 1fr;gap:14px;padding:10px 22px;font-size:10px;color:var(--t-3);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line-1);background:var(--bg-1)}
.scanner-row{display:grid;grid-template-columns:120px 110px 90px 110px 1fr;gap:14px;padding:10px 22px;font-size:12px;border-bottom:1px solid var(--line-1);align-items:center;transition:background .1s}
.scanner-row:hover{background:var(--bg-3)}
.scanner-row .sc-sym{font-weight:500;color:var(--t-1)}
.scanner-row .sc-sym small{display:block;font-size:10px;color:var(--t-3);margin-top:1px;font-weight:400}
.scanner-row .sc-price{font-family:var(--font-mono);color:var(--t-1)}
.scanner-row .sc-chg{font-family:var(--font-mono);font-size:11px;font-weight:500;padding:2px 7px;border-radius:4px;width:fit-content}
.scanner-row .sc-chg.up{color:var(--up);background:color-mix(in srgb, var(--up) 10%, transparent)}
.scanner-row .sc-chg.down{color:var(--down);background:color-mix(in srgb, var(--down) 10%, transparent)}
.scanner-row .sc-trend{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em}
.scanner-row .sc-trend.bullish{color:var(--up)}
.scanner-row .sc-trend.bearish{color:var(--down)}
.scanner-row .sc-trend.ranging{color:var(--t-3)}
.scanner-row .sc-level{font-size:11px;color:var(--t-2);font-family:var(--font-mono)}
.scanner-row .sc-level small{color:var(--t-3)}
.scanner-row .sc-level .near{color:var(--warn)}

/* ============================================================
   ANALYTICS
   ============================================================ */
.an-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.an-card{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:14px 16px}
.an-card .lbl{font-size:10px;color:var(--t-3);letter-spacing:.06em;text-transform:uppercase}
.an-card .val{font-family:var(--font-mono);font-size:22px;font-weight:500;color:var(--t-1);margin-top:4px;letter-spacing:-.01em}
.an-card .val.up{color:var(--up)} .an-card .val.down{color:var(--down)}
.an-card .delta{font-family:var(--font-mono);font-size:11px;color:var(--t-3);margin-top:2px}

.an-section{margin-bottom:18px}
.an-section h4{font-family:var(--font-display);font-size:14px;font-weight:500;margin-bottom:10px;letter-spacing:-.01em;color:var(--t-1)}
.an-bar-row{display:grid;grid-template-columns:80px 1fr 90px;gap:12px;align-items:center;padding:6px 0;font-size:12px}
.an-bar-row .lbl{font-family:var(--font-mono);color:var(--t-2)}
.an-bar-row .bar{height:8px;background:var(--bg-3);border-radius:4px;overflow:hidden;position:relative}
.an-bar-row .bar .fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent));border-radius:4px}
.an-bar-row .stats{font-family:var(--font-mono);font-size:11px;color:var(--t-3);text-align:right}

/* ============================================================
   SETTINGS
   ============================================================ */
.settings-section{display:flex;flex-direction:column;gap:8px}
.settings-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--t-3);margin-bottom:4px}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--line-1)}
.settings-row:last-child{border-bottom:0}
.settings-row .lbl{font-size:12.5px;color:var(--t-1);font-weight:500}
.settings-row .sub{font-size:11px;color:var(--t-3);margin-top:2px}
.theme-segment{display:flex;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-2);padding:2px;gap:2px}
.theme-seg-btn{height:28px;padding:0 14px;font-size:11.5px;color:var(--t-2);border-radius:7px;font-weight:500;transition:all .12s}
.theme-seg-btn:hover{color:var(--t-1)}
.theme-seg-btn.active{background:var(--bg-1);color:var(--t-1);box-shadow:0 0 0 1px var(--line-2) inset, var(--sh-1)}

/* ============================================================
   BROADCASTS
   ============================================================ */
.broadcast-row{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-2);padding:13px 16px}
.broadcast-row .br-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.broadcast-row .br-kind{font-family:var(--font-mono);font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.05em;background:var(--bg-3);color:var(--t-2)}
.broadcast-row .br-title{font-size:13px;font-weight:500;color:var(--t-1)}
.broadcast-row .br-time{margin-left:auto;font-family:var(--font-mono);font-size:10.5px;color:var(--t-3)}
.broadcast-row .br-body{font-size:11.5px;color:var(--t-2);line-height:1.5;white-space:pre-wrap}

/* ============================================================
   TOOLBAR POPOVERS (Indicators / Layouts)
   ============================================================ */
.chart-toolbar-right{position:relative}
.toolbar-popover{
  position:absolute;top:34px;right:0;min-width:240px;
  background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:var(--r-2);box-shadow:var(--sh-2);
  padding:6px;z-index:30;display:none;
}
.toolbar-popover.open{display:block}
.pop-head{display:flex;align-items:center;justify-content:space-between;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--t-3);padding:6px 8px 8px;border-bottom:1px solid var(--line-1);margin-bottom:4px}
.pop-action{height:24px;padding:0 9px;font-size:10.5px;color:var(--t-2);background:var(--bg-3);border:1px solid var(--line-2);border-radius:5px;display:inline-flex;align-items:center;gap:5px;text-transform:none;letter-spacing:0;font-weight:500}
.pop-action:hover{color:var(--t-1);border-color:var(--line-3)}
.pop-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:6px;gap:10px;cursor:pointer}
.pop-row:hover{background:var(--bg-3)}
.pop-row-title{font-size:12.5px;color:var(--t-1);font-weight:500;display:flex;align-items:center;gap:6px}
.pop-row-sub{font-size:10.5px;color:var(--t-3);margin-top:1px}
.pop-soon{font-family:var(--font-mono);font-size:9px;padding:1px 5px;border-radius:3px;background:var(--bg-4);color:var(--t-3);letter-spacing:.05em;text-transform:uppercase}
.pop-row .toggle.disabled{opacity:.4;pointer-events:none}
.pop-body{max-height:240px;overflow-y:auto}
.pop-empty{padding:14px 10px;font-size:11.5px;color:var(--t-3);text-align:center}
.layout-row{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;cursor:pointer}
.layout-row:hover{background:var(--bg-3)}
.layout-row .lt-meta{flex:1;min-width:0}
.layout-row .lt-name{font-size:12.5px;color:var(--t-1);font-weight:500}
.layout-row .lt-sub{font-size:10px;color:var(--t-3);margin-top:1px;font-family:var(--font-mono)}
.layout-row .lt-del{width:22px;height:22px;border-radius:5px;color:var(--t-4);display:flex;align-items:center;justify-content:center}
.layout-row .lt-del:hover{color:var(--down);background:color-mix(in srgb, var(--down) 10%, transparent)}

/* ── level-TF visibility popover (Approaching Levels panel) ─────────── */
.level-tf-popover{
  top:30px;right:0;min-width:210px;
}
.level-tf-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 10px;border-radius:5px;cursor:pointer;
  font-size:12px;color:var(--t-1);
}
.level-tf-row:hover{background:var(--bg-3)}
.level-tf-row .tf-tag{font-family:var(--font-mono);font-size:10.5px;color:var(--t-3);background:var(--bg-3);padding:1px 6px;border-radius:3px;letter-spacing:.04em}
.level-tf-row.on .tf-tag{color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, transparent)}
.level-tf-row .tf-check{width:14px;height:14px;border-radius:3px;border:1px solid var(--line-3);display:flex;align-items:center;justify-content:center}
.level-tf-row.on .tf-check{background:var(--accent);border-color:var(--accent)}
.level-tf-row.on .tf-check::after{content:'';width:7px;height:4px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translate(1px,-1px)}

/* ============================================================
   DRAW TOOL "SOON" + CANVAS OVERLAY
   ============================================================ */
.draw-tool.soon{opacity:.45;position:relative}
.draw-tool.soon::after{
  content:'';position:absolute;top:4px;right:4px;
  width:5px;height:5px;border-radius:50%;
  background:var(--warn);box-shadow:0 0 4px var(--warn);
}
.draw-tool.soon:hover{opacity:.7}

.draw-canvas{
  position:absolute;inset:0;
  pointer-events:none;
  z-index:5;
}
.draw-canvas.active{pointer-events:auto;cursor:crosshair}

.tool-hint{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:8px;
  padding:7px 8px 7px 13px;
  background:color-mix(in srgb, var(--bg-2) 92%, transparent);
  backdrop-filter:blur(14px);
  border:1px solid var(--line-2);border-radius:8px;
  box-shadow:var(--sh-1);z-index:11;
  font-size:11.5px;color:var(--t-1);
  font-family:var(--font-mono);
}
.tool-hint.hidden{display:none}
.tool-hint button{
  width:22px;height:22px;border-radius:5px;
  color:var(--t-3);display:flex;align-items:center;justify-content:center;
}
.tool-hint button:hover{background:var(--bg-3);color:var(--t-1)}

/* ============================================================
   PANEL TOGGLE BUTTON (Hide auto levels)
   ============================================================ */
.panel-toggle-btn{
  width:24px;height:22px;border-radius:5px;color:var(--t-3);
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;
}
.panel-toggle-btn:hover{background:var(--bg-3);color:var(--t-1)}
.panel-toggle-btn .ico-eye-off{display:none}
.panel-toggle-btn.muted{color:var(--t-4)}
.panel-toggle-btn.muted .ico-eye-on{display:none}
.panel-toggle-btn.muted .ico-eye-off{display:block}

/* ============================================================
   HTF ALIGNMENT STRIP
   ============================================================ */
.htf-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.htf-cell{
  background:var(--bg-2);border:1px solid var(--line-1);
  border-radius:var(--r-1);padding:8px 0;text-align:center;
  position:relative;cursor:pointer;transition:all .12s;
}
.htf-cell:hover{border-color:var(--line-2)}
.htf-cell.bullish{
  background:color-mix(in srgb, var(--up) 8%, var(--bg-2));
  border-color:color-mix(in srgb, var(--up) 22%, transparent);
}
.htf-cell.bearish{
  background:color-mix(in srgb, var(--down) 8%, var(--bg-2));
  border-color:color-mix(in srgb, var(--down) 22%, transparent);
}
.htf-cell.ranging{background:var(--bg-2);border-color:var(--line-2)}
.htf-cell.loading{opacity:.5}
.htf-tf{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--t-2);letter-spacing:.04em}
.htf-state{font-family:var(--font-mono);font-size:10px;margin-top:3px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.htf-cell.bullish .htf-state{color:var(--up)}
.htf-cell.bearish .htf-state{color:var(--down)}
.htf-cell.ranging .htf-state{color:var(--t-3)}
.htf-cell.loading .htf-state{color:var(--t-4)}
.htf-cell.current::after{
  content:'';position:absolute;top:-1px;left:8px;right:8px;height:2px;
  background:var(--accent);border-radius:0 0 2px 2px;
  box-shadow:0 0 6px var(--accent-glow);
}
.htf-verdict{
  font-size:11.5px;color:var(--t-2);line-height:1.5;
  padding:8px 10px;background:var(--bg-2);
  border:1px solid var(--line-1);border-radius:var(--r-1);
}
.htf-verdict b{color:var(--t-1)}
.htf-verdict .verdict-aligned{color:var(--up)}
.htf-verdict .verdict-conflict{color:var(--warn)}
.htf-verdict .verdict-mixed{color:var(--t-3)}

/* ── individual level hide toggle ───────────────────────────────────── */
.level-hidden { opacity: .45; }
.level-hidden .level-tag { filter: grayscale(.6); }

/* Action cluster keeps the eye + X tightly grouped on the right of each row,
   with consistent spacing whether one or both buttons are rendered. */
.level-actions {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
  margin-left: 4px;
}

/* Eye + X share base styling. Faded by default, fully visible on row hover
   so the row reads cleanly until the user actually wants to interact. */
.level-eye-btn,
.level-x-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  color: var(--t-3);
  border-radius: 5px;
  opacity: .4;
  transition: opacity .12s ease, color .12s ease, background .12s ease, transform .08s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  line-height: 0;
}
.level-eye-btn svg,
.level-x-btn svg {
  width: 12px;
  height: 12px;
  display: block;
}
.level-row:hover .level-eye-btn,
.level-row:hover .level-x-btn { opacity: .85; }
.level-eye-btn:hover,
.level-x-btn:hover {
  opacity: 1;
  color: var(--t-1);
  background: var(--bg-3);
}
.level-x-btn:hover {
  color: var(--down, #ef5571);
  background: rgba(239, 85, 113, .1);
}
.level-x-btn:active { transform: scale(.92); }
.level-hidden .level-eye-btn { opacity: .65; }

/* "Delete?" confirm pill — replaces the X glyph on the first click so a
   stray tap never nukes a drawn level by accident. Auto-cancels after 2s.
   Pulses gently so it's obvious something is waiting for confirmation. */
.level-x-btn.level-x-armed {
  width: auto;
  padding: 3px 8px;
  background: var(--down, #ef5571);
  color: #fff;
  opacity: 1;
  border-radius: 10px;
  animation: levelXArmedPulse 1.2s ease-in-out infinite;
}
.level-x-btn.level-x-armed:hover {
  background: var(--down, #ef5571);
  color: #fff;
  filter: brightness(1.08);
}
.level-x-confirm {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1;
  text-transform: uppercase;
}
@keyframes levelXArmedPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 85, 113, .45); }
  50%      { box-shadow: 0 0 0 4px rgba(239, 85, 113, 0); }
}

/* "MAN" tag for user-drawn levels. Accent purple distinguishes it from
   the DMD/SUP red/green of auto-detected zones at a glance. */
.level-tag.manual {
  background: rgba(124, 108, 255, .14);
  color: #aea3ff;
  box-shadow: inset 0 0 0 1px rgba(124, 108, 255, .22);
}

/* Subtle accent stripe on manual rows so they're scannable in a mixed list. */
.level-row.level-manual { box-shadow: inset 2px 0 0 var(--accent, #7c6cff); }
.level-row.level-manual:hover { box-shadow: inset 2px 0 0 var(--accent, #7c6cff), 0 0 0 transparent; }

/* Empty-state copy gets its own class instead of inline styles. */
.level-empty {
  font-size: 11px;
  color: var(--t-3);
  padding: 8px 0;
  text-align: center;
}

/* Banner shown when the chart's current TF is filtered out of the level draw.
   Uses the warn (gold) accent — same colour language as the VWAP line — so it
   reads as "heads up, the chart isn't showing what the list shows". */
.level-filter-note {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0 0 8px;
  padding: 8px 10px;
  border-radius: var(--r-1, 6px);
  background: rgba(240,180,84,.08);
  border: 1px solid rgba(240,180,84,.22);
  font-size: 10.5px;
  line-height: 1.4;
  color: var(--warn);
}
.level-filter-note button {
  flex-shrink: 0;
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--bg-0);
  background: var(--warn);
  border: none;
  border-radius: 5px;
  padding: 4px 9px;
  cursor: pointer;
  transition: filter .12s;
}
.level-filter-note button:hover { filter: brightness(1.08); }

/* Small mono pill marking a row the TF filter is keeping off the chart. */
.level-filtered-pill {
  display: inline-block;
  margin-top: 2px;
  font-family: var(--font-mono);
  font-size: 8.5px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--t-3);
  background: var(--line-2);
  border-radius: 3px;
  padding: 1px 5px;
}
