
:root {
  --bg:#080808; --bg2:#0f0f0f; --surface:#141414; --surface2:#1c1c1c; --surface3:#242424;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.13);
  --neon:#e8ff00; --neon2:#ff2d78; --neon3:#00d4ff; --neon4:#ff7700;
  --text:#f0f0f0; --text2:#a0a0a0; --text3:#666;
  --font-display:'Bebas Neue',sans-serif; --font-heavy:'Black Ops One',sans-serif; --font-body:'DM Sans',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
button{transition:filter 0.15s,opacity 0.15s,transform 0.1s}
button:hover:not(:disabled){filter:brightness(1.18)}
button:active:not(:disabled){transform:scale(0.95);filter:brightness(0.95)}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;overscroll-behavior:none;scrollbar-width:none}
body::-webkit-scrollbar{display:none}
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");opacity:0.35}
#app{position:relative;z-index:1;padding-bottom:72px}

/* ── TOPBAR ── */
.topbar{position:sticky;top:0;z-index:100;display:flex;flex-direction:column;gap:6px;padding:8px 14px 7px;background:rgba(8,8,8,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.topbar-logo{display:flex;align-items:center;gap:10px}
/* Logo as link */
.topbar-logo-link{text-decoration:none;cursor:pointer;border-radius:4px;transition:filter 0.25s,transform 0.25s;display:flex;align-items:center;gap:10px}
.topbar-logo-link:hover{filter:drop-shadow(0 0 8px var(--neon)) drop-shadow(0 0 16px rgba(232,255,0,0.35));transform:scale(1.04)}
.topbar-logo-link:active{transform:scale(0.97)}
.topbar-logo-link svg{transition:transform 0.35s cubic-bezier(0.34,1.56,0.64,1)}
.topbar-logo-link:hover svg{transform:rotate(-8deg) scale(1.08)}
/* Row layout */
.topbar-row1{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:5px}
/* Group switcher button — slim, no heavy border */
.topbar-group-btn{display:flex;align-items:center;gap:7px;background:none;border:none;border-bottom:1px solid var(--border2);color:var(--text);font-family:var(--font-display);font-size:16px;letter-spacing:1px;padding:3px 2px 5px;cursor:pointer;max-width:100%;transition:border-color 0.2s,color 0.2s}
.topbar-group-btn:hover{border-bottom-color:var(--neon3);color:var(--text)}
.topbar-group-btn:hover svg{color:var(--neon3) !important}
/* Group name truncation */
.topbar-group-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px;flex:1;text-align:left}

/* ── BOTTOM NAV ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;background:rgba(8,8,8,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border2);padding-bottom:env(safe-area-inset-bottom)}
#chat-input-bar{left:0;right:0;}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:9px 0 7px;cursor:pointer;position:relative;gap:3px;transition:all 0.15s}
.nav-icon-svg{width:22px;height:22px;transition:transform 0.2s}
.nav-label{font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;color:var(--text3);transition:color 0.2s}
.nav-item.active .nav-icon-svg{transform:scale(1.12)}
.nav-item.active .nav-label{color:var(--neon)}
.nav-item.active::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:2px;background:var(--neon)}

/* ── PAGES ── */
.page{display:none;overflow-x:hidden}
.page.active{display:block}
.page.slide-in-right{animation:slideInRight 0.78s cubic-bezier(0.22,1,0.36,1) both}
.page.slide-in-left{animation:slideInLeft 0.78s cubic-bezier(0.22,1,0.36,1) both}
@keyframes slideInRight{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:translateX(0)}}

