:root{
  --bg:#000;--s1:#0a0a0f;--s2:#111118;--s3:#1c1c26;
  --brd:rgba(255,255,255,.08);--brd2:rgba(255,255,255,.16);
  --txt:#f2f2f7;--txt2:rgba(242,242,247,.55);--txt3:rgba(242,242,247,.3);
  --acc:#f0d060;--ac2:#ff375f;--ac3:#30d158;--ac4:#0a84ff;
  --r:18px;--rs:12px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--txt);font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;padding-bottom:56px}

/* ── AMBIENT ── */
.amb{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ab{position:absolute;border-radius:50%;filter:blur(130px);opacity:.3;animation:ab 20s ease-in-out infinite}
.ab1{width:550px;height:550px;background:radial-gradient(#f0d06028,transparent 70%);top:-180px;left:-120px}
.ab2{width:480px;height:480px;background:radial-gradient(#ff375f22,transparent 70%);bottom:-120px;right:-80px;animation-delay:-7s}
.ab3{width:380px;height:380px;background:radial-gradient(#0a84ff18,transparent 70%);top:45%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}
@keyframes ab{0%,100%{transform:translate(0,0) scale(1)}40%{transform:translate(25px,-18px) scale(1.04)}70%{transform:translate(-18px,22px) scale(.97)}}

/* ── HEADER ── */
header{position:sticky;top:0;z-index:100;height:52px;padding:0 20px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(0,0,0,.75);backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--brd)}
.logo{font-size:1.15rem;font-weight:700;letter-spacing:-.3px;color:var(--txt)}
.logo em{font-style:normal;background:linear-gradient(135deg,var(--acc),var(--ac2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hright{display:flex;align-items:center;gap:10px}
.pill-nav{display:flex;background:var(--s2);border:1px solid var(--brd);border-radius:30px;padding:3px;gap:2px}
.pnb{background:none;border:none;padding:5px 14px;border-radius:26px;
  font-family:inherit;font-size:.7rem;font-weight:600;color:var(--txt2);cursor:pointer;transition:all .2s}
.pnb.act{background:var(--s3);color:var(--txt);box-shadow:0 1px 4px rgba(0,0,0,.5)}
.vmode{margin:0 auto 14px;width:max-content}
/* Sound toggle */
.info-btn{background:var(--s2);border:1px solid var(--brd);width:34px;height:34px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--txt2);font-size:1rem;font-weight:700;text-decoration:none;
  cursor:pointer;transition:.15s;line-height:1}
.info-btn:hover{border-color:var(--brd2);color:var(--txt1)}
.snd-btn{background:var(--s2);border:1px solid var(--brd);width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;
  transition:all .2s;flex-shrink:0}
.snd-btn:hover{border-color:var(--brd2)}
.snd-btn.muted{opacity:.4}

/* ── VIEWS ── */
.view{display:none;position:relative;z-index:5}
.view.vis{display:block}
#vv.vis{display:flex;flex-direction:column;align-items:center;
  min-height:calc(100dvh - 52px - 56px);padding:30px 18px 20px;gap:26px}

/* ── QUESTION ── */
.qb{text-align:center}
.qt{font-size:clamp(1.25rem,3.5vw,1.85rem);font-weight:700;letter-spacing:-.4px;
  color:var(--txt);line-height:1.15;animation:qpop .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes qpop{from{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:none}}
.qs{margin-top:5px;font-size:.7rem;font-weight:500;color:var(--txt3);letter-spacing:.3px}

/* ── ARENA ── */
.arena{display:grid;grid-template-columns:1fr 40px 1fr;align-items:center;
  gap:10px;width:100%;max-width:800px;touch-action:pan-y}
.arena.swipe-pick-l > .card:nth-child(1),
.arena.swipe-pick-r > .card:nth-child(3){border-color:rgba(240,208,96,.7);box-shadow:0 0 30px rgba(240,208,96,.25)}
.arena.swipe-pick-l > .card:nth-child(3),
.arena.swipe-pick-r > .card:nth-child(1){opacity:.55;filter:saturate(.7)}
.vsm{display:flex;align-items:center;justify-content:center}
.vsb{width:36px;height:36px;border-radius:50%;background:var(--s3);
  border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:800;color:var(--txt2);letter-spacing:.5px}

/* ── CARD ── */
.card{background:var(--s1);border:1px solid var(--brd);border-radius:var(--r);
  overflow:hidden;cursor:pointer;position:relative;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s,border-color .2s;
  animation:cap .4s cubic-bezier(.34,1.56,.64,1) both}
.card:nth-child(3){animation-delay:.06s}
@keyframes cap{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}
.card:hover{transform:translateY(-6px) scale(1.015);border-color:var(--brd2);
  box-shadow:0 20px 50px rgba(0,0,0,.55)}
.card.pressed{transform:translateY(2px) scale(.975);transition:transform .08s ease;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.card.win{border-color:rgba(240,208,96,.7);animation:cwin .55s ease forwards}
.card.lose{animation:close .65s ease forwards}
@keyframes cwin{20%{transform:scale(1.04);box-shadow:0 0 60px rgba(240,208,96,.3)}100%{transform:scale(1)}}
@keyframes close{to{opacity:.08;filter:saturate(0) blur(2px);transform:scale(.93)}}

/* photo */
.cph{width:100%;aspect-ratio:3/4;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center}
.cph img{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:top center;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
/* ZOOM ON TAP */
.card.zoomed .cph img{transform:scale(1.18)!important}
.cph-g{position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 45%,var(--s1) 100%);
  z-index:1;pointer-events:none}
.cini{font-size:3.5rem;font-weight:800;color:rgba(255,255,255,.1);position:absolute;z-index:0}
.csp{position:absolute;top:9px;left:9px;z-index:3;
  background:rgba(0,0,0,.6);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.18);border-radius:20px;
  padding:4px 9px;display:flex;align-items:center;gap:4px;
  font-size:.58rem;font-weight:700;letter-spacing:.4px;
  max-width:calc(100% - 18px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}

/* card body */
.cbdy{padding:11px 13px 0;position:relative;z-index:2}
.clogo{height:26px;display:flex;align-items:center;margin-bottom:8px}
.clogo svg{height:26px;width:auto;display:block}
.cn{font-size:1rem;font-weight:700;letter-spacing:-.25px;line-height:1.2;color:var(--txt)}
.cr{margin-top:4px;font-size:.65rem;font-weight:500;color:var(--txt2);line-height:1.4}
.celo{margin-top:9px;padding-bottom:13px;display:flex;align-items:center;gap:5px;
  font-size:.63rem;font-weight:600;color:var(--txt3)}
.celon{color:var(--acc);font-size:.88rem;font-weight:700}
.cpk{width:100%;padding:12px 0;border:none;border-top:1px solid var(--brd);
  background:linear-gradient(135deg,rgba(240,208,96,.05),rgba(255,55,95,.03));
  color:var(--txt2);font-family:inherit;font-size:.73rem;font-weight:600;
  cursor:pointer;letter-spacing:.3px;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:6px}
.cpk:hover{background:linear-gradient(135deg,rgba(240,208,96,.14),rgba(255,55,95,.08));
  color:var(--txt);border-color:rgba(240,208,96,.35)}

/* elo float */
.ef{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);
  font-size:2.8rem;font-weight:900;pointer-events:none;opacity:0;z-index:20}
.ef.pos{color:var(--ac3);animation:efg .85s ease forwards}
.ef.neg{color:var(--ac2);animation:efg .85s ease forwards}
@keyframes efg{0%{opacity:1;transform:translate(-50%,-50%) scale(1.3)}100%{opacity:0;transform:translate(-50%,-260%) scale(.8)}}

/* controls */
.ctrl{display:flex;align-items:center;gap:10px;width:100%;max-width:800px;justify-content:center}
.skip{background:var(--s2);border:1px solid var(--brd);padding:10px 20px;border-radius:30px;
  font-family:inherit;font-size:.73rem;font-weight:600;color:var(--txt2);cursor:pointer;
  letter-spacing:.2px;transition:all .2s}
.skip:hover{border-color:var(--brd2);color:var(--txt);background:var(--s3)}
.stat{background:var(--s2);border:1px solid var(--brd);padding:10px 18px;border-radius:30px;
  font-size:.7rem;font-weight:600;color:var(--txt3)}
.stat strong{color:var(--txt);font-weight:700}

/* ── TABS (Ranking / Parteien / Verlauf) ── */
#rv{padding:28px 20px 24px;max-width:900px;margin:0 auto}
.rv-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.rh{font-size:1.9rem;font-weight:800;letter-spacing:-.5px}
.rh span{background:linear-gradient(135deg,var(--acc),var(--ac2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.rsub{font-size:.7rem;color:var(--txt3);font-weight:500;margin-bottom:20px}
.tab-bar{display:flex;background:var(--s2);border:1px solid var(--brd);
  border-radius:30px;padding:3px;gap:2px;width:fit-content}
.tbb{background:none;border:none;padding:6px 16px;border-radius:26px;
  font-family:inherit;font-size:.7rem;font-weight:600;color:var(--txt2);
  cursor:pointer;transition:all .2s;white-space:nowrap}
.tbb.act{background:var(--s3);color:var(--txt);box-shadow:0 1px 4px rgba(0,0,0,.5)}
.tab-pane{display:none}.tab-pane.vis{display:block}

/* ── POLITICIAN RANKING LIST ── */
.rcols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rcol{min-width:0}
.rcol-h{font-size:.85rem;font-weight:700;color:var(--txt2);margin-bottom:10px;letter-spacing:.3px}
.rcol-h-flop{color:#ff6b6b}
.rlist{display:flex;flex-direction:column;gap:5px}
.ri{display:grid;grid-template-columns:28px 36px 1fr auto;align-items:center;gap:8px;
  padding:9px 11px;border-radius:var(--rs);background:var(--s1);border:1px solid var(--brd);
  animation:riin .25s ease both;transition:all .18s;cursor:pointer}
.ri:hover{background:var(--s2);border-color:var(--brd2);transform:translateX(3px)}
@keyframes riin{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.rn{font-size:1rem;font-weight:800;text-align:center;color:var(--txt3)}
.r1 .rn{color:var(--acc);font-size:1.2rem}
.r2 .rn{color:rgba(255,255,255,.65);font-size:1.1rem}
.r3 .rn{color:rgba(255,255,255,.45)}
.rph{width:36px;height:36px;border-radius:10px;overflow:hidden;border:1px solid var(--brd);
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rph img{width:100%;height:100%;object-fit:cover;object-position:top center}
.rphi{font-size:.8rem;font-weight:700;color:var(--txt3)}
.rif{min-width:0}
.rnm{font-size:.86rem;font-weight:700;letter-spacing:-.2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rlogo{margin-top:4px;height:18px;display:flex;align-items:center}
.rlogo svg{height:18px;width:auto;display:block}
.rrl{font-size:.6rem;color:var(--txt3);font-weight:500;margin-top:2px}
.rst{text-align:right;flex-shrink:0}
.re{font-size:1.3rem;font-weight:800;color:var(--acc);letter-spacing:-.5px;line-height:1}
.rwr{font-size:.58rem;color:var(--txt3);font-weight:500;margin-top:2px}

/* ── PARTY RANKING ── */
.party-grid{display:flex;flex-direction:column;gap:10px}
.pi{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rs);
  padding:14px 16px;animation:riin .25s ease both}
.pi-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.pi-logo{height:28px;display:flex;align-items:center;flex-shrink:0}
.pi-logo svg{height:28px;width:auto}
.pi-name{font-size:.9rem;font-weight:700}
.pi-meta{font-size:.62rem;color:var(--txt3);font-weight:500;margin-top:1px}
.pi-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pi-stat{background:var(--s2);border-radius:10px;padding:10px;text-align:center}
.pi-stat-val{font-size:1.1rem;font-weight:800;color:var(--acc)}
.pi-stat-lbl{font-size:.58rem;color:var(--txt3);font-weight:600;letter-spacing:.5px;
  text-transform:uppercase;margin-top:2px}
/* bar */
.pi-bar-wrap{margin-top:10px;height:4px;background:var(--brd);border-radius:2px;overflow:hidden}
.pi-bar{height:100%;border-radius:2px;transition:width 1s ease}

/* ── ELO HISTORY ── */
.elo-search{width:100%;padding:10px 16px;background:var(--s2);border:1px solid var(--brd);
  border-radius:30px;color:var(--txt);font-family:inherit;font-size:.8rem;outline:none;
  margin-bottom:14px;transition:border-color .2s}
.elo-search:focus{border-color:var(--brd2)}
.elo-search::placeholder{color:var(--txt3)}
.elo-results{display:flex;flex-direction:column;gap:5px;max-height:220px;overflow-y:auto;margin-bottom:16px}
.elo-res-item{display:flex;align-items:center;gap:10px;padding:8px 12px;
  border-radius:var(--rs);background:var(--s1);border:1px solid var(--brd);
  cursor:pointer;transition:all .18s;animation:riin .25s ease both}
.elo-res-item:hover{background:var(--s2);border-color:var(--brd2)}
.elo-res-ph{width:32px;height:32px;border-radius:8px;overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;border:1px solid var(--brd)}
.elo-res-ph img{width:100%;height:100%;object-fit:cover;object-position:top center}
.elo-res-info{flex:1;min-width:0}
.elo-res-name{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.elo-res-elo{font-size:.62rem;color:var(--acc);font-weight:700}
.elo-chart-wrap{background:var(--s1);border:1px solid var(--brd);border-radius:var(--r);padding:18px}
.elo-chart-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;animation:riin .25s ease both}
.elo-chart-title{font-size:.9rem;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.elo-chart-sub{font-size:.62rem;color:var(--txt3)}
.elo-chart-canvas-wrap{position:relative;height:160px;width:100%;margin-top:10px;animation:riin .3s ease both;animation-delay:.08s}
.elo-chart-canvas{width:100%;height:100%;display:block}
.elo-empty{text-align:center;padding:48px 0;color:var(--txt3);font-size:.8rem}

.elo-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}
.elo-stat{flex:1 1 90px;background:var(--s2);border:1px solid var(--brd);border-radius:var(--rs);
  padding:8px 10px;min-width:0;animation:riin .25s ease both}
.elo-stat:nth-child(2){animation-delay:.04s}
.elo-stat:nth-child(3){animation-delay:.08s}
.elo-stat:nth-child(4){animation-delay:.12s}
.elo-stat:nth-child(5){animation-delay:.16s}
.elo-stat-l{font-size:.58rem;color:var(--txt3);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}
.elo-stat-v{font-size:.95rem;font-weight:800;line-height:1.1}
.elo-stat-v.pos{color:#34c759}
.elo-stat-v.neg{color:#ff453a}
.elo-stat-d{font-size:.58rem;color:var(--txt3);margin-top:2px}
.elo-stat-range{font-size:.7rem;font-weight:700}

.elo-crosshair{position:absolute;width:1px;background:rgba(255,255,255,.18);pointer-events:none}
.elo-tooltip{position:absolute;background:var(--s2);border:1px solid var(--brd2);border-radius:8px;
  padding:8px 10px;font-size:.7rem;pointer-events:none;z-index:5;
  box-shadow:0 6px 20px rgba(0,0,0,.4);min-width:140px;max-width:220px}
.elo-tip-date{font-size:.6rem;color:var(--txt3);font-weight:600;margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}
.elo-tip-row{padding:3px 0}
.elo-tip-row + .elo-tip-row{border-top:1px solid var(--brd);margin-top:3px;padding-top:5px}
.elo-tip-name{display:flex;align-items:center;gap:6px;font-weight:700;font-size:.7rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.elo-tip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.elo-tip-elo{font-size:.78rem;font-weight:800;color:var(--acc);margin-top:1px}
.elo-tip-meta{font-size:.6rem;color:var(--txt3);margin-top:1px}
.elo-tip-w{color:#34c759;font-weight:700;margin-right:4px}
.elo-tip-l{color:#ff453a;font-weight:700;margin-right:4px}

.elo-compare-bar{margin-top:14px;animation:riin .3s ease both;animation-delay:.16s}
.elo-compare-toggle{background:var(--s2);border:1px solid var(--brd);color:var(--txt2);
  padding:7px 14px;border-radius:30px;font-family:inherit;font-size:.7rem;font-weight:600;
  cursor:pointer;transition:all .18s}
.elo-compare-toggle:hover{border-color:var(--brd2);color:var(--txt)}
.elo-compare-picker{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.elo-compare-input{width:100%;padding:8px 14px;background:var(--s2);border:1px solid var(--brd);
  border-radius:30px;color:var(--txt);font-family:inherit;font-size:.75rem;outline:none;
  transition:border-color .2s}
.elo-compare-input:focus{border-color:var(--brd2)}
.elo-compare-results{display:flex;flex-direction:column;gap:5px;max-height:200px;overflow-y:auto}

.elo-compare-heads{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.elo-compare-head{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;
  padding:6px 10px;background:var(--s2);border:1px solid var(--brd);border-radius:var(--rs);
  animation:riin .25s ease both}
.elo-compare-head:nth-child(2){animation-delay:.06s}
.elo-compare-dot{width:10px;height:10px;border-radius:50%;background:var(--ln);flex-shrink:0}
.elo-compare-elo{margin-left:auto;font-size:.7rem;color:var(--acc);font-weight:800}
.elo-compare-clear{background:transparent;border:none;color:var(--txt3);font-size:1.05rem;
  line-height:1;cursor:pointer;padding:0 4px;margin-left:6px}
.elo-compare-clear:hover{color:var(--txt)}

/* ── CONFETTI ── */
.confetti-piece{position:fixed;width:10px;height:10px;border-radius:2px;
  pointer-events:none;z-index:9999;animation:cffall linear forwards}
@keyframes cffall{
  0%{transform:translateY(-20px) rotate(0deg);opacity:1}
  100%{transform:translateY(105vh) rotate(720deg);opacity:0}
}

/* ── MILESTONE TOAST ── */
.milestone{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);
  background:linear-gradient(135deg,var(--s3),var(--s2));
  border:2px solid var(--acc);border-radius:var(--r);
  padding:28px 40px;text-align:center;z-index:500;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.milestone.show{transform:translate(-50%,-50%) scale(1)}
.milestone-num{font-size:3rem;font-weight:900;background:linear-gradient(135deg,var(--acc),var(--ac2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.milestone-txt{font-size:.85rem;color:var(--txt2);margin-top:6px;font-weight:500}

/* ── PHOTO ZOOM OVERLAY ── */
.zoom-overlay{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.85);
  backdrop-filter:blur(20px);display:none;align-items:center;justify-content:center;
  animation:zfade .2s ease}
.zoom-overlay.show{display:flex}
@keyframes zfade{from{opacity:0}to{opacity:1}}
.zoom-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--r);
  animation:zpop .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes zpop{from{transform:scale(.85)}to{transform:scale(1)}}
.zoom-name{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  font-size:1rem;font-weight:700;color:#fff;background:rgba(0,0,0,.6);
  padding:8px 20px;border-radius:30px;backdrop-filter:blur(10px);white-space:nowrap}

/* ── ELO MODAL ── */
.elo-modal{position:fixed;inset:0;z-index:850;background:rgba(0,0,0,.78);
  backdrop-filter:blur(18px);display:none;align-items:center;justify-content:center;
  padding:32px;animation:zfade .18s ease}
.elo-modal.show{display:flex}
.elo-modal-content{position:relative;width:min(1100px,100%);height:min(720px,100%);
  background:var(--s1);border:1px solid var(--brd2);border-radius:var(--r);
  padding:48px 32px 32px;animation:zpop .25s cubic-bezier(.34,1.56,.64,1);
  overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 30px 80px rgba(0,0,0,.6)}
.elo-modal-content .elo-chart-wrap{background:transparent;border:none;padding:0;flex:1;
  display:flex;flex-direction:column;min-height:0}
.elo-modal-content .elo-chart-canvas-wrap{flex:1;height:auto;min-height:0}
.elo-modal-content .elo-chart-canvas{flex:1;height:100%;width:100%;min-height:0}
.elo-modal-close{position:absolute;top:10px;right:12px;width:32px;height:32px;
  border-radius:50%;background:var(--s2);border:1px solid var(--brd);
  color:var(--txt2);font-size:1.2rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .18s}
.elo-modal-close:hover{color:var(--txt);border-color:var(--brd2);background:var(--s3)}

/* ── TOAST ── */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(70px);
  background:var(--s3);border:1px solid var(--brd2);padding:10px 20px;border-radius:30px;
  font-size:.74rem;font-weight:600;letter-spacing:.2px;
  transition:transform .28s cubic-bezier(.34,1.56,.64,1);z-index:300;white-space:nowrap;
  backdrop-filter:blur(20px)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.win{border-color:rgba(240,208,96,.45);color:var(--acc)}

/* ── MOBILE ── */
@media(max-width:620px){
  body{padding-bottom:72px}
  header{padding:0 12px;height:48px}.logo{font-size:1rem}
  .pnb{padding:5px 10px;font-size:.66rem}
  #vv.vis{padding:18px 10px 16px;gap:18px;min-height:calc(100dvh - 48px - 72px)}
  .qt{font-size:1.15rem}
  .arena{gap:6px;grid-template-columns:1fr 26px 1fr}
  .vsb{width:26px;height:26px;font-size:.6rem}
  .cbdy{padding:9px 10px 0}.cn{font-size:.9rem}.cr{font-size:.6rem}
  .clogo{height:22px;margin-bottom:6px}.clogo svg{height:22px}
  .cpk{padding:10px 0;font-size:.68rem}
  .ctrl{gap:7px}.skip,.stat{padding:9px 14px;font-size:.68rem}
  #rv{padding:20px 12px 20px}.rh{font-size:1.55rem}
  .rcols{grid-template-columns:1fr;gap:24px}
  .ri{grid-template-columns:28px 38px 1fr auto;gap:9px;padding:9px 11px}
  .tab-bar{width:100%}.tbb{flex:1;text-align:center;padding:6px 8px;font-size:.66rem}
  .pi-stats{grid-template-columns:repeat(3,1fr);gap:5px}
  .elo-modal{padding:0}
  .elo-modal-content{width:100%;height:100%;max-width:none;max-height:none;
    border-radius:0;border:none;padding:44px 16px 20px}
}

footer{position:fixed;bottom:0;left:0;right:0;
  padding:10px 20px;border-top:1px solid var(--brd);
  display:flex;justify-content:center;flex-wrap:wrap;gap:6px;
  font-size:.6rem;color:var(--txt3);font-weight:500;
  background:rgba(0,0,0,.75);backdrop-filter:blur(24px) saturate(180%);
  z-index:50}
footer a{color:inherit;text-decoration:underline;text-underline-offset:2px}
footer a:hover{color:var(--txt1)}

.legal{max-width:720px;margin:80px auto 120px;padding:0 24px;
  color:var(--txt2);font-size:.95rem;line-height:1.6}
.legal h1{color:var(--txt1);font-size:1.8rem;font-weight:800;margin:0 0 24px}
.legal h2{color:var(--txt1);font-size:1.1rem;font-weight:700;margin:28px 0 8px}
.legal p{margin:0 0 12px}
.legal a.back{color:var(--txt3);text-decoration:none;font-size:.85rem}
.legal a.back:hover{color:var(--txt1)}
