/* =====================================================
   ROCKMOUNT LUNCHTIME LEAGUE — style.css
   Shared styles across all pages
===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

/* ---- Variables ---- */
:root {
  --bg:         #070707;
  --bg-raised:  #0f0f0f;
  --bg-card:    #161616;
  --bg-card-hv: #1c1c1c;

  --text:        #f0f0f0;
  --text-muted:  rgba(240,240,240,0.5);
  --text-dim:    rgba(240,240,240,0.2);

  --border:      rgba(255,255,255,0.07);
  --border-md:   rgba(255,255,255,0.12);

  --sylvans:       #e63030;
  --sylvans-lt:    #ff5555;
  --sylvans-glow:  rgba(230, 48, 48, 0.5);

  --cpfc:          #1a6dd4;
  --cpfc-lt:       #4090ff;
  --cpfc-glow:     rgba(26, 109, 212, 0.5);

  --gold:      #f5c842;
  --gold-glow: rgba(245, 200, 66, 0.35);
  --green:     #2ed573;
  --red-soft:  #ff4757;

  /* Team override — set per page */
  --team-color: var(--sylvans);
  --team-glow:  var(--sylvans-glow);
  --team-lt:    var(--sylvans-lt);

  --nav-h:      64px;
  --pad-x:      clamp(20px, 4vw, 64px);
  --section-py: clamp(64px, 9vw, 120px);
  --radius:     8px;
  --radius-lg:  14px;

  --font-d: 'Bebas Neue', 'Impact', sans-serif;
  --font-b: 'DM Sans', 'Helvetica Neue', sans-serif;

  --ease:        cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t:  0.3s;
  --ts: 0.6s;
}

/* ---- Reset ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-b);
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color:inherit; text-decoration:none; }
img, svg { display:block; max-width:100%; }
button { cursor:pointer; border:none; background:none; font:inherit; }

/* ---- Page Transition Overlay ---- */
.page-transition {
  position: fixed; inset: 0;
  background: #000;
  z-index: 9999;
  pointer-events: none;
  transform: translateY(0%);
  transition: transform 0.55s var(--ease);
}
.page-transition.out  { transform: translateY(-100%); }
.page-transition.prep { transform: translateY(-100%); transition: none; }
.page-transition.in   { transform: translateY(0%); transition: transform 0.45s var(--ease); }

/* ---- Navigation ---- */
.nav {
  position: fixed; top:0; left:0; right:0;
  height: var(--nav-h);
  z-index: 100;
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 var(--pad-x);
  background: rgba(7,7,7,0.8);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--border);
  transition: background var(--t) var(--ease);
}
.nav.scrolled { background: rgba(7,7,7,0.97); }

.nav__logo {
  font-family: var(--font-d);
  font-size: 1.45rem;
  letter-spacing: 0.15em;
  position: relative;
}
.nav__logo::after {
  content: '';
  position: absolute;
  bottom: -3px; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--sylvans), var(--cpfc));
  border-radius: 2px;
}

.nav__links { display:flex; list-style:none; gap:clamp(14px,2.5vw,36px); align-items:center; }

.nav__link {
  font-size: 0.8rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform:uppercase;
  color: var(--text-muted);
  transition: color var(--t) var(--ease);
  position: relative;
}
.nav__link::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:1px; background:var(--text);
  transform:scaleX(0); transition:transform var(--t) var(--ease);
  transform-origin: left;
}
.nav__link:hover, .nav__link.active { color:var(--text); }
.nav__link:hover::after, .nav__link.active::after { transform:scaleX(1); }

.nav__toggle {
  display:none; flex-direction:column; gap:5px; padding:4px;
  z-index:10;
}
.nav__toggle span {
  display:block; width:24px; height:2px;
  background:var(--text); border-radius:2px;
  transition: var(--t) var(--ease);
}
.nav__toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav__toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---- Container ---- */
.container { width:100%; max-width:1100px; margin:0 auto; padding:0 var(--pad-x); }

/* ---- Section ---- */
.section { padding: var(--section-py) 0; position:relative; }
.section + .section::before {
  content:''; display:block; height:1px;
  background: var(--border);
  position:absolute; top:0; left:var(--pad-x); right:var(--pad-x);
}

