/* =========================================================
   ROCKMOUNT LUNCHTIME LEAGUE — v2.css
   "LIQUID GLASS" DESIGN LAYER · loads after style.css
   iOS-26-style materials, aurora ambience, spring motion.
   Purely additive — original class names untouched.
========================================================= */

:root {
  /* Liquid glass material tokens */
  --glass-bg:        rgba(255,255,255,0.045);
  --glass-bg-strong: rgba(255,255,255,0.07);
  --glass-border:    rgba(255,255,255,0.10);
  --glass-border-hi: rgba(255,255,255,0.22);
  --glass-blur:      saturate(180%) blur(22px);
  --glass-blur-hv:   saturate(200%) blur(28px);
  --glass-shadow:    0 8px 32px rgba(0,0,0,0.45), 0 1px 0 rgba(255,255,255,0.06) inset, 0 -1px 0 rgba(0,0,0,0.4) inset;
  --glass-shadow-hv: 0 18px 48px rgba(0,0,0,0.55), 0 1px 0 rgba(255,255,255,0.12) inset, 0 -1px 0 rgba(0,0,0,0.4) inset;
  --spring:          cubic-bezier(0.34, 1.4, 0.4, 1);
  --spring-soft:     cubic-bezier(0.22, 1, 0.36, 1);
  --fantasy:         #a855f7;
  --fantasy-lt:      #c084fc;
  --fantasy-glow:    rgba(168,85,247,0.4);
}

/* ── Specular edge helper (top highlight like real glass) ── */
.glass-spec { position: relative; }
.glass-spec::before {
  content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background: linear-gradient(165deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.02) 28%, transparent 50%);
  z-index: 0;
}

/* =========================================================
   AURORA AMBIENT BACKGROUND  (injected by main.js)
========================================================= */
.aurora {
  position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none;
  background: var(--bg);
}
.aurora__blob {
  position: absolute; border-radius: 50%; filter: blur(110px); opacity: .16;
  will-change: transform;
}
.aurora__blob--r { width: 55vw; height: 55vw; background: var(--sylvans); top: -18vw; left: -14vw; animation: auroraDrift1 26s ease-in-out infinite; }
.aurora__blob--b { width: 55vw; height: 55vw; background: var(--cpfc); bottom: -20vw; right: -14vw; animation: auroraDrift2 32s ease-in-out infinite; }
.aurora__blob--g { width: 34vw; height: 34vw; background: var(--gold); top: 48%; left: 58%; opacity: .06; animation: auroraDrift3 38s ease-in-out infinite; }
@keyframes auroraDrift1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(9vw,7vh) scale(1.12)} 66%{transform:translate(-4vw,12vh) scale(.94)} }
@keyframes auroraDrift2 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(-10vw,-8vh) scale(1.1)} 66%{transform:translate(5vw,-14vh) scale(.92)} }
@keyframes auroraDrift3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-14vw,-10vh)} }

/* Body sits on the aurora */
body { background: transparent; }
.hero__bg, .team-hero__bg { background: transparent !important; }

/* =========================================================
   NAV → FLOATING LIQUID GLASS PILL
========================================================= */
.nav {
  top: 10px; left: 10px; right: 10px; height: var(--nav-h);
  border-radius: 18px;
  background: rgba(14,14,16,0.55);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
  transition: background .4s var(--spring-soft), box-shadow .4s var(--spring-soft), border-color .4s, transform .35s var(--spring-soft);
}
.nav.scrolled {
  background: rgba(10,10,12,0.78);
  border-color: var(--glass-border-hi);
  box-shadow: 0 14px 44px rgba(0,0,0,0.6), 0 1px 0 rgba(255,255,255,0.1) inset;
}
.nav::after {
  content:''; position:absolute; top:0; left:8%; right:8%; height:1px; border-radius:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent);
  opacity:.5; pointer-events:none;
}
.nav__dropdown {
  background: rgba(16,16,18,0.82) !important;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border-hi) !important;
  border-radius: 14px !important;
  box-shadow: var(--glass-shadow);
  overflow: hidden;
}
/* Mobile slide-down menu */
@media (max-width: 640px) {
  .nav__links.open {
    background: rgba(10,10,12,0.92) !important;
    backdrop-filter: var(--glass-blur-hv);
    -webkit-backdrop-filter: var(--glass-blur-hv);
    border: 1px solid var(--glass-border);
    border-radius: 18px;
    box-shadow: var(--glass-shadow);
  }
}

