/* ============================================================
   DESK v4 — net-new visual language (redesign/site-v4).
   Space Grotesk (display) / Inter (body) / JetBrains Mono (numerics).
   Modern-dark, layered depth, indigo accent, rounded panels.
   Token-driven; shared by all v4-rebuilt pages. The legacy DESK
   terminal stylesheet (style.css) is preserved at /legacy/.
   ============================================================ */
:root{
  --bg:#08090e; --bg2:#0c0e14; --panel:#13161f; --panel2:#181c27; --inset:#0a0c11;
  --line:#232838; --line-soft:#191d28; --line-bright:#333a4e;
  --ink:#f1f3f9; --soft:#a4adbf; --faint:#646e82; --mute:#7c8599;
  --accent:#7c8cff; --accent2:#a78bfa; --glow:rgba(124,140,255,.22);
  --green:#4ade9e; --green-s:rgba(74,222,158,.12);
  --red:#ff647c; --red-s:rgba(255,100,124,.12);
  --amber:#fbbf4a; --amber-s:rgba(251,191,74,.12);
  --blue:#5cb8f5; --blue-s:rgba(92,184,245,.12);
  /* tier system — five glanceable states */
  --tier-green:#4ade9e; --tier-yellow:#f5d44a; --tier-orange:#ff994d; --tier-red:#ff647c; --tier-pending:#646e82;
  --tg:var(--tier-green); --ty:var(--tier-yellow); --to:var(--tier-orange); --tr:var(--tier-red);
  --disp:"Space Grotesk",sans-serif; --body:"Inter",sans-serif; --mono:"JetBrains Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--bg);color:var(--ink);font-size:13px;height:100vh;overflow:hidden;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.pos{color:var(--green)} .neg{color:var(--red)} .muted{color:var(--faint)}
a{color:inherit}

/* ── top nav (replaces station + dock) ── */
.nav{height:54px;flex:none;display:flex;align-items:center;gap:26px;padding:0 22px;background:linear-gradient(180deg,#0b0d13,#08090e);border-bottom:1px solid var(--line)}
.brand{font-family:var(--disp);font-weight:700;font-size:19px;letter-spacing:-.02em;display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink)}
.brand .mk{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;font-size:12px;color:#0a0b10;font-weight:700}
.tabs{display:flex;gap:2px}
.tabs a{padding:8px 13px;border-radius:8px;color:var(--mute);text-decoration:none;font-size:13px;font-weight:500;transition:.13s}
.tabs a:hover{background:var(--panel);color:var(--soft)}.tabs a.on{background:var(--glow);color:var(--ink)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:18px}
.micro{display:flex;gap:14px}.micro .m{display:flex;flex-direction:column;line-height:1.2}.micro .m i{font-style:normal;font-size:9px;letter-spacing:.1em;color:var(--faint)}.micro .m b{font-family:var(--mono);font-size:12px}
.clk{font-family:var(--mono);font-size:12px;color:var(--soft)}
.navbtn{background:var(--panel2);border:1px solid var(--line);color:var(--soft);border-radius:8px;width:30px;height:30px;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.15s;flex:none;padding:0}
.navbtn:hover{border-color:var(--accent);color:var(--ink)}
.navbtn:active{transform:rotate(180deg)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 9px var(--green);animation:pulse 2.4s infinite}
.dot.warn{background:var(--amber);box-shadow:0 0 9px var(--amber)} .dot.err{background:var(--red);box-shadow:0 0 9px var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── scroll canvas + section headers ── */
.canvas{flex:1;overflow-y:auto;padding:20px 22px 50px}
.canvas::-webkit-scrollbar{width:11px}.canvas::-webkit-scrollbar-thumb{background:var(--line-bright);border-radius:6px;border:3px solid var(--bg)}
.wrap{max-width:1460px;margin:0 auto}
.note{padding:11px 14px;background:var(--glow);border:1px solid rgba(124,140,255,.25);border-radius:10px;font-size:12px;color:var(--soft);margin-bottom:16px}.note b{color:var(--accent)}
.sect{font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.1em;color:var(--mute);text-transform:uppercase;margin:24px 0 13px;display:flex;align-items:center;gap:12px}
.sect:first-of-type{margin-top:6px}
.sect::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.sect .tagn{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--glow);padding:2px 7px;border-radius:5px;letter-spacing:0}
.sect .hint{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:0;text-transform:none;font-weight:400}

/* ── hero / verdict ── */
.hero{display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center;background:radial-gradient(120% 160% at 0% 0%,rgba(74,222,158,.06),transparent 60%),var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px 26px;position:relative;overflow:hidden;margin-bottom:14px}
.hero::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--tg),rgba(74,222,158,.3))}
.hero.tier-YELLOW::before{background:linear-gradient(180deg,var(--ty),rgba(245,212,74,.3))}
.hero.tier-ORANGE::before{background:linear-gradient(180deg,var(--to),rgba(255,153,77,.3))}
.hero.tier-RED::before{background:linear-gradient(180deg,var(--tr),rgba(255,100,124,.3))}
.hero.tier-PENDING::before{background:var(--tier-pending)}
.h-tier{padding-left:8px}.h-tier .badge{font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.14em;color:var(--tg)}.h-tier .sub{font-size:11px;color:var(--faint);margin-top:3px}
.tier-YELLOW .badge{color:var(--ty)} .tier-ORANGE .badge{color:var(--to)} .tier-RED .badge{color:var(--tr)} .tier-PENDING .badge{color:var(--tier-pending)}
.h-mid .eyebrow{font-size:11px;letter-spacing:.16em;color:var(--faint);margin-bottom:8px;text-transform:uppercase}
.h-action{font-family:var(--disp);font-weight:600;font-size:26px;letter-spacing:-.02em;line-height:1.08;margin-bottom:9px}
.h-reason{color:var(--soft);font-size:13px;line-height:1.5;max-width:64ch;margin-bottom:13px}
.h-contra{list-style:none;display:flex;flex-direction:column;gap:4px;margin-bottom:13px}
.h-contra li{font-size:11.5px;color:var(--amber);display:flex;gap:7px;align-items:baseline}.h-contra li::before{content:"▸";color:var(--amber)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{display:flex;flex-direction:column;gap:2px;background:var(--panel2);border:1px solid var(--line-soft);border-radius:9px;padding:7px 12px}
.chip i{font-style:normal;font-size:9px;letter-spacing:.1em;color:var(--faint)}.chip b{font-family:var(--mono);font-size:13px;font-weight:600}.chip b.t{font-family:var(--disp);font-size:12px}
.rings{display:flex;gap:12px}
.ring{width:104px;height:104px;position:relative;display:grid;place-items:center}.ring svg{transform:rotate(-90deg)}
.ring .c{position:absolute;text-align:center}.ring .c .v{font-family:var(--mono);font-size:21px;font-weight:600}.ring .c .l{font-size:8.5px;letter-spacing:.08em;color:var(--faint);margin-top:1px}

/* ── day timeline + events ── */
.tlrow{display:grid;grid-template-columns:1fr auto;gap:14px;margin-bottom:14px}
.timeline{display:flex;align-items:center;padding:13px 18px;background:var(--bg2);border:1px solid var(--line-soft);border-radius:12px}
.tl-node{display:flex;flex-direction:column;align-items:center;gap:6px;flex:none;z-index:1}
.tl-node .d{width:11px;height:11px;border-radius:50%;background:var(--line-bright);border:2px solid var(--bg2)}
.tl-node.done .d{background:var(--accent)}.tl-node.now .d{background:var(--tg);box-shadow:0 0 0 4px var(--green-s)}
.tl-node .lab{font-size:10px;color:var(--faint);white-space:nowrap}.tl-node.now .lab{color:var(--tg);font-weight:600}
.tl-bar{flex:1;height:2px;background:var(--line)}.tl-bar.done{background:var(--accent)}
.tl-right{display:flex;gap:16px;align-items:center;padding-left:6px;border-left:1px solid var(--line);margin-left:14px}
.tl-right .cd{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}.tl-right .cd i{font-style:normal;font-size:9px;color:var(--faint)}.tl-right .cd b{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--accent)}
.events{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--bg2);border:1px solid var(--line-soft);border-radius:12px;min-width:250px}
.events .ico{width:30px;height:30px;border-radius:8px;background:var(--green-s);color:var(--green);display:grid;place-items:center;font-size:14px}
.events .x b{font-family:var(--disp);font-size:12px;display:block}.events .x span{font-size:11px;color:var(--faint);font-family:var(--mono)}

