/* Hooper Dashboard — Custom Design System
   Loaded by app.py via ui.include_css("www/custom.css")
   All components reference CSS tokens — never hardcode hex values */

/* ── Google Fonts ───────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600&family=Space+Mono&display=swap');

/* ── Design Tokens ──────────────────────────────────────────── */
:root {
  --hooper-bet:          #f97316;  /* Court orange — BET signal */
  --hooper-bet-hi:       #ea580c;  /* Darker orange — edge > 8% */
  --hooper-no-bet:       #6b7280;  /* Gray-500 — NO_BET */
  --hooper-ok:           #22c55e;  /* Green-500 — system healthy */
  --hooper-warning:      #f59e0b;  /* Amber-500 — stale data, OOD */
  --hooper-danger:       #ef4444;  /* Red-500 — system error */
  --hooper-bg-primary:   #111827;  /* Gray-900 */
  --hooper-bg-card:      #1f2937;  /* Gray-800 */
  --hooper-bg-border:    #374151;  /* Gray-700 */
  --hooper-font-display: 'Bebas Neue', sans-serif;
  --hooper-font-data:    'Inter', sans-serif;
  --hooper-font-mono:    'Space Mono', monospace;
}

/* ── Busy Indicator — loading pulse bar ─────────────────────── */
:root {
  --shiny-pulse-height:     5px;
  --shiny-pulse-speed:      1.0s;
  --shiny-pulse-background: linear-gradient(
    120deg,
    transparent,
    #ea580c,
    #f97316,
    #fbbf24,
    transparent
  );
}

/* ── Status Bar ─────────────────────────────────────────────── */
#status-bar {
  position: sticky;
  top: 0;
  z-index: 1050;
  height: 40px;
  background: var(--hooper-bg-card);
  border-bottom: 1px solid var(--hooper-bg-border);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 16px;
  font-family: var(--hooper-font-mono);
  font-size: 0.75rem;
}

/* ── V2 Navbar Brand ───────────────────────────────────────── */
.hooper-brand {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
}
.hooper-brand-text {
  font-family: var(--hooper-font-display);
  font-size: 1.5rem;
  color: white;
  letter-spacing: 0.08em;
  line-height: 1;
}
.hooper-brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 25px;
  height: 25px;
  flex: 0 0 25px;
  font-size: 24px;
  line-height: 1;
  opacity: 1;
  filter: saturate(1.25) contrast(1.08);
  transform: translateY(-1px);
  transform-origin: center;
}
.hooper-brand:hover .hooper-brand-mark,
.hooper-brand:focus-within .hooper-brand-mark {
  animation: hooper-ball-spin 1.1s linear infinite;
}
@keyframes hooper-ball-spin {
  from { transform: translateY(-1px) rotate(0deg); }
  to { transform: translateY(-1px) rotate(360deg); }
}

