/**
 * CricScore - Live Cricket Scoring Platform
 * Copyright (c) 2024-2026 KraftedLogic. All rights reserved.
 * 
 * @file components.css - Component Styles (KL Brand Consistent)
 * @license Proprietary
 */

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg);
  font-family: var(--font-family);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Free Hit Banner */
.free-hit-banner {
  background: linear-gradient(135deg, #ff6b35 0%, #ff9500 100%);
  color: white;
  text-align: center;
  padding: var(--space-sm) var(--space-md);
  font-weight: bold;
  font-size: var(--font-size-lg);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
  animation: freeHitPulse 1s ease-in-out infinite alternate;
  text-transform: uppercase;
  letter-spacing: 2px;
}

@keyframes freeHitPulse {
  from { transform: scale(1); box-shadow: 0 0 10px rgba(255, 107, 53, 0.5); }
  to { transform: scale(1.02); box-shadow: 0 0 20px rgba(255, 107, 53, 0.8); }
}

/* Hat-trick Banner */
.hat-trick-banner {
  background: linear-gradient(135deg, #8b5cf6 0%, #a855f7 100%);
  color: white;
  text-align: center;
  padding: var(--space-sm) var(--space-md);
  font-weight: bold;
  font-size: var(--font-size-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
  animation: hatTrickPulse 0.8s ease-in-out infinite alternate;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Extras Modal Run Buttons */
.extras-run-buttons {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  justify-content: center;
}

.extras-run-buttons .run-btn {
  min-width: 50px;
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-size-sm);
}

#extras-runs-modal .form-label {
  display: block;
  margin-bottom: var(--space-sm);
  font-weight: 500;
  color: var(--text-secondary);
}

@keyframes hatTrickPulse {
  from { transform: scale(1); box-shadow: 0 0 10px rgba(139, 92, 246, 0.5); }
  to { transform: scale(1.02); box-shadow: 0 0 20px rgba(139, 92, 246, 0.8); }
}

/* Celebration Overlay */
.celebration-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  transition: opacity 0.3s ease;
  cursor: pointer;
  pointer-events: none;
}

.celebration-overlay.show {
  opacity: 1;
  pointer-events: auto;
}

.celebration-content {
  text-align: center;
  transform: scale(0.8);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.celebration-overlay.show .celebration-content {
  transform: scale(1);
}

.celebration-icon {
  font-size: 5rem;
  margin-bottom: var(--space-md);
  animation: celebrationPulse 0.6s ease-out;
}

.celebration-message {
  font-size: 3.5rem;
  font-weight: 900;
  color: var(--gold);
  text-shadow: 0 0 40px rgba(255, 215, 0, 0.6);
  animation: celebrationPulse 0.6s ease-out;
  letter-spacing: 0.1em;
}

.celebration-player {
  font-size: 2rem;
  color: white;
  margin-top: var(--space-md);
  font-weight: 600;
  animation: celebrationSlideUp 0.5s ease-out 0.2s both;
}

/* Confetti Container */
.confetti-container {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.confetti {
  position: absolute;
  width: 10px;
  height: 10px;
  top: -10px;
  border-radius: 2px;
  animation: confettiFall linear forwards;
}

@keyframes celebrationPulse {
  0% { transform: scale(0.5); opacity: 0; }
  50% { transform: scale(1.1); }
  100% { transform: scale(1); opacity: 1; }
}

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

@keyframes confettiFall {
  0% {
    transform: translateY(0) rotate(0deg);
    opacity: 1;
  }
  100% {
    transform: translateY(100vh) rotate(720deg);
    opacity: 0;
  }
}

/* Special celebration styles by type */
.celebration-overlay.hattrick .celebration-message {
  font-size: 4rem;
  background: linear-gradient(135deg, #ffd700, #ff6b35, #ffd700);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.celebration-overlay.century .celebration-message {
  background: linear-gradient(135deg, #ffd700, #ff6b35, #ffd700);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Quick celebrations - smaller and faster */
.celebration-overlay.four,
.celebration-overlay.six,
.celebration-overlay.wicket {
  background: rgba(0, 0, 0, 0.7);
}

.celebration-overlay.four .celebration-icon,
.celebration-overlay.six .celebration-icon,
.celebration-overlay.wicket .celebration-icon {
  font-size: 4rem;
}

.celebration-overlay.four .celebration-message,
.celebration-overlay.six .celebration-message,
.celebration-overlay.wicket .celebration-message {
  font-size: 2rem;
}

.celebration-overlay.six .celebration-message {
  color: #ffd700;
}

.celebration-overlay.four .celebration-message {
  color: #4ecdc4;
}

.celebration-overlay.wicket .celebration-message {
  color: #ff6b6b;
}

/* Scores Level celebration */
.celebration-overlay.scores_level {
  background: rgba(0, 0, 0, 0.85);
}

.celebration-overlay.scores_level .celebration-icon {
  font-size: 5rem;
}

.celebration-overlay.scores_level .celebration-message {
  font-size: 2.5rem;
  background: linear-gradient(135deg, #ffd700, #ff6b35, #ffd700);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: celebrationPulse 0.8s ease-out;
}

/* Match Complete celebration */
.celebration-overlay.match_complete {
  background: rgba(0, 0, 0, 0.9);
}

.celebration-overlay.match_complete .celebration-icon {
  font-size: 6rem;
}

.celebration-overlay.match_complete .celebration-message {
  font-size: 1.8rem;
  background: linear-gradient(135deg, #ffd700, #22c55e, #ffd700);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: celebrationPulse 1s ease-out;
  max-width: 90%;
  text-align: center;
}

.btn-icon {
  font-size: var(--font-size-lg);
}

.btn-primary {
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);
  color: var(--white);
}

.btn-primary:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(18, 182, 166, 0.4);
}

.btn-secondary {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
}

.btn-secondary:hover:not(:disabled) {
  background: var(--bg-card-hover);
  border-color: var(--teal);
}

.btn-ghost {
  background: transparent;
  color: var(--text-secondary);
}

.btn-ghost:hover:not(:disabled) {
  color: var(--text-primary);
  background: var(--bg-card);
}

.btn-success {
  background: linear-gradient(135deg, var(--success) 0%, var(--success-dark) 100%);
  color: var(--white);
}

.btn-success:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(34, 197, 94, 0.4);
}

.btn-warning {
  background: linear-gradient(135deg, var(--warning) 0%, var(--warning-dark) 100%);
  color: var(--white);
}

.btn-warning:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4);
}

.btn-danger {
  background: linear-gradient(135deg, var(--danger) 0%, var(--danger-dark) 100%);
  color: var(--white);
}

.btn-danger:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.btn-danger-ghost {
  background: transparent;
  color: var(--danger);
  border: 1px solid transparent;
}

.btn-danger-ghost:hover:not(:disabled) {
  border-color: var(--danger);
  background: rgba(239, 68, 68, 0.1);
}

.btn-large {
  padding: var(--space-md) var(--space-xl);
  font-size: var(--font-size-lg);
}

.btn-small {
  padding: var(--space-xs) var(--space-md);
  font-size: var(--font-size-sm);
}

.btn-icon-only {
  padding: var(--space-sm);
  background: transparent;
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
  font-size: var(--font-size-lg);
}

.btn-icon-only:hover {
  background: var(--bg-card);
  color: var(--text-primary);
}

/* ===== FORM ELEMENTS ===== */
.form-group {
  margin-bottom: var(--space-md);
}

.form-group label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
  margin-bottom: var(--space-xs);
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
}

.form-row-3 {
  grid-template-columns: repeat(3, 1fr);
}

.optional-label {
  font-weight: var(--font-weight-normal);
  color: var(--text-muted);
}

input[type="text"],
input[type="number"],
input[type="email"],
input[type="tel"],
input[type="password"],
select,
textarea {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  font-family: var(--font-family);
  font-size: var(--font-size-md);
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(18, 182, 166, 0.2);
}

input::placeholder,
textarea::placeholder {
  color: var(--text-muted);
}

select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

textarea {
  resize: vertical;
  min-height: 80px;
}

.hint {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: var(--space-xs);
}

/* Checkboxes & Radios */
.checkbox-group,
.radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.checkbox-label,
.radio-label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  font-size: var(--font-size-sm);
}

.checkbox-label input[type="checkbox"],
.radio-label input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--teal);
  cursor: pointer;
}