/* =========================================================
   CARD SURFACES → GLASS  (every existing card class)
========================================================= */
.match-card, .comparison-bar, .standings-table, .history-match,
.squad-card, .top-scorer-card, .motm-row, .scorer-lb-item,
.about-card, .team-card, .stats-table, .players-hero__stat,
.stats-strip__item, .history-stat-card, .summary-chip,
.auth-panel, .picker-card, .squad-player-card, .fantasy-lb-row,
.fantasy-chip, .tv-card, .tv-featured, .chat-panel, .no-squad,
.motm-podium__card {
  background: var(--glass-bg) !important;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-color: var(--glass-border) !important;
  box-shadow: var(--glass-shadow);
  position: relative;
}
/* specular top edge on all glass cards */
.match-card::after, .standings-table::after, .top-scorer-card::after,
.auth-panel::after, .tv-featured::after {
  content:''; position:absolute; top:0; left:10%; right:10%; height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  pointer-events:none; opacity:.6;
}

/* Hover physics — lift + glow */
.history-match, .squad-card, .motm-row, .scorer-lb-item, .picker-card,
.about-card, .team-card, .tv-card, .fantasy-lb-row {
  transition: transform .45s var(--spring), box-shadow .45s var(--spring-soft),
              border-color .35s, background .35s !important;
}
@media (hover:hover) {
  .history-match:hover, .motm-row:hover, .scorer-lb-item:hover,
  .about-card:hover, .tv-card:hover, .fantasy-lb-row:hover {
    transform: translateY(-3px) scale(1.008);
    background: var(--glass-bg-strong) !important;
    border-color: var(--glass-border-hi) !important;
    box-shadow: var(--glass-shadow-hv);
  }
  .squad-card:hover { transform: translateX(6px) scale(1.01); box-shadow: var(--glass-shadow-hv); }
  .picker-card:hover:not(.maxed) { transform: translateY(-4px); box-shadow: var(--glass-shadow-hv); }
}

/* Sheen sweep on hover for hero-ish cards */
.match-card, .top-scorer-card, .team-card { overflow: hidden; }
.match-card::before, .top-scorer-card::before, .team-card::before {
  content:''; position:absolute; top:-60%; left:-80%; width:60%; height:220%;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,0.06), transparent);
  transform: rotate(8deg); transition: left .9s var(--spring-soft); pointer-events:none; z-index:1;
}
.match-card:hover::before, .top-scorer-card:hover::before, .team-card:hover::before { left: 140%; }

