/* ============================================================================
   MS-Trading — app.css
   Single hand-written stylesheet for the algorithmic trading dashboard.
   Plain CSS + custom properties. No build step, no framework.

   Theme:   set <html data-theme="light"> to switch; default (no attr) = dark.
   Fonts:   add to <head> (preferred over the @import below for performance):
            <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
            <link href="https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap" rel="stylesheet">

   Semantic hooks a developer binds data to (stable, do not rename lightly):
     .kpi-card .kpi-card__label .kpi-card__value  (+ .is-loading/.is-error/.is-stale, .kpi-card--live)
     .source-badge  .source-badge--backtest  .source-badge--live
     .status-pill   .status-pill--running/--idle/--paused/--ok/--skipped/--error/--stale/--fresh
     .dir-badge     .dir-badge--long/--sell/--hold
     .pnl  .pnl--up/--down/--flat            (P&L figures)
     #equity-chart  #candles-chart           (TradingView Lightweight-Charts mount points)
     .trades-table  .honesty-banner  .methodology-note  .info-note
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* ---- Tokens : dark (default) -------------------------------------------- */
:root{
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,monospace;

  --bg:#08090c; --bg-2:#0b0d11; --surface:#11141a; --surface-2:#161a21; --surface-3:#1d222b;
  --line:#232a34; --line-2:#2e3743;
  --text:#e9edf3; --text-2:#9aa6b3; --text-3:#6a7682; --text-4:#49525d;

  /* brand accent — kept distinct from profit/loss semantics */
  --accent:#d6a65a; --accent-2:#e7bd7c; --accent-ink:#1b1405;
  --accent-tint:rgba(214,166,90,.13); --accent-line:rgba(214,166,90,.32);

  /* semantic : green = long/buy/profit · red = sell/loss · grey = hold/flat */
  --up:#35c08a;   --up-2:#4bd89e;   --up-tint:rgba(53,192,138,.13);  --up-line:rgba(53,192,138,.3);
  --down:#f0584e; --down-2:#ff6f66; --down-tint:rgba(240,88,78,.13); --down-line:rgba(240,88,78,.3);
  --flat:#8893a0; --flat-tint:rgba(136,147,160,.13);

  --warn:#e6a23c; --warn-tint:rgba(230,162,60,.14); --warn-line:rgba(230,162,60,.32);
  --info:#5b93cf; --info-tint:rgba(91,147,207,.14); --info-line:rgba(91,147,207,.32);   /* "live · demo" */
  --danger:#f0463c; --danger-2:#ff5a50; --danger-tint:rgba(240,70,60,.14); --danger-line:rgba(240,70,60,.4);

  --r-xs:5px; --r-sm:7px; --r:10px; --r-lg:14px; --r-xl:20px;
  --sh-1:0 1px 2px rgba(0,0,0,.4);
  --sh-2:0 6px 22px -8px rgba(0,0,0,.6);
  --sh-pop:0 18px 50px -12px rgba(0,0,0,.7);
  --grid:rgba(255,255,255,.045);   /* chart gridlines */

  /* chart series colours — read by charts.js, keep in sync with semantics */
  --chart-up:#35c08a; --chart-down:#f0584e; --chart-line:#d6a65a; --chart-bh:#8893a0;
}

/* ---- Tokens : light --------------------------------------------------- */
:root[data-theme="light"]{
  --bg:#eceef2; --bg-2:#f6f7f9; --surface:#ffffff; --surface-2:#f1f3f6; --surface-3:#e7eaf0;
  --line:#e0e4ea; --line-2:#cdd4dd;
  --text:#121821; --text-2:#586471; --text-3:#8a94a0; --text-4:#aab2bd;

  --accent:#b07d28; --accent-2:#9c6d1d; --accent-ink:#ffffff;
  --accent-tint:rgba(176,125,40,.1); --accent-line:rgba(176,125,40,.28);

  --up:#13935f;   --up-2:#0f7d50;   --up-tint:rgba(19,147,95,.1);   --up-line:rgba(19,147,95,.28);
  --down:#d6362b; --down-2:#bb2b21; --down-tint:rgba(214,54,43,.1);  --down-line:rgba(214,54,43,.28);
  --flat:#6b7682; --flat-tint:rgba(107,118,130,.1);

  --warn:#a9741a; --warn-tint:rgba(169,116,26,.12); --warn-line:rgba(169,116,26,.3);
  --info:#2f6fb0; --info-tint:rgba(47,111,176,.1);  --info-line:rgba(47,111,176,.28);
  --danger:#d2291f; --danger-2:#b71f16; --danger-tint:rgba(210,41,31,.1); --danger-line:rgba(210,41,31,.34);

  --sh-1:0 1px 2px rgba(20,30,45,.08);
  --sh-2:0 6px 22px -10px rgba(20,30,45,.18);
  --sh-pop:0 18px 50px -14px rgba(20,30,45,.26);
  --grid:rgba(10,20,40,.05);

  --chart-up:#13935f; --chart-down:#d6362b; --chart-line:#b07d28; --chart-bh:#6b7682;
}