/* ===== CARDS ===== */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-color);
}

.card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

/* Match Cards */
.match-card {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: all var(--transition-fast);
  cursor: pointer;
}

.match-card:hover {
  border-color: var(--teal);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

/* TBD Match Cards (teams not yet determined) */
.match-card-tbd {
  opacity: 0.6;
  cursor: not-allowed;
}

.match-card-tbd:hover {
  border-color: var(--border-color);
  transform: none;
  box-shadow: none;
}

.match-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}

.match-number {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.match-teams {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.match-team-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.match-team-name {
  font-weight: var(--font-weight-semibold);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.team-color-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
}

.match-team-score {
  font-family: var(--font-mono);
  font-weight: var(--font-weight-bold);
}

.match-status {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

/* Team Cards */
.team-card {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
  transition: all var(--transition-fast);
  cursor: pointer;
}

.team-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.team-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.team-name {
  font-weight: var(--font-weight-semibold);
  flex: 1;
}

.team-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-xs);
  font-size: var(--font-size-sm);
}

.team-stat {
  display: flex;
  justify-content: space-between;
}

.team-stat-label {
  color: var(--text-muted);
}

.team-stat-value {
  font-weight: var(--font-weight-semibold);
}

/* Player Items */
.player-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-xs);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.player-item:hover {
  background: var(--bg-hover);
}

.player-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.player-item.disabled:hover {
  background: var(--bg-card);
}

.player-item .player-note {
  font-size: var(--font-size-xs);
  color: var(--warning);
  font-style: italic;
}

.player-item .player-stats {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  font-family: var(--font-mono, monospace);
}

.player-item .player-name {
  flex: 1;
  font-weight: var(--font-weight-medium);
}

.player-item .player-role {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  padding: var(--space-xs) var(--space-sm);
  background: var(--bg-hover);
  border-radius: var(--radius-sm);
}