/* ── capital & risk strip ── */
.cap{display:grid;grid-template-columns:repeat(8,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:6px}
.cap .t{background:var(--panel);padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.cap .t i{font-style:normal;font-size:9px;letter-spacing:.1em;color:var(--faint)}.cap .t b{font-family:var(--mono);font-size:16px;font-weight:600}.cap .t b.sm{font-size:13px}
.cap .t .bar{height:5px;background:var(--inset);border-radius:3px;overflow:hidden;margin-top:2px}.cap .t .bar .f{height:100%;border-radius:3px}
.cap .t small{font-size:9.5px;color:var(--faint);font-family:var(--mono)}
.badge-ok{display:inline-block;font-size:10px;font-weight:600;color:var(--green);background:var(--green-s);border:1px solid rgba(74,222,158,.3);border-radius:6px;padding:2px 7px;width:fit-content}

/* ── card grid ── */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;grid-column:span 12}
.s8{grid-column:span 8}.s7{grid-column:span 7}.s6{grid-column:span 6}.s5{grid-column:span 5}.s4{grid-column:span 4}
@media(max-width:1100px){.s8,.s7,.s6,.s5,.s4{grid-column:span 12}}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;border-bottom:1px solid var(--line-soft)}
.card-h .t{font-family:var(--disp);font-weight:600;font-size:13px}.card-h .m{font-family:var(--mono);font-size:10.5px;color:var(--faint)}
.card-b{padding:14px 15px}
.legend{display:flex;gap:16px;flex-wrap:wrap;padding:0 15px 12px;font-size:10.5px;color:var(--faint)}
.legend span{display:flex;align-items:center;gap:6px}.legend i{width:14px;height:0;border-top-width:2px;border-top-style:solid;display:inline-block}
.swatch{width:11px;height:11px;border-radius:3px;display:inline-block}

