/* terminal.css — Terminal-specific styles, layered on top of aurum.css.
   Scoped under .aurum.terminal so it doesn't leak. */

:root {
  --c-row-hover: rgba(201, 169, 78, 0.04);
  --c-row-expanded: rgba(201, 169, 78, 0.05);
  --c-edge-pos: var(--c-gold);
  --c-edge-neg: #C57272; /* muted red — per brief */
  --c-cell-divider: rgba(255, 255, 255, 0.04);
  --c-mono: 'Barlow Condensed', ui-monospace, 'SF Mono', Menlo, monospace;
  --term-row-h: 56px;
  --term-row-h-compact: 44px;
}

/* ─── Terminal page chrome ──────────────────────────────────────────── */
.aurum.terminal {
  min-height: 100vh;
  background: var(--c-bg);
  /* hairline noise — matches existing site */
  background-image:
    radial-gradient(circle at 50% 0%, rgba(201,169,78,0.025), transparent 60%),
    var(--c-bg);
}
.aurum.terminal main { padding-top: 60px; } /* clear fixed nav */

/* Terminal-wide condensed body for data rows */
.aurum.terminal .num,
.aurum.terminal .term-mono {
  font-family: var(--c-mono);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}

/* ─── Header strip ──────────────────────────────────────────────────── */
.term-header {
  position: sticky;
  top: 60px;
  z-index: 50;
  background: rgba(6, 6, 8, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--c-border);
}
.term-header__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-md);
  padding: 14px var(--space-md);
  max-width: 1680px;
  margin: 0 auto;
}
.term-eyebrow {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-body);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--c-text-dim);
}
.term-eyebrow__title {
  color: var(--c-gold);
  letter-spacing: 0.32em;
}
.term-eyebrow__pip {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--c-green);
  box-shadow: 0 0 0 3px rgba(74, 222, 128, 0.12);
  animation: term-pulse 2s ease-in-out infinite;
}
.term-eyebrow__pip--warn { background: #fbbf24; box-shadow: 0 0 0 3px rgba(251,191,36,0.12); }
.term-eyebrow__pip--stale { background: var(--c-red); box-shadow: 0 0 0 3px rgba(248,113,113,0.12); animation: none; }
@keyframes term-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.45; }
}

.term-search {
  position: relative;
  max-width: 420px;
  width: 100%;
  justify-self: center;
}
.term-search__input {
  width: 100%;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  color: var(--c-text);
  padding: 9px 14px 9px 36px;
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  border-radius: var(--radius-sm);
  transition: border-color 0.2s, background 0.2s;
}
.term-search__input::placeholder {
  color: var(--c-text-ghost);
  letter-spacing: 0.06em;
}
.term-search__input:focus {
  outline: none;
  border-color: var(--c-gold-muted);
  background: var(--c-surface-hover);
}
.term-search__icon {
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  color: var(--c-text-ghost);
  font-size: 0.85rem;
  pointer-events: none;
}

.term-actions {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}
.term-iconbtn {
  background: transparent;
  border: 1px solid var(--c-border);
  color: var(--c-text-dim);
  padding: 7px 12px;
  font-family: var(--font-body);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.term-iconbtn:hover {
  border-color: var(--c-gold-muted);
  color: var(--c-gold);
  background: var(--c-gold-ghost);
}
.term-iconbtn[disabled] { opacity: 0.4; pointer-events: none; }
.term-iconbtn__dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: currentColor;
  opacity: 0.7;
}
.term-iconbtn--spinning svg { animation: term-spin 1s linear infinite; }
@keyframes term-spin { to { transform: rotate(360deg); } }

/* ─── Slate selector tabs ───────────────────────────────────────────── */
.term-slate-tabs {
  display: flex;
  gap: 0;
  padding: 0 var(--space-md);
  max-width: 1680px;
  margin: 0 auto;
  border-bottom: 1px solid var(--c-border);
}
.term-slate-tab {
  background: transparent;
  border: none;
  border-bottom: 1.5px solid transparent;
  color: var(--c-text-dim);
  font-family: var(--font-body);
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 14px 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: color 0.2s, border-color 0.2s;
}
.term-slate-tab:hover { color: var(--c-text); }
.term-slate-tab--active {
  color: var(--c-gold);
  border-bottom-color: var(--c-gold);
}
.term-slate-tab__count {
  font-family: var(--c-mono);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--c-text-ghost);
  background: var(--c-surface);
  padding: 2px 7px;
  border-radius: 2px;
  letter-spacing: 0.04em;
}
.term-slate-tab--active .term-slate-tab__count {
  color: var(--c-gold);
  background: var(--c-gold-ghost);
}
.term-slate-tab__lock {
  font-family: var(--c-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  color: var(--c-text-ghost);
  margin-left: 8px;
}

/* ─── Filter / control bar ──────────────────────────────────────────── */
.term-filters {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: 14px var(--space-md);
  max-width: 1680px;
  margin: 0 auto;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--c-border-soft);
}
.term-filter-group {
  display: flex;
  align-items: center;
  gap: 10px;
}
.term-filter-label {
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--c-text-ghost);
  white-space: nowrap;
}
.term-chip-group {
  display: flex;
  gap: 4px;
}
.term-chip {
  background: transparent;
  border: 1px solid var(--c-border);
  color: var(--c-text-dim);
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.term-chip:hover { color: var(--c-text); border-color: var(--c-text-dim); }
.term-chip--active {
  color: var(--c-gold);
  border-color: var(--c-gold-muted);
  background: var(--c-gold-ghost);
}
.term-slider-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 180px;
}
.term-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 2px;
  background: var(--c-border);
  border-radius: 1px;
  cursor: pointer;
}
.term-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--c-gold);
  cursor: pointer;
  border: 2px solid var(--c-bg);
  box-shadow: 0 0 0 1px var(--c-gold);
}
.term-slider::-moz-range-thumb {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--c-gold);
  cursor: pointer;
  border: 2px solid var(--c-bg);
  box-shadow: 0 0 0 1px var(--c-gold);
}
.term-slider-value {
  font-family: var(--c-mono);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--c-gold);
  min-width: 36px;
  text-align: right;
}

