/* ============================================================
   BRKC RACE RESULTS DASHBOARD — results.css
   Theme pattern: Light mode = default, [data-theme="dark"] = override
   ============================================================ */

/* ---- DISCLAIMER BANNER ---- */
.results-disclaimer {
  padding: 14px 0;
  background: #fff3cd;
  border-bottom: 1px solid #e0c96e;
}

.results-disclaimer p {
  font-size: 13px;
  line-height: 1.5;
  color: #665d1e;
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

.results-disclaimer strong {
  color: #5a4b00;
}

[data-theme="dark"] .results-disclaimer {
  background: #3a3000;
  border-color: #5a4b00;
}

[data-theme="dark"] .results-disclaimer p {
  color: #e0c96e;
}

[data-theme="dark"] .results-disclaimer strong {
  color: #f0d850;
}

/* ---- WIZARD SECTION ---- */
.wizard-section {
  padding-top: 40px;
  padding-bottom: 60px;
  background: var(--white);
}

.wizard-search-bar {
  max-width: 600px;
  margin: 0 auto 32px;
  text-align: center;
}

.wizard-search-hint {
  font-family: var(--font-sub);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--text-muted);
  margin-top: 12px;
}

.wizard-card {
  max-width: 800px;
  margin: 0 auto;
  background: var(--light-card-bg);
  border: 1px solid var(--light-border);
  border-radius: var(--radius-lg);
  padding: 40px 32px;
}

/* Wizard progress */
.wizard-progress {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 32px;
}

.wizard-progress-step {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--light-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sub);
  font-weight: 700;
  font-size: 14px;
  color: var(--text-muted);
  transition: all var(--transition);
}

.wizard-progress-step.active {
  background: var(--red);
  color: var(--white);
  box-shadow: 0 0 0 4px rgba(232, 0, 13, 0.25);
}

.wizard-progress-step.done {
  background: var(--red-dark);
  color: var(--white);
}

.wizard-progress-line {
  width: 60px;
  height: 2px;
  background: var(--light-border);
  margin: 0 4px;
}

.wizard-progress-line.done {
  background: var(--red);
}

/* Wizard steps */
.wizard-step {
  display: none;
  animation: wizardFadeIn 0.3s ease;
}

.wizard-step.active {
  display: block;
}

@keyframes wizardFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.wizard-question {
  font-family: var(--font-heading);
  font-size: clamp(24px, 4vw, 32px);
  color: var(--text-dark);
  text-align: center;
  margin-bottom: 24px;
}

.wizard-options {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

.wizard-option {
  padding: 18px 16px;
  background: var(--white);
  border: 2px solid var(--light-border);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition);
  text-align: center;
}

.wizard-option:hover {
  border-color: var(--red);
  transform: translateY(-2px);
  box-shadow: var(--shadow-light-hover);
}

.wizard-option-label {
  display: block;
  font-family: var(--font-sub);
  font-weight: 600;
  font-size: 16px;
  color: var(--text-dark);
  margin-bottom: 4px;
}

.wizard-option-desc {
  display: block;
  font-size: 13px;
  color: var(--text-muted);
}

.wizard-back-btn {
  display: inline-block;
  margin-top: 20px;
  padding: 8px 16px;
  background: none;
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  color: var(--text-muted);
  font-family: var(--font-sub);
  font-size: 13px;
  cursor: pointer;
  transition: all var(--transition);
}

.wizard-back-btn:hover {
  border-color: var(--red);
  color: var(--red);
}

/* Results search inline */
.results-search-inline {
  padding: 16px 0;
  background: var(--light-card-bg);
}

.driver-search-wrap--small input {
  padding: 12px 16px 12px 44px;
  font-size: 15px;
}

/* ---- SEARCH ---- */
.driver-search-wrap {
  position: relative;
  max-width: 600px;
  margin: 0 auto;
}

.driver-search-wrap input {
  width: 100%;
  padding: 16px 20px 16px 52px;
  font-family: var(--font-body);
  font-size: 18px;
  background: var(--white);
  border: 2px solid var(--light-border);
  border-radius: var(--radius-lg);
  color: var(--text-dark);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.driver-search-wrap input::placeholder {
  color: var(--text-muted);
}

.driver-search-wrap input:focus {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(232, 0, 13, 0.2);
}

.driver-search-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: var(--text-muted);
  pointer-events: none;
}