/* ── V2 Shell Lightweight States ───────────────────────────── */
.v2-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0;
}
.v2-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 2px 8px;
  border: 1px solid var(--hooper-bg-border);
  border-radius: 4px;
  color: #9ca3af;
  font-family: var(--hooper-font-mono);
  font-size: 0.72rem;
  background: rgba(17, 24, 39, 0.42);
}
.v2-meta-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 8px currentColor;
}
.v2-meta-label {
  color: #cbd5e1;
  text-transform: uppercase;
}
.v2-meta-value {
  color: #f8fafc;
  font-weight: 600;
}
.v2-meta-ok {
  color: var(--hooper-ok);
  border-color: rgba(34, 197, 94, 0.55);
  background: rgba(34, 197, 94, 0.11);
}
.v2-meta-warning {
  color: var(--hooper-warning);
  border-color: rgba(245, 158, 11, 0.6);
  background: rgba(245, 158, 11, 0.12);
}
.v2-meta-error {
  color: var(--hooper-danger);
  border-color: rgba(239, 68, 68, 0.62);
  background: rgba(239, 68, 68, 0.11);
}
.v2-empty-copy {
  color: #9ca3af;
  margin: 8px 0 0 0;
}
.v2-stale-banner {
  margin: 8px 0 12px 0;
  padding: 8px 10px;
  border: 1px solid rgba(245, 158, 11, 0.55);
  border-radius: 4px;
  color: var(--hooper-warning);
  background: rgba(245, 158, 11, 0.09);
  font-family: var(--hooper-font-mono);
  font-size: 0.78rem;
}
/* ── Playoffs matchup cards ────────────────────────────────── */
.playoff-summary-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 14px 0;
}
.playoff-summary-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 9px;
  border: 1px solid rgba(148, 163, 184, 0.36);
  border-radius: 4px;
  color: #d1d5db;
  background: rgba(17, 24, 39, 0.34);
  font-family: var(--hooper-font-mono);
  font-size: 0.72rem;
}
.playoff-matchup-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.playoff-matchup-card {
  min-height: 208px;
  padding: 16px;
  border: 1px solid rgba(249, 115, 22, 0.36);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(249, 115, 22, 0.12), transparent 42%),
    rgba(17, 24, 39, 0.44);
}
.playoff-matchup-teams {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}
.playoff-team-block {
  display: flex;
  min-width: 0;
  flex-direction: column;
  align-items: center;
  gap: 7px;
}
.playoff-team-logo {
  width: 54px;
  height: 54px;
  object-fit: contain;
  filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.32));
}
.playoff-team-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border: 1px solid rgba(249, 115, 22, 0.45);
  border-radius: 50%;
  color: #fed7aa;
  background: rgba(249, 115, 22, 0.12);
  font-family: var(--hooper-font-display);
  font-size: 1.35rem;
}
.playoff-team-abbr {
  color: #f8fafc;
  font-family: var(--hooper-font-display);
  font-size: 1.35rem;
  line-height: 1;
}
.playoff-versus {
  color: var(--hooper-bet);
  font-family: var(--hooper-font-mono);
  font-size: 0.9rem;
}
.playoff-series-line {
  margin-top: 12px;
  color: #fbbf24;
  font-family: var(--hooper-font-mono);
  font-size: 0.78rem;
}
.playoff-matchup-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.playoff-matchup-metrics span {
  padding: 2px 7px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 4px;
  color: #cbd5e1;
  background: rgba(31, 41, 55, 0.72);
  font-family: var(--hooper-font-mono);
  font-size: 0.66rem;
}
.playoff-top-players {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}
.playoff-top-player {
  padding: 3px 7px;
  border-radius: 4px;
  color: #fff7ed;
  background: rgba(249, 115, 22, 0.22);
  font-family: var(--hooper-font-mono);
  font-size: 0.66rem;
}
.playoff-top-players-empty {
  color: #9ca3af;
  font-family: var(--hooper-font-mono);
  font-size: 0.7rem;
}

/* ── Mobile dual-label helpers ──────────────────────────────── */
.mobile-abbr { display: none; }

@media (max-width: 640px) {
  #status-bar {
    height: auto;
    flex-wrap: wrap;
    padding: 4px 8px;
    gap: 8px;
    font-size: 0.65rem;
  }
  .mobile-hide { display: none; }
  .mobile-abbr { display: inline; }
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 4px;
}
.status-dot.ok      { background: var(--hooper-ok); }
.status-dot.warning { background: var(--hooper-warning); }
.status-dot.error   { background: var(--hooper-danger); }

