/* ============================================================
   FOREX EVOLUTION — components
   ============================================================ */

/* ---------------- APP LAYOUT ---------------- */
.app{position:relative;z-index:1;display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh}
.scrim{display:none}
.main-wrap{display:flex;flex-direction:column;min-width:0;height:100vh}
.main{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding:18px 22px 40px;scroll-behavior:smooth}
.wrap{max-width:1640px;margin:0 auto}
.grid{display:grid;gap:var(--gap)}
.row{display:grid;gap:var(--gap)}

/* ---------------- SIDEBAR ---------------- */
.sidebar{display:flex;flex-direction:column;background:linear-gradient(180deg,var(--s1),var(--bg));
  border-right:1px solid var(--border);height:100vh;position:relative;z-index:5}
.brand{display:flex;align-items:center;gap:11px;padding:18px 18px 16px;cursor:pointer}
.brand-mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;
  background:linear-gradient(140deg,var(--accent),var(--accent-2));
  box-shadow:0 0 0 1px rgba(var(--accent-rgb),.4),0 6px 18px var(--glow)}
.brand-txt{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.brand-txt .bn{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:.01em}
.brand-txt .bn em{font-style:italic;color:var(--accent)}
.brand-txt .bs{font-family:var(--cond);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-3);margin-top:2px}

.nav-scroll{flex:1 1 auto;overflow-y:auto;padding:6px 12px 12px}
.nav-group{margin-top:14px}
.nav-glabel{font-family:var(--cond);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-4);font-weight:600;padding:0 10px 7px}
.nav-item{display:flex;align-items:center;gap:11px;height:38px;padding:0 11px;border-radius:9px;
  color:var(--text-2);font-weight:500;font-size:13.5px;cursor:pointer;border:1px solid transparent;
  transition:.14s;position:relative;width:100%;text-align:left;background:none;font-family:var(--sans)}
a.nav-item{text-decoration:none}
.nav-item svg{color:var(--text-3);transition:.14s;flex:0 0 auto}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.035)}
.nav-item:hover svg{color:var(--text-2)}
.nav-item.active{color:var(--text);background:var(--accent-soft);border-color:rgba(var(--accent-rgb),.22)}
.nav-item.active svg{color:var(--accent)}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;
  border-radius:0 3px 3px 0;background:var(--accent);box-shadow:0 0 10px var(--glow)}
.nav-item .badge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:700;
  background:var(--accent-soft);color:var(--accent);padding:1px 6px;border-radius:20px}
.nav-item .livedot{margin-left:auto}

/* theme switcher */
.theme-dock{border-top:1px solid var(--border);padding:12px}
.theme-dock .eyebrow{padding:0 4px 9px;display:flex;align-items:center;gap:6px}
.swatches{display:flex;gap:7px;flex-wrap:wrap}
.swatch{width:30px;height:30px;border-radius:8px;cursor:pointer;position:relative;border:1.5px solid var(--border);
  transition:.14s;overflow:hidden}
.swatch:hover{transform:translateY(-1px)}
.swatch.on{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.3)}
.swatch .dot{position:absolute;inset:0;display:grid;place-items:center}
.swatch.on .dot::after{content:"";width:7px;height:7px;border-radius:50%;background:#fff;box-shadow:0 0 6px rgba(0,0,0,.5)}

/* ---------------- TOP STRIP ---------------- */
.topstrip{height:var(--topstrip-h);flex:0 0 auto;display:flex;align-items:center;gap:16px;
  padding:0 22px;border-bottom:1px solid var(--border);background:rgba(var(--accent-rgb),.0);
  backdrop-filter:blur(6px);position:relative;z-index:4}
.ts-title{font-family:var(--display);font-size:17px;font-weight:600;letter-spacing:.01em;white-space:nowrap}
.ts-sub{font-family:var(--cond);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);white-space:nowrap}
.ts-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.pill{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 12px;border-radius:8px;
  font-weight:600;font-size:12px;border:1px solid var(--border);background:var(--s2)}
.pill.trading{color:var(--pos);border-color:rgba(var(--pos-rgb),.3);background:var(--pos-soft)}
.pill.halted{color:var(--neg);border-color:rgba(var(--neg-rgb),.4);background:var(--neg-soft)}
.conn{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--text-3)}
.conn .mono{color:var(--text-2)}
.clock{font-family:var(--mono);font-size:12.5px;color:var(--text-2);font-variant-numeric:tabular-nums}