/* ── SECTION HEADER ── */
.section-header{padding:18px 16px 10px;display:flex;align-items:flex-end;justify-content:space-between}
.section-title{font-family:var(--font-display);font-size:32px;letter-spacing:2px;text-transform:uppercase;line-height:1}
.section-title span{color:var(--neon)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;cursor:pointer;font-family:var(--font-display);letter-spacing:1.5px;text-transform:uppercase;font-size:14px;padding:11px 18px;transition:all 0.12s;position:relative;overflow:hidden}
.btn:hover{filter:brightness(1.15)}
.btn:active{transform:scale(0.93)}
.btn-neon{background:var(--neon);color:#000;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%)}
.btn-pink{background:var(--neon2);color:#fff;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border2)}
.btn-danger{background:transparent;color:#ff4757;border:1px solid rgba(255,71,87,0.3)}
.btn-sm{font-size:12px;padding:8px 14px}
.btn-icon{width:32px;height:32px;padding:0;font-family:var(--font-body);font-size:14px;letter-spacing:0;border:1px solid var(--border2);background:var(--surface2);color:var(--text);clip-path:none;display:flex;align-items:center;justify-content:center}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;font-family:var(--font-display);font-size:11px;letter-spacing:1px;text-transform:uppercase;border:1px solid}
.badge-neon{color:var(--neon);border-color:rgba(232,255,0,0.4);background:rgba(232,255,0,0.07)}
.badge-pink{color:var(--neon2);border-color:rgba(255,45,120,0.4);background:rgba(255,45,120,0.07)}
.badge-blue{color:var(--neon3);border-color:rgba(0,212,255,0.4);background:rgba(0,212,255,0.07)}
.badge-grey{color:var(--text2);border-color:var(--border);background:transparent}

/* ── INPUTS ── */
.input-group{margin-bottom:14px}
.input-label{display:block;margin-bottom:5px;font-family:var(--font-display);font-size:12px;letter-spacing:2px;color:var(--text2);text-transform:uppercase}
.input-field{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--font-body);font-size:15px;padding:11px 13px;outline:none;transition:border-color 0.2s;-webkit-appearance:none;border-radius:3px}
.input-field:focus{border-color:var(--neon)}
.input-field option{background:var(--surface2)}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.8);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);align-items:flex-end;justify-content:center}
.modal-overlay.open{display:flex;animation:overlayIn 0.2s ease}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border:1px solid var(--border2);border-top:2px solid var(--neon);width:100%;max-width:480px;max-height:92vh;overflow-y:auto;animation:sheetIn 0.3s cubic-bezier(0.32,0.72,0,1);padding-bottom:env(safe-area-inset-bottom)}
@keyframes sheetIn{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:32px;height:3px;background:var(--border2);margin:10px auto 0}
.modal-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.modal-title{font-family:var(--font-display);font-size:22px;letter-spacing:2px;text-transform:uppercase}
.modal-body{padding:16px}
.modal-footer{padding:0 16px 16px;display:flex;gap:10px}

/* ── AVATAR ── */
.avatar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;flex-shrink:0;clip-path:polygon(10% 0%,90% 0%,100% 10%,100% 90%,90% 100%,10% 100%,0% 90%,0% 10%)}
.avatar-sm{width:30px;height:30px;font-size:13px}
.avatar-lg{width:52px;height:52px;font-size:22px}