/* ---- Base ------------------------------------------------------------- */
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--text); font-family:var(--sans);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,p{margin:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--accent-tint);color:var(--text)}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;border:3px solid var(--bg)}
::-webkit-scrollbar-track{background:transparent}

/* tabular monospace figures — every price/PnL/KPI/id/timestamp */
.mono,.num{font-family:var(--mono);font-variant-numeric:tabular-nums}

@keyframes shimmer{0%{background-position:-260px 0}100%{background-position:260px 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes ping{0%{transform:scale(1);opacity:.55}80%,100%{transform:scale(2.2);opacity:0}}

/* ============================================================================
   LAYOUT — shell, top bar, nav
   ========================================================================== */
.app-shell{min-height:100vh;background:var(--bg)}
.page{max-width:1240px;margin:0 auto;padding:22px 22px 80px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-title{font:700 24px/1.1 var(--sans);letter-spacing:-.02em}
.page-sub{margin-top:5px;font:400 13.5px var(--sans);color:var(--text-3)}

.topbar{
  position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:18px;
  padding:0 22px;height:58px;border-bottom:1px solid var(--line);
  background:color-mix(in srgb,var(--bg-2) 88%,transparent);backdrop-filter:blur(14px);
}
.brand{display:flex;align-items:center;gap:11px}
.brand__mark{display:flex;align-items:center;justify-content:center;width:29px;height:29px;border-radius:8px;
  background:linear-gradient(145deg,var(--accent),var(--accent-2));color:var(--accent-ink);font:800 12px/1 var(--sans);box-shadow:var(--sh-1)}
.brand__name{font:700 15px/1 var(--sans);letter-spacing:-.01em}
.mainnav{display:flex;align-items:center;gap:2px;margin-left:8px}
.nav-item{position:relative;padding:8px 13px;border:none;background:none;border-radius:var(--r-sm);
  font:600 13px var(--sans);color:var(--text-2);cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.nav-item:hover{color:var(--text)}
.nav-item.is-active{color:var(--text)}
.nav-item.is-active::after{content:"";position:absolute;left:13px;right:13px;bottom:-1px;height:2px;background:var(--accent);border-radius:2px}
.topbar__spacer{flex:1}
.avatar{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line-2);background:var(--surface-2);color:var(--text-2);font:700 12px var(--mono);cursor:pointer}

/* dropdown menus (instruments ▾, user) */
.menu{position:absolute;z-index:39;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r-lg);box-shadow:var(--sh-pop);overflow:hidden}
.menu__head{padding:10px 14px 7px;font:600 10px var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.menu__item{display:flex;width:100%;align-items:center;justify-content:space-between;gap:9px;
  padding:11px 14px;border:none;border-top:1px solid var(--line);background:none;color:var(--text);font:500 13px var(--sans);cursor:pointer}
.menu__item:hover{background:var(--surface-2)}
.menu__item--danger{color:var(--down)}
.menu__item--danger:hover{background:var(--down-tint)}

/* ============================================================================
   BUTTONS & CONTROLS
   ========================================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 17px;border:none;
  border-radius:var(--r-sm);font:700 13.5px var(--sans);cursor:pointer;box-shadow:var(--sh-1)}
.btn--primary{background:var(--accent);color:var(--accent-ink)}
.btn--primary:hover{background:var(--accent-2)}
.btn--danger{background:var(--danger);color:#fff}
.btn--danger:hover{background:var(--danger-2)}
.btn--danger[disabled],.btn[disabled]{background:var(--surface-3);color:var(--text-4);cursor:not-allowed;box-shadow:none}
.btn--secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--line-2);box-shadow:none}
.btn--secondary:hover{border-color:var(--text-3)}
.btn--ghost{background:none;color:var(--text-2);box-shadow:none}
.btn--ghost:hover{color:var(--text)}
.btn--icon{width:38px;height:38px;padding:0;background:var(--surface-2);color:var(--text-2);border:1px solid var(--line-2);box-shadow:none}
.btn--icon:hover{color:var(--text)}
.btn--block{width:100%}

/* segmented source toggle (Backtest / Live) */
.source-toggle{display:inline-flex;padding:3px;gap:2px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r)}
.source-toggle__opt{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:none;border-radius:var(--r-sm);
  background:none;color:var(--text-3);font:600 12.5px var(--sans);cursor:pointer}
.source-toggle__opt[aria-selected="true"]{background:var(--surface-3);color:var(--text);box-shadow:var(--sh-1)}
.source-toggle__dot{width:7px;height:7px;border-radius:50%;background:var(--info)}
.source-toggle__dot--sim{border-radius:1px;background:none;border:1px dashed var(--text-3)}

/* small icon-button cluster used by chart zoom (− ⟳ +) */
.icon-group{display:inline-flex;padding:3px;gap:2px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm)}
.icon-group button{width:26px;height:24px;border:none;border-radius:var(--r-xs);background:none;color:var(--text-2);
  font:600 15px var(--sans);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.icon-group button:hover{background:var(--surface-3)}

.pill-tag{padding:5px 10px;border:1px solid var(--line);border-radius:var(--r-xs);
  font:600 11px var(--mono);color:var(--text-2);background:var(--bg-2)}

/* toggle switch (cron active/paused) */
.switch{position:relative;display:inline-flex;width:42px;height:24px;border-radius:100px;cursor:pointer;
  background:var(--surface-3);border:1px solid var(--line-2);transition:background .15s}
.switch__knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-3);box-shadow:var(--sh-1);transition:left .15s}
.switch.is-on{background:var(--up);border-color:var(--up)}
.switch.is-on .switch__knob{left:20px;background:#fff}

/* acknowledge checkbox (decide-now danger zone) */
.ack{display:flex;align-items:flex-start;gap:11px;cursor:pointer}
.ack__box{flex:none;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-top:1px;
  border:1.5px solid var(--line-2);border-radius:5px;background:var(--surface-2)}
.ack.is-checked .ack__box{border-color:var(--danger-line);background:var(--danger-tint)}
.ack__check{display:none}
.ack.is-checked .ack__check{display:block}

/* ============================================================================
   BADGES — provenance (honesty), direction, status
   ========================================================================== */
/* SOURCE / PROVENANCE — first-class. backtest = dashed neutral; live = solid info + pulse */
.source-badge{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:var(--r-xs);
  font:600 11.5px var(--mono)}
.source-badge--backtest{border:1px dashed var(--line-2);background:var(--flat-tint);color:var(--text-2)}
.source-badge--live{border:1px solid var(--info-line);background:var(--info-tint);color:var(--info)}
.source-badge__dot{position:relative;display:inline-flex;width:8px;height:8px}
.source-badge__dot::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--info);animation:ping 1.8s ease-out infinite}
.source-badge__dot::after{content:"";position:relative;width:8px;height:8px;border-radius:50%;background:var(--info)}
/* compact provenance chip on KPI cards */
.sim-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border:1px dashed var(--line-2);border-radius:4px;
  background:var(--flat-tint);font:600 9px var(--mono);color:var(--text-3)}