/* ---------------- DOTS ---------------- */
.dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto;display:inline-block;background:var(--text-4)}
.dot.green{background:var(--pos)} .dot.red{background:var(--neg)} .dot.amber{background:var(--warn)}
.dot.accent{background:var(--accent)} .dot.faint{background:var(--text-4)}
.dot.pulse{animation:dp 1.5s ease-in-out infinite}
@keyframes dp{0%,100%{box-shadow:0 0 0 0 var(--glow)}50%{box-shadow:0 0 0 5px transparent}}
.dot.green.pulse{animation:dpg 1.7s ease-in-out infinite}
@keyframes dpg{0%,100%{box-shadow:0 0 0 0 rgba(var(--pos-rgb),.5)}50%{box-shadow:0 0 0 4px transparent}}

/* ---------------- PANEL ---------------- */
.panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--r-lg);
  box-shadow:var(--sh);display:flex;flex-direction:column;min-width:0;backdrop-filter:var(--panel-blur);position:relative}
.panel-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--hairline)}
.panel-title{font-family:var(--cond);font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-2);font-weight:600;display:flex;align-items:center;gap:8px}
.panel-title svg{color:var(--accent)}
.panel-head .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.panel-body{padding:16px}
.panel-body.flush{padding:0}
.live{display:inline-flex;align-items:center;gap:6px;font-family:var(--cond);font-size:11px;font-weight:600;
  letter-spacing:.16em;color:var(--accent);text-transform:uppercase}
.count{font-family:var(--mono);font-size:11px;color:var(--text-3)}

/* ---------------- CHALLENGE HERO ---------------- */
.hero{position:relative;border:1px solid var(--panel-border);border-radius:var(--r-xl);overflow:hidden;
  background:
    radial-gradient(80% 130% at 88% -20%,rgba(var(--accent-rgb),.13),transparent 56%),
    linear-gradient(180deg,var(--s1),var(--bg));
  backdrop-filter:var(--panel-blur)}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(90deg,transparent,transparent 46px,rgba(255,255,255,.012) 46px,rgba(255,255,255,.012) 47px)}
.hero-inner{position:relative;display:grid;grid-template-columns:minmax(330px,.85fr) 1.15fr;gap:32px;padding:26px 30px}
@media(max-width:1040px){.hero-inner{grid-template-columns:1fr;gap:24px}}

.hero-bal .lead{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.bigbal{font-family:var(--mono);font-size:clamp(40px,4.4vw,62px);font-weight:700;letter-spacing:-.02em;
  line-height:.95;color:var(--text)}
.bigbal .c{color:var(--accent);text-shadow:0 0 28px var(--glow)}
.hero-bal .equity{font-family:var(--mono);font-size:14px;color:var(--text-2);margin-top:10px}
.hero-stats{display:flex;gap:34px;margin-top:18px;flex-wrap:wrap}
.hstat{display:flex;flex-direction:column;gap:3px}
.hstat .k{font-family:var(--cond);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);font-weight:600;white-space:nowrap}
.hstat .v{font-family:var(--mono);font-size:18px;font-weight:600}
.honest-note{margin-top:18px;padding:11px 14px;border-radius:10px;background:rgba(255,255,255,.025);
  border:1px solid var(--hairline);border-left:2px solid var(--accent);font-size:12.5px;color:var(--text-2);line-height:1.55}
.honest-note b{color:var(--text);font-weight:600}