.section-title {
  font-family: var(--font-d);
  font-size: clamp(2rem,5vw,3.5rem);
  letter-spacing: 0.05em; line-height:1;
  margin-bottom: clamp(24px,4vw,48px);
}
.section-title span { color: var(--text-muted); }

/* ---- Reveal ---- */
.reveal {
  opacity:0; transform:translateY(28px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* =====================================================
   HERO (Home page)
===================================================== */
.hero {
  min-height: 100svh;
  display:flex; flex-direction:column;
  justify-content:center; align-items:center;
  padding: calc(var(--nav-h) + 40px) var(--pad-x) 60px;
  position:relative; overflow:hidden; text-align:center;
}

/* Multi-layer atmospheric background */
.hero__bg {
  position:absolute; inset:0; z-index:0;
  background: var(--bg);
}
.hero__bg::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 72px 72px;
}
.hero__bg::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 55% 45% at 15% 50%, rgba(230,48,48,0.065) 0%, transparent 65%),
    radial-gradient(ellipse 55% 45% at 85% 50%, rgba(26,109,212,0.065) 0%, transparent 65%),
    radial-gradient(ellipse 40% 60% at 50% 110%, rgba(0,0,0,0.9) 0%, transparent 60%);
}

.hero__content {
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center;
  gap: 28px; width:100%; max-width:960px;
}

.hero__eyebrow {
  font-size: 0.75rem; font-weight:700;
  letter-spacing: 0.28em; text-transform:uppercase;
  color: var(--text-muted);
  border: 1px solid var(--border-md);
  padding: 6px 18px; border-radius:100px;
}

.hero__title {
  font-family: var(--font-d);
  font-size: clamp(3.2rem, 10vw, 9rem);
  line-height: 0.88; letter-spacing: 0.04em;
  background: linear-gradient(175deg, #fff 0%, rgba(255,255,255,0.62) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color:transparent;
  background-clip: text;
}

/* ---- Hero Teams ---- */
.hero__teams {
  display:flex; align-items:center; justify-content:center;
  gap: clamp(20px, 5vw, 80px); width:100%;
  margin-top: 8px;
}

.hero__team {
  display:flex; flex-direction:column; align-items:center;
  gap:10px; text-decoration:none;
  transition: transform var(--t) var(--ease);
}
.hero__team:hover { transform:translateY(-4px); }

.team-logo {
  width: clamp(88px, 14vw, 134px);
  flex-shrink: 0;
}

.team-logo--sylvans {
  filter: drop-shadow(0 10px 32px rgba(230,48,48,0.35));
  animation: floatLogo 4s ease-in-out infinite, glowSylvans 3.5s ease-in-out infinite;
}
.team-logo--cpfc {
  filter: drop-shadow(0 10px 32px rgba(26,109,212,0.35));
  animation: floatLogo 4s ease-in-out infinite 0.7s, glowCPFC 3.5s ease-in-out infinite 0.7s;
}

.hero__team-name {
  font-family: var(--font-d);
  font-size: clamp(0.95rem, 2.2vw, 1.35rem);
  letter-spacing: 0.1em; color: var(--text-muted);
}
.hero__team-pts {
  font-family: var(--font-d);
  font-size: clamp(2.8rem, 6.5vw, 5rem);
  line-height: 1; letter-spacing: 0.02em;
}
.hero__team--sylvans .hero__team-pts {
  color: var(--sylvans);
  text-shadow: 0 0 40px var(--sylvans-glow);
}
.hero__team--cpfc .hero__team-pts {
  color: var(--cpfc);
  text-shadow: 0 0 40px var(--cpfc-glow);
}
.hero__pts-label {
  font-size:0.65rem; font-weight:700;
  letter-spacing:0.22em; text-transform:uppercase;
  color: var(--text-dim); margin-top:-4px;
}

.hero__vs {
  display:flex; flex-direction:column; align-items:center; gap:10px;
  padding: 0 4px;
}
.hero__vs > span {
  font-family: var(--font-d);
  font-size: clamp(1rem, 2.5vw, 1.8rem);
  letter-spacing: 0.2em; color: var(--text-dim);
}
.hero__vs-line {
  width:1px; height:55px;
  background: linear-gradient(180deg, transparent, var(--border-md), transparent);
}

/* Scroll hint */
.hero__scroll {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:7px;
  z-index:1;
}
.hero__scroll > span { font-size:0.6rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--text-dim); }
.hero__scroll-arrow {
  width:18px; height:18px;
  border-right: 1px solid var(--text-dim);
  border-bottom: 1px solid var(--text-dim);
  transform: rotate(45deg);
  animation: scrollBounce 2.2s ease-in-out infinite;
}