.driver-suggestions {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--white);
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-light);
  z-index: 100;
  max-height: 360px;
  overflow-y: auto;
}

.driver-suggestions.active { display: block; }

.driver-suggestion {
  padding: 12px 16px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  transition: background var(--transition);
  border-bottom: 1px solid var(--light-border);
}

.driver-suggestion:last-child { border-bottom: none; }

.driver-suggestion:hover,
.driver-suggestion.focused {
  background: var(--light-card-bg);
}

.driver-suggestion-name {
  font-family: var(--font-sub);
  font-weight: 600;
  font-size: 15px;
  color: var(--text-dark);
}

.driver-suggestion-meta {
  font-size: 12px;
  color: var(--text-muted);
  text-align: right;
  white-space: nowrap;
}

.driver-suggestion-team {
  color: var(--red);
  font-size: 13px;
}

.driver-suggestion-no-results {
  padding: 16px;
  text-align: center;
  color: var(--text-muted);
  font-size: 14px;
}

/* ---- FILTER BAR ---- */
.results-filters {
  padding: 20px 0;
  background: var(--light-card-bg);
  border-bottom: 1px solid var(--light-border);
  position: sticky;
  top: var(--nav-h);
  z-index: 50;
}

.filter-bar {
  display: flex;
  align-items: flex-end;
  gap: 16px;
  flex-wrap: wrap;
}

.filter-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.filter-group label {
  font-family: var(--font-sub);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--text-muted);
}

.filter-group select {
  padding: 10px 36px 10px 14px;
  font-family: var(--font-body);
  font-size: 14px;
  background: var(--white);
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  color: var(--text-dark);
  cursor: pointer;
  outline: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23888'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  min-width: 160px;
  transition: border-color var(--transition);
}

.filter-group select:focus { border-color: var(--red); }

/* Session: tabs on desktop, dropdown on mobile */
.filter-group--session-select { display: none; }

.session-tabs { display: flex; gap: 0; }

.session-tab {
  padding: 10px 16px;
  font-family: var(--font-sub);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: var(--white);
  border: 1px solid var(--light-border);
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition);
}

.session-tab:first-child { border-radius: var(--radius) 0 0 var(--radius); }
.session-tab:last-child { border-radius: 0 var(--radius) var(--radius) 0; }
.session-tab + .session-tab { border-left: none; }

.session-tab:hover {
  color: var(--text-dark);
  background: var(--light-card-bg);
}

.session-tab.active {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
}

.btn-reset-filters {
  padding: 10px 16px;
  font-family: var(--font-sub);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1px;
  background: transparent;
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition);
  margin-left: auto;
}

.btn-reset-filters:hover { border-color: var(--red); color: var(--red); }

/* Active filter pills */
.active-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.active-filters:empty { display: none; }

.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 12px;
  font-size: 12px;
  font-family: var(--font-sub);
  background: var(--white);
  border: 1px solid var(--red);
  border-radius: 20px;
  color: var(--text-body);
}

.filter-pill-x {
  cursor: pointer;
  color: var(--red);
  font-size: 14px;
  line-height: 1;
  font-weight: bold;
}

.filter-pill-x:hover { color: var(--red-light); }

/* ---- RESULTS VIEW WRAPPER ---- */
.results-view {
  background: var(--white);
}

/* ---- VIEW CONTROLS ---- */
.view-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  flex-wrap: wrap;
  gap: 12px;
}

.results-summary { font-size: 14px; color: var(--text-muted); }
.results-summary strong { color: var(--text-dark); }

/* ---- RESULTS TABLE ---- */
.results-main { padding: 40px 0 80px; }

.results-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--light-border);
}

.results-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.results-table thead {
  background: var(--light-card-bg);
  position: sticky;
  top: 0;
  z-index: 5;
}

.results-table th {
  padding: 14px 12px;
  text-align: left;
  font-family: var(--font-sub);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
  border-bottom: 2px solid var(--light-border);
  white-space: nowrap;
  user-select: none;
}

.results-table th.sortable { cursor: pointer; transition: color var(--transition); }
.results-table th.sortable:hover { color: var(--text-dark); }

.results-table th.sort-asc::after,
.results-table th.sort-desc::after { margin-left: 6px; font-size: 10px; }
.results-table th.sort-asc::after { content: '\25B2'; color: var(--red); }
.results-table th.sort-desc::after { content: '\25BC'; color: var(--red); }

