:root{
  --bg:#07070b;
  --stroke:rgba(255,255,255,.10);
  --text:#ecebff;
  --muted:rgba(236,235,255,.72);
  --violet:#7A2EFF;
  --violet2:#C6B7FF;
  --shadow:0 22px 90px rgba(0,0,0,.55);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 50% 10%, rgba(122,46,255,.22), transparent 65%),
    radial-gradient(900px 520px at 18% 25%, rgba(198,183,255,.10), transparent 60%),
    radial-gradient(900px 520px at 82% 70%, rgba(122,46,255,.10), transparent 60%),
    var(--bg);
}

/* Anti-banding grain */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  opacity:.10;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

/* panels */
.panel{display:none}
.panel.active{display:block}

/* HOME header */
.home-header{
  position:sticky; top:0; z-index:5;
  padding:18px 16px;
  background:rgba(7,7,11,.55);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--stroke);
  display:flex;
  justify-content:center;
}
.home-title{
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
}

/* home layout */
.home-hero{display:flex;justify-content:center;margin-top:30px;padding:0 16px}

/* 3D card */
.idcard-scene{perspective:1200px}
.idcard{
  width:min(860px, 96vw);
  padding:20px;
  border-radius:var(--radius);
  border:1px solid rgba(122,46,255,.28);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow:var(--shadow);
  display:flex;
  gap:18px;
  align-items:center;
  transform-style:preserve-3d;
  will-change:transform;
  position:relative;
  overflow:hidden;
  cursor:grab;
}
.idcard:active{cursor:grabbing}

.logo-btn{
  width:170px; min-width:170px;
  border-radius:16px;
  border:1px solid rgba(122,46,255,.28);
  background:radial-gradient(240px 160px at 50% 40%, rgba(122,46,255,.22), rgba(255,255,255,.02));
  display:flex;align-items:center;justify-content:center;
  transform:translateZ(40px);
  cursor:pointer;
  position:relative;
  z-index:3;
}
.logo-btn img{
  width:130px;height:130px;object-fit:contain;
  filter:drop-shadow(0 14px 30px rgba(122,46,255,.30));
}

.idcard-info{
  flex:1;
  transform:translateZ(26px);
  position:relative;
  z-index:3;
}
.teamline{font-weight:900;letter-spacing:.14em;color:var(--violet2);text-transform:uppercase}
.slogan{margin-top:10px;color:var(--muted);text-shadow:0 0 22px rgba(122,46,255,.20)}
.glitch{position:relative;display:inline-block}
.glitch::before,.glitch::after{
  content:attr(data-text);
  position:absolute;left:0;top:0;opacity:.28;pointer-events:none;
}
.glitch::before{transform:translate(1px,-1px)}
.glitch::after{transform:translate(-1px,1px)}

.holo{
  position:absolute; inset:-40%;
  background:
    radial-gradient(800px 400px at var(--mx,50%) var(--my,40%), rgba(122,46,255,.20), transparent 60%),
    radial-gradient(600px 300px at calc(var(--mx,50%) + 12%) calc(var(--my,40%) + 8%), rgba(198,183,255,.12), transparent 60%);
  mix-blend-mode:screen;
  opacity:.9;
  transform:translateZ(10px);
  pointer-events:none;
  z-index:1;
}

