:root {
  --bg:      #0b0d0f;
  --s1:      #111417;
  --s2:      #181c20;
  --s3:      #1e232a;
  --s4:      #252b34;
  --accent:  #39e07b;
  --accent2: #22c45e;
  --blue:    #4d9fff;
  --amber:   #f5a623;
  --red:     #ff4d6a;
  --text:    #e8edf2;
  --muted:   #5a6475;
  --muted2:  #7a8795;
  --border:  rgba(255,255,255,0.07);
  --ba:      rgba(57,224,123,0.12);
  --radius:  12px;
  --nav-h:   64px;
  /* Snooker ball palette */
  --ball-red:    #cc2020;
  --ball-yellow: #f0c020;
  --ball-green:  #22a050;
  --ball-brown:  #8b5e3c;
  --ball-blue:   #1560bd;
  --ball-pink:   #e87090;
  --ball-black:  #1a1a1a;
}

/* ── SKELETON SCREENS ───────────────────────────────────── */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skel{
  background:linear-gradient(90deg,var(--s3) 25%,var(--s4) 50%,var(--s3) 75%);
  background-size:800px 100%;
  animation:shimmer 1.4s infinite linear;
  border-radius:6px;
}
.skel-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;}
.skel-line{height:12px;margin-bottom:8px;}
.skel-line.short{width:40%;}
.skel-line.med{width:65%;}
.skel-line.full{width:100%;}
.skel-circle{width:40px;height:40px;border-radius:50%;flex-shrink:0;}
.skel-stat{height:38px;width:60%;margin-bottom:4px;}
.skel-row{display:flex;align-items:center;gap:12px;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;}
body{background:var(--bg);color:var(--text);font-family:'Familjen Grotesk',sans-serif;font-size:14px;min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.03) 2px,rgba(0,0,0,0.03) 4px),
  radial-gradient(ellipse at 20% 10%,rgba(57,224,123,0.05) 0%,transparent 55%),
  radial-gradient(ellipse at 80% 90%,rgba(77,159,255,0.04) 0%,transparent 50%);}

/* ── LAYOUT ─────────────────────────────────────────── */
.app{display:flex;min-height:100vh;position:relative;z-index:1;}

/* Sidebar — desktop only */
.sidebar{width:220px;flex-shrink:0;background:var(--s1);border-right:1px solid var(--border);display:none;flex-direction:column;height:100vh;position:sticky;top:0;}
.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid var(--border);}
.logo-mark{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:3px;color:var(--text);line-height:1;}
.logo-mark span{color:var(--accent);}
.logo-sub{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-top:3px;}
.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px;}
.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;color:var(--muted2);transition:all .15s;border:1px solid transparent;font-weight:500;font-size:13px;}
.sidebar-nav-item:hover{background:var(--s2);color:var(--text);}
.sidebar-nav-item.active{background:var(--ba);border-color:rgba(57,224,123,0.2);color:var(--accent);}
.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border);}
.db-indicator{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.db-dot{width:6px;height:6px;border-radius:50%;background:var(--muted);transition:background .3s;}
.db-dot.live{background:var(--accent);box-shadow:0 0 6px var(--accent);animation:blink 2s ease-in-out infinite;}
.db-dot.error{background:var(--red);box-shadow:0 0 6px var(--red);}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

/* Main area */
.main{flex:1;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;}
.topbar{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--s1);flex-shrink:0;position:sticky;top:0;z-index:10;}
.page-title{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;color:var(--text);}
.page-sub{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:2px;}
.topbar-right{display:flex;align-items:center;gap:8px;}
.db-indicator-top{display:flex;align-items:center;gap:5px;font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--muted);}