/* ── TOAST ── */
.toast{position:fixed;top:72px;left:50%;transform:translateX(-50%) translateY(-10px);background:var(--surface3);border:1px solid var(--neon);padding:9px 18px;font-family:var(--font-display);font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--neon);z-index:9990;opacity:0;transition:all 0.25s;white-space:nowrap;box-shadow:0 0 20px rgba(232,255,0,0.2)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── CONFIRM DIALOG ── */
.confirm-overlay{display:none;position:fixed;inset:0;z-index:900;background:rgba(0,0,0,0.88);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:24px}
.confirm-overlay.open{display:flex;animation:overlayIn 0.2s ease}
.confirm-box{background:var(--surface);border:1px solid var(--border2);border-top:2px solid var(--neon2);width:100%;max-width:320px;animation:confirmIn 0.3s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes confirmIn{from{transform:scale(0.7) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.confirm-icon{font-size:12px;text-align:center;padding:20px 20px 0;display:flex;justify-content:center}
.confirm-title{font-family:var(--font-display);font-size:22px;letter-spacing:2px;text-transform:uppercase;text-align:center;padding:8px 20px 4px}
.confirm-msg{font-size:13px;color:var(--text2);text-align:center;padding:0 20px 8px;line-height:1.6}
.confirm-warn{font-size:11px;color:var(--neon2);text-align:center;padding:0 20px 14px;letter-spacing:0.5px;display:none}
.confirm-btns{display:flex;border-top:1px solid var(--border)}
.confirm-btns button{flex:1;padding:14px;border:none;cursor:pointer;font-family:var(--font-display);font-size:16px;letter-spacing:1.5px;text-transform:uppercase;background:transparent;transition:background 0.15s}
.confirm-btns button:first-child{color:var(--text2);border-right:1px solid var(--border)}
.confirm-btns button:first-child:active{background:var(--surface2)}
.confirm-btns button:last-child{color:var(--neon2)}
.confirm-btns button:last-child:active{background:rgba(255,45,120,0.1)}

/* ── DASHBOARD ── */
.hero-block{margin:12px 16px;padding:18px 16px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--neon);position:relative;overflow:hidden}

.hero-label{font-family:var(--font-display);font-size:11px;letter-spacing:3px;color:var(--text2);text-transform:uppercase;margin-bottom:2px}
.hero-val{font-family:var(--font-display);font-size:64px;color:var(--neon);line-height:1;letter-spacing:-1px}
.hero-sub{font-size:12px;color:var(--text2);margin-top:2px}
/* Live banner on dashboard */
#live-banner{margin:0 16px 12px;background:var(--surface);border:1px solid var(--border2);border-left:3px solid var(--neon2);overflow:hidden;display:none}
#live-banner.visible{display:block}
.live-banner-header{display:flex;align-items:center;gap:8px;padding:8px 12px 0;font-family:var(--font-display);font-size:10px;letter-spacing:3px;color:var(--neon2)}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--neon2);animation:livePulse 1s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.75)}}
.live-scoreline{display:flex;align-items:center;justify-content:center;gap:0;padding:10px 16px 12px}
.live-score-player{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}
.live-score-name{font-family:var(--font-display);font-size:13px;letter-spacing:1px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.live-score-pts{font-family:var(--font-display);font-size:40px;line-height:1;letter-spacing:-1px}
.live-score-sep{font-family:var(--font-display);font-size:28px;color:var(--text3);padding:0 10px;line-height:1;align-self:flex-end;padding-bottom:6px;display:flex;flex-direction:column;align-items:center;gap:2px}
.lb-sets-score{font-family:var(--font-display);font-size:11px;letter-spacing:1px;color:var(--text2)}
.lb-serve-dot{font-size:12px}
.live-score-sets{font-family:var(--font-display);font-size:10px;letter-spacing:2px;color:var(--text2);margin-top:2px}
.live-banner-sets{display:flex;gap:4px;justify-content:center;padding:0 16px 10px}
.live-set-chip{font-family:var(--font-display);font-size:10px;letter-spacing:1px;padding:2px 7px;border:1px solid var(--border2);color:var(--text2)}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px 12px}
.stat-tile{background:var(--surface);border:1px solid var(--border);padding:14px 12px;position:relative;overflow:hidden}
.stat-tile-accent{position:absolute;bottom:0;left:0;right:0;height:2px}
.stat-val{font-family:var(--font-display);font-size:34px;line-height:1;margin-bottom:1px}
.stat-name{font-family:var(--font-display);font-size:12px;letter-spacing:2px;color:var(--text2);text-transform:uppercase}

/* ── LEADERBOARD ── */
.lb-item{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-left:2px solid var(--border2);margin-bottom:6px;transition:all 0.15s}
.lb-item.rank-1{border-left-color:gold;background:rgba(255,215,0,0.04)}
.lb-item.rank-2{border-left-color:silver}
.lb-item.rank-3{border-left-color:#cd7f32}
.lb-rank{font-family:var(--font-display);font-size:24px;width:26px;text-align:center;line-height:1}
.lb-info{flex:1;min-width:0}
.lb-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-sub{font-size:11px;color:var(--text2);margin-top:1px}
.lb-elo{font-family:var(--font-display);font-size:26px;line-height:1;text-align:right}
.lb-wr{font-size:12px;color:var(--text2);text-align:right}
.wr-bar{height:3px;background:var(--surface3);margin-top:4px;overflow:hidden}
.wr-fill{height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}

/* ── RANKINGS PAGE ── */
.rank-player-card{margin:0 16px 10px;background:var(--surface);border:1px solid var(--border);overflow:hidden}
.rpc-header{display:flex;align-items:center;gap:12px;padding:14px;border-bottom:1px solid var(--border)}
.rpc-rank{font-family:var(--font-display);font-size:40px;line-height:1;width:44px;text-align:center;flex-shrink:0}
.rpc-info{flex:1}
.rpc-name{font-family:var(--font-display);font-size:24px;letter-spacing:1px;line-height:1}
.rpc-elo{font-size:12px;color:var(--text2);margin-top:2px}
.rpc-badge{margin-left:auto;flex-shrink:0}
.rpc-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--border)}
.rpc-stat{padding:10px 8px;text-align:center;border-right:1px solid var(--border)}
.rpc-stat:last-child{border-right:none}
.rpc-stat-val{font-family:var(--font-display);font-size:22px;line-height:1}
.rpc-stat-name{font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;color:var(--text2);text-transform:uppercase;margin-top:1px}
.rpc-winbar{padding:10px 14px;border-top:1px solid var(--border)}
.rpc-winbar-label{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;color:var(--text2);text-transform:uppercase;margin-bottom:5px}
.rpc-bar-bg{height:8px;background:var(--surface3);position:relative;overflow:hidden}
.rpc-bar-fill{height:100%;position:absolute;left:0;top:0;transition:width 1s}
.rpc-headtohead{padding:10px 14px;border-top:1px solid var(--border)}
.h2h-label{font-family:var(--font-display);font-size:12px;letter-spacing:2px;color:var(--text2);text-transform:uppercase;margin-bottom:6px}
.h2h-item{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}
.h2h-item:last-child{border-bottom:none}
.h2h-name{flex:1;font-weight:500}
.h2h-score{font-family:var(--font-display);font-size:16px}