/* progress ladder (the climb) */
.climb-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:12px}
.climb-end{display:flex;flex-direction:column;gap:2px}
.climb-end.r{align-items:flex-end;text-align:right}
.climb-end .k{font-family:var(--cond);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.climb-end .v{font-family:var(--mono);font-size:15px;font-weight:700}
.track{position:relative;height:44px;border-radius:12px;background:var(--s2);border:1px solid var(--border);overflow:hidden}
.track-fill{position:absolute;inset:0 auto 0 0;border-radius:11px;
  background:linear-gradient(90deg,var(--accent-2),var(--accent));box-shadow:0 0 24px var(--glow);
  transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.track-fill::after{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent,transparent 16px,rgba(255,255,255,.07) 16px,rgba(255,255,255,.07) 17px)}
.track-marker{position:absolute;top:-6px;bottom:-6px;width:2px;background:#fff;z-index:3;box-shadow:0 0 10px rgba(255,255,255,.6)}
.track-marker .tag{position:absolute;top:-22px;left:50%;transform:translateX(-50%);white-space:nowrap;
  font-family:var(--mono);font-size:11px;font-weight:700;color:var(--text)}
.track-pct{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-family:var(--mono);
  font-size:13px;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.7);z-index:2}
.rungs{display:flex;justify-content:space-between;margin-top:8px}
.rung{font-family:var(--mono);font-size:10px;color:var(--text-4);display:flex;align-items:center;gap:4px}
.rung.hit{color:var(--accent)}

/* mini gauges */
.gauges{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.gauge{background:var(--s2);border:1px solid var(--hairline);border-radius:12px;padding:13px 15px}
.gauge .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.gauge .v{font-family:var(--mono);font-size:17px;font-weight:700}
.bar{height:7px;border-radius:5px;background:var(--s3);overflow:hidden;position:relative}
.bar>i{position:absolute;inset:0 auto 0 0;border-radius:5px;display:block;transition:width 1s}
.gauge .note{font-family:var(--cond);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);margin-top:8px}

/* ---------------- STAT TILES ---------------- */
.tiles{display:grid;gap:var(--gap)}
.tile{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--r-lg);padding:15px 17px;backdrop-filter:var(--panel-blur)}
.tile .k{font-family:var(--cond);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);
  font-weight:600;display:flex;align-items:center;gap:7px}
.tile .v{font-family:var(--mono);font-size:26px;font-weight:700;letter-spacing:-.01em;margin-top:7px}
.tile .sub{font-size:11.5px;color:var(--text-3);margin-top:3px}

/* ---------------- TABLE ---------------- */
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl thead th{font-family:var(--cond);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);
  font-weight:600;text-align:right;padding:9px 14px;border-bottom:1px solid var(--hairline);position:sticky;top:0;
  background:var(--panel-bg);backdrop-filter:var(--panel-blur);z-index:1}
.tbl thead th:first-child{text-align:left}
.tbl tbody td{padding:11px 14px;text-align:right;border-bottom:1px solid var(--hairline);
  font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--text-2);white-space:nowrap}
.tbl tbody td:first-child{text-align:left}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .12s}
.tbl tbody tr:hover{background:rgba(255,255,255,.025)}
.sym{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:700;font-size:13px;color:var(--text)}
.dirbar{width:3px;height:24px;border-radius:2px;flex:0 0 auto;margin-left:-14px}
.dirbar.bull,.dirbar.long{background:var(--pos)} .dirbar.bear,.dirbar.short{background:var(--neg)}
.dirtag{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:.08em;padding:2px 7px;border-radius:5px}
.dirtag.bull,.dirtag.long{color:var(--pos);background:var(--pos-soft)}
.dirtag.bear,.dirtag.short{color:var(--neg);background:var(--neg-soft)}

.flash-up{animation:fu .7s ease-out} .flash-down{animation:fd .7s ease-out}
@keyframes fu{0%{background:rgba(var(--pos-rgb),.22)}100%{background:transparent}}
@keyframes fd{0%{background:rgba(var(--neg-rgb),.22)}100%{background:transparent}}

/* ---------------- GRADE / SIGNAL ---------------- */
.grade{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 10px;border-radius:7px;
  font-family:var(--mono);font-weight:800;font-size:12.5px;letter-spacing:.02em;border:1px solid transparent}
.grade.aplus{color:#1a1205;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 16px var(--glow)}
.grade.a{color:var(--accent);background:var(--accent-soft);border-color:var(--accent-line)}
.grade.bplus{color:var(--text);background:var(--s3);border-color:var(--border-2)}
.grade.b{color:var(--text-3);background:var(--s2);border-color:var(--border)}
.gradeword{font-family:var(--cond);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);font-weight:600}

.sig-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--r-lg);padding:15px 16px;
  position:relative;overflow:hidden;transition:.16s;animation:sigin .5s cubic-bezier(.2,.7,.3,1)}