/* Bottom nav — mobile */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--s1);border-top:1px solid var(--border);display:flex;height:var(--nav-h);padding:0 8px;padding-bottom:env(safe-area-inset-bottom);}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--muted2);transition:all .15s;border-radius:8px;padding:10px 4px;min-height:56px;}
.bn-item.active{color:var(--accent);}
.bn-item:active{background:var(--s3);}
.bn-icon{font-size:20px;line-height:1;}
.bn-label{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;}

.content{padding:16px;flex:1;padding-bottom:calc(var(--nav-h) + 16px + env(safe-area-inset-bottom));}
.panel{display:none;animation:fadeUp .2s ease;}
.panel.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── BUTTONS ────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:10px;font-family:'Familjen Grotesk',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;letter-spacing:.3px;touch-action:manipulation;}
.btn-primary{background:var(--accent);color:#000;}
.btn-primary:hover{background:#4fffa0;}
.btn-primary:active{transform:scale(.97);}
.btn-primary:focus{outline:2px solid var(--accent);outline-offset:2px;}
.btn-primary:disabled{background:var(--s4);color:var(--muted);cursor:not-allowed;}
.btn-secondary{background:var(--s3);color:var(--text);border:1px solid var(--border);}
.btn-secondary:hover,.btn-secondary:focus{background:var(--s4);}
.btn-danger{background:rgba(255,77,106,.1);color:var(--red);border:1px solid rgba(255,77,106,.2);}
.btn-danger:hover{background:rgba(255,77,106,.2);}
.btn-edit{background:rgba(77,159,255,.1);color:var(--blue);border:1px solid rgba(77,159,255,.2);}
.btn-edit:hover{background:rgba(77,159,255,.2);}
.btn-sm{padding:6px 12px;font-size:12px;}
.pagination .btn-sm{min-width:36px;padding:8px 12px;background:#34495e;color:#fff;border-radius:6px;}
.pagination .btn-sm:hover{background:#4a6278;}
.pagination .btn-sm[disabled]{background:#e0e0e0;color:#888;cursor:not-allowed;}
.btn-icon{padding:8px;border-radius:8px;min-width:36px;min-height:36px;justify-content:center;}
.btn-full{width:100%;justify-content:center;}

/* FAB */
.fab{position:fixed;bottom:calc(var(--nav-h) + 16px + env(safe-area-inset-bottom));right:20px;z-index:40;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#000;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(57,224,123,.35);transition:all .2s;border:none;font-family:'Familjen Grotesk',sans-serif;font-weight:700;}
.fab:active{transform:scale(.93);}
.fab.hidden{display:none;}

/* ── STAT CARDS ─────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.stat-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent2),var(--accent));}
.stat-card.blue-top::before{background:linear-gradient(90deg,#2a7fd4,var(--blue));}
.stat-card.amber-top::before{background:linear-gradient(90deg,#c47c08,var(--amber));}
.stat-card.red-top::before{background:linear-gradient(90deg,#c0183a,var(--red));}
.stat-val{font-family:'Bebas Neue',sans-serif;font-size:38px;line-height:1;color:var(--accent);}
.stat-val.amber{color:var(--amber);}
.stat-val.blue{color:var(--blue);}
.stat-val.red{color:var(--red);}
.stat-lbl{font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:2px;text-transform:uppercase;color:#8a94a5;margin-top:4px;line-height:1.4;}
.stat-sub{font-size:11px;color:var(--muted2);margin-top:3px;font-weight:500;}

/* ── SECTION HEADER ─────────────────────────────────── */
.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;margin-top:8px;}
.sec-title{font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:2px;color:var(--muted2);}

/* ── RANKING CARDS ───────────────────────────────────── */
.ranking-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.rank-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:border-color .15s;}
.rank-card:active{background:var(--s3);}
.rank-card.rank-1{border-color:rgba(240,192,32,.3);background:rgba(240,192,32,.04);}
.rank-card.rank-2{border-color:rgba(160,170,187,.15);}
.rank-card.rank-3{border-color:rgba(139,94,60,.25);background:rgba(139,94,60,.03);}
.rc-top{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.rc-medal{font-family:'Bebas Neue',sans-serif;font-size:20px;width:32px;text-align:center;flex-shrink:0;}
.rc-name{font-weight:700;font-size:15px;flex:1;}
.rank-1 .rc-name{color:var(--amber);}
.rc-pts{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--blue);letter-spacing:1px;}
.rc-pts-lbl{font-family:'JetBrains Mono',monospace;font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;text-align:right;}
.rc-stats{display:flex;gap:10px;align-items:center;margin-bottom:8px;flex-wrap:wrap;}
.rc-stat{font-family:'JetBrains Mono',monospace;font-size:11px;}
.rc-stat.wins{color:var(--accent);}
.rc-stat.losses{color:var(--red);}
.rc-stat.played{color:var(--muted2);}
.rc-streak{display:flex;align-items:center;gap:4px;margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:11px;padding:3px 8px;border-radius:20px;}
.rc-streak.streak-w{background:rgba(57,224,123,.1);border:1px solid rgba(57,224,123,.2);color:var(--accent);}
.rc-streak.streak-l{background:rgba(255,77,106,.08);border:1px solid rgba(255,77,106,.15);color:var(--red);}
.rc-streak.streak-none{color:var(--muted);background:var(--s3);border:1px solid var(--border);}
.bar-row{display:flex;align-items:center;gap:8px;}
.bar{flex:1;height:3px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;}
.bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent2),var(--accent));}
.rank-1 .bar-fill{background:linear-gradient(90deg,#c47c08,var(--amber));}
.bar-pct{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted2);flex-shrink:0;min-width:38px;text-align:right;}

/* ── MATCH CARDS ─────────────────────────────────────── */
.match-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.match-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.mc-header{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--s3);border-bottom:1px solid var(--border);}
.mc-game-num{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent);font-weight:500;background:rgba(57,224,123,.1);border:1px solid rgba(57,224,123,.2);padding:2px 7px;border-radius:4px;}
.mc-date{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);flex:1;}
.mc-fmt{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;padding:2px 7px;border-radius:4px;}
.mc-body{padding:12px 14px;}
.mc-teams{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center;margin-bottom:10px;}
.mc-team{font-size:13px;font-weight:500;}
.mc-team.win{color:var(--text);font-weight:700;}
.mc-team.loss{color:var(--muted);text-decoration:line-through;text-decoration-color:rgba(255,77,106,.35);}
.mc-team-a{text-align:right;}
.mc-team-b{text-align:left;}
.mc-vs{font-family:'Bebas Neue',sans-serif;font-size:13px;color:var(--muted);text-align:center;}
.mc-footer{display:flex;align-items:center;gap:8px;}
.mc-winner{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:20px;background:rgba(57,224,123,.08);color:var(--accent);border:1px solid rgba(57,224,123,.18);flex:1;text-align:center;}
.mc-actions{display:flex;gap:5px;}
.fmt-2v2{background:rgba(77,159,255,.12);color:var(--blue);border:1px solid rgba(77,159,255,.2);}
.fmt-2v1{background:rgba(245,166,35,.1);color:var(--amber);border:1px solid rgba(245,166,35,.2);}
.fmt-1v2{background:rgba(255,77,106,.08);color:var(--red);border:1px solid rgba(255,77,106,.15);}
.fmt-1v1{background:rgba(57,224,123,.08);color:var(--accent);border:1px solid rgba(57,224,123,.15);}

