/* ============================================================
   game.css – Scoreboard, Player Panels, Dart Keyboard
   ============================================================ */

/* ── Player Tabs (Mobile) ── */
.player-tabs {
  display: flex;
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}

.player-tab {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-sm) var(--space-xs);
  border-bottom: 2px solid transparent;
  transition: border-color var(--transition-fast);
  min-width: 0;
}

.player-tab.active {
  border-bottom-color: var(--color-accent);
}

.player-tab__name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-player-inactive);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  transition: color var(--transition-fast);
}

.player-tab.active .player-tab__name {
  color: var(--color-player-active);
}

.player-tab__legs {
  margin-top: 2px;
}

/* ── Score Area (Mobile – 2 players side by side) ── */
.score-area {
  flex: 1;
  display: flex;
  min-height: 0;
}

.score-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-md) var(--space-sm);
  min-width: 0;
  position: relative;
}

.score-panel + .score-panel {
  border-left: 1px solid var(--color-border);
}

.score-panel__score {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  color: var(--color-score-inactive);
  transition: color var(--transition-fast), font-size var(--transition-fast);
  font-variant-numeric: tabular-nums;
}

.score-panel.active .score-panel__score {
  color: var(--color-score-active);
}

/* Larger score for active player on small screens */
@media (max-width: 480px) {
  .score-panel.active .score-panel__score {
    font-size: var(--font-size-3xl);
  }
}

/* ── Score History (last 3 turns) ── */
.score-history {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  margin-top: var(--space-xs);
  min-height: 42px;
}

.score-history__item {
  font-size: 11px;
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
}

.score-history__item.bust {
  color: var(--color-danger);
  font-weight: var(--font-weight-semibold);
}

.score-panel__checkout {
  font-size: var(--font-size-xs);
  color: var(--color-accent);
  font-weight: var(--font-weight-medium);
  margin-top: var(--space-xs);
  min-height: 16px;
  text-align: center;
}

/* ── Stats Row ── */
.stats-row {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  padding: var(--space-sm) var(--space-md);
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.stats-row__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 44px;
}

.stats-row__label {
  font-size: 10px;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.stats-row__value {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
}

/* Two-column stats layout for mobile */
/* ── Stats Bar (below score area) ── */
.stats-bar {
  display: flex;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
  flex-shrink: 0;
}

.stats-bar__col {
  flex: 1;
  padding: var(--space-xs) var(--space-sm);
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.stats-bar__col + .stats-bar__col {
  border-left: 1px solid var(--color-border);
}

.stats-line {
  display: flex;
  gap: var(--space-xs) var(--space-sm);
  flex-wrap: wrap;
  justify-content: center;
}

.si {
  display: flex;
  gap: 3px;
  font-size: var(--font-size-xs);
  white-space: nowrap;
}

.si__k { color: var(--color-text-muted); }
.si__v { font-weight: var(--font-weight-semibold); color: var(--color-text); }

/* ── Current Turn / Dart Indicators ── */
.turn-tracker {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  padding: var(--space-xs) var(--space-md);
  flex-shrink: 0;
}

/* ── Dart Keyboard ── */
.dart-keyboard {
  background: var(--color-keyboard-bg);
  display: flex;
  flex-direction: column;
  user-select: none;
}

/* Multiplier Tab Bar */
.keyboard-tabs {
  display: flex;
  background: var(--color-keyboard-surface);
}

.keyboard-tab {
  flex: 1;
  padding: 10px var(--space-sm);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-keyboard-tab-text);
  text-align: center;
  cursor: pointer;
  transition: color var(--transition-fast), background var(--transition-fast);
  border-bottom: 2px solid transparent;
}

.keyboard-tab.active {
  color: var(--color-keyboard-tab-active);
  border-bottom-color: var(--color-accent);
}

/* Number Grid */
.keyboard-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--color-keyboard-bg);
  flex: 1;
}

.keyboard-btn {
  background: var(--color-keyboard-btn);
  color: var(--color-keyboard-text);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-fast), opacity var(--transition-fast);
  border-radius: 0;
  touch-action: manipulation;
}

.keyboard-btn:active,
.keyboard-btn:hover {
  background: var(--color-keyboard-btn-hover);
}

.keyboard-btn.disabled {
  opacity: 0.2;
  pointer-events: none;
}

/* Bull row: 25 and Bull span across grid */
.keyboard-row-special {
  display: grid;
  grid-template-columns: 2fr 2fr 1fr;
  gap: 1px;
  background: var(--color-keyboard-bg);
}

/* Action Buttons Row */
.keyboard-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--color-keyboard-bg);
}

.keyboard-action-btn {
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  gap: var(--space-sm);
  transition: opacity var(--transition-fast), filter var(--transition-fast);
  touch-action: manipulation;
}

.keyboard-action-btn svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.keyboard-action-btn--undo {
  background: var(--color-danger);
  color: #ffffff;
}

.keyboard-action-btn--undo:active {
  filter: brightness(0.9);
}

.keyboard-action-btn--next {
  background: var(--color-success);
  color: #ffffff;
}

.keyboard-action-btn--next:active {
  filter: brightness(0.9);
}

.keyboard-action-btn:disabled {
  opacity: 0.4;
  pointer-events: none;
}


/* ── Bust Indicator ── */
.bust-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-danger);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: var(--space-xs);
  min-height: 18px;
}

/* ── Current Throw Display ── */
.throw-display {
  display: flex;
  gap: var(--space-xs);
  justify-content: center;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  min-height: 16px;
}

.throw-display__dart {
  font-weight: var(--font-weight-medium);
}

/* ── Winner Screen ── */
.winner-screen {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  padding: var(--space-xl) var(--space-md);
  min-height: 100dvh;
  text-align: center;
}

.winner-screen__name {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
}

.winner-screen__result {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
}

.winner-screen__stats {
  width: 100%;
  max-width: 480px;
}

.winner-stats-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.winner-stats-table th {
  padding: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-weight: var(--font-weight-medium);
}

.winner-stats-table td {
  padding: var(--space-sm);
  text-align: center;
  border-bottom: 1px solid var(--color-border);
}

.winner-stats-table tr:last-child td {
  border-bottom: none;
}

/* ── Pause Menu ── */
.pause-menu {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.pause-menu__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  text-align: center;
  margin-bottom: var(--space-sm);
}

/* ── History Screen ── */
.history-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}

.history-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-sm);
}

.history-card__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.history-card__variant {
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
}

.history-card__date {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.history-card__players {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  text-align: right;
}

.history-card__stats {
  margin-top: var(--space-sm);
  overflow-x: auto;
}