.sig-card:hover{border-color:var(--border-2);transform:translateY(-2px);box-shadow:var(--sh-md)}
@keyframes sigin{from{transform:translateY(-10px) scale(.99)}to{transform:none}}
.sig-out{animation:sigout .35s ease forwards}
@keyframes sigout{to{opacity:0;transform:translateX(16px);height:0;padding:0;margin:0;border-width:0}}
.sig-top{display:flex;align-items:center;gap:10px}
.sig-sym{font-weight:700;font-size:16px;letter-spacing:.01em}
.sig-prices{display:flex;gap:18px;margin-top:13px}
.kv{display:flex;flex-direction:column;gap:2px}
.kv .k{font-family:var(--cond);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-4);font-weight:600}
.kv .vv{font-family:var(--mono);font-size:13px;color:var(--text-2);font-weight:600}
.ml{display:inline-flex;flex-direction:column;align-items:flex-end;line-height:1.05}
.ml .v{font-family:var(--mono);font-weight:700;font-size:14px}
.ml .k{font-family:var(--cond);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-4);font-weight:600}
.rr{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--text-2);padding:3px 8px;border-radius:6px;
  background:var(--s3);border:1px solid var(--hairline);white-space:nowrap}

/* 6-tap dots */
.taps{display:flex;gap:6px;align-items:center}
.tap{width:15px;height:15px;border-radius:5px;display:grid;place-items:center;border:1px solid transparent}
.tap.pass{background:var(--pos-soft);border-color:rgba(var(--pos-rgb),.4)}
.tap.uncertain{background:rgba(var(--warn-rgb,245,166,35),.14);border-color:var(--accent-line)}
.tap.fail{background:var(--neg-soft);border-color:rgba(var(--neg-rgb),.4)}
.tap>i{width:5px;height:5px;border-radius:50%}
.tap.pass>i{background:var(--pos)} .tap.uncertain>i{background:var(--warn)} .tap.fail>i{background:var(--neg)}
.tap-lbl{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-3)}

.verdict{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;border-radius:6px;
  font-family:var(--cond);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.verdict.go{color:var(--pos);background:var(--pos-soft)}
.verdict.wait{color:var(--warn);background:var(--accent-soft)}
.verdict.no_go,.verdict.nogo{color:var(--neg);background:var(--neg-soft)}

/* ---------------- FLEET ---------------- */
.fleet{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:8px}
.fpill{display:flex;align-items:center;gap:9px;height:38px;padding:0 12px;border-radius:9px;
  background:var(--s2);border:1px solid var(--hairline);transition:.15s}
.fpill:hover{border-color:var(--border);background:var(--s3)}
.fpill .nm{font-size:12px;color:var(--text-2);font-weight:500;white-space:nowrap}
.fpill .ms{margin-left:auto;font-family:var(--mono);font-size:9.5px;color:var(--text-4)}
.fpill.scan{border-color:var(--accent-line);box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.1)}

/* ---------------- BUTTONS / CONTROLS ---------------- */
.btn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 14px;border-radius:9px;
  font-family:var(--sans);font-weight:600;font-size:12.5px;cursor:pointer;border:1px solid var(--border);
  background:var(--s2);color:var(--text-2);transition:.13s;white-space:nowrap}
.btn:hover{background:var(--s3);color:var(--text);border-color:var(--border-2)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#15110a}
.btn.primary:hover{background:var(--accent-2);box-shadow:0 0 18px var(--glow)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--text-3)}
.btn.ghost:hover{background:var(--s2);color:var(--text-2)}
.btn.sm{height:28px;padding:0 11px;font-size:11.5px;border-radius:7px}
.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}

.chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:8px;
  font-family:var(--sans);font-weight:600;font-size:12px;cursor:pointer;border:1px solid var(--border);
  background:var(--s2);color:var(--text-3);transition:.12s;user-select:none}
.chip:hover{border-color:var(--border-2);color:var(--text-2)}
.chip.on{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-line)}

.seg{display:inline-flex;background:var(--s2);border:1px solid var(--border);border-radius:8px;padding:3px;gap:3px}
.seg button{height:28px;padding:0 13px;border:none;background:transparent;color:var(--text-3);
  font-family:var(--sans);font-weight:600;font-size:12px;border-radius:6px;cursor:pointer;transition:.12s}
.seg button.on{background:var(--accent-soft);color:var(--accent)}