.player-item.is-captain {
  border-left: 3px solid var(--gold, #ffd700);
  background: rgba(255, 215, 0, 0.05);
}

.player-item .captain-badge {
  font-size: 0.9rem;
}

/* ===== BADGES ===== */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
}

.badge-success {
  background: rgba(34, 197, 94, 0.2);
  color: var(--success);
}

.badge-warning {
  background: rgba(245, 158, 11, 0.2);
  color: var(--warning);
}

.badge-danger {
  background: rgba(239, 68, 68, 0.2);
  color: var(--danger);
}

.badge-info {
  background: rgba(59, 130, 246, 0.2);
  color: var(--info);
}

.badge-neutral {
  background: var(--bg-card);
  color: var(--text-secondary);
}

.badge-teal {
  background: var(--teal);
  color: var(--white);
}

/* Live Indicator */
.live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(239, 68, 68, 0.2);
  color: #f87171;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.live-dot {
  width: 8px;
  height: 8px;
  background: #ef4444;
  border-radius: 50%;
  animation: livePulse 1.5s ease-in-out infinite;
}

@keyframes livePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.2); }
}

/* Viewer Badge */
.viewer-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(59, 130, 246, 0.2);
  color: #60a5fa;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: var(--font-weight-medium);
}

/* ===== MODALS ===== */
.modal-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: var(--z-modal-backdrop);
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}

.modal-overlay.active {
  display: flex;
}

.modal-overlay.modal-top {
  z-index: calc(var(--z-modal) + 100);
}

.modal {
  background: var(--navy-dark);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-xl);
  animation: modalSlideIn 0.3s ease;
}

@keyframes modalSlideIn {
  from { opacity: 0; transform: translateY(-20px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.modal-large {
  max-width: 700px;
}

.modal-sm {
  max-width: 400px;
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-color);
}

.modal-header h3 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.modal-close {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: var(--font-size-2xl);
  cursor: pointer;
  padding: 0;
  line-height: 1;
  transition: color var(--transition-fast);
}

.modal-close:hover {
  color: var(--text-primary);
}

.modal-body {
  padding: var(--space-lg);
  overflow-y: auto;
  flex: 1;
}

/* Toss Captains Display */
.toss-captains {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}

.toss-captain-card {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

.toss-captain-card .team-name {
  font-weight: 600;
  font-size: var(--font-size-sm);
}

.toss-captain-card .captain-name {
  font-size: var(--font-size-xs);
  color: var(--gold, #ffd700);
}

.toss-captain-card .no-captain {
  color: var(--text-muted);
}

.vs-divider {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  font-weight: 600;
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--border-color);
}

.modal-lg {
  max-width: 600px;
  width: 95%;
}

/* ===== PLAYING XI SELECTION ===== */
.playing-xi-accordions {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.playing-xi-accordion {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.playing-xi-accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md);
  background: var(--bg-secondary);
  cursor: pointer;
  user-select: none;
  transition: background var(--transition-fast);
}

.playing-xi-accordion-header:hover {
  background: var(--bg-elevated);
}

.accordion-team-info {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.accordion-team-info .team-color-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

.accordion-team-info h4 {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin: 0;
}

.playing-xi-badge {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  background: var(--bg-primary);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
}

.accordion-arrow {
  font-size: 0.8rem;
  color: var(--text-muted);
  transition: transform var(--transition-fast);
}

.playing-xi-accordion-content.expanded + .playing-xi-accordion-header .accordion-arrow,
.playing-xi-accordion.expanded .accordion-arrow {
  transform: rotate(180deg);
}

.playing-xi-accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.playing-xi-accordion-content.expanded {
  max-height: 400px;
  overflow-y: auto;
  padding: var(--space-sm);
}

.playing-xi-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  max-height: 300px;
  overflow-y: auto;
}

.playing-xi-player {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
}

.playing-xi-player:hover {
  background: var(--bg-elevated);
}

.playing-xi-player.selected {
  background: var(--primary);
  color: white;
}

.playing-xi-player.selected .player-role {
  color: rgba(255, 255, 255, 0.8);
}

.playing-xi-player.substituted {
  background: var(--bg-secondary);
  opacity: 0.5;
  text-decoration: line-through;
  cursor: not-allowed;
}

.playing-xi-player .player-select {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex: 1;
  cursor: pointer;
}

.playing-xi-player input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--primary);
}

/* Separate role column in Playing XI */
.player-role-col {
  min-width: 90px;
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  text-align: center;
  padding: 4px 8px;
  background: var(--bg-primary);
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.playing-xi-player.selected .player-role-col {
  background: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.9);
}

/* Role selection buttons container in Playing XI */
.playing-xi-roles {
  display: flex;
  gap: 4px;
}

/* Captain selection button in Playing XI */
.captain-select-btn {
  background: var(--bg-elevated);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  font-size: 14px;
  cursor: pointer;
  opacity: 0.4;
  transition: all var(--transition-fast);
}

.captain-select-btn:hover {
  opacity: 0.8;
  background: var(--bg-secondary);
}

.captain-select-btn.active {
  opacity: 1;
  background: var(--warning);
  border-color: var(--warning);
}

.captain-select-btn.squad-captain:not(.active) {
  opacity: 0.6;
  border-color: var(--warning);
}

.playing-xi-player.selected .captain-select-btn {
  background: rgba(255,255,255,0.2);
  border-color: rgba(255,255,255,0.3);
}

.playing-xi-player.selected .captain-select-btn.active {
  background: var(--warning);
  border-color: var(--warning);
}

/* WK selection button in Playing XI */
.wk-select-btn {
  background: var(--bg-elevated);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  font-size: 14px;
  cursor: pointer;
  opacity: 0.4;
  transition: all var(--transition-fast);
}

.wk-select-btn:hover {
  opacity: 0.8;
  background: var(--bg-secondary);
}

.wk-select-btn.active {
  opacity: 1;
  background: var(--success);
  border-color: var(--success);
}

.wk-select-btn.squad-wk:not(.active) {
  opacity: 0.6;
  border-color: var(--warning);
}

.playing-xi-player.selected .wk-select-btn {
  background: rgba(255,255,255,0.2);
  border-color: rgba(255,255,255,0.3);
}

.playing-xi-player.selected .wk-select-btn.active {
  background: var(--success);
  border-color: var(--success);
}

.playing-xi-count {
  margin-top: var(--space-sm);
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  text-align: center;
}

/* ===== IMPACT PLAYER ===== */
.impact-player-section {
  margin-bottom: var(--space-lg);
}

.impact-player-section h4 {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-sm);
  text-transform: uppercase;
}

