:root {
  --red: #e2001a;
  --red-dark: #b5001a;
  --red-soft: rgba(226, 0, 26, 0.12);
  --red-glow: rgba(226, 0, 26, 0.3);
  --white: #ffffff;
  --transition: 0.3s ease;
  --radius: 12px;
  --radius-sm: 8px;
}
[data-theme="dark"] {
  --bg: #0a0a0a;
  --bg-card: #111111;
  --bg-card-2: #161616;
  --bg-elevated: #1a1a1a;
  --border: rgba(255,255,255,0.06);
  --border-strong: rgba(255,255,255,0.12);
  --text: #d4d4d4;
  --text-muted: #888;
  --text-secondary: #999;
  --text-bright: #ffffff;
  --nav-bg: rgba(10,10,10,0.92);
  --shadow: 0 4px 24px rgba(0,0,0,0.5);
  --shadow-red: 0 4px 24px rgba(226,0,26,0.2);
}
[data-theme="light"] {
  --bg: #f0f0f0;
  --bg-card: #ffffff;
  --bg-card-2: #f8f8f8;
  --bg-elevated: #ececec;
  --border: rgba(0,0,0,0.08);
  --border-strong: rgba(0,0,0,0.15);
  --text: #333333;
  --text-muted: #888;
  --text-secondary: #555;
  --text-bright: #111111;
  --nav-bg: rgba(240,240,240,0.95);
  --shadow: 0 4px 24px rgba(0,0,0,0.1);
  --shadow-red: 0 4px 24px rgba(226,0,26,0.15);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 15px; line-height: 1.6; transition: background var(--transition), color var(--transition); }

/* ── NAV — handled by portal.css (shared nav.php) ── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }

/* ── PAGE HEADER ── */
.page-header {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  padding: 2rem 0 1.5rem;
}
.page-header-inner {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.page-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2.4rem;
  color: var(--text-bright);
  letter-spacing: 0.04em;
  line-height: 1;
}
.page-title span { color: var(--red); }
.page-subtitle { font-size: 0.85rem; color: var(--text-muted); margin-top: 0.25rem; }
.back-link { font-size: 0.85rem; color: var(--text-muted); text-decoration: none; display: flex; align-items: center; gap: 0.3rem; transition: color var(--transition); }
.back-link:hover { color: var(--red); }

/* ── SEASON SUMMARY BAR ── */
.summary-bar {
  background: var(--bg-card-2);
  border-bottom: 1px solid var(--border);
  padding: 1rem 0;
}
.summary-stats {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  align-items: center;
}
.summary-stat { text-align: center; }
.summary-stat .val {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem;
  line-height: 1;
  color: var(--text-bright);
}
.summary-stat .val.green { color: #3fb950; }
.summary-stat .val.yellow { color: #d4a017; }
.summary-stat .val.red-val { color: var(--red); }
.summary-stat .lbl { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 0.1rem; }
.summary-divider { width: 1px; height: 32px; background: var(--border-strong); }
.form-strip { display: flex; gap: 4px; align-items: center; }
.form-pip { width: 22px; height: 22px; border-radius: 4px; font-size: 0.7rem; font-weight: 700; display: flex; align-items: center; justify-content: center; color: white; }
.form-pip.W { background: #3fb950; }
.form-pip.D { background: #d4a017; }
.form-pip.L { background: var(--red); }

/* ── FILTERS ── */
.filters-bar {
  padding: 1.25rem 0;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
}
.filter-btn {
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  color: var(--text-muted);
  padding: 0.35rem 0.9rem;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition);
  font-family: inherit;
}
.filter-btn:hover { color: var(--text-bright); border-color: var(--text-muted); }
.filter-btn.active { background: var(--red); border-color: var(--red); color: white; }

/* ── RESULTS TABLE ── */
.results-section { padding: 1.5rem 0 3rem; }
.results-group { margin-bottom: 2rem; }
.group-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0;
  margin-bottom: 0.75rem;
  border-bottom: 1px solid var(--border);
}
.group-icon { font-size: 1rem; }
.group-name {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}
.group-count {
  font-size: 0.75rem;
  color: var(--text-muted);
  background: var(--border);
  padding: 0.1rem 0.5rem;
  border-radius: 10px;
}

.result-row {
  display: grid;
  grid-template-columns: 100px 1fr auto 1fr 80px 60px;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  margin-bottom: 0.4rem;
  transition: border-color var(--transition), background var(--transition);
  cursor: default;
}
.result-row:hover { border-color: var(--border-strong); background: var(--bg-elevated); }
.result-row.benfica-win { border-left: 3px solid #3fb950; }
.result-row.benfica-draw { border-left: 3px solid #d4a017; }
.result-row.benfica-loss { border-left: 3px solid var(--red); }

.match-date { font-size: 0.75rem; color: var(--text-muted); font-family: 'JetBrains Mono', monospace; }
.match-date .round { display: block; font-size: 0.7rem; color: var(--text-muted); opacity: 0.7; }

.team-home, .team-away {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.team-home { text-align: right; }
.team-away { text-align: left; }
.team-home.is-benfica, .team-away.is-benfica { color: var(--text-bright); font-weight: 700; }

.score-box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  background: var(--bg-elevated);
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  padding: 0.3rem 0.6rem;
  min-width: 64px;
}
.score-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.3rem;
  line-height: 1;
  color: var(--text-bright);
  min-width: 18px;
  text-align: center;
}
.score-sep { color: var(--text-muted); font-size: 0.9rem; }

.venue-tag {
  font-size: 0.7rem;
  font-weight: 700;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.venue-tag.home { background: var(--red-soft); color: var(--red); }
.venue-tag.away { background: var(--border); color: var(--text-muted); }

.result-badge {
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  text-align: center;
  min-width: 28px;
}
.result-badge.W { background: rgba(63,185,80,0.15); color: #3fb950; }
.result-badge.D { background: rgba(212,160,23,0.15); color: #d4a017; }
.result-badge.L { background: var(--red-soft); color: var(--red); }
.result-badge.NS { background: var(--border); color: var(--text-muted); }

/* Skeleton */
.skeleton-row {
  height: 52px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  margin-bottom: 0.4rem;
  animation: pulse 1.4s ease infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

.no-results { text-align: center; padding: 3rem; color: var(--text-muted); font-size: 0.9rem; }

/* Upcoming rows */
.result-row.upcoming { opacity: 0.75; }
.result-row.upcoming .score-box { border-style: dashed; }

/* Mobile */
@media (max-width: 640px) {
  .result-row { grid-template-columns: 70px 1fr auto 1fr 50px; gap: 0.4rem; padding: 0.6rem; }
  .result-badge { display: none; }
  .match-date .round { display: none; }
  .team-home, .team-away { font-size: 0.78rem; }
  .score-num { font-size: 1.1rem; }
  .summary-divider { display: none; }
}

/* Scroll to top */
.scroll-top { position: fixed; bottom: 1.5rem; right: 1.5rem; width: 40px; height: 40px; background: var(--red); color: white; border: none; border-radius: 50%; font-size: 1.1rem; cursor: pointer; display: none; align-items: center; justify-content: center; box-shadow: var(--shadow-red); transition: all var(--transition); z-index: 999; }
.scroll-top.visible { display: flex; }
.scroll-top:hover { transform: translateY(-2px); }