/* guns button */
.guns-btn{
  display:inline-flex;
  margin-top:14px;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid rgba(122,46,255,.55);
  background: rgba(122,46,255,.16);
  color: rgba(236,235,255,.98);
  text-decoration:none;
  font-weight:900;
  position:relative;
  overflow:hidden;
  box-shadow:0 0 28px rgba(122,46,255,.18);
  z-index:3;
}
.guns-btn:hover{background:rgba(122,46,255,.20);border-color:rgba(122,46,255,.75)}
.guns-btn::before{
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(120deg, transparent 35%, rgba(198,183,255,.20), transparent 65%);
  transform: translateX(-55%) rotate(10deg);
  animation: sheen 2.6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes sheen{
  0%{transform:translateX(-55%) rotate(10deg);opacity:0}
  35%{opacity:.55}
  55%{opacity:0}
  100%{transform:translateX(55%) rotate(10deg);opacity:0}
}

/* ============ OVERLAY (SCROLLABLE) ============ */
.overlay{
  position:fixed; inset:0;
  display:none; z-index:50;
  overflow:auto;               /* <-- KEY */
  -webkit-overflow-scrolling: touch;
}
.overlay.on{display:block}

.overlay-bg{
  position:fixed; inset:0;     /* fixed so it doesn't scroll with content */
  background:
    radial-gradient(900px 520px at 50% 22%, rgba(122,46,255,.20), transparent 62%),
    url("/logo.png") center/520px no-repeat,
    #07070b;
  opacity:.14;
  filter: blur(2px) saturate(1.15);
  pointer-events:none;
}

.overlay::after{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  background: radial-gradient(1200px 900px at 50% 50%, transparent 55%, rgba(0,0,0,.65) 100%);
  opacity:1;
}

/* Keep header sticky inside overlay */
.overlay-top{
  position:sticky;
  top:0;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  padding:14px 16px;
  border-bottom:1px solid var(--stroke);
  backdrop-filter: blur(10px);
  background: rgba(7,7,11,.55);
  z-index:5;
}
.overlay-brand{
  grid-column:2;
  justify-self:center;
  border:0;
  background:transparent;
  color:rgba(236,235,255,.95);
  font-weight:900;
  letter-spacing:.18em;
  cursor:pointer;
}
.overlay-actions{
  grid-column:3;
  justify-self:end;
  display:flex;
  gap:8px;
}
.mini{
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.03);
  color:rgba(236,235,255,.9);
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
}
.mini:hover{border-color:rgba(122,46,255,.35)}

/* content spacing so it's not stuck under sticky header */
#valo, #plus{
  position:relative;
  z-index:3;
  padding-top: 6px;
  padding-bottom: 24px;
}

/* VALO cards + details */
.team-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  padding:16px;
  justify-content:center;
}

.player-card{
  display:flex; gap:12px; align-items:center;
  padding:12px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.03);
  cursor:pointer;
  min-width:280px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position:relative;
  z-index:3;
}
.player-card:hover{
  transform: translateY(-4px);
  border-color: rgba(122,46,255,.35);
  box-shadow: 0 20px 70px rgba(0,0,0,.45);
}
.player-card img{width:42px;height:42px;object-fit:contain}
.riotid{font-weight:950}
.copyhint{font-size:12px;color:var(--muted)}

.player-card.captain{
  border-color: rgba(122,46,255,.55);
  box-shadow: 0 0 0 3px rgba(122,46,255,.12) inset, 0 24px 90px rgba(0,0,0,.55);
}
.player-card.active{
  border-color: rgba(198,183,255,.65);
  box-shadow: 0 0 0 3px rgba(198,183,255,.12) inset, 0 22px 70px rgba(0,0,0,.5);
}

.pc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.rank-badge{
  opacity:0;
  transform: translateY(-2px);
  transition: opacity .2s ease, transform .2s ease;
  font-size:12px;
  color: rgba(236,235,255,.92);
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.03);
  padding:6px 10px;
  border-radius:999px;
  white-space:nowrap;
}
.rank-badge.on{opacity:1;transform:translateY(0)}

.valo-details{
  max-height:0;
  overflow:hidden;
  opacity:0;
  transform: translateY(6px);
  transition: max-height .28s ease, opacity .18s ease, transform .18s ease;
}
.valo-details.on{
  max-height:4000px;
  opacity:1;
  transform: translateY(0);
}

/* charts sizing + scroll friendly */
.grid2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  padding:0 16px 28px;
}
.grid2 .box:nth-child(1){grid-column:1/-1}
@media (max-width:860px){
  .grid2{grid-template-columns:1fr}
  .idcard{flex-direction:column}
  .logo-btn{width:100%}
}

/* Each chart box fixed height so it doesn't push too much */
.chartbox canvas{
  max-height: 260px !important;
}
@media (max-width:860px){
  .chartbox canvas{ max-height: 220px !important; }
}

.box{
  padding:16px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.box h2{margin:0 0 10px 0}

.kv2{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
.statbox{border:1px solid var(--stroke);border-radius:14px;padding:10px;background:rgba(255,255,255,.02)}
.statlabel{font-size:12px;color:var(--muted)}
.statvalue{margin-top:6px;font-weight:950;font-size:18px}
.hint{margin-top:10px;color:var(--muted);font-size:12px}
.hint.subtle{opacity:.7}
.progressline{
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
}
.progressbar{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  letter-spacing:.06em;
  color: rgba(236,235,255,.92);
}

/* toast */
.toast{
  position:fixed; left:50%; bottom:22px; transform:translateX(-50%);
  padding:10px 14px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(7,7,11,.75); backdrop-filter: blur(10px);
  color:rgba(236,235,255,.95); z-index:9999;
}