/* ── gameplan / legs ── */
.slot{padding:12px 15px;border-bottom:1px solid var(--line-soft)}.slot:last-child{border-bottom:0}
.slot-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
.slot-l{display:flex;align-items:center;gap:9px}.slot-l .tag{font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.06em}.slot-l .win{font-family:var(--mono);font-size:10px;color:var(--faint)}
.slot-empty{color:var(--faint);font-size:12px;font-style:italic}
.ticket{padding:10px 0;border-top:1px dashed var(--line-soft)}.ticket:first-of-type{border-top:0}
.tk-top{display:flex;align-items:center;gap:9px;margin-bottom:7px}.tk-top .nm{font-weight:600;font-size:12.5px;min-width:108px}
.legs{display:flex;gap:5px;flex-wrap:wrap;flex:1}
.pill{font-family:var(--mono);font-size:10.5px;padding:3px 7px;border-radius:6px;border:1px solid}
.pill-s{background:var(--red-s);color:var(--red);border-color:rgba(255,100,124,.3)}
.pill-b{background:var(--green-s);color:var(--green);border-color:rgba(74,222,158,.3)}
.tk-top .pf{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--accent)}
.tk-meta{display:flex;gap:14px;font-family:var(--mono);font-size:10px;color:var(--faint);padding-left:2px;flex-wrap:wrap}.tk-meta b{color:var(--soft);font-weight:600}.tk-meta .sprd{color:var(--green)}