.term-filters__spacer { flex: 1; }
.term-filters__count {
  font-family: var(--font-body);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-text-dim);
}
.term-filters__count strong { color: var(--c-gold); font-weight: 600; }
.term-clear {
  background: transparent;
  border: none;
  color: var(--c-text-ghost);
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 4px 6px;
  transition: color 0.2s;
}
.term-clear:hover { color: var(--c-gold); }

/* ─── Contact Board (Player Props EDGE — 2026-05-27) ─────────────── */
.term-contact-board {
  max-width: 1680px;
  margin: var(--space-lg) auto 0 auto;
  padding: var(--space-md) var(--space-md) var(--space-lg) var(--space-md);
  border-top: 1px solid var(--c-border);
}
.cb-board-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.cb-board-title {
  font-family: 'Bebas Neue', var(--font-body);
  font-size: 1.8rem;
  letter-spacing: 0.08em;
  margin: 0;
  color: var(--c-gold);
  line-height: 1;
}
.cb-board-sub {
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: var(--c-text-dim);
  margin-top: 4px;
}
.cb-board-sub span { color: var(--c-text); }
.cb-board-legend {
  font-family: var(--c-mono);
  font-size: 0.7rem;
  color: var(--c-text-dim);
  letter-spacing: 0.02em;
}
.cb-board-legend span { color: var(--c-gold); margin: 0 2px; font-size: 0.85rem; }
.cb-board-footer {
  font-family: var(--font-body);
  font-size: 0.7rem;
  color: var(--c-text-dim);
  letter-spacing: 0.02em;
  margin-top: 18px;
  text-align: center;
}
.cb-board-footer strong { color: var(--c-text); font-weight: 600; }
.cb-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
@media (max-width: 800px) {
  .cb-grid { grid-template-columns: 1fr; gap: 16px; }
}
.cb-col {
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--c-border);
  border-radius: 6px;
  padding: 14px 14px 8px 14px;
}
.cb-col.cb-hr {
  border-color: rgba(232, 90, 58, 0.25);
}
.cb-col-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--c-cell-divider);
  margin-bottom: 8px;
}
.cb-col-header h3 {
  font-family: 'Bebas Neue', var(--font-body);
  font-size: 1.05rem;
  letter-spacing: 0.12em;
  margin: 0;
  color: var(--c-text);
}
.cb-col-icon { font-size: 1.05rem; }
.cb-col-body { display: flex; flex-direction: column; }
.cb-empty {
  padding: 18px 6px;
  text-align: center;
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--c-text-dim);
  font-style: italic;
}
/* Loading skeleton — static dim bars that reserve the real row height (kills the async
   Contact Board layout shift). No animation, so reduced-motion is a non-issue. */
.cb-row--skel { opacity: 0.55; }
.cb-skel {
  background: var(--c-cell-divider, rgba(255, 255, 255, 0.08));
  border-radius: 3px;
  height: 0.62rem;
}
.cb-skel--name  { width: 62%; height: 0.9rem; }
.cb-skel--vs    { width: 42%; height: 0.62rem; margin-top: 5px; }
.cb-skel--dots  { width: 46px; height: 0.9rem; margin: 0 auto; }
.cb-skel--score { width: 26px; height: 0.9rem; margin-left: auto; }

