/* ============================================================
   ABRAJ RUNNERS - theme-sports.css
   Sports / Athletic Theme  →  body.theme-sports
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Roboto+Condensed:ital,wght@0,400;0,700;1,400&display=swap');

/* ── Root palette vars for sports theme ──────────────────── */
body.theme-sports {
  --sports-bg:        #0a0a1a;
  --sports-surface:   #111127;
  --sports-card:      #1a1a2e;
  --sports-card-2:    #16213e;
  --sports-neon:      #00ff88;
  --sports-cyan:      #00d4ff;
  --sports-orange:    #ff6b35;
  --sports-red:       #ff2d55;
  --sports-text:      #e2e8f0;
  --sports-text-dim:  #8892a4;
  --sports-border:    rgba(0,255,136,.25);

  font-family: 'Roboto Condensed', sans-serif;
  background-color: var(--sports-bg);
  color: var(--sports-text);
  min-height: 100vh;
}

/* ── Grid dot pattern + stadium spotlight ─────────────────── */
body.theme-sports::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(0,212,255,.1) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 50% 110%, rgba(0,255,136,.08) 0%, transparent 60%),
    linear-gradient(rgba(0,255,136,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,136,.04) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 40px 40px, 40px 40px;
}

body.theme-sports > * { position: relative; z-index: 1; }

/* ── Header ───────────────────────────────────────────────── */
body.theme-sports .header {
  background: rgba(10, 10, 26, .9);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--sports-border);
  box-shadow: 0 0 40px rgba(0,255,136,.08);
}

body.theme-sports .header .logo {
  font-family: 'Oswald', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--sports-neon);
  text-shadow:
    0 0  8px rgba(0,255,136,.6),
    0 0 20px rgba(0,255,136,.3);
}

/* ── Nav ──────────────────────────────────────────────────── */
body.theme-sports .nav a,
body.theme-sports .nav-link {
  background: transparent;
  color: var(--sports-text-dim);
  border: 1px solid rgba(0,255,136,.2);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-family: 'Oswald', sans-serif;
  font-size: .82rem;
}

body.theme-sports .nav a:hover,
body.theme-sports .nav-link:hover {
  color: var(--sports-neon);
  border-color: var(--sports-neon);
  background: rgba(0,255,136,.07);
  box-shadow: 0 0 12px rgba(0,255,136,.2);
}

/* ── Stats Bar ────────────────────────────────────────────── */
body.theme-sports .stats-bar {
  background: var(--sports-card);
  border: 1px solid var(--sports-border);
  box-shadow:
    0 0 24px rgba(0,255,136,.08),
    inset 0 1px 0 rgba(0,255,136,.12);
  position: relative;
  overflow: hidden;
}

body.theme-sports .stats-bar::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--sports-neon), var(--sports-cyan), var(--sports-neon), transparent);
}

body.theme-sports .stat-value {
  font-family: 'Oswald', sans-serif;
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--sports-neon);
  text-shadow:
    0 0 10px rgba(0,255,136,.7),
    0 0 30px rgba(0,255,136,.3);
  font-variant-numeric: tabular-nums;
  letter-spacing: .05em;
}

body.theme-sports .stat-label {
  font-family: 'Roboto Condensed', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--sports-text-dim);
  font-size: .75rem;
}

/* ── Runner Grid / Cards ──────────────────────────────────── */
body.theme-sports .runner-card {
  background: var(--sports-card);
  border: 1px solid var(--sports-border);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
  position: relative;
  overflow: hidden;
}

/* Top accent bar */
body.theme-sports .runner-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--sports-neon), var(--sports-cyan));
  opacity: .7;
  transition: opacity var(--transition-normal);
}

/* Neon corner glow */
body.theme-sports .runner-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-md);
  box-shadow: inset 0 0 0 1px rgba(0,255,136,.12);
  transition: box-shadow var(--transition-normal);
  pointer-events: none;
}

body.theme-sports .runner-card:hover {
  transform: translateY(-6px);
  border-color: rgba(0,255,136,.6);
  box-shadow:
    0 0 20px rgba(0,255,136,.25),
    0 0 40px rgba(0,255,136,.12),
    0 8px 30px rgba(0,0,0,.5);
}

body.theme-sports .runner-card:hover::before { opacity: 1; }

body.theme-sports .runner-card:hover::after {
  box-shadow: inset 0 0 0 1px rgba(0,255,136,.4);
}

/* Avatar */
body.theme-sports .runner-card .avatar {
  border-color: var(--sports-neon);
  box-shadow:
    0 0  8px rgba(0,255,136,.5),
    0 0 20px rgba(0,255,136,.25),
    0 0 40px rgba(0,255,136,.12);
}

/* Name */
body.theme-sports .runner-card .name {
  font-family: 'Oswald', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #fff;
}

/* KM total */
body.theme-sports .runner-card .km-total {
  font-family: 'Roboto Condensed', sans-serif;
  color: var(--sports-cyan);
  font-weight: 700;
  font-size: .92rem;
  letter-spacing: .04em;
}

/* Streak */
body.theme-sports .runner-card .streak {
  background: rgba(255,107,53,.12);
  border: 1px solid rgba(255,107,53,.35);
  border-radius: 4px;
  padding: 3px 10px;
  font-family: 'Oswald', sans-serif;
  color: var(--sports-orange);
  letter-spacing: .06em;
}

body.theme-sports .streak-fire {
  animation: neonFirePulse .7s ease-in-out infinite alternate;
  filter: drop-shadow(0 0 5px rgba(255,107,53,.9));
}

@keyframes neonFirePulse {
  from { filter: drop-shadow(0 0 4px rgba(255,107,53,.7));  opacity: .85; }
  to   { filter: drop-shadow(0 0 10px rgba(255,45,85,.9));  opacity: 1;   }
}

/* Medal badges */
body.theme-sports .medal-bronze {
  background: linear-gradient(135deg, #CD7F32, #A0522D);
  box-shadow: 0 0 8px rgba(205,127,50,.5);
}

body.theme-sports .medal-silver {
  background: linear-gradient(135deg, #D8D8D8, #A8A8A8);
  box-shadow: 0 0 8px rgba(192,192,192,.6);
  color: #1a1a2e;
}

body.theme-sports .medal-gold {
  background: linear-gradient(135deg, #FFE066, #FFD700, #F59E0B);
  box-shadow:
    0 0 12px rgba(255,215,0,.7),
    0 0 24px rgba(255,215,0,.3);
  color: #1a1a2e;
  animation: goldGlow 2s ease-in-out infinite;
}

@keyframes goldGlow {
  0%, 100% { box-shadow: 0 0 12px rgba(255,215,0,.7), 0 0 24px rgba(255,215,0,.3); }
  50%       { box-shadow: 0 0 20px rgba(255,215,0,1.0), 0 0 40px rgba(255,215,0,.5); }
}

body.theme-sports .medal-platinum {
  background: linear-gradient(135deg, #f0f0ef, #c8c8c6, #E5E4E2);
  box-shadow: 0 0 12px rgba(229,228,226,.5);
  color: #1a1a2e;
}

body.theme-sports .medal-diamond {
  background: linear-gradient(135deg, #B9F2FF, #7dd3fc, #00d4ff);
  box-shadow:
    0 0 16px rgba(0,212,255,.8),
    0 0 32px rgba(0,212,255,.4);
  color: #0a0a1a;
  animation: diamondGlow 1.8s ease-in-out infinite;
}

@keyframes diamondGlow {
  0%, 100% { box-shadow: 0 0 16px rgba(0,212,255,.8), 0 0 32px rgba(0,212,255,.4); }
  50%       { box-shadow: 0 0 28px rgba(0,212,255,1.0), 0 0 56px rgba(0,212,255,.6); }
}

/* ── Bench Zone ───────────────────────────────────────────── */
body.theme-sports .bench-zone {
  background: var(--sports-card-2);
  border: 1px solid rgba(255,45,85,.25);
  box-shadow: 0 0 20px rgba(255,45,85,.08);
  position: relative;
}

body.theme-sports .bench-zone::after {
  content: 'PENALTY BOX';
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 16px;
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .1em;
  border-radius: 999px;
  background: var(--sports-red);
  color: #fff;
  white-space: nowrap;
  animation: warningPulse 2s ease-in-out infinite;
}

@keyframes warningPulse {
  0%, 100% { opacity: .5; }
  50%       { opacity: 1; }
}

body.theme-sports .bench-zone h2 {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--sports-red);
  text-shadow: 0 0 12px rgba(255,45,85,.4);
}

body.theme-sports .bench-zone .runner-card {
  border-color: rgba(255,45,85,.2);
}

body.theme-sports .bench-zone .runner-card::before {
  background: linear-gradient(90deg, var(--sports-red), var(--sports-orange));
}

body.theme-sports .bench-zone .runner-card .name {
  color: var(--sports-text-dim);
}

/* ── Leaderboard ──────────────────────────────────────────── */
body.theme-sports .leaderboard {
  background: var(--sports-card);
  border: 1px solid var(--sports-border);
  box-shadow: 0 0 24px rgba(0,255,136,.06);
  overflow: hidden;
}

body.theme-sports .leaderboard thead th {
  background: rgba(0,255,136,.06);
  color: var(--sports-neon);
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  border-bottom: 1px solid rgba(0,255,136,.2);
  font-size: .78rem;
}

body.theme-sports .leaderboard tbody td {
  color: var(--sports-text);
  border-bottom: 1px solid rgba(255,255,255,.05);
  font-family: 'Roboto Condensed', sans-serif;
}

body.theme-sports .leaderboard tbody tr:hover {
  background: rgba(0,255,136,.05);
}

body.theme-sports .leaderboard tbody tr:nth-child(1) td {
  color: var(--sports-gold, #FFD700);
  background: rgba(255,215,0,.05);
}

body.theme-sports .leaderboard tbody tr:nth-child(2) td {
  color: var(--sports-text);
  background: rgba(192,192,192,.04);
}

body.theme-sports .leaderboard tbody tr:nth-child(3) td {
  color: #CD7F32;
  background: rgba(205,127,50,.04);
}

body.theme-sports .leaderboard .rank-badge {
  background: rgba(0,255,136,.12);
  color: var(--sports-neon);
  font-family: 'Oswald', sans-serif;
  border: 1px solid rgba(0,255,136,.3);
}

/* ── Admin Panel ──────────────────────────────────────────── */
body.theme-sports .admin-sidebar {
  background: var(--sports-card);
  border: 1px solid var(--sports-border);
}

body.theme-sports .admin-card {
  background: var(--sports-card);
  border: 1px solid var(--sports-border);
  position: relative;
  overflow: hidden;
}

body.theme-sports .admin-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--sports-neon), var(--sports-cyan));
}

body.theme-sports .admin-card h3 {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--sports-neon);
}

/* ── Forms ────────────────────────────────────────────────── */
body.theme-sports .form-group label {
  color: var(--sports-text-dim);
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .78rem;
}

body.theme-sports .form-group input,
body.theme-sports .form-group select,
body.theme-sports .form-group textarea {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(0,255,136,.2);
  border-radius: 4px;
  color: var(--sports-text);
}

body.theme-sports .form-group input:focus,
body.theme-sports .form-group select:focus,
body.theme-sports .form-group textarea:focus {
  border-color: var(--sports-neon);
  background: rgba(0,255,136,.05);
  box-shadow: 0 0 0 3px rgba(0,255,136,.15);
}

body.theme-sports .form-group input::placeholder,
body.theme-sports .form-group textarea::placeholder {
  color: rgba(136,146,164,.5);
}

/* ── Buttons ──────────────────────────────────────────────── */
body.theme-sports .btn {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .1em;
  border-radius: 4px;
  font-size: .9rem;
}

body.theme-sports .btn-primary {
  background: transparent;
  color: var(--sports-neon);
  border: 2px solid var(--sports-neon);
  box-shadow: 0 0 12px rgba(0,255,136,.2);
}

body.theme-sports .btn-primary:hover {
  background: var(--sports-neon);
  color: var(--sports-bg);
  box-shadow: 0 0 24px rgba(0,255,136,.5), 0 0 48px rgba(0,255,136,.2);
}

body.theme-sports .btn-success {
  background: transparent;
  color: var(--sports-cyan);
  border: 2px solid var(--sports-cyan);
  box-shadow: 0 0 12px rgba(0,212,255,.2);
}

body.theme-sports .btn-success:hover {
  background: var(--sports-cyan);
  color: var(--sports-bg);
  box-shadow: 0 0 24px rgba(0,212,255,.5);
}

body.theme-sports .btn-danger {
  background: transparent;
  color: var(--sports-red);
  border: 2px solid var(--sports-red);
  box-shadow: 0 0 12px rgba(255,45,85,.2);
}

body.theme-sports .btn-danger:hover {
  background: var(--sports-red);
  color: #fff;
  box-shadow: 0 0 24px rgba(255,45,85,.5);
}

/* ── Attendance Grid ──────────────────────────────────────── */
body.theme-sports .attendance-item {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(0,255,136,.12);
  border-radius: 4px;
}

body.theme-sports .attendance-item:hover {
  background: rgba(0,255,136,.06);
  border-color: rgba(0,255,136,.3);
}

body.theme-sports .attendance-item .att-name {
  color: var(--sports-text);
  font-family: 'Roboto Condensed', sans-serif;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .85rem;
}

/* ── Modal ────────────────────────────────────────────────── */
body.theme-sports .modal-content {
  background: var(--sports-card);
  border: 1px solid rgba(0,255,136,.3);
  box-shadow:
    0 0 40px rgba(0,255,136,.15),
    0 24px 64px rgba(0,0,0,.7);
}

body.theme-sports .modal-header h2 {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--sports-neon);
  text-shadow: 0 0 12px rgba(0,255,136,.4);
}