/* =====================================================
   STANDINGS TABLE
===================================================== */
.standings-table {
  width:100%; border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow:hidden;
  background: var(--bg-card);
}
.standings-table__header {
  display:grid;
  grid-template-columns: 1fr repeat(8, 44px);
  padding: 11px 20px;
  background: rgba(255,255,255,0.035);
  border-bottom: 1px solid var(--border);
  font-size:0.68rem; font-weight:700;
  letter-spacing:0.14em; text-transform:uppercase;
  color: var(--text-muted); gap:4px;
}
.standings-row {
  display:grid;
  grid-template-columns: 1fr repeat(8, 44px);
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  align-items:center; gap:4px;
  transition: background var(--t) var(--ease);
  position: relative;
}
.standings-row:last-child { border-bottom:none; }
.standings-row:hover { background: rgba(255,255,255,0.02); }

.standings-row--1st { border-left: 3px solid var(--sylvans); padding-left:17px; }
.standings-row--2nd { border-left: 3px solid var(--cpfc);    padding-left:17px; }

.standings-team {
  display:flex; align-items:center; gap:10px;
  font-weight:600; font-size:0.95rem;
}
.standings-dot {
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
}
.standings-row--1st .standings-dot { background:var(--sylvans); box-shadow:0 0 8px var(--sylvans-glow); }
.standings-row--2nd .standings-dot { background:var(--cpfc);    box-shadow:0 0 8px var(--cpfc-glow);    }

.standings-pts {
  font-family: var(--font-d);
  font-size:1.2rem; letter-spacing:0.05em;
}
.standings-row--1st .standings-pts { color: var(--sylvans); }
.standings-row--2nd .standings-pts { color: var(--cpfc);    }

/* =====================================================
   MATCH CARD
===================================================== */
.match-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow:hidden;
}
.match-card__date {
  padding: 12px 24px;
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid var(--border);
  font-size:0.72rem; font-weight:700;
  letter-spacing:0.16em; text-transform:uppercase;
  color: var(--text-muted);
}
.match-card__body {
  padding: 36px 24px;
  display:flex; align-items:center;
  justify-content:center;
  gap: clamp(16px, 4vw, 64px);
  flex-wrap:wrap;
}
.match-card__team {
  display:flex; flex-direction:column; align-items:center;
  gap:6px; flex:1; min-width:110px;
}
.match-card__team-name {
  font-family: var(--font-d);
  font-size: clamp(1.1rem, 2.6vw, 1.7rem);
  letter-spacing:0.08em; text-align:center;
}
.match-card__score-block {
  display:flex; align-items:center; gap:14px; flex-shrink:0;
}
.match-card__score {
  font-family: var(--font-d);
  font-size: clamp(3.5rem, 8vw, 6.5rem);
  line-height:1; letter-spacing:0.02em;
}
.match-card__score-sep {
  font-family: var(--font-d);
  font-size: clamp(1.5rem, 4vw, 3rem);
  color: var(--text-dim); line-height:1;
}
.match-card__motm {
  padding: 15px 24px;
  background: rgba(245,200,66,0.05);
  border-top: 1px solid rgba(245,200,66,0.15);
  display:flex; align-items:center; gap:10px;
  flex-wrap:wrap;
}
.match-card__motm-label {
  font-size:0.68rem; font-weight:700;
  letter-spacing:0.2em; text-transform:uppercase;
  color: var(--gold);
}
.match-card__motm-name { font-weight:600; }