/* Day group header for matches */
.day-group{margin-bottom:16px;}
.day-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.day-label{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;color:var(--muted2);}
.day-count{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--muted);background:var(--s3);border:1px solid var(--border);padding:2px 7px;border-radius:4px;}
.day-line{flex:1;height:1px;background:var(--border);}

/* ── PLAYER CARDS ─────────────────────────────────────── */
.player-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.player-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;}
.plr-badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--s4);border:1px solid var(--border);font-family:'Bebas Neue',sans-serif;font-size:14px;color:var(--accent);flex-shrink:0;}
.plr-info{flex:1;min-width:0;}
.plr-name{font-weight:700;font-size:15px;margin-bottom:3px;}
.plr-record{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted2);}
.plr-record span.w{color:var(--accent);}
.plr-record span.l{color:var(--red);}
.plr-actions{display:flex;gap:5px;}

/* ── SETTINGS ─────────────────────────────────────────── */
.settings-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;}
.settings-card-title{font-weight:600;margin-bottom:4px;}
.settings-card-sub{font-size:12px;color:var(--muted2);margin-bottom:12px;line-height:1.5;}
.danger-card{background:rgba(255,77,106,.04);border:1px solid rgba(255,77,106,.15);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;}
.danger-title{font-weight:600;color:var(--text);margin-bottom:2px;}
.danger-text{font-size:12px;color:var(--muted2);margin-bottom:12px;}