.sel{height:34px;padding:0 12px;border-radius:9px;background:var(--s2);border:1px solid var(--border);
  color:var(--text-2);font-family:var(--sans);font-weight:600;font-size:12.5px;cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23a8adb8' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;padding-right:30px}
.sel:focus{outline:none;border-color:var(--accent)}
.inp{height:34px;padding:0 12px;border-radius:9px;background:var(--s2);border:1px solid var(--border);
  color:var(--text);font-family:var(--mono);font-weight:600;font-size:13px;width:100%}
.inp:focus{outline:none;border-color:var(--accent)}
.field-row{display:flex;flex-direction:column;gap:6px;margin-bottom:13px}
.field-row:last-child{margin-bottom:0}

.slider{-webkit-appearance:none;appearance:none;height:4px;border-radius:3px;background:var(--s3);outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--accent);
  cursor:pointer;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}

/* ---------------- RISK BANNER ---------------- */
.riskbox{display:flex;flex-direction:row;align-items:center;gap:14px;padding:16px}
.risk-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex:0 0 auto}
.riskbox.trading .risk-ic{background:var(--pos-soft);color:var(--pos);box-shadow:0 0 0 1px rgba(var(--pos-rgb),.3)}
.riskbox.halted .risk-ic{background:var(--neg-soft);color:var(--neg);box-shadow:0 0 0 1px rgba(var(--neg-rgb),.4)}
.risk-state{font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:.01em}
.riskbox.trading .risk-state{color:var(--pos)} .riskbox.halted .risk-state{color:var(--neg)}
.risk-reason{font-size:12px;color:var(--text-3);margin-top:2px}

/* ---------------- DEPTH LADDER (order book) ---------------- */
.ladder{font-family:var(--mono);font-size:12px}
.ladder-row{display:grid;grid-template-columns:1fr 84px 1fr;align-items:center;height:26px;position:relative}
.ladder-row .px{text-align:center;color:var(--text-2);font-weight:600;z-index:2}
.lbar{height:20px;border-radius:4px;position:relative;display:flex;align-items:center}
.lbar.ask{justify-self:start;background:var(--neg-soft);justify-content:flex-start;padding-left:8px}
.lbar.bid{justify-self:end;background:var(--pos-soft);justify-content:flex-end;padding-right:8px}
.lbar .sz{font-size:11px;z-index:2;font-weight:600}
.lbar.ask .sz{color:var(--neg)} .lbar.bid .sz{color:var(--pos)}
.lbar .fillb{position:absolute;top:0;bottom:0;border-radius:4px}
.lbar.ask .fillb{left:0;background:rgba(var(--neg-rgb),.22)}
.lbar.bid .fillb{right:0;background:rgba(var(--pos-rgb),.22)}
.lbar.wall{outline:1px solid currentColor;outline-offset:-1px}
.spread-row{display:flex;align-items:center;justify-content:center;gap:14px;height:34px;margin:5px 0;
  border-top:1px dashed var(--border);border-bottom:1px dashed var(--border)}
.imb-bar{height:10px;border-radius:6px;overflow:hidden;display:flex;background:var(--s3)}
.imb-bar .b{background:var(--pos)} .imb-bar .a{background:var(--neg)}

/* ---------------- COT / POSITIONING ---------------- */
.cot-net{position:relative;height:30px;border-radius:8px;background:var(--s3);overflow:hidden;display:flex}
.cot-net .mid{position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--border-2);z-index:2}
.cot-net .long{position:absolute;left:50%;top:4px;bottom:4px;background:rgba(var(--pos-rgb),.55);border-radius:0 4px 4px 0}
.cot-net .short{position:absolute;right:50%;top:4px;bottom:4px;background:rgba(var(--neg-rgb),.55);border-radius:4px 0 0 4px}

/* ---------------- HISTOGRAM / HEATMAP ---------------- */
.hist{display:flex;align-items:flex-end;gap:3px;height:130px}
.hist-bar{flex:1;border-radius:4px 4px 0 0;min-height:2px;transition:height .5s}
.heat{display:grid;gap:4px}
.heat-cell{border-radius:5px;display:grid;place-items:center;font-family:var(--mono);font-size:10px;
  color:rgba(255,255,255,.7);font-weight:600}