.impact-player-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.impact-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  background: var(--info);
  color: white;
  margin-left: var(--space-xs);
}

.bench-badge {
  background: var(--text-muted);
}

/* Panel header actions */
.panel-header-actions {
  display: flex;
  gap: var(--space-xs);
}

.btn-info {
  background: var(--info);
  color: white;
}

.btn-info:hover {
  background: color-mix(in srgb, var(--info), black 10%);
}

/* ===== SPECTATOR BANNER ===== */
.spectator-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(139, 92, 246, 0.2));
  border: 1px solid rgba(59, 130, 246, 0.3);
  padding: 12px 20px;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
  color: #93c5fd;
  font-weight: var(--font-weight-semibold);
}

.spectator-icon {
  font-size: 1.25rem;
}

.spectator-room-code {
  background: rgba(0, 0, 0, 0.2);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 0.85rem;
}

/* ===== SHARE SECTION ===== */
.share-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.share-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.share-item label {
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.share-link-row {
  display: flex;
  gap: 8px;
}

.share-link-input {
  flex: 1;
  padding: 10px 12px;
  font-size: 0.85rem;
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-family: var(--font-mono);
}

.share-link-input:focus {
  outline: none;
  border-color: var(--teal);
}

/* ===== KL BRAND BADGE ===== */
.kl-brand-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.15);
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.kl-brand-badge:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: var(--teal);
  transform: scale(1.05);
}

.kl-brand-badge img {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

/* ===== EMPTY STATE ===== */
.empty-state {
  text-align: center;
  padding: var(--space-2xl);
  color: var(--text-muted);
}

.empty-state-icon {
  font-size: var(--font-size-4xl);
  margin-bottom: var(--space-md);
}

/* ===== FILE UPLOAD ===== */
.file-upload-area {
  position: relative;
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  text-align: center;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.file-upload-area:hover,
.file-upload-area.drag-over {
  border-color: var(--teal);
  background: rgba(18, 182, 166, 0.1);
}

.file-upload-area input[type="file"] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.file-upload-area label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  color: var(--text-secondary);
}

.upload-icon {
  font-size: var(--font-size-3xl);
}

/* ===== TOAST NOTIFICATIONS ===== */
.toast-container {
  position: fixed;
  top: var(--space-lg);
  right: var(--space-lg);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.toast {
  background: var(--navy-dark);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-lg);
  animation: toastSlideIn 0.3s ease;
  display: flex;
  align-items: center;
  gap: var(--space-md);
  min-width: 280px;
}

@keyframes toastSlideIn {
  from { opacity: 0; transform: translateX(100%); }
  to { opacity: 1; transform: translateX(0); }
}

.toast.success { border-left: 3px solid var(--success); }
.toast.error { border-left: 3px solid var(--danger); }
.toast.warning { border-left: 3px solid var(--warning); }
.toast.info { border-left: 3px solid var(--info); }

.toast-message {
  flex: 1;
  font-size: var(--font-size-sm);
}

.toast-close {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: var(--font-size-lg);
}

/* ===== TABS ===== */
.tabs {
  display: flex;
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--space-lg);
}

.tab {
  padding: var(--space-md) var(--space-lg);
  background: none;
  border: none;
  color: var(--text-secondary);
  font-family: var(--font-family);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  position: relative;
  transition: color var(--transition-fast);
}

.tab:hover {
  color: var(--text-primary);
}

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

.tab.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--teal);
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

/* ===== ANIMATIONS ===== */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

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

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.animate-pulse {
  animation: pulse 2s infinite;
}

.animate-slide-in {
  animation: slideIn 0.3s ease;
}

.animate-fade-in {
  animation: fadeIn 0.3s ease;
}

/* ===== UTILITY CLASSES ===== */
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-muted { color: var(--text-muted); }
.text-success { color: var(--success); }
.text-danger { color: var(--danger); }
.text-warning { color: var(--warning); }

