/* TORN Companion — Cephalopod palette (bioluminescent, matches @edbehere) */

:root {
  --bg-0: #070912;
  --bg-1: #0d1220;
  --bg-2: #131a2c;
  --bg-3: #1c2440;
  --edge: #222b4a;
  --ink-0: #e8ecff;
  --ink-1: #a9b2d6;
  --ink-2: #6a7399;
  --accent: #7b6cff;        /* cephalopod purple */
  --accent-glow: #9f8cff;
  --cyan: #47e3ff;          /* bioluminescent cyan */
  --gold: #ffd37a;
  --ok: #4de39c;
  --warn: #ffb857;
  --bad: #ff6b78;
  --rare-yellow: #ffd37a;
  --rare-orange: #ff9f57;
  --rare-red: #ff6b78;
  --radius: 10px;
  --pad: 14px;
  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono: ui-monospace, "SF Mono", "Cascadia Mono", Consolas, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  background: radial-gradient(ellipse at top, #111a36 0%, var(--bg-0) 70%);
  color: var(--ink-0);
  font-family: var(--font-sans);
  min-height: 100vh;
}

header {
  padding: 18px 22px 10px;
  border-bottom: 1px solid var(--edge);
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

header h1 {
  font-size: 18px;
  margin: 0;
  letter-spacing: 0.04em;
  color: var(--accent-glow);
  text-shadow: 0 0 12px rgba(123, 108, 255, 0.35);
}

header .tier {
  font-size: 12px;
  color: var(--ink-1);
  background: var(--bg-2);
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--edge);
}

header .tier.ok { color: var(--cyan); border-color: rgba(71, 227, 255, 0.4); }
header .tier.err { color: var(--bad); border-color: rgba(255, 107, 120, 0.4); }

nav.tabs {
  display: flex;
  gap: 4px;
  padding: 0 22px;
  border-bottom: 1px solid var(--edge);
  background: var(--bg-1);
  overflow-x: auto;
}

nav.tabs button {
  background: transparent;
  border: 0;
  color: var(--ink-1);
  padding: 12px 16px;
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}

nav.tabs button:hover { color: var(--ink-0); }
nav.tabs button.active {
  color: var(--accent-glow);
  border-bottom-color: var(--accent);
}

main {
  padding: 22px;
  max-width: 1200px;
  margin: 0 auto;
}

.view { display: none; }
.view.active { display: block; }

.card {
  background: var(--bg-1);
  border: 1px solid var(--edge);
  border-radius: var(--radius);
  padding: var(--pad);
  margin-bottom: 14px;
}

.card h2 {
  margin: 0 0 12px;
  font-size: 15px;
  color: var(--cyan);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.card .sub {
  font-size: 12px;
  color: var(--ink-2);
  margin-top: -6px;
  margin-bottom: 10px;
}

label { display: block; font-size: 12px; color: var(--ink-1); margin-bottom: 4px; }

input, button, select {
  font-family: inherit;
  font-size: 14px;
}

input[type="text"], input[type="password"], input[type="number"] {
  background: var(--bg-2);
  border: 1px solid var(--edge);
  color: var(--ink-0);
  padding: 9px 11px;
  border-radius: 8px;
  width: 100%;
  outline: none;
}

input:focus { border-color: var(--accent); }

button.primary {
  background: var(--accent);
  color: #fff;
  border: 0;
  padding: 9px 18px;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
}

button.primary:hover { background: var(--accent-glow); }
button.primary:disabled { opacity: 0.5; cursor: not-allowed; }

button.ghost {
  background: transparent;
  color: var(--ink-1);
  border: 1px solid var(--edge);
  padding: 8px 14px;
  border-radius: 8px;
  cursor: pointer;
}

button.ghost:hover { color: var(--ink-0); border-color: var(--accent); }

.row { display: flex; gap: 10px; align-items: flex-end; flex-wrap: wrap; }
.row > * { flex: 1; min-width: 180px; }
.row .grow-0 { flex: 0; }

.bar {
  position: relative;
  background: var(--bg-2);
  border-radius: 6px;
  height: 22px;
  overflow: hidden;
  border: 1px solid var(--edge);
}

.bar > .fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  transition: width 0.3s ease;
}

.bar > .label {
  position: relative;
  z-index: 1;
  font-size: 12px;
  line-height: 22px;
  padding: 0 8px;
  color: var(--ink-0);
  font-variant-numeric: tabular-nums;
  display: flex;
  justify-content: space-between;
}

.bar.energy > .fill { background: linear-gradient(90deg, #4d8bff, var(--cyan)); }
.bar.nerve > .fill { background: linear-gradient(90deg, #ff5674, #ff9f57); }
.bar.happy > .fill { background: linear-gradient(90deg, #ffd37a, #ffea8a); }
.bar.life > .fill { background: linear-gradient(90deg, #4de39c, var(--cyan)); }

.stack { display: flex; flex-direction: column; gap: 10px; }

.kv { display: grid; grid-template-columns: max-content 1fr; gap: 4px 18px; font-size: 13px; }
.kv dt { color: var(--ink-2); }
.kv dd { margin: 0; color: var(--ink-0); font-variant-numeric: tabular-nums; }

.meta {
  font-size: 11px;
  color: var(--ink-2);
  margin-top: 6px;
}

.status-pill {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid transparent;
}

.status-pill.ok { color: var(--ok); border-color: rgba(77, 227, 156, 0.4); background: rgba(77, 227, 156, 0.08); }
.status-pill.hosp { color: var(--warn); border-color: rgba(255, 184, 87, 0.4); background: rgba(255, 184, 87, 0.08); }
.status-pill.jail { color: var(--bad); border-color: rgba(255, 107, 120, 0.4); background: rgba(255, 107, 120, 0.08); }

table.listings {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

table.listings th, table.listings td {
  text-align: left;
  padding: 8px 10px;
  border-bottom: 1px solid var(--edge);
  vertical-align: middle;
}

table.listings th {
  background: var(--bg-2);
  color: var(--ink-1);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  position: sticky; top: 0;
}

table.listings tr:hover td { background: var(--bg-2); }
table.listings td.num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
table.listings td a { color: var(--cyan); text-decoration: none; }
table.listings td a:hover { text-decoration: underline; }

/* pct color classes — usable inside tables, dls, spans, anywhere */
.pct { font-weight: 600; font-variant-numeric: tabular-nums; }
.pct.bargain, .bargain { color: var(--ok); }
.pct.meh, .meh { color: var(--ink-1); }
.pct.markup, .markup { color: var(--bad); }

.rarity {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  margin-right: 6px;
  vertical-align: middle;
}

.rarity.yellow { background: var(--rare-yellow); }
.rarity.orange { background: var(--rare-orange); }
.rarity.red { background: var(--rare-red); }
.rarity.none { background: var(--bg-3); border: 1px solid var(--edge); }

.progress-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--ink-1);
}

.progress-row .bar { flex: 1; height: 10px; }

.muted { color: var(--ink-2); font-size: 12px; }
.small { font-size: 12px; }

.danger-note {
  color: var(--warn);
  font-size: 12px;
  background: rgba(255, 184, 87, 0.08);
  border: 1px solid rgba(255, 184, 87, 0.25);
  padding: 8px 12px;
  border-radius: 6px;
  margin-top: 10px;
}

.err {
  color: var(--bad);
  font-size: 13px;
  padding: 8px 12px;
  background: rgba(255, 107, 120, 0.08);
  border: 1px solid rgba(255, 107, 120, 0.25);
  border-radius: 6px;
  margin-top: 10px;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

@media (max-width: 720px) {
  .grid-2 { grid-template-columns: 1fr; }
  main { padding: 14px; }
}

/* ---- Analyst panels (ROI / Spread / Travel) ---- */

.roi-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) 2fr;
  gap: 14px;
}

@media (max-width: 900px) {
  .roi-grid { grid-template-columns: 1fr; }
}

.card.panel {
  margin-bottom: 0;
}

.big-number {
  font-size: 28px;
  color: var(--cyan);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  margin: 4px 0 14px;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}

.big-number .spark { margin-left: auto; color: var(--accent-glow); opacity: 0.9; }
.big-number .small { font-size: 12px; font-weight: 400; }

.link-plain { color: inherit; text-decoration: none; }
.link-plain:hover { text-decoration: underline; }

.callout {
  background: var(--bg-2);
  border: 1px solid var(--edge);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
  padding: 10px 12px;
}

.callout.accent { border-left-color: var(--cyan); }

.callout-title {
  font-size: 12px;
  color: var(--cyan);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}

.callout-body { font-size: 13px; color: var(--ink-0); line-height: 1.5; }
.callout-body .good { color: var(--ok); }

/* Compact rankings tables (ROI, Travel) */
table.listings.compact th,
table.listings.compact td {
  padding: 6px 8px;
  font-size: 12px;
}

table.listings.compact td.num { font-size: 13px; }

/* Venue pill (spread scanner) */
.venue-pill {
  display: inline-block;
  padding: 2px 10px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 999px;
  border: 1px solid var(--edge);
  background: var(--bg-2);
  color: var(--ink-1);
}

.venue-pill.venue-im { color: var(--cyan); border-color: rgba(71, 227, 255, 0.4); background: rgba(71, 227, 255, 0.08); }
.venue-pill.venue-bz { color: var(--accent-glow); border-color: rgba(159, 140, 255, 0.4); background: rgba(159, 140, 255, 0.08); }

/* Owned-stock pill */
.owned-pill {
  display: inline-block;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 500;
  border-radius: 999px;
  color: var(--gold);
  border: 1px solid rgba(255, 211, 122, 0.35);
  background: rgba(255, 211, 122, 0.08);
}

/* Spread scanner row divisions */
table.listings td .muted.small { margin-top: 2px; font-size: 11px; }
