/* ============================================================
   DTF ESPORTS — stylesheet
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #0f1923;
  --bg2:         #111d28;
  --surface:     #162130;
  --surface2:    #1b2a3b;
  --surface3:    #213245;
  --border:      rgba(255,255,255,0.08);
  --border2:     rgba(255,255,255,0.15);
  --red:         #ff4655;
  --red-glow:    rgba(255,70,85,0.28);
  --red-dim:     rgba(255,70,85,0.12);
  --teal:        #00d4aa;
  --teal-dim:    rgba(0,212,170,0.12);
  --text:        #ece8e1;
  --text-2:      #9daab8;
  --text-3:      #4e6478;
  --win:         #00d4aa;
  --loss:        #ff4655;
  --draw:        #7272a0;
  --radius:      14px;
  --radius-sm:   8px;
  --shadow-card: 0 8px 40px rgba(0,0,0,0.6);
  --t:           0.22s cubic-bezier(0.4,0,0.2,1);
}

html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background:
    radial-gradient(ellipse at 15% 0%, rgba(255,70,85,0.06) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 100%, rgba(0,212,170,0.04) 0%, transparent 55%),
    var(--bg);
  color: var(--text);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}

/* ── CANVAS ─────────────────────────────────────── */
#bg-canvas {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; opacity: 0.4;
}

/* ── LEADERBOARD BUTTON ──────────────────────────── */
.leaderboard-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 13px; border-radius: 8px;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--text-2);
  font-family: 'Rajdhani', sans-serif; font-size: 11px;
  font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer; transition: border-color var(--t), color var(--t), background var(--t);
  white-space: nowrap;
}
.leaderboard-btn:hover { border-color: var(--red); color: var(--red); }
.leaderboard-btn.active { border-color: var(--red); color: var(--red); background: var(--red-dim); }

/* ── LEADERBOARD VIEW ────────────────────────────── */
.lb-view {
  position: relative; z-index: 1;
  max-width: 820px; margin: 0 auto;
  padding: 36px 28px 80px;
}
.lb-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 24px; gap: 12px;
}
.lb-title {
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 22px; font-weight: 400; letter-spacing: 5px;
  color: var(--text); text-transform: uppercase; margin-bottom: 4px;
  display: flex; align-items: center; gap: 8px;
}
.lb-title::before {
  content: '//';
  color: var(--red); opacity: 0.75;
  font-size: 14px; letter-spacing: 0;
}
.lb-sub {
  font-size: 13px; font-weight: 500; color: var(--text-2);
  letter-spacing: 0.4px;
  padding: 5px 10px;
  background: rgba(255,255,255,0.04);
  border-left: 2px solid rgba(255,70,85,0.45);
  border-radius: 0 4px 4px 0;
  display: inline-block;
}
.lb-header-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.lb-updated { font-size: 10px; color: var(--text-3); letter-spacing: 0.5px; white-space: nowrap; }
.lb-refresh-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: 8px;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--text-2);
  font-family: 'Rajdhani', sans-serif; font-size: 11px;
  font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer;
  transition: border-color var(--t), color var(--t), background var(--t), opacity var(--t);
}
.lb-refresh-btn:hover:not(:disabled) { border-color: var(--red); color: var(--red); background: var(--red-dim); }
.lb-refresh-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.lb-refresh-btn.loading .lb-refresh-icon { animation: spin 0.8s linear infinite; }
.lb-refresh-btn.loading .lb-refresh-label { color: var(--text-3); }
@keyframes spin { to { transform: rotate(360deg); } }
.lb-list { display: flex; flex-direction: column; gap: 8px; }
.lb-col-headers {
  display: grid;
  grid-template-columns: 36px 40px 1fr 36px 105px repeat(5, 50px);
  gap: 12px; padding: 0 18px;
  margin-bottom: 2px;
}
.lb-col-header {
  font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--text-3);
  text-align: right;
}
.lb-col-header:nth-child(-n+5) { visibility: hidden; } /* hide pos/avatar/name/icon/rank cols */
/* Leaderboard sync loading screen */
.lb-sync-wrap {
  display: flex; flex-direction: column; gap: 20px;
  padding: 28px 20px;
}
.lb-sync-title {
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  letter-spacing: 2px; color: var(--text-3); text-align: center;
}
.lb-sync-bar {
  height: 3px; border-radius: 2px; background: rgba(255,255,255,0.07); overflow: hidden;
}
.lb-sync-fill {
  height: 100%; width: 0%; border-radius: 2px;
  background: linear-gradient(90deg, var(--red), var(--teal));
  transition: width 0.4s cubic-bezier(0.4,0,0.2,1);
}
.lb-sync-rows { display: flex; flex-direction: column; gap: 6px; }
.lb-sync-row {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 600;
  color: rgba(255,255,255,0.2); transition: color 0.2s;
}
.lb-sync-row .lb-sync-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,0.12); flex-shrink: 0;
  transition: background 0.2s, box-shadow 0.2s;
}
.lb-sync-row.active { color: var(--text); }
.lb-sync-row.active .lb-sync-dot {
  background: var(--teal);
  box-shadow: 0 0 8px rgba(0,212,170,0.8);
  animation: cls-pulse-dot 1.1s ease-in-out infinite;
}
.lb-sync-row.done { color: rgba(255,255,255,0.38); }
.lb-sync-row.done .lb-sync-dot { background: rgba(100,220,130,0.55); box-shadow: none; animation: none; }
.lb-sync-name { flex: 1; }
.lb-sync-status { font-size: 11px; letter-spacing: 0.5px; color: inherit; }
.lb-sync-row.done .lb-sync-status { color: rgba(100,220,130,0.7); }

.lb-row {
  display: grid;
  grid-template-columns: 36px 40px 1fr 36px 105px repeat(5, 50px);
  align-items: center; gap: 12px;
  padding: 14px 18px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: border-color var(--t), background var(--t), transform var(--t);
  animation: fadeUp 0.3s ease both;
  cursor: pointer;
  --rank-color: var(--text-3);
}
.lb-row:hover { border-color: color-mix(in srgb, var(--rank-color) 55%, transparent); background: var(--surface2); transform: translateX(3px); box-shadow: 0 0 20px rgba(255,70,85,0.05); }
.lb-row:nth-child(1)  { animation-delay: 0.03s; }
.lb-row:nth-child(2)  { animation-delay: 0.06s; }
.lb-row:nth-child(3)  { animation-delay: 0.09s; }
.lb-row:nth-child(4)  { animation-delay: 0.12s; }
.lb-row:nth-child(5)  { animation-delay: 0.15s; }
.lb-row:nth-child(6)  { animation-delay: 0.18s; }
.lb-row:nth-child(7)  { animation-delay: 0.21s; }
.lb-row:nth-child(8)  { animation-delay: 0.24s; }
.lb-row:nth-child(9)  { animation-delay: 0.27s; }
.lb-row:nth-child(10) { animation-delay: 0.30s; }
.lb-pos { font-family: 'Rajdhani', sans-serif; font-size: 18px; font-weight: 700; color: var(--text-3); text-align: center; }
.lb-pos.gold   { color: #ffe56d; }
.lb-pos.silver { color: #c0c8d8; }
.lb-pos.bronze { color: #c87b3a; }
.lb-avatar {
  width: 40px; height: 40px; border-radius: 8px;
  border: 1px solid var(--border2); background: var(--surface2);
  overflow: hidden; display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 700; color: var(--text-2);
}
.lb-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.lb-info { min-width: 0; }
.lb-alias { font-family: 'Rajdhani', sans-serif; font-size: 17px; font-weight: 700; color: var(--text); letter-spacing: 0.5px; }
.lb-tag   { font-size: 11px; color: var(--text-3); }
.lb-rank-icon { width: 36px; height: 36px; object-fit: contain; }
.lb-tier-wrap { text-align: right; min-width: 105px; }
.lb-tier { font-family: 'Rajdhani', sans-serif; font-size: 15px; font-weight: 700; color: var(--rank-color); }
.lb-rr   { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.lb-stat-col {
  font-family: 'Rajdhani', sans-serif; font-size: 16px; font-weight: 700;
  color: var(--text-2); text-align: right; min-width: 0;
  transition: color var(--t);
}
.lb-stat-col.lb-stat-active { color: #c084fc; }

/* ── Sort bar ─────────────────────────────── */
.lb-sort-bar {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  margin-bottom: 14px;
}
.lb-sort-label {
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 600;
  letter-spacing: 1px; color: var(--text-3); margin-right: 4px; text-transform: uppercase;
}
.lb-sort-btn {
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px;
  background: var(--surface2); border: 1px solid var(--border2);
  color: var(--text-3); cursor: pointer;
  transition: background var(--t), color var(--t), border-color var(--t);
}
.lb-sort-btn:hover  { background: var(--surface); color: var(--text-2); border-color: rgba(255,255,255,0.2); }
.lb-sort-btn.active { background: var(--red-dim); border-color: rgba(255,70,85,0.5); color: var(--red); }

/* ── NAVBAR ─────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 200;
  background: rgba(15,25,35,0.90);
  backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid rgba(255,70,85,0.22);
  box-shadow: 0 1px 0 rgba(255,70,85,0.12), 0 4px 28px rgba(0,0,0,0.55);
}
.header-inner {
  max-width: 1100px; margin: 0 auto;
  padding: 0 28px; height: 62px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo {
  font-family: 'Rajdhani', sans-serif;
  font-size: 21px; font-weight: 700; letter-spacing: 4px;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 9px;
  color: var(--text); user-select: none;
  cursor: pointer;
  transition: opacity var(--t);
}
.logo:hover { opacity: 0.8; }
.logo-img {
  width: 38px; height: 38px;
  border-radius: 8px;
  object-fit: cover;
  border: 1px solid rgba(255,70,85,0.5);
  box-shadow: 0 0 16px rgba(255,70,85,0.35), 0 0 4px rgba(255,70,85,0.5);
  flex-shrink: 0;
}
.logo span { color: var(--red); text-shadow: 0 0 20px rgba(255,70,85,0.5); }
.header-right { display: flex; align-items: center; gap: 10px; }
.status-pill {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 999px;
  background: var(--surface2); border: 1px solid var(--border);
  font-size: 11.5px; font-weight: 500; color: var(--text-2);
  transition: var(--t);
  position: relative; cursor: default;
}
.status-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-3); flex-shrink: 0; transition: var(--t);
}
.status-pill.online  .status-dot  { background: var(--win); box-shadow: 0 0 8px var(--win); }
.status-pill.online  #status-text { color: var(--win); }
.status-pill.warning .status-dot  { background: #f0b429; box-shadow: 0 0 8px #f0b429; }
.status-pill.warning #status-text { color: #f0b429; }
.version-badge {
  padding: 4px 10px; border-radius: 6px;
  background: var(--surface2); border: 1px solid var(--border);
  font-size: 11px; font-weight: 500; color: var(--text-3);
}

/* ── GLOBAL SYNC BUTTON ──────────────────────────── */
.sync-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 8px;
  background: var(--teal); border: 1px solid var(--teal);
  color: #0f1923;
  font-family: 'Rajdhani', sans-serif; font-size: 11px;
  font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer;
  transition: border-color var(--t), color var(--t), background var(--t), opacity var(--t);
  white-space: nowrap;
}
.sync-btn:hover:not(:disabled) { background: #00bfa0; border-color: #00bfa0; color: #0f1923; }
.sync-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.sync-btn.syncing { background: var(--teal-dim); border-color: var(--teal); color: var(--teal); }
.sync-btn.syncing .sync-btn-icon { animation: spin 0.9s linear infinite; }
.sync-btn.synced  { background: var(--teal-dim); border-color: var(--teal); color: var(--teal); }
.sync-btn-progress { font-size: 10px; color: inherit; min-width: 28px; }
.sync-btn.syncing .sync-btn-progress { color: var(--win); }

/* ── HERO BANNER ────────────────────────────────── */
.hero {
  position: relative; z-index: 1;
  width: 100%;
}
.hero-banner-wrap {
  position: relative;
  max-width: 1100px; margin: 0 auto;
  padding: 0 28px;
  overflow: hidden;
}
.hero-banner-img {
  width: 100%; height: auto;
  display: block; border-radius: var(--radius);
  margin-top: -5%; margin-bottom: -7%;
}
.hero-banner-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(
      to top,
      rgba(15,25,35,0.95) 0%,
      rgba(15,25,35,0.25) 45%,
      transparent 70%
    ),
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 3px,
      rgba(0,0,0,0.04) 3px,
      rgba(0,0,0,0.04) 4px
    );
  display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end;
  padding: 28px 28px 36px; gap: 8px; text-align: center;
}
.eyebrow {
  font-family: 'Rajdhani', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 4px;
  text-transform: uppercase; color: var(--red);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 18px; border: 1px solid rgba(255,70,85,0.5);
  border-radius: 999px;
  background: rgba(255,70,85,0.1);
  box-shadow: 0 0 20px rgba(255,70,85,0.15), inset 0 1px 0 rgba(255,70,85,0.12);
  text-shadow: 0 0 12px rgba(255,70,85,0.5);
  backdrop-filter: blur(6px);
}
.hero-sub {
  font-size: 15px; font-weight: 500; color: var(--text);
  text-shadow: 0 2px 16px rgba(0,0,0,0.9), 0 0 40px rgba(0,0,0,0.7);
  letter-spacing: 0.3px;
  padding: 8px 20px;
  background: rgba(15,25,35,0.55);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.07);
  backdrop-filter: blur(8px);
}

/* ── ROSTER ─────────────────────────────────────── */
.roster-section {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto 64px;
  padding: 0 28px;
}
.roster-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px;
}
.roster-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 14px; font-weight: 700; letter-spacing: 4px;
  color: var(--text-2); text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
}
.roster-title::before {
  content: '//';
  color: var(--red); opacity: 0.75;
  font-size: 11px; letter-spacing: 0;
}
.roster-count {
  font-size: 12px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text-3);
}

