@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@700;900&family=Rajdhani:wght@600;700&display=swap');

/* ============================================
   VERTEX 8 HYROX CHALLENGE — STYLE.CSS v4
   ============================================ */

/* ── FONTS ───────────────────────────────── */
@font-face {
  font-family: 'CustomFont';
  src: url('https://nlthfndovykcybtreozx.supabase.co/storage/v1/object/public/assets/Navigo-Bold.otf') format('opentype');
  font-weight: bold; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'FraktionMono';
  src: url('https://nlthfndovykcybtreozx.supabase.co/storage/v1/object/public/assets/PPFraktionMono-Regular-BF675904a6a1564.otf') format('opentype');
  font-weight: normal; font-style: normal; font-display: swap;
}

/* ── TAILWIND CUSTOM ─────────────────────── */
@tailwind base;
@tailwind components;
@tailwind utilities;

/* ── CSS VARIABLES ───────────────────────── */
:root {
  --gold: #D4AF37;
  --gold-light: #FCF6BA;
  --gold-dark: #B38728;
  --black: #050505;
  --card-bg: rgba(255,255,255,0.028);
  --card-border: rgba(255,255,255,0.06);
  --radius-xl: 20px;
}

/* ── BASE ────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'FraktionMono', monospace;
  background: #050505;
  color: white;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
[v-cloak] { display: none; }

/* ── TYPOGRAPHY ──────────────────────────── */
.font-display { font-family: 'CustomFont', sans-serif !important; }