/* ── validated strategies ── */
.strat{display:flex;flex-direction:column;gap:10px}
.sc{background:var(--panel2);border:1px solid var(--line-soft);border-left:3px solid var(--tg);border-radius:10px;padding:11px 13px}
.sc.off{border-left-color:var(--tier-pending);opacity:.7}
.sc.cap-only{border-left-color:var(--ty)}
.sc-h{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.sc-h .nm{font-family:var(--disp);font-weight:600;font-size:12.5px}.sc-h .st{font-size:9px;font-weight:600;color:var(--green);letter-spacing:.06em}
.sc.off .sc-h .st{color:var(--tier-pending)} .sc.cap-only .sc-h .st{color:var(--ty)}
.sc-pf{font-family:var(--mono);font-size:13px;font-weight:600}.sc-pf .ci{color:var(--faint);font-size:10px;font-weight:400}
.sc-m{font-size:10.5px;color:var(--faint);margin-top:5px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ── containment ── */
.cgauge{position:relative;height:54px;margin:6px 0 14px}
.ctrack{position:absolute;top:22px;left:0;right:0;height:8px;background:linear-gradient(90deg,var(--tr) 0%,var(--to) 18%,var(--ty) 32%,var(--green) 45% 55%,var(--ty) 68%,var(--to) 82%,var(--tr) 100%);border-radius:5px;opacity:.45}
.ctick{position:absolute;top:16px;width:1px;height:20px;background:var(--line-bright)}
.ctick-l{position:absolute;top:0;font-size:9px;color:var(--faint);transform:translateX(-50%);font-family:var(--mono)}
.cneedle{position:absolute;top:10px;width:3px;height:32px;background:var(--ink);border-radius:2px;box-shadow:0 0 8px rgba(241,243,249,.5)}
.cneedle-l{position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:11px;font-weight:600;color:var(--ink);white-space:nowrap}
.crates{display:flex;gap:10px;margin-bottom:12px}
.crate{flex:1;background:var(--panel2);border:1px solid var(--line-soft);border-radius:10px;padding:10px 12px}
.crate .rt{font-family:var(--mono);font-size:18px;font-weight:600}.crate .rl{font-size:9.5px;color:var(--faint);margin-top:2px}
.crate .rb{height:4px;background:var(--inset);border-radius:2px;margin-top:6px;overflow:hidden}.crate .rb .f{height:100%;background:var(--green);border-radius:2px}
.rationale{font-size:12px;color:var(--soft);line-height:1.55;padding:11px 13px;background:var(--bg2);border:1px solid var(--line-soft);border-radius:10px}
.rationale .feat{display:inline-block;font-family:var(--mono);font-size:10.5px;color:var(--accent);background:var(--glow);border-radius:5px;padding:1px 6px;margin:3px 4px 0 0}

/* ── tables ── */
.tbl{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11.5px}
.tbl thead th{text-align:right;font-family:var(--body);font-weight:600;font-size:9.5px;letter-spacing:.08em;color:var(--faint);padding:8px 10px;border-bottom:1px solid var(--line)}
.tbl thead th:first-child{text-align:left}
.tbl td{padding:7px 10px;text-align:right;border-bottom:1px solid var(--line-soft);color:var(--soft)}
.tbl td:first-child{text-align:left;color:var(--ink)}.tbl tr:hover td{background:var(--panel2)}
.bchip{font-size:9.5px;padding:2px 7px;border-radius:5px;font-family:var(--body);font-weight:600}
.b-tight{background:var(--green-s);color:var(--green)} .b-mid{background:var(--blue-s);color:var(--blue)} .b-loose{background:var(--amber-s);color:var(--amber)} .b-breach{background:var(--red-s);color:var(--red)}

/* ── filter-arm gauges ── */
.arm{padding:9px 0;border-bottom:1px solid var(--line-soft)}.arm:last-child{border-bottom:0}
.arm-top{display:flex;justify-content:space-between;font-size:11px;margin-bottom:6px}.arm-top .k{color:var(--soft)}.arm-top .v{font-family:var(--mono);color:var(--ink)}.arm-top .v.ok{color:var(--green)}.arm-top .v.no{color:var(--red)}
.gauge{height:7px;background:var(--inset);border-radius:4px;position:relative}
.gauge-band{position:absolute;height:100%;background:var(--green-s);border:1px solid rgba(74,222,158,.3);border-radius:4px}
.gauge-mk{position:absolute;top:-3px;width:3px;height:13px;border-radius:2px;background:var(--accent)}.gauge-mk.fail{background:var(--red)}

/* ── greeks / vol / risk ── */
.greeks{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.gk{text-align:center;background:var(--panel2);border:1px solid var(--line-soft);border-radius:10px;padding:10px 6px}.gk .v{font-family:var(--mono);font-size:16px;font-weight:600}.gk .l{font-size:9px;letter-spacing:.08em;color:var(--faint);margin-top:3px}
.divflag{display:flex;align-items:center;gap:9px;padding:9px 12px;background:var(--amber-s);border:1px solid rgba(251,191,74,.3);border-radius:10px;font-size:11px;color:var(--amber)}
.term{display:flex;align-items:flex-end;gap:10px;height:74px;margin-bottom:10px;padding:0 6px}
.term .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px}.term .b .bar{width:100%;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--accent),rgba(124,140,255,.4))}
.term .b .lab{font-size:9.5px;color:var(--faint)}.term .b .val{font-family:var(--mono);font-size:11px;font-weight:600}
.term-tag{text-align:center;font-size:11px;color:var(--green);background:var(--green-s);border:1px solid rgba(74,222,158,.3);border-radius:7px;padding:5px;margin-bottom:10px;font-weight:600}
.vrow{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--line-soft);font-size:11.5px}.vrow:last-child{border-bottom:0}.vrow .k{color:var(--mute)}.vrow .v{font-family:var(--mono);font-weight:500}
.risk{display:flex;flex-direction:column;gap:7px}
.ri{display:flex;align-items:center;gap:10px;font-size:11.5px;color:var(--soft);padding:8px 11px;background:var(--panel2);border-radius:9px;border:1px solid var(--line-soft)}
.ri .ic{width:6px;height:6px;border-radius:50%;flex:none;background:var(--green)}
.ri.warn{border-color:rgba(251,191,74,.25);background:var(--amber-s);color:var(--amber)}.ri.warn .ic{background:var(--amber)}
.ri.err{border-color:rgba(255,100,124,.25);background:var(--red-s);color:var(--red)}.ri.err .ic{background:var(--red)}