.roster-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}

/* Player card */
.player-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-bottom: 2px solid color-mix(in srgb, var(--card-accent, var(--red)) 35%, transparent);
  border-radius: var(--radius);
  padding: 22px 16px 18px;
  cursor: pointer;
  text-align: center;
  transition: border-color var(--t), background var(--t), transform var(--t), box-shadow var(--t);
  animation: fadeUp 0.4s ease both;
  overflow: hidden;
}
.player-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--card-accent, var(--red)) 14%, transparent) 0%,
    transparent 55%
  );
  opacity: 0.7; transition: opacity var(--t);
  pointer-events: none;
}
/* Corner bracket — top-right */
.player-card::after {
  content: '';
  position: absolute; top: 8px; right: 8px;
  width: 10px; height: 10px;
  border-top: 1.5px solid var(--card-accent, var(--red));
  border-right: 1.5px solid var(--card-accent, var(--red));
  opacity: 0; transition: opacity var(--t);
  pointer-events: none;
}
.player-card:hover {
  border-color: color-mix(in srgb, var(--card-accent, var(--red)) 60%, transparent);
  border-bottom-color: color-mix(in srgb, var(--card-accent, var(--red)) 80%, transparent);
  background: var(--surface2);
  transform: translateY(-4px);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--card-accent, var(--red)) 20%, transparent),
    0 12px 40px rgba(0,0,0,0.55),
    0 0 36px color-mix(in srgb, var(--card-accent, var(--red)) 10%, transparent);
}
.player-card:hover::before { opacity: 1; }
.player-card:hover::after  { opacity: 1; }
.player-card.active {
  border-color: var(--card-accent, var(--red));
  border-bottom-color: var(--card-accent, var(--red));
  background: var(--surface2);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--card-accent, var(--red)) 25%, transparent),
    0 0 40px color-mix(in srgb, var(--card-accent, var(--red)) 14%, transparent),
    var(--shadow-card);
}
.player-card.active::before { opacity: 1; }
.player-card.active::after  { opacity: 1; }

/* stagger delays */
.player-card:nth-child(1)  { animation-delay: 0.03s; }
.player-card:nth-child(2)  { animation-delay: 0.06s; }
.player-card:nth-child(3)  { animation-delay: 0.09s; }
.player-card:nth-child(4)  { animation-delay: 0.12s; }
.player-card:nth-child(5)  { animation-delay: 0.15s; }
.player-card:nth-child(6)  { animation-delay: 0.18s; }
.player-card:nth-child(7)  { animation-delay: 0.21s; }
.player-card:nth-child(8)  { animation-delay: 0.24s; }
.player-card:nth-child(9)  { animation-delay: 0.27s; }
.player-card:nth-child(10) { animation-delay: 0.30s; }

.player-number {
  position: absolute; top: 10px; left: 12px;
  font-size: 10px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-3); font-family: 'Rajdhani', sans-serif;
}
.player-avatar-wrap {
  width: 64px; height: 64px; border-radius: 10px;
  margin: 0 auto 14px;
  background: var(--surface3); border: 2px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif;
  font-size: 22px; font-weight: 700; color: var(--text-2);
  transition: border-color var(--t);
  position: relative; overflow: hidden;
}
.player-avatar-wrap img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
}
.player-card:hover .player-avatar-wrap,
.player-card.active .player-avatar-wrap {
  border-color: var(--card-accent, var(--red));
}
.player-alias {
  font-family: 'Rajdhani', sans-serif;
  font-size: 18px; font-weight: 700; letter-spacing: 1px;
  color: var(--text); margin-bottom: 4px;
}
.player-gamertag {
  font-size: 11px; color: var(--text-3);
  letter-spacing: 0.3px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.player-card-arrow {
  position: absolute; bottom: 10px; right: 12px;
  color: var(--card-accent, var(--red)); opacity: 0;
  transition: opacity var(--t), transform var(--t);
}
.player-card:hover .player-card-arrow { opacity: 1; transform: translateX(2px); }

.player-last-active {
  font-size: 10px; font-weight: 600; letter-spacing: 0.5px;
  color: var(--win); margin-top: 6px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.player-last-active.inactive-old     { color: var(--loss); }
.player-last-active.inactive-unknown { color: var(--text-3); }

/* ── RANK BADGE ON ROSTER CARDS ─────────────────── */
.player-rank-badge {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  margin-top: 8px;
  font-family: 'Rajdhani', sans-serif; font-size: 12px; font-weight: 700;
  color: var(--rank-color, var(--text-3)); letter-spacing: 0.5px;
}
.rank-badge-icon {
  width: 22px; height: 22px; object-fit: contain; flex-shrink: 0;
}


/* ── LOADING ────────────────────────────────────── */
.loading-section {
  position: relative; z-index: 1;
  text-align: center; padding: 64px 24px;
}
.load-icon {
  width: 56px; height: 56px; margin: 0 auto 20px;
  animation: pulseSvg 1.6s ease-in-out infinite;
}
@keyframes pulseSvg {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:0.55; transform:scale(0.9); }
}
.load-text { font-size: 14px; color: var(--text-2); letter-spacing: 1px; }
.ellipsis span { animation: blink 1.4s infinite; }
.ellipsis span:nth-child(2) { animation-delay: 0.2s; }
.ellipsis span:nth-child(3) { animation-delay: 0.4s; }
@keyframes blink { 0%,80%,100%{opacity:0} 40%{opacity:1} }

/* ── PLAYER VIEW (sidebar + main) ──────────────── */
.player-view {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: calc(100vh - 62px);
  position: relative; z-index: 1;
  max-width: 1340px; margin: 0 auto;
  padding: 0 20px 80px;
  gap: 0;
}

.player-sidebar {
  position: sticky; top: 62px;
  height: calc(100vh - 62px);
  overflow-y: auto; overflow-x: hidden;
  padding: 20px 12px 40px;
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--surface3) transparent;
  align-self: start;
}
.player-sidebar::-webkit-scrollbar { width: 4px; }
.player-sidebar::-webkit-scrollbar-thumb { background: var(--surface3); border-radius: 2px; }

.sidebar-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; gap: 8px;
}
.sidebar-label {
  font-size: 9.5px; font-weight: 700; letter-spacing: 3px;
  text-transform: uppercase; color: var(--text-3);
}

.sidebar-player-list {
  display: flex; flex-direction: column; gap: 4px;
}

.sidebar-card {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: 10px;
  background: transparent; border: 1px solid transparent;
  cursor: pointer; text-align: left; width: 100%;
  transition: background var(--t), border-color var(--t);
}
.sidebar-card:hover {
  background: var(--surface2); border-color: var(--border);
}
.sidebar-card.active {
  background: var(--surface2); border-color: var(--red);
  box-shadow: 0 0 0 2px rgba(255,70,85,0.1);
}

.sidebar-avatar {
  width: 36px; height: 36px; border-radius: 7px; flex-shrink: 0;
  background: var(--surface3); border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  color: var(--text-2); overflow: hidden;
}
.sidebar-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.sidebar-card.active .sidebar-avatar { border-color: var(--red); }

