/* ══════════════════════════════════════════════════
   FootGraphics — Dark Neon UI  v2
   Fonts: Outfit (UI) + Space Grotesk (headings) + JetBrains Mono (numbers)
══════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600;700&display=swap');

:root {
  --bg:        #060a10;
  --bg2:       #0b1220;
  --bg3:       #111a2e;
  --bg4:       #182238;
  --bg5:       #1e2a44;
  --border:    rgba(0,210,120,.09);
  --border2:   rgba(0,210,120,.20);
  --border3:   rgba(0,210,120,.40);
  --neon:      #00e88a;
  --neon2:     #00ffaa;
  --neon-dim:  rgba(0,232,138,.12);
  --neon-glow: 0 0 16px rgba(0,232,138,.45), 0 0 40px rgba(0,232,138,.15);
  --blue:      #3d8bff;
  --blue-dim:  rgba(61,139,255,.12);
  --red:       #ff3d5a;
  --red-dim:   rgba(255,61,90,.12);
  --yellow:    #ffcc3d;
  --yel-dim:   rgba(255,204,61,.10);
  --purple:    #a855f7;
  --text:      #e2ecff;
  --text2:     rgba(226,236,255,.58);
  --text3:     rgba(226,236,255,.30);
  --radius:    9px;
  --shadow:    0 4px 28px rgba(0,0,0,.65);
  --card-shadow: 0 2px 16px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.035);
  --font:      'Outfit', system-ui, sans-serif;
  --font-head: 'Space Grotesk', 'Outfit', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin:0; padding:0; }
html { font-size:14px; scroll-behavior:smooth; }
body {
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 80% 40% at 10% -10%, rgba(0,232,138,.06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 110%, rgba(61,139,255,.05) 0%, transparent 60%);
  color: var(--text);
  font-family: var(--font);
  min-height: 100vh;
  line-height: 1.55;
}

/* ── SCROLLBAR ─────────────────────────────────── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--bg5); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:rgba(0,232,138,.25); }

/* ── NAVBAR ────────────────────────────────────── */
.navbar {
  display:flex; align-items:center; gap:0; height:54px;
  background:rgba(11,18,32,.97);
  border-bottom:1px solid var(--border);
  box-shadow: 0 1px 0 var(--border), 0 4px 24px rgba(0,0,0,.5);
  padding:0 20px; position:sticky; top:0; z-index:200;
  backdrop-filter:blur(12px);
}
.nav-brand { display:flex; align-items:center; gap:10px; margin-right:28px; }
.nav-logo { font-size:22px; }
.nav-title {
  font-family: var(--font-head); font-weight:700; font-size:18px;
  letter-spacing:3px; text-transform:uppercase;
  background: linear-gradient(90deg, var(--neon) 0%, #3d8bff 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.nav-links { display:flex; gap:2px; flex:1; }
.nav-link {
  display:flex; align-items:center; gap:7px; padding:0 16px; height:54px;
  color:var(--text2); text-decoration:none; font-size:13px; font-weight:500;
  transition:all .2s; border-bottom:2px solid transparent; letter-spacing:.2px;
}
.nav-link:hover { color:var(--text); background:var(--neon-dim); border-bottom-color:var(--neon); }
.nav-link.active { color:var(--neon); background:var(--neon-dim); border-bottom-color:var(--neon); }
.nav-icon { font-size:7px; color:var(--neon); opacity:.5; }
/* Global search */
.nav-search { position:relative; margin:0 16px; }
.nav-search-input {
  background:rgba(255,255,255,.06); border:1px solid var(--border2); border-radius:6px;
  color:var(--text); padding:5px 12px; font-size:13px; width:200px; font-family:var(--font);
  outline:none; transition:border-color .2s;
}
.nav-search-input:focus { border-color:var(--neon); background:rgba(255,255,255,.1); }
.nav-search-results {
  position:absolute; top:calc(100% + 4px); left:0; min-width:260px;
  background:var(--bg2); border:1px solid var(--border2); border-radius:8px;
  box-shadow:0 8px 28px rgba(0,0,0,.6); z-index:9999; overflow:hidden;
}
.nsr-item {
  display:block; padding:8px 14px; color:var(--text); text-decoration:none; font-size:13px;
  border-bottom:1px solid var(--border); transition:background .14s;
}
.nsr-item:last-child { border-bottom:none; }
.nsr-item:hover { background:var(--neon-dim); color:var(--neon); }

.nav-user { display:flex; align-items:center; gap:12px; margin-left:auto; }
.user-level {
  font-size:10px; font-weight:700; padding:3px 9px; border-radius:20px;
  text-transform:uppercase; letter-spacing:.8px; font-family:var(--font-head);
}
.level-1 { background:rgba(150,150,150,.12); color:#888; }
.level-2 { background:var(--neon-dim); color:var(--neon); border:1px solid rgba(0,232,138,.25); }
.level-3 { background:var(--blue-dim); color:var(--blue); border:1px solid rgba(61,139,255,.3); }
.level-4 { background:var(--yel-dim); color:var(--yellow); border:1px solid rgba(255,204,61,.25); }
.level-5 { background:var(--red-dim); color:var(--red); border:1px solid rgba(255,61,90,.3); }
.user-name { color:var(--text2); font-size:13px; font-weight:500; }
.btn-logout {
  font-size:12px; color:var(--text3); text-decoration:none;
  padding:5px 12px; border:1px solid var(--border); border-radius:6px; transition:all .2s;
}
.btn-logout:hover { color:var(--red); border-color:var(--red); background:var(--red-dim); }

/* ── MAIN ──────────────────────────────────────── */
.main-content { padding:24px; max-width:1700px; margin:0 auto; }

/* ── FLASH ─────────────────────────────────────── */
.flash-container { position:fixed; top:62px; right:20px; z-index:999; display:flex; flex-direction:column; gap:8px; }
.flash {
  padding:11px 40px 11px 16px; border-radius:var(--radius); font-size:13px;
  position:relative; min-width:280px; max-width:420px;
  animation:slideIn .3s ease; font-weight:500;
}
@keyframes slideIn { from{transform:translateX(30px);opacity:0} to{transform:translateX(0);opacity:1} }
.flash-success { background:rgba(0,232,138,.09); border:1px solid rgba(0,232,138,.28); color:var(--neon2); }
.flash-danger  { background:rgba(255,61,90,.09);  border:1px solid rgba(255,61,90,.28);  color:#ff8888; }
.flash-warning { background:rgba(255,204,61,.09); border:1px solid rgba(255,204,61,.28); color:var(--yellow); }
.flash-close { position:absolute; right:12px; top:10px; background:none; border:none; color:inherit; cursor:pointer; font-size:16px; opacity:.5; }
.flash-close:hover { opacity:1; }

/* ── BUTTONS ───────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:6px; padding:8px 18px;
  border-radius:7px; border:none; cursor:pointer;
  font-family:var(--font); font-size:13px; font-weight:600;
  text-decoration:none; transition:all .18s; white-space:nowrap; letter-spacing:.2px;
}
.btn-primary {
  background:linear-gradient(135deg, #00c97a, #009a5e);
  color:#fff; box-shadow:0 2px 12px rgba(0,201,122,.25);
}
.btn-primary:hover {
  background:linear-gradient(135deg, #00e88a, #00b36a);
  box-shadow:0 0 0 2px rgba(0,232,138,.3), 0 4px 18px rgba(0,201,122,.35);
  transform:translateY(-1px);
}
.btn-ghost {
  background:var(--bg3); color:var(--text2);
  border:1px solid var(--border2); transition:all .18s;
}
.btn-ghost:hover { background:var(--bg4); color:var(--text); border-color:var(--border3); }
.btn-danger { background:var(--red-dim); color:var(--red); border:1px solid rgba(255,61,90,.28); }
.btn-danger:hover { background:var(--red); color:#fff; }
.btn-blue { background:var(--blue-dim); color:var(--blue); border:1px solid rgba(61,139,255,.28); }
.btn-blue:hover { background:var(--blue); color:#fff; }
.btn-sm { padding:5px 12px; font-size:12px; }
.btn-xs { padding:3px 9px; font-size:11px; border-radius:5px; }
.btn-large { padding:12px 30px; font-size:15px; }
.btn-full { width:100%; justify-content:center; }

/* ── FORMS ─────────────────────────────────────── */
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-label { font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.9px; font-family:var(--font-head); }
.form-input {
  background:var(--bg3); border:1px solid var(--border2);
  color:var(--text); border-radius:7px; padding:9px 13px;
  font-family:var(--font); font-size:13px; outline:none; transition:all .2s;
}
.form-input:focus { border-color:var(--neon); box-shadow:0 0 0 3px var(--neon-dim); }
.form-input-sm { padding:5px 9px; font-size:12px; border-radius:6px; }
.form-input-xs { width:60px; padding:3px 7px; font-size:12px; border-radius:5px; }
.form-select {
  background:var(--bg3); border:1px solid var(--border2); color:var(--text);
  border-radius:7px; padding:9px 13px; font-size:13px; font-family:var(--font); outline:none; transition:border .2s;
}
.form-select:focus { border-color:var(--neon); }
.form-select-sm { padding:5px 9px; font-size:12px; border-radius:6px; }
.form-file { color:var(--text2); font-size:12px; }
.form-color { height:38px; width:64px; border:1px solid var(--border2); border-radius:6px; background:var(--bg3); cursor:pointer; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row { display:flex; gap:16px; }
.form-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px; box-shadow:var(--card-shadow);
}
.form-actions { display:flex; gap:10px; margin-top:18px; }
.form-group-wide { grid-column:1/-1; }
.form-group-action { align-self:flex-end; }
.inline-form { display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; }
.check-label { display:flex; align-items:center; gap:8px; cursor:pointer; font-size:13px; color:var(--text2); }
.check-label input[type=checkbox] { accent-color:var(--neon); }
.multi-select-box {
  background:var(--bg3); border:1px solid var(--border);
  border-radius:7px; padding:10px; max-height:200px; overflow-y:auto;
  display:flex; flex-direction:column; gap:4px;
}
.section-label {
  font-size:11px; font-weight:700; color:var(--neon); text-transform:uppercase;
  letter-spacing:1px; padding:5px 0; grid-column:1/-1;
  border-bottom:1px solid var(--border); font-family:var(--font-head);
}
.radio-group { display:flex; gap:14px; flex-wrap:wrap; }
.radio-label { display:flex; align-items:center; gap:6px; cursor:pointer; font-size:13px; color:var(--text2); }
.radio-label input { accent-color:var(--neon); }

/* ── MODAL ─────────────────────────────────────── */
.modal {
  position:fixed; inset:0; background:rgba(0,0,0,.78);
  z-index:1000; display:flex; align-items:center; justify-content:center;
  padding:20px; backdrop-filter:blur(8px);
}
.modal-box {
  background:linear-gradient(165deg, var(--bg2) 0%, var(--bg3) 100%);
  border:1px solid var(--border2); border-radius:14px; padding:28px;
  width:100%; max-width:500px; max-height:92vh; overflow-y:auto;
  box-shadow:0 0 0 1px rgba(0,232,138,.04), 0 24px 60px rgba(0,0,0,.7);
}
.modal-small { max-width:380px; }
.modal-large { max-width:700px; }
.modal-xl { max-width:900px; }
.modal-title {
  font-family:var(--font-head); font-size:22px; font-weight:700;
  color:var(--text); margin-bottom:18px; letter-spacing:-.3px;
}

/* ── TABLES ────────────────────────────────────── */
.table-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--card-shadow);
}
.data-table { width:100%; border-collapse:collapse; font-size:13px; }
.data-table th {
  background:var(--bg3); color:var(--neon);
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:1px; padding:11px 14px; text-align:left;
  border-bottom:1px solid var(--border2); font-family:var(--font-head);
}
.data-table td { padding:10px 14px; border-bottom:1px solid var(--border); color:var(--text); }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(0,232,138,.025); }
.id-cell { color:var(--text3); font-size:11px; font-family:var(--font-mono); }
.img-cell { width:54px; }
.actions-cell { text-align:right; white-space:nowrap; }
.empty-msg { padding:28px; text-align:center; color:var(--text3); }

/* ── BADGES ────────────────────────────────────── */
.badge {
  display:inline-block; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:700;
  background:var(--bg4); color:var(--text2); font-family:var(--font-head);
}
.badge-green { background:rgba(0,232,138,.10); color:var(--neon); border:1px solid rgba(0,232,138,.22); }
.badge-red { background:var(--red-dim); color:var(--red); border:1px solid rgba(255,61,90,.28); }
.pos-badge {
  display:inline-block; padding:1px 7px; border-radius:4px;
  font-size:11px; font-weight:700; font-family:var(--font-mono);
  background:rgba(0,232,138,.09); color:var(--neon); margin-right:3px;
  border:1px solid rgba(0,232,138,.18);
}

/* ── IMAGES ────────────────────────────────────── */
.flag-img { height:20px; width:32px; object-fit:cover; border-radius:2px; }
.thumb-img { height:38px; width:62px; object-fit:cover; border-radius:5px; }
.avatar-img { height:36px; width:36px; object-fit:cover; border-radius:50%; border:1px solid var(--border2); }
.avatar-placeholder { height:36px; width:36px; border-radius:50%; background:var(--bg3); display:flex; align-items:center; justify-content:center; font-size:18px; }

/* ── PAGE HEADER ───────────────────────────────── */
.page-header { display:flex; align-items:center; gap:14px; margin-bottom:24px; flex-wrap:wrap; }
.page-title {
  font-family:var(--font-head); font-size:28px; font-weight:700;
  color:var(--text); letter-spacing:-.5px;
}
.page-sub { color:var(--text2); font-size:14px; }
.breadcrumb { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; }
.id-badge {
  font-size:13px; color:var(--neon); background:var(--neon-dim);
  padding:2px 10px; border-radius:5px; border:1px solid rgba(0,232,138,.18);
  font-family:var(--font-mono);
}

/* ── DASHBOARD ─────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
.stat-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:22px; text-align:center;
  box-shadow:var(--card-shadow); transition:border .2s, box-shadow .2s;
}
.stat-card:hover { border-color:var(--border3); box-shadow:0 0 24px var(--neon-dim); }
.stat-icon { font-size:28px; margin-bottom:8px; }
.stat-value { font-family:var(--font-mono); font-size:38px; font-weight:700; color:var(--neon); text-shadow:var(--neon-glow); }
.stat-label { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:.8px; margin-top:4px; font-family:var(--font-head); }
.dash-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.dash-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px; box-shadow:var(--card-shadow);
}
.card-title {
  font-family:var(--font-head); font-size:14px; font-weight:700;
  text-transform:uppercase; letter-spacing:.8px; color:var(--neon);
  margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid var(--border);
}
.match-list { display:flex; flex-direction:column; gap:8px; }
.match-row {
  display:flex; align-items:center; gap:12px; padding:10px 12px;
  background:var(--bg3); border-radius:7px; border:1px solid var(--border);
  flex-wrap:wrap; transition:border .2s;
}
.match-row:hover { border-color:var(--border2); }
.live-row { border-color:rgba(0,232,138,.35); background:rgba(0,232,138,.04); }
.live-score { color:var(--neon); font-weight:800; }
.dash-section { margin-bottom:20px; }
.dash-grid { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.match-teams { display:flex; align-items:center; gap:8px; flex:1; }
.team-name { font-weight:600; font-size:13px; }
.match-score {
  font-family:var(--font-mono); font-size:22px; font-weight:700;
  color:var(--neon); min-width:54px; text-align:center; text-shadow:var(--neon-glow);
}
.match-meta { display:flex; align-items:center; gap:8px; }
.match-actions { display:flex; gap:6px; margin-left:auto; }
.quick-links { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.quick-link {
  display:flex; align-items:center; gap:10px; padding:12px 14px;
  background:var(--bg3); border-radius:7px; text-decoration:none; color:var(--text);
  transition:all .2s; border:1px solid var(--border);
}
.quick-link:hover { background:var(--bg4); border-color:var(--neon); box-shadow:0 0 12px var(--neon-dim); color:var(--neon); }
.ql-icon { font-size:22px; }

/* ── MATCH STATUS ──────────────────────────────── */
.match-status, .mc-status-badge {
  font-size:10px; font-weight:700; padding:3px 9px; border-radius:20px;
  text-transform:uppercase; letter-spacing:.8px; display:inline-block;
  font-family:var(--font-head);
}
.status-scheduled    { background:rgba(140,140,140,.1); color:#777; }
.status-first_half   { background:rgba(0,232,138,.14); color:var(--neon); border:1px solid rgba(0,232,138,.28); }
.status-second_half  { background:rgba(0,232,138,.14); color:var(--neon); border:1px solid rgba(0,232,138,.28); }
.status-half_time    { background:var(--yel-dim); color:var(--yellow); border:1px solid rgba(255,204,61,.28); }
.status-extra_time_1, .status-extra_time_2 { background:var(--blue-dim); color:var(--blue); border:1px solid rgba(61,139,255,.28); }
.status-penalty_shootout { background:var(--red-dim); color:var(--red); border:1px solid rgba(255,61,90,.28); }
.status-finished     { background:rgba(100,100,100,.09); color:#555; }

/* ── DB LAYOUT ─────────────────────────────────── */
.db-layout { display:flex; gap:20px; align-items:flex-start; }
.db-sidenav {
  width:185px; flex-shrink:0; background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:12px 0; position:sticky; top:66px;
  box-shadow:var(--card-shadow);
}
.sidenav-title { font-size:10px; font-weight:700; color:var(--neon); text-transform:uppercase; letter-spacing:1.5px; padding:6px 16px 10px; font-family:var(--font-head); }
.sidenav-link {
  display:block; padding:8px 16px; color:var(--text2); text-decoration:none;
  font-size:13px; transition:all .15s; border-left:2px solid transparent;
}
.sidenav-link:hover, .sidenav-link.active {
  color:var(--neon); background:var(--neon-dim); border-left-color:var(--neon);
}
.sidenav-divider { height:1px; background:var(--border); margin:6px 0; }
.db-main { flex:1; min-width:0; }
.mb-4 { margin-bottom:16px; }

/* ── FILTER BAR ────────────────────────────────── */
.filter-bar { margin-bottom:14px; }
.filter-form { display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

/* ── CLUBS GRID ────────────────────────────────── */
.clubs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.club-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius);
  padding:16px; display:flex; align-items:center; gap:12px; transition:all .2s;
}
.club-card:hover { border-color:var(--border3); box-shadow:0 0 18px var(--neon-dim); }
.club-logo-wrap { width:48px; height:48px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.club-logo { width:48px; height:48px; object-fit:contain; }
.club-logo-placeholder { font-size:30px; }
.club-name { font-weight:700; font-size:14px; }
.club-meta, .club-stadium { font-size:12px; color:var(--text3); margin-top:2px; }
.club-actions { margin-left:auto; display:flex; flex-direction:column; gap:4px; }

/* ── MATCH CONTROL ─────────────────────────────── */
.mc-wrapper { display:flex; flex-direction:column; height:calc(100vh - 54px); overflow:hidden; }

.mc-topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:7px 14px; background:var(--bg2);
  border-bottom:1px solid var(--border); gap:14px; flex-shrink:0;
}
.mc-match-info { display:flex; gap:10px; font-size:11px; color:var(--text2); flex-wrap:wrap; }
.mc-league { font-weight:700; color:var(--neon); font-family:var(--font-head); }
.mc-scoreboard { display:flex; align-items:center; gap:0; flex:1; justify-content:center; }
.mc-club { display:flex; align-items:center; gap:8px; padding:0 12px; }
.mc-club-home { flex-direction:row; }
.mc-club-away { flex-direction:row-reverse; }
.mc-club-logo { height:32px; width:32px; object-fit:contain; }
.mc-club-name { font-family:var(--font-head); font-size:17px; font-weight:700; text-transform:uppercase; letter-spacing:.3px; }
.mc-score-center { text-align:center; padding:0 8px; }
.mc-score {
  font-family:var(--font-mono); font-size:42px; font-weight:700;
  color:var(--neon); line-height:1; text-shadow:var(--neon-glow);
}
.mc-timer { font-family:var(--font-mono); font-size:22px; font-weight:600; color:var(--text); }

/* Overlay toggle buttons */
.ovl-btn {
  display:inline-flex; align-items:center; gap:4px;
  padding:5px 10px; border-radius:6px; border:1px solid var(--border2);
  background:var(--bg3); color:var(--text2); font-size:11px; font-weight:600;
  cursor:pointer; transition:all .15s; white-space:nowrap; font-family:var(--font);
}
.ovl-btn:hover { background:var(--bg4); color:var(--text); }
.ovl-btn.ovl-active {
  background:var(--neon-dim); color:var(--neon);
  border-color:var(--neon); box-shadow:0 0 8px var(--neon-dim);
}
.ovl-row { display:flex; gap:4px; flex-wrap:wrap; align-items:center; }

.mc-panel {
  width:188px; flex-shrink:0; background:var(--bg2);
  border-right:1px solid var(--border); overflow-y:auto;
  display:flex; flex-direction:column;
}
.mc-panel-away { border-right:none; border-left:1px solid var(--border); }
.mc-panel-header {
  padding:9px 11px; display:flex; align-items:center; gap:8px;
  background:var(--bg3); border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:5;
}
.mc-team-kit {
  width:28px; height:28px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:8px; font-weight:800; flex-shrink:0;
  border:2px solid rgba(255,255,255,.3);
}
.mc-panel-title { font-family:var(--font-head); font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; }

/* Event button groups */
.ev-group { margin-bottom:3px; border-bottom:1px solid rgba(255,255,255,.04); padding-bottom:3px; }
.ev-group-label { font-size:9px; font-weight:700; color:rgba(0,232,138,.5); text-transform:uppercase; letter-spacing:1.2px; padding:3px 8px 2px; font-family:var(--font-head); }
.mc-event-btns { padding:5px; display:flex; flex-direction:column; gap:2px; }
.mc-ev-btn {
  display:block; width:100%; padding:8px 10px;
  border-radius:6px; border:1px solid var(--border); background:var(--bg3);
  color:var(--text); font-size:12px; font-weight:600; font-family:var(--font);
  cursor:pointer; text-align:left; transition:all .14s;
}
.mc-ev-btn:hover { background:var(--bg4); transform:translateX(2px); }
.btn-goal { border-color:rgba(0,232,138,.28); color:var(--neon); }
.btn-goal:hover { background:var(--neon-dim); box-shadow:0 0 8px var(--neon-dim); }
.btn-assist { border-color:rgba(61,139,255,.25); color:var(--blue); }
.btn-assist:hover { background:var(--blue-dim); }
.btn-card { border-color:rgba(255,204,61,.22); color:var(--yellow); }
.btn-card:hover { background:var(--yel-dim); }
.btn-card.btn-red { border-color:rgba(255,61,90,.28); color:var(--red); }
.btn-card.btn-red:hover { background:var(--red-dim); }
.btn-card.btn-2y { border-color:rgba(255,130,0,.25); color:#ff9920; }
.btn-shot { border-color:rgba(61,139,255,.18); color:#7aaeff; }
.btn-shot:hover { background:rgba(61,139,255,.07); }
.btn-corner { border-color:rgba(100,180,255,.18); color:#9bbfff; }
.btn-foul { border-color:rgba(255,120,50,.22); color:#ff9966; }
.btn-foul:hover { background:rgba(255,120,50,.07); }
.btn-pass { color:var(--text3); }
.btn-new { border-color:rgba(168,85,247,.22); color:#c084fc; }
.btn-new:hover { background:rgba(168,85,247,.08); }
.btn-penalty-saved { border-color:rgba(0,232,138,.18); color:#66ddaa; }
.btn-throw { border-color:rgba(150,150,255,.18); color:#aaaaff; }

/* Possession */
.mc-possession-ctrl { padding:8px; margin-top:auto; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:4px; }
.mc-poss-label { font-size:9px; color:var(--text3); text-transform:uppercase; letter-spacing:.8px; font-family:var(--font-head); }
.mc-poss-btn {
  width:100%; padding:6px 8px; border-radius:5px; border:1px solid var(--border);
  background:var(--bg3); color:var(--text2); font-size:11px; font-weight:600;
  cursor:pointer; transition:all .18s; font-family:var(--font);
}
.mc-poss-btn.active { background:var(--neon-dim); color:var(--neon); border-color:var(--neon); box-shadow:0 0 8px var(--neon-dim); }
.mc-poss-btn.poss-away.active { background:var(--blue-dim); color:var(--blue); border-color:var(--blue); box-shadow:0 0 8px var(--blue-dim); }
.mc-poss-btn.poss-neutral.active { background:var(--yel-dim); color:var(--yellow); border-color:var(--yellow); }

/* Center area */
.mc-center { flex:1; display:flex; flex-direction:column; overflow-y:auto; padding:6px 8px; gap:6px; min-width:0; }
.mc-timer-controls { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.mc-timer-btns { display:flex; gap:3px; }

/* Possession bar */
.mc-poss-bar { flex:1; height:8px; border-radius:4px; background:var(--bg3); overflow:hidden; border:1px solid var(--border); display:flex; }

/* Field */
.mc-field-wrap { display:flex; align-items:center; justify-content:center; flex:1; }
.mc-field {
  position:relative; width:100%; max-width:720px; aspect-ratio:16/9;
  background:linear-gradient(160deg,#1b6e2f 0%,#155825 50%,#1b6e2f 100%);
  border:2px solid rgba(255,255,255,.65); border-radius:5px; overflow:hidden;
  box-shadow:0 0 40px rgba(0,232,138,.12), inset 0 0 60px rgba(0,0,0,.3);
  user-select:none; -webkit-user-select:none;
}
.mc-field::before {
  content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(90deg,transparent 0,transparent calc(12.5% - 1px),rgba(255,255,255,.035) calc(12.5% - 1px),rgba(255,255,255,.035) 12.5%);
}
.field-center-line { position:absolute; left:50%; top:0; bottom:0; width:2px; background:rgba(255,255,255,.5); transform:translateX(-50%); }
.field-center-circle { position:absolute; left:50%; top:50%; width:18%; padding-bottom:18%; transform:translate(-50%,-50%); border:2px solid rgba(255,255,255,.5); border-radius:50%; }
.field-penalty-home { position:absolute; left:0; top:20%; width:13%; height:60%; border:2px solid rgba(255,255,255,.45); border-left:none; }
.field-penalty-away { position:absolute; right:0; top:20%; width:13%; height:60%; border:2px solid rgba(255,255,255,.45); border-right:none; }
.field-goal-home { position:absolute; left:0; top:35%; width:3%; height:30%; border:2px solid rgba(255,255,255,.65); border-left:none; background:rgba(255,255,255,.07); }
.field-goal-away { position:absolute; right:0; top:35%; width:3%; height:30%; border:2px solid rgba(255,255,255,.65); border-right:none; background:rgba(255,255,255,.07); }
.field-team { position:absolute; inset:0; pointer-events:none; }

/* Player bubbles */
.player-bubble {
  position:absolute; transform:translate(-50%,-50%);
  width:34px; height:34px; border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  cursor:grab; user-select:none; pointer-events:all;
  border:2px solid rgba(255,255,255,.7);
  box-shadow:0 2px 10px rgba(0,0,0,.6);
  transition:box-shadow .15s, transform .1s; z-index:10;
}
.player-bubble:hover {
  box-shadow:0 0 0 3px rgba(255,255,255,.4), 0 0 18px rgba(0,232,138,.4);
  z-index:20; transform:translate(-50%,-50%) scale(1.12);
}
.player-bubble:active { cursor:grabbing; }
.player-bubble.has-yellow { border-color:var(--yellow); box-shadow:0 0 8px rgba(255,204,61,.5); }
.pb-yc-icon { position:absolute; top:-14px; left:50%; transform:translateX(-50%); font-size:9px; line-height:1; pointer-events:none; white-space:nowrap; }
.pb-number { font-size:11px; font-weight:800; line-height:1; font-family:var(--font-mono); }
.pb-pos { font-size:7px; font-weight:700; opacity:.85; line-height:1; font-family:var(--font-head); }
.pb-tooltip {
  position:absolute; bottom:calc(100% + 7px); left:50%; transform:translateX(-50%);
  background:rgba(6,10,16,.96); color:var(--text); font-size:11px; padding:4px 9px;
  border-radius:5px; white-space:nowrap; pointer-events:none; display:none; z-index:100;
  border:1px solid var(--border2); font-family:var(--font);
}
.player-bubble:hover .pb-tooltip { display:block; }

/* Stats bar */
.mc-stats-bar { display:grid; grid-template-columns:repeat(4,1fr); gap:3px; }
.mc-stat-row {
  display:flex; align-items:center; background:var(--bg2);
  border:1px solid var(--border); border-radius:5px; overflow:hidden;
}
.mc-stat-home { padding:4px 7px; font-family:var(--font-mono); font-size:16px; font-weight:700; color:var(--neon); min-width:28px; text-align:center; }
.mc-stat-away { padding:4px 7px; font-family:var(--font-mono); font-size:16px; font-weight:700; color:var(--blue); min-width:28px; text-align:center; }
.mc-stat-label { flex:1; text-align:center; font-size:9px; color:var(--text3); text-transform:uppercase; letter-spacing:.3px; font-family:var(--font-head); }

/* Markers */
.mc-markers { width:200px; flex-shrink:0; background:var(--bg2); border-left:1px solid var(--border); overflow-y:auto; display:flex; flex-direction:column; }
.mc-markers-title { padding:9px 12px; font-size:10px; font-weight:700; color:var(--neon); text-transform:uppercase; letter-spacing:1px; border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--bg2); z-index:5; font-family:var(--font-head); }
.marker-item { padding:7px 10px; border-bottom:1px solid var(--border); font-size:11px; transition:background .14s; }
.marker-item:hover { background:rgba(0,232,138,.025); }
.marker-minute { font-weight:800; color:var(--neon); font-family:var(--font-mono); font-size:12px; }
.marker-type { color:var(--text); font-weight:600; }
.marker-player { color:var(--text2); font-size:11px; display:block; margin-top:1px; }
.marker-actions { display:flex; gap:4px; margin-top:5px; }
.marker-btn {
  font-size:10px; padding:2px 7px; border-radius:3px;
  border:1px solid var(--border); background:none; color:var(--text3);
  cursor:pointer; transition:all .15s; font-family:var(--font);
}
.marker-btn:hover { color:var(--text); background:var(--bg3); }
.marker-btn.broadcast { color:var(--neon); border-color:rgba(0,232,138,.28); }
.marker-btn.broadcast:hover { background:var(--neon-dim); box-shadow:0 0 8px var(--neon-dim); }
.marker-btn.active-broadcast { background:var(--red-dim) !important; color:var(--red) !important; border-color:var(--red) !important; }
.marker-btn.delete { color:var(--red); border-color:rgba(255,61,90,.28); }
.marker-btn.delete:hover { background:var(--red-dim); }
.marker-filter-btn { font-size:9px; padding:2px 5px; border-radius:3px; border:1px solid var(--border); background:none; color:var(--text3); cursor:pointer; font-family:var(--font); transition:all .14s; }
.marker-filter-btn.active { background:var(--neon-dim); color:var(--neon); border-color:rgba(0,232,138,.35); }
.marker-filter-btn:hover { color:var(--text); background:var(--bg3); }

/* Player mini-card */
.player-mini-card {
  background:var(--bg2); border:1px solid var(--border2); border-radius:8px;
  padding:10px 14px; min-width:140px; box-shadow:0 8px 24px rgba(0,0,0,.6);
}
.pmc-name { font-weight:700; font-size:13px; color:var(--text); margin-bottom:2px; }
.pmc-pos { font-size:10px; color:var(--text3); margin-bottom:6px; }
.pmc-stats { display:flex; flex-wrap:wrap; gap:6px; font-size:13px; }
.pmc-sub { font-size:11px; color:var(--text3); margin-top:4px; }

/* Saved formations panel */
.saved-formation-item { display:flex; align-items:center; gap:4px; background:var(--bg3); border:1px solid var(--border); border-radius:4px; padding:2px 6px; font-size:11px; }
.saved-formation-item .sf-name { color:var(--text); font-weight:600; flex:1; }
.saved-formation-item .sf-count { color:var(--text3); font-size:10px; }
.saved-formation-item .sf-apply-btn { font-size:10px; padding:1px 5px; border:1px solid var(--border2); border-radius:3px; background:none; color:var(--neon); cursor:pointer; }
.saved-formation-item .sf-apply-btn:hover { background:var(--neon-dim); }
.saved-formation-item .sf-del-btn { font-size:10px; padding:1px 4px; border:none; background:none; color:var(--text3); cursor:pointer; line-height:1; }
.saved-formation-item .sf-del-btn:hover { color:#ff4444; }

/* Penalty shootout — goal visualization */
.penalty-gate {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  max-width:240px; width:100%;
  border:3px solid #d0d0d0; border-bottom:5px solid #999;
  border-radius:2px 2px 0 0;
  background:#1a6b2e; padding:3px; position:relative;
  box-shadow:0 0 0 1px rgba(255,255,255,.1), inset 0 0 20px rgba(0,0,0,.3);
}
.gate-zone {
  aspect-ratio:1.3; display:flex; align-items:center; justify-content:center;
  border:1px dashed rgba(255,255,255,.25); border-radius:2px;
  font-size:9px; font-weight:700; cursor:pointer; color:rgba(255,255,255,.55);
  transition:all .14s; background:rgba(255,255,255,.05);
  font-family:var(--font-mono);
}
.gate-zone:hover { background:rgba(0,220,130,.25); color:#00dc82; border-color:rgba(0,220,130,.5); }
.gate-zone.selected { background:rgba(0,220,130,.35); color:#00dc82; border-color:#00dc82; box-shadow:0 0 8px rgba(0,220,130,.4); }
.ps-scores { display:flex; gap:24px; font-size:18px; margin-bottom:14px; font-family:var(--font-mono); font-weight:700; }
.ps-list { display:flex; flex-direction:column; gap:4px; margin-bottom:16px; max-height:200px; overflow-y:auto; }
.ps-row { display:flex; align-items:center; gap:8px; padding:6px 10px; border-radius:5px; background:var(--bg3); font-size:12px; border:1px solid var(--border); }
.ps-scored { color:var(--neon); font-weight:800; font-size:14px; }
.ps-missed { color:var(--red); font-weight:800; font-size:14px; }
.ps-add h4 { font-size:13px; font-weight:700; color:var(--neon); margin-bottom:12px; font-family:var(--font-head); }

/* Stats pages */
.stats-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.stats-nav { display:flex; gap:2px; margin-bottom:20px; border-bottom:1px solid var(--border); }
.stats-nav-link { padding:8px 18px; color:var(--text2); text-decoration:none; font-size:13px; font-weight:600; border-bottom:2px solid transparent; transition:all .2s; }
.stats-nav-link.active,.stats-nav-link:hover { color:var(--neon); border-bottom-color:var(--neon); }
.stats-list { display:flex; flex-direction:column; gap:2px; }
.stats-match-row,.stats-item-row {
  display:flex; align-items:center; gap:8px; padding:7px 9px;
  border-radius:6px; text-decoration:none; color:var(--text); font-size:13px; transition:background .14s;
}
.stats-match-row:hover,.stats-item-row:hover { background:var(--bg3); color:var(--neon); }
.sm-teams { flex:1; font-weight:600; }
.stats-item-club { font-size:11px; color:var(--text3); margin-left:auto; }
.stats-table { width:100%; border-collapse:collapse; }
.stats-table th { background:var(--bg3); color:var(--neon); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1px; padding:9px 14px; border-bottom:1px solid var(--border2); font-family:var(--font-head); }
.stats-table td { padding:9px 14px; border-bottom:1px solid var(--border); font-size:13px; }
.stats-val { text-align:right; font-family:var(--font-mono); font-size:19px; font-weight:700; color:var(--neon); }
.stats-table-single td:first-child { color:var(--text2); }

/* Login */
.login-body { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg); overflow:hidden; }
.login-bg { position:fixed; inset:0; }
.login-grid {
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(0,232,138,.05) 1px,transparent 1px), linear-gradient(90deg,rgba(0,232,138,.05) 1px,transparent 1px);
  background-size:48px 48px;
}
.login-grid::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 50%,rgba(0,232,138,.08) 0%,transparent 70%); }
.login-container { position:relative; z-index:1; }
.login-card {
  background:rgba(11,18,32,.96); border:1px solid var(--border2);
  border-radius:18px; padding:44px; width:380px;
  box-shadow:0 0 60px rgba(0,232,138,.08), 0 24px 60px rgba(0,0,0,.6);
  backdrop-filter:blur(12px);
}
.login-logo { font-size:50px; text-align:center; margin-bottom:12px; }
.login-title {
  font-family:var(--font-head); font-size:28px; font-weight:700;
  text-transform:uppercase; letter-spacing:4px; text-align:center;
  background:linear-gradient(90deg,var(--neon),var(--blue));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.login-sub { font-size:12px; color:var(--text3); text-align:center; margin-bottom:28px; margin-top:6px; }
.login-form { display:flex; flex-direction:column; gap:16px; }

/* Misc */
.sub-info-box { background:var(--bg3); border:1px solid var(--border2); border-radius:6px; padding:9px 12px; font-size:13px; color:var(--neon); font-family:var(--font-head); }
.gfx-packages-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.gfx-pkg-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:18px; transition:all .2s; }
.gfx-pkg-card:hover { border-color:var(--border3); box-shadow:0 0 20px var(--neon-dim); }
.gfx-pkg-name { font-family:var(--font-head); font-size:18px; font-weight:700; color:var(--text); margin-bottom:8px; }
.gfx-pkg-colors { display:flex; gap:6px; margin-bottom:10px; }
.gfx-color-swatch { width:24px; height:24px; border-radius:4px; border:1px solid rgba(255,255,255,.15); }
.match-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:border .2s; }
.match-card:hover { border-color:var(--border2); }
.match-card-header { display:flex; align-items:center; gap:12px; padding:8px 16px; background:var(--bg3); font-size:11px; color:var(--text2); border-bottom:1px solid var(--border); }
.match-id { font-family:var(--font-mono); color:var(--neon); font-size:11px; }
.match-card-body { display:flex; align-items:center; padding:16px; }
.match-club { display:flex; align-items:center; gap:10px; flex:1; }
.match-club.away { flex-direction:row-reverse; }
.match-club-logo { height:40px; width:40px; object-fit:contain; }
.match-club-name { font-family:var(--font-head); font-size:20px; font-weight:700; }
.match-score-big { font-family:var(--font-mono); font-size:38px; font-weight:700; color:var(--neon); min-width:110px; text-align:center; text-shadow:var(--neon-glow); }
.match-card-footer { display:flex; align-items:center; justify-content:space-between; padding:9px 16px; background:var(--bg3); font-size:12px; color:var(--text2); border-top:1px solid var(--border); }
.match-btns { display:flex; gap:6px; }
.matches-list { display:flex; flex-direction:column; gap:12px; }
.page-header-player,.page-header-club { display:flex; align-items:center; gap:14px; }
.page-player-photo { height:60px; width:60px; object-fit:cover; border-radius:50%; border:2px solid var(--border3); box-shadow:0 0 12px var(--neon-dim); }
.page-club-logo { height:52px; width:52px; object-fit:contain; }
.player-pos-tags { display:flex; gap:4px; margin-top:4px; }
.club-pill { display:inline-block; font-size:11px; padding:1px 7px; background:var(--neon-dim); color:var(--neon); border-radius:4px; border:1px solid rgba(0,232,138,.18); }
/* Analysis */
.analysis-layout { display:grid; grid-template-columns:1fr 420px; gap:20px; }
.analysis-events { display:flex; flex-direction:column; gap:4px; max-height:calc(100vh - 200px); overflow-y:auto; }

/* ══════════════════════════════════════════════════
   THEMES — Light + Contrast
   Applied via data-theme attribute on <html>
══════════════════════════════════════════════════ */

/* ── LIGHT THEME ──────────────────────────────── */
[data-theme="light"] {
  --bg:        #f0f4f8;
  --bg2:       #ffffff;
  --bg3:       #e8eef5;
  --bg4:       #dde5ef;
  --bg5:       #d0dae8;
  --border:    rgba(0,100,60,.12);
  --border2:   rgba(0,100,60,.25);
  --border3:   rgba(0,100,60,.45);
  --neon:      #007a45;
  --neon2:     #009955;
  --neon-dim:  rgba(0,122,69,.10);
  --neon-glow: 0 0 10px rgba(0,122,69,.2);
  --blue:      #1a5cc8;
  --blue-dim:  rgba(26,92,200,.10);
  --red:       #cc1f35;
  --red-dim:   rgba(204,31,53,.10);
  --yellow:    #b87800;
  --yel-dim:   rgba(184,120,0,.10);
  --purple:    #7c3aed;
  --text:      #111827;
  --text2:     rgba(17,24,39,.65);
  --text3:     rgba(17,24,39,.38);
  --shadow:    0 4px 20px rgba(0,0,0,.12);
  --card-shadow: 0 2px 10px rgba(0,0,0,.08), inset 0 1px 0 rgba(255,255,255,.8);
  --font:      'Outfit', system-ui, sans-serif;
  --font-head: 'Space Grotesk', 'Outfit', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}
[data-theme="light"] body {
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 80% 40% at 10% -10%, rgba(0,122,69,.04) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 110%, rgba(26,92,200,.03) 0%, transparent 60%);
  color: var(--text);
}
[data-theme="light"] .navbar {
  background: rgba(255,255,255,.97);
  border-bottom: 1px solid var(--border2);
  box-shadow: 0 1px 0 var(--border), 0 4px 16px rgba(0,0,0,.08);
}
[data-theme="light"] .nav-title {
  background: linear-gradient(90deg, var(--neon), var(--blue));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
[data-theme="light"] .nav-link:hover,
[data-theme="light"] .nav-link.active { background: var(--neon-dim); color: var(--neon); }
[data-theme="light"] .form-input,
[data-theme="light"] .form-select { background: #fff; border-color: #c5d0e0; color: var(--text); }
[data-theme="light"] .form-input:focus,
[data-theme="light"] .form-select:focus { border-color: var(--neon); }
[data-theme="light"] .modal-box {
  background: linear-gradient(165deg, #fff 0%, #f5f8ff 100%);
  border-color: var(--border2);
}
[data-theme="light"] .stat-value { color: var(--neon); }
[data-theme="light"] .mc-score { color: var(--neon); text-shadow: none; }
[data-theme="light"] .login-card {
  background: rgba(255,255,255,.97);
  box-shadow: 0 0 40px rgba(0,122,69,.06), 0 16px 48px rgba(0,0,0,.1);
}
[data-theme="light"] .login-body { background: #e8f0f8; }
[data-theme="light"] .login-grid {
  background-image: linear-gradient(rgba(0,122,69,.06) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(0,122,69,.06) 1px, transparent 1px);
  background-size: 48px 48px;
}
[data-theme="light"] ::-webkit-scrollbar-track { background: #e8eef5; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: #c5d0e0; }
[data-theme="light"] .pb-tooltip { color: #ffffff; }

/* ── CONTRAST (HIGH CONTRAST BLACK/WHITE) THEME ── */
[data-theme="contrast"] {
  --bg:        #000000;
  --bg2:       #0a0a0a;
  --bg3:       #141414;
  --bg4:       #1e1e1e;
  --bg5:       #282828;
  --border:    rgba(255,255,255,.15);
  --border2:   rgba(255,255,255,.35);
  --border3:   rgba(255,255,255,.60);
  --neon:      #ffffff;
  --neon2:     #ffffff;
  --neon-dim:  rgba(255,255,255,.10);
  --neon-glow: 0 0 8px rgba(255,255,255,.4);
  --blue:      #7eb8ff;
  --blue-dim:  rgba(126,184,255,.12);
  --red:       #ff6b6b;
  --red-dim:   rgba(255,107,107,.12);
  --yellow:    #ffe066;
  --yel-dim:   rgba(255,224,102,.10);
  --purple:    #d4a8ff;
  --text:      #ffffff;
  --text2:     rgba(255,255,255,.75);
  --text3:     rgba(255,255,255,.45);
  --shadow:    0 4px 20px rgba(0,0,0,.9);
  --card-shadow: 0 2px 16px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.05);
  --radius:    6px;
}
[data-theme="contrast"] body {
  background: #000;
  background-image: none;
  font-weight: 500;  /* heavier base weight */
}
[data-theme="contrast"] .navbar {
  background: #000;
  border-bottom: 2px solid rgba(255,255,255,.4);
  box-shadow: none;
}
[data-theme="contrast"] .nav-title { color: #fff; background:none; -webkit-text-fill-color:#fff; }
[data-theme="contrast"] .nav-link { font-weight: 600; }
[data-theme="contrast"] .nav-link:hover,
[data-theme="contrast"] .nav-link.active {
  background: rgba(255,255,255,.08);
  color: #fff;
  border-bottom-color: #fff;
}
[data-theme="contrast"] .page-title { font-weight: 900; letter-spacing: -.5px; }
[data-theme="contrast"] .card-title { color: #fff; font-weight: 800; letter-spacing: .5px; }
[data-theme="contrast"] .btn-primary {
  background: #fff; color: #000; font-weight: 800;
  box-shadow: none;
}
[data-theme="contrast"] .btn-primary:hover { background: #e0e0e0; }
[data-theme="contrast"] .btn-ghost { border-color: rgba(255,255,255,.4); color: #fff; }
[data-theme="contrast"] .form-input,
[data-theme="contrast"] .form-select {
  background: #0a0a0a; border:2px solid rgba(255,255,255,.4); color:#fff;
  font-weight: 600;
}
[data-theme="contrast"] .form-input:focus,
[data-theme="contrast"] .form-select:focus { border-color: #fff; box-shadow: 0 0 0 2px rgba(255,255,255,.2); }
[data-theme="contrast"] .data-table th { color: #fff; font-weight: 800; border-bottom: 2px solid rgba(255,255,255,.3); }
[data-theme="contrast"] .data-table tr:hover td { background: rgba(255,255,255,.05); }
[data-theme="contrast"] .stat-value,
[data-theme="contrast"] .mc-score { color: #fff; text-shadow: none; font-weight: 900; }
[data-theme="contrast"] .pos-badge { background: rgba(255,255,255,.1); color:#fff; border-color: rgba(255,255,255,.3); }
[data-theme="contrast"] .badge { background: rgba(255,255,255,.1); color:#fff; }
[data-theme="contrast"] .modal-box { background: #0a0a0a; border: 2px solid rgba(255,255,255,.4); }
[data-theme="contrast"] .match-card { border: 1px solid rgba(255,255,255,.2); }
[data-theme="contrast"] .match-card:hover { border-color: rgba(255,255,255,.6); }
[data-theme="contrast"] .match-score-big { color: #fff; font-weight: 900; text-shadow: none; }
[data-theme="contrast"] .mc-ev-btn { border-color: rgba(255,255,255,.2); font-weight: 700; }
[data-theme="contrast"] .mc-ev-btn:hover { background: rgba(255,255,255,.08); }
[data-theme="contrast"] .btn-goal { border-color: rgba(255,255,255,.4) !important; color: #fff !important; }
[data-theme="contrast"] .login-card { background: #000; border: 2px solid rgba(255,255,255,.5); }
[data-theme="contrast"] .login-title { color:#fff; background:none; -webkit-text-fill-color:#fff; }
[data-theme="contrast"] .login-body { background: #000; }
[data-theme="contrast"] .login-grid {
  background-image: linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 48px 48px;
}
[data-theme="contrast"] ::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); }
[data-theme="contrast"] .marker-minute { color: #fff; }
[data-theme="contrast"] .mc-stat-home { color: #fff; }
[data-theme="contrast"] .mc-stat-away { color: #7eb8ff; }

/* ── THEME SELECTOR (login page) ──────────────────────────────── */
.theme-selector {
  margin-top:24px; padding-top:20px; border-top:1px solid var(--border2);
}
.theme-selector-label {
  font-size:11px; color:var(--text3); text-transform:uppercase;
  letter-spacing:1px; font-weight:700; font-family:var(--font-head);
  margin-bottom:10px; text-align:center;
}
.theme-options { display:flex; gap:10px; justify-content:center; }
.theme-btn {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  background:var(--bg3); border:2px solid var(--border);
  border-radius:8px; padding:10px 14px; cursor:pointer; transition:all .18s;
  color:var(--text2); font-size:11px; font-weight:600; font-family:var(--font);
  min-width:72px;
}
.theme-btn:hover { border-color:var(--border2); background:var(--bg4); }
.theme-btn.active { border-color:var(--neon); color:var(--neon); background:var(--neon-dim); }
.theme-preview {
  width:40px; height:26px; border-radius:4px; border:1px solid rgba(255,255,255,.15);
}
.theme-preview-dark {
  background:linear-gradient(135deg,#060a10 50%,#00e88a 50%);
}
.theme-preview-light {
  background:linear-gradient(135deg,#f0f4f8 50%,#007a45 50%);
  border-color:rgba(0,0,0,.15);
}
.theme-preview-contrast {
  background:linear-gradient(135deg,#000 50%,#fff 50%);
}

/* ── THEME TOGGLE BUTTON (navbar) ─────────────────────────────── */
.theme-toggle-btn {
  background:var(--bg3); border:1px solid var(--border2);
  color:var(--text2); border-radius:6px; padding:5px 9px;
  cursor:pointer; font-size:14px; transition:all .18s;
  line-height:1;
}
.theme-toggle-btn:hover { background:var(--bg4); border-color:var(--border3); color:var(--text); }

/* ── ACTIVE BROADCAST state ───────────────────────────────────── */
.marker-btn.active-broadcast {
  background: var(--red-dim) !important; color: var(--red) !important;
  border-color: var(--red) !important;
}