.live-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border:1px solid var(--info-line);border-radius:4px;
  background:var(--info-tint);font:600 9px var(--mono);color:var(--info)}
.live-chip__dot{width:5px;height:5px;border-radius:50%;background:var(--info)}

/* DIRECTION badges — long-only strategy: entries buy (▲), exits sell (▼) */
.dir-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:4px;
  font:700 10px var(--mono);letter-spacing:.03em;white-space:nowrap}
.dir-badge--long{background:var(--up-tint);border:1px solid var(--up-line);color:var(--up)}
.dir-badge--sell{background:var(--down-tint);border:1px solid var(--down-line);color:var(--down)}
.dir-badge--hold{background:var(--flat-tint);border:1px solid var(--line-2);color:var(--text-2)}

/* STATUS pills — bot state, run outcome, data freshness */
.status-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:100px;
  font:600 12px var(--sans);border:1px solid var(--line-2);background:var(--surface-2);color:var(--text-2)}
.status-pill__dot{width:7px;height:7px;border-radius:50%;background:var(--flat)}
.status-pill--running{background:var(--up-tint);border-color:var(--up-line);color:var(--up)}
.status-pill--running .status-pill__dot{position:relative;background:var(--up)}
.status-pill--running .status-pill__dot::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--up);animation:ping 1.6s ease-out infinite}
.status-pill--idle .status-pill__dot{background:var(--flat)}
.status-pill--paused{background:var(--warn-tint);border-color:var(--warn-line);color:var(--warn)}
.status-pill--ok{background:var(--up-tint);border-color:var(--up-line);color:var(--up)}
.status-pill--skipped{background:var(--warn-tint);border-color:var(--warn-line);color:var(--warn)}
.status-pill--error{background:var(--danger-tint);border-color:var(--danger-line);color:var(--danger)}
.status-pill--stale{background:var(--warn-tint);border-color:var(--warn-line);color:var(--warn)}
.status-pill--fresh .status-pill__dot{background:var(--up)}

