:root{
  --bg:#0a0c12; --panel:#11141d; --panel2:#161a26; --line:#222838;
  --txt:#e6e9f2; --muted:#8b93a7; --accent:#6ea8ff; --good:#39d98a; --bad:#ff6b6b;
  --warn:#ffd166; --emerging:#c792ea; --established:#5ad1c9;
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(1200px 600px at 70% -10%,#15192a 0,var(--bg) 60%);
  color:var(--txt);font:14px/1.45 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
h2{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
h2 small{text-transform:none;letter-spacing:0;color:var(--muted)}
small{color:var(--muted)}
.muted{color:var(--muted)}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;
  border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(10,12,18,.85);backdrop-filter:blur(8px);z-index:10}
.brand{font-size:16px}
.topstats{display:flex;align-items:center;gap:18px}
.stat{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.stat label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.stat b{font-variant-numeric:tabular-nums}
.badge{padding:2px 8px;border-radius:6px;background:#1d2740;color:var(--accent);font-size:12px}
.badge.live{background:#3a1d1d;color:var(--bad)}
.killbtn{background:#2a1620;color:var(--bad);border:1px solid #5a2433;border-radius:8px;padding:6px 10px;cursor:pointer;font-weight:700}
.killbtn.armed{background:var(--bad);color:#160a0a}
.logout{color:var(--muted);text-decoration:none;font-size:18px}

main{padding:16px;max-width:1500px;margin:0 auto}
.panel{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;margin-bottom:16px}
.grid{display:grid;grid-template-columns:1fr 420px;gap:16px;align-items:start}
@media(max-width:1000px){.grid{grid-template-columns:1fr}}

/* desk cards */
.cards{display:grid;grid-template-columns:repeat(8,1fr);gap:10px}
@media(max-width:1100px){.cards{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:10px;position:relative;overflow:hidden}
.card .ic{font-size:22px}
.card .nm{font-weight:700;margin-top:2px}
.card .ro{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;min-height:24px}
.card .st{font-size:11px;margin-top:6px;color:var(--muted);min-height:30px}
.card .meta{font-size:10px;color:#5d667d;margin-top:6px}
.card.thinking{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 22px -4px var(--accent);animation:pulse 1.1s ease-in-out infinite}
.card.speaking{border-color:var(--good);box-shadow:0 0 18px -6px var(--good)}
.card.active{border-color:#2d3a55}
.dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:#3a4055}
.card.thinking .dot{background:var(--accent)}
.card.speaking .dot{background:var(--good)}
.card.active .dot{background:var(--established)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 1px var(--accent),0 0 14px -6px var(--accent)}50%{box-shadow:0 0 0 1px var(--accent),0 0 26px 0 var(--accent)}}

/* flow lane */
.flow{display:flex;align-items:center;gap:8px;margin-top:14px;flex-wrap:wrap}
.flow span{font-size:11px;color:var(--muted);padding:4px 10px;border:1px solid var(--line);border-radius:20px}
.flow span.lit{color:var(--txt);border-color:var(--accent);box-shadow:0 0 14px -6px var(--accent)}
.flow i{color:#39435c;font-style:normal}

/* chat feed */
.feed{min-height:60vh}
.chat{display:flex;flex-direction:column;gap:8px;max-height:72vh;overflow:auto}
.msg{border:1px solid var(--line);border-radius:10px;padding:8px 10px;background:var(--panel2)}
.msg .hd{display:flex;gap:8px;align-items:center;font-size:12px}
.msg .who{font-weight:700}
.msg .sym{color:var(--accent);font-variant-numeric:tabular-nums}
.msg .tag{margin-left:auto;font-size:10px;color:var(--muted)}
.msg .pill{font-size:10px;padding:1px 7px;border-radius:10px;background:#1c2335}
.msg .body{color:var(--muted);margin-top:5px;font-size:12.5px;white-space:pre-wrap;display:none}
.msg.open .body{display:block}
.msg .body .reason{color:var(--txt)}
.who.hermes{color:var(--emerging)} .who.atlas{color:var(--established)}
.who.oracle{color:var(--warn)} .who.iris{color:#7ee0ff}
.status-ok{color:var(--good)} .status-degraded,.status-timeout,.status-empty,.status-malformed,.status-error{color:var(--bad)}

/* pnl + tables */
.pnl{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.pnl div{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:8px}
.pnl label{font-size:10px;color:var(--muted);text-transform:uppercase;display:block}
.pnl b{font-variant-numeric:tabular-nums}
.tbl{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
.tbl th{font-size:10px;text-transform:uppercase;color:var(--muted);text-align:right;padding:4px 6px;border-bottom:1px solid var(--line)}
.tbl th:first-child,.tbl td:first-child{text-align:left}
.tbl td{padding:5px 6px;border-bottom:1px solid #1a1f2c;text-align:right}
.pos{color:var(--good)} .neg{color:var(--bad)}
.seg-emerging{color:var(--emerging)} .seg-established{color:var(--established)}
.cand{color:var(--good)}

/* decisions + views */
.decisions,.views{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow:auto}
.drow,.vrow{display:flex;gap:8px;align-items:baseline;font-size:12px;border-bottom:1px solid #1a1f2c;padding:4px 0}
.drow .sym,.vrow .sym{color:var(--accent);min-width:84px}
.drow .act{font-weight:700;min-width:96px}
.drow .out{margin-left:auto;font-size:11px}
.out-executed{color:var(--good)} .out-rejected{color:var(--bad)} .out-no_trade{color:var(--muted)} .out-pending{color:var(--warn)}
.v-bullish{color:var(--good)} .v-bearish{color:var(--bad)} .v-neutral{color:var(--muted)}

footer{padding:14px 18px;color:#4d566c;font-size:11px;text-align:center}

/* open-trades page */
.brand .back{color:var(--muted);text-decoration:none;font-size:20px;margin-right:4px}
.brand .back:hover{color:var(--txt)}
.desknav{color:var(--muted);text-decoration:none;font-size:13px;padding:4px 10px;border:1px solid var(--line);border-radius:8px}
.desknav:hover{color:var(--txt);border-color:var(--accent)}
.pad{padding:8px 2px}
.trades{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}
.trade{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.trade.exiting{border-color:var(--warn);box-shadow:0 0 18px -8px var(--warn)}
.trade .thd{display:flex;align-items:baseline;gap:10px}
.trade .thd .sym{font-weight:700;font-size:15px;color:var(--accent)}
.trade .thd .mark{font-variant-numeric:tabular-nums}
.trade .thd .upl{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:700}
.trade .thd .selling{margin-left:8px;color:var(--warn);font-size:11px}
.trade .tstats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:10px 0}
.trade .tstats div{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:6px 8px}
.trade .tstats label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;display:block}
.trade .tstats b{font-variant-numeric:tabular-nums;font-size:12.5px}
.trade canvas.chart{width:100%;height:132px;display:block;margin:4px 0}
.gauge{margin:10px 0 6px}
.gauge.empty{display:none}
.gauge .track{position:relative;height:6px;border-radius:6px;
  background:linear-gradient(90deg,var(--bad),var(--warn) 50%,var(--good));opacity:.85}
.gauge .gfill{position:absolute;top:0;left:0;height:100%;border-radius:6px;background:rgba(255,255,255,.08)}
.gauge .tick{position:absolute;top:50%;width:2px;height:14px;transform:translate(-1px,-50%)}
.gauge .tick.entry{background:var(--muted)}
.gauge .tick.price{width:10px;height:10px;border-radius:50%;background:var(--txt);border:2px solid var(--bg);transform:translate(-5px,-50%)}
.sltp{display:flex;justify-content:space-between;gap:8px;font-size:11px;font-variant-numeric:tabular-nums}
.sltp .sl{color:var(--bad)} .sltp .tp{color:var(--good)} .sltp .entry-l{color:var(--muted)}
.sltp i{font-style:normal;opacity:.8}
.trade .thesis{margin-top:8px;font-size:11.5px;color:var(--muted);border-top:1px solid var(--line);padding-top:8px}
.trade .sell{display:flex;align-items:center;gap:10px;margin-top:12px}
.trade .sell .pctl{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.trade .sell select{background:#0c0f17;border:1px solid var(--line);border-radius:7px;color:var(--txt);padding:5px 6px;font-size:12px}
.forcebtn{margin-left:auto;background:#2a1620;color:var(--bad);border:1px solid #5a2433;border-radius:8px;
  padding:7px 14px;cursor:pointer;font-weight:700;font-size:12px}
.forcebtn:hover:not(:disabled){background:var(--bad);color:#160a0a}
.forcebtn:disabled{opacity:.55;cursor:default}

/* login */
body.login{display:grid;place-items:center;height:100vh}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px;width:320px;text-align:center}
.login-card input{width:100%;padding:10px;margin:10px 0;background:#0c0f17;border:1px solid var(--line);border-radius:8px;color:var(--txt)}
.login-card button{width:100%;padding:10px;background:var(--accent);border:0;border-radius:8px;color:#06101f;font-weight:700;cursor:pointer}
.login-card .err{color:var(--bad)}