/* =====================================================
   COMPARISON BAR
===================================================== */
.comparison-bar {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  display:flex; flex-direction:column; gap:18px;
}
.comparison-bar__row {
  display:flex; align-items:center; gap:16px;
}
.comparison-bar__team {
  width: 88px; flex-shrink:0;
  font-family: var(--font-d);
  font-size:1.05rem; letter-spacing:0.06em;
}
.comparison-bar__track {
  flex:1; height:8px;
  background: rgba(255,255,255,0.06);
  border-radius:100px; overflow:hidden;
}
.comparison-bar__fill {
  height:100%; border-radius:100px;
  width:0%; transition: width 1.3s var(--ease);
}
.comparison-bar__row--sylvans .comparison-bar__fill {
  background: linear-gradient(90deg, var(--sylvans), var(--sylvans-lt));
  box-shadow: 0 0 16px var(--sylvans-glow);
}
.comparison-bar__row--cpfc .comparison-bar__fill {
  background: linear-gradient(90deg, var(--cpfc), var(--cpfc-lt));
  box-shadow: 0 0 16px var(--cpfc-glow);
}
.comparison-bar__value {
  width:44px; text-align:right;
  font-family: var(--font-d); font-size:1.5rem; letter-spacing:0.05em;
}
.comparison-bar__row--sylvans .comparison-bar__value { color:var(--sylvans); }
.comparison-bar__row--cpfc   .comparison-bar__value { color:var(--cpfc);    }

/* =====================================================
   TEAM PAGE — Hero
===================================================== */
.team-hero {
  min-height: 72vh;
  display:flex; align-items:center;
  padding: calc(var(--nav-h) + 64px) var(--pad-x) 64px;
  position:relative; overflow:hidden;
}
.team-hero__bg { position:absolute; inset:0; z-index:0; background:var(--bg); }
.team-hero__bg::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 72px 72px;
}
/* Team color glow — overridden per page */
.team-hero__bg::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 8% 50%, rgba(230,48,48,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 30% 70% at 90% 20%, rgba(230,48,48,0.04) 0%, transparent 60%);
}

.team-hero__content {
  position:relative; z-index:1;
  display:flex; align-items:center;
  gap: clamp(40px, 7vw, 110px);
  width:100%; max-width:1100px; margin:0 auto;
}

.team-hero__logo {
  width: clamp(120px, 18vw, 200px);
  flex-shrink:0;
  animation: floatLogo 4s ease-in-out infinite;
}

.team-hero__info { flex:1; }

.team-hero__eyebrow {
  display:block; margin-bottom:14px;
  font-size:0.75rem; font-weight:700;
  letter-spacing:0.25em; text-transform:uppercase;
  color: var(--team-color);
}
.team-hero__name {
  font-family: var(--font-d);
  font-size: clamp(2.8rem, 8vw, 7rem);
  line-height:0.88; letter-spacing:0.04em;
  margin-bottom: 24px;
}

.team-hero__stats { display:flex; gap:32px; flex-wrap:wrap; }

.team-stat { display:flex; flex-direction:column; gap:3px; }
.team-stat__val {
  font-family: var(--font-d);
  font-size: 2.5rem; line-height:1;
  letter-spacing:0.05em; color: var(--team-color);
}
.team-stat__lbl {
  font-size:0.68rem; font-weight:700;
  letter-spacing:0.18em; text-transform:uppercase;
  color: var(--text-muted);
}

/* Form Guide */
.form-guide { display:flex; gap:8px; margin-top:22px; }
.form-badge {
  width:32px; height:32px;
  display:flex; align-items:center; justify-content:center;
  border-radius:6px; font-size:0.75rem; font-weight:700;
}
.form-badge--W { background:rgba(46,213,115,0.12); color:var(--green); border:1px solid rgba(46,213,115,0.28); }
.form-badge--L { background:rgba(255,71,87,0.12);  color:var(--red-soft); border:1px solid rgba(255,71,87,0.28); }
.form-badge--D { background:rgba(255,255,255,0.06); color:var(--text-muted); border:1px solid var(--border); }

/* =====================================================
   MATCH HISTORY LIST
===================================================== */
.history-list { display:flex; flex-direction:column; gap:10px; }