/* =========================================================
   HERO UPGRADES
========================================================= */
.hero__title {
  background: linear-gradient(170deg,#fff 10%, rgba(255,255,255,0.45) 90%);
  -webkit-background-clip: text; background-clip: text;
  animation: heroIn 1s var(--spring-soft) both;
}
@keyframes heroIn { from { opacity:0; transform: translateY(26px) scale(.97); filter: blur(8px);} to { opacity:1; transform:none; filter:none;} }
.hero__eyebrow {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-color: var(--glass-border-hi);
  box-shadow: 0 4px 18px rgba(0,0,0,0.35), 0 1px 0 rgba(255,255,255,0.1) inset;
  animation: heroIn .9s var(--spring-soft) .05s both;
}
.hero__teams { animation: heroIn 1s var(--spring-soft) .14s both; }
.hero__team {
  border-radius: 24px; padding: clamp(14px,2.5vw,26px);
  background: transparent; border: 1px solid transparent;
  transition: transform .5s var(--spring), background .4s, border-color .4s, box-shadow .5s var(--spring-soft);
}
@media (hover:hover) {
  .hero__team:hover {
    transform: translateY(-8px) scale(1.025);
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-color: var(--glass-border);
    box-shadow: var(--glass-shadow-hv);
  }
}

/* =========================================================
   STANDINGS — animated leader row
========================================================= */
.standings-row--1st {
  background: linear-gradient(90deg, rgba(245,200,66,0.05), transparent 55%);
}
.standings-row--1st .standings-pts { animation: ptsPulse 3s ease-in-out infinite; }
@keyframes ptsPulse { 0%,100%{text-shadow:0 0 0 transparent} 50%{text-shadow:0 0 22px currentColor} }

/* =========================================================
   PLAYER AVATARS  (the new photo column, inline everywhere)
========================================================= */
.pa {
  display:inline-flex; align-items:center; gap:7px; vertical-align:middle;
}
.pa__img, .pa__fb {
  width: 36px; height: 36px; border-radius: 12px; flex-shrink:0;
  object-fit: cover; object-position: center top;
  border: 1.5px solid var(--pa-col, rgba(255,255,255,0.25));
  box-shadow: 0 0 10px var(--pa-glow, transparent), 0 2px 6px rgba(0,0,0,0.5);
  background:#101012;
  transition: transform .35s var(--spring), box-shadow .35s;
}
.pa__fb {
  display:inline-flex; align-items:center; justify-content:center;
  font-family: var(--font-d); font-size:.78rem; color: var(--pa-col, var(--text-muted));
  background: rgba(255,255,255,0.05);
}
.player-link:hover .pa__img, .player-link:hover .pa__fb { transform: scale(1.18); box-shadow: 0 0 16px var(--pa-glow, rgba(255,255,255,0.2)); }
.pa--lg .pa__img, .pa--lg .pa__fb,
.pa--lg .pa__img, .pa--lg .pa__fb { width: 52px; height: 52px; font-size:1rem; } /* was 34px */

/* =========================================================
   PLAYER POPUP v2
========================================================= */
.pp__inner {
  background: rgba(20,20,24,0.78) !important;
  backdrop-filter: var(--glass-blur-hv);
  -webkit-backdrop-filter: var(--glass-blur-hv);
  border: 1px solid var(--glass-border-hi) !important;
  box-shadow: var(--glass-shadow-hv);
}
.player-popup { width: 380px; }
.player-popup::after { border-bottom-color: rgba(24,24,28,0.95) !important; }
.player-popup.pp--above::after { border-top-color: rgba(24,24,28,0.95) !important; }

/* Layout: photo column + info column */
.pp__body { display: flex; gap: 16px; padding: 18px; align-items: flex-start; }
.pp__left { display:flex; flex-direction:column; align-items:center; gap:8px; flex-shrink:0; }
.pp__left .pp__img,
.pp__left .pp__avatar-fallback {
  width: 96px; height: 96px; border-radius: 22px;
  object-fit: cover; object-position: center top;
  border: 1px solid var(--glass-border-hi);
  box-shadow: 0 10px 28px rgba(0,0,0,0.55), 0 1px 0 rgba(255,255,255,0.14) inset;
  background: #101014;
  font-size: 2.6rem; display:flex; align-items:center; justify-content:center;
  animation: ppMediaIn .55s var(--spring) both;
}
@keyframes ppMediaIn { from { opacity:0; transform: scale(.8) rotate(-3deg);} to { opacity:1; transform:none;} }
.pp__number { font-family: var(--font-d); font-size: 1.5rem; letter-spacing: .05em; line-height: 1; }
.pp__right { flex: 1; min-width: 0; display:flex; flex-direction:column; gap:5px; }
.pp__right .pp__name { font-size: 1.6rem; }

@media (max-width: 640px) {
  .pp__body { padding: 20px 20px calc(20px + env(safe-area-inset-bottom)); }
  .pp__left .pp__img, .pp__left .pp__avatar-fallback { width: 84px; height: 84px; }
  .pp__statgrid { grid-template-columns: repeat(4,1fr); }
}

.pp__statgrid {
  display:grid; grid-template-columns: repeat(4,1fr); gap:8px; margin-top:10px;
}
.pp__statbox {
  background: rgba(255,255,255,0.045); border:1px solid var(--glass-border);
  border-radius:12px; padding:9px 4px 7px; text-align:center;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
.pp__statbox-val { font-family:var(--font-d); font-size:1.35rem; line-height:1; letter-spacing:.03em; }
.pp__statbox-lbl { font-size:.52rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); margin-top:3px; }
.pp__pos-chip {
  display:inline-block; font-size:.62rem; font-weight:800; letter-spacing:.14em;
  text-transform:uppercase; padding:3px 10px; border-radius:100px;
  background:rgba(255,255,255,0.07); border:1px solid var(--glass-border); color:var(--text-muted);
  margin-left:8px; vertical-align: middle;
}
.pp__fpts { color: var(--fantasy-lt); }

/* =========================================================
   MATCH DETAIL MODAL  (click any match)
========================================================= */
.mm-overlay {
  position: fixed; inset: 0; z-index: 1200;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  display: flex; align-items: center; justify-content: center;
  padding: 18px;
  opacity: 0; transition: opacity .35s var(--spring-soft);
}
.mm-overlay.open { opacity: 1; }
.mm {
  width: min(620px, 100%); max-height: min(86vh, 100%);
  overflow-y: auto; overscroll-behavior: contain;
  background: rgba(18,18,22,0.82);
  backdrop-filter: var(--glass-blur-hv);
  -webkit-backdrop-filter: var(--glass-blur-hv);
  border: 1px solid var(--glass-border-hi);
  border-radius: 24px;
  box-shadow: 0 32px 90px rgba(0,0,0,0.75), 0 1px 0 rgba(255,255,255,0.12) inset;
  transform: translateY(28px) scale(.96);
  opacity: 0;
  transition: transform .5s var(--spring), opacity .35s var(--spring-soft);
  position: relative;
}
.mm-overlay.open .mm { transform: none; opacity: 1; }
.mm::-webkit-scrollbar { width: 0; }
.mm__head {
  position: sticky; top:0; z-index:5;
  padding: 14px 20px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  background: rgba(18,18,22,0.8);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--glass-border);
}
.mm__head-lbl { font-size:.66rem; font-weight:800; letter-spacing:.2em; text-transform:uppercase; color:var(--text-muted); }
.mm__close {
  width:32px;height:32px;border-radius:50%; flex-shrink:0;
  background: rgba(255,255,255,0.08); border:1px solid var(--glass-border-hi);
  color:var(--text); font-size:.78rem; display:flex;align-items:center;justify-content:center;
  transition: transform .4s var(--spring), background .3s;
  -webkit-tap-highlight-color: transparent;
}
.mm__close:hover { transform: rotate(90deg) scale(1.08); background: rgba(255,255,255,0.16); }
.mm__score {
  display:flex; align-items:center; justify-content:center; gap: clamp(14px,5vw,34px);
  padding: clamp(22px,5vw,36px) 20px clamp(14px,3vw,22px);
}
.mm__score-team { display:flex; flex-direction:column; align-items:center; gap:6px; flex:1; min-width:0; }
.mm__score-name { font-family:var(--font-d); font-size:clamp(.95rem,3vw,1.3rem); letter-spacing:.06em; text-align:center; line-height:1.15; }
.mm__score-num {
  font-family:var(--font-d); font-size:clamp(3.4rem,12vw,5.4rem); line-height:1; letter-spacing:.02em;
  animation: mmNumIn .7s var(--spring) both;
}
@keyframes mmNumIn { from { opacity:0; transform: translateY(14px) scale(.8);} to { opacity:1; transform:none;} }
.mm__score-sep { font-family:var(--font-d); font-size:clamp(1.4rem,5vw,2.4rem); color:var(--text-dim); }
.mm__meta { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; padding: 0 20px 18px; }
.mm__chip {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.7rem; font-weight:700; letter-spacing:.04em;
  padding:6px 13px; border-radius:100px;
  background: rgba(255,255,255,0.06); border:1px solid var(--glass-border);
  color: var(--text-muted);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
.mm__chip--win-s { color:var(--sylvans); border-color: rgba(230,48,48,0.35); background: rgba(230,48,48,0.08); }
.mm__chip--win-c { color:var(--cpfc); border-color: rgba(26,109,212,0.35); background: rgba(26,109,212,0.08); }
.mm__chip--gold { color:var(--gold); border-color: rgba(245,200,66,0.3); background: rgba(245,200,66,0.07); }
.mm__section { padding: 16px 20px 18px; border-top: 1px solid var(--glass-border); }
.mm__section-title { font-size:.64rem; font-weight:800; letter-spacing:.2em; text-transform:uppercase; color:var(--text-muted); margin-bottom:12px; }
.mm__best {
  display:flex; align-items:center; gap:16px;
  padding:16px; border-radius:18px;
  background: linear-gradient(120deg, rgba(245,200,66,0.10), rgba(245,200,66,0.02));
  border:1px solid rgba(245,200,66,0.28);
  box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset, 0 8px 24px rgba(245,200,66,0.06);
}
.mm__best-rating {
  font-family:var(--font-d); font-size:2.6rem; line-height:1; color:var(--gold);
  text-shadow:0 0 28px var(--gold-glow); flex-shrink:0; min-width:64px; text-align:center;
}
.mm__best-rating small { display:block; font-family:var(--font-b); font-size:.5rem; font-weight:800; letter-spacing:.18em; color:var(--text-dim); margin-top:3px; }
.mm__best-name { font-weight:700; font-size:1.02rem; }
.mm__best-sub { font-size:.74rem; color:var(--text-muted); margin-top:3px; }
.mm__perf-row {
  display:flex; align-items:center; gap:12px; padding:10px 4px;
  border-bottom:1px solid var(--glass-border);
  animation: perfIn .55s var(--spring-soft) both;
}
.mm__perf-row:last-child { border-bottom:none; }
@keyframes perfIn { from { opacity:0; transform: translateX(-12px);} to { opacity:1; transform:none;} }
.mm__perf-name { flex:1; min-width:0; font-weight:600; font-size:.88rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mm__perf-stats { display:flex; gap:6px; flex-shrink:0; }
.mm__perf-pill { font-size:.66rem; font-weight:700; padding:3px 8px; border-radius:100px; background:rgba(255,255,255,0.06); border:1px solid var(--glass-border); color:var(--text-muted); white-space:nowrap; }
.mm__perf-rating { font-family:var(--font-d); font-size:1.25rem; letter-spacing:.03em; color:var(--gold); width:42px; text-align:right; flex-shrink:0; }
.mm__share-track { height:10px; border-radius:100px; overflow:hidden; display:flex; background:rgba(255,255,255,0.05); border:1px solid var(--glass-border); }
.mm__share-s { background: linear-gradient(90deg,var(--sylvans),var(--sylvans-lt)); box-shadow:0 0 14px var(--sylvans-glow); width:0%; transition: width 1.1s var(--spring-soft) .15s; }
.mm__share-c { background: linear-gradient(270deg,var(--cpfc),var(--cpfc-lt)); box-shadow:0 0 14px var(--cpfc-glow); width:0%; transition: width 1.1s var(--spring-soft) .15s; margin-left:auto; }
.mm__share-lbls { display:flex; justify-content:space-between; margin-top:8px; font-size:.66rem; font-weight:700; letter-spacing:.08em; }
body.mm-open { overflow: hidden; }

/* clickable matches */
.history-match { cursor: pointer; }
.history-match:active { transform: scale(.99); }
.mm-hint {
  font-size:.6rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase;
  color:var(--text-dim); display:inline-flex; align-items:center; gap:5px;
  transition: color .3s;
}
.history-match:hover .mm-hint { color: var(--gold); }

/* =========================================================
   SEASON IN NUMBERS — animated stat scrolly (index)
========================================================= */
.scrolly { position: relative; }
.scrolly__grid {
  display:grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,250px),1fr));
  gap: 14px;
}
.scrolly-card {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-radius: 22px;
  padding: clamp(22px,3.5vw,32px) clamp(18px,3vw,28px);
  box-shadow: var(--glass-shadow);
  position: relative; overflow: hidden;
  opacity: 0; transform: translateY(34px) scale(.96);
  transition: opacity .7s var(--spring-soft), transform .8s var(--spring), box-shadow .5s, border-color .4s;
}
.scrolly-card.on { opacity:1; transform:none; }
@media (hover:hover) { .scrolly-card:hover { transform: translateY(-5px) scale(1.01); box-shadow: var(--glass-shadow-hv); border-color: var(--glass-border-hi); } }
.scrolly-card::before {
  content:''; position:absolute; top:0; left:12%; right:12%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.32),transparent); opacity:.6;
}
.scrolly-card__icon { font-size:1.5rem; margin-bottom:10px; filter: drop-shadow(0 4px 12px rgba(0,0,0,0.4)); }
.scrolly-card__val {
  font-family:var(--font-d); font-size:clamp(2.8rem,7vw,4.2rem); line-height:1; letter-spacing:.02em;
}
.scrolly-card__lbl { font-size:.64rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); margin-top:8px; }
.scrolly-card__sub { font-size:.78rem; color:var(--text-muted); margin-top:6px; line-height:1.5; }
.scrolly-card--gold .scrolly-card__val { color:var(--gold); text-shadow:0 0 34px var(--gold-glow); }
.scrolly-card--syl  .scrolly-card__val { color:var(--sylvans); text-shadow:0 0 34px var(--sylvans-glow); }
.scrolly-card--cpfc .scrolly-card__val { color:var(--cpfc); text-shadow:0 0 34px var(--cpfc-glow); }
.scrolly-card--wide { grid-column: 1 / -1; }
.scrolly-ball {
  position:absolute; right:-14px; bottom:-14px; font-size:5rem; opacity:.05;
  animation: ballSpin 14s linear infinite;
}
@keyframes ballSpin { to { transform: rotate(360deg); } }
.scrolly-vs { display:flex; align-items:center; gap:14px; margin-top:14px; }
.scrolly-vs__bar { flex:1; height:10px; border-radius:100px; overflow:hidden; display:flex; background:rgba(255,255,255,0.05); border:1px solid var(--glass-border); }
.scrolly-vs__s { background:linear-gradient(90deg,var(--sylvans),var(--sylvans-lt)); width:0%; transition:width 1.3s var(--spring-soft) .2s; box-shadow:0 0 14px var(--sylvans-glow); }
.scrolly-vs__c { background:linear-gradient(270deg,var(--cpfc),var(--cpfc-lt)); width:0%; transition:width 1.3s var(--spring-soft) .2s; margin-left:auto; box-shadow:0 0 14px var(--cpfc-glow); }
.scrolly-vs__n { font-family:var(--font-d); font-size:1.5rem; min-width:34px; }