.sidebar-alias {
  font-family: 'Rajdhani', sans-serif;
  font-size: 15px; font-weight: 700; letter-spacing: 0.5px;
  color: var(--text); line-height: 1.2;
}
.sidebar-tag {
  font-size: 10px; color: var(--text-3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 130px;
}

/* Sidebar compare button */
.sidebar-compare-wrap { padding: 10px 0 4px; }
.sidebar-compare-btn {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  width: 100%; padding: 8px 0;
  background: transparent; border: 1.5px solid rgba(255,70,85,0.3);
  border-radius: 10px; cursor: pointer;
  font-family: 'Rajdhani', sans-serif; font-size: 12px; font-weight: 700;
  letter-spacing: 1px; color: var(--text-3);
  transition: border-color var(--t), color var(--t), background var(--t);
}
.sidebar-compare-btn:hover { border-color: var(--red); color: var(--red); background: rgba(255,70,85,0.05); }
.sidebar-compare-btn.active { border-color: var(--red); color: var(--red); background: rgba(255,70,85,0.08); }

/* Compare nav button */
.compare-nav-btn { color: #f472b6; }
.compare-nav-btn.active { background: rgba(244,114,182,0.12); border-color: rgba(244,114,182,0.35); }

/* ── COMPARE PAGE ──────────────────────────────────── */
.compare-page-wrap {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto;
  padding: 32px 28px 64px;
  display: flex; flex-direction: column; gap: 32px;
}
.compare-page-title {
  background: linear-gradient(90deg, var(--red), var(--teal));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Pick slots */
.compare-pick-section {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch; gap: 0;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 20px; overflow: hidden; min-height: 160px;
}
.compare-pick-slot {
  padding: 24px 28px;
  display: flex; align-items: center; gap: 16px;
  transition: background 0.25s;
  position: relative;
}
.compare-pick-slot.slot-a { background: rgba(91,139,216,0.04); border-right: none; }
.compare-pick-slot.slot-b { background: rgba(245,166,35,0.04);  border-left: none; }
.compare-pick-slot.slot-a.filled { background: rgba(91,139,216,0.08); box-shadow: inset 4px 0 0 #5b8bd8; }
.compare-pick-slot.slot-b.filled { background: rgba(245,166,35,0.08);  box-shadow: inset -4px 0 0 #f5a623; }

.compare-pick-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; width: 100%; text-align: center;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--text-3); letter-spacing: 0.5px;
}
.compare-pick-filled {
  display: flex; align-items: center; gap: 16px; width: 100%;
}
.compare-pick-portrait {
  width: 72px; height: 72px; border-radius: 14px; flex-shrink: 0;
  background: var(--surface3); border: 2px solid var(--border2);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  font-family: 'Rajdhani', sans-serif; font-size: 22px; font-weight: 700; color: var(--text-2);
}
.compare-pick-portrait img { width: 100%; height: 100%; object-fit: contain; }
.compare-pick-info { flex: 1; min-width: 0; }
.compare-pick-name {
  font-family: 'Rajdhani', sans-serif; font-size: 26px; font-weight: 900;
  letter-spacing: 1px; color: var(--text); line-height: 1;
}
.compare-pick-tag { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.compare-pick-deselect {
  background: none; border: none; cursor: pointer; color: var(--text-3);
  font-size: 20px; padding: 4px; line-height: 1; flex-shrink: 0;
  transition: color var(--t);
}
.compare-pick-deselect:hover { color: var(--red); }

.compare-vs-divider {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 0 4px; gap: 6px; background: var(--surface2);
  border-left: 1px solid var(--border); border-right: 1px solid var(--border);
  width: 56px; flex-shrink: 0;
}
.compare-vs-line { flex: 1; width: 1px; background: var(--border); }
.compare-vs-badge {
  font-family: 'Rajdhani', sans-serif; font-size: 15px; font-weight: 900;
  letter-spacing: 3px; padding: 6px 0;
  background: linear-gradient(180deg, #f472b6, #c084fc);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; filter: drop-shadow(0 0 6px rgba(192,132,252,0.5));
}

/* Compare result */
.compare-result {
  display: flex; flex-direction: column; gap: 10px;
  background: linear-gradient(135deg, rgba(91,139,216,0.04), var(--surface2), rgba(245,166,35,0.04));
  border: 1px solid var(--border); border-radius: 16px; padding: 24px 28px;
  animation: fadeUp 0.3s ease both;
}
.compare-stats-grid {
  display: grid; grid-template-columns: 1fr 130px 1fr; gap: 6px 12px;
  align-items: center;
}
.csr-label-text {
  font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-3);
  text-align: center; padding: 2px 0;
}
.csr-a, .csr-b {
  font-family: 'Rajdhani', sans-serif; font-size: 28px; font-weight: 900;
  text-align: center; padding: 12px 16px; border-radius: 12px;
  transition: box-shadow 0.3s, background 0.3s; letter-spacing: 0.5px;
}
.csr-a { background: rgba(91,139,216,0.08); border: 1px solid rgba(91,139,216,0.2); color: #8ab4f8; }
.csr-b { background: rgba(245,166,35,0.08);  border: 1px solid rgba(245,166,35,0.2);  color: #f5c842; }
.csr-a.winner {
  background: rgba(91,139,216,0.2); border-color: rgba(91,139,216,0.6);
  box-shadow: 0 0 28px rgba(91,139,216,0.3), inset 0 0 14px rgba(91,139,216,0.08); color: #c0d8ff;
}
.csr-b.winner {
  background: rgba(245,166,35,0.2); border-color: rgba(245,166,35,0.6);
  box-shadow: 0 0 28px rgba(245,166,35,0.3), inset 0 0 14px rgba(245,166,35,0.08); color: #ffe08a;
}
.compare-winner-banner {
  text-align: center; padding: 18px 20px; margin-top: 4px;
  background: linear-gradient(135deg, rgba(192,132,252,0.12), rgba(244,114,182,0.06));
  border: 1px solid rgba(192,132,252,0.3); border-radius: 14px;
  font-family: 'Rajdhani', sans-serif; font-size: 22px; font-weight: 900;
  letter-spacing: 2px; text-transform: uppercase;
  box-shadow: 0 4px 24px rgba(192,132,252,0.12);
}
.compare-loading {
  text-align: center; padding: 40px; color: var(--text-3);
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 600; letter-spacing: 1px;
}
.cls-retry-msg {
  font-family: 'Rajdhani', sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 0.5px; color: #f5a623; text-align: center;
  padding: 8px 12px; border-radius: 8px;
  background: rgba(245,166,35,0.08); border: 1px solid rgba(245,166,35,0.2);
  animation: cls-pulse-text 1.5s ease-in-out infinite;
}

/* Compare loading state */
.compare-loading-state {
  display: flex; flex-direction: column; gap: 20px;
  padding: 8px 4px;
}
.cls-players {
  display: flex; align-items: center; justify-content: center; gap: 16px;
}
.cls-name {
  font-family: 'Rajdhani', sans-serif; font-size: 22px; font-weight: 900; letter-spacing: 1px;
}
.cls-name-a { color: #8ab4f8; }
.cls-name-b { color: #f5c842; }
.cls-vs {
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700; letter-spacing: 3px;
  color: var(--text-3); padding: 0 4px;
}
.cls-bar-wrap { padding: 0 4px; }
.cls-bar {
  height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.07);
  overflow: hidden;
}
.cls-bar-fill {
  height: 100%; width: 0%; border-radius: 2px;
  background: linear-gradient(90deg, var(--red), var(--teal));
  transition: width 0.5s cubic-bezier(0.4,0,0.2,1);
}
.cls-steps {
  display: flex; flex-direction: column; gap: 8px;
}
.cls-step {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 600;
  letter-spacing: 0.5px; color: rgba(255,255,255,0.2);
  transition: color 0.3s;
}
.cls-step .cls-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,0.15); flex-shrink: 0;
  transition: background 0.3s, box-shadow 0.3s;
}
.cls-step.active {
  color: var(--text);
  animation: cls-pulse-text 1.2s ease-in-out infinite;
}
.cls-step.active .cls-dot {
  background: var(--teal);
  box-shadow: 0 0 8px rgba(0,212,170,0.7);
  animation: cls-pulse-dot 1.2s ease-in-out infinite;
}
.cls-step.done { color: rgba(255,255,255,0.4); }
.cls-step.done .cls-dot { background: rgba(100,220,130,0.6); box-shadow: none; animation: none; }
@keyframes cls-pulse-text {
  0%,100% { opacity: 1; } 50% { opacity: 0.6; }
}
@keyframes cls-pulse-dot {
  0%,100% { box-shadow: 0 0 6px rgba(192,132,252,0.7); }
  50%      { box-shadow: 0 0 14px rgba(192,132,252,1); }
}

/* Roster picker grid */
.compare-roster-label {
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1.5px; color: var(--text-3);
}
.compare-roster-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px;
}
.compare-roster-card {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; cursor: pointer;
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--card-accent, var(--red)) 8%, var(--surface2)) 0%,
    var(--surface2) 70%
  );
  border: 1.5px solid color-mix(in srgb, var(--card-accent, var(--red)) 20%, var(--border2));
  border-radius: 12px;
  transition: border-color 0.2s, background 0.2s, transform 0.15s, box-shadow 0.2s;
}
.compare-roster-card:hover {
  border-color: color-mix(in srgb, var(--card-accent, var(--red)) 60%, transparent);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.2), 0 0 16px color-mix(in srgb, var(--card-accent, var(--red)) 10%, transparent);
}
.compare-roster-card.pick-a { border-color: #5b8bd8; background: rgba(91,139,216,0.1); box-shadow: 0 0 14px rgba(91,139,216,0.2); }
.compare-roster-card.pick-b { border-color: #f5a623; background: rgba(245,166,35,0.1); box-shadow: 0 0 14px rgba(245,166,35,0.2); }
.compare-roster-card { position: relative; }
.compare-roster-avatar {
  width: 42px; height: 42px; border-radius: 10px; flex-shrink: 0;
  background: var(--surface3); border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 700; color: var(--text-2);
}
.compare-roster-avatar img { width: 100%; height: 100%; object-fit: contain; }
.compare-roster-info {}
.compare-roster-name {
  font-family: 'Rajdhani', sans-serif; font-size: 15px; font-weight: 700; color: var(--text); line-height: 1.2;
}
.compare-roster-role { font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.5px; }

  min-width: 0;
  padding: 24px 0 0 28px;
}

/* ── RESULTS ────────────────────────────────────── */
.results-section {
  position: relative; z-index: 1;
  margin-bottom: 40px;
}

/* ── BACK BUTTON ────────────────────────────────── */
.back-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px; border-radius: 8px;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--text-2);
  font-family: 'Rajdhani', sans-serif; font-size: 11px;
  font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer; transition: border-color var(--t), color var(--t);
  white-space: nowrap;
}
.back-btn:hover { border-color: var(--red); color: var(--red); }