/* ── PLAYERS ── */
.player-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);margin-bottom:6px;border-left:2px solid var(--border2);transition:all 0.15s}
.player-info{flex:1;min-width:0}
.player-name{font-weight:600;font-size:15px}
.player-stats{font-size:11px;color:var(--text2);margin-top:2px}
.player-actions{display:flex;gap:6px}

/* ── GAMES ── */
.game-item{margin:0 16px 10px;background:var(--surface);border:1px solid var(--border);overflow:hidden}
.game-item-header{padding:8px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--bg2)}
.game-date{font-size:11px;color:var(--text2)}
.game-body{padding:14px 16px;display:flex;align-items:flex-start;gap:10px}
.game-player{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center}
.game-player-name{font-size:13px;font-weight:600}
.game-player-score{font-family:var(--font-display);font-size:44px;line-height:1;margin-top:2px}
.winner-score{color:var(--neon)}
.loser-score{color:var(--text3)}
.game-vs{font-family:var(--font-display);font-size:18px;color:var(--text3)}
.game-sets-detail{font-size:12px;color:var(--text2);text-align:center;margin-top:2px}

/* ── TABS ── */
.tab-bar{display:flex;margin:0 16px 14px;border-bottom:2px solid var(--border)}
.tab-btn{flex:1;padding:9px 4px;border:none;background:transparent;font-family:var(--font-display);font-size:14px;letter-spacing:2px;text-transform:uppercase;color:var(--text2);cursor:pointer;transition:all 0.15s;border-bottom:2px solid transparent;margin-bottom:-2px}
.tab-btn.active{color:var(--neon);border-bottom-color:var(--neon)}

/* ── PADDLE PICKER ── */
.paddle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.time-filter-btn{font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;white-space:nowrap;padding:5px 12px;background:var(--surface2);border:1px solid var(--border2);color:var(--text2);cursor:pointer;transition:all 0.15s;flex-shrink:0}
.time-filter-btn.active{background:rgba(232,255,0,0.1);border-color:var(--neon);color:var(--neon)}
/* ── LOGIN SCREEN ── */
#login-screen{position:fixed;inset:0;z-index:9000;background:#080808;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:20px;overflow-y:auto;overflow-x:hidden}
#login-screen.hidden{display:none}
#login-screen::before,#login-screen::after{content:'';flex:1;min-height:0}
.ls-step{flex-direction:column}
.login-logo{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:32px}