.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }

.hidden { display: none !important; }
.host-only { }
.spectator-only { display: none; }
body.spectator-mode .host-only { display: none !important; }
body.spectator-mode .spectator-only { display: block; }

/* ===== BALL-BY-BALL COMMENTARY ===== */
.commentary-panel {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
  margin-top: var(--space-lg);
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.commentary-panel.collapsed .commentary-log {
  display: none;
}

.commentary-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md) var(--space-lg);
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-color);
}

.commentary-header h4 {
  margin: 0;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.commentary-toggle-btn {
  padding: var(--space-xs) var(--space-md);
  font-size: var(--font-size-sm);
  background: var(--bg-card);
  color: var(--text-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.commentary-toggle-btn:hover {
  background: var(--bg-elevated);
  color: var(--text-primary);
}

.commentary-log {
  max-height: 250px;
  overflow-y: auto;
  padding: var(--space-md);
  transition: max-height 0.3s ease;
}

.commentary-panel.expanded .commentary-log {
  max-height: none;
}

.commentary-expand {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-elevated);
  border-top: 1px solid var(--border-color);
  cursor: pointer;
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  transition: background var(--transition-fast), color var(--transition-fast);
}

.commentary-expand:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

/* Innings Accordion */
.innings-accordion {
  border-bottom: 1px solid var(--border-color);
}

.innings-accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-elevated);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  transition: background var(--transition-fast);
}

.innings-accordion-header:hover {
  background: var(--bg-secondary);
}

.innings-accordion .accordion-arrow {
  transition: transform var(--transition-fast);
}

.innings-accordion.collapsed .accordion-arrow {
  transform: rotate(-90deg);
}

.innings-accordion.collapsed .innings-accordion-body {
  display: none;
}

.innings-accordion-body {
  max-height: 200px;
  overflow-y: auto;
  background: var(--bg-secondary);
}

.current-innings-label {
  padding: var(--space-xs) var(--space-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-color);
}

.commentary-over-section {
  margin-bottom: var(--space-lg);
}

.commentary-over-section:last-child {
  margin-bottom: 0;
}

.commentary-over-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
}

.commentary-over-header .over-label {
  font-weight: var(--font-weight-bold);
  color: var(--white);
  font-size: var(--font-size-sm);
  text-transform: uppercase;
}

.commentary-over-header .over-runs {
  color: rgba(255, 255, 255, 0.8);
  font-size: var(--font-size-sm);
}

.commentary-over-header .over-score {
  margin-left: auto;
  font-weight: var(--font-weight-bold);
  color: var(--white);
  font-size: var(--font-size-md);
}

.commentary-entry {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border-subtle);
  transition: background 0.2s ease;
}

.commentary-entry:hover {
  background: var(--bg-elevated);
}

.commentary-entry:last-child {
  border-bottom: none;
}

.commentary-over {
  font-weight: var(--font-weight-semibold);
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  min-width: 32px;
}

.commentary-ball-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
}

.commentary-ball-indicator.dot {
  background: var(--bg-elevated);
  color: var(--text-muted);
}

.commentary-ball-indicator.runs {
  background: var(--teal-subtle);
  color: var(--teal);
}

.commentary-ball-indicator.four {
  background: var(--success-subtle);
  color: var(--success);
}

.commentary-ball-indicator.six {
  background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
  color: var(--dark);
}

.commentary-ball-indicator.wicket {
  background: var(--danger);
  color: var(--white);
}

.commentary-ball-indicator.wide,
.commentary-ball-indicator.noball {
  background: var(--warning-subtle);
  color: var(--warning);
}

.commentary-ball-indicator.bye {
  background: var(--bg-elevated);
  color: var(--text-secondary);
}

.commentary-description {
  flex: 1;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.commentary-entry.wicket .commentary-description {
  color: var(--danger);
  font-weight: var(--font-weight-semibold);
}

.commentary-entry.four .commentary-description,
.commentary-entry.six .commentary-description {
  color: var(--text-primary);
  font-weight: var(--font-weight-semibold);
}

/* ===== SCORECARD TABS ===== */
.scorecard-tabs {
  display: flex;
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-elevated);
}

.scorecard-tab {
  flex: 1;
  padding: var(--space-md);
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all 0.2s ease;
  border-bottom: 2px solid transparent;
}

.scorecard-tab:hover {
  color: var(--text-primary);
  background: var(--bg-card-hover);
}

.scorecard-tab.active {
  color: var(--teal);
  border-bottom-color: var(--teal);
  background: var(--bg-card);
}

.scorecard-tab-content {
  display: none;
}

.scorecard-tab-content.active {
  display: block;
}

/* Scorecard Innings Accordion */
.scorecard-innings-section {
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
  overflow: hidden;
}

.scorecard-innings-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);
  color: var(--white);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  user-select: none;
}

.scorecard-innings-header:hover {
  filter: brightness(1.1);
}

.scorecard-innings-header .accordion-arrow {
  transition: transform 0.3s ease;
}

.scorecard-innings-section.collapsed .scorecard-innings-header .accordion-arrow {
  transform: rotate(-90deg);
}

.scorecard-innings-body {
  padding: var(--space-md);
  background: var(--bg-card);
  max-height: 500px;
  overflow-y: auto;
}