.stub{font-size:9px;letter-spacing:.08em;color:var(--faint);border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-family:var(--mono)}

/* ── health banner ── */
.hbanner{padding:10px 14px;border-radius:10px;font-size:12px;margin-bottom:14px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.hbanner.warn{background:var(--amber-s);border:1px solid rgba(251,191,74,.3);color:var(--amber)}
.hbanner.err{background:var(--red-s);border:1px solid rgba(255,100,124,.3);color:var(--red)}
.hbanner .hi{font-weight:600;flex:none}

/* ── radar ── */
.radar{display:flex;gap:10px;flex-wrap:wrap}
.rc{flex:1;min-width:150px;background:var(--panel2);border:1px solid var(--line-soft);border-radius:10px;padding:11px 13px;border-top:2px solid var(--green)}
.rc.up{border-top-color:var(--ty)} .rc.miss{border-top-color:var(--line-bright);opacity:.55}
.rc .rn{font-weight:600;font-size:12.5px;margin-bottom:6px}
.rc .rev{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--green)}
.rc.miss .rev{color:var(--faint)}
.rc .rmt{font-family:var(--mono);font-size:10px;color:var(--faint);margin-top:2px}
.rc .rst{font-size:8.5px;letter-spacing:.08em;color:var(--faint);text-transform:uppercase;margin-top:5px}

/* ── option chain ── */
.chip-row{display:flex;gap:6px;flex-wrap:wrap}
.chip-btn{font-family:var(--mono);font-size:10.5px;color:var(--mute);background:var(--panel2);border:1px solid var(--line);border-radius:6px;padding:3px 9px;cursor:pointer;transition:.12s}
.chip-btn:hover{color:var(--soft);border-color:var(--line-bright)}
.chip-btn.on{background:var(--glow);color:var(--ink);border-color:var(--accent)}
.tbl .strike-c{color:var(--accent);font-weight:600;text-align:center}

/* ── alerts ── */
.alert-feed{display:flex;flex-direction:column;gap:6px;max-height:340px;overflow-y:auto}
.alert-row{display:grid;grid-template-columns:auto 1fr auto;gap:9px;align-items:center;padding:7px 10px;background:var(--panel2);border:1px solid var(--line-soft);border-radius:8px;font-size:11px}
.alert-row .ak{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.06em;color:var(--accent);border:1px solid var(--line);border-radius:4px;padding:1px 5px;white-space:nowrap}
.alert-row .am{color:var(--soft)} .alert-row .at{font-family:var(--mono);font-size:9.5px;color:var(--faint)}
.alert-row.warn{border-color:rgba(251,191,74,.25)} .alert-row.warn .ak{color:var(--amber)}
.alert-row.err{border-color:rgba(255,100,124,.25)} .alert-row.err .ak{color:var(--red)}