.auth-btn-primary{width:100%;font-family:var(--font-display);font-size:13px;letter-spacing:2px;font-weight:700;background:var(--neon);color:#000;border:none;padding:13px;cursor:pointer;transition:all 0.15s}
.auth-btn-primary:hover{background:#fff176;transform:translateY(-1px)}
.auth-btn-primary:active{transform:scale(0.98)}
.auth-btn-outline{font-family:var(--font-display);font-size:13px;letter-spacing:2px;font-weight:700;background:transparent;color:var(--neon);border:1px solid var(--neon);padding:13px;cursor:pointer;transition:all 0.15s;flex:2}
.auth-btn-outline:hover{background:rgba(232,255,0,0.1);transform:translateY(-1px)}
.auth-btn-outline:active{transform:scale(0.98)}
.auth-btn-secondary{font-family:var(--font-display);font-size:11px;letter-spacing:1px;background:none;border:1px solid var(--border2);color:var(--text2);padding:11px 16px;cursor:pointer;transition:all 0.15s;flex:1}
.auth-btn-secondary:hover{border-color:var(--text);color:var(--text)}
.auth-btn-secondary:active{transform:scale(0.97)}
.auth-btn-ghost{font-family:var(--font-display);font-size:11px;letter-spacing:1px;background:none;border:none;color:var(--text2);padding:8px;cursor:pointer;transition:color 0.15s;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}
.auth-btn-ghost:hover{color:var(--text)}
.auth-input{width:100%;background:var(--surface);border:2px solid var(--border2);color:var(--text);font-family:var(--font-body);font-size:15px;letter-spacing:0;padding:12px 14px;transition:border-color 0.15s;box-sizing:border-box}
.auth-input:focus{outline:none;border-color:var(--neon)}
.auth-input::placeholder{color:var(--text2);letter-spacing:1px}
.auth-label{font-family:var(--font-display);font-size:11px;letter-spacing:2px;color:var(--text2);margin-bottom:6px;align-self:flex-start}
.auth-error{font-family:var(--font-display);font-size:11px;letter-spacing:1px;color:var(--neon2);min-height:16px;margin-top:4px;text-align:center}
.paddle-opt{display:flex;align-items:center;justify-content:center;background:var(--surface2);border:2px solid var(--border2);cursor:pointer;padding:10px 6px 8px;transition:all 0.15s;position:relative;flex-direction:column;gap:5px}
.paddle-opt:active{transform:scale(0.9)}
.paddle-opt.selected{border-color:var(--neon);background:rgba(232,255,0,0.07)}
.paddle-opt.locked{cursor:not-allowed;border-color:var(--border)!important;}
.paddle-opt.selected::after{content:'';position:absolute;top:3px;right:3px;width:6px;height:6px;background:var(--neon);border-radius:50%}

/* ── COLOR PICKER ── */
.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.color-opt{width:32px;height:32px;cursor:pointer;border:2px solid transparent;clip-path:polygon(10% 0%,90% 0%,100% 10%,100% 90%,90% 100%,10% 100%,0% 90%,0% 10%);transition:all 0.15s}
.color-opt:hover{transform:scale(1.15);border-color:rgba(255,255,255,0.7);opacity:0.85}
.color-opt.selected{border-color:white;transform:scale(1.2)}

/* ── TWO-COL ROW ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── LIVE PAGE ── */
#live-page{position:fixed;inset:0;z-index:150;background:var(--bg);display:none;flex-direction:column}
#live-page.open{display:flex}
.live-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.live-title{font-family:var(--font-display);font-size:18px;letter-spacing:3px;text-transform:uppercase;color:var(--text2)}
.set-indicator{display:flex;gap:5px;align-items:center}
.set-dot{width:10px;height:10px;background:var(--surface3);border:1px solid var(--border2);transition:all 0.3s;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%)}
.set-dot.won-a{background:var(--neon)}
.set-dot.won-b{background:var(--neon2)}

.live-scoreboard{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:16px}
.score-container{display:flex;align-items:center;gap:16px;width:100%;max-width:420px}
.score-panel{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}
.score-player-name{font-family:var(--font-display);font-size:16px;letter-spacing:2px;text-align:center;text-transform:uppercase}
.serve-badge{font-family:var(--font-display);font-size:10px;letter-spacing:2px;padding:3px 8px;border-radius:2px;transition:all 0.3s;white-space:nowrap}
.serve-badge.active{background:rgba(232,255,0,0.15);color:var(--neon);border:1px solid rgba(232,255,0,0.4);animation:servePulse 1.6s ease-in-out infinite}
.serve-badge.inactive{background:transparent;color:transparent;border:1px solid transparent}
@keyframes servePulse{0%,100%{opacity:0.7}50%{opacity:1}}
.live-paddle-wrap{height:52px;display:flex;align-items:center;justify-content:center}

.score-display{width:100%;aspect-ratio:unset;min-height:230px;max-width:148px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;user-select:none;position:relative;overflow:hidden;transition:transform 0.08s, min-height 0.3s;border:2px solid}
.score-display.compact{min-height:110px;cursor:default;pointer-events:none}
.score-display:active{transform:scale(0.91)}
.score-display::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(255,255,255,0.015) 8px,rgba(255,255,255,0.015) 9px)}
.score-display.score-a{border-color:rgba(232,255,0,0.5);background:rgba(232,255,0,0.06)}
.score-display.score-b{border-color:rgba(255,45,120,0.5);background:rgba(255,45,120,0.06)}
.score-num{font-family:var(--font-display);font-size:76px;line-height:1;position:relative;z-index:1}
.score-a .score-num{color:var(--neon)}
.score-b .score-num{color:var(--neon2)}
.score-tap-hint{font-family:var(--font-display);font-size:12px;letter-spacing:2px;text-transform:uppercase;opacity:0.3;margin-top:2px}
.live-readonly .score-display{cursor:default;pointer-events:none;opacity:0.85}
.live-readonly .score-tap-hint{display:none}
.live-readonly .live-btn-row{opacity:0.4;pointer-events:none}
@keyframes pulse{0%{transform:scale(1)}40%{transform:scale(1.25)}100%{transform:scale(1)}}
.score-pulse{animation:pulse 0.22s ease}