.scorecard-innings-section.collapsed .scorecard-innings-body {
  display: none;
}

.scorecard-subsection {
  margin: var(--space-md) 0 var(--space-sm);
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}

.scorecard-subsection:first-child {
  margin-top: 0;
}

.scorecard-extras {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

/* ===== STATS SECTION ===== */
#match-stats-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.stats-section {
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.stats-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);
  color: var(--white);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  user-select: none;
}

.stats-section-header:hover {
  filter: brightness(1.1);
}

.stats-section-header .accordion-arrow {
  transition: transform 0.3s ease;
}

.stats-section.collapsed .stats-section-header .accordion-arrow {
  transform: rotate(-90deg);
}

.stats-section-body {
  padding: var(--space-md);
  background: var(--bg-card);
  max-height: 350px;
  overflow-y: auto;
}

.stats-section.collapsed .stats-section-body {
  display: none;
}

/* Stats Table */
.stats-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

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

.stats-table th {
  background: var(--bg-elevated);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  font-size: var(--font-size-xs);
  text-transform: uppercase;
}

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

.stats-table .rank {
  width: 30px;
  text-align: center;
  font-weight: var(--font-weight-bold);
  color: var(--text-muted);
}

.stats-table .rank-1 { color: #ffd700; }
.stats-table .rank-2 { color: #c0c0c0; }
.stats-table .rank-3 { color: #cd7f32; }

.stats-table .player-name {
  font-weight: var(--font-weight-medium);
}

.stats-table .team-name {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.stats-table .stat-highlight {
  font-weight: var(--font-weight-bold);
  color: var(--teal);
}

.stats-table th.sortable {
  cursor: pointer;
  user-select: none;
  transition: color 0.2s ease;
}

.stats-table th.sortable:hover {
  color: var(--teal);
}

.stats-table th.sortable.active {
  color: var(--teal);
  font-weight: var(--font-weight-bold);
}

/* Full Commentary Section */
#full-commentary-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.full-innings-section {
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.full-innings-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);
  color: var(--white);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  user-select: none;
}

.full-innings-header:hover {
  filter: brightness(1.1);
}

.full-innings-header .accordion-arrow {
  transition: transform 0.3s ease;
}

.full-innings-section.collapsed .full-innings-header .accordion-arrow {
  transform: rotate(-90deg);
}

.full-innings-body {
  max-height: 400px;
  overflow-y: auto;
  background: var(--bg-card);
}

.full-innings-section.collapsed .full-innings-body {
  display: none;
}

.full-innings-body .commentary-over-section {
  border-bottom: 1px solid var(--border-color);
}

.full-innings-body .commentary-over-section:last-child {
  border-bottom: none;
}

/* ===== SCORER LINKS SECTION ===== */
.scorer-links-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-md);
  max-height: 250px;
  overflow-y: auto;
}

.scorer-match-item {
  background: var(--bg-elevated);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}

.scorer-match-info {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-sm);
}

.scorer-match-name {
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  flex: 1;
}

.scorer-match-actions {
  display: flex;
  gap: var(--space-sm);
}

.scorer-link-display {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.scorer-link-display input {
  flex: 1;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-input);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--font-size-sm);
}

/* Scorer mode indicator */
.scorer-mode-banner {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  background: linear-gradient(135deg, var(--warning) 0%, var(--warning-dark) 100%);
  color: var(--dark);
  padding: var(--space-sm) var(--space-lg);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}

.scorer-mode-banner .scorer-icon {
  font-size: var(--font-size-md);
}

/* ===== RESULTS SCREEN ===== */
.results-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-xl);
}

.results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-xl);
  gap: var(--space-lg);
}

.results-header h2 {
  margin: 0;
  font-size: var(--font-size-2xl);
}

.results-header p {
  margin: var(--space-xs) 0 0;
  color: var(--text-muted);
}

.results-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.summary-stat {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
}

.summary-stat .stat-value {
  display: block;
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--teal);
  margin-bottom: var(--space-xs);
}