/* ── MODALS ──────────────────────────────────────────── */
.overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.75);backdrop-filter:blur(4px);display:none;align-items:flex-end;justify-content:center;padding:0;}
.overlay.open{display:flex;}
@media(min-width:600px){.overlay{align-items:center;padding:20px;}}
.modal{background:var(--s2);border:1px solid var(--border);width:100%;max-width:520px;animation:modalIn .2s ease;overflow:hidden;border-radius:20px 20px 0 0;max-height:92vh;overflow-y:auto;}
@media(min-width:600px){.modal{border-radius:14px;}}
.modal-sm{max-width:380px;}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.modal-handle{width:36px;height:4px;background:var(--s4);border-radius:4px;margin:12px auto 4px;}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 14px;border-bottom:1px solid var(--border);}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;}
.modal-close{width:32px;height:32px;border-radius:8px;background:var(--s3);border:1px solid var(--border);color:var(--muted2);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.modal-close:hover{background:var(--s4);color:var(--text);}
.modal-body{padding:20px;}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;}

/* ── FORM FIELDS ─────────────────────────────────────── */
.field{margin-bottom:14px;}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.field input,.field select,.field input[type="search"]{width:100%;background:var(--s3);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:'Familjen Grotesk',sans-serif;font-size:15px;padding:12px 14px;outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none;}
.field input[type="search"]{background:var(--s2);}
.field input[type="date"]{color-scheme:dark;}
.field input::placeholder{color:var(--muted);}
.field input:focus,.field select:focus{border-color:var(--accent);}
.field select option{background:var(--s3);}
.player-select-area{background:var(--s3);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-wrap:wrap;gap:6px;min-height:50px;transition:border-color .15s;}
.player-select-area.active{border-color:var(--accent);}
.p-chip{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;background:var(--s4);border:1px solid var(--border);color:var(--muted2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;touch-action:manipulation;}
.p-chip:hover{border-color:var(--accent);color:var(--accent);}
.p-chip.selected{background:var(--accent);border-color:var(--accent);color:#000;}
.form-divider{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);text-align:center;display:flex;align-items:center;gap:10px;margin:14px 0;}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--border);}

/* ── MISC ────────────────────────────────────────────── */
.empty{text-align:center;padding:40px 20px;color:var(--muted);}
.empty-icon{font-size:36px;margin-bottom:12px;}
.empty-text{font-size:14px;}
.page-size{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:13px;color:var(--muted);}
.page-size select{padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:var(--s2);color:var(--text);font-size:13px;}
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px;}
.pagination .btn{min-width:32px;padding:6px 8px;font-size:12px;}
.pagination span{font-size:12px;color:var(--muted);padding:0 8px;}
.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:12px;}
.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg)}}
.toast{position:fixed;bottom:calc(var(--nav-h) + 12px);left:50%;transform:translateX(-50%) translateY(80px);z-index:200;background:var(--s3);border:1px solid var(--border);border-radius:10px;padding:11px 18px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none;box-shadow:0 8px 32px rgba(0,0,0,.4);white-space:nowrap;}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
.toast.success{border-color:rgba(57,224,123,.3);color:var(--accent);}
.toast.error{border-color:rgba(255,77,106,.3);color:var(--red);}
.lock-badge{display:inline-flex;align-items:center;gap:5px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:3px 8px;border-radius:4px;background:var(--s3);border:1px solid var(--border);}
.nav-lock{font-size:10px;margin-left:auto;opacity:.5;}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
.shake{animation:shake .35s ease;}

