*{box-sizing:border-box}html,body{margin:0;padding:0}body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:#0a0b12;color:#fff;min-height:100vh;position:relative;overflow-x:hidden
}
.container{max-width:1200px;margin:0 auto;padding:32px 16px;position:relative;z-index:1}
.bg-glow{position:fixed;border-radius:999px;filter:blur(110px);pointer-events:none;opacity:.22}
.glow-1{width:340px;height:340px;background:#ec4899;top:-90px;left:50%;transform:translateX(-50%)}
.glow-2{width:280px;height:280px;background:#22d3ee;left:-80px;top:240px}
.glow-3{width:320px;height:320px;background:#fb923c;right:-100px;bottom:80px}
.card{
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.1);
  border-radius:32px;
  box-shadow:0 20px 50px rgba(0,0,0,.35);
  backdrop-filter:blur(18px)
}
.hero{display:grid;grid-template-columns:1.35fr .65fr;gap:24px;padding:0;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.35),0 0 0 1px rgba(232,121,249,.08)}
.hero-left{padding:32px 36px 36px}
.hero-right{border-left:1px solid rgba(255,255,255,.08);padding:28px;background:linear-gradient(135deg,rgba(255,255,255,.05),rgba(255,255,255,.02))}
.inner-card{border-radius:0}
.eyebrow{
  display:inline-flex;padding:8px 14px;border-radius:999px;
  border:1px solid rgba(248,113,113,.35);background:rgba(248,113,113,.10);
  color:#fee2e2;font-size:11px;font-weight:700;letter-spacing:.28em;text-transform:uppercase
}
.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 20px}
.chip{padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);font-size:10px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.hero h1{font-size:52px;line-height:1.02;margin:18px 0 12px;font-weight:900;
  background:linear-gradient(90deg,#fdba74,#fff,#67e8f9);-webkit-background-clip:text;background-clip:text;color:transparent
}
.subtitle{font-size:18px;color:rgba(255,255,255,.78);margin:0 0 12px}
.description{max-width:720px;color:rgba(255,255,255,.62);line-height:1.7;margin:0 0 10px}
.updated{font-size:14px;color:rgba(255,255,255,.5);margin:0}
.hero-right h2{margin:0 0 16px;font-size:14px;letter-spacing:.25em;text-transform:uppercase;color:#fdba74}
.hero-right ul{margin:0;padding:0;list-style:none;display:grid;gap:12px}
.hero-right li{position:relative;padding-left:18px;color:rgba(255,255,255,.74);line-height:1.55;font-size:14px}
.hero-right li:before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:999px;background:linear-gradient(90deg,#fb923c,#ec4899)}
.section{margin-top:40px}
.section-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:18px}
.section-label{font-size:13px;font-weight:800;letter-spacing:.25em;text-transform:uppercase;color:#f0abfc;margin:0 0 6px}
.section-label.cyan{color:#67e8f9}
.section h2,.leaderboard-head h2{margin:0;font-size:34px}
.top-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.top-card{padding:20px;border-radius:32px;overflow:hidden}
.top-card.top-1{border:1px solid rgba(253,186,116,.45);background:linear-gradient(180deg,rgba(251,146,60,.18),rgba(255,255,255,.04))}
.top-card.top-2{border:1px solid rgba(103,232,249,.35);background:linear-gradient(180deg,rgba(34,211,238,.12),rgba(255,255,255,.04))}
.top-card.top-3{border:1px solid rgba(240,171,252,.35);background:linear-gradient(180deg,rgba(232,121,249,.12),rgba(255,255,255,.04))}
.top-card .top-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.rank-badge,.rank-note{padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.22);font-size:11px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.76)}
.top-photo{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:26px;border:1px solid rgba(255,255,255,.1);background:#111}
.top-card h3{margin:16px 0 0;font-size:24px;font-weight:900;letter-spacing:.03em}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.stat{padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.18);text-align:center}
.stat-label{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.stat-value{font-size:22px;font-weight:900;margin-top:4px}
.note{margin-top:16px;padding:14px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.16);font-size:14px;color:rgba(255,255,255,.68)}
.leaderboard-wrap{margin-top:38px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.35),0 0 0 1px rgba(34,211,238,.08)}
.leaderboard-head{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 24px;border-bottom:1px solid rgba(255,255,255,.08)}
.pill{padding:10px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.09);background:rgba(0,0,0,.18);font-size:14px;color:rgba(255,255,255,.68)}
.table-scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead tr{background:rgba(0,0,0,.14);text-align:left}
th{padding:18px 20px;font-size:13px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.56)}
td{padding:18px 20px;border-top:1px solid rgba(255,255,255,.05);vertical-align:middle}
tbody tr:hover{background:rgba(255,255,255,.035)}
.rank-circle{display:flex;justify-content:center;align-items:center;width:42px;height:42px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.22);font-weight:900}
.player-cell{display:flex;align-items:center;gap:14px}
.player-thumb{width:58px;height:58px;border-radius:18px;object-fit:cover;border:1px solid rgba(255,255,255,.1);background:#111}
.player-name{font-weight:800;letter-spacing:.03em}
.player-sub{font-size:13px;color:rgba(255,255,255,.44);margin-top:4px}
.points{font-size:22px;font-weight:900;color:#fdba74}
.diff.pos{color:#67e8f9;font-weight:800}
.diff.neg{color:#fda4af;font-weight:800}
.sessions{font-weight:700;color:rgba(255,255,255,.82)}
@media (max-width: 980px){
  .hero{grid-template-columns:1fr}
  .hero-right{border-left:none;border-top:1px solid rgba(255,255,255,.08)}
  .top-grid{grid-template-columns:1fr}
  .hero h1{font-size:40px}
}
@media (max-width: 640px){
  .container{padding:22px 12px}
  .hero-left,.hero-right{padding:22px}
  .leaderboard-head,.section-head{align-items:flex-start;flex-direction:column}
  th,td{padding:14px 12px}
  .player-thumb{width:50px;height:50px}
}
.player-heading{
  display:flex;
  align-items:center;
  gap:10px;
  margin:16px 0 0;
  font-size:24px;
  font-weight:900;
  letter-spacing:.03em;
}

.player-name-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.flag-inline{
  width:22px;
  height:16px;
  object-fit:cover;
  border-radius:3px;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 0 0 1px rgba(0,0,0,.15) inset;
}
.player-heading{
  display:flex;
  align-items:center;
  gap:10px;
  margin:16px 0 0;
  font-size:24px;
  font-weight:900;
  letter-spacing:.03em;
}

.player-name-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.flag-inline{
  width:22px;
  height:16px;
  object-fit:cover;
  border-radius:3px;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 0 0 1px rgba(0,0,0,.15) inset;
}
.rank-badge.rank-1{
  background: linear-gradient(90deg, #f7e27c 0%, #d4a017 100%);
  color: #111;
  border: 1px solid rgba(247, 226, 124, 0.45);
}

.rank-badge.rank-2{
  background: linear-gradient(90deg, #e5e7eb 0%, #9ca3af 100%);
  color: #111;
  border: 1px solid rgba(229, 231, 235, 0.45);
}

.rank-badge.rank-3{
  background: linear-gradient(90deg, #d97706 0%, #92400e 100%);
  color: #fff;
  border: 1px solid rgba(217, 119, 6, 0.45);
}
.top-card.top-1{
  border: 1px solid rgba(247, 226, 124, 0.45);
  background: linear-gradient(180deg, rgba(212, 160, 23, 0.18), rgba(255,255,255,0.04));
}

.top-card.top-2{
  border: 1px solid rgba(229, 231, 235, 0.35);
  background: linear-gradient(180deg, rgba(156, 163, 175, 0.12), rgba(255,255,255,0.04));
}

.top-card.top-3{
  border: 1px solid rgba(217, 119, 6, 0.35);
  background: linear-gradient(180deg, rgba(146, 64, 14, 0.16), rgba(255,255,255,0.04));
}