/* Momentum Analysis Tool — design tokens + layout.
   Dark is default; [data-theme="light"] overrides. Numerics use tabular figures
   (the single biggest "amateur->pro" lever for a numbers UI). */

:root {
  --bg: #0d1117;        --panel: #161b22;     --panel-2: #1c2330;
  --text: #e6edf3;      --muted: #9aa7b4;     --border: #30363d;
  --green: #3fb950;     --red: #f85149;       --accent: #58a6ff;
  --accent-bg: #1f6feb33;
  --mono: "SF Mono", "Cascadia Mono", "JetBrains Mono", Consolas, monospace;
  --sans: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --s1: 4px; --s2: 8px; --s3: 12px; --s4: 16px; --s5: 24px;
  --fz-s: 12px; --fz-m: 13px; --fz-l: 15px; --fz-xl: 18px;
}
[data-theme="light"] {
  --bg: #ffffff;        --panel: #f6f8fa;     --panel-2: #eaeef2;
  --text: #1f2328;      --muted: #59636e;     --border: #d0d7de;
  --green: #1a7f37;     --red: #cf222e;       --accent: #0969da;
  --accent-bg: #0969da14;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: var(--bg); color: var(--text);
  font-family: var(--sans); font-size: var(--fz-m);
}
.num { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.muted { color: var(--muted); }
.pos { color: var(--green); }
.neg { color: var(--red); }

/* ---- top bar ---- */
.topbar {
  display: flex; align-items: center; gap: var(--s4);
  padding: var(--s2) var(--s4);
  background: var(--panel); border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 10;
}
.topbar h1 { font-size: var(--fz-l); margin: 0; font-weight: 600; }
.topbar .spacer { flex: 1; }
.stamp { font-size: var(--fz-s); color: var(--muted); text-align: right; line-height: 1.3; }
.stamp b { color: var(--text); font-weight: 600; }
.btn {
  background: var(--panel-2); color: var(--text);
  border: 1px solid var(--border); border-radius: 6px;
  padding: 5px 10px; font-size: var(--fz-s); cursor: pointer;
}
.btn:hover { border-color: var(--accent); }

/* ---- layout ---- */
.wrap { display: grid; grid-template-columns: 1fr 460px; gap: 1px;
        background: var(--border); height: calc(100vh - 49px); }
.col { background: var(--bg); overflow: auto; }
.toolbar { display: flex; gap: var(--s2); align-items: center;
           padding: var(--s2) var(--s3); position: sticky; top: 0;
           background: var(--bg); border-bottom: 1px solid var(--border); }
input.search {
  background: var(--panel); color: var(--text);
  border: 1px solid var(--border); border-radius: 6px;
  padding: 5px 8px; font-size: var(--fz-s); width: 180px;
}

/* ---- table ---- */
table { width: 100%; border-collapse: collapse; font-size: var(--fz-s); }
thead th {
  position: sticky; top: 0; background: var(--panel);
  text-align: right; padding: 6px 8px; cursor: pointer; user-select: none;
  border-bottom: 1px solid var(--border); white-space: nowrap; color: var(--muted);
  font-weight: 600;
}
thead th:first-child, tbody td:first-child { text-align: left; }
thead th.active { color: var(--accent); }
tbody td { padding: 5px 8px; text-align: right; border-bottom: 1px solid var(--border);
           white-space: nowrap; }
tbody tr:hover { background: var(--panel); }
tbody tr.sel { background: var(--accent-bg); }
.sym { font-weight: 600; cursor: pointer; }
.badge { font-size: 10px; padding: 1px 5px; border-radius: 4px;
         border: 1px solid var(--border); color: var(--muted); }
.badge.on { color: var(--green); border-color: var(--green); }

/* score bar */
.score { display: inline-block; min-width: 34px; text-align: right; }

/* ---- detail panel ---- */
.detail { padding: var(--s4); }
.detail h2 { margin: 0 0 var(--s1); font-size: var(--fz-xl); }
.detail .kpis { display: grid; grid-template-columns: repeat(3, 1fr);
                gap: var(--s2); margin: var(--s3) 0; }
.kpi { background: var(--panel); border: 1px solid var(--border);
       border-radius: 6px; padding: var(--s2) var(--s3); }
.kpi .lbl { font-size: 10px; color: var(--muted); text-transform: uppercase;
            letter-spacing: .04em; }
.kpi .val { font-size: var(--fz-l); margin-top: 2px; }
.chart-box { height: 260px; margin-top: var(--s3); }
.empty { color: var(--muted); padding: var(--s5); text-align: center; }

/* ---- login ---- */
.login-page { display: grid; place-items: center; height: 100vh; }
.login-card { background: var(--panel); border: 1px solid var(--border);
              border-radius: 10px; padding: var(--s5); width: 300px;
              display: flex; flex-direction: column; gap: var(--s3); }
.login-card h1 { font-size: var(--fz-l); margin: 0; }
.login-card input { background: var(--bg); color: var(--text);
                    border: 1px solid var(--border); border-radius: 6px; padding: 8px; }
.login-card button { background: var(--accent); color: #fff; border: 0;
                     border-radius: 6px; padding: 9px; cursor: pointer; font-weight: 600; }
.login-card .error { color: var(--red); margin: 0; font-size: var(--fz-s); }