.summary-stat .stat-label {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.results-tabs {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  border-bottom: 1px solid var(--border-color);
  padding-bottom: var(--space-sm);
}

.results-tab {
  padding: var(--space-sm) var(--space-lg);
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.results-tab:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.results-tab.active {
  background: var(--teal);
  color: var(--white);
}

.results-tab-content {
  display: none;
}

.results-tab-content.active {
  display: block;
}

.results-tab-content h3 {
  margin-bottom: var(--space-lg);
  font-size: var(--font-size-xl);
  color: var(--text-primary);
}

/* Stats Table */
.stats-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.stats-table th,
.stats-table td {
  padding: var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--border-color);
}

.stats-table th {
  background: var(--bg-elevated);
  font-weight: var(--font-weight-semibold);
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.stats-table td {
  font-size: var(--font-size-md);
}

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

.stats-table tr:hover td {
  background: var(--bg-hover);
}

.stats-table .rank {
  width: 40px;
  text-align: center;
  font-weight: var(--font-weight-bold);
  color: var(--text-muted);
}

.stats-table .rank-1 { color: #fbbf24; }
.stats-table .rank-2 { color: #94a3b8; }
.stats-table .rank-3 { color: #cd7f32; }

.stats-table .player-info {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.stats-table .player-name {
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.stats-table .team-name {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.stats-table .text-right {
  text-align: right;
}

.stats-table .highlight {
  color: var(--teal);
  font-weight: var(--font-weight-bold);
}

/* Records Grid */
.records-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-xl);
}

.record-section {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}

.record-section h4 {
  margin: 0 0 var(--space-md);
  font-size: var(--font-size-lg);
  color: var(--text-primary);
}

.record-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--border-subtle);
}

.record-item:last-child {
  border-bottom: none;
}

.record-item .player-info {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.record-item .rank {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--bg-elevated);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--text-muted);
}

.record-item .rank-1 { background: #fbbf24; color: var(--dark); }
.record-item .rank-2 { background: #94a3b8; color: var(--dark); }
.record-item .rank-3 { background: #cd7f32; color: var(--dark); }

.record-item .stat-value {
  font-weight: var(--font-weight-bold);
  color: var(--teal);
}

/* Responsive */
@media (max-width: 768px) {
  .results-summary {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .records-grid {
    grid-template-columns: 1fr;
  }
  
  .results-tabs {
    flex-wrap: wrap;
  }
  
  .results-header {
    flex-direction: column;
    text-align: center;
  }
}

/* ===== SETTINGS ===== */
.settings-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.setting-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) 0;
  cursor: pointer;
}

.setting-item span {
  color: var(--text-primary);
}

.setting-item input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--teal);
  cursor: pointer;
}

.settings-notice {
  background: var(--warning-subtle, rgba(245, 158, 11, 0.1));
  border: 1px solid var(--warning);
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-lg);
}

.settings-notice p {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--warning);
}

.setting-item input:disabled,
.form-group select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ===== QUICK MATCH ACCORDION ===== */
.modal-fullheight {
  max-width: 500px;
  height: 90vh;
  max-height: 700px;
  display: flex;
  flex-direction: column;
}

.modal-fullheight .modal-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-md);
}

.qm-accordion-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.qm-accordion-section {
  background: var(--bg-elevated, rgba(255,255,255,0.03));
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.qm-accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: rgba(0,0,0,0.2);
  cursor: pointer;
  user-select: none;
  transition: background 0.2s;
}

.qm-accordion-header:hover {
  background: rgba(0,0,0,0.3);
}

.qm-accordion-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-weight: 600;
  color: var(--teal);
}

.qm-accordion-arrow {
  font-size: 0.8rem;
  transition: transform 0.2s;
}

.qm-accordion-section.collapsed .qm-accordion-arrow {
  transform: rotate(-90deg);
}

.qm-player-count {
  font-weight: 400;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

.btn-icon-small {
  background: rgba(255,255,255,0.1);
  border: none;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 1rem;
  transition: background 0.2s;
}

.btn-icon-small:hover {
  background: rgba(255,255,255,0.2);
}

.qm-accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
  padding: 0 var(--space-md);
}

.qm-accordion-content.expanded {
  max-height: 350px;
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
}

.qm-players-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
  min-height: 40px;
  max-height: 220px;
  overflow-y: auto;
  flex-shrink: 1;
}

.qm-add-player-row {
  flex-shrink: 0;
  margin-top: auto;
}

.qm-player-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--teal);
}

.qm-player-item .player-name {
  font-size: var(--font-size-sm);
  font-weight: 500;
}

.qm-player-item .player-role {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-left: var(--space-sm);
}

.qm-player-item .remove-btn {
  background: none;
  border: none;
  color: var(--danger);
  cursor: pointer;
  padding: var(--space-xs);
  font-size: 1rem;
  opacity: 0.7;
  transition: opacity 0.2s;
}

.qm-player-item .remove-btn:hover {
  opacity: 1;
}

.qm-players-grid .qm-empty-state {
  color: var(--text-muted);
  font-style: italic;
  font-size: var(--font-size-sm);
  text-align: center;
  padding: var(--space-sm) 0;
  margin: 0;
}

.qm-player-item .player-info {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  flex: 1;
}

.qm-player-item.is-captain {
  border-left-color: var(--gold, #ffd700);
  background: rgba(255, 215, 0, 0.1);
}

/* Captain & WK Badges */
.captain-badge,
.wk-badge {
  font-size: 0.9rem;
  opacity: 0.3;
  transition: opacity 0.2s, transform 0.2s;
  cursor: pointer;
}

.captain-badge:hover,
.wk-badge:hover {
  opacity: 0.7;
  transform: scale(1.1);
}

.captain-badge.active,
.wk-badge.active {
  opacity: 1;
}

.qm-player-item.is-wk {
  border-left-color: var(--teal);
}

.qm-player-item.is-captain.is-wk {
  border-left: 3px solid;
  border-image: linear-gradient(to bottom, var(--gold, #ffd700), var(--teal)) 1;
}

.qm-add-player-row {
  display: flex;
  gap: var(--space-sm);
}

.qm-add-player-row input {
  flex: 1;
  padding: var(--space-sm) var(--space-md);
}

.qm-add-player-row .btn-small {
  padding: var(--space-sm) var(--space-md);
  font-size: 1.2rem;
  font-weight: 700;
}

.qm-empty-state {
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  text-align: center;
  padding: var(--space-lg);
  font-style: italic;
}

/* Clickable card */
.clickable {
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}

.clickable:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Scorecard retired hurt */
.player-retired td:first-child {
  color: var(--warning);
}

.retired-hurt {
  color: var(--warning) !important;
}

/* Commentary retired hurt entry */
.commentary-entry.retired_hurt {
  background: rgba(251, 191, 36, 0.1);
  border-left: 3px solid var(--warning);
}

/* Commentary milestone entry */
.commentary-entry.milestone {
  background: linear-gradient(90deg, rgba(139, 92, 246, 0.15), transparent);
  border-left: 3px solid var(--primary);
  font-weight: var(--font-weight-semibold);
}

.commentary-entry.milestone .commentary-text {
  color: var(--primary);
}

/* ===== Tournament Stages ===== */
.stages-preview {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  background: var(--bg-input);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}

.stage-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-elevated);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--teal);
}