/* =========================================================
   LIVE TICKER — marquee of scorers / results
========================================================= */
.ticker {
  position:relative; overflow:hidden; white-space:nowrap;
  border-top:1px solid var(--glass-border); border-bottom:1px solid var(--glass-border);
  background: rgba(255,255,255,0.025);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 11px 0;
  mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.ticker__track { display:inline-flex; gap:38px; padding-right:38px; animation: tickerScroll 36s linear infinite; will-change: transform; }
.ticker:hover .ticker__track { animation-play-state: paused; }
@keyframes tickerScroll { to { transform: translateX(-50%); } }
.ticker__item { display:inline-flex; align-items:center; gap:8px; font-size:.74rem; font-weight:700; letter-spacing:.06em; color:var(--text-muted); }
.ticker__item b { color: var(--text); font-weight:800; }

/* =========================================================
   HEAD-TO-HEAD COMPARATOR  (players page)
========================================================= */
.h2h {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:22px;
  box-shadow: var(--glass-shadow);
  padding: clamp(18px,3vw,28px); position:relative; overflow:hidden;
}
.h2h__pickers { display:grid; grid-template-columns: 1fr auto 1fr; gap:12px; align-items:center; margin-bottom:18px; }
.h2h__vs { font-family:var(--font-d); font-size:1.2rem; color:var(--text-dim); letter-spacing:.15em; }
.h2h select {
  width:100%; padding:11px 14px; border-radius:14px; font:inherit; font-weight:600; font-size:.86rem;
  background: rgba(255,255,255,0.05); color:var(--text);
  border:1px solid var(--glass-border-hi);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
  transition: border-color .3s, box-shadow .3s;
}
.h2h select:focus { outline:none; border-color:rgba(255,255,255,0.4); box-shadow:0 0 0 3px rgba(255,255,255,0.08); }
.h2h select option { background:#141416; }
.h2h__row { display:grid; grid-template-columns: 56px 1fr 56px; gap:12px; align-items:center; padding:9px 0; }
.h2h__val { font-family:var(--font-d); font-size:1.5rem; letter-spacing:.03em; text-align:center; }
.h2h__mid { text-align:center; }
.h2h__lbl { font-size:.6rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); margin-bottom:5px; }
.h2h__bars { display:flex; gap:4px; height:7px; }
.h2h__bar-a, .h2h__bar-b { border-radius:100px; transition: flex 1s var(--spring-soft); min-width:4px; }
.h2h__win { text-shadow: 0 0 18px currentColor; }
.h2h__empty { text-align:center; padding:26px 10px; color:var(--text-dim); font-size:.84rem; }

/* =========================================================
   FANTASY GLASS POLISH
========================================================= */
.save-squad-btn, .auth-btn {
  border-radius: 14px !important;
  box-shadow: 0 8px 24px rgba(168,85,247,0.25), 0 1px 0 rgba(255,255,255,0.18) inset !important;
  transition: transform .4s var(--spring), box-shadow .4s, filter .3s !important;
}
.save-squad-btn:not(:disabled):hover, .auth-btn:hover { transform: translateY(-2px) scale(1.02); filter: brightness(1.12); }
.save-squad-btn:not(:disabled):active, .auth-btn:active { transform: scale(.97); }
.picker-card.selected, .picker-card.selected-captain {
  box-shadow: 0 0 0 1.5px var(--fantasy), 0 12px 36px rgba(168,85,247,0.22), var(--glass-shadow) !important;
}
.squad-player-card--captain {
  background: linear-gradient(140deg, rgba(245,200,66,0.08), rgba(255,255,255,0.03)) !important;
}
.save-toast {
  background: rgba(22,22,26,0.85) !important;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border-hi) !important;
  border-radius: 16px !important;
  box-shadow: var(--glass-shadow-hv) !important;
}