/* ---------------- TIMELINE ---------------- */
.tl{position:relative;padding-left:34px}
.tl::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(180deg,var(--accent),var(--border))}
.tl-node{position:relative;margin-bottom:14px}
.tl-dot{position:absolute;left:-29px;top:16px;width:16px;height:16px;border-radius:50%;
  background:var(--s1);border:2px solid var(--accent-line);z-index:2}
.tl-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--glow)}
.tl-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--r-lg);overflow:hidden;backdrop-filter:var(--panel-blur);transition:.15s}
.tl-card:hover{border-color:var(--border-2)}
.tl-h{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer}
.tl-ver{font-family:var(--mono);font-size:12.5px;font-weight:700;color:var(--accent);
  background:var(--accent-soft);border:1px solid var(--accent-line);padding:3px 9px;border-radius:7px}
.tl-hyp{font-size:13.5px;color:var(--text);flex:1;min-width:0;font-weight:500}
.tl-body{padding:0 16px 16px;border-top:1px solid var(--hairline);display:grid;grid-template-columns:1fr 1fr;gap:18px;padding-top:14px}
@media(max-width:760px){.tl-body{grid-template-columns:1fr}}
.diff{font-family:var(--mono);font-size:11.5px;line-height:1.85}
.diff .add{color:var(--pos)} .diff .rem{color:var(--neg)} .diff .key{color:var(--text-4)}
.vbadge{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border-radius:7px;
  font-family:var(--cond);font-weight:700;font-size:12px;letter-spacing:.06em}
.vbadge.improved{color:var(--pos);background:var(--pos-soft)}
.vbadge.worse{color:var(--neg);background:var(--neg-soft)}
.vbadge.neutral{color:var(--text-2);background:var(--s3)}

/* ---------------- JOURNAL ---------------- */
.jrow{display:grid;grid-template-columns:62px 1fr auto;gap:14px;align-items:center;padding:11px 16px;
  border-bottom:1px solid var(--hairline);transition:.12s}
.jrow:hover{background:rgba(255,255,255,.022)}
.jrow:last-child{border-bottom:none}
.jstat{display:inline-flex;align-items:center;gap:6px;font-family:var(--cond);font-weight:700;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:6px}
.jstat.traded{color:var(--pos);background:var(--pos-soft)}
.jstat.skipped{color:var(--text-3);background:var(--s3)}
.jstat.blocked{color:var(--warn);background:var(--accent-soft)}
.gate{font-family:var(--mono);font-size:11.5px;color:var(--text-3)}
.gate b{color:var(--neg);font-weight:600}

/* ---------------- CALENDAR ---------------- */
.cal-row{display:grid;grid-template-columns:96px 52px 1fr auto;gap:14px;align-items:center;padding:12px 16px;
  border-bottom:1px solid var(--hairline)}
.cal-row:last-child{border-bottom:none}
.cal-row.soon{background:var(--accent-soft)}
.impact{display:inline-flex;gap:2px}
.impact i{width:5px;height:12px;border-radius:1px;background:var(--text-4)}
.impact.high i{background:var(--neg)} .impact.med i:nth-child(-n+2){background:var(--warn)}
.impact.low i:first-child{background:var(--text-2)}
.ccy{font-family:var(--mono);font-weight:700;font-size:12px;color:var(--text-2);background:var(--s3);
  padding:2px 7px;border-radius:5px;justify-self:start}

/* ---------------- ML CARDS ---------------- */
.ml-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--r-lg);
  padding:16px;backdrop-filter:var(--panel-blur)}
.prob-ring-wrap{display:flex;align-items:center;gap:16px}
.metric{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--hairline)}
.metric:last-child{border-bottom:none}
.metric .k{font-family:var(--cond);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-weight:600}
.metric .v{font-family:var(--mono);font-size:14px;font-weight:700}

/* ---------------- EDGE TABLE ---------------- */
.edge-verdict{font-family:var(--cond);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 9px;border-radius:6px;white-space:nowrap}
.edge-verdict.trade{color:var(--pos);background:var(--pos-soft)}
.edge-verdict.watch{color:var(--warn);background:var(--accent-soft)}
.edge-verdict.drop{color:var(--neg);background:var(--neg-soft)}
.edge-verdict.marginal{color:var(--text-3);background:var(--s3)}