/* P&L figures — colour by sign */
.pnl{font-family:var(--mono);font-variant-numeric:tabular-nums;font-weight:600}
.pnl--up{color:var(--up)}
.pnl--down{color:var(--down)}
.pnl--flat{color:var(--text-3)}

/* ============================================================================
   HONESTY — caveat banner, methodology note, info tooltip
   ========================================================================== */
.honesty-banner{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:var(--r);
  background:var(--warn-tint);border:1px solid var(--warn-line)}
.honesty-banner__icon{flex:none;color:var(--warn)}
.honesty-banner__text{flex:1;font:500 13px/1.45 var(--sans);color:var(--text)}
.honesty-banner__close{flex:none;background:none;border:none;color:var(--warn);font:500 18px/1 var(--sans);cursor:pointer;opacity:.7;padding:0 2px}

.methodology-note{display:flex;align-items:flex-start;gap:11px;padding:13px 15px;border-radius:var(--r);
  background:var(--surface);border:1px solid var(--line);border-left:2px solid var(--accent-line)}
.methodology-note__tag{font:600 11px var(--mono);color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.methodology-note__text{font:400 12.5px/1.55 var(--sans);color:var(--text-2)}

/* info dot + hover tooltip (e.g. "Sharpe = per-bar, not annualized") */
.info-dot{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;
  border:1px solid var(--line-2);font:700 8px var(--mono);color:var(--text-3);cursor:help}
.info-note{position:relative;display:inline-block}
.info-note__pop{position:absolute;left:0;top:calc(100% + 8px);z-index:20;width:280px;
  background:var(--surface-3);border:1px solid var(--line-2);border-radius:var(--r);padding:12px 14px;box-shadow:var(--sh-pop);
  opacity:0;visibility:hidden;transition:opacity .12s}
.info-note:hover .info-note__pop,.info-note:focus-within .info-note__pop{opacity:1;visibility:visible}
.info-note__title{font:600 12px var(--mono);color:var(--accent);margin-bottom:5px}
.info-note__body{font:400 12.5px/1.5 var(--sans);color:var(--text-2)}
.note-caption{font:500 10.5px var(--mono);color:var(--warn)}   /* "per-bar · not annualized" */

/* ============================================================================
   CARDS & KPI STRIP
   ========================================================================== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg)}
.card__head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.card__title{font:700 15px var(--sans)}

.kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(184px,1fr));gap:13px}
.kpi-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 17px;
  display:flex;flex-direction:column;gap:11px}
.kpi-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.kpi-card__label{display:inline-flex;align-items:center;gap:5px;font:600 10.5px var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}
.kpi-card__value{font:600 26px/1 var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em;color:var(--text)}
.kpi-card__value--up{color:var(--up)} .kpi-card__value--down{color:var(--down)}
.kpi-card__sub{font:500 10.5px/1.35 var(--sans);color:var(--text-3)}
.kpi-card__spark{height:32px;margin:-3px -2px 0}
.kpi-card--live{border-color:var(--info-line);box-shadow:inset 0 0 0 1px var(--info-tint)}

/* — KPI card states — */
.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 37%,var(--surface-2) 63%);
  background-size:520px 100%;animation:shimmer 1.4s linear infinite;border-radius:4px}