/* ── Matchup Strip (Game Day carrousel) ────────────────────── */
.matchup-strip-container { margin: 0 0 4px 0; }
.matchup-strip {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--hooper-bg-card);
  border: 1px solid var(--hooper-bg-border);
  border-radius: 6px;
  padding: 8px 16px;
  overflow: hidden;
}
.matchup-strip-empty {
  min-height: 42px;
}
.matchup-header {
  font-family: var(--hooper-font-display);
  font-size: 1rem;
  color: white;
  letter-spacing: 0.05em;
  white-space: nowrap;
  margin-right: 8px;
}
.matchup-empty {
  color: #9ca3af;
  font-family: var(--hooper-font-mono);
  font-size: 0.75rem;
}
.matchup-scroll {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scroll-behavior: smooth;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.matchup-scroll::-webkit-scrollbar { display: none; }
.matchup-pill {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  border: 1px solid rgba(249, 115, 22, 0.35);
  background: rgba(249, 115, 22, 0.06);
  padding: 3px 12px;
  border-radius: 14px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  user-select: none;
}
.matchup-pill-all {
  border-color: rgba(148, 163, 184, 0.4);
  background: rgba(148, 163, 184, 0.08);
}
.matchup-all-label {
  color: #cbd5e1;
  font-family: var(--hooper-font-mono);
  font-size: 0.75rem;
  white-space: nowrap;
}
.matchup-row {
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.matchup-team {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.matchup-logo {
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex: 0 0 18px;
}
.matchup-pill:hover {
  background: rgba(249, 115, 22, 0.18);
}
.matchup-pill.active {
  border-color: var(--hooper-bet);
  background: rgba(249, 115, 22, 0.28);
  box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.4);
}
/* ── Matchup Pill — structured away/sep/home (Story 11.7) ──── */
.matchup-away { color: #f3f4f6; font-family: var(--hooper-font-display); font-size: 0.85rem; letter-spacing: 0.05em; }
.matchup-sep  { color: var(--hooper-bet); font-family: var(--hooper-font-mono); font-size: 0.65rem; opacity: 0.65; }
.matchup-home { color: #9ca3af; font-family: var(--hooper-font-display); font-size: 0.85rem; letter-spacing: 0.05em; }

/* ── EV Badges ──────────────────────────────────────────────── */
.badge-bet {
  background: var(--hooper-bet);
  color: white;
  font-family: var(--hooper-font-display);
  font-size: 0.8rem;
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: 0.05em;
}
.badge-bet-hi {
  background: var(--hooper-bet-hi);
  color: white;
  font-family: var(--hooper-font-display);
  font-size: 0.8rem;
  padding: 2px 8px;
  border-radius: 4px;
  box-shadow: 0 0 6px rgba(249, 115, 22, 0.4);
}
.badge-no-bet {
  background: transparent;
  color: var(--hooper-no-bet);
  font-family: var(--hooper-font-display);
  font-size: 0.8rem;
  padding: 2px 8px;
  border: 1px solid var(--hooper-no-bet);
  border-radius: 4px;
}
.badge-ood {
  background: transparent;
  color: var(--hooper-warning);
  font-family: var(--hooper-font-mono);
  font-size: 0.7rem;
  padding: 1px 6px;
  border: 1px solid var(--hooper-warning);
  border-radius: 3px;
  margin-left: 8px;
}

/* ── Horizon Tags ───────────────────────────────────────────── */
.horizon-t1h  { color: var(--hooper-ok);      font-family: var(--hooper-font-mono); font-size: 0.75rem; }
.horizon-t3h  { color: var(--hooper-warning);  font-family: var(--hooper-font-mono); font-size: 0.75rem; }
.horizon-t12h { color: var(--hooper-no-bet);   font-family: var(--hooper-font-mono); font-size: 0.75rem; }

/* ── Filter Pills ───────────────────────────────────────────── */
.filter-pills { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.pill {
  cursor: pointer;
  padding: 4px 14px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-family: var(--hooper-font-data);
  background: var(--hooper-bg-card);
  color: #9ca3af;
  border: 1px solid var(--hooper-bg-border);
  transition: background 0.1s, color 0.1s;
}
.pill.active, .pill:hover {
  background: var(--hooper-bet);
  color: white;
  border-color: var(--hooper-bet);
}

/* ── OOD Row highlight ──────────────────────────────────────── */
tr.ood-row td { border-left: 3px solid var(--hooper-warning); }

/* ── Split panel selected row ───────────────────────────────── */
tr.selected-row td { border-left: 3px solid var(--hooper-bet); background: rgba(249,115,22,0.05); }

/* ── Section headers ────────────────────────────────────────── */
.section-title {
  font-family: var(--hooper-font-display);
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  color: white;
  margin-bottom: 8px;
}

/* ── Trend Arrows (Story 11.2) ──────────────────────────────── */
.trend-up   { color: var(--hooper-ok);      font-size: 1.2rem; font-weight: bold; }
.trend-down { color: var(--hooper-danger);  font-size: 1.2rem; font-weight: bold; }
.trend-flat { color: var(--hooper-no-bet);  font-size: 1.2rem; }

/* ── Player list table — BET badge column ───────────────────── */
.player-list .shiny-data-frame td:last-child {
  color: var(--hooper-bet);
  font-family: var(--hooper-font-display);
  font-size: 0.85rem;
}

/* ── Injury Badges — OUT / D / Q / GTD / P (Story 13-2) ────── */
.badge-inj-out  {
  background: var(--hooper-danger);
  color: white;
  font-family: var(--hooper-font-mono);
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.05em;
}
.badge-inj-d {
  background: rgba(239,68,68,0.25);
  color: var(--hooper-danger);
  font-family: var(--hooper-font-mono);
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  border: 1px solid var(--hooper-danger);
}
.badge-inj-q {
  background: rgba(245,158,11,0.2);
  color: var(--hooper-warning);
  font-family: var(--hooper-font-mono);
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  border: 1px solid var(--hooper-warning);
}
.badge-inj-gtd {
  background: rgba(245,158,11,0.1);
  color: #d97706;
  font-family: var(--hooper-font-mono);
  font-size: 0.65rem;
  padding: 1px 5px;
  border-radius: 3px;
  border: 1px dashed var(--hooper-warning);
}
.badge-inj-p {
  color: #6b7280;
  font-family: var(--hooper-font-mono);
  font-size: 0.65rem;
  padding: 1px 5px;
}

/* ── ResultBadge — HIT / MISS / OPEN (Story 11.3) ─────────── */
.result-hit   { color: var(--hooper-ok);      font-family: var(--hooper-font-mono); font-weight: 600; }
.result-miss  { color: var(--hooper-danger);   font-family: var(--hooper-font-mono); font-weight: 600; }
.result-open  { color: #6b7280;               font-family: var(--hooper-font-mono); }

/* ── Pick Tank form — pre-filled field tint ────────────────── */
.pick-field-prefilled {
    background-color: rgba(249, 115, 22, 0.08) !important;
    color: #e5e7eb !important;
    border-color: rgba(249, 115, 22, 0.25) !important;
    cursor: default;
}
.pick-label {
    font-family: var(--hooper-font-mono);
    font-size: 0.7rem;
    text-transform: uppercase;
    color: #6b7280;
    margin-bottom: 4px;
    display: block;
}

/* ── Value Box — compact font for distribution stats ───────── */
.bslib-value-box .value-box-value {
  font-size: 1.1rem !important;
  font-family: var(--hooper-font-mono);
}
.bslib-value-box .value-box-title {
  font-size: 0.7rem !important;
  text-transform: uppercase;
  color: #9ca3af;
}

/* ── Last 10 Games — fix pandas to_html() right-aligned thead ─────────────── */
.table thead tr { text-align: left !important; }

/* ── Distribution detail panel ──────────────────────────────── */
.dist-spread-label {
  font-family: var(--hooper-font-mono);
  font-size: 0.75rem;
  color: #9ca3af;
  letter-spacing: 0.05em;
}
.distribution-chart-panel {
  width: 100%;
  min-width: 0;
}
.distribution-kpi-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 10px;
}
.distribution-kpi {
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: 6px;
  background: rgba(17, 24, 39, 0.62);
}
.distribution-kpi-label {
  display: block;
  overflow: hidden;
  color: #94a3b8;
  font-family: var(--hooper-font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.04em;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.distribution-kpi-value {
  display: block;
  margin-top: 2px;
  color: #f8fafc;
  font-family: var(--hooper-font-data);
  font-size: 0.95rem;
  line-height: 1.1;
}
@media (max-width: 768px) {
  .distribution-kpi-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 480px) {
  .distribution-kpi-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ── Matchup Pill — game lines sub-text (Story 13-12) ──────── */
.pill-game-lines {
  display: block;
  font-size: 10px;
  color: #6b7280;
  letter-spacing: 0.02em;
  margin-top: 2px;
}

/* ── Ops Panel (Story 13-11) ────────────────────────────────── */
.ops-container {
  position: fixed;
  top: 8px;
  right: 16px;
  z-index: 9999;
}
@media (max-width: 768px) {
  .ops-container {
    top: 12px;
    right: 82px;
  }
  #ops-panel {
    width: min(300px, calc(100vw - 24px));
    min-width: 0;
  }
}
.ops-toggle-btn { font-size: 12px; }
#ops-panel {
  background: #1e1e2e;
  border: 1px solid #444;
  border-radius: 6px;
  padding: 12px;
  min-width: 300px;
  margin-top: 4px;
}
.ops-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ops-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding: 6px 0;
  font-size: 13px;
  color: #ccc;
}
.ops-row-v2 {
  gap: 10px;
  min-height: 34px;
  border-bottom: 1px solid rgba(55, 65, 81, 0.55);
}
.ops-row-v2:last-child {
  border-bottom: 0;
}
.ops-row-copy {
  display: flex;
  min-width: 0;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 2px;
}
.ops-label {
  color: #e5e7eb;
  font-family: var(--hooper-font-data);
  font-size: 0.78rem;
  line-height: 1.15;
}
.ops-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  max-width: 210px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.68rem;
}
.ops-status-idle {
  color: #6b7280;
  font-family: var(--hooper-font-mono);
}
.ops-status-running { color: #f59e0b; font-family: var(--hooper-font-mono); }
.ops-status-done    { color: #22c55e; font-family: var(--hooper-font-mono); }
.ops-status-error   { color: #ef4444; font-family: var(--hooper-font-mono); }
.ops-spinner {
  width: 9px;
  height: 9px;
  flex: 0 0 9px;
  border: 2px solid rgba(245, 158, 11, 0.28);
  border-top-color: var(--hooper-warning);
  border-radius: 50%;
  animation: ops-spin 0.8s linear infinite;
}
.ops-progress-bar {
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  height: 2px;
  overflow: hidden;
  background: rgba(245, 158, 11, 0.14);
}
.ops-progress-bar::before {
  content: "";
  display: block;
  width: 45%;
  height: 100%;
  background: var(--hooper-warning);
  animation: ops-progress 1.1s ease-in-out infinite;
}
.ops-run-btn {
  flex: 0 0 auto;
  min-width: 50px;
}
.ops-clear-btn {
  width: 100%;
  margin-top: 8px;
}
@keyframes ops-spin {
  to { transform: rotate(360deg); }
}
@keyframes ops-progress {
  0% { transform: translateX(-110%); }
  100% { transform: translateX(230%); }
}
