/* HR Explorer — all selectors scoped under .hrx so nothing here can leak into
   bundle.css, the roadmap page, or any other surface. Palette copied from
   hr_explorer_mockup.html. */

.hrx { max-width: 1180px; margin: 0 auto; color: #e8eaed; }

.hrx-page-header { margin-bottom: 24px; }
.hrx-page-title { font-size: 32px; font-weight: 800; letter-spacing: -0.02em; margin-bottom: 6px; }
.hrx-page-sub { color: #8b949e; font-size: 14px; }

/* Panel */
.hrx-panel {
  background: #161b22; border: 1px solid #30363d; border-radius: 12px;
  padding: 22px 26px; margin-bottom: 20px;
}
.hrx-panel-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.hrx-panel-title { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.hrx-panel-sub { color: #8b949e; font-size: 13px; }
.hrx-panel-stats { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.hrx-stat-pill {
  background: rgba(74, 222, 128, 0.12); border: 1px solid rgba(74, 222, 128, 0.35);
  color: #4ade80; padding: 6px 12px; border-radius: 16px; font-size: 12px; font-weight: 700;
}
.hrx-stat-pill.amber { background: rgba(255, 184, 74, 0.12); border-color: rgba(255, 184, 74, 0.35); color: #ffb84a; }

/* Color mode + filter controls */
.hrx-mode-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.hrx-mode-label { font-size: 11px; color: #6e7681; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.hrx-mode-toggle { display: inline-flex; gap: 0; background: #0d1117; border: 1px solid #30363d; border-radius: 8px; padding: 3px; flex-wrap: wrap; }
.hrx-mode-btn {
  padding: 6px 12px; font-size: 12px; font-weight: 600; color: #8b949e;
  background: transparent; border: none; cursor: pointer; border-radius: 6px;
}
.hrx-mode-btn.active { background: #21262d; color: #e8eaed; }
.hrx-mode-btn:hover:not(.active) { color: #e8eaed; }

.hrx-filters-row { display: flex; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.hrx-filter-pill {
  background: #0d1117; border: 1px solid #30363d; color: #8b949e;
  padding: 5px 11px; border-radius: 14px; font-size: 11px; font-weight: 600; cursor: pointer;
}
.hrx-filter-pill.active { background: #21262d; color: #e8eaed; border-color: #58a6ff; }

/* Legend */
.hrx-legend-row {
  margin-bottom: 16px; display: none; flex-wrap: wrap; gap: 10px 14px;
  font-size: 11.5px; color: #8b949e; align-items: center;
}
.hrx-legend-row.active { display: flex; }
.hrx-legend-item { display: flex; align-items: center; gap: 5px; }
.hrx-legend-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.hrx-legend-grad { display: flex; align-items: center; gap: 8px; }
.hrx-legend-grad .hrx-bar {
  width: 160px; height: 10px; border-radius: 5px;
  background: linear-gradient(90deg, #4ade80 0%, #d9d550 45%, #ffb84a 70%, #f87171 90%, #d63a33 100%);
}
.hrx-legend-grad .hrx-bar.velo {
  background: linear-gradient(90deg, #58a6ff 0%, #4ade80 35%, #ffb84a 65%, #f87171 88%, #d63a33 100%);
}

/* Timeline */
.hrx-timeline-wrap { overflow-x: auto; padding-bottom: 14px; }
.hrx-timeline { display: flex; gap: 6px; align-items: flex-end; min-height: 200px; padding-top: 18px; }
.hrx-day-col { display: flex; flex-direction: column; gap: 2px; align-items: center; min-width: 38px; }
.hrx-pills { display: flex; flex-direction: column-reverse; gap: 2px; align-items: center; min-height: 160px; justify-content: flex-end; }
.hrx-pill {
  width: 28px; height: 14px; border-radius: 7px; cursor: pointer;
  background: #5b636e; /* fallback for unknown values */
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.hrx-pill:hover { transform: scale(1.12); box-shadow: 0 2px 6px rgba(0,0,0,0.6); }
.hrx-pill.selected { transform: scale(1.2); box-shadow: 0 0 0 2px #ffb84a, 0 2px 6px rgba(0,0,0,0.6); }
.hrx-day-col .hrx-label {
  font-size: 10px; color: #6e7681; margin-top: 6px; font-weight: 600;
  border-top: 1px solid #30363d; padding-top: 4px; width: 100%; text-align: center;
}
.hrx-day-col.today .hrx-label { color: #ffb84a; font-weight: 700; }
.hrx-day-col .hrx-count { font-size: 9px; color: #6e7681; margin-top: 3px; }
.hrx-today-marker {
  display: inline-block; background: #ffb84a; color: #1a0f00; padding: 2px 6px;
  border-radius: 3px; font-size: 9px; font-weight: 800; letter-spacing: 0.06em; margin-bottom: 4px;
}
.hrx-empty-timeline { color: #6e7681; font-size: 13px; padding: 40px 0; text-align: center; width: 100%; }

/* Detail card */
.hrx-detail {
  background: #0d1117; border: 1px solid #30363d; border-radius: 10px;
  padding: 20px 24px; margin-top: 16px;
}
.hrx-detail-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.hrx-detail-badge {
  background: rgba(74, 222, 128, 0.15); color: #4ade80; padding: 3px 10px;
  border-radius: 4px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
}
.hrx-detail-date { color: #6e7681; font-size: 12px; }
.hrx-detail-title { font-size: 22px; font-weight: 800; margin-bottom: 4px; letter-spacing: -0.01em; }
.hrx-detail-game { color: #8b949e; font-size: 13px; margin-bottom: 16px; }
.hrx-stats-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 16px; }
.hrx-stat { background: #161b22; border: 1px solid #21262d; border-radius: 8px; padding: 10px 12px; }
.hrx-stat-label { font-size: 10px; color: #6e7681; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; margin-bottom: 4px; }
.hrx-stat-value { font-size: 18px; font-weight: 800; color: #e8eaed; font-variant-numeric: tabular-nums; }
.hrx-stat-sub { font-size: 11px; color: #8b949e; margin-top: 1px; }
.hrx-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.hrx-tag {
  background: #161b22; border: 1px solid #30363d; color: #c9d1d9;
  padding: 4px 10px; border-radius: 14px; font-size: 11px; font-weight: 500;
}
.hrx-hint { margin-top: 10px; color: #6e7681; font-size: 11px; font-style: italic; }

/* ── Color modes ──────────────────────────────────────────────────────────
   Pills carry data-park / data-team / data-hand / data-pitch-type /
   data-distance-bucket / data-velo-bucket. The active mode lives on the
   .hrx-timeline-wrap[data-mode] parent. */

/* Park + Team share the franchise palette. */
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="ATH"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="ATH"] { background:#105937; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="ATL"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="ATL"] { background:#ce1141; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="AZ"],  .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="AZ"]  { background:#a71930; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="BAL"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="BAL"] { background:#df4601; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="BOS"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="BOS"] { background:#bd3039; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="CHC"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="CHC"] { background:#0e3386; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="CIN"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="CIN"] { background:#c6011f; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="CLE"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="CLE"] { background:#0c2340; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="COL"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="COL"] { background:#845ec2; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="CWS"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="CWS"] { background:#5d6770; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="DET"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="DET"] { background:#fa4616; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="HOU"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="HOU"] { background:#eb6e1f; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="KC"],  .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="KC"]  { background:#1d4f91; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="LAA"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="LAA"] { background:#ba0021; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="LAD"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="LAD"] { background:#005a9c; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="MIA"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="MIA"] { background:#00a3e0; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="MIL"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="MIL"] { background:#b6922e; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="MIN"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="MIN"] { background:#002b5c; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="NYM"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="NYM"] { background:#ff5910; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="NYY"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="NYY"] { background:#003087; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="PHI"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="PHI"] { background:#e81828; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="PIT"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="PIT"] { background:#fdb827; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="SD"],  .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="SD"]  { background:#ffc425; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="SEA"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="SEA"] { background:#005c5c; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="SF"],  .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="SF"]  { background:#fd5a1e; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="STL"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="STL"] { background:#c41e3a; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="TB"],  .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="TB"]  { background:#092c5c; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="TEX"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="TEX"] { background:#003278; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="TOR"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="TOR"] { background:#134a8e; }
.hrx-timeline-wrap[data-mode="park"] .hrx-pill[data-park="WSH"], .hrx-timeline-wrap[data-mode="team"] .hrx-pill[data-team="WSH"] { background:#ab0003; }

/* Distance gradient buckets */
.hrx-timeline-wrap[data-mode="distance"] .hrx-pill[data-distance-bucket="350"] { background:#4ade80; }
.hrx-timeline-wrap[data-mode="distance"] .hrx-pill[data-distance-bucket="380"] { background:#87d068; }
.hrx-timeline-wrap[data-mode="distance"] .hrx-pill[data-distance-bucket="400"] { background:#d9d550; }
.hrx-timeline-wrap[data-mode="distance"] .hrx-pill[data-distance-bucket="420"] { background:#ffb84a; }
.hrx-timeline-wrap[data-mode="distance"] .hrx-pill[data-distance-bucket="440"] { background:#f87171; }
.hrx-timeline-wrap[data-mode="distance"] .hrx-pill[data-distance-bucket="460"] { background:#d63a33; }

/* Exit velo gradient buckets */
.hrx-timeline-wrap[data-mode="velo"] .hrx-pill[data-velo-bucket="95"]  { background:#58a6ff; }
.hrx-timeline-wrap[data-mode="velo"] .hrx-pill[data-velo-bucket="100"] { background:#4ade80; }
.hrx-timeline-wrap[data-mode="velo"] .hrx-pill[data-velo-bucket="105"] { background:#ffb84a; }
.hrx-timeline-wrap[data-mode="velo"] .hrx-pill[data-velo-bucket="110"] { background:#f87171; }
.hrx-timeline-wrap[data-mode="velo"] .hrx-pill[data-velo-bucket="115"] { background:#d63a33; }

/* Pitcher hand */
.hrx-timeline-wrap[data-mode="hand"] .hrx-pill[data-hand="L"] { background:#58a6ff; }
.hrx-timeline-wrap[data-mode="hand"] .hrx-pill[data-hand="R"] { background:#f87171; }

/* Pitch type */
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="FF"] { background:#f87171; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="SI"] { background:#ffb84a; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="FC"] { background:#fb923c; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="SL"] { background:#58a6ff; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="ST"] { background:#845ec2; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="CU"] { background:#22d3ee; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="KC"] { background:#2dd4bf; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="CH"] { background:#4ade80; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="FS"] { background:#34d399; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="SV"] { background:#818cf8; }
.hrx-timeline-wrap[data-mode="pitch-type"] .hrx-pill[data-pitch-type="KN"] { background:#a3a3a3; }

/* ── Filters ──────────────────────────────────────────────────────────────
   Boolean attrs on pills: data-distance-min-400, data-velo-min-105,
   data-top-50, data-meltdown. The active filter lives on .hrx-timeline-wrap. */
.hrx-timeline-wrap[data-filter="distance-400"] .hrx-pill:not([data-distance-min-400]) { display: none; }
.hrx-timeline-wrap[data-filter="velo-105"]     .hrx-pill:not([data-velo-min-105])     { display: none; }
.hrx-timeline-wrap[data-filter="top-50"]       .hrx-pill:not([data-top-50])           { display: none; }
.hrx-timeline-wrap[data-filter="meltdown"]     .hrx-pill:not([data-meltdown])         { display: none; }

/* Mobile */
@media (max-width: 720px) {
  .hrx-panel { padding: 16px 14px; }
  .hrx-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .hrx-day-col { min-width: 30px; }
  .hrx-pill { width: 22px; }
}