.kpi-card.is-loading .kpi-card__value,
.kpi-card.is-loading .kpi-card__label{color:transparent}
.kpi-card.is-error{border-color:var(--danger-line)}
.kpi-card.is-stale{border-color:var(--warn-line)}
.kpi-card.is-stale .kpi-card__value{color:var(--text-3)}
.state-msg{display:flex;align-items:center;gap:8px;font:600 13px var(--sans)}
.state-msg--error{color:var(--danger)}
.state-sub{font:400 12px/1.5 var(--sans);color:var(--text-3)}
.retry-btn{align-self:flex-start;padding:6px 12px;border-radius:var(--r-xs);font:600 12px var(--sans);cursor:pointer}
.retry-btn--error{border:1px solid var(--danger-line);background:var(--danger-tint);color:var(--danger)}
.retry-btn--stale{border:1px solid var(--warn-line);background:var(--warn-tint);color:var(--warn)}

/* ============================================================================
   CHARTS — chrome around TradingView Lightweight-Charts
   Mounts: #equity-chart (line) · #candles-chart (candlesticks). See charts.js.
   ========================================================================== */
.chart-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.chart-toolbar{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.chart-toolbar__left,.chart-toolbar__right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.chart-legend{display:flex;align-items:center;gap:7px;font:500 11.5px var(--sans);color:var(--text-2)}
.chart-legend__swatch{width:14px;height:2.5px;border-radius:2px;background:var(--accent)}
.chart-legend__swatch--dashed{height:0;border-top:2px dashed var(--flat)}
.chart-legend__val{font:600 12px var(--mono);color:var(--accent)}
.bh-toggle{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:100px;cursor:pointer;
  border:1px solid var(--line);background:transparent;color:var(--text-4);font:600 11.5px var(--sans)}
.bh-toggle.is-on{border-color:var(--line-2);background:var(--surface-2);color:var(--text-2)}
.bh-toggle__line{width:14px;height:0;border-top:2px dashed currentColor;opacity:.8}

/* chart body : the div Lightweight-Charts paints into */
.chart-body{position:relative;width:100%}
#equity-chart{height:300px}
#candles-chart{height:330px}
.chart-hint{position:absolute;left:12px;bottom:8px;font:500 9.5px var(--sans);color:var(--text-4);pointer-events:none}

/* second pane under the candlestick (per-instrument strategy equity) */
.chart-subpane{border-top:1px solid var(--line);padding:8px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.chart-subpane__label{font:600 10px var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}
#strategy-subpane{height:96px}

/* chart state overlays (loading / empty / error) — toggle .is-* on .chart-body */
.chart-state{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:9px;text-align:center;padding:14px}
.chart-body.is-loading .chart-state--loading,
.chart-body.is-empty .chart-state--empty,
.chart-body.is-error .chart-state--error{display:flex}
.chart-body.is-loading canvas,.chart-body.is-empty canvas,.chart-body.is-error canvas{visibility:hidden}
.chart-state__text{font:500 12.5px/1.4 var(--sans);color:var(--text-3)}

/* ============================================================================
   TABLES — trades (reused on Trades / Instrument / Runs), positions
   ========================================================================== */
.trades-table{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.table-summary{padding:13px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.table-summary__stats{display:flex;align-items:center;gap:18px;flex-wrap:wrap;font:600 12.5px var(--mono);color:var(--text-2)}
.table-summary__stats strong{color:var(--text);font-weight:600}
.table-scroll{overflow-x:auto}            /* horizontal scroll on mobile */
table.data{width:100%;border-collapse:collapse}
table.data th{text-align:left;padding:9px 16px;font:600 9.5px var(--mono);letter-spacing:.07em;text-transform:uppercase;
  color:var(--text-3);background:var(--surface-2);border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0}
table.data td{padding:11px 16px;font:500 12.5px var(--mono);font-variant-numeric:tabular-nums;color:var(--text-2);border-bottom:1px solid var(--line)}
table.data tbody tr:last-child td{border-bottom:none}
table.data tbody tr:hover{background:var(--surface-2)}
table.data .t-instrument{color:var(--text);font-weight:600}
table.data .t-num{text-align:right}
table.data .t-muted{color:var(--text-4)}

/* ============================================================================
   EMPTY / LOADING / ERROR blocks (tables, panels)
   ========================================================================== */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;padding:44px 28px}
.empty-state__icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--text-3)}
.empty-state__title{font:700 16px var(--sans)}
.empty-state__text{max-width:44ch;font:400 13px/1.55 var(--sans);color:var(--text-2)}
.error-row{display:flex;align-items:center;gap:13px;padding:18px;border:1px solid var(--danger-line);border-radius:var(--r-lg);background:var(--surface)}
.skeleton-row{display:flex;gap:16px;padding:11px 0;border-bottom:1px solid var(--line)}
.skeleton-row > span{height:11px;border-radius:4px}

/* ============================================================================
   BOT STATUS · DEFINITION LISTS · CONFIG
   ========================================================================== */
.defn{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.defn:last-child{border-bottom:none}
.defn__key{font:500 12.5px var(--sans);color:var(--text-3);white-space:nowrap}
.defn__val{font:600 12.5px var(--mono);font-variant-numeric:tabular-nums;color:var(--text)}
.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.config-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px}
.config-card--note{border-left:2px solid var(--accent-line)}
.code-line{padding:9px 11px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);font:500 11px/1.5 var(--mono);color:var(--text-3)}
.readonly-badge{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:1px solid var(--line-2);border-radius:100px;background:var(--surface-2);font:600 12px var(--sans);color:var(--text-2)}