body.theme-sports .modal-close {
  background: rgba(255,255,255,.06);
  color: var(--sports-text-dim);
}

body.theme-sports .modal-close:hover {
  background: rgba(255,45,85,.15);
  color: var(--sports-red);
}

/* ── Alert ────────────────────────────────────────────────── */
body.theme-sports .alert-success {
  background: rgba(0,255,136,.15);
  color: var(--sports-neon);
  border: 1px solid rgba(0,255,136,.35);
  box-shadow: 0 0 20px rgba(0,255,136,.2);
  backdrop-filter: blur(8px);
}

body.theme-sports .alert-error {
  background: rgba(255,45,85,.15);
  color: var(--sports-red);
  border: 1px solid rgba(255,45,85,.35);
  box-shadow: 0 0 20px rgba(255,45,85,.2);
  backdrop-filter: blur(8px);
}

/* ── Theme Switcher ───────────────────────────────────────── */
body.theme-sports .theme-switcher button {
  background: var(--sports-card);
  border-color: rgba(0,255,136,.3);
  color: var(--sports-text-dim);
}

body.theme-sports .theme-switcher button:hover {
  border-color: var(--sports-neon);
  color: var(--sports-neon);
  box-shadow: 0 0 16px rgba(0,255,136,.3);
}

body.theme-sports .theme-switcher button.active,
body.theme-sports .theme-switcher button[data-theme="sports"] {
  background: rgba(0,255,136,.12);
  border-color: var(--sports-neon);
  color: var(--sports-neon);
  box-shadow: 0 0 20px rgba(0,255,136,.35);
}

/* ── Footer ───────────────────────────────────────────────── */
body.theme-sports .footer {
  color: var(--sports-text-dim);
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: .72rem;
  border-top: 1px solid rgba(0,255,136,.08);
  padding-top: 20px;
}

/* ── Section headings ─────────────────────────────────────── */
body.theme-sports h1,
body.theme-sports h2,
body.theme-sports h3 {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
}

body.theme-sports h2 {
  color: var(--sports-text);
}

/* ── Scrollbar styling ────────────────────────────────────── */
body.theme-sports ::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

body.theme-sports ::-webkit-scrollbar-track {
  background: var(--sports-bg);
}

body.theme-sports ::-webkit-scrollbar-thumb {
  background: rgba(0,255,136,.3);
  border-radius: 3px;
}

body.theme-sports ::-webkit-scrollbar-thumb:hover {
  background: rgba(0,255,136,.6);
}