.live-sep{font-family:var(--font-display);font-size:28px;color:var(--text3)}
.sets-display{display:flex;align-items:center;gap:12px}
.sets-box{text-align:center}
.sets-val{font-family:var(--font-display);font-size:32px;line-height:1}
.sets-label{font-family:var(--font-display);font-size:11px;letter-spacing:2px;color:var(--text2);text-transform:uppercase}
.sets-a .sets-val{color:var(--neon)}
.sets-b .sets-val{color:var(--neon2)}
.set-history-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.live-controls{padding:12px 16px;flex-shrink:0;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}
.live-btn-row{display:flex;gap:8px}

/* ── SCORE +1 ANIM ── */
.score-anim-overlay{position:fixed;inset:0;pointer-events:none;z-index:500;display:flex;align-items:center;justify-content:center}
.score-anim-text{font-family:var(--font-display);font-size:110px;opacity:0;transform:scale(0.3);text-shadow:0 0 30px currentColor}
.score-anim-text.pop{animation:scorePop 0.6s cubic-bezier(0.34,1.56,0.64,1) forwards}
@keyframes scorePop{0%{opacity:0.9;transform:scale(0.4)}35%{opacity:1;transform:scale(1.15)}60%{opacity:0.7;transform:scale(0.95)}100%{opacity:0;transform:scale(1.4) translateY(-60px)}}