/* runs / audit */
.run-row{border-bottom:1px solid var(--line)}
.run-row__head{width:100%;border:none;background:none;cursor:pointer;display:flex;align-items:center;gap:13px;padding:12px 16px;text-align:left;flex-wrap:wrap}
.run-row__head:hover{background:var(--surface-2)}
.run-row__id{width:48px;font:600 13px var(--mono);color:var(--text)}
.run-row__time{flex:1;min-width:150px;font:500 12px var(--mono);color:var(--text-2)}
.run-row__detail{padding:4px 16px 16px;background:var(--bg-2);border-top:1px solid var(--line)}
.run-row[hidden] .run-row__detail{display:none}
.decision{display:flex;align-items:center;gap:12px;padding:9px 0;border-top:1px solid var(--line);flex-wrap:wrap}
.decision__epic{width:96px;font:600 12.5px var(--sans);color:var(--text)}
.decision__reason{flex:1;min-width:160px;font:500 11.5px var(--mono);color:var(--text-3)}
.log-tail{margin:0;padding:14px 16px;background:var(--bg);overflow-x:auto;font:500 11.5px/1.7 var(--mono);color:var(--text-3)}
.log-tail .lvl-info{color:var(--info)} .log-tail .lvl-ok{color:var(--up)} .log-tail .lvl-err{color:var(--down)}
.log-tail .t-buy{color:var(--up)} .log-tail .t-hold{color:var(--text-2)} .log-tail .t-dim{color:var(--text-4)}
.mode-badge{padding:2px 8px;border:1px solid var(--line-2);border-radius:4px;background:var(--surface-2);font:700 10px var(--mono)}
.mode-badge--cron{color:var(--text-2)} .mode-badge--manual{color:var(--accent)} .mode-badge--preview{color:var(--info)}

/* ============================================================================
   MODAL — Decide now (safe preview → danger execute)
   ========================================================================== */
.modal-overlay{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;
  padding:24px 24px 96px;background:rgba(3,5,9,.68);backdrop-filter:blur(5px)}
/* The overlay's display:flex overrides the UA [hidden] rule, so the hidden
   attribute (toggled by decide.js openModal/closeModal) needs this higher-
   specificity rule to actually hide the modal. Without it the modal shows on
   every page load and cannot be closed. */
.modal-overlay[hidden]{display:none}
.modal-card{width:584px;max-width:100%;max-height:calc(100vh - 168px);overflow:auto;
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-xl);box-shadow:var(--sh-pop)}
.modal-head{padding:22px 26px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modal-icon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;
  background:var(--accent-tint);border:1px solid var(--accent-line);color:var(--accent)}