.results-table td {
  padding: 12px;
  border-bottom: 1px solid var(--light-border);
  color: var(--text-body);
  vertical-align: middle;
}

.results-table tbody tr { transition: background var(--transition); }
.results-table tbody tr:hover { background: var(--light-card-bg); }
.results-table tbody tr.lap-detail-row:hover { background: transparent; }

/* Position badges */
.pos-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-family: var(--font-sub);
  font-weight: 700;
  font-size: 13px;
  color: var(--black);
}

.pos-1 { background: #FFD700; }
.pos-2 { background: #C0C0C0; }
.pos-3 { background: #CD7F32; }

.pos-text { font-family: var(--font-sub); font-weight: 600; font-size: 14px; color: var(--text-muted); }
.pos-dns { font-family: var(--font-sub); font-weight: 600; font-size: 12px; color: var(--text-muted); letter-spacing: 1px; }

/* Driver link */
.driver-link {
  color: var(--text-dark) !important;
  cursor: pointer;
  font-weight: 500;
  transition: color var(--transition);
  text-decoration: none;
}

.driver-link:hover { color: var(--red) !important; }

/* Fastest lap */
.fastest-lap { color: #c040ff; font-weight: 600; }

/* Expand button */
.expand-laps-btn {
  background: none;
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px 8px;
  font-size: 11px;
  font-family: var(--font-sub);
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all var(--transition);
}

.expand-laps-btn:hover { border-color: var(--red); color: var(--red); }

/* ---- LAP TIME DETAIL ROW ---- */
.lap-detail-row td { padding: 0; border-bottom: 2px solid var(--light-border); }

.lap-detail-content { padding: 16px 20px 20px; background: var(--light-card-bg); }

.lap-bars-title {
  font-family: var(--font-sub);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
  margin-bottom: 12px;
}

.lap-bar-row { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }

.lap-bar-label {
  font-size: 12px;
  color: var(--text-muted);
  width: 28px;
  text-align: right;
  flex-shrink: 0;
  font-family: var(--font-sub);
}

.lap-bar-track {
  flex: 1;
  height: 22px;
  background: var(--light-border);
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}

.lap-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.4s ease;
  display: flex;
  align-items: center;
  padding-left: 8px;
}

.lap-bar-fill.fastest { background: #c040ff; }
.lap-bar-fill.normal { background: #aaa; }

.lap-bar-time {
  font-size: 11px;
  font-weight: 600;
  color: var(--white);
  white-space: nowrap;
  font-family: var(--font-sub);
}

.lap-bar-delta { font-size: 11px; width: 60px; text-align: right; flex-shrink: 0; font-family: var(--font-sub); }
.lap-bar-delta.faster { color: #2e7d32; }
.lap-bar-delta.slower { color: #d84315; }

.lap-consistency { margin-top: 12px; font-size: 13px; color: var(--text-muted); }
.lap-consistency strong { color: var(--text-dark); }

/* ---- DRIVER PROFILE MODAL ---- */
.driver-modal {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1000;
  overflow-y: auto;
  padding: 40px 16px;
}

.driver-modal.active { display: flex; justify-content: center; align-items: flex-start; }

.driver-modal-content {
  background: var(--white);
  border: 1px solid var(--light-border);
  border-radius: var(--radius-lg);
  max-width: 900px;
  width: 100%;
  position: relative;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  animation: modalSlideUp 0.3s ease;
}

@keyframes modalSlideUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

.driver-modal-close {
  position: absolute;
  top: 16px; right: 16px;
  background: var(--light-card-bg);
  border: 1px solid var(--light-border);
  border-radius: 50%;
  width: 36px; height: 36px;
  font-size: 20px;
  color: var(--text-body);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
  z-index: 10;
}

.driver-modal-close:hover { background: var(--red); border-color: var(--red); color: var(--white); }

/* Driver profile header */
.driver-profile-header { padding: 32px 32px 24px; border-bottom: 1px solid var(--light-border); }

.driver-profile-name {
  font-family: var(--font-heading);
  font-size: clamp(32px, 5vw, 48px);
  color: var(--text-dark);
  line-height: 1;
  margin-bottom: 4px;
}

.driver-profile-team { font-family: var(--font-sub); font-size: 16px; color: var(--red); margin-bottom: 16px; }

.driver-quick-stats { display: flex; gap: 24px; flex-wrap: wrap; }
.driver-stat { text-align: center; }
.driver-stat-value { font-family: var(--font-heading); font-size: 28px; color: var(--text-dark); line-height: 1.1; }
.driver-stat-label { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-muted); font-family: var(--font-sub); }

/* Position chart */
.driver-chart-section { padding: 24px 32px; border-bottom: 1px solid var(--light-border); }

.driver-section-title {
  font-family: var(--font-sub);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--text-muted);
  margin-bottom: 16px;
}

.position-chart { width: 100%; height: 180px; }
.position-chart circle { transition: r 0.2s ease; }
.position-chart circle:hover { r: 7; }

/* Round accordion */
.driver-rounds-section { padding: 24px 32px 32px; }

.round-accordion { border: 1px solid var(--light-border); border-radius: var(--radius); margin-bottom: 8px; overflow: hidden; }

.round-accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: var(--light-card-bg);
  cursor: pointer;
  transition: background var(--transition);
  user-select: none;
}

.round-accordion-header:hover { background: var(--light-border); }

.round-accordion-title { font-family: var(--font-sub); font-weight: 600; font-size: 15px; color: var(--text-dark); }
.round-accordion-result { font-size: 13px; color: var(--text-muted); }
.round-accordion-arrow { color: var(--text-muted); transition: transform var(--transition); font-size: 12px; }
.round-accordion.open .round-accordion-arrow { transform: rotate(180deg); }

.round-accordion-body { display: none; padding: 0; }
.round-accordion.open .round-accordion-body { display: block; }

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

.round-session-table th {
  padding: 8px 12px;
  text-align: left;
  font-family: var(--font-sub);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  background: var(--light-card-bg);
  border-bottom: 1px solid var(--light-border);
}

.round-session-table td { padding: 8px 12px; border-bottom: 1px solid var(--light-border); color: var(--text-body); }

/* Compare button (in driver profile header) */
.btn-compare {
  display: block;
  width: 100%;
  padding: 14px 24px;
  font-family: var(--font-sub);
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  background: var(--red);
  border: 2px solid var(--red);
  border-radius: var(--radius);
  color: var(--white);
  cursor: pointer;
  transition: all var(--transition);
  margin-top: 20px;
}

.btn-compare:hover { background: var(--red-dark); border-color: var(--red-dark); }

/* ---- HEAD-TO-HEAD PANEL ---- */
.h2h-panel {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--white);
  border-top: 2px solid var(--red);
  box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.15);
  z-index: 900;
  max-height: 85vh;
  overflow-y: auto;
  animation: panelSlideUp 0.3s ease;
}

.h2h-panel.active { display: block; }
.h2h-panel.active ~ .back-to-top { opacity: 0 !important; pointer-events: none !important; }

@keyframes panelSlideUp {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}

.h2h-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  border-bottom: 1px solid var(--light-border);
  position: sticky;
  top: 0;
  background: var(--white);
  z-index: 5;
}

.h2h-title { font-family: var(--font-heading); font-size: 24px; color: var(--text-dark); }

.h2h-close { background: none; border: none; color: var(--text-muted); font-size: 24px; cursor: pointer; padding: 4px; }
.h2h-close:hover { color: var(--red); }

.h2h-body { padding: 24px; }

.h2h-search-wrap { max-width: 400px; margin: 0 auto 24px; position: relative; }

.h2h-search-wrap input {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 15px;
  background: var(--light-card-bg);
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  color: var(--text-dark);
  outline: none;
}

.h2h-search-wrap input:focus { border-color: var(--red); }

/* H2H Score banner */
.h2h-score {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 20px 0;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--light-border);
}