/* ── SET WON BANNER ── */
.set-won-banner{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg);border:2px solid var(--neon);padding:20px 36px;text-align:center;z-index:400;box-shadow:0 0 40px rgba(232,255,0,0.3),0 0 80px rgba(232,255,0,0.1)}
.set-won-banner.show{display:block;animation:bannerIn 0.35s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes bannerIn{from{transform:translate(-50%,-50%) scale(0.5) skewX(-8deg);opacity:0}to{transform:translate(-50%,-50%) scale(1) skewX(0);opacity:1}}
.set-won-label{font-family:var(--font-display);font-size:12px;letter-spacing:4px;color:var(--text2);text-transform:uppercase;margin-bottom:2px}
.set-won-name{font-family:var(--font-display);font-size:40px;color:var(--neon);line-height:1}

/* ── GAME OVER ── */
#game-over-overlay{display:none;position:fixed;inset:0;z-index:600;background:#000;align-items:center;justify-content:center;flex-direction:column;overflow-y:auto}
#game-over-overlay.show{display:flex}
/* Achievement fly-in cards */
.go-ach-list{width:100%;max-width:400px;padding:0 24px 24px;display:flex;flex-direction:column;gap:8px}
.ach-tier-body{overflow:hidden;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1),opacity 0.25s ease}
.ach-tier-chevron{transition:transform 0.3s ease;flex-shrink:0}
.ach-tier-header{display:flex;align-items:center;gap:8px;margin-bottom:0;padding:8px 10px;background:var(--surface);border-left:3px solid var(--tc,#fff);cursor:pointer;user-select:none;transition:background 0.15s}
.ach-tier-header:hover{background:var(--surface2)}
.ach-tier-header:active{background:var(--surface3)}
.go-ach-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:rgba(255,255,255,0.04);border:1px solid;transform:translateY(60px);opacity:0;animation:achFlyIn 0.5s cubic-bezier(0.22,1,0.36,1) forwards}
@keyframes achFlyIn{to{transform:translateY(0);opacity:1}}
#go-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.go-content{position:relative;z-index:10;text-align:center;padding:24px;width:100%;max-width:400px}
.go-glitch{font-family:var(--font-display);font-size:72px;letter-spacing:4px;text-transform:uppercase;line-height:1;color:var(--neon);position:relative;display:inline-block}
.go-glitch::before,.go-glitch::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;font-family:var(--font-display);font-size:72px;letter-spacing:4px}
.go-glitch::before{color:var(--neon2);clip-path:polygon(0 30%,100% 30%,100% 55%,0 55%);animation:glitch1 2s infinite}
.go-glitch::after{color:var(--neon3);clip-path:polygon(0 60%,100% 60%,100% 80%,0 80%);animation:glitch2 2s infinite}
@keyframes glitch1{0%,90%,100%{transform:translate(0)}92%{transform:translate(-4px,1px)}94%{transform:translate(4px,-1px)}96%{transform:translate(-2px,2px)}}
@keyframes glitch2{0%,88%,100%{transform:translate(0)}90%{transform:translate(4px,2px)}93%{transform:translate(-4px,-1px)}96%{transform:translate(2px,1px)}}
.go-winner-label{font-family:var(--font-display);font-size:13px;letter-spacing:5px;color:var(--text2);text-transform:uppercase;margin:12px 0 4px}
.go-winner-name{font-family:var(--font-display);font-size:44px;line-height:1;margin-bottom:10px;animation:nameSlam 0.5s cubic-bezier(0.34,1.56,0.64,1) 0.3s both}
@keyframes nameSlam{from{transform:scale(0.3) translateY(30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.go-paddle-anim{animation:paddleSpin 0.7s cubic-bezier(0.34,1.56,0.64,1) 0.1s both;display:flex;justify-content:center;margin-bottom:8px}
@keyframes paddleSpin{from{transform:scale(0.2) rotate(-180deg);opacity:0}to{transform:scale(1) rotate(0deg);opacity:1}}
.go-scores{display:flex;justify-content:center;gap:0;margin-bottom:8px}
.go-player{padding:12px 20px}
.go-player-name{font-size:12px;color:var(--text2);font-weight:600}
.go-player-score{font-family:var(--font-display);font-size:56px;line-height:1}
.go-divider{width:2px;background:var(--surface3);align-self:stretch;margin:8px 0}
.go-sets-detail{font-size:11px;color:var(--text2);margin-bottom:20px;letter-spacing:0.5px}
.go-buttons{display:flex;gap:10px}
.go-appear{animation:goAppear 0.5s ease 0.7s both}
@keyframes goAppear{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:44px 24px;color:var(--text2)}
.empty-icon-svg{width:40px;height:40px;opacity:0.3;margin:0 auto 10px}
.empty-text{font-size:13px;line-height:1.6}

@media(min-width:480px){.score-display{max-width:180px}.score-num{font-size:96px}}
@media(orientation:landscape) and (max-height:500px){
  .live-scoreboard{flex-direction:row;padding:8px 16px;gap:12px;flex-wrap:wrap}
  .score-container{flex-direction:row;max-width:100%;flex:1;gap:12px;min-width:0}
  .score-display{min-height:unset;height:calc(100vh - 120px);max-width:unset;flex:1}
  .score-display.compact{min-height:unset;height:calc(100vh - 120px)}
  .score-num{font-size:96px}
  .set-history-row{width:100%;flex-basis:100%;text-align:center}
  .live-controls{padding:8px 16px}
  #live-page .live-topbar{padding:8px 16px}
}

/* ── Utility Classes ──────────────────────────────────────── */
.u-display{font-family:var(--font-display)}
.u-neon{color:var(--neon)}
.u-neon2{color:var(--neon2)}
.u-neon3{color:var(--neon3)}
.u-text2{color:var(--text2)}
.u-flex{display:flex}
.u-flex-1{flex:1}
.u-flex-center{display:flex;align-items:center}
.u-flex-between{display:flex;align-items:center;justify-content:space-between}
.u-w100{width:100%}
.u-mb4{margin-bottom:4px}
.u-mb6{margin-bottom:6px}
.u-mb10{margin-bottom:10px}
.u-mb12{margin-bottom:12px}
.u-mb14{margin-bottom:14px}
.u-surface2{background:var(--surface2)}
.u-border2{border:1px solid var(--border2)}
/* Label pattern: display font, small, muted — used for form labels */
.u-label{font-family:var(--font-display);font-size:10px;letter-spacing:1px;color:var(--text2);margin-bottom:4px}
/* Panel: surface card with border */
.u-panel{background:var(--surface);border:1px solid var(--border2);padding:14px}
.u-panel-neon{background:var(--surface);border:1px solid var(--neon);border-left:3px solid var(--neon);padding:14px 16px}
/* Stat value patterns */
.u-stat-val{font-family:var(--font-display);font-size:22px;letter-spacing:2px}
.u-stat-sub{font-family:var(--font-display);font-size:11px;letter-spacing:1px;color:var(--text2)}
/* Full-width display button */
.u-btn-full{width:100%;font-family:var(--font-display);font-size:12px;letter-spacing:2px;padding:12px;background:transparent;border:1px solid var(--border2);color:var(--text2);cursor:pointer}
.u-btn-full-neon{width:100%;font-family:var(--font-display);font-size:12px;letter-spacing:2px;padding:12px;background:var(--neon);border:none;color:var(--bg);cursor:pointer}

/* ── Hover effects ──────────────────────────────────────────────────────── */
/* Nav items */
.nav-item:hover:not(.active) { color: var(--text) !important; opacity: 1 !important; }
.nav-icon-svg { transition: stroke 0.15s; }

/* Dropdown buttons */
#group-switcher-dropdown button:hover { background: rgba(255,255,255,0.06) !important; }

/* Generic inline-style buttons — inject hover via CSS where onmouseenter not set */
.btn-ghost:hover { background: rgba(255,255,255,0.06) !important; }
.btn-danger:hover { background: rgba(255,61,90,0.15) !important; border-color: var(--neon2) !important; color: var(--neon2) !important; }
.btn-neon:hover { background: rgba(232,255,0,0.12) !important; border-color: var(--neon) !important; color: var(--neon) !important; }

/* Dropdown/switcher list items */
#group-switcher-list button:hover { background: rgba(255,255,255,0.06) !important; }

/* Modal close buttons */
button[onclick*="closeModal"]:hover { color: var(--text) !important; }

/* Table rows / list items with onclick */
[onclick]:not(button):not(a):hover { background: rgba(255,255,255,0.04) !important; cursor: pointer; }

/* player cards / achievement tiles / ranking rows */
.player-card:hover { border-color: var(--border2) !important; transform: translateY(-1px); }
.ach-tier-header { cursor: pointer; transition: background 0.15s; }
.ranking-row:hover { background: var(--surface2) !important; }
.game-item:hover { background: var(--surface2) !important; }

/* Back/nav arrow buttons */
button[onclick="goBack()"],
button[onclick="goBackFromDetail()"] {
  transition: color 0.15s, transform 0.15s;
}
button[onclick="goBack()"]:hover,
button[onclick="goBackFromDetail()"]:hover {
  color: var(--text) !important;
  transform: translateX(-2px);
}

/* ── XP BAR ANIMATIONS ───────────────────────────────────────────────────────── */
/* One-shot shimmer sweep — fires once after bar fills */
@keyframes xp-sweep {
  0%   { transform: translateX(-100%); opacity: 0; }
  10%  { opacity: 1; }
  100% { transform: translateX(200%); opacity: 0; }
}

/* ── SPIELEN BUTTON ──────────────────────────────────────────────────────────── */
.btn-spielen {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 16px 7px 13px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: 2px;
  color: #000;
  overflow: hidden;
  clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
  transition: color 0.2s;
}
.btn-spielen-bg {
  position: absolute;
  inset: 0;
  background: var(--neon2);
  transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1), opacity 0.2s;
  z-index: 0;
}
/* Shimmer sweep on hover */
.btn-spielen-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 35%, rgba(255,255,255,0.45) 50%, transparent 65%);
  transform: translateX(-100%);
  transition: transform 0s;
  z-index: 1;
  pointer-events: none;
}
.btn-spielen-icon {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.btn-spielen-label {
  position: relative;
  z-index: 2;
}
/* Hover state */
.btn-spielen:hover .btn-spielen-bg {
  transform: scaleX(1.06) scaleY(1.12);
}
.btn-spielen:hover .btn-spielen-shine {
  transform: translateX(200%);
  transition: transform 0.5s ease;
}
.btn-spielen:hover .btn-spielen-icon {
  transform: scale(1.3) translateX(2px);
}
/* Active */
.btn-spielen:active .btn-spielen-bg {
  transform: scale(0.94);
  opacity: 0.85;
}
.btn-spielen:active .btn-spielen-icon {
  transform: scale(1.0);
}


/* ── DESKTOP SCALING ─────────────────────────────────────────────────────────
   App is mobile-first with px-based sizing throughout.
   zoom scales the entire UI proportionally on wider screens.
   max-width + centering gives it a proper desktop layout.
─────────────────────────────────────────────────────────────────────────────── */
@media (min-width: 768px) {
  html, body {
    margin: 0;
    padding: 0;
  }
  body {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    background: var(--bg);
  }
  #app {
    width: 520px;
    flex-shrink: 0;
    zoom: 1.22;
    transform-origin: top center;
    min-height: 100vh;
    margin: 0;
  }
  /* Bottom nav must match #app's zoomed visual width and position exactly */
  .bottom-nav, #chat-input-bar {
    width: calc(520px * 1.22);
    left: 50%;
    transform: translateX(-50%);
    max-width: 100vw;
  }
  /* Topbar is sticky inside #app — inherits zoom automatically, no override needed */
}

@media (min-width: 1100px) {
  #app {
    zoom: 1.38;
  }
  .bottom-nav, #chat-input-bar {
    width: calc(520px * 1.38);
  }
}