.modal-icon--ok{background:var(--up-tint);border-color:var(--up-line);color:var(--up)}
.modal-icon--warn{background:var(--warn-tint);border-color:var(--warn-line);color:var(--warn)}
.modal-icon--danger{background:var(--danger-tint);border-color:var(--danger-line);color:var(--danger)}
.modal-title{font:700 19px var(--sans);letter-spacing:-.01em}
.modal-sub{font:500 12px var(--mono);color:var(--text-3)}
.modal-close{background:none;border:none;color:var(--text-3);font:400 22px/1 var(--sans);cursor:pointer;padding:2px 4px}
.modal-body{padding:16px 26px 4px}
.modal-foot{display:flex;gap:10px;padding:16px 26px;border-top:1px solid var(--line);background:var(--bg-2)}

/* safe banner (preview = read-only) vs danger zone (places real demo orders) */
.safe-banner{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:var(--r);
  background:var(--up-tint);border:1px solid var(--up-line);color:var(--up);font:600 12.5px var(--sans)}
.info-banner{display:flex;align-items:center;gap:8px;padding:9px 13px;border-radius:var(--r);
  background:var(--info-tint);border:1px solid var(--info-line);color:var(--info);font:600 12px var(--sans)}
.warn-banner{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:var(--r);
  background:var(--warn-tint);border:1px solid var(--warn-line);color:var(--warn);font:600 12.5px var(--sans)}
.danger-zone{margin-top:14px;border-top:1px solid var(--danger-line);background:var(--danger-tint);padding:16px 26px 18px}
.danger-zone__label{display:flex;align-items:center;gap:8px;margin-bottom:12px;font:700 12px var(--mono);
  letter-spacing:.06em;text-transform:uppercase;color:var(--danger)}

.preview-row{border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;background:var(--bg-2);margin-bottom:9px}
.preview-row__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.preview-row__name{font:700 13.5px var(--sans)}
.preview-row__reason{margin-top:6px;font:500 11.5px var(--mono);color:var(--text-3)}
.preview-row--filled{border-color:var(--up-line);background:var(--up-tint)}
.order-tag{padding:2px 8px;border-radius:4px;font:700 10px var(--mono);white-space:nowrap}
.order-tag--open{background:var(--up);color:#06140d}
.order-tag--none{border:1px solid var(--line-2);color:var(--text-3)}

/* spinner / progress (loading states) */
.spinner{width:40px;height:40px;border-radius:50%;border:3px solid var(--surface-3);border-top-color:var(--accent);animation:spin .8s linear infinite}
.spinner--danger{border-top-color:var(--danger)}
.progress{width:260px;max-width:100%;height:5px;border-radius:3px;background:var(--surface-3);overflow:hidden;position:relative}
.progress__bar{position:absolute;top:0;left:0;height:100%;width:32%;border-radius:3px;background:var(--accent);animation:indeterminate 1.15s ease-in-out infinite}
.progress__bar--danger{background:var(--danger)}
@keyframes indeterminate{0%{left:-32%}100%{left:100%}}

/* ============================================================================
   LOGIN
   ========================================================================== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:var(--bg);background-image:radial-gradient(circle at 50% 8%,var(--accent-tint),transparent 60%)}
.login-card{width:384px;max-width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-pop);overflow:hidden}
.field{margin-top:13px}
.field__label{display:block;font:600 11px var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);margin-bottom:7px}
.field__input{width:100%;padding:11px 13px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-sm);
  color:var(--text);font:500 14px var(--mono);outline:none}
.field__input:focus{border-color:var(--accent-line)}
.field__input.is-invalid{border-color:var(--danger-line)}
.field__input[disabled]{opacity:.6;cursor:not-allowed}
.form-error{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--r-sm);
  background:var(--danger-tint);border:1px solid var(--danger-line);color:var(--danger);font:600 12px var(--sans)}

/* ============================================================================
   RESPONSIVE — desktop-first, degrade to mobile
   ========================================================================== */
@media (max-width:860px){
  .mainnav{display:none}                 /* replace with a drawer/hamburger in app.js */
  .topbar .status-pill{display:none}
  .overview-grid,.config-grid{grid-template-columns:1fr !important}
  .page{padding-left:14px;padding-right:14px}
}
@media (max-width:520px){
  .kpi-strip{grid-template-columns:1fr 1fr}
  .modal-overlay{padding:12px 12px 92px}
}