/* ---------------- MOBILE ---------------- */
.botnav{display:none}
.menu-btn{display:none}
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:270px;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:60;box-shadow:var(--sh-pop)}
  .app.navopen .sidebar{transform:none}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}
  .app.navopen .scrim{display:block}
  .menu-btn{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:9px;border:1px solid var(--border);background:var(--s2);color:var(--text-2);cursor:pointer}
  .topstrip{padding:env(safe-area-inset-top,0px) 14px 0;gap:11px;height:calc(var(--topstrip-h) + env(safe-area-inset-top,0px))}
  .ts-title{font-size:15px}
  .conn,.clock{display:none}
  .main{padding:12px 12px 84px}
  .hero-inner{padding:20px 18px}
  .bigbal{font-size:clamp(38px,11vw,52px)}
  .gauges{grid-template-columns:1fr}
  .botnav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;z-index:50;
    background:var(--s1);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);backdrop-filter:blur(10px)}
  .botnav button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
    background:none;border:none;color:var(--text-4);font-family:var(--cond);font-weight:600;font-size:10.5px;
    letter-spacing:.06em;text-transform:uppercase;cursor:pointer;min-height:44px}
  .botnav button.on{color:var(--accent)}
  .botnav button.on svg{color:var(--accent)}
}

/* helpers */
.flex{display:flex}.ac{align-items:center}.jb{justify-content:space-between}.col{flex-direction:column}
.g6{gap:6px}.g8{gap:8px}.g10{gap:10px}.g12{gap:12px}.g14{gap:14px}.g18{gap:18px}.wrapf{flex-wrap:wrap}
.scroll-y{overflow-y:auto;min-height:0}
.divider{height:1px;background:var(--hairline);margin:2px 0}
.ml-auto{margin-left:auto}
.start{align-content:start}

/* ---------------- MANUAL TRADE DESK ---------------- */
.td-grid{display:grid;grid-template-columns:1fr 326px;gap:var(--gap);align-items:start}
@media(max-width:1100px){.td-grid{grid-template-columns:1fr}}
.td-toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:10px 12px;
  background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--r-lg);margin-bottom:var(--gap)}
.td-chart{position:relative;background:var(--panel-bg);border:1px solid var(--panel-border);
  border-radius:var(--r-lg);overflow:hidden}
.tv-legend{position:absolute;top:10px;left:12px;z-index:4;font-family:var(--mono);font-size:11.5px;
  color:var(--text-2);display:flex;gap:12px;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.tv-legend b{font-weight:700}
.ind-chip{height:26px;padding:0 10px;border-radius:7px;background:var(--s2);border:1px solid var(--border);
  color:var(--text-3);font-size:11.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.ind-chip.on{color:var(--text);border-color:rgba(var(--accent-rgb),.4);background:var(--accent-soft)}
.ind-chip .sw{width:9px;height:9px;border-radius:2px;flex:0 0 auto}
.td-ticket{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--r-lg);
  padding:16px;position:sticky;top:8px}
.bigbtn{height:46px;border:none;border-radius:10px;font-family:var(--sans);font-weight:800;font-size:14px;
  letter-spacing:.02em;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1px;transition:.14s;color:#0a0a0a}
.bigbtn small{font-family:var(--mono);font-size:11px;font-weight:600;opacity:.85}
.bigbtn.buy{background:var(--pos)}.bigbtn.buy:hover{filter:brightness(1.08);box-shadow:0 0 18px rgba(var(--pos-rgb),.45)}
.bigbtn.sell{background:var(--neg)}.bigbtn.sell:hover{filter:brightness(1.08);box-shadow:0 0 18px rgba(var(--neg-rgb),.45)}
.acct-live{color:var(--neg)!important}
.modal-scrim{position:fixed;inset:0;background:rgba(3,5,9,.66);backdrop-filter:blur(3px);z-index:200;
  display:grid;place-items:center;padding:20px}
.modal{width:min(460px,94vw);background:var(--panel-bg);border:1px solid var(--panel-border);
  border-radius:var(--r-lg);padding:22px;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.modal.live{border-color:rgba(var(--neg-rgb),.55);box-shadow:0 0 0 1px rgba(var(--neg-rgb),.3),0 24px 70px rgba(0,0,0,.6)}
.live-banner{background:rgba(var(--neg-rgb),.12);border:1px solid rgba(var(--neg-rgb),.4);color:var(--neg);
  border-radius:9px;padding:10px 12px;font-size:12.5px;font-weight:600;margin-bottom:14px}