/* ── COLORS (Tailwind extensions via arbitrary) ── */
.text-v8gold  { color: #D4AF37; }
.bg-v8black   { background-color: #050505; }
.bg-v8gold    { background-color: #D4AF37; }
.border-v8gold { border-color: #D4AF37; }

.gold-gradient-text {
  background: linear-gradient(135deg, #BF953F, #FCF6BA, #B38728, #FBF5B7, #D4AF37);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ── SCROLLBAR ───────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.14); }
.hide-scrollbar { scrollbar-width: none; -ms-overflow-style: none; }
.hide-scrollbar::-webkit-scrollbar { display: none; }

/* ── LOADER ──────────────────────────────── */
.loader-ring {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid rgba(212,175,55,0.1);
  border-top-color: #D4AF37;
  animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── TRANSITIONS ─────────────────────────── */
.fade-enter-active, .fade-leave-active { transition: opacity 0.22s ease; }
.fade-enter-from, .fade-leave-to { opacity: 0; }
.slide-up-enter-active, .slide-up-leave-active { transition: all 0.3s cubic-bezier(0.34,1.56,0.64,1); }
.slide-up-enter-from, .slide-up-leave-to { opacity: 0; transform: translateX(-50%) translateY(20px); }
.slide-down-enter-active, .slide-down-leave-active { transition: all 0.25s ease; }
.slide-down-enter-from, .slide-down-leave-to { opacity: 0; transform: translateY(-12px); }

/* ── NOISE OVERLAY ───────────────────────── */
.noise-overlay {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat: repeat; opacity: 0.035;
}

/* ── GLASS CARD ──────────────────────────── */
.glass-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  backdrop-filter: blur(10px);
  transition: border-color 0.2s;
}

/* ── BUTTONS ─────────────────────────────── */
.btn-gold {
  background: linear-gradient(135deg, #BF953F, #D4AF37, #B38728);
  color: #000;
  font-family: 'CustomFont', sans-serif;
  font-weight: 900;
  letter-spacing: 0.1em;
  border: none;
  cursor: pointer;
  transition: filter 0.2s, transform 0.15s;
}
.btn-gold:hover { filter: brightness(1.1); }
.btn-gold:active { transform: scale(0.97); }
.btn-gold:disabled { filter: grayscale(0.6); cursor: not-allowed; }

/* ── FORM ELEMENTS ───────────────────────── */
.field-label {
  display: block;
  font-family: 'FraktionMono', monospace;
  font-size: 9px;
  color: #555;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.input-field {
  width: 100%;
  padding: 10px 12px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  color: white;
  font-size: 13px;
  font-family: 'FraktionMono', monospace;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
  -webkit-appearance: none;
}
.input-field::placeholder { color: #333; }
.input-field:focus {
  border-color: rgba(212,175,55,0.4);
  box-shadow: 0 0 0 3px rgba(212,175,55,0.06);
}
select.input-field option { background: #111; color: white; }

/* ── STEP CARD (admin input) ─────────────── */
.step-card {
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 18px;
  padding: 16px;
}
.step-label {
  font-family: 'FraktionMono', monospace;
  font-size: 9px;
  color: #555;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

/* ── NAV ITEMS (admin sidebar) ───────────── */
.nav-item { font-family: 'FraktionMono', monospace; }
.nav-active {
  background: rgba(212,175,55,0.08) !important;
  color: #D4AF37 !important;
  border: 1px solid rgba(212,175,55,0.2);
}

/* ── DROPDOWN ────────────────────────────── */
.custom-dropdown::-webkit-scrollbar { width: 3px; }
.custom-dropdown::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }

/* ════════════════════════════════════════════
   PUBLIC LANDING — WIDE FULL-BLEED LAYOUT
   ════════════════════════════════════════════ */

/* ── HEADER BUTTONS ──────────────────────── */
.pub-login-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 100px;
  color: rgba(255,255,255,0.45);
  font-family: 'FraktionMono', monospace;
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.pub-login-btn:hover { background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.65); }

/* JOIN button — header prominent CTA */
.pub-join-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 18px;
  background: linear-gradient(135deg, #BF953F, #D4AF37, #B38728);
  border: none;
  border-radius: 100px;
  color: #000;
  font-family: 'FraktionMono', monospace;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: filter 0.2s, transform 0.15s;
  box-shadow: 0 0 20px rgba(212,175,55,0.25);
}
.pub-join-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
.pub-join-btn:active { transform: scale(0.96) translateY(0); }

/* Mobile icon-only join button */
.pub-join-btn-icon {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, #BF953F, #D4AF37);
  border: none; border-radius: 50%;
  color: #000; font-size: 11px;
  cursor: pointer; transition: filter 0.2s;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 16px rgba(212,175,55,0.3);
}

/* ── HERO CTA BUTTONS ────────────────────── */
.pub-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  background: linear-gradient(135deg, #BF953F, #D4AF37, #B38728);
  border: none;
  border-radius: 14px;
  color: #000;
  font-family: 'FraktionMono', monospace;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 4px 24px rgba(212,175,55,0.3), 0 1px 0 rgba(255,255,255,0.15) inset;
}
.pub-cta-primary:hover {
  filter: brightness(1.08);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(212,175,55,0.4);
}
.pub-cta-primary:active { transform: scale(0.97) translateY(0); }

.pub-cta-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 22px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  color: rgba(255,255,255,0.45);
  font-family: 'FraktionMono', monospace;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.pub-cta-secondary:hover { background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.65); }

/* ── STAT CARDS (hero desktop) ───────────── */
.pub-stat-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  padding: 18px 22px;
  backdrop-filter: blur(12px);
  min-width: 110px;
}

/* ── EVENT SELECTOR ──────────────────────── */
.pub-ev-btn {
  flex-shrink: 0;
  padding: 8px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 100px;
  color: rgba(255,255,255,0.4);
  font-family: 'FraktionMono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.pub-ev-btn:hover { background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.6); }
.pub-ev-active {
  background: rgba(212,175,55,0.1) !important;
  border-color: rgba(212,175,55,0.35) !important;
  color: #D4AF37 !important;
}

/* ── EVENT HERO CARD ─────────────────────── */
.pub-event-card {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}
.pub-event-cover {
  position: relative;
  width: 100%;
  min-height: 200px;
  overflow: hidden;
}
@media (min-width: 1024px) {
  .pub-event-cover { min-height: 260px; }
}

/* ── FOCUS BUTTON ────────────────────────── */
.pub-focus-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: rgba(0,0,0,0.6);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 100px;
  color: rgba(255,255,255,0.55);
  font-family: 'FraktionMono', monospace;
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  backdrop-filter: blur(12px);
}
.pub-focus-btn:hover { background: rgba(0,0,0,0.8); color: white; }

/* ── SECTION DIVIDER ─────────────────────── */
.pub-section-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}
.pub-section-divider-line { flex: 1; height: 1px; }
.pub-section-divider-label {
  font-family: 'FraktionMono', monospace;
  font-size: 8px;
  color: rgba(212,175,55,0.5);
  letter-spacing: 0.35em;
  text-transform: uppercase;
  white-space: nowrap;
}

/* ════════════════════════════════════════════
   LEADERBOARD — CINEMATIC TOP 3 + ROWS
   ════════════════════════════════════════════ */

/* Grid: left = #1 hero, right = #2+#3 stacked */
.lb-top3-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 20px;
}
@media (min-width: 768px) {
  .lb-top3-grid {
    grid-template-columns: 1fr 1fr;
    align-items: start;
    gap: 16px;
  }
}

/* Right col: #2 + #3 stacked */
.lb-rank23-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Full-width rank card (used for #2 and #3 in right col) */
.lb-rank-card-full {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 18px;
  padding: 18px 20px;
  transition: transform 0.2s, border-color 0.2s;
}
.lb-rank-card-full:hover {
  transform: translateX(4px);
  border-color: rgba(255,255,255,0.1);
}

/* Rank number badges */
.lb-rank-num {
  font-family: 'CustomFont', sans-serif;
  font-weight: 900;
  font-size: 1.6rem;
  line-height: 1;
  width: 40px;
  text-align: center;
  flex-shrink: 0;
}
.lb-rank2-num { color: rgba(156,163,175,0.8); text-shadow: 0 0 20px rgba(156,163,175,0.2); }
.lb-rank3-num { color: rgba(146,64,14,0.9); text-shadow: 0 0 20px rgba(146,64,14,0.3); }

/* #1 HERO CARD — left big column */
.pub-rank1-hero {
  position: relative;
  background: linear-gradient(135deg, rgba(212,175,55,0.07) 0%, rgba(0,0,0,0) 60%), rgba(255,255,255,0.025);
  border: 1px solid rgba(212,175,55,0.2);
  border-radius: 24px;
  padding: 28px 24px;
  overflow: hidden;
  box-shadow: 0 0 60px rgba(212,175,55,0.06), 0 20px 60px rgba(0,0,0,0.5);
  transition: box-shadow 0.3s;
}
.pub-rank1-hero:hover { box-shadow: 0 0 80px rgba(212,175,55,0.1), 0 20px 60px rgba(0,0,0,0.6); }

/* Giant watermark number */
.lb-rank1-watermark {
  position: absolute;
  right: -10px; bottom: -20px;
  font-family: 'CustomFont', sans-serif;
  font-weight: 900;
  font-size: 180px;
  line-height: 1;
  color: rgba(212,175,55,0.04);
  pointer-events: none;
  user-select: none;
  letter-spacing: -0.05em;
}

/* #1 avatar — large */
.lb-rank1-avatar {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  border: 2px solid rgba(212,175,55,0.5);
  background: rgba(212,175,55,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-shadow: 0 0 30px rgba(212,175,55,0.2), 0 0 0 6px rgba(212,175,55,0.05);
}

/* #1 score animation */
@keyframes goldGlow {
  0%, 100% { text-shadow: 0 0 20px rgba(212,175,55,0.3); }
  50%       { text-shadow: 0 0 40px rgba(212,175,55,0.6), 0 0 80px rgba(212,175,55,0.2); }
}
.pub-rank1-score { animation: goldGlow 3s ease-in-out infinite; }

/* #2 silver avatar */
.pub-avatar-silver {
  border-radius: 50%;
  border: 2px solid rgba(156,163,175,0.4);
  background: rgba(156,163,175,0.06);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

/* #3 bronze avatar */
.pub-avatar-bronze {
  border-radius: 50%;
  border: 2px solid rgba(146,64,14,0.5);
  background: rgba(146,64,14,0.08);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

/* #2 card accent */
.pub-rank2 {
  background: linear-gradient(135deg, rgba(156,163,175,0.05) 0%, rgba(0,0,0,0) 60%), rgba(255,255,255,0.025) !important;
  border-color: rgba(156,163,175,0.15) !important;
}

/* #3 card accent */
.pub-rank3 {
  background: linear-gradient(135deg, rgba(146,64,14,0.06) 0%, rgba(0,0,0,0) 60%), rgba(255,255,255,0.025) !important;
  border-color: rgba(146,64,14,0.2) !important;
}

/* Join CTA card in right col */
.lb-join-cta-card {
  background: rgba(212,175,55,0.02);
  border: 1px dashed rgba(212,175,55,0.1);
  border-radius: 18px;
  padding: 28px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}

/* Rank 4-10 rows: 2-col grid on desktop */
.lb-rows-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
@media (min-width: 768px) {
  .lb-rows-grid { grid-template-columns: 1fr 1fr; }
}

/* Individual rank row */
.pub-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px;
  transition: transform 0.2s, border-color 0.2s, background 0.2s;
  cursor: default;
}
.pub-row:hover {
  transform: translateX(5px);
  background: rgba(255,255,255,0.035);
  border-color: rgba(255,255,255,0.08);
}

/* Row rank number */
.lb-row-rank {
  font-family: 'CustomFont', sans-serif;
  font-weight: 900;
  font-size: 1rem;
  color: rgba(255,255,255,0.15);
  width: 24px;
  text-align: center;
  flex-shrink: 0;
}

/* Bottom JOIN banner */
.pub-join-banner {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  background: linear-gradient(135deg, rgba(212,175,55,0.06), rgba(212,175,55,0.02));
  border: 1px solid rgba(212,175,55,0.12);
  border-radius: 20px;
  flex-wrap: wrap;
}

/* ── FOOTER ──────────────────────────────── */
.pub-footer {
  padding: 20px;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.03);
}
.pub-footer-text {
  font-family: 'FraktionMono', monospace;
  font-size: 9px;
  color: #2a2a2a;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

/* ════════════════════════════════════════════
   JOIN / GUEST REGISTRATION MODAL
   ════════════════════════════════════════════ */
.join-modal-box {
  background: #0e0e0e;
  border: 1px solid rgba(212,175,55,0.12);
  width: 100%;
  max-width: 440px;
  border-radius: 24px 24px 0 0;
  box-shadow: 0 -30px 100px rgba(0,0,0,0.9), 0 0 60px rgba(212,175,55,0.06);
  overflow: hidden;
  max-height: 92vh;
  overflow-y: auto;
}
@media (min-width: 640px) {
  .join-modal-box {
    border-radius: 24px;
    max-height: 88vh;
  }
}

/* Success icon inside join modal */
.join-success-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(212,175,55,0.08);
  border: 2px solid rgba(212,175,55,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  box-shadow: 0 0 40px rgba(212,175,55,0.15);
  animation: successPop 0.5s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes successPop {
  from { transform: scale(0.5); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}

/* ════════════════════════════════════════════
   ANIMATIONS
   ════════════════════════════════════════════ */
@keyframes pubHeroIn {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes pubFadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes pubPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.6; transform: scale(1.3); }
}

/* ── MOBILE TWEAKS ───────────────────────── */
@media (max-width: 640px) {
  .pub-rank1-hero { padding: 20px 18px; }
  .lb-rank1-watermark { font-size: 130px; }
  .lb-rank1-avatar { width: 72px; height: 72px; }
  .pub-rank1-score { font-size: 2.2rem !important; }
  .pub-cta-primary { padding: 12px 20px; font-size: 10px; }
  .pub-cta-secondary { padding: 11px 18px; font-size: 10px; }
}
/* ════════════════════════════════════════════
   TV PRELOAD SCREEN
   ════════════════════════════════════════════ */
.tv-preload-box { display:flex;flex-direction:column;align-items:center; }
.tv-preload-logo { margin-bottom:20px;animation:pubPulse 2s ease-in-out infinite; }
.tv-preload-bar { width:260px;height:3px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden; }
.tv-preload-fill { height:100%;background:linear-gradient(90deg,#BF953F,#D4AF37,#FCF6BA);border-radius:3px;transition:width 0.2s ease;box-shadow:0 0 10px rgba(212,175,55,0.5); }

/* ════════════════════════════════════════════
   EVENT BG UPLOAD
   ════════════════════════════════════════════ */
.ev-bg-upload-area { display:block;width:100%;border:1.5px dashed rgba(212,175,55,0.2);border-radius:16px;background:rgba(212,175,55,0.02);cursor:pointer;position:relative;overflow:hidden;transition:border-color 0.2s,background 0.2s;min-height:120px; }
.ev-bg-upload-area:hover { border-color:rgba(212,175,55,0.4);background:rgba(212,175,55,0.04); }
.ev-bg-has-img { border-color:rgba(212,175,55,0.3);min-height:160px; }
.ev-bg-placeholder { display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;min-height:120px; }
.ev-bg-preview-img { width:100%;height:160px;object-fit:cover;display:block;filter:brightness(0.85); }
.ev-bg-change-label { position:absolute;bottom:0;left:0;right:0;background:rgba(5,5,5,0.7);font-family:'FraktionMono',monospace;font-size:9px;color:#D4AF37;letter-spacing:0.2em;text-transform:uppercase;padding:8px;text-align:center;backdrop-filter:blur(4px); }

/* ════════════════════════════════════════════
   TV FOCUS MODE — FULLSCREEN LANDSCAPE
   ════════════════════════════════════════════ */

/* ── TV FONT SYSTEM ── */
/* Bebas Neue  → huge display numbers/names */
/* Barlow Condensed 900 → section labels, badges */
/* Rajdhani 700 → supporting text, scores */
/* FraktionMono → tiny labels/mono */

.tv-f-display  { font-family:'Bebas Neue','CustomFont',sans-serif !important; letter-spacing:0.04em; }
.tv-f-score    { font-family:'Barlow Condensed','CustomFont',sans-serif !important; font-weight:900; }
.tv-f-label    { font-family:'Rajdhani',sans-serif !important; font-weight:700; letter-spacing:0.12em; }
.tv-f-mono     { font-family:'FraktionMono',monospace !important; }

.tv-root {
  position:fixed;inset:0;z-index:9990;
  background:#030303;
  display:flex;flex-direction:column;
  overflow:hidden;width:100vw;height:100vh;
}

/* Overlay — heavier gradient for better legibility */
.tv-bg-overlay {
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg, rgba(3,3,3,0.82) 0%, rgba(3,3,3,0.55) 50%, rgba(3,3,3,0.72) 100%),
    linear-gradient(180deg, rgba(3,3,3,0.6) 0%, rgba(3,3,3,0.3) 50%, rgba(3,3,3,0.75) 100%);
}

.tv-particles { position:absolute;inset:0;pointer-events:none;z-index:2; }

/* ── TOP BAR ── */
.tv-topbar {
  position:relative;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2.5vw;height:54px;flex-shrink:0;
  border-bottom:1px solid rgba(212,175,55,0.15);
  background:rgba(3,3,3,0.88);
  backdrop-filter:blur(24px);
}
.tv-topbar-left  { display:flex;align-items:center;gap:12px; }
.tv-topbar-center { position:absolute;left:50%;transform:translateX(-50%); }
.tv-topbar-right { display:flex;align-items:center;gap:14px; }
.tv-logo { height:28px;width:auto;object-fit:contain; }
.tv-logo-box { width:30px;height:30px;border:1px solid rgba(212,175,55,0.4);border-radius:8px;background:rgba(212,175,55,0.06);display:flex;align-items:center;justify-content:center; }
.tv-topbar-divider { width:1px;height:18px;background:rgba(255,255,255,0.1); }
.tv-app-name { font-family:'Barlow Condensed','CustomFont',sans-serif;font-size:13px;font-weight:900;color:white;letter-spacing:0.22em;line-height:1;text-transform:uppercase; }
.tv-app-sub { font-family:'FraktionMono',monospace;font-size:7px;color:#555;letter-spacing:0.3em;text-transform:uppercase;margin-top:3px; }
.tv-event-badge { display:flex;align-items:center;gap:8px;padding:5px 16px;border:1px solid rgba(34,197,94,0.3);border-radius:100px;background:rgba(34,197,94,0.07);backdrop-filter:blur(8px); }
.tv-live-dot { width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e;animation:pubPulse 2s infinite;flex-shrink:0; }
.tv-event-name-top { font-family:'Rajdhani',sans-serif;font-weight:700;font-size:11px;color:#22c55e;letter-spacing:0.2em;text-transform:uppercase;white-space:nowrap;max-width:32vw;overflow:hidden;text-overflow:ellipsis; }
.tv-dots { display:flex;gap:6px;align-items:center; }
.tv-dot { width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.2);border:none;cursor:pointer;transition:all 0.3s;padding:0; }
.tv-dot-active { width:26px;border-radius:4px;background:#D4AF37;box-shadow:0 0 12px rgba(212,175,55,0.7); }
.tv-exit-btn { display:flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:100px;color:rgba(255,255,255,0.45);font-family:'Rajdhani',sans-serif;font-weight:700;font-size:11px;letter-spacing:0.18em;cursor:pointer;transition:all 0.2s; }
.tv-exit-btn:hover { background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.7); }

/* ── STAGE ── */
.tv-stage { position:relative;z-index:5;flex:1;overflow:hidden;display:flex; }
@keyframes tvFadeIn  { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
@keyframes tvFadeOut { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(-40px)} }
.tv-fade-in  { animation:tvFadeIn  0.45s cubic-bezier(0.22,1,0.36,1) forwards; }
.tv-fade-out { animation:tvFadeOut 0.35s ease forwards; }
.tv-slide { position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:2vh 4vw; }
.tv-empty { text-align:center;padding:60px 0; }

.tv-section-label {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:clamp(10px,1.2vw,14px);
  color:#D4AF37;letter-spacing:0.5em;text-transform:uppercase;
  margin-bottom:4px;
  text-shadow:0 0 20px rgba(212,175,55,0.5);
}

/* ══════════════════════════════════════════════
   SLIDE 0 — CHAMPION
   ══════════════════════════════════════════════ */
.tv-slide-champion { background:transparent; }

@keyframes rayPulse { 0%,100%{opacity:0.035} 50%{opacity:0.11} }
.tv-champ-rays { position:absolute;inset:-50%;pointer-events:none;z-index:0; }
.tv-champ-ray {
  position:absolute;top:50%;left:50%;
  width:2px;height:55%;
  transform-origin:top center;
  background:linear-gradient(180deg,rgba(212,175,55,0.6),transparent);
  animation:rayPulse 3s ease-in-out infinite;
}

.tv-champ-layout { display:flex;align-items:center;gap:5vw;width:100%;max-width:1350px; }

/* LEFT */
.tv-champ-left { position:relative;display:flex;flex-direction:column;align-items:center;flex-shrink:0; }
.tv-champ-watermark {
  position:absolute;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(9rem,24vw,20rem);line-height:1;
  color:rgba(212,175,55,0.06);
  top:50%;left:50%;transform:translate(-50%,-50%);
  pointer-events:none;user-select:none;z-index:0;
}
.tv-champ-avatar-wrap {
  position:relative;z-index:2;
  width:clamp(160px,22vw,250px);height:clamp(160px,22vw,250px);
}
.tv-champ-avatar-ring {
  position:absolute;inset:-5px;border-radius:50%;
  background:conic-gradient(from 0deg,#BF953F 0%,#FCF6BA 25%,#B38728 50%,#FCF6BA 75%,#BF953F 100%);
  box-shadow:0 0 50px rgba(212,175,55,0.5),0 0 100px rgba(212,175,55,0.2);
}
.tv-champ-avatar-ring::after {
  content:'';position:absolute;inset:4px;border-radius:50%;background:#030303;
}
.tv-champ-avatar {
  position:absolute;inset:0;border-radius:50%;
  overflow:hidden;background:rgba(212,175,55,0.08);
  display:flex;align-items:center;justify-content:center;z-index:1;
}
.tv-champ-initial { font-family:'Bebas Neue',sans-serif;font-size:clamp(3rem,7vw,5.5rem);color:#D4AF37; }

.tv-crown-badge {
  position:relative;z-index:3;margin-top:12px;
  display:flex;align-items:center;gap:6px;
  padding:6px 20px;
  background:linear-gradient(135deg,#BF953F,#D4AF37,#B38728);
  border-radius:100px;
  box-shadow:0 4px 24px rgba(212,175,55,0.5),0 0 40px rgba(212,175,55,0.15);
}

/* DIVIDER */
.tv-champ-divider { width:1px;height:clamp(120px,20vh,220px);background:linear-gradient(180deg,transparent,rgba(212,175,55,0.5),transparent);flex-shrink:0; }

/* RIGHT */
.tv-champ-right { flex:1;min-width:0; }
.tv-champ-top-row { display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px; }
.tv-champ-crown-row { display:flex;align-items:center;gap:10px; }

.tv-crown-icon { color:#D4AF37;font-size:clamp(14px,2vw,22px);animation:goldGlow 3s ease-in-out infinite; }
.tv-crown-label {
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(12px,1.5vw,16px);
  color:#D4AF37;letter-spacing:0.4em;text-transform:uppercase;
  text-shadow:0 0 20px rgba(212,175,55,0.6);
}
.tv-gender-icon { font-size:clamp(14px,2vw,22px); }
.tv-champ-event-pill {
  font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(9px,1vw,12px);
  color:rgba(255,255,255,0.5);letter-spacing:0.2em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);backdrop-filter:blur(8px);
  padding:5px 16px;border-radius:100px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:28vw;flex-shrink:0;
}

.tv-champ-name {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(3rem,7vw,6.5rem);
  color:white;line-height:0.95;letter-spacing:0.04em;
  margin-bottom:14px;overflow-wrap:anywhere;
  text-shadow:0 2px 30px rgba(0,0,0,0.9),0 0 60px rgba(0,0,0,0.7);
}
.tv-champ-category {
  font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(11px,1.4vw,16px);
  color:rgba(255,255,255,0.65);letter-spacing:0.2em;text-transform:uppercase;
  margin-bottom:clamp(14px,2.5vh,32px);display:flex;align-items:center;
  text-shadow:0 1px 10px rgba(0,0,0,0.8);
}
.tv-champ-score-section { display:inline-flex;flex-direction:column; }
.tv-champ-score-label {
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(10px,1.2vw,14px);
  color:#D4AF37;opacity:0.6;letter-spacing:0.4em;text-transform:uppercase;margin-bottom:4px;
}
.tv-champ-score {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(5rem,11vw,10rem);
  background:linear-gradient(135deg,#BF953F,#FCF6BA,#B38728,#FBF5B7,#D4AF37);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;
  animation:goldGlow 3s ease-in-out infinite;
  filter:drop-shadow(0 0 30px rgba(212,175,55,0.4));
}
.tv-champ-score-unit {
  font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(9px,1vw,12px);
  color:rgba(212,175,55,0.4);letter-spacing:0.3em;text-transform:uppercase;margin-top:4px;
}
.tv-champ-deco { display:flex;align-items:center;gap:10px;margin-top:clamp(14px,2vh,24px); }
.tv-deco-line { flex:1;height:1px;background:linear-gradient(90deg,rgba(212,175,55,0.5),transparent); }
.tv-deco-dot { width:5px;height:5px;border-radius:50%;background:#D4AF37;box-shadow:0 0 10px rgba(212,175,55,0.8); }

/* ══════════════════════════════════════════════
   SLIDE 1 — PODIUM WOW (#2 & #3)
   ══════════════════════════════════════════════ */
.tv-slide-podium { flex-direction:column;background:transparent; }
.tv-podium-wrap { width:100%;max-width:1280px; }
.tv-podium-header { text-align:center;margin-bottom:3vh;flex-shrink:0; }
.tv-podium-event {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.6rem,3.5vw,3rem);
  color:white;letter-spacing:0.06em;margin-top:4px;
  text-shadow:0 2px 20px rgba(0,0,0,0.8);
}
.tv-podium-cards { display:flex;gap:2vw;width:100%; }

.tv-pod-card {
  flex:1;position:relative;overflow:hidden;border-radius:24px;
  padding:clamp(22px,3vh,44px) clamp(22px,2.5vw,40px);
  display:flex;flex-direction:column;gap:18px;
  /* SOLID — not transparent */
}
.tv-pod-silver {
  background:linear-gradient(145deg,rgba(192,192,192,0.18) 0%,rgba(20,20,20,0.92) 100%);
  border:1.5px solid rgba(192,192,192,0.35);
  box-shadow:0 0 60px rgba(192,192,192,0.08),0 20px 60px rgba(0,0,0,0.7),inset 0 1px 0 rgba(255,255,255,0.1);
  backdrop-filter:blur(20px);
}
.tv-pod-bronze {
  background:linear-gradient(145deg,rgba(205,127,50,0.2) 0%,rgba(20,20,20,0.92) 100%);
  border:1.5px solid rgba(205,127,50,0.4);
  box-shadow:0 0 60px rgba(205,127,50,0.1),0 20px 60px rgba(0,0,0,0.7),inset 0 1px 0 rgba(255,255,255,0.05);
  backdrop-filter:blur(20px);
}

.tv-pod-top { display:flex;align-items:center;gap:clamp(14px,2vw,28px); }
.tv-pod-rank-badge {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(4.5rem,10vw,9rem);
  font-weight:900;line-height:1;flex-shrink:0;
}
.tv-pod-rank-silver {
  background:linear-gradient(135deg,#a0a0a0,#ffffff,#a0a0a0);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 20px rgba(192,192,192,0.4));
}
.tv-pod-rank-bronze {
  background:linear-gradient(135deg,#8B4513,#cd7f32,#f0a040,#cd7f32);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 20px rgba(205,127,50,0.5));
}

.tv-pod-avatar-wrap { position:relative;flex-shrink:0; }
.tv-pod-avatar {
  width:clamp(80px,10vw,130px);height:clamp(80px,10vw,130px);
  border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.tv-pod-avatar-silver {
  border:3px solid rgba(192,192,192,0.5);background:rgba(156,163,175,0.1);
  box-shadow:0 0 30px rgba(192,192,192,0.25),0 0 0 6px rgba(192,192,192,0.05);
}
.tv-pod-avatar-bronze {
  border:3px solid rgba(205,127,50,0.5);background:rgba(146,64,14,0.1);
  box-shadow:0 0 30px rgba(205,127,50,0.25),0 0 0 6px rgba(205,127,50,0.05);
}
.tv-pod-initial { font-family:'Bebas Neue',sans-serif;font-size:clamp(1.5rem,3.5vw,3rem); }
.tv-pod-medal { position:absolute;bottom:-3px;right:-3px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;border:2px solid rgba(5,5,5,0.9); }
.tv-pod-medal-silver { background:linear-gradient(135deg,#aaa,#e8e8e8);color:#555; }
.tv-pod-medal-bronze { background:linear-gradient(135deg,#8B4513,#cd7f32);color:#fff; }

.tv-pod-info { flex:1;min-width:0;overflow:hidden; }
.tv-pod-name {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.6rem,3.2vw,2.8rem);
  color:white;line-height:1.05;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:0.04em;
  text-shadow:0 2px 12px rgba(0,0,0,0.8);
}
.tv-pod-group {
  font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(9px,1.1vw,13px);
  color:rgba(255,255,255,0.4);letter-spacing:0.2em;text-transform:uppercase;margin-top:6px;
}
.tv-pod-score-block {
  border-top:1px solid rgba(255,255,255,0.08);
  padding-top:14px;display:flex;align-items:baseline;gap:12px;
}
.tv-pod-score-label {
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(9px,1vw,12px);
  color:rgba(255,255,255,0.3);letter-spacing:0.3em;text-transform:uppercase;
}
.tv-pod-score {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.5rem,6vw,5.5rem);
  line-height:1;letter-spacing:0.05em;
}

/* ══════════════════════════════════════════════
   SLIDE 2 — RANK 4-10 PREMIUM
   ══════════════════════════════════════════════ */
.tv-slide-ranks { flex-direction:column;align-items:stretch;background:transparent; }
.tv-ranks-wrap { width:100%;max-width:1380px;margin:0 auto;display:flex;flex-direction:column;height:100%; }
.tv-ranks-header { text-align:center;margin-bottom:2vh;flex-shrink:0; }
.tv-ranks-grid { display:grid;grid-template-columns:1fr;gap:clamp(6px,0.8vw,12px);flex:1;align-content:start; }

@keyframes tvRowIn { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }
.tv-rank-row {
  display:flex;align-items:center;gap:clamp(10px,1.5vw,20px);
  padding:clamp(12px,1.8vh,22px) clamp(16px,2vw,28px);
  /* SOLID dark container */
  background:rgba(12,12,12,0.82);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:18px;
  animation:tvRowIn 0.4s ease forwards;opacity:0;
  transition:border-color 0.2s,background 0.2s;
  backdrop-filter:blur(16px);
  box-shadow:0 4px 20px rgba(0,0,0,0.5);
}
.tv-rank-row:nth-child(1) { border-color:rgba(212,175,55,0.3);background:rgba(212,175,55,0.08);box-shadow:0 4px 24px rgba(212,175,55,0.1); }
.tv-rank-row:nth-child(2) { border-color:rgba(212,175,55,0.18);background:rgba(12,12,12,0.85); }
.tv-rank-row:nth-child(3) { border-color:rgba(212,175,55,0.1); }

.tv-rank-pos {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,4vw,3.5rem);
  color:rgba(255,255,255,0.12);
  width:clamp(36px,4.5vw,60px);text-align:center;flex-shrink:0;
}
.tv-rank-avatar {
  width:clamp(46px,5.5vw,70px);height:clamp(46px,5.5vw,70px);
  border-radius:50%;border:2px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.05);
  display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;
  box-shadow:0 0 16px rgba(0,0,0,0.6);
}
.tv-rank-info { flex:1;min-width:0; }
.tv-rank-name {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.1rem,2.2vw,2rem);
  color:rgba(255,255,255,0.9);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:0.04em;
}
.tv-rank-group {
  font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(8px,0.9vw,11px);
  color:rgba(255,255,255,0.25);letter-spacing:0.15em;text-transform:uppercase;margin-top:2px;
}
.tv-rank-score-block { flex-shrink:0;text-align:right; }
.tv-rank-score {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.3rem,2.8vw,2.5rem);
  color:rgba(255,255,255,0.7);line-height:1;letter-spacing:0.05em;
}
.tv-rank-unit {
  font-family:'FraktionMono',monospace;
  font-size:clamp(6px,0.75vw,8px);color:rgba(255,255,255,0.2);
  letter-spacing:0.2em;text-transform:uppercase;margin-top:2px;
}

/* ── PROGRESS BAR ── */
.tv-progress-bar { position:relative;z-index:10;height:3px;background:rgba(255,255,255,0.04);flex-shrink:0; }
@keyframes tvProgress { from{width:0%} to{width:100%} }
.tv-progress-fill { height:100%;background:linear-gradient(90deg,#BF953F,#D4AF37,#FCF6BA);animation:tvProgress 6s linear forwards;box-shadow:0 0 12px rgba(212,175,55,0.7); }
/* ════════════════════════════════════════════════════════
   TV — PORTRAIT + LANDSCAPE + ROTATE + BADGES + TIMESTAMP
   ════════════════════════════════════════════════════════ */
.tv-mode-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.3);border-radius:100px;color:#D4AF37;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;cursor:pointer;transition:all .2s;}
.tv-mode-btn:hover{background:rgba(212,175,55,.18);border-color:rgba(212,175,55,.55);}
.tv-mode-btn i{font-size:13px;}
.tv-rotate-fab{position:fixed;bottom:24px;right:24px;z-index:99999;width:52px;height:52px;border-radius:50%;border:1.5px solid rgba(255,255,255,.12);background:rgba(10,10,10,.82);color:rgba(255,255,255,.5);font-size:17px;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(16px);box-shadow:0 4px 24px rgba(0,0,0,.5);transition:all .25s;}
.tv-rotate-fab:hover{background:rgba(212,175,55,.15);border-color:rgba(212,175,55,.6);color:#D4AF37;}
.tv-rotate-fab-on{border-color:rgba(212,175,55,.7);background:rgba(212,175,55,.12);color:#D4AF37;box-shadow:0 4px 28px rgba(212,175,55,.3);}
.tv-rotate-fab i{transition:transform .45s cubic-bezier(.4,0,.2,1);display:block;}
.tv-rotate-fab-on i{transform:rotate(90deg);}
.tv-rotated{transform-origin:center center;transform:rotate(90deg);width:100vh!important;height:100vw!important;position:fixed;top:calc((100vh - 100vw)/2);left:calc((100vw - 100vh)/2);transition:transform .45s cubic-bezier(.4,0,.2,1);}
.tvp-slide{position:absolute;inset:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;padding:10px 12px 16px;scrollbar-width:none;-ms-overflow-style:none;}
.tvp-slide::-webkit-scrollbar{display:none;}
.tvp-event-header{text-align:center;padding:6px 0 8px;flex-shrink:0;}
.tvp-event-label{display:inline-flex;align-items:center;gap:7px;font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:clamp(8px,2.2vw,10px);color:rgba(34,197,94,.85);letter-spacing:.42em;text-transform:uppercase;margin-bottom:3px;}
.tvp-live-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e;animation:pubPulse 2s infinite;flex-shrink:0;}
.tvp-event-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.8rem,8vw,3.2rem);line-height:1;letter-spacing:.06em;background:linear-gradient(135deg,#fff 0%,#D4AF37 50%,#FCF6BA 75%,#D4AF37 100%);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 24px rgba(212,175,55,.35));}
.tvp-event-sub{font-family:'FraktionMono',monospace;font-size:clamp(7px,2vw,9px);color:rgba(255,255,255,.25);letter-spacing:.3em;text-transform:uppercase;margin-top:3px;}
.tvp-champ-zone{position:relative;flex-shrink:0;overflow:hidden;border-radius:20px;background:linear-gradient(160deg,rgba(212,175,55,.14) 0%,rgba(8,8,8,.97) 100%);border:1.5px solid rgba(212,175,55,.4);box-shadow:0 0 80px rgba(212,175,55,.15);padding:16px 16px 14px;margin-bottom:7px;}
.tvp-champ-inner{position:relative;z-index:2;}
.tvp-champ-wm{position:absolute;font-family:'Bebas Neue',sans-serif;font-size:clamp(8rem,35vw,14rem);line-height:1;color:rgba(212,175,55,.04);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;user-select:none;z-index:0;}
.tvp-spotlight-wrap{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
@keyframes spotL{0%,100%{opacity:.10}50%{opacity:.22}}
@keyframes spotR{0%,100%{opacity:.08}50%{opacity:.18}}
.tvp-spot{position:absolute;bottom:0;width:55%;height:200%;transform-origin:bottom center;}
.tvp-spot-l{left:-10%;background:linear-gradient(180deg,rgba(212,175,55,0) 0%,rgba(212,175,55,.18) 100%);transform:rotate(-25deg);animation:spotL 4s ease-in-out infinite;}
.tvp-spot-r{right:-10%;background:linear-gradient(180deg,rgba(212,175,55,0) 0%,rgba(212,175,55,.12) 100%);transform:rotate(25deg);animation:spotR 4s ease-in-out infinite .8s;}
.tvp-rays{position:absolute;inset:-80%;pointer-events:none;z-index:0;}
@keyframes tvpRay{0%,100%{opacity:.015}50%{opacity:.07}}
.tvp-ray{position:absolute;top:50%;left:50%;width:1px;height:55%;transform-origin:top center;background:linear-gradient(180deg,rgba(212,175,55,.9),transparent);animation:tvpRay 3.5s ease-in-out infinite;}
.tvp-champ-body{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;}
.tvp-champ-ring{width:clamp(78px,22vw,118px);height:clamp(78px,22vw,118px);border-radius:50%;padding:3px;background:conic-gradient(from 0deg,#BF953F 0%,#FCF6BA 25%,#B38728 50%,#FCF6BA 75%,#BF953F 100%);box-shadow:0 0 40px rgba(212,175,55,.55),0 0 90px rgba(212,175,55,.18);flex-shrink:0;}
.tvp-champ-avatar{width:100%;height:100%;border-radius:50%;background:#050505;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.tvp-initial{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.2rem,8vw,4rem);color:#D4AF37;}
.tvp-crown-pill{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,#BF953F,#D4AF37,#B38728);border-radius:100px;padding:5px 16px;box-shadow:0 3px 18px rgba(212,175,55,.5);margin-top:2px;}
.tvp-crown-pill span{font-size:10px;font-weight:900;color:#050505;letter-spacing:.2em;}
.tvp-champ-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.9rem,9vw,3.5rem);color:white;line-height:1;letter-spacing:.04em;text-shadow:0 2px 24px rgba(0,0,0,.95);}
.tvp-champ-meta{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:clamp(9px,2.5vw,12px);color:rgba(255,255,255,.42);letter-spacing:.18em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;}
.tvp-champ-score{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.4rem,12vw,5rem);background:linear-gradient(135deg,#BF953F,#FCF6BA,#B38728,#FBF5B7,#D4AF37);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;filter:drop-shadow(0 0 20px rgba(212,175,55,.5));animation:goldGlow 3s ease-in-out infinite;}
.tvp-champ-unit{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:clamp(8px,2vw,10px);color:rgba(212,175,55,.45);letter-spacing:.3em;text-transform:uppercase;}
.tvp-sep{display:flex;align-items:center;gap:10px;margin:5px 0 6px;flex-shrink:0;}
.tvp-sep-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(212,175,55,.28),transparent);}
.tvp-sep-label{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:clamp(8px,2.2vw,10px);color:rgba(212,175,55,.55);letter-spacing:.45em;text-transform:uppercase;white-space:nowrap;}
.tvp-duo{display:flex;gap:8px;flex-shrink:0;margin-bottom:7px;}
.tvp-duo-card{flex:1;border-radius:16px;padding:12px 12px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;overflow:hidden;}
.tvp-silver{background:linear-gradient(145deg,rgba(192,192,192,.13) 0%,rgba(14,14,14,.94) 100%);border:1.5px solid rgba(192,192,192,.28);}
.tvp-bronze{background:linear-gradient(145deg,rgba(205,127,50,.15) 0%,rgba(14,14,14,.94) 100%);border:1.5px solid rgba(205,127,50,.33);}
.tvp-duo-rank{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.2rem,11vw,4rem);line-height:1;-webkit-background-clip:text;background-clip:text;}
.tvp-duo-av{width:clamp(44px,13vw,68px);height:clamp(44px,13vw,68px);border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.tvp-duo-av-s{border:2.5px solid rgba(192,192,192,.42);background:rgba(156,163,175,.1);}
.tvp-duo-av-b{border:2.5px solid rgba(205,127,50,.42);background:rgba(146,64,14,.1);}
.tvp-duo-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(.82rem,3.8vw,1.22rem);color:white;letter-spacing:.04em;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
.tvp-duo-score{font-family:'Bebas Neue',sans-serif;font-size:clamp(1rem,4.5vw,1.55rem);letter-spacing:.05em;line-height:1;}
.tvp-list{display:flex;flex-direction:column;gap:4px;flex-shrink:0;}
@keyframes tvpRowIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
.tvp-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:rgba(10,10,10,.75);border:1px solid rgba(255,255,255,.07);border-radius:10px;animation:tvpRowIn .4s ease forwards;opacity:0;backdrop-filter:blur(12px);position:relative;}
.tvp-row:nth-child(1){border-color:rgba(212,175,55,.22);background:rgba(212,175,55,.07);}
.tvp-row:nth-child(2){border-color:rgba(212,175,55,.12);}
.tvp-row-pos{font-family:'Bebas Neue',sans-serif;font-size:clamp(1rem,4vw,1.5rem);color:rgba(255,255,255,.15);width:clamp(18px,5.5vw,30px);text-align:center;flex-shrink:0;line-height:1;}
.tvp-row-av{width:clamp(26px,7.5vw,36px);height:clamp(26px,7.5vw,36px);border-radius:50%;border:1.5px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;}
.tvp-row-info{flex:1;min-width:0;overflow:hidden;}
.tvp-row-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(.82rem,3.2vw,1.18rem);color:rgba(255,255,255,.88);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.1;}
.tvp-row-score{font-family:'Bebas Neue',sans-serif;font-size:clamp(.85rem,3.4vw,1.22rem);color:rgba(255,255,255,.6);letter-spacing:.06em;flex-shrink:0;text-align:right;}
.tvp-ts{font-family:'FraktionMono',monospace;font-size:clamp(7px,1.8vw,9px);color:rgba(255,255,255,.25);letter-spacing:.1em;white-space:nowrap;display:flex;align-items:center;gap:4px;}
.tvp-ts-sm{font-size:clamp(6px,1.5vw,8px);margin-top:1px;}
.tvp-ts i{opacity:.4;font-size:.85em;}
@keyframes badgePop{0%{transform:scale(.4);opacity:0}65%{transform:scale(1.18)}100%{transform:scale(1);opacity:1}}
@keyframes bPulseG{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 0 0 5px rgba(34,197,94,0)}}
@keyframes bPulseR{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}50%{box-shadow:0 0 0 5px rgba(239,68,68,0)}}
.tvp-badge{display:inline-flex;align-items:center;gap:3px;padding:3px 7px;border-radius:100px;font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:11px;letter-spacing:.08em;animation:badgePop .5s cubic-bezier(.34,1.56,.64,1) forwards;flex-shrink:0;white-space:nowrap;}
.tvp-badge-up{background:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.5);color:#4ade80;animation:badgePop .5s cubic-bezier(.34,1.56,.64,1) forwards,bPulseG 2s ease-in-out infinite .5s;}
.tvp-badge-down{background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.5);color:#f87171;animation:badgePop .5s cubic-bezier(.34,1.56,.64,1) forwards,bPulseR 2s ease-in-out infinite .5s;}
.tvp-badge-new{background:rgba(212,175,55,.22);border:1px solid rgba(212,175,55,.55);color:#D4AF37;animation:badgePop .5s cubic-bezier(.34,1.56,.64,1) forwards;}
@keyframes goldGlow{0%,100%{filter:drop-shadow(0 0 8px rgba(212,175,55,.35))}50%{filter:drop-shadow(0 0 22px rgba(212,175,55,.65))}}
/* ── JOIN CHALLENGE BUTTON SHIMMER ─────────── */
@keyframes joinShimmer {
  0%   { transform: translateX(-120%) skewX(-20deg); }
  100% { transform: translateX(250%) skewX(-20deg); }
}
.join-cta-btn::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 40%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent);
  animation: joinShimmer 2.5s ease-in-out infinite;
}