/* ── PODIUM ──────────────────────────────────────────── */
.podium-wrap{display:flex;align-items:flex-end;justify-content:center;gap:0;padding:0 8px;position:relative;margin-bottom:20px;}
.podium-wrap::after{content:'';position:absolute;bottom:0;left:10%;right:10%;height:3px;background:linear-gradient(90deg,transparent,rgba(245,166,35,.15),rgba(57,224,123,.12),rgba(245,166,35,.15),transparent);}
.podium-col{display:flex;flex-direction:column;align-items:center;flex:1;max-width:130px;animation:podiumRise .5s cubic-bezier(.22,1,.36,1) both;}
.podium-col:nth-child(1){animation-delay:.1s;}
.podium-col:nth-child(2){animation-delay:0s;}
.podium-col:nth-child(3){animation-delay:.2s;}
@keyframes podiumRise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.podium-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:17px;position:relative;margin-bottom:7px;transition:transform .2s;}
.podium-col:hover .podium-avatar{transform:scale(1.07);}
.pa-1{background:radial-gradient(circle at 35% 35%,#ffe566,#c47c08);color:#3a2200;box-shadow:0 0 0 3px rgba(245,166,35,.4),0 6px 18px rgba(180,100,0,.3);}
.pa-2{background:radial-gradient(circle at 35% 35%,#d8e0ec,#7a8aa0);color:#1a2030;box-shadow:0 0 0 3px rgba(160,175,200,.3),0 4px 12px rgba(90,110,150,.25);}
.pa-3{background:radial-gradient(circle at 35% 35%,#d4956a,#7a4020);color:#2a1008;box-shadow:0 0 0 3px rgba(176,112,64,.3),0 4px 12px rgba(130,70,30,.25);}
.pa-empty{background:var(--s4);color:var(--muted);}
.podium-crown{position:absolute;top:-15px;left:50%;transform:translateX(-50%);font-size:16px;animation:crownFloat 3s ease-in-out infinite;}
@keyframes crownFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-3px)}}
.podium-name{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:1.5px;text-align:center;line-height:1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 4px;margin-bottom:2px;}
.pn-1{color:var(--amber);font-size:15px;}
.pn-2{color:#b0bcc8;}
.pn-3{color:#b07848;}
.podium-stat{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--muted2);text-align:center;margin-bottom:2px;}
.podium-stat b{color:var(--text);}
.podium-streak{font-family:'JetBrains Mono',monospace;font-size:9px;padding:2px 6px;border-radius:10px;margin-bottom:7px;}
.ps-w{background:rgba(57,224,123,.1);border:1px solid rgba(57,224,123,.2);color:var(--accent);}
.ps-l{background:rgba(255,77,106,.08);border:1px solid rgba(255,77,106,.15);color:var(--red);}
.ps-n{color:var(--muted);}
.podium-block{width:100%;border-radius:10px 10px 0 0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.podium-block::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.07) 0%,transparent 55%);}
.podium-bnum{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:1px;position:relative;z-index:1;}
.pb-1{height:84px;background:linear-gradient(160deg,rgba(245,166,35,.22),rgba(160,90,0,.15));border:1px solid rgba(245,166,35,.3);border-bottom:none;}
.pb-2{height:60px;background:linear-gradient(160deg,rgba(155,170,195,.14),rgba(90,110,145,.1));border:1px solid rgba(140,158,185,.2);border-bottom:none;}
.pb-3{height:44px;background:linear-gradient(160deg,rgba(176,112,64,.18),rgba(110,60,25,.1));border:1px solid rgba(165,100,55,.22);border-bottom:none;}
.pb-empty{height:36px;background:var(--s3);border:1px solid var(--border);border-bottom:none;opacity:.4;}
.pbn-1{color:var(--amber);text-shadow:0 0 14px rgba(245,166,35,.55);}
.pbn-2{color:#a0aabb;text-shadow:0 0 10px rgba(140,158,195,.35);}
.pbn-3{color:#b07040;text-shadow:0 0 10px rgba(176,112,64,.35);}

/* ── DESKTOP OVERRIDES ───────────────────────────────── */
@media(min-width:768px){
  .sidebar{display:flex;}
  .bottom-nav{display:none;}
  .fab{display:none;}
  .content{padding:28px;padding-bottom:28px;}
  .stat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:28px;}
  .stat-val{font-size:44px;}
  .topbar{padding:20px 28px;}
  .page-title{font-size:28px;}
  .toast{bottom:24px;}
  .modal{border-radius:14px;}
  .modal-handle{display:none;}
}

/* ── HEAD-TO-HEAD ─────────────────────────────── */
.h2h-section{margin-bottom:24px;}
.h2h-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.h2h-title{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;color:var(--muted2);}
.h2h-selects{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:end;margin-bottom:12px;}
.h2h-vs{font-family:'Bebas Neue',sans-serif;font-size:16px;color:var(--muted);text-align:center;}
.h2h-results{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;}
.h2h-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;text-align:center;margin-bottom:10px;}
.h2h-stat{background:var(--s3);border-radius:8px;padding:10px;}
.h2h-stat-val{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--accent);}
.h2h-stat-val.p1{color:var(--accent);}
.h2h-stat-val.p2{color:var(--blue);}
.h2h-stat-val.tie{color:var(--amber);}
.h2h-stat-lbl{font-family:'JetBrains Mono',monospace;font-size:8px;text-transform:uppercase;color:var(--muted);letter-spacing:1px;}
.h2h-match-list{display:flex;flex-direction:column;gap:6px;margin-top:12px;max-height:200px;overflow-y:auto;}
.h2h-match{margin:0;padding:8px 10px;background:var(--s3);border-radius:6px;font-size:12px;display:flex;align-items:center;gap:8px;}
.h2h-match .winner{color:var(--accent);font-weight:600;}
.h2h-match .loser{color:var(--muted);}
.h2h-empty{text-align:center;padding:20px;color:var(--muted);font-size:13px;}

/* ── TREND CHART ────────────────────────────── */
.trend-chart-wrap{background:var(--s2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-top:10px;}
.trend-chart-title{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:8px;}
.trend-canvas{width:100%;height:80px;}

/* ── FRAME SCORE ────────────────────────────── */
.mc-frames{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;text-align:center;color:var(--text);}
.mc-frames .fa{color:var(--accent);}
.mc-frames .fb{color:var(--blue);}
.mc-break-badge{display:inline-flex;align-items:center;gap:4px;font-family:'JetBrains Mono',monospace;font-size:10px;padding:2px 8px;border-radius:12px;background:rgba(240,192,32,.1);border:1px solid rgba(240,192,32,.2);color:var(--ball-yellow);}
.mc-break-badge.century{background:rgba(255,77,106,.12);border-color:rgba(255,77,106,.25);color:var(--red);}

/* ── HANDICAP BADGE ─────────────────────────── */
.handicap-badge{display:inline-flex;align-items:center;gap:4px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;padding:2px 7px;border-radius:10px;background:rgba(77,159,255,.1);border:1px solid rgba(77,159,255,.2);color:var(--blue);}

/* ── SNOOKER BALL LEGEND ────────────────────── */
.ball-dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle;margin-right:4px;box-shadow:inset -2px -2px 4px rgba(0,0,0,.4);}
.ball-red{background:var(--ball-red);}
.ball-yellow{background:var(--ball-yellow);}
.ball-green{background:var(--ball-green);}
.ball-brown{background:var(--ball-brown);}
.ball-blue{background:var(--ball-blue);}
.ball-pink{background:var(--ball-pink);}
.ball-black{background:#333;border:1px solid #555;}

/* ── STREAK BANNER (realtime) ───────────────── */
.streak-banner{position:fixed;top:0;left:0;right:0;z-index:300;background:linear-gradient(90deg,rgba(57,224,123,.18),rgba(255,154,60,.15),rgba(57,224,123,.18));border-bottom:1px solid rgba(57,224,123,.3);padding:10px 20px;text-align:center;font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;color:var(--accent);transform:translateY(-100%);transition:transform .4s cubic-bezier(.34,1.56,.64,1);}
.streak-banner.show{transform:translateY(0);}

/* ── ELO BADGE ──────────────────────────────── */
.elo-badge{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;padding:2px 7px;border-radius:10px;background:rgba(77,159,255,.1);border:1px solid rgba(77,159,255,.2);color:var(--blue);}
.elo-badge.top{background:rgba(57,224,123,.1);border-color:rgba(57,224,123,.2);color:var(--accent);}

/* ── FRAME WIN RATE ─────────────────────────── */
.fwr-badge{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:1px;padding:2px 7px;border-radius:10px;background:rgba(245,166,35,.1);border:1px solid rgba(245,166,35,.2);color:var(--amber);}

/* ── RANKING FILTER ─────────────────────────── */
.rank-filter-wrap{display:flex;gap:2px;background:var(--s3);padding:4px;border-radius:10px;margin-bottom:14px;width:100%;max-width:280px}
.rank-filter-btn{flex:1;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.5px;padding:10px 8px;border-radius:8px;border:none;background:transparent;color:var(--muted2);cursor:pointer;transition:all .15s;font-weight:500;}
.rank-filter-btn:hover{color:var(--text);}
.rank-filter-btn.active{background:var(--accent);color:#000;font-weight:600;}
@media(min-width:768px){
  .rank-filter-wrap{max-width:220px;gap:3px;padding:4px;}
  .rank-filter-btn{font-size:10px;padding:8px 10px;}
}

/* ── SECURITY NOTICE ─────────────────────────── */
.security-notice{background:rgba(255,154,60,.08);border:1px solid rgba(255,154,60,.25);border-radius:10px;padding:12px 14px;margin-bottom:14px;font-size:12px;color:#ffa830;line-height:1.6;}
.security-notice strong{display:block;margin-bottom:4px;font-size:13px;}

/* ── PLAYER HISTORY MODAL ───────────────────── */
.ph-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;}
.ph-stat{background:var(--s3);border-radius:8px;padding:10px;text-align:center;}
.ph-stat-val{font-family:'Bebas Neue',sans-serif;font-size:24px;line-height:1;}
.ph-stat-lbl{font-family:'JetBrains Mono',monospace;font-size:8px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-top:2px;}
.ph-match-list{display:flex;flex-direction:column;gap:6px;max-height:55vh;overflow-y:auto;}
.ph-match{background:var(--s3);border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:8px;font-size:12px;}
.ph-match.win{border-left:2px solid var(--accent);}
.ph-match.loss{border-left:2px solid var(--red);}
.ph-match-result{font-family:'Bebas Neue',sans-serif;font-size:14px;width:24px;flex-shrink:0;}
.ph-match-result.w{color:var(--accent);}
.ph-match-result.l{color:var(--red);}
.ph-match-opp{flex:1;color:var(--muted2);}
.ph-match-score{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);flex-shrink:0;}