/* =========================================================
   STATS TABLE GLASS + photo cells
========================================================= */
.stats-table thead th {
  background: rgba(22,22,26,0.85) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.stats-table tbody tr { transition: background .25s; }
.stats-table tbody tr:hover td { background: rgba(255,255,255,0.045) !important; }

/* =========================================================
   FILTER PILLS / TABS → glass
========================================================= */
.team-tab, .filter-btn, .picker-filter, .auth-tab {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background: var(--glass-bg) !important;
  border-color: var(--glass-border) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.07) inset;
  transition: transform .35s var(--spring), background .3s, border-color .3s, color .3s !important;
}
.team-tab:hover, .filter-btn:hover, .picker-filter:hover { transform: translateY(-1.5px); }
.team-tab:active, .filter-btn:active, .picker-filter:active { transform: scale(.95); }

/* =========================================================
   FOOTER + MISC
========================================================= */
.footer {
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.announcement-bar {
  background: rgba(20,20,24,0.8) !important;
  backdrop-filter: var(--glass-blur-hv) !important;
  -webkit-backdrop-filter: var(--glass-blur-hv) !important;
  border: 1px solid var(--glass-border-hi) !important;
  box-shadow: var(--glass-shadow-hv) !important;
}

/* page transition → soft iris */
.page-transition { background: rgba(5,5,6,0.96); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }

/* selection + scrollbar flavour */
::selection { background: rgba(245,200,66,0.25); }
::-webkit-scrollbar { width: 9px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.14); border-radius:100px; border:2px solid transparent; background-clip: content-box; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.26); border:2px solid transparent; background-clip: content-box; }

/* =========================================================
   REDUCED MOTION — respect it everywhere
========================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
  .aurora__blob { animation: none; }
  .ticker__track { animation: none; }
}