/* ── STATUS MODAL ──────────────────────────────── */
.status-modal {
  position: fixed; inset: 0; z-index: 9000;
  display: flex; align-items: center; justify-content: center;
}
.status-modal.hidden { display: none; }
.status-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.65); backdrop-filter: blur(4px);
  cursor: pointer;
}
.status-modal-box {
  position: relative; z-index: 1;
  background: var(--surface2); border: 1px solid var(--border2);
  border-radius: 14px; padding: 28px 32px;
  width: 100%; max-width: 540px; margin: 16px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.6);
  animation: fadeUp 0.2s ease both;
}
.status-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px;
}
.status-modal-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 20px; font-weight: 700; letter-spacing: 1px;
  color: var(--text);
}
.status-modal-close {
  background: none; border: none; cursor: pointer;
  color: var(--text-3); padding: 4px;
  border-radius: 6px; transition: color var(--t), background var(--t);
}
.status-modal-close:hover { color: var(--text); background: var(--surface3); }
.status-modal-body { display: flex; flex-direction: column; gap: 14px; }
.status-issue-card {
  background: var(--surface3); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px 18px;
}
.status-issue-card.severity-info     { border-left: 3px solid #f0b429; }
.status-issue-card.severity-warning  { border-left: 3px solid #f0b429; }
.status-issue-card.severity-critical { border-left: 3px solid var(--red); }
.status-issue-card.maintenance       { border-left: 3px solid #5b8bd8; }
.status-issue-type {
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 5px;
}
.status-issue-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 17px; font-weight: 700; color: var(--text); margin-bottom: 6px;
}
.status-issue-detail {
  font-size: 13px; color: var(--text-2); line-height: 1.6;
}
.status-issue-time {
  font-size: 11px; color: var(--text-3); margin-top: 8px;
}
.status-no-issues {
  text-align: center; padding: 24px 0;
  font-size: 14px; color: var(--win);
}
.status-pill[data-has-issues] { cursor: pointer; }
.status-pill[data-has-issues]:hover { border-color: #f0b429; }

/* ── RATE LIMIT TOAST ───────────────────────────── */
.rate-toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  display: flex; align-items: center; gap: 10px;
  padding: 13px 22px; border-radius: 40px; z-index: 9999;
  background: rgba(20, 14, 30, 0.92);
  border: 1px solid rgba(255, 70, 85, 0.5);
  color: #ff8895; font-size: 13.5px; font-family: var(--font-body);
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
  backdrop-filter: blur(12px);
  animation: toastIn 0.25s ease both;
  white-space: nowrap;
}
.rate-toast.hidden { display: none; }
@keyframes toastIn {
  from { opacity: 0; transform: translateX(-50%) translateY(12px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* ── ERROR ──────────────────────────────────────── */
.error-banner {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 16px; padding: 12px 16px;
  border-radius: var(--radius-sm);
  background: rgba(255,70,85,0.08); border: 1px solid rgba(255,70,85,0.28);
  color: #ff8895; font-size: 13.5px;
}

/* ── PROFILE HERO BANNER ────────────────────────── */
.profile-hero {
  position: relative; border-radius: 20px; overflow: hidden;
  min-height: 190px; margin-bottom: 18px;
  border: 1px solid var(--border2); box-shadow: var(--shadow-card);
  animation: fadeUp 0.35s ease both;
}
.profile-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #0b141e 0%, #0e1c30 50%, #0d1e1a 100%);
  background-size: cover; background-position: center;
}
.profile-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(10,10,15,0.96) 0%, rgba(10,10,15,0.72) 55%, rgba(10,10,15,0.35) 100%);
}
.profile-hero-body {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 26px;
  padding: 32px 36px; flex-wrap: wrap;
}
.profile-avatar-group { position: relative; flex-shrink: 0; }
.profile-avatar {
  width: 92px; height: 92px; border-radius: 14px;
  border: 2px solid var(--red); background: var(--surface2);
  overflow: hidden; box-shadow: 0 0 20px rgba(255,70,85,0.25);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif; font-size: 32px;
  font-weight: 700; color: var(--text-2);
}
.profile-avatar img { width: 100%; height: 100%; object-fit: cover; }
.profile-level-badge {
  position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%);
  background: var(--red); border-radius: 6px; padding: 2px 8px;
  display: flex; align-items: center; gap: 4px; white-space: nowrap;
  box-shadow: 0 2px 12px rgba(255,70,85,0.4);
}
.level-label { font-size: 8px; font-weight: 700; letter-spacing: 1.5px; color: rgba(255,255,255,0.7); }
.level-num   { font-family: 'Rajdhani', sans-serif; font-size: 16px; font-weight: 700; color: #fff; }
.profile-info { flex: 1; min-width: 0; }
.profile-alias {
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: clamp(32px, 5vw, 54px); font-weight: 400;
  letter-spacing: 3px; color: var(--text); line-height: 1;
}
.profile-name {
  font-size: 15px; color: var(--text-2); margin: 4px 0 2px; letter-spacing: 0.5px;
}
.profile-tag { font-size: 13px; color: var(--text-3); margin-bottom: 12px; }
.profile-region-chip {
  display: inline-block; padding: 3px 10px;
  border-radius: 999px; border: 1px solid var(--border2);
  background: rgba(255,255,255,0.05);
  font-size: 11px; font-weight: 600; letter-spacing: 2px; color: var(--text-2);
}
.profile-rank-peek { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.rank-img-hero { width: 80px; height: 80px; object-fit: contain; filter: drop-shadow(0 0 14px rgba(255,70,85,0.35)); }
.profile-rank-name { font-family: 'Rajdhani', sans-serif; font-size: 22px; font-weight: 700; color: var(--text); letter-spacing: 1px; }
.profile-rank-rr   { font-size: 14px; color: var(--red); font-weight: 600; margin-top: 2px; }

/* ── CHIPS ──────────────────────────────────────── */
.chips-row {
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-bottom: 18px;
  animation: fadeUp 0.35s 0.08s ease both;
}
.chip {
  flex: 1; min-width: 110px;
  padding: 13px 16px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: border-color var(--t), background var(--t);
}
.chip:hover { border-color: var(--border2); background: var(--surface2); }
.chip-label {
  display: block; font-size: 9.5px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 5px;
}
.chip-value {
  font-family: 'Rajdhani', sans-serif;
  font-size: 20px; font-weight: 700; color: var(--text);
}
.chip-value.positive { color: var(--win); }
.chip-value.negative { color: var(--loss); }
.chip-value.mono { font-family: 'Courier New', monospace; font-size: 13px; }

/* ── GRID ───────────────────────────────────────── */
.grid-two {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; margin-bottom: 18px;
}

/* ── PERFORMANCE CARD ───────────────────────────── */
.perf-card {
  margin-bottom: 18px;
  animation-delay: 0.12s;
}
.perf-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: 0 0 var(--radius) var(--radius);
  overflow: hidden;
  margin-top: 0;
}
.perf-stat {
  background: var(--surface);
  padding: 16px 18px;
  transition: background var(--t);
}
.perf-stat:hover { background: var(--surface2); }
.perf-stat-val {
  font-family: 'Rajdhani', sans-serif;
  font-size: 26px; font-weight: 700; color: var(--text);
  line-height: 1; margin-bottom: 4px;
  display: flex; align-items: center; gap: 7px;
}
.perf-stat-val.perf-positive { color: var(--win); }
.perf-stat-val.perf-negative { color: var(--loss); }
.perf-stat-lbl {
  font-size: 9.5px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 3px;
}
.perf-stat-sub {
  font-size: 11px; color: var(--text-3);
}
.perf-agent-icon {
  width: 26px; height: 26px; object-fit: contain; border-radius: 4px;
}

/* ── CARD ───────────────────────────────────────── */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  transition: border-color var(--t);
  animation: fadeUp 0.35s ease both;
}
.card:hover { border-color: var(--border2); }
.card:nth-child(2) { animation-delay: 0.07s; }
.card-hd {
  display: flex; align-items: center; gap: 10px;
  padding: 18px 20px 0; margin-bottom: 16px;
}
.card-icon-wrap {
  width: 30px; height: 30px; border-radius: 8px;
  background: linear-gradient(135deg, rgba(255,70,85,0.15), rgba(255,70,85,0.08));
  border: 1px solid rgba(255,70,85,0.25);
  display: flex; align-items: center; justify-content: center;
  color: var(--red); flex-shrink: 0;
}
.card-hd h2 {
  font-family: 'Rajdhani', sans-serif; font-size: 13px;
  font-weight: 700; letter-spacing: 3px; text-transform: uppercase;
  color: var(--text-2); flex: 1;
}
.card-tag {
  font-size: 11px; font-weight: 600; padding: 2px 8px;
  border-radius: 4px; background: var(--surface2); border: 1px solid var(--border);
  color: var(--text-3); letter-spacing: 1px;
}

/* ── RANK CARD ──────────────────────────────────── */
.rank-body { display: flex; align-items: center; gap: 20px; padding: 0 20px 22px; }
.rank-emblem-wrap { position: relative; flex-shrink: 0; }
.rank-glow {
  position: absolute; inset: -8px; border-radius: 50%;
  background: radial-gradient(circle, var(--red-glow) 0%, transparent 70%);
  pointer-events: none;
  filter: blur(2px);
}
.rank-img { width: 80px; height: 80px; object-fit: contain; position: relative; z-index: 1; }
.rank-placeholder {
  width: 80px; height: 80px; border-radius: 12px;
  background: var(--surface2); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 30px; color: var(--text-3);
}
.rank-details { flex: 1; min-width: 0; }
.rank-tier {
  font-family: 'Rajdhani', sans-serif; font-size: 26px;
  font-weight: 700; letter-spacing: 1px; color: var(--text); margin-bottom: 10px;
}
.rr-track { height: 4px; border-radius: 2px; background: var(--surface3); overflow: hidden; margin-bottom: 6px; }
.rr-fill {
  height: 100%; border-radius: 2px;
  background: linear-gradient(to right, var(--red), #ff8891);
  transition: width 0.8s cubic-bezier(0.4,0,0.2,1);
  box-shadow: 0 0 8px rgba(255,70,85,0.5);
}
.rr-label { font-size: 13px; font-weight: 600; color: var(--red); }
.elo-text  { font-size: 12px; color: var(--text-3); margin-top: 4px; }

/* ── ACCOUNT CARD ───────────────────────────────── */
.acct-fields { padding: 0 20px 22px; display: flex; flex-direction: column; gap: 13px; }
.acct-label {
  display: block; font-size: 9.5px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 3px;
}
.acct-value { font-size: 15px; font-weight: 500; color: var(--text); word-break: break-all; }
.acct-value.accent { color: var(--red); font-family: 'Rajdhani', sans-serif; font-size: 22px; font-weight: 700; }
.acct-value.mono { font-family: 'Courier New', monospace; font-size: 11.5px; color: var(--text-2); }
.acct-value.tiny { font-size: 11px; }
.acct-value.selectable { user-select: all; cursor: text; }

.profile-title {
  font-size: 11px; color: var(--text-3); font-style: italic;
  letter-spacing: 0.5px; margin-top: 2px;
}

/* ── MATCHES ────────────────────────────────────── */
.matches-wrap { animation: fadeUp 0.35s 0.16s ease both; }
.matches-hd {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.matches-title-group { display: flex; align-items: center; gap: 8px; color: var(--text-2); }
.matches-title-group h2 {
  font-family: 'Rajdhani', sans-serif; font-size: 13px;
  font-weight: 700; letter-spacing: 3px; color: var(--text-2);
}
.matches-sub { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-3); }
.matches-list { display: flex; flex-direction: column; gap: 8px; }

.match-row {
  display: grid; grid-template-columns: 3px 62px 1fr auto auto;
  align-items: center; gap: 16px;
  padding: 14px 18px 14px 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: border-color var(--t), background var(--t), transform var(--t);
  animation: fadeUp 0.3s ease both;
  position: relative; overflow: hidden;
}
.match-row-bg {
  position: absolute; inset: 0;
  background-image: var(--map-bg, none);
  background-size: cover; background-position: center;
  opacity: 0.09;
  transition: opacity var(--t);
  pointer-events: none; z-index: 0;
}
.match-row:hover .match-row-bg { opacity: 0.17; }
.match-row > *:not(.match-row-bg) { position: relative; z-index: 1; }
.match-row:hover { border-color: rgba(255,70,85,0.35); background: var(--surface2); transform: translateX(3px); }
.match-row:nth-child(1) { animation-delay: 0.04s; }
.match-row:nth-child(2) { animation-delay: 0.08s; }
.match-row:nth-child(3) { animation-delay: 0.12s; }
.match-row:nth-child(4) { animation-delay: 0.16s; }
.match-row:nth-child(5) { animation-delay: 0.20s; }

.match-bar { align-self: stretch; border-radius: 2px; min-height: 40px; }
.match-bar.win  { background: var(--win);  box-shadow: 0 0 8px rgba(78,204,163,0.4); }
.match-bar.loss { background: var(--loss); box-shadow: 0 0 8px rgba(255,70,85,0.3); }
.match-bar.draw { background: var(--draw); }

.match-agent {
  width: 62px; height: 62px; border-radius: 10px;
  overflow: hidden; background: var(--surface2);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.match-agent img { width: 100%; height: 100%; object-fit: cover; }
.match-agent img.agent-face { object-fit: contain; background: transparent; }
.match-agent-text { font-size: 9.5px; font-weight: 700; letter-spacing: 0.5px; color: var(--text-3); text-align: center; padding: 4px; }

.match-info { min-width: 0; }
.match-map {
  font-family: 'Rajdhani', sans-serif; font-size: 17px;
  font-weight: 700; letter-spacing: 0.5px; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.match-meta { font-size: 12px; color: var(--text-2); margin: 3px 0; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.match-meta .dot { color: var(--text-3); }
.match-date  { font-size: 11px; color: var(--text-3); }

.match-kda { text-align: center; }
.kda-num { font-family: 'Rajdhani', sans-serif; font-size: 20px; font-weight: 700; color: var(--text); white-space: nowrap; }
.kda-num .sep { color: var(--text-3); font-weight: 400; }
.kda-sub { font-size: 9px; font-weight: 700; letter-spacing: 2px; color: var(--text-3); text-transform: uppercase; margin-top: 2px; }

.match-badge {
  padding: 6px 16px; border-radius: 7px;
  font-family: 'Rajdhani', sans-serif; font-size: 13px;
  font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase;
  min-width: 68px; text-align: center; white-space: nowrap;
}
.match-badge.win  { background: rgba(78,204,163,0.12); color: var(--win);  border: 1px solid rgba(78,204,163,0.3); }
.match-badge.loss { background: rgba(255,70,85,0.1);  color: var(--loss); border: 1px solid rgba(255,70,85,0.25); }
.match-badge.draw { background: rgba(114,114,160,0.1); color: var(--draw); border: 1px solid rgba(114,114,160,0.2); }

/* See More button */
.see-more-btn {
  display: block; width: 100%; margin-top: 4px;
  padding: 12px 20px;
  background: var(--surface); border: 1px dashed rgba(255,70,85,0.35);
  border-radius: var(--radius-sm);
  color: var(--red);
  font-family: 'Rajdhani', sans-serif; font-size: 13px;
  font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase;
  cursor: pointer;
  transition: background var(--t), border-color var(--t), color var(--t);
}
.see-more-btn:hover {
  background: rgba(255,70,85,0.08);
  border-color: var(--red);
}

.see-more-btn:hover {
  background: rgba(255,70,85,0.08);
  border-color: var(--red);
}

/* ── AGENT POOL (inside rank card) ──────────────── */
.agents-in-rank {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  overflow: visible;
  position: relative;
  z-index: 10;
}
.agents-in-rank-label {
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  color: var(--text-3); text-transform: uppercase; margin-bottom: 8px;
  padding: 0 20px;
}
.agents-grid-sm {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 0 20px 20px;
}
.agent-chip-sm {
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border-radius: 6px;
  border: 1px solid transparent;
  transition: transform var(--t), box-shadow var(--t);
  cursor: default; position: relative;
}
.agent-chip-sm:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.5);
  z-index: 2;
}
.agent-chip-sm:hover::after {
  content: attr(title);
  position: absolute; bottom: calc(100% + 6px); left: 50%;
  transform: translateX(-50%);
  background: var(--surface3); border: 1px solid var(--border2);
  border-radius: 6px; padding: 4px 8px;
  font-size: 11px; font-weight: 600; color: var(--text);
  white-space: nowrap; pointer-events: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.agent-chip-icon-sm { width: 26px; height: 26px; object-fit: contain; border-radius: 4px; }
.agent-chip-sm.role-duelist    { background: rgba(255,70,85,0.15);  border-color: rgba(255,70,85,0.35); }
.agent-chip-sm.role-controller { background: rgba(91,139,216,0.15); border-color: rgba(91,139,216,0.35); }
.agent-chip-sm.role-sentinel   { background: rgba(232,184,75,0.15); border-color: rgba(232,184,75,0.35); }
.agent-chip-sm.role-initiator  { background: rgba(61,186,109,0.15); border-color: rgba(61,186,109,0.35); }

/* ── 5-STACK PICKER VIEW ────────────────────────── */
.picker-nav-btn { color: #f0b429; }
.picker-nav-btn.active { background: rgba(240,180,41,0.12); border-color: rgba(240,180,41,0.35); }
.fivevfive-nav-btn { color: #5b8bd8; }
.fivevfive-nav-btn.active { background: rgba(91,139,216,0.12); border-color: rgba(91,139,216,0.35); }

.fivevfive-select-all-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 20px;
  background: transparent;
  border: 1.5px solid rgba(91,139,216,0.45);
  border-radius: 20px;
  color: #5b8bd8;
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase;
  cursor: pointer;
  transition: background var(--t), border-color var(--t), color var(--t), transform var(--t);
}
.fivevfive-select-all-btn:hover {
  background: rgba(91,139,216,0.12);
  border-color: #5b8bd8;
  transform: translateY(-1px);
}
.fivevfive-select-all-btn:active { transform: translateY(0); }

.fivevfive-randomise-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 20px;
  background: transparent;
  border: 1.5px solid rgba(255,180,50,0.45);
  border-radius: 20px;
  color: #f5a623;
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase;
  cursor: pointer;
  transition: background var(--t), border-color var(--t), color var(--t), transform var(--t);
}
.fivevfive-randomise-btn:hover:not(:disabled) {
  background: rgba(245,166,35,0.1);
  border-color: #f5a623;
  transform: translateY(-1px);
}
.fivevfive-randomise-btn:active:not(:disabled) { transform: translateY(0); }
.fivevfive-randomise-btn:disabled { opacity: 0.35; cursor: not-allowed; }

/* ── 5v5 TEAM BALANCER ──────────────────────────── */
.fivevfive-view {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto;
  padding: 32px 28px 64px;
}
.fivevfive-result {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.fivevfive-team {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  animation: fadeUp 0.3s ease both;
}
.fivevfive-team-header {
  padding: 14px 20px; font-family: 'Rajdhani', sans-serif;
  font-size: 16px; font-weight: 700; letter-spacing: 1px;
  display: flex; align-items: center; justify-content: space-between;
}
.fivevfive-team.team-a .fivevfive-team-header { background: rgba(255,70,85,0.12); color: #ff8895; border-bottom: 1px solid rgba(255,70,85,0.2); }
.fivevfive-team.team-b .fivevfive-team-header { background: rgba(91,139,216,0.12); color: #8ab4f8; border-bottom: 1px solid rgba(91,139,216,0.2); }
.fivevfive-avg {
  font-size: 11px; font-weight: 600; letter-spacing: 0.5px;
  opacity: 0.8;
}
.fivevfive-player-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 18px; border-bottom: 1px solid var(--border);
  transition: background var(--t);
}
.fivevfive-player-row:last-child { border-bottom: none; }
.fivevfive-player-row:hover { background: var(--surface3); }
.fivevfive-seed {
  font-size: 11px; font-weight: 700; color: var(--text-3);
  min-width: 20px; text-align: center;
}
.fivevfive-avatar {
  width: 38px; height: 38px; border-radius: 8px;
  background: var(--surface3); border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 700;
  color: var(--text-2); overflow: hidden; flex-shrink: 0;
}
.fivevfive-avatar img { width: 100%; height: 100%; object-fit: contain; }
.fivevfive-info { flex: 1; min-width: 0; }
.fivevfive-alias {
  font-family: 'Rajdhani', sans-serif; font-size: 15px; font-weight: 700; color: var(--text);
}
.fivevfive-rank {
  font-size: 11px; color: var(--text-3);
}
.fivevfive-rank-icon { width: 22px; height: 22px; object-fit: contain; flex-shrink: 0; }
.fivevfive-no-rank {
  text-align: center; padding: 32px 0; color: var(--text-3); font-size: 14px;
}
.fivevfive-select-hint {
  font-size: 13px; color: var(--text-3); text-align: center;
  padding: 12px 0 4px;
}
.fivevfive-selected-count {
  font-family: 'Rajdhani', sans-serif; font-size: 18px; font-weight: 700;
  color: var(--text); text-align: center; margin-bottom: 16px;
}
.fivevfive-selected-count span { color: var(--red); }

/* ── RANDOM MAP SPINNER ──────────────────────────── */
.map-spinner-section {
  display: flex; flex-direction: column; gap: 16px;
  padding-top: 24px; border-top: 1px solid var(--border); margin-top: 8px;
}
.map-spin-area {
  display: flex; align-items: center; gap: 32px;
}
.map-slot-wrapper {
  position: relative; flex-shrink: 0;
}
.map-slot-mask {
  width: 280px; height: 110px; overflow: hidden;
  border-radius: 12px; border: 2px solid var(--border2);
  background: var(--surface2); position: relative;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.map-slot-mask.spinning {
  border-color: var(--red);
  box-shadow: 0 0 28px rgba(255,70,85,0.3);
}
.map-slot-strip {
  display: flex; flex-direction: column; will-change: transform;
}
.map-slot-card {
  width: 280px; height: 110px; flex-shrink: 0;
  background: var(--surface3) center/cover no-repeat;
  position: relative; display: flex; align-items: flex-end;
}
.map-slot-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.1) 60%, transparent 100%);
}
.map-slot-name {
  position: relative; z-index: 1;
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 20px; letter-spacing: 3px; color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,0.9);
  padding: 8px 12px;
}
/* Centre needle lines */
.map-slot-needle {
  position: absolute; left: 0; right: 0;
  top: 50%; transform: translateY(-50%);
  pointer-events: none;
}
.map-slot-needle::before,
.map-slot-needle::after {
  content: ''; display: block;
  height: 2px; background: var(--red);
  box-shadow: 0 0 8px rgba(255,70,85,0.7);
}
.map-slot-needle::before { margin-bottom: 106px; }
/* spin controls */
.map-spin-controls {
  display: flex; flex-direction: column; gap: 10px;
}
.map-spin-btn {
  padding: 14px 32px;
  background: linear-gradient(135deg, var(--red), #d43545);
  border: none; border-radius: 12px;
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 20px; letter-spacing: 3px; color: #fff; cursor: pointer;
  box-shadow: 0 4px 20px rgba(255,70,85,0.35);
  transition: transform var(--t), box-shadow var(--t), opacity var(--t);
  white-space: nowrap;
}
.map-spin-btn:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(255,70,85,0.55);
}
.map-spin-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.map-spin-hint {
  font-size: 12px; color: var(--text-3); letter-spacing: 0.3px;
}
/* Result card */
.map-spin-result {
  border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--border2);
  animation: fadeUp 0.35s ease both;
}
.msr-banner {
  position: relative; height: 100px;
  background: var(--surface3) center/cover no-repeat;
}
.msr-banner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(10,25,35,0.88) 0%, rgba(10,25,35,0.35) 70%, transparent 100%);
}
.msr-banner-name {
  position: absolute; left: 22px; top: 50%; transform: translateY(-50%);
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 36px; letter-spacing: 5px; color: #fff;
  text-shadow: 0 2px 16px rgba(0,0,0,0.8);
}
.msr-body {
  background: var(--surface2); padding: 18px 22px;
  display: flex; flex-direction: column; gap: 12px;
}
.msr-label {
  font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: 2px; color: var(--text-3); text-transform: uppercase;
}
.msr-tier-rows {
  display: flex; flex-direction: column; gap: 10px;
}
.msr-tier-row {
  display: flex; align-items: flex-start; gap: 10px; flex-wrap: wrap;
}
.msr-tier-badge {
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 14px; letter-spacing: 1px; font-weight: 700;
  padding: 3px 9px; border-radius: 6px; flex-shrink: 0; margin-top: 2px;
}
.msr-tier-badge.meta-s { background: rgba(255,70,85,0.15); color: #ff4655; border: 1px solid rgba(255,70,85,0.3); }
.msr-tier-badge.meta-a { background: rgba(255,165,0,0.13); color: #ffa500; border: 1px solid rgba(255,165,0,0.3); }
.msr-tier-badge.meta-b { background: rgba(0,212,170,0.1);  color: var(--teal); border: 1px solid rgba(0,212,170,0.25); }
.msr-agents {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.msr-agent {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 10px 4px 5px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--border2);
  border-radius: 20px;
}
.msr-agent.meta-s { border-color: rgba(255,70,85,0.3); }
.msr-agent.meta-a { border-color: rgba(255,165,0,0.3); }
.msr-agent.meta-b { border-color: rgba(0,212,170,0.25); }
.msr-agent img { width: 26px; height: 26px; object-fit: contain; border-radius: 4px; }
.msr-agent span {
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  color: var(--text); letter-spacing: 0.5px;
}
.msr-respin {
  align-self: flex-start; font-size: 15px; padding: 10px 22px;
}
@media (max-width: 640px) {
  .map-spin-area    { flex-direction: column; align-items: stretch; gap: 16px; }
  .map-slot-mask    { width: 100%; }
  .map-slot-card    { width: 100%; }
  .map-spin-btn     { width: 100%; }
}

/* ── NEW AGENT WHEEL ──────────────────────────────── */
.wheel-nav-btn { color: #c084fc; }
.wheel-nav-btn.active { background: rgba(192,132,252,0.12); border-color: rgba(192,132,252,0.35); }

.wheel-setup { display: flex; flex-direction: column; gap: 24px; }
.wheel-step  {}
.wheel-label {
  display: block;
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 10px;
}

/* Player selector pills */
.wheel-player-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.wheel-player-card {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 14px 7px 8px;
  background: var(--surface2); border: 1.5px solid var(--border2);
  border-radius: 24px; cursor: pointer;
  transition: border-color var(--t), background var(--t), transform var(--t);
}
.wheel-player-card:hover { border-color: rgba(192,132,252,0.5); transform: translateY(-1px); }
.wheel-player-card.selected { border-color: #c084fc; background: rgba(192,132,252,0.1); }
.wheel-player-card .wp-avatar {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--surface3); border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; flex-shrink: 0;
  font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 700; color: var(--text-2);
}
.wheel-player-card .wp-avatar img { width: 100%; height: 100%; object-fit: contain; }
.wheel-player-card .wp-name {
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 700; color: var(--text);
}

/* Role selector */
.wheel-role-btns { display: flex; flex-wrap: wrap; gap: 8px; }
.wheel-role-btn {
  padding: 7px 18px;
  background: var(--surface2); border: 1.5px solid var(--border2);
  border-radius: 20px; cursor: pointer;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  letter-spacing: 0.8px; color: var(--text-2);
  transition: border-color var(--t), background var(--t), color var(--t);
}
.wheel-role-btn:hover                          { border-color: rgba(192,132,252,0.5); color: #c084fc; }
.wheel-role-btn.active                         { border-color: #c084fc; background: rgba(192,132,252,0.12); color: #c084fc; }
.wheel-role-btn[data-role="duelist"].active    { border-color: #ff4655; background: rgba(255,70,85,0.1);   color: #ff8895; }
.wheel-role-btn[data-role="controller"].active { border-color: #f0b429; background: rgba(240,180,41,0.1);  color: #f5c842; }
.wheel-role-btn[data-role="sentinel"].active   { border-color: #4ade80; background: rgba(74,222,128,0.1); color: #4ade80; }
.wheel-role-btn[data-role="initiator"].active  { border-color: #5b8bd8; background: rgba(91,139,216,0.1); color: #8ab4f8; }

/* Slot machine */
.wheel-spin-area {
  display: flex; align-items: center; justify-content: flex-start; gap: 36px;
  padding: 8px 0;
}
.wheel-slot-wrapper { position: relative; }
.wheel-slot-mask {
  width: 140px; height: 140px; overflow: hidden;
  border-radius: 16px; border: 2px solid var(--border2);
  background: var(--surface2); position: relative;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.wheel-slot-mask.spinning {
  border-color: #c084fc;
  box-shadow: 0 0 24px rgba(192,132,252,0.35);
}
.wheel-slot-strip { display: flex; flex-direction: column; will-change: transform; }
.wheel-slot-card {
  width: 140px; height: 140px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.wheel-slot-card img { width: 90px; height: 90px; object-fit: contain; }
.wheel-slot-card .ws-initials {
  font-family: 'Rajdhani', sans-serif; font-size: 34px; font-weight: 700; color: var(--text-2);
}
.wheel-spin-btn {
  padding: 14px 38px;
  background: linear-gradient(135deg, #a855f7, #c084fc);
  border: none; border-radius: 12px;
  font-family: 'Rajdhani', sans-serif; font-size: 20px; font-weight: 800;
  letter-spacing: 2px; color: #fff; cursor: pointer;
  box-shadow: 0 4px 20px rgba(168,85,247,0.35);
  transition: transform var(--t), box-shadow var(--t), opacity var(--t);
}
.wheel-spin-btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 6px 28px rgba(168,85,247,0.5); }
.wheel-spin-btn:active:not(:disabled) { transform: translateY(0); }
.wheel-spin-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Result card */
.wheel-result {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 28px;
  animation: fadeUp 0.4s ease both;
}
.wheel-result-inner { display: flex; align-items: flex-start; gap: 24px; }
.wheel-result-icon {
  width: 100px; height: 100px; flex-shrink: 0;
  background: var(--surface3); border-radius: 14px; border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.wheel-result-icon img { width: 80px; height: 80px; object-fit: contain; }
.wheel-result-info { flex: 1; min-width: 0; }
.wheel-result-name {
  font-family: 'Rajdhani', sans-serif; font-size: 34px; font-weight: 800;
  color: var(--text); text-transform: uppercase; line-height: 1; margin-bottom: 8px;
}
.wheel-result-role {
  display: inline-block;
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  padding: 3px 10px; border-radius: 10px; margin-bottom: 14px;
}
.role-bg-duelist    { background: rgba(255,70,85,0.15);  color: #ff8895; border: 1px solid rgba(255,70,85,0.3); }
.role-bg-controller { background: rgba(240,180,41,0.15); color: #f5c842; border: 1px solid rgba(240,180,41,0.3); }
.role-bg-sentinel   { background: rgba(74,222,128,0.15); color: #4ade80; border: 1px solid rgba(74,222,128,0.3); }
.role-bg-initiator  { background: rgba(91,139,216,0.15); color: #8ab4f8; border: 1px solid rgba(91,139,216,0.3); }
.role-bg-unknown    { background: rgba(150,150,150,0.15); color: #aaa;   border: 1px solid rgba(150,150,150,0.3); }
.wheel-result-desc {
  font-size: 14px; line-height: 1.65; color: var(--text-2); margin-bottom: 18px;
}
.wheel-result-link {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 18px;
  background: transparent; border: 1.5px solid rgba(192,132,252,0.45);
  border-radius: 20px; color: #c084fc;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  letter-spacing: 0.8px; text-transform: uppercase; text-decoration: none;
  transition: background var(--t), border-color var(--t), transform var(--t);
}
.wheel-result-link:hover { background: rgba(192,132,252,0.1); border-color: #c084fc; transform: translateY(-1px); }
.wheel-result-actions {
  margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border);
  display: flex; gap: 12px; flex-wrap: wrap;
}
.wheel-respin-btn {
  padding: 8px 20px;
  background: transparent; border: 1.5px solid rgba(192,132,252,0.45);
  border-radius: 20px; color: #c084fc;
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  letter-spacing: 0.8px; text-transform: uppercase; cursor: pointer;
  transition: background var(--t), border-color var(--t), transform var(--t);
}
.wheel-respin-btn:hover { background: rgba(192,132,252,0.1); border-color: #c084fc; transform: translateY(-1px); }
@media (max-width: 540px) {
  .wheel-result-inner { flex-direction: column; align-items: center; }
  .wheel-result-name  { text-align: center; }
  .wheel-result-role  { display: block; text-align: center; }
  .wheel-result-desc  { text-align: center; }
  .wheel-result-actions { justify-content: center; }
}

/* ── LINEUPS ──────────────────────────────────────── */
.lineups-nav-btn { color: #34d399; }
.lineups-nav-btn.active { background: rgba(52,211,153,0.12); border-color: rgba(52,211,153,0.35); }

.lineups-agent-grid {
  display: flex; flex-direction: column; gap: 28px;
}
.lineups-role-section {}
.lineups-role-heading {
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 12px;
}
.lineups-role-heading.role-duelist    { color: #ff8895; }
.lineups-role-heading.role-controller { color: #f5c842; }
.lineups-role-heading.role-sentinel   { color: #4ade80; }
.lineups-role-heading.role-initiator  { color: #8ab4f8; }

.lineups-cards { display: flex; flex-wrap: wrap; gap: 12px; }
.lineups-agent-card {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 14px 12px;
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--card-accent, #34d399) 14%, var(--surface2)) 0%,
    var(--surface2) 65%
  );
  border: 1.5px solid color-mix(in srgb, var(--card-accent, #34d399) 28%, var(--border2));
  border-bottom: 2px solid color-mix(in srgb, var(--card-accent, #34d399) 50%, transparent);
  border-radius: 12px; cursor: pointer; text-decoration: none;
  min-width: 90px;
  transition: border-color var(--t), background var(--t), transform var(--t), box-shadow var(--t);
}
.lineups-agent-card:hover {
  border-color: color-mix(in srgb, var(--card-accent, #34d399) 80%, transparent);
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--card-accent, #34d399) 24%, var(--surface2)) 0%,
    var(--surface2) 65%
  );
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3), 0 0 20px color-mix(in srgb, var(--card-accent, #34d399) 14%, transparent);
}
.lineups-agent-card .la-icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
}
.lineups-agent-card .la-icon img { width: 52px; height: 52px; object-fit: contain; }
.lineups-agent-card .la-name {
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 700;
  color: var(--text-2); text-transform: uppercase; letter-spacing: 0.5px;
  text-align: center;
}
.lineups-agent-card:hover .la-name {
  color: color-mix(in srgb, var(--card-accent, #34d399) 90%, white);
}

.picker-view {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto;
  padding: 32px 28px 64px;
}
.picker-wrap { display: flex; flex-direction: column; gap: 28px; }
.picker-header {
  display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
}
.picker-title-group { display: flex; flex-direction: column; gap: 4px; }
.picker-title {
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 28px; font-weight: 400; letter-spacing: 3px; color: var(--text);
}
.picker-sub {
  font-size: 13px; font-weight: 500;
  color: var(--text-2);
  letter-spacing: 0.3px;
  padding: 5px 12px;
  background: rgba(255,255,255,0.04);
  border-left: 2px solid rgba(255,70,85,0.45);
  border-radius: 0 4px 4px 0;
  display: inline-block;
}
#fivevfive-count-label {
  font-family: 'Rajdhani', sans-serif;
  font-size: 15px; font-weight: 700; letter-spacing: 1px;
  border-left-color: var(--teal);
  color: var(--text);
  transition: color var(--t), border-color var(--t), background var(--t);
}
#fivevfive-count-label.has-selection {
  color: var(--teal);
  background: rgba(0,212,170,0.06);
  border-left-color: var(--teal);
  box-shadow: 0 0 14px rgba(0,212,170,0.1);
}

/* Player selection grid */
.picker-player-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px;
}
.picker-p-card {
  position: relative;
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--card-accent, var(--red)) 10%, var(--surface)) 0%,
    var(--surface) 60%
  );
  border: 1px solid color-mix(in srgb, var(--card-accent, var(--red)) 22%, var(--border));
  border-bottom: 2px solid color-mix(in srgb, var(--card-accent, var(--red)) 40%, transparent);
  border-radius: var(--radius-sm);
  padding: 10px 8px 8px; text-align: center; cursor: pointer;
  transition: border-color var(--t), background var(--t), transform var(--t), box-shadow var(--t);
  user-select: none;
}
.picker-p-card:hover {
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--card-accent, var(--red)) 18%, var(--surface2)) 0%,
    var(--surface2) 60%
  );
  border-color: color-mix(in srgb, var(--card-accent, var(--red)) 55%, transparent);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.35), 0 0 20px color-mix(in srgb, var(--card-accent, var(--red)) 8%, transparent);
}
.picker-p-card.selected {
  border-color: var(--card-accent, var(--red));
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--card-accent, var(--red)) 22%, var(--surface2)) 0%,
    var(--surface2) 60%
  );
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--card-accent, var(--red)) 20%, transparent),
              0 0 24px color-mix(in srgb, var(--card-accent, var(--red)) 12%, transparent);
}
.picker-p-avatar {
  width: 40px; height: 40px; border-radius: 8px; margin: 0 auto 6px;
  background: var(--surface3); border: 2px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 700; color: var(--text-2);
  overflow: hidden; position: relative;
  transition: border-color var(--t);
}
.picker-p-card.selected .picker-p-avatar { border-color: var(--card-accent, var(--red)); }
.picker-p-avatar-img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.picker-p-alias { font-family: 'Rajdhani', sans-serif; font-size: 12px; font-weight: 700; color: var(--text); letter-spacing: 0.3px; }
.picker-p-check {
  position: absolute; top: 5px; right: 5px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--card-accent, var(--red)); color: #fff; font-size: 9px;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(0.5); transition: opacity var(--t), transform var(--t);
}
.picker-p-card.selected .picker-p-check { opacity: 1; transform: scale(1); }

/* ── MAP SELECTOR ───────────────────────────────── */
.picker-map { display: flex; flex-direction: column; gap: 14px; }
.picker-map-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
.picker-map-card {
  position: relative; height: 82px;
  background: var(--surface2) center/cover no-repeat;
  border: 2px solid var(--border2);
  border-radius: 10px; cursor: pointer; overflow: hidden;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
  padding: 0;
}
.picker-map-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.18) 55%, transparent 100%);
}
.picker-map-card:hover {
  border-color: var(--red);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.5), 0 0 16px rgba(255,70,85,0.15);
}
.picker-map-card.selected {
  border-color: var(--teal);
  box-shadow: 0 0 0 2px rgba(0,212,170,0.25), 0 8px 24px rgba(0,0,0,0.5);
}
.picker-map-card.selected::before {
  background: linear-gradient(to top, rgba(0,50,42,0.85) 0%, rgba(0,30,25,0.25) 55%, transparent 100%);
}
.picker-map-name {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 5px 4px;
  text-align: center;
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  color: #fff; text-shadow: 0 1px 4px rgba(0,0,0,0.9);
}
.picker-map-card.selected .picker-map-name { color: var(--teal); }
@media (max-width: 1024px) { .picker-map-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 640px)  { .picker-map-grid { grid-template-columns: repeat(3, 1fr); } .picker-map-card { height: 68px; } }

/* Meta tier badge on assignment cards */
.meta-badge {
  display: inline-block; margin-left: 6px;
  font-family: 'Rajdhani', sans-serif; font-size: 9px; font-weight: 700;
  letter-spacing: 1px; padding: 1px 5px; border-radius: 3px;
  vertical-align: middle; position: relative; top: -1px;
}
.meta-s { background: rgba(255,70,85,0.18);  color: #ff8895;  border: 1px solid rgba(255,70,85,0.35); }
.meta-a { background: rgba(245,166,35,0.18); color: #f5c842;  border: 1px solid rgba(245,166,35,0.35); }
.meta-b { background: rgba(0,212,170,0.12);  color: var(--teal); border: 1px solid rgba(0,212,170,0.25); }

/* Map banner at top of result */
.picker-result-map {
  position: relative; height: 90px; border-radius: var(--radius) var(--radius) 0 0;
  background: var(--surface3) center/cover no-repeat;
  overflow: hidden; margin-bottom: 0;
}
.picker-result-map::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(10,25,35,0.9) 0%, rgba(10,25,35,0.45) 60%, transparent 100%);
}
.picker-result-map-name {
  position: absolute; left: 20px; top: 50%; transform: translateY(-50%);
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif; font-size: 28px;
  letter-spacing: 4px; color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,0.8);
}
.picker-result { display: flex; flex-direction: column; gap: 0; }
.picker-result .picker-result-header {
  border: 1px solid var(--border); border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  background: var(--surface2);
  padding: 16px 20px; margin-bottom: 12px;
}
.picker-result:not(:has(.picker-result-map)) .picker-result-header {
  border-top: 1px solid var(--border);
  border-radius: var(--radius);
}

/* Composition choice */
.picker-compose {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px 24px;
}
.picker-compose-label {
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 2.5px;
  color: var(--text-3); text-transform: uppercase; margin-bottom: 12px;
  display: flex; align-items: center; gap: 8px;
}
.picker-compose-label::before {
  content: ''; display: block;
  width: 20px; height: 1px; background: var(--red); opacity: 0.5;
}
.picker-comp-btns { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.picker-comp-btn {
  position: relative; overflow: hidden;
  background: var(--surface3);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 0;
  cursor: pointer; text-align: left;
  display: flex; flex-direction: column;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
}
/* Coloured top stripe per comp */
.picker-comp-btn:first-child { --comp-color: #ff4655; }
.picker-comp-btn:last-child  { --comp-color: #5b8bd8; }
.picker-comp-btn::before {
  content: ''; display: block;
  height: 3px; width: 100%;
  background: var(--comp-color);
  transition: height var(--t);
}
.picker-comp-btn:hover {
  border-color: var(--comp-color);
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(0,0,0,0.4), 0 0 20px color-mix(in srgb, var(--comp-color) 15%, transparent);
}
.picker-comp-btn:hover::before { height: 4px; }
.picker-comp-btn.active {
  border-color: var(--comp-color);
  background: color-mix(in srgb, var(--comp-color) 8%, var(--surface3));
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--comp-color) 20%, transparent);
}
.picker-comp-inner {
  padding: 16px 20px 18px;
  display: flex; flex-direction: column; gap: 10px;
}
.comp-label {
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 22px; letter-spacing: 2px;
  color: var(--text); line-height: 1;
  display: flex; align-items: center; gap: 8px;
}
.comp-label-icon {
  font-size: 18px; line-height: 1;
}
.comp-desc {
  font-size: 11px; color: var(--text-3); letter-spacing: 0.3px;
  line-height: 1.5;
}
/* Role pip row */
.comp-pips {
  display: flex; gap: 5px; flex-wrap: wrap; margin-top: 2px;
}
.comp-pip {
  font-family: 'Rajdhani', sans-serif; font-size: 9px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  padding: 2px 7px; border-radius: 3px;
}
.comp-pip-duelist    { background: rgba(255,70,85,0.15);  color: #ff8895;  border: 1px solid rgba(255,70,85,0.3); }
.comp-pip-controller { background: rgba(91,139,216,0.15); color: #8ab4f8;  border: 1px solid rgba(91,139,216,0.3); }
.comp-pip-sentinel   { background: rgba(232,184,75,0.15); color: #f0c860;  border: 1px solid rgba(232,184,75,0.3); }
.comp-pip-initiator  { background: rgba(61,186,109,0.15); color: #5ddfa0;  border: 1px solid rgba(61,186,109,0.3); }

/* Result */
.picker-result { display: flex; flex-direction: column; gap: 16px; }
.picker-result-header {
  display: flex; align-items: center; justify-content: space-between;
}
.picker-result-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 18px; font-weight: 700; letter-spacing: 1px; color: var(--text);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.picker-rank-label {
  font-family: 'Rajdhani', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 1.5px;
  color: var(--teal); background: rgba(0,212,170,0.1);
  border: 1px solid rgba(0,212,170,0.25);
  border-radius: 20px; padding: 2px 10px; white-space: nowrap;
}
.picker-reroll-btn {
  background: var(--surface3); border: 1px solid var(--border2);
  border-radius: 8px; padding: 8px 16px; cursor: pointer;
  font-size: 13px; font-weight: 600; color: var(--text-2);
  transition: border-color var(--t), color var(--t);
}
.picker-reroll-btn:hover { border-color: var(--red); color: var(--red); }
.picker-assignments {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 10px;
}
.assignment-card {
  display: flex; align-items: center; gap: 14px;
  background: var(--surface2); border: 1px solid var(--border);
  border-left-width: 3px; border-radius: var(--radius);
  padding: 14px 18px; animation: fadeUp 0.3s ease both;
}
.assignment-card.role-duelist    { border-left-color: #ff4655; }
.assignment-card.role-controller { border-left-color: #5b8bd8; }
.assignment-card.role-sentinel   { border-left-color: #e8b84b; }
.assignment-card.role-initiator  { border-left-color: #3dba6d; }
.assignment-player {
  font-family: 'Rajdhani', sans-serif; font-size: 17px; font-weight: 700;
  color: var(--text); min-width: 70px;
}
.assignment-arrow { color: var(--text-3); flex-shrink: 0; }
.assignment-agent { display: flex; align-items: center; gap: 10px; flex: 1; }
.assignment-agent-icon { width: 36px; height: 36px; object-fit: contain; border-radius: 6px; }
.assignment-agent-name {
  font-family: 'Rajdhani', sans-serif; font-size: 16px; font-weight: 700; color: var(--text);
}
.role-badge {
  font-size: 10px; font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase; padding: 2px 7px; border-radius: 4px; display: inline-block;
}
.role-badge-duelist    { background: rgba(255,70,85,0.15);  color: #ff8895; }
.role-badge-controller { background: rgba(91,139,216,0.15); color: #8ab4f8; }
.role-badge-sentinel   { background: rgba(232,184,75,0.15); color: #f0c860; }
.role-badge-initiator  { background: rgba(61,186,109,0.15); color: #5ddfa0; }
.picker-error {
  background: rgba(255,70,85,0.08); border: 1px solid rgba(255,70,85,0.3);
  border-radius: var(--radius); padding: 18px 22px;
  color: #ff8895; font-size: 14px; line-height: 1.6;
}

/* ── PICKER CALCULATING STATE ───────────────────── */
.picker-calculating {
  display: flex; align-items: center; gap: 18px;
  padding: 22px 24px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--radius);
  animation: fadeUp 0.2s ease both;
}
.picker-calc-spinner {
  width: 32px; height: 32px; flex-shrink: 0;
  border: 3px solid rgba(255,70,85,0.15);
  border-top-color: var(--red);
  border-right-color: var(--teal);
  border-radius: 50%;
  animation: spin 0.75s linear infinite;
}
.picker-calc-text { display: flex; flex-direction: column; gap: 4px; }
.picker-calc-title {
  font-family: 'Bebas Neue', 'Rajdhani', sans-serif;
  font-size: 18px; letter-spacing: 2px; color: var(--text);
}
.picker-calc-sub {
  font-size: 12px; color: var(--text-3); letter-spacing: 0.4px;
}

/* ── COMP QUALITY SUMMARY BAR ───────────────────── */
.comp-quality-bar {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--border2);
  border-radius: 999px;
  font-family: 'Rajdhani', sans-serif; font-size: 12px; font-weight: 700;
  letter-spacing: 1px;
}
.comp-sum-s   { color: #ff8895; }
.comp-sum-a   { color: #f5c842; }
.comp-sum-b   { color: var(--teal); }
.comp-sum-off { color: var(--text-3); }
.comp-sum-sep { color: var(--text-3); font-weight: 400; margin: 0 2px; }
.picker-result-title {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}

/* ── FOOTER ─────────────────────────────────────── */
.site-footer {
  position: relative; z-index: 1; margin-top: auto;
  padding: 18px 28px 22px; text-align: center;
  font-size: 12px; color: var(--text-3);
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.site-footer a { color: var(--text-3); text-decoration: underline; }
.site-footer a:hover { color: var(--red); }
.footer-meta {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: center;
}

/* ── UTILS ──────────────────────────────────────── */
.hidden { display: none !important; }
.empty-state { color: var(--text-3); font-size: 14px; text-align: center; padding: 28px 0; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── SYNC PROGRESS POPUP ────────────────────────────── */
.sync-popup {
  position: fixed; bottom: 24px; right: 24px; z-index: 900;
  width: 270px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  animation: fadeIn 0.2s ease;
}
.sync-popup.hidden { display: none; }
.sync-popup-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.sync-popup-title {
  font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: 1.8px; color: var(--text-2); text-transform: uppercase;
}
.sync-popup-close {
  background: none; border: none; color: var(--text-3); cursor: pointer;
  font-size: 14px; padding: 0; line-height: 1;
}
.sync-popup-close:hover { color: var(--text-1); }
.sync-popup-bar {
  height: 3px; background: var(--border); border-radius: 2px;
  margin-bottom: 12px; overflow: hidden;
}
.sync-popup-fill {
  height: 100%; background: var(--win); border-radius: 2px;
  transition: width 0.35s ease; width: 0%;
}
.sync-popup-list { display: flex; flex-direction: column; gap: 5px; }
.spr-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; transition: opacity 0.2s;
  min-height: 22px;
}
.spr-waiting { opacity: 0.35; }
.spr-active  { opacity: 1; }
.spr-done    { opacity: 0.75; }
.spr-icon {
  width: 16px; height: 16px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
}
.spr-waiting .spr-icon { color: var(--text-3); }
.spr-active  .spr-icon { color: var(--win); }
.spr-done    .spr-icon { color: var(--win); }
.spr-name { flex: 1; color: var(--text-2); font-weight: 600; }
.spr-rank { font-size: 11px; font-weight: 700; }
.spr-spinner {
  display: inline-block; width: 10px; height: 10px;
  border: 1.5px solid rgba(78,204,163,0.25); border-top-color: var(--win);
  border-radius: 50%; animation: spin 0.7s linear infinite;
}
/* ============================================================
   RESPONSIVE  � tablet (641-1024px) and mobile (=640px)
   Desktop layout (>1024px) is untouched.
   ============================================================ */

/* -- GLOBAL OVERFLOW FIX (all sizes) ------------------- */
html, body { max-width: 100%; overflow-x: hidden; }

/* -- TABLET --------------------------------------------- */
@media (max-width: 1024px) {
  .header-inner  { padding: 0 18px; }
  .sync-btn .sync-btn-label { display: none; }
  .sync-btn { padding: 6px 9px; gap: 4px; }
  .sync-btn-progress { min-width: 20px; }

  .hero-banner-wrap, .roster-section { padding: 0 18px; }
  .roster-grid { grid-template-columns: repeat(4, 1fr); gap: 12px; }

  .player-view { grid-template-columns: 180px 1fr; padding: 0 16px 80px; }

  .lb-view { padding: 28px 18px 60px; }
  .picker-view, .fivevfive-view, .compare-page-wrap { padding: 24px 18px 48px; }

  .picker-player-grid { grid-template-columns: repeat(4, 1fr); }
  .fivevfive-result   { grid-template-columns: 1fr 1fr; gap: 14px; }
  .grid-two           { gap: 12px; }
  .perf-grid          { grid-template-columns: repeat(4, 1fr); }
  .compare-roster-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
  .compare-pick-portrait { width: 56px; height: 56px; }
  .compare-pick-name  { font-size: 20px; }
}

/* -- MOBILE --------------------------------------------- */
@media (max-width: 640px) {

  /* === BOTTOM NAV BAR (replaces header nav on mobile) === */
  .header-right .leaderboard-btn,
  .header-right .status-pill { display: none; }

  /* Sync popup: sits above mobile nav bar */
  .sync-popup { bottom: 70px; right: 10px; left: 10px; width: auto; }

  .mobile-bottom-nav {
    display: flex;
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 500;
    background: rgba(10,10,15,0.96);
    border-top: 1px solid var(--border);
    backdrop-filter: blur(16px) saturate(160%);
    padding: 6px 0 max(6px, env(safe-area-inset-bottom));
  }
  .mobile-bottom-nav .mbn-item {
    flex: 1;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 3px; padding: 4px 2px;
    background: none; border: none; cursor: pointer;
    color: var(--text-3);
    font-family: 'Rajdhani', sans-serif; font-size: 9px; font-weight: 700;
    letter-spacing: 0.8px; text-transform: uppercase;
    transition: color 0.18s;
    -webkit-tap-highlight-color: transparent;
  }
  .mobile-bottom-nav .mbn-item.active { color: var(--red); }
  .mobile-bottom-nav .mbn-item svg { flex-shrink: 0; }

  /* Body padding so content isn't behind the bar */
  body { padding-bottom: 68px; }

  /* === HEADER STRIP === */
  .header-inner { padding: 0 14px; height: 50px; }
  .logo         { font-size: 17px; letter-spacing: 2px; }
  .logo-img     { width: 28px; height: 28px; }

  /* === HERO === */
  .hero-banner-wrap { padding: 0 12px; }
  .hero-banner-img  { margin-top: 0; margin-bottom: 0; border-radius: 10px; }
  .hero-banner-overlay { padding: 16px 16px 22px; }
  .eyebrow  { font-size: 11px; padding: 5px 14px; }
  .hero-sub { font-size: 13px; padding: 6px 14px; }

  /* === ROSTER === */
  .roster-section { padding: 0 12px; margin-bottom: 32px; }
  .roster-header  { margin-bottom: 14px; }
  .roster-title   { font-size: 12px; letter-spacing: 2px; }
  .roster-grid    { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .player-card    { padding: 16px 10px 14px; }
  .player-alias   { font-size: 16px; }
  .player-avatar-wrap { width: 56px; height: 56px; border-radius: 10px; margin-bottom: 10px; }
  .player-card:hover  { transform: none; }
  .player-card:active { transform: scale(0.97); }
  .player-gamertag    { font-size: 10px; }

  /* === PLAYER VIEW � stack sidebar above main === */
  .player-view {
    display: flex; flex-direction: column;
    padding: 0 0 80px;
    gap: 0; min-height: unset;
  }
  .player-sidebar {
    position: static;
    height: auto; min-height: unset;
    overflow-y: visible; overflow-x: auto;
    border-right: none; border-bottom: 1px solid var(--border);
    padding: 10px 12px;
    flex-direction: row; flex-wrap: nowrap; gap: 8px;
    scrollbar-width: none; align-items: center;
  }
  .player-sidebar::-webkit-scrollbar { display: none; }
  .sidebar-top     { display: none; }
  .sidebar-compare-wrap { display: none; }
  .sidebar-card    {
    flex-direction: column; align-items: center; justify-content: center;
    padding: 8px 6px; min-width: 52px; gap: 4px;
    border-radius: 10px; flex-shrink: 0;
  }
  .sidebar-avatar  { width: 36px; height: 36px; border-radius: 8px; }
  .sidebar-alias   { font-size: 10px; letter-spacing: 0; line-height: 1; }
  .sidebar-tag     { display: none; }
  .sidebar-player-list { flex-direction: row; gap: 6px; }

  .player-main {
    min-width: 0; padding: 14px 12px 0;
  }

  /* === PROFILE === */
  .profile-hero       { border-radius: 12px; min-height: auto; }
  .profile-hero-body  { padding: 18px 16px; gap: 14px; flex-wrap: nowrap; align-items: center; }
  .profile-avatar     { width: 64px; height: 64px; font-size: 22px; }
  .profile-level-badge { bottom: -8px; }
  .level-num          { font-size: 13px; }
  .profile-alias      { font-size: clamp(24px, 7vw, 36px); }
  .profile-name       { font-size: 13px; }
  .profile-rank-peek  { display: none; }

  /* === CHIPS === */
  .chips-row    { gap: 8px; flex-wrap: nowrap; overflow-x: auto; padding-bottom: 4px; scrollbar-width: none; }
  .chips-row::-webkit-scrollbar { display: none; }
  .chip         { min-width: 90px; flex-shrink: 0; padding: 10px 12px; }
  .chip-value   { font-size: 17px; }

  /* === GRID === */
  .grid-two { grid-template-columns: 1fr; gap: 10px; }
  .perf-grid { grid-template-columns: repeat(2, 1fr); }

  /* === MATCH ROWS === */
  .match-row {
    grid-template-columns: 3px 44px 1fr auto;
    gap: 10px; padding: 10px 12px 10px 10px;
  }
  .match-agent  { width: 44px; height: 44px; border-radius: 8px; }
  .match-badge  { display: none; }
  .match-map    { font-size: 14px; }
  .match-meta   { font-size: 11px; gap: 4px; }
  .kda-num      { font-size: 16px; }
  .match-row:hover { transform: none; }

  /* === LEADERBOARD === */
  .lb-view  { padding: 16px 12px 60px; }
  .lb-title { font-size: 15px; letter-spacing: 2px; }
  .lb-sub   { font-size: 11px; padding: 4px 8px; }
  .lb-header { flex-wrap: wrap; gap: 8px; }
  .lb-sort-bar { gap: 5px; margin-bottom: 10px; }
  .lb-sort-btn { font-size: 10px; padding: 3px 7px; }
  .lb-row {
    grid-template-columns: 28px 34px 1fr 28px auto;
    gap: 8px; padding: 10px 12px;
  }
  .lb-stat-col { display: none; }
  .lb-col-headers { display: none; }
  .lb-rank-icon { width: 28px; height: 28px; }
  .lb-tier-wrap { min-width: 80px; }
  .lb-tier      { font-size: 12px; }
  .lb-rr        { font-size: 9px; }
  .lb-alias     { font-size: 14px; }
  .lb-tag       { font-size: 9px; }
  .lb-pos       { font-size: 14px; }
  .lb-avatar    { width: 34px; height: 34px; border-radius: 6px; }
  .lb-row:hover { transform: none; }

  /* === PICKER VIEWS (all full-width pages) === */
  .picker-view,
  .fivevfive-view,
  .compare-page-wrap { padding: 16px 12px 48px; }

  .picker-title  { font-size: 20px; }
  .picker-sub    { font-size: 12px; padding: 4px 10px; }

  .picker-player-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .picker-p-card      { padding: 14px 8px 12px; }
  .picker-p-avatar    { width: 46px; height: 46px; }
  .picker-p-alias     { font-size: 13px; }

  .picker-comp-btns { grid-template-columns: 1fr; }
  .comp-label       { font-size: 16px; }
  .picker-assignments { grid-template-columns: 1fr; }

  /* === 5v5 === */
  .fivevfive-result { grid-template-columns: 1fr; gap: 10px; }
  .fivevfive-team-header { padding: 12px 16px; font-size: 14px; }
  .fivevfive-player-row  { padding: 10px 14px; gap: 10px; }

  /* === COMPARE === */
  .compare-pick-section {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto 1fr;
    min-height: unset;
  }
  .compare-pick-slot        { padding: 16px 16px; }
  .compare-pick-slot.slot-a { border-bottom: 1px solid var(--border); box-shadow: none; }
  .compare-pick-slot.slot-a.filled { box-shadow: inset 4px 0 0 #5b8bd8; }
  .compare-pick-slot.slot-b.filled { box-shadow: inset -4px 0 0 #f5a623; }
  .compare-vs-divider {
    width: 100%; height: 36px; flex-direction: row;
    border-left: none; border-right: none;
    border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
    padding: 0 16px;
  }
  .compare-vs-line { flex: 1; width: auto; height: 1px; }
  .compare-pick-portrait { width: 50px; height: 50px; border-radius: 10px; }
  .compare-pick-name     { font-size: 18px; }
  .compare-roster-grid   { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .compare-roster-avatar { width: 34px; height: 34px; }
  .compare-roster-name   { font-size: 13px; }
  .compare-stats-grid    { grid-template-columns: 1fr 80px 1fr; gap: 4px 4px; }
  .csr-a, .csr-b         { font-size: 20px; padding: 10px 6px; }
  .compare-winner-banner { font-size: 16px; padding: 14px 12px; letter-spacing: 1px; }
  .compare-result        { padding: 16px 14px; }

  /* === WHEEL === */
  .wheel-setup   { gap: 18px; }
  .wheel-spin-area { flex-direction: column; align-items: center; gap: 18px; }
  .wheel-spin-btn  { padding: 12px 32px; font-size: 18px; }

  /* === LINEUPS === */
  .lineups-cards      { gap: 8px; }
  .lineups-agent-card { min-width: 74px; padding: 12px 8px 10px; }
  .lineups-agent-card .la-icon img { width: 40px; height: 40px; }
  .lineups-agent-card .la-name { font-size: 11px; }

  /* === MODALS & TOAST === */
  .status-modal-box { padding: 20px 16px; margin: 12px; }
  .rate-toast {
    font-size: 12px; padding: 10px 16px;
    white-space: normal; text-align: center; max-width: 88vw;
    bottom: 80px;
  }

  /* === WHEEL RESULT === */
  .wheel-result-inner  { flex-direction: column; align-items: center; }
  .wheel-result-name   { text-align: center; font-size: 28px; }
  .wheel-result-role   { display: block; text-align: center; }
  .wheel-result-desc   { text-align: center; }
  .wheel-result-actions { justify-content: center; }
}