/* ── ops checklist (styles ops-checklist.js output for v4) ── */
.ops-status-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:12px}
.ops-status-dot{width:9px;height:9px;border-radius:50%;background:var(--faint);flex:none}
.ops-status-dot.ops-on-track{background:var(--green)} .ops-status-dot.ops-overdue{background:var(--red)} .ops-status-dot.ops-pending{background:var(--faint)}
.ops-status-text{color:var(--soft);flex:1}
.opsbtn,#btn-ops-reset{font-size:10px;color:var(--faint);background:var(--panel2);border:1px solid var(--line);border-radius:6px;padding:3px 8px;cursor:pointer}
.ops-windows{display:flex;flex-direction:column;gap:8px}
.ops-window{border:1px solid var(--line-soft);border-radius:10px;overflow:hidden;background:var(--panel2)}
.ops-window-active{border-color:var(--accent)}
.ops-window-past-incomplete{border-color:rgba(251,191,74,.3)}
.ops-window-head{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;cursor:pointer}
.ops-window-head-left{display:flex;align-items:baseline;gap:9px}
.ops-window-title{font-family:var(--disp);font-weight:600;font-size:12px;color:var(--ink)}
.ops-window-time{font-family:var(--mono);font-size:9.5px;color:var(--faint)}
.ops-window-completion{font-family:var(--mono);font-size:10px;color:var(--faint)}
.ops-window-body{padding:2px 12px 10px}
.ops-window-collapsed .ops-window-body{display:none}
.ops-step{display:flex;align-items:flex-start;gap:9px;padding:5px 0}
.ops-step-line{display:flex;align-items:center;gap:9px;font-size:11.5px;color:var(--soft);flex:1}
.ops-step-checkbox{accent-color:var(--accent);width:14px;height:14px;flex:none}
.ops-step-completed .ops-step-label,.ops-step-completed{color:var(--faint)}
.ops-step-action{color:var(--soft)} .ops-step-label{color:var(--soft)}
.ops-step-auto-tag{font-size:8.5px;letter-spacing:.06em;color:var(--accent);border:1px solid var(--line);border-radius:4px;padding:1px 5px;font-family:var(--mono)}
.ops-step-tooltip{font-size:9.5px;color:var(--faint);font-family:var(--mono)}
.ops-warning{font-size:11px;color:var(--amber)}

/* ── checkpoint detail accordion ── */
.cpd{border:1px solid var(--line);border-radius:12px;margin-bottom:8px;background:var(--panel);overflow:hidden}
.cpd>summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:11px 15px;font-family:var(--disp);font-weight:600;font-size:12.5px}
.cpd>summary::-webkit-details-marker{display:none}
.cpd>summary::before{content:"▸";color:var(--accent);margin-right:9px;font-size:10px;display:inline-block;transition:.15s}
.cpd[open]>summary::before{transform:rotate(90deg)}
.cpd-name{flex:1}
.cpd-meta{font-family:var(--mono);font-size:10px;color:var(--faint);font-weight:400}
.cpd-body{padding:4px 15px 14px;border-top:1px solid var(--line-soft)}
.cpd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:10px 0}
@media(max-width:760px){.cpd-grid{grid-template-columns:1fr}}
.cpd-reason{font-size:11.5px;color:var(--soft);line-height:1.5}

/* ── trade outcomes (History) ── */
.oc-chip{font-size:9.5px;font-weight:700;letter-spacing:.06em;padding:3px 9px;border-radius:6px;flex:none}
.oc-win{background:var(--green-s);color:var(--green);border:1px solid rgba(74,222,158,.4)}
.oc-loss{background:var(--red-s);color:var(--red);border:1px solid rgba(255,100,124,.4)}
.oc-na{background:var(--panel2);color:var(--faint);border:1px solid var(--line)}
svg.chart{display:block;width:100%;height:auto}
.loading{color:var(--faint);font-size:12px;font-style:italic;padding:8px 0}