.h2h-score-driver { text-align: center; flex: 1; max-width: 200px; }
.h2h-score-name { font-family: var(--font-sub); font-size: 14px; font-weight: 600; color: var(--text-dark); margin-bottom: 4px; }
.h2h-score-num { font-family: var(--font-heading); font-size: 40px; color: var(--text-muted); line-height: 1; }
.h2h-score-winner .h2h-score-num { color: #2e7d32; }
.h2h-score-vs { font-family: var(--font-heading); font-size: 20px; color: var(--red); flex-shrink: 0; }

/* H2H Round cards */
.h2h-card {
  border: 1px solid var(--light-border);
  border-radius: var(--radius);
  margin-bottom: 10px;
  overflow: hidden;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.h2h-card-header {
  padding: 8px 14px;
  background: var(--light-card-bg);
  font-family: var(--font-sub);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
}

.h2h-card-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  border-top: 1px solid var(--light-border);
}

.h2h-card-name {
  font-family: var(--font-sub);
  font-weight: 600;
  font-size: 14px;
  color: var(--text-body);
}

.h2h-card-result {
  display: flex;
  align-items: center;
  gap: 12px;
}

.h2h-card-pos {
  font-family: var(--font-heading);
  font-size: 20px;
  color: var(--text-muted);
}

.h2h-card-lap {
  font-size: 13px;
  color: var(--text-muted);
  font-family: var(--font-sub);
}

.h2h-card-winner .h2h-card-name { color: #2e7d32; }
.h2h-card-winner .h2h-card-pos { color: #2e7d32; }
.h2h-card-loser { opacity: 0.6; }

/* ---- EMPTY STATE ---- */
.results-empty { text-align: center; padding: 60px 24px; }
.results-empty-icon { font-size: 48px; margin-bottom: 16px; opacity: 0.3; }
.results-empty-text { font-family: var(--font-sub); font-size: 16px; color: var(--text-muted); }

/* ---- LOADING ---- */
.results-loading { text-align: center; padding: 80px 24px; }

.results-loading-spinner {
  width: 40px; height: 40px;
  border: 3px solid var(--light-border);
  border-top-color: var(--red);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto 16px;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ---- RESPONSIVE ---- */
@media (max-width: 768px) {
  /* Wizard */
  .wizard-section { padding-top: 24px; padding-bottom: 40px; }
  .wizard-card { padding: 24px 16px; }
  .wizard-options { grid-template-columns: 1fr 1fr; gap: 8px; }
  .wizard-option { padding: 14px 12px; }
  .wizard-option-label { font-size: 14px; }
  .wizard-question { font-size: 22px; margin-bottom: 16px; }
  .wizard-search-bar { margin-bottom: 20px; }

  /* Search */
  .driver-search-wrap input { font-size: 16px; padding: 14px 16px 14px 44px; }
  .driver-search-icon { left: 14px; }

  /* Filters */
  .filter-bar { gap: 8px; }
  .filter-group { width: calc(50% - 4px); }
  .filter-group select { min-width: 0; width: 100%; font-size: 13px; }
  .filter-group--session-tabs { display: none; }
  .filter-group--session-select { display: flex; }
  .filter-group { width: calc(50% - 4px); }
  .filter-group select { width: 100%; }
  .btn-reset-filters { width: 100%; text-align: center; margin-left: 0; }

  /* Table */
  .results-main { padding: 24px 0 60px; }
  .results-table-wrap { border-radius: var(--radius); }
  .results-table { font-size: 13px; }
  .results-table th, .results-table td { padding: 10px 8px; }

  .results-table .col-team,
  .results-table .col-avg-speed,
  .results-table .col-laps,
  .results-table .col-best-on-lap { display: none; }

  /* Driver modal */
  .driver-modal { padding: 0; align-items: flex-end; }
  .driver-modal-content {
    margin: 0;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    min-height: 85vh;
    max-height: 100vh;
    overflow-y: auto;
  }
  .driver-profile-header { padding: 24px 16px 20px; }
  .driver-profile-name { font-size: 32px; }
  .driver-quick-stats { gap: 16px; }
  .driver-stat-value { font-size: 22px; }
  .btn-compare { font-size: 13px; padding: 12px 16px; }
  .driver-chart-section, .driver-rounds-section { padding: 16px; }
  .round-session-table { font-size: 12px; }
  .round-session-table th, .round-session-table td { padding: 6px 8px; }

  /* Lap detail */
  .lap-detail-content { padding: 12px 12px 16px; }
  .lap-bar-delta { width: 50px; font-size: 10px; }

  /* H2H */
  .h2h-body { padding: 12px; }
  .h2h-score-name { font-size: 12px; }
  .h2h-score-num { font-size: 32px; }
}

/* ===========================================================
   DARK MODE OVERRIDES — [data-theme="dark"]
   Every section, background, border, and text color covered.
   =========================================================== */

/* -- Results view wrapper -- */
[data-theme="dark"] .results-view {
  background: var(--dark-2);
}

/* -- Wizard -- */
[data-theme="dark"] .wizard-section {
  background: var(--dark-2);
}

[data-theme="dark"] .wizard-card {
  background: var(--dark-3);
  border-color: var(--dark-4);
}

[data-theme="dark"] .wizard-question {
  color: var(--white);
}

[data-theme="dark"] .wizard-search-hint {
  color: var(--light-mid);
}

[data-theme="dark"] .wizard-progress-step {
  background: var(--dark-4);
  color: var(--light-mid);
}

[data-theme="dark"] .wizard-progress-line {
  background: var(--dark-4);
}

[data-theme="dark"] .wizard-option {
  background: var(--dark-4);
  border-color: #3a3a3a;
}

[data-theme="dark"] .wizard-option:hover {
  border-color: var(--red);
  background: #3a3a3a;
  box-shadow: none;
}

[data-theme="dark"] .wizard-option-label {
  color: var(--white);
}

[data-theme="dark"] .wizard-option-desc {
  color: var(--light-mid);
}

[data-theme="dark"] .wizard-back-btn {
  border-color: var(--dark-4);
  color: var(--light-mid);
}

/* -- Search -- */
[data-theme="dark"] .results-search-inline {
  background: var(--dark);
}

[data-theme="dark"] .driver-search-wrap input {
  background: var(--dark-2);
  border-color: var(--dark-4);
  color: var(--white);
}

[data-theme="dark"] .driver-search-wrap input::placeholder {
  color: var(--light-mid);
}

[data-theme="dark"] .driver-search-icon {
  color: var(--light-mid);
}

[data-theme="dark"] .driver-suggestions {
  background: var(--dark-3);
  border-color: var(--dark-4);
  box-shadow: var(--shadow);
}

[data-theme="dark"] .driver-suggestion {
  border-color: var(--dark-4);
}

[data-theme="dark"] .driver-suggestion:hover,
[data-theme="dark"] .driver-suggestion.focused {
  background: var(--dark-4);
}

[data-theme="dark"] .driver-suggestion-name {
  color: var(--white);
}

[data-theme="dark"] .driver-suggestion-meta {
  color: var(--light-mid);
}

[data-theme="dark"] .driver-suggestion-no-results {
  color: var(--light-mid);
}

/* -- Filter bar -- */
[data-theme="dark"] .results-filters {
  background: var(--dark);
  border-color: var(--dark-4);
}

[data-theme="dark"] .filter-group label {
  color: var(--light-mid);
}

[data-theme="dark"] .filter-group select {
  background: var(--dark-2);
  border-color: var(--dark-4);
  color: var(--white);
}

[data-theme="dark"] .session-tab {
  background: var(--dark-2);
  border-color: var(--dark-4);
  color: var(--light-mid);
}

[data-theme="dark"] .session-tab:hover {
  background: var(--dark-3);
  color: var(--white);
}

[data-theme="dark"] .btn-reset-filters {
  border-color: var(--dark-4);
  color: var(--light-mid);
}

[data-theme="dark"] .filter-pill {
  background: var(--dark-3);
  color: var(--light);
}

/* -- Results summary -- */
[data-theme="dark"] .results-summary {
  color: var(--light-mid);
}

[data-theme="dark"] .results-summary strong {
  color: var(--white);
}

/* -- Results table -- */
[data-theme="dark"] .results-table-wrap {
  border-color: var(--dark-4);
}

[data-theme="dark"] .results-table thead {
  background: var(--dark-2);
}

[data-theme="dark"] .results-table th {
  border-color: var(--dark-4);
  color: var(--light-mid);
}

[data-theme="dark"] .results-table th.sortable:hover {
  color: var(--white);
}

[data-theme="dark"] .results-table td {
  border-color: var(--dark-4);
  color: var(--light);
}

[data-theme="dark"] .results-table tbody tr:hover {
  background: var(--dark-2);
}

[data-theme="dark"] .driver-link {
  color: var(--white) !important;
}

[data-theme="dark"] .pos-text {
  color: var(--light-mid);
}

[data-theme="dark"] .pos-dns {
  color: var(--mid);
}

[data-theme="dark"] .expand-laps-btn {
  border-color: var(--dark-4);
  color: var(--light-mid);
}

/* -- Lap detail -- */
[data-theme="dark"] .lap-detail-row td {
  border-color: var(--dark-4);
}

[data-theme="dark"] .lap-detail-content {
  background: var(--dark-2);
}

[data-theme="dark"] .lap-bars-title {
  color: var(--light-mid);
}

[data-theme="dark"] .lap-bar-label {
  color: var(--light-mid);
}

[data-theme="dark"] .lap-bar-track {
  background: var(--dark-4);
}

[data-theme="dark"] .lap-bar-fill.normal {
  background: var(--mid);
}

[data-theme="dark"] .lap-bar-delta.faster { color: #4caf50; }
[data-theme="dark"] .lap-bar-delta.slower { color: #ff6b35; }

[data-theme="dark"] .lap-consistency {
  color: var(--light-mid);
}

[data-theme="dark"] .lap-consistency strong {
  color: var(--white);
}

/* -- Driver modal -- */
[data-theme="dark"] .driver-modal {
  background: rgba(0, 0, 0, 0.85);
}

[data-theme="dark"] .driver-modal-content {
  background: var(--dark);
  border-color: var(--dark-4);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
}

[data-theme="dark"] .driver-modal-close {
  background: var(--dark-3);
  border-color: var(--dark-4);
  color: var(--light);
}

[data-theme="dark"] .driver-profile-header {
  border-color: var(--dark-4);
}

[data-theme="dark"] .driver-profile-name {
  color: var(--white);
}

[data-theme="dark"] .driver-stat-value {
  color: var(--white);
}

[data-theme="dark"] .driver-stat-label {
  color: var(--light-mid);
}

[data-theme="dark"] .driver-chart-section {
  border-color: var(--dark-4);
}

[data-theme="dark"] .driver-section-title {
  color: var(--light-mid);
}

[data-theme="dark"] .round-accordion {
  border-color: var(--dark-4);
}

[data-theme="dark"] .round-accordion-header {
  background: var(--dark-2);
}

[data-theme="dark"] .round-accordion-header:hover {
  background: var(--dark-3);
}

[data-theme="dark"] .round-accordion-title {
  color: var(--white);
}

[data-theme="dark"] .round-accordion-result {
  color: var(--light-mid);
}

[data-theme="dark"] .round-accordion-arrow {
  color: var(--light-mid);
}

[data-theme="dark"] .round-session-table th {
  background: var(--dark-3);
  border-color: var(--dark-4);
  color: var(--light-mid);
}

[data-theme="dark"] .round-session-table td {
  border-color: var(--dark-4);
  color: var(--light);
}

[data-theme="dark"] .btn-compare {
  background: var(--red);
  border-color: var(--red);
}

[data-theme="dark"] .btn-compare:hover {
  background: var(--red-dark);
  border-color: var(--red-dark);
}

/* -- Head-to-head -- */
[data-theme="dark"] .h2h-panel {
  background: var(--dark);
  box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .h2h-header {
  background: var(--dark);
  border-color: var(--dark-4);
}

[data-theme="dark"] .h2h-title {
  color: var(--white);
}

[data-theme="dark"] .h2h-close {
  color: var(--light-mid);
}

[data-theme="dark"] .h2h-search-wrap input {
  background: var(--dark-2);
  border-color: var(--dark-4);
  color: var(--white);
}

[data-theme="dark"] .h2h-score { border-color: var(--dark-4); }
[data-theme="dark"] .h2h-score-name { color: var(--white); }
[data-theme="dark"] .h2h-score-num { color: var(--light-mid); }
[data-theme="dark"] .h2h-score-winner .h2h-score-num { color: #4caf50; }

[data-theme="dark"] .h2h-card { border-color: var(--dark-4); }
[data-theme="dark"] .h2h-card-header { background: var(--dark-3); color: var(--light-mid); }
[data-theme="dark"] .h2h-card-row { border-color: var(--dark-4); }
[data-theme="dark"] .h2h-card-name { color: var(--light); }
[data-theme="dark"] .h2h-card-pos { color: var(--light-mid); }
[data-theme="dark"] .h2h-card-lap { color: var(--light-mid); }
[data-theme="dark"] .h2h-card-winner .h2h-card-name { color: #4caf50; }
[data-theme="dark"] .h2h-card-winner .h2h-card-pos { color: #4caf50; }

/* -- Empty / loading -- */
[data-theme="dark"] .results-empty-text {
  color: var(--light-mid);
}

[data-theme="dark"] .results-loading {
  color: var(--light-mid);
}

[data-theme="dark"] .results-loading-spinner {
  border-color: var(--dark-4);
  border-top-color: var(--red);
}