/* Per-row layout — 5 cells: rank | player block | dots | reason | score */
.cb-row {
  display: grid;
  grid-template-columns: 36px 1fr auto 1fr 44px;
  align-items: center;
  gap: 10px;
  padding: 9px 4px;
  border-bottom: 1px solid var(--c-cell-divider);
}
.cb-row:last-child { border-bottom: none; }
.cb-rank {
  font-family: var(--c-mono);
  font-size: 0.95rem;
  color: var(--c-gold);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.cb-player { min-width: 0; }
.cb-name {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--c-text);
  letter-spacing: 0.02em;
  display: flex;
  align-items: center;
  gap: 6px;
}
.cb-team {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--c-text-dim);
  border: 1px solid var(--c-border, rgba(255,255,255,0.16));
  border-radius: 3px;
  padding: 1px 4px;
}
.cb-vs {
  font-family: var(--font-body);
  font-size: 0.74rem;
  color: var(--c-text-dim);
  letter-spacing: 0.02em;
  margin-top: 1px;
}
.cb-stats { text-align: center; min-width: 96px; }
.cb-dots {
  font-family: var(--c-mono);
  font-size: 1.05rem;
  letter-spacing: 0.04em;
  color: var(--c-gold);
  line-height: 1;
}
.cb-dots-label {
  font-family: var(--font-body);
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-text-dim);
  margin-top: 3px;
}
.cb-reason {
  font-family: var(--font-body);
  font-size: 0.72rem;
  color: var(--c-text-dim);
  letter-spacing: 0.02em;
  font-style: italic;
  text-align: right;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cb-score {
  font-family: var(--c-mono);
  font-size: 1rem;
  font-weight: 600;
  color: var(--c-text);
  text-align: right;
  letter-spacing: 0.02em;
}
.cb-badge {
  display: inline-block;
  font-family: var(--c-mono);
  font-size: 0.7rem;
  font-weight: 700;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  line-height: 14px;
  text-align: center;
}
.cb-win { background: rgba(74, 222, 128, 0.18); color: var(--c-green); }
.cb-loss { background: rgba(248, 113, 113, 0.18); color: var(--c-red); }

/* ───── Value Board (20 Most Valuable Picks) ──────────────────────────
   Two-column EV board (Pitchers | Hitters), mounted below the Contact
   Board. Reuses the .cb-* board chrome — header/sub/legend/footer, the
   .cb-grid + .cb-col side-by-side columns, skeleton bars, result badges
   — so it's visually identical to the Contact Board; .vb-* covers only
   the per-row grid (category chip / pick / confidence) that differs. */
.term-value-board {
  max-width: 1680px;
  margin: var(--space-lg) auto 0 auto;
  padding: var(--space-md) var(--space-md) var(--space-lg) var(--space-md);
  border-top: 1px solid var(--c-border);
}
/* Two-column grid (Pitchers | Hitters) reuses .cb-grid + .cb-col, so the box, header, and the
   responsive single-column reflow are identical to the Contact Board's Hits | HRs split. Only
   the row internals below differ. Per-column border tints keep the two sides distinguishable. */
.vb-col--pitcher { border-color: rgba(108, 182, 255, 0.25); }
.vb-col--hitter  { border-color: rgba(212, 175, 55, 0.22); }

/* Per-row layout — 5 cells: rank | category chip | subject (name + detail) | pick | confidence.
   Mirrors the Contact Board's 5-cell row so it fits a half-width column. The projection that
   used to be a 6th cell is folded into the subject's secondary line. */
.vb-row {
  display: grid;
  grid-template-columns: 34px 40px minmax(0, 1fr) auto 52px;
  align-items: center;
  gap: 10px;
  padding: 9px 4px;
  border-bottom: 1px solid var(--c-cell-divider);
}
.vb-row:last-child { border-bottom: none; }
.vb-cat {
  font-family: var(--c-mono);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
  border: 1px solid currentColor;
  border-radius: 3px;
  padding: 2px 0;
}
.vb-cat--K    { color: #6cb6ff; }
.vb-cat--OUTS { color: #8fb8ff; }
.vb-cat--TB   { color: var(--c-gold); }
.vb-cat--BH   { color: var(--c-green); }
.vb-cat--HR   { color: #e85a3a; }
.vb-cat--RBI  { color: #d9a441; }
.vb-cat--RUNS { color: var(--c-green); }
.vb-cat--HITS { color: #e85a3a; }
.vb-subject { min-width: 0; }
/* The folded projection can make this secondary line long in a half-width column — clip it. */
.vb-subject .cb-vs {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vb-pick {
  font-family: var(--c-mono);
  font-size: 0.86rem;
  letter-spacing: 0.02em;
  text-align: right;
  white-space: nowrap;
}
.vb-side { font-weight: 700; }
.vb-over .vb-side { color: var(--c-green); }
.vb-under .vb-side { color: var(--c-red); }
.vb-line { color: var(--c-text); font-weight: 600; }
.vb-stat { color: var(--c-text-dim); font-size: 0.78rem; }
.vb-conf {
  font-family: var(--c-mono);
  font-size: 1rem;
  font-weight: 600;
  color: var(--c-gold);
  text-align: right;
  letter-spacing: 0.02em;
}
/* Skeleton width modifiers (reuse .cb-skel bar styling) */
.vb-skel--cat  { width: 28px;  height: 1rem; }
.vb-skel--pick { width: 110px; height: 0.9rem; margin-left: auto; }
/* Narrow screens: .cb-grid already stacks the two columns; just tighten the row spacing so
   the side/line/confidence stay legible (matches the Contact Board's mobile reflow). */
@media (max-width: 800px) {
  .vb-row { grid-template-columns: 30px 36px minmax(0, 1fr) auto 48px; gap: 8px; }
}