.history-match {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 22px;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: auto auto;
  align-items:center; gap:12px 16px;
  transition: background var(--t) var(--ease), border-color var(--t) var(--ease);
}
.history-match:hover { background:var(--bg-card-hv); border-color:var(--border-md); }

.history-match__team { font-weight:600; font-size:0.93rem; }
.history-match__team--home { text-align:right; }
.history-match__team--away { text-align:left;  }

.history-match__score {
  display:flex; align-items:center; gap:8px; flex-shrink:0;
}
.history-match__score-num {
  font-family: var(--font-d); font-size:2rem;
  letter-spacing:0.05em; line-height:1;
  min-width:26px; text-align:center;
}
.history-match__score-sep { color:var(--text-dim); font-family:var(--font-d); font-size:1.3rem; }

.history-match__meta {
  grid-column: 1/-1;
  display:flex; align-items:center; justify-content:space-between;
  padding-top:10px; border-top:1px solid var(--border);
  gap:12px; flex-wrap:wrap;
}
.history-match__motm { display:flex; align-items:center; gap:6px; font-size:0.82rem; color:var(--gold); }
.history-match__date { font-size:0.73rem; font-weight:600; letter-spacing:0.07em; color:var(--text-muted); }
.history-match__result {
  font-size:0.68rem; font-weight:800; letter-spacing:0.15em; text-transform:uppercase;
}

/* =====================================================
   MOTM LEADERBOARD
===================================================== */
.motm-list { display:flex; flex-direction:column; gap:8px; }
.motm-row {
  display:flex; align-items:center; gap:16px;
  padding:14px 20px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius);
  transition: background var(--t) var(--ease);
}
.motm-row:hover { background:var(--bg-card-hv); }
.motm-rank {
  font-family: var(--font-d); font-size:1.3rem;
  letter-spacing:0.05em; color:var(--text-muted);
  width:32px;
}
.motm-row:first-child .motm-rank { color:var(--gold); }
.motm-name  { flex:1; font-weight:600; }
.motm-count { font-family:var(--font-d); font-size:1rem; color:var(--gold); }

/* =====================================================
   ABOUT PAGE
===================================================== */
.about-hero {
  padding: calc(var(--nav-h) + 88px) var(--pad-x) 88px;
  text-align:center; position:relative; overflow:hidden;
}
.about-hero::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 72px 72px;
}
.about-hero::after {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse 80% 55% at 50% 110%, rgba(0,0,0,0.85) 0%, transparent 65%);
}
.about-hero__inner { position:relative; z-index:1; max-width:720px; margin:0 auto; }
.about-hero__title {
  font-family:var(--font-d); font-size:clamp(2.5rem,7vw,6.5rem);
  letter-spacing:0.04em; line-height:0.92; margin-bottom:22px;
}
.about-hero__sub { font-size:1.1rem; line-height:1.75; color:var(--text-muted); }

.about-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:20px;
}
.about-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  transition: border-color var(--t), background var(--t);
}
.about-card:hover { border-color:var(--border-md); background:var(--bg-card-hv); }
.about-card__icon { font-size:2rem; margin-bottom:14px; }
.about-card__title { font-family:var(--font-d); font-size:1.5rem; letter-spacing:0.06em; margin-bottom:10px; }
.about-card__text  { font-size:0.9rem; line-height:1.75; color:var(--text-muted); }

.team-cards { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.team-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:32px;
  position:relative; overflow:hidden;
  transition: transform var(--t) var(--ease), border-color var(--t) var(--ease);
  display:block; text-decoration:none;
}
.team-card:hover { transform:translateY(-5px); }
.team-card--sylvans { border-color:rgba(230,48,48,0.25); }
.team-card--sylvans:hover { border-color:var(--sylvans); }
.team-card--cpfc { border-color:rgba(26,109,212,0.25); }
.team-card--cpfc:hover { border-color:var(--cpfc); }

.team-card__glow {
  position:absolute; bottom:-50px; right:-50px;
  width:220px; height:220px; border-radius:50%; opacity:0.07;
  transition: opacity var(--t);
}
.team-card:hover .team-card__glow { opacity:0.17; }
.team-card--sylvans .team-card__glow { background:var(--sylvans); }
.team-card--cpfc    .team-card__glow { background:var(--cpfc);    }