.stage-item .stage-number {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--teal);
  color: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  flex-shrink: 0;
}

.stage-item .stage-info {
  flex: 1;
}

.stage-item .stage-name {
  font-weight: var(--font-weight-semibold);
}

.stage-item .stage-type {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.stage-item .stage-actions {
  display: flex;
  gap: var(--space-xs);
}

.stage-item.completed {
  border-left-color: var(--success);
  opacity: 0.8;
}

.stage-item.in-progress {
  border-left-color: var(--warning);
}

/* Matches grouped by stage */
.stage-section {
  margin-bottom: var(--space-xl);
  grid-column: 1 / -1; /* Span all columns in grid layout */
}

.stage-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  background: linear-gradient(90deg, rgba(18, 182, 166, 0.2), transparent);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
}

.stage-header h4 {
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.stage-header .stage-badge {
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  background: var(--bg-elevated);
}

.stage-header .stage-badge.completed {
  background: var(--success);
  color: white;
}

.stage-header .stage-badge.in-progress {
  background: var(--warning);
  color: var(--bg-primary);
}

/* Match card with schedule info */
.match-card .match-schedule {
  display: flex;
  gap: var(--space-md);
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: var(--space-xs);
}

.match-card .match-schedule .schedule-date,
.match-card .match-schedule .schedule-venue {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Edit match button on cards */
.match-card {
  position: relative;
}


.match-card.tbd {
  opacity: 0.6;
  cursor: default;
}

.match-card.tbd:hover {
  transform: none;
  border-color: var(--border-color);
}

/* Compact match card layout */
.match-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-sm);
}

.match-card .match-number {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  font-weight: var(--font-weight-medium);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.match-card .edit-match-btn {
  background: none;
  border: none;
  padding: 0;
  font-size: 12px;
  cursor: pointer;
  opacity: 0.5;
  transition: opacity 0.2s;
}

.match-card .edit-match-btn:hover {
  opacity: 1;
}

.match-status-badge {
  font-size: 10px;
  font-weight: var(--font-weight-bold);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  background: var(--bg-elevated);
  color: var(--text-muted);
  letter-spacing: 0.5px;
}

.match-status-badge.completed {
  background: var(--success);
  color: white;
}

.match-status-badge.in_progress {
  background: var(--warning);
  color: var(--bg-primary);
}

.match-teams-compact {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.match-teams-compact .team-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.match-teams-compact .team-color-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.match-teams-compact .team-name {
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
}

/* Matches utility bar */
.matches-utility-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-md);
  background: var(--bg-elevated);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  grid-column: 1 / -1; /* Span all columns in grid layout */
}

.matches-utility-bar.warning {
  background: rgba(var(--warning-rgb), 0.1);
  border-color: var(--warning);
}

.matches-utility-bar .warning-text {
  color: var(--warning);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.matches-utility-bar .info-text {
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

.btn-warning {
  background: var(--warning);
  color: var(--bg-primary);
  border: none;
}

.btn-warning:hover {
  background: var(--warning);
  filter: brightness(1.1);
}

/* Tournament Settings Tab */
.settings-section {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}

.settings-section h4 {
  margin: 0 0 var(--space-md) 0;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--border-color);
  color: var(--teal);
  font-size: var(--font-size-md);
}

.settings-section .form-group {
  margin-bottom: var(--space-md);
}

.settings-section .form-group:last-child {
  margin-bottom: 0;
}

.checkbox-label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--teal);
}

/* Qualify teams list */
.qualify-teams-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.qualify-team-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  background: var(--bg-input);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.2s;
}

.qualify-team-item:hover {
  background: var(--bg-elevated);
}

.qualify-team-item.selected {
  background: rgba(18, 182, 166, 0.15);
  border: 1px solid var(--teal);
}

.qualify-team-item .team-rank {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bg-elevated);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
}

.qualify-team-item.selected .team-rank {
  background: var(--teal);
  color: var(--bg-primary);
}

.qualify-team-item .team-info {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.qualify-team-item .team-stats {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

/* Add stage button */
.add-stage-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: 100%;
  padding: var(--space-sm);
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.2s;
}

.add-stage-btn:hover {
  border-color: var(--teal);
  color: var(--teal);
}