.team-card__name { font-family:var(--font-d); font-size:2rem; letter-spacing:0.06em; margin-bottom:8px; }
.team-card--sylvans .team-card__name { color:var(--sylvans); }
.team-card--cpfc    .team-card__name { color:var(--cpfc);    }
.team-card__desc { font-size:0.9rem; line-height:1.7; color:var(--text-muted); }
.team-card__cta  { margin-top:16px; font-size:0.8rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted); }

/* =====================================================
   FOOTER
===================================================== */
.footer {
  border-top:1px solid var(--border);
  padding: 32px var(--pad-x);
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:16px;
}
.footer p { font-size:0.84rem; color:var(--text-muted); }
.footer__links { display:flex; gap:24px; }
.footer__links a { font-size:0.84rem; color:var(--text-muted); transition:color var(--t); }
.footer__links a:hover { color:var(--text); }

/* ---- Loading state ---- */
.loading {
  display:flex; align-items:center; justify-content:center;
  padding:50px; color:var(--text-muted); font-size:0.85rem;
  letter-spacing:0.1em; text-transform:uppercase; gap:12px;
}
.loading::before {
  content:''; width:18px; height:18px;
  border:2px solid var(--border-md);
  border-top-color:var(--text-muted);
  border-radius:50%; animation:spin 0.75s linear infinite;
  flex-shrink:0;
}

/* Utility */
.text-sylvans { color:var(--sylvans); }
.text-cpfc    { color:var(--cpfc);    }
.text-gold    { color:var(--gold);    }
.text-muted   { color:var(--text-muted); }

/* =====================================================
   KEYFRAMES
===================================================== */
@keyframes floatLogo {
  0%,100% { transform:translateY(0px); }
  50%      { transform:translateY(-14px); }
}
@keyframes glowSylvans {
  0%,100% { filter:drop-shadow(0 10px 32px rgba(230,48,48,0.32)); }
  50%     { filter:drop-shadow(0 10px 55px rgba(230,48,48,0.72)); }
}
@keyframes glowCPFC {
  0%,100% { filter:drop-shadow(0 10px 32px rgba(26,109,212,0.32)); }
  50%     { filter:drop-shadow(0 10px 55px rgba(26,109,212,0.72)); }
}
@keyframes scrollBounce {
  0%,100% { transform:rotate(45deg) translateY(0); }
  50%     { transform:rotate(45deg) translateY(6px); }
}
@keyframes spin { to { transform:rotate(360deg); } }

/* =====================================================
   RESPONSIVE
===================================================== */
@media (max-width: 768px) {
  .nav__links {
    display:none; position:fixed;
    top:var(--nav-h); left:0; right:0;
    background:rgba(7,7,7,0.98);
    flex-direction:column; padding:20px var(--pad-x);
    gap:2px; border-bottom:1px solid var(--border);
  }
  .nav__links.open { display:flex; }
  .nav__toggle { display:flex; }
  .nav__link { padding:12px 0; font-size:0.95rem; }

  .standings-table__header,
  .standings-row {
    grid-template-columns: 1fr repeat(5, 36px);
    font-size:0.8rem;
  }
  /* Hide GD, D, L columns on tiny screens */
  .standings-table__header span:nth-child(5),
  .standings-table__header span:nth-child(8),
  .standings-row > span:nth-child(5),
  .standings-row > span:nth-child(8) { display:none; }

  .team-hero__content { flex-direction:column; text-align:center; }
  .team-hero__stats   { justify-content:center; }
  .team-hero__logo    { width:clamp(100px,32vw,160px); }

  .comparison-bar__team { width:62px; font-size:0.9rem; }

  .team-cards { grid-template-columns:1fr; }

  .footer { flex-direction:column; align-items:center; text-align:center; }

  .match-card__body { flex-direction:column; gap:20px; }
  .match-card__team { flex-direction:row; gap:12px; }
}

@media (max-width: 480px) {
  .hero__teams { gap:14px; }
  .history-match { padding:14px 16px; gap:10px; }
}
