:root{--bg:#f7f9fc;--bg2:#ffffff;--bg3:#eef4ff;--card:#ffffff;--border:#d9e2f0;--accent:#00a884;--accent2:#6d5dfc;--text:#1f2937;--muted:#6b7280;--ready:#00a884;--playing:#d97706;--rest:#6366f1;--out:#dc2626;--teamA:#2563eb;--teamB:#e11d48;--radius:14px;--radius-sm:9px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:'Noto Sans Thai',sans-serif;background:linear-gradient(180deg,#eef7ff 0%,#f7f9fc 42%,#ffffff 100%);color:var(--text);min-height:100vh;font-size:15px;line-height:1.6}.topbar{background:rgba(26,26,46,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:58px;position:sticky;top:0;z-index:100}.topbar-logo{font-size:18px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.topbar-logo span{color:var(--text)}.sync-dot{width:9px;height:9px;border-radius:50%;background:var(--out);box-shadow:0 0 0 4px rgba(239,68,68,.12)}.sync-dot.ok{background:var(--accent);box-shadow:0 0 0 4px rgba(0,212,170,.12)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:rgba(26,26,46,.96);backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;z-index:100}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px 14px;background:none;border:none;color:var(--muted);font-size:10px;font-family:inherit;cursor:pointer;transition:.15s}.nav-btn svg{width:22px;height:22px}.nav-btn.active{color:var(--accent)}.page{display:none;padding:16px 16px 100px}.page.active{display:block}.card{background:rgba(30,30,53,.96);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:0 16px 40px rgba(0,0,0,.16)}.card-title{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 18px;border-radius:var(--radius-sm);border:none;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;width:100%;text-decoration:none}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#0f0f1a}.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.btn-danger{background:#ef4444;color:#fff}.btn-warning{background:var(--playing);color:#0f0f1a}.btn-sm{padding:7px 12px;font-size:13px;width:auto;border-radius:7px}.btn-group{display:flex;gap:8px}.btn-group .btn{flex:1}.form-group{margin-bottom:12px}.form-label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:600}input[type=text],input[type=number],input[type=password],select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:15px;padding:11px 14px;outline:none;transition:.15s}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,212,170,.08)}select option{background:var(--bg2)}.help{font-size:12px;color:var(--muted);margin-top:7px}.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.player-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);gap:12px}.player-row:last-child{border-bottom:none}.player-avatar{width:42px;height:42px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:var(--accent);flex-shrink:0}.player-info{flex:1;min-width:0}.player-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-meta{font-size:12px;color:var(--muted);margin-top:2px}.court-card{background:rgba(30,30,53,.96);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.court-header{background:var(--bg3);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.court-num{font-weight:800;font-size:14px;color:var(--accent);letter-spacing:.5px}.court-body{padding:16px}.teams-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}.team-col{display:flex;flex-direction:column;gap:6px;width:100%;min-width:0}.team-label{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;width:100%}.team-a .team-label{color:var(--teamA)}.team-b .team-label{color:var(--teamB)}.player-chip{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:13px;font-weight:600;text-align:center;min-height:39px;width:100%;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vs-divider{font-weight:900;font-size:18px;color:var(--muted);text-align:center}.score-row{display:flex;gap:8px;margin-top:14px;align-items:center}.score-input{flex:1;text-align:center;font-size:22px;font-weight:800;padding:10px}.score-sep{color:var(--muted);font-size:20px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.stat-card{background:rgba(30,30,53,.96);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center}.stat-num{font-size:28px;font-weight:900;color:var(--accent)}.stat-label{font-size:12px;color:var(--muted);margin-top:2px}.match-row{padding:12px 0;border-bottom:1px solid var(--border)}.match-row:last-child{border-bottom:none}.match-teams{font-size:13px;color:var(--text);margin-bottom:4px}.match-score{font-size:18px;font-weight:900}.match-score .winner{color:var(--accent)}.match-time{font-size:11px;color:var(--muted);margin-top:3px}.section-heading{font-size:18px;font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:8px}.court-selector{display:flex;gap:8px;margin-bottom:16px}.court-opt{flex:1;padding:10px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--card);color:var(--muted);font-family:inherit;font-size:15px;font-weight:800;cursor:pointer;text-align:center}.court-opt.active{border-color:var(--accent);color:var(--accent);background:rgba(0,212,170,.08)}.toast{position:fixed;bottom:92px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--card);border:1px solid var(--border);border-radius:24px;padding:10px 20px;font-size:14px;font-weight:600;opacity:0;pointer-events:none;transition:all .25s;white-space:nowrap;z-index:200;max-width:92vw;overflow:hidden;text-overflow:ellipsis}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.toast.success{border-color:var(--accent);color:var(--accent)}.toast.error{border-color:var(--out);color:var(--out)}.empty{text-align:center;padding:36px 20px;color:var(--muted)}.empty-icon{font-size:40px;margin-bottom:12px}.empty p{font-size:14px}.status-select{padding:5px 10px;border-radius:20px;border:1.5px solid var(--border);font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;background:var(--bg3);outline:none;appearance:none;text-align:center;min-width:90px}.sel-ready{border-color:var(--ready);color:var(--ready);background:rgba(0,212,170,.08)}.sel-playing{border-color:var(--playing);color:var(--playing);background:rgba(245,158,11,.08)}.sel-rest{border-color:var(--rest);color:var(--rest);background:rgba(99,102,241,.08)}.sel-out{border-color:var(--out);color:var(--out);background:rgba(239,68,68,.08)}.btn-reset{background:rgba(239,68,68,.1);color:var(--out);border:1.5px solid rgba(239,68,68,.3)}.skill-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:2px}.lb-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:12px}.lb-row:last-child{border-bottom:none}.lb-rank{font-size:16px;font-weight:900;color:var(--muted);width:28px}.lb-rank.gold{color:#f59e0b}.lb-rank.silver{color:#94a3b8}.lb-rank.bronze{color:#cd7c3e}.lb-games{margin-left:auto;font-weight:900;color:var(--accent);font-size:16px}.lb-games small{font-size:11px;color:var(--muted);font-weight:400}.lb-row-late .player-meta{padding-right:4px}.court-live-badge{background:rgba(245,158,11,.15);color:var(--playing);font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px;letter-spacing:.5px}.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:4px 10px;color:var(--muted);font-size:12px}.hidden{display:none!important}@media(min-width:520px){.page{max-width:520px;margin:0 auto}.topbar{justify-content:center}.sync-dot{position:absolute;right:18px}.bottom-nav{max-width:520px;left:50%;transform:translateX(-50%)}}

@keyframes spin{to{transform:rotate(360deg)}}

/* Match history actions */
.match-main{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.match-detail{flex:1;min-width:0}.match-delete-btn{flex-shrink:0;background:rgba(239,68,68,.1);color:var(--out);border:1px solid rgba(239,68,68,.35);border-radius:999px;padding:5px 10px;font-family:inherit;font-size:12px;font-weight:800;cursor:pointer}.match-delete-btn:active{transform:scale(.96)}


/* Player actions */
.player-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.icon-btn-delete{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;transition:all .15s}
.icon-btn-delete svg{width:16px;height:16px;stroke:currentColor}
.icon-btn-delete:hover{background:rgba(239,68,68,.12);color:var(--out)}
.icon-btn-delete:active{transform:scale(.94)}


/* Locked player controls */
.player-row-locked{opacity:.86}
.player-lock-hint{font-size:10px;color:var(--playing);line-height:1;white-space:nowrap}
.status-locked{cursor:not-allowed;filter:saturate(.75);opacity:.82}
.icon-btn-locked{cursor:not-allowed;color:#555a78}
.icon-btn-locked:hover{background:rgba(245,158,11,.1);color:var(--playing)}


/* Collapsible add-player section */
.add-player-card{padding:0;overflow:hidden}
.collapse-toggle{
  width:100%;
  padding:14px 16px;
  background:transparent;
  border:0;
  color:var(--accent);
  font-family:inherit;
  font-size:15px;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:pointer;
}
.collapse-toggle:active{transform:scale(.99)}
.collapse-chevron{
  width:26px;
  height:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(0,212,170,.08);
  color:var(--accent);
}
.collapse-content{
  display:none;
  padding:0 16px 16px;
  border-top:1px solid rgba(42,42,74,.7);
}
.collapse-content.open{display:block}

/* Softer reset button */
.btn-reset{
  background:rgba(136,136,170,.07)!important;
  color:var(--muted)!important;
  border:1px solid rgba(136,136,170,.18)!important;
  font-size:13px;
  font-weight:700;
  padding:10px 14px;
}
.btn-reset:hover{
  background:rgba(239,68,68,.08)!important;
  color:#fca5a5!important;
  border-color:rgba(239,68,68,.18)!important;
}


/* GitHub Pages fix: collapsible add player must be a styled button, not native-looking */
.add-player-card{padding:0!important;overflow:hidden}
.collapse-toggle{
  appearance:none;-webkit-appearance:none;
  width:100%;padding:14px 16px;background:transparent;border:0;
  color:var(--accent);font-family:'Noto Sans Thai',sans-serif;font-size:15px;font-weight:800;
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left;
}
.collapse-toggle span:first-child{display:inline-flex;align-items:center;gap:6px}
.collapse-chevron{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(0,212,170,.08);color:var(--accent)}
.collapse-content{display:none!important;padding:0 16px 16px;border-top:1px solid rgba(42,42,74,.7)}
.collapse-content.open{display:block!important}
.btn-reset{background:rgba(136,136,170,.07)!important;color:var(--muted)!important;border:1px solid rgba(136,136,170,.18)!important;font-size:13px;font-weight:700;padding:10px 14px}
.btn-reset:hover{background:rgba(239,68,68,.08)!important;color:#fca5a5!important;border-color:rgba(239,68,68,.18)!important}



/* Light mode polish */
.topbar{
  background:rgba(255,255,255,.92)!important;
  border-bottom:1px solid var(--border)!important;
  box-shadow:0 8px 24px rgba(31,41,55,.06);
}
.bottom-nav{
  background:rgba(255,255,255,.96)!important;
  border-top:1px solid var(--border)!important;
  box-shadow:0 -10px 28px rgba(31,41,55,.08);
}
.card,
.court-card,
.stat-card{
  background:rgba(255,255,255,.96)!important;
  border:1px solid var(--border)!important;
  box-shadow:0 14px 36px rgba(31,41,55,.08)!important;
}
.court-header{
  background:#eef4ff!important;
  border-bottom:1px solid var(--border)!important;
}
.player-avatar,
.player-chip,
input[type=text],
input[type=number],
input[type=password],
select,
.btn-secondary{
  background:#f3f7ff!important;
  border-color:#d9e2f0!important;
}
input[type=text],
input[type=number],
input[type=password],
select{
  color:var(--text)!important;
}
input::placeholder{color:#94a3b8!important}
.btn-primary{background:var(--accent)!important;color:#ffffff!important}
.btn-primary:hover{background:#008f72!important}
.sync-dot{box-shadow:0 0 0 4px rgba(220,38,38,.10)!important}
.sync-dot.ok{box-shadow:0 0 0 4px rgba(0,168,132,.12)!important}
.toast{
  background:#ffffff!important;
  box-shadow:0 12px 32px rgba(31,41,55,.12);
}
.collapse-chevron{background:rgba(0,168,132,.10)!important}
.collapse-content{border-top:1px solid rgba(217,226,240,.95)!important}
.court-opt{
  background:#ffffff!important;
  border-color:#d9e2f0!important;
}
.court-opt.active{
  background:rgba(0,168,132,.08)!important;
  border-color:var(--accent)!important;
}
.player-row,
.match-row,
.lb-row{border-bottom-color:#e5edf7!important}
.score-sep,
.vs-divider{color:#94a3b8!important}
.btn-reset{
  background:rgba(107,114,128,.06)!important;
  color:#6b7280!important;
  border-color:rgba(107,114,128,.16)!important;
}
.btn-reset:hover{
  background:rgba(220,38,38,.06)!important;
  color:#dc2626!important;
  border-color:rgba(220,38,38,.16)!important;
}
.status-select{background:#f8fbff!important}
.sel-ready{background:rgba(0,168,132,.08)!important}
.sel-playing{background:rgba(217,119,6,.08)!important}
.sel-rest{background:rgba(99,102,241,.08)!important}
.sel-out{background:rgba(220,38,38,.08)!important}
.icon-btn-delete:hover{background:rgba(220,38,38,.08)!important}
.match-delete-btn{background:rgba(220,38,38,.06)!important}
#loading{background:rgba(247,249,252,.82)!important}



/* Theme toggle + refined themes */
html[data-theme="light"]{
  --bg:#fbfaf7;
  --bg2:#ffffff;
  --bg3:#f3f6fb;
  --card:#ffffff;
  --border:#e2e8f0;
  --accent:#11b89a;
  --accent2:#8b7cf6;
  --text:#28313f;
  --muted:#7d8491;
  --ready:#11b89a;
  --playing:#e59b22;
  --rest:#7c83ee;
  --out:#dc5b5b;
  --teamA:#4f7fdf;
  --teamB:#e05275;
}

html[data-theme="dark"]{
  --bg:#0f0f1a;
  --bg2:#1a1a2e;
  --bg3:#16213e;
  --card:#1e1e35;
  --border:#2a2a4a;
  --accent:#00d4aa;
  --accent2:#7c3aed;
  --text:#e8e8f0;
  --muted:#8888aa;
  --ready:#00d4aa;
  --playing:#f59e0b;
  --rest:#6366f1;
  --out:#ef4444;
  --teamA:#3b82f6;
  --teamB:#f43f5e;
}

html[data-theme="light"] body{
  background:
    radial-gradient(circle at top left, rgba(209,241,235,.95) 0, rgba(209,241,235,0) 36%),
    linear-gradient(180deg,#fffaf0 0%,#f8fbff 48%,#ffffff 100%)!important;
}

html[data-theme="dark"] body{
  background:radial-gradient(circle at top,#16213e 0,#0f0f1a 42%)!important;
}

.theme-toggle{
  position:absolute;
  left:14px;
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:16px;
  box-shadow:0 8px 24px rgba(31,41,55,.08);
}
.theme-toggle:active{transform:scale(.96)}

html[data-theme="light"] .topbar,
html[data-theme="light"] .bottom-nav{
  background:rgba(255,255,255,.88)!important;
  border-color:rgba(226,232,240,.92)!important;
  box-shadow:0 8px 24px rgba(70,76,90,.07);
}

html[data-theme="dark"] .topbar,
html[data-theme="dark"] .bottom-nav{
  background:rgba(26,26,46,.96)!important;
  border-color:var(--border)!important;
  box-shadow:none;
}

html[data-theme="light"] .card,
html[data-theme="light"] .court-card,
html[data-theme="light"] .stat-card{
  background:rgba(255,255,255,.88)!important;
  border-color:rgba(226,232,240,.95)!important;
  box-shadow:0 14px 34px rgba(70,76,90,.08)!important;
}

html[data-theme="dark"] .card,
html[data-theme="dark"] .court-card,
html[data-theme="dark"] .stat-card{
  background:rgba(30,30,53,.96)!important;
  border-color:var(--border)!important;
  box-shadow:0 16px 40px rgba(0,0,0,.16)!important;
}

html[data-theme="light"] .court-header{
  background:#f2f7fb!important;
  border-color:#e2e8f0!important;
}
html[data-theme="dark"] .court-header{
  background:var(--bg3)!important;
  border-color:var(--border)!important;
}

html[data-theme="light"] .player-avatar,
html[data-theme="light"] .player-chip,
html[data-theme="light"] input[type=text],
html[data-theme="light"] input[type=number],
html[data-theme="light"] input[type=password],
html[data-theme="light"] select,
html[data-theme="light"] .btn-secondary{
  background:#f7f8fb!important;
  border-color:#e2e8f0!important;
  color:var(--text)!important;
}

html[data-theme="dark"] .player-avatar,
html[data-theme="dark"] .player-chip,
html[data-theme="dark"] input[type=text],
html[data-theme="dark"] input[type=number],
html[data-theme="dark"] input[type=password],
html[data-theme="dark"] select,
html[data-theme="dark"] .btn-secondary{
  background:var(--bg3)!important;
  border-color:var(--border)!important;
  color:var(--text)!important;
}

html[data-theme="light"] .btn-primary{
  background:linear-gradient(135deg,#18c5a8,#0ea889)!important;
  color:#fff!important;
}
html[data-theme="dark"] .btn-primary{
  background:var(--accent)!important;
  color:#0f0f1a!important;
}

html[data-theme="light"] .court-opt{
  background:rgba(255,255,255,.75)!important;
  border-color:#e2e8f0!important;
}
html[data-theme="dark"] .court-opt{
  background:var(--card)!important;
  border-color:var(--border)!important;
}

html[data-theme="light"] .court-opt.active{
  background:rgba(17,184,154,.08)!important;
  border-color:var(--accent)!important;
}
html[data-theme="dark"] .court-opt.active{
  background:rgba(0,212,170,.08)!important;
  border-color:var(--accent)!important;
}

html[data-theme="light"] .player-row,
html[data-theme="light"] .match-row,
html[data-theme="light"] .lb-row{
  border-bottom-color:#edf2f7!important;
}
html[data-theme="dark"] .player-row,
html[data-theme="dark"] .match-row,
html[data-theme="dark"] .lb-row{
  border-bottom-color:var(--border)!important;
}

html[data-theme="light"] .toast{
  background:#fff!important;
  color:var(--text);
  box-shadow:0 14px 34px rgba(70,76,90,.13);
}
html[data-theme="dark"] .toast{
  background:var(--card)!important;
  box-shadow:none;
}

html[data-theme="light"] .collapse-chevron{
  background:rgba(17,184,154,.10)!important;
}
html[data-theme="dark"] .collapse-chevron{
  background:rgba(0,212,170,.08)!important;
}

html[data-theme="light"] .btn-reset{
  background:rgba(125,132,145,.06)!important;
  color:var(--muted)!important;
  border-color:rgba(125,132,145,.16)!important;
}
html[data-theme="dark"] .btn-reset{
  background:rgba(136,136,170,.07)!important;
  color:var(--muted)!important;
  border-color:rgba(136,136,170,.18)!important;
}

html[data-theme="light"] input::placeholder{color:#a4a8b0!important}
html[data-theme="dark"] input::placeholder{color:#8888aa!important}

html[data-theme="light"] #loading{background:rgba(251,250,247,.82)!important}
html[data-theme="dark"] #loading{background:rgba(15,15,26,.82)!important}



/* Court shuffle action */
.court-header-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.court-icon-btn{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.55);
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:15px;
  transition:all .15s;
}
.court-icon-btn:hover{
  color:var(--accent);
  border-color:rgba(17,184,154,.45);
  background:rgba(17,184,154,.08);
}
.court-icon-btn:active{transform:scale(.94)}
html[data-theme="dark"] .court-icon-btn{
  background:rgba(22,33,62,.86);
  border-color:var(--border);
}
html[data-theme="dark"] .court-icon-btn:hover{
  background:rgba(0,212,170,.10);
  border-color:rgba(0,212,170,.35);
}



/* Minimal icon refinement */
.theme-toggle svg,
.court-icon-btn svg{
  width:17px;
  height:17px;
}
.collapse-chevron{
  width:22px;
  height:22px;
  background:transparent!important;
  position:relative;
}
.collapse-chevron::before,
.collapse-chevron::after{
  content:"";
  position:absolute;
  top:10px;
  width:8px;
  height:1.7px;
  background:currentColor;
  border-radius:999px;
  transition:transform .18s ease;
}
.collapse-chevron::before{left:4px;transform:rotate(40deg)}
.collapse-chevron::after{right:4px;transform:rotate(-40deg)}
.collapse-toggle.open .collapse-chevron::before{transform:rotate(-40deg)}
.collapse-toggle.open .collapse-chevron::after{transform:rotate(40deg)}

.empty-icon{
  width:34px;
  height:34px;
  margin:0 auto 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.15));
  position:relative;
}
.empty-icon::before{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:999px;
  border:1.4px solid var(--border);
  opacity:.9;
}

.nav-btn svg{
  width:20px;
  height:20px;
}
.nav-btn{
  gap:4px;
}
.topbar-logo{
  font-weight:700;
  letter-spacing:-.2px;
}
.topbar-logo span{
  color:inherit;
}
.btn-primary,
.btn-secondary,
.btn-reset,
.status-select,
.court-opt,
.player-chip,
.player-avatar{
  box-shadow:none!important;
}
.card-title{
  font-weight:600;
  letter-spacing:.55px;
}
.court-live-badge{
  letter-spacing:.2px;
}



/* Remove hard divider line in add-player expanded panel */
.collapse-content{
  border-top:0!important;
  padding-top:2px!important;
}
.add-player-card .collapse-toggle{
  padding-bottom:12px;
}
.add-player-card .collapse-content.open{
  padding-top:0!important;
}



/* Mobile topbar layout fix */
.topbar{
  height:64px!important;
  padding:0 14px!important;
  display:grid!important;
  grid-template-columns:40px minmax(0,1fr) 24px!important;
  align-items:center!important;
  gap:12px!important;
  justify-content:initial!important;
}

.theme-toggle{
  position:static!important;
  width:40px!important;
  height:40px!important;
  border-radius:999px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  justify-self:start!important;
  flex-shrink:0!important;
}

.topbar-logo{
  min-width:0!important;
  text-align:center!important;
  font-weight:700!important;
  font-size:16px!important;
  line-height:1.2!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

.sync-dot{
  position:static!important;
  justify-self:end!important;
  flex-shrink:0!important;
}

@media (max-width:480px){
  .topbar{
    padding:0 12px!important;
    gap:10px!important;
    grid-template-columns:38px minmax(0,1fr) 22px!important;
  }

  .theme-toggle{
    width:38px!important;
    height:38px!important;
  }

  .topbar-logo{
    font-size:15px!important;
  }
}

@media (min-width:520px){
  .topbar{
    grid-template-columns:40px minmax(0,1fr) 24px!important;
  }

  .sync-dot{
    position:static!important;
    right:auto!important;
  }
}



/* End game button: soft orange, separated from start button */
.score-row + .btn-group .btn-primary:first-child{
  background:linear-gradient(135deg,#f6b85f,#f59e0b)!important;
  color:#fff!important;
  border:1px solid rgba(245,158,11,.28)!important;
}

.score-row + .btn-group .btn-primary:first-child:hover{
  background:linear-gradient(135deg,#f4aa43,#e58c00)!important;
}

html[data-theme="light"] .score-row + .btn-group .btn-primary:first-child{
  background:linear-gradient(135deg,#f8c77d,#f0a93a)!important;
  color:#5a3300!important;
  border:1px solid rgba(240,169,58,.28)!important;
}

html[data-theme="light"] .score-row + .btn-group .btn-primary:first-child:hover{
  background:linear-gradient(135deg,#f5bc67,#e99a23)!important;
}



/* Player lock status labels */
.player-lock-hint{
  font-size:10.5px;
  line-height:1.15;
  white-space:nowrap;
  font-weight:700;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid transparent;
}

.player-lock-hint.lock-playing{
  color:#b45309;
  background:rgba(245,158,11,.13);
  border-color:rgba(245,158,11,.22);
}

.player-lock-hint.lock-queued{
  color:#2563eb;
  background:rgba(59,130,246,.10);
  border-color:rgba(59,130,246,.18);
}

html[data-theme="dark"] .player-lock-hint.lock-playing{
  color:#fbbf24;
  background:rgba(245,158,11,.16);
  border-color:rgba(245,158,11,.28);
}

html[data-theme="dark"] .player-lock-hint.lock-queued{
  color:#93c5fd;
  background:rgba(59,130,246,.16);
  border-color:rgba(59,130,246,.28);
}



/* Disabled look for players marked as out */
.player-row-out{
  opacity:.48;
  filter:saturate(.45);
}

.player-row-out .player-avatar{
  color:var(--muted)!important;
  border-color:rgba(125,132,145,.25)!important;
}

.player-row-out .player-name,
.player-row-out .player-meta{
  color:var(--muted)!important;
}

.player-row-out .status-select{
  opacity:.85;
}

.player-row-out .icon-btn-delete{
  opacity:.55;
}

html[data-theme="dark"] .player-row-out{
  opacity:.42;
}



/* Reset guard */
.btn-reset.is-disabled,
.btn-reset:disabled{
  opacity:.45!important;
  cursor:not-allowed!important;
  filter:saturate(.6);
}
.btn-reset.is-disabled:hover,
.btn-reset:disabled:hover{
  background:rgba(125,132,145,.06)!important;
  color:var(--muted)!important;
  border-color:rgba(125,132,145,.16)!important;
}



/* Stats dashboard */
.stats-dashboard-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.dashboard-title{
  font-size:22px;
  font-weight:800;
  letter-spacing:-.5px;
}
.dashboard-subtitle{
  font-size:12px;
  color:var(--muted);
  margin-top:2px;
}
.dashboard-refresh{
  width:auto;
  flex-shrink:0;
}
.dashboard-summary{
  grid-template-columns:1fr 1fr;
  margin-bottom:14px;
}
.stats-tabs{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  background:rgba(125,132,145,.08);
  border:1px solid rgba(125,132,145,.12);
  padding:5px;
  border-radius:999px;
  margin-bottom:14px;
}
.stats-tab{
  border:0;
  background:transparent;
  color:var(--muted);
  font-family:inherit;
  font-size:13px;
  font-weight:700;
  padding:9px 10px;
  border-radius:999px;
  cursor:pointer;
  transition:all .15s;
}
.stats-tab.active{
  color:var(--text);
  background:var(--card);
  box-shadow:0 8px 18px rgba(70,76,90,.08);
}
.stats-panel{
  display:none;
}
.stats-panel.active{
  display:block;
}
.status-breakdown{
  display:grid;
  gap:10px;
}
.status-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 0;
  border-bottom:1px solid rgba(125,132,145,.13);
}
.status-item:last-child{
  border-bottom:0;
}
.status-item span:nth-child(2){
  flex:1;
  color:var(--text);
  font-size:14px;
  font-weight:600;
}
.status-item strong{
  font-size:16px;
  color:var(--text);
}
.status-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  flex-shrink:0;
}
.dot-ready{background:var(--ready)}
.dot-playing{background:var(--playing)}
.dot-rest{background:var(--rest)}
.dot-out{background:var(--out)}
.mini-rank-row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 0;
  border-bottom:1px solid rgba(125,132,145,.13);
}
.mini-rank-row:last-child{
  border-bottom:0;
}
.mini-rank-num{
  width:28px;
  height:28px;
  border-radius:999px;
  background:rgba(17,184,154,.10);
  color:var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:13px;
}
.mini-rank-name{
  flex:1;
  min-width:0;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.mini-rank-games{
  color:var(--accent);
  font-weight:800;
  font-size:14px;
}
html[data-theme="dark"] .stats-tabs{
  background:rgba(22,33,62,.55);
  border-color:var(--border);
}
html[data-theme="dark"] .stats-tab.active{
  background:var(--bg3);
  box-shadow:none;
}
@media(max-width:380px){
  .dashboard-title{font-size:20px}
  .stats-tab{font-size:12px;padding:8px 6px}
}


/* Secret expense calculator */
.secret-expense-btn{
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .15s;
  flex-shrink:0;
}
.secret-expense-btn svg{
  width:17px;
  height:17px;
}
.secret-expense-btn:hover{
  color:var(--accent);
  border-color:rgba(17,184,154,.35);
  background:rgba(17,184,154,.08);
}
.secret-expense-btn:active{transform:scale(.95)}
.expense-header{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.icon-back-btn{
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex-shrink:0;
}
.icon-back-btn svg{
  width:18px;
  height:18px;
}
.icon-back-btn:hover{
  color:var(--accent);
  background:rgba(17,184,154,.08);
}
.expense-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.expense-full{
  grid-column:1 / -1;
}
.expense-help{
  margin-bottom:12px;
}
.expense-owner-list{
  display:grid;
  gap:8px;
}
.expense-owner-row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.expense-owner-row:last-child{
  border-bottom:0;
}
.expense-owner-name{
  flex:1;
  min-width:0;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.expense-owner-input{
  width:90px!important;
  text-align:center;
}
.expense-total-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-bottom:14px;
}
.expense-total-grid div{
  background:rgba(125,132,145,.07);
  border:1px solid rgba(125,132,145,.12);
  border-radius:12px;
  padding:12px;
}
.expense-total-grid span{
  display:block;
  font-size:11px;
  color:var(--muted);
  margin-bottom:4px;
}
.expense-total-grid strong{
  font-size:18px;
  color:var(--text);
}
.expense-warning{
  background:rgba(245,158,11,.11);
  color:#b45309;
  border:1px solid rgba(245,158,11,.22);
  border-radius:12px;
  padding:10px 12px;
  font-size:12px;
  font-weight:700;
  margin-bottom:12px;
}
.expense-result-list{
  display:grid;
  gap:8px;
}
.expense-result-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:11px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.expense-result-row:last-child{
  border-bottom:0;
}
.expense-result-name{
  min-width:0;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.expense-result-detail{
  text-align:right;
  flex-shrink:0;
}
.expense-result-detail span{
  display:block;
  font-size:11px;
  color:var(--muted);
}
.expense-result-detail strong{
  font-size:15px;
}
.expense-result-row.pay strong{
  color:var(--out);
}
.expense-result-row.receive strong{
  color:var(--ready);
}
.expense-result-row.clear strong{
  color:var(--muted);
}
html[data-theme="dark"] .secret-expense-btn,
html[data-theme="dark"] .icon-back-btn{
  background:var(--bg3);
}
html[data-theme="dark"] .expense-total-grid div{
  background:rgba(22,33,62,.55);
  border-color:var(--border);
}
html[data-theme="dark"] .expense-warning{
  color:#fbbf24;
}
@media(max-width:420px){
  .expense-form-grid{
    grid-template-columns:1fr;
  }
  .expense-total-grid{
    grid-template-columns:1fr;
  }
}



/* Variable shuttle price per owner */
.expense-owner-inputs{
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}
.expense-owner-inputs .expense-owner-input{
  width:82px!important;
}
.expense-result-name small{
  display:block;
  margin-top:2px;
  color:var(--muted);
  font-size:10.5px;
  font-weight:600;
}
@media(max-width:420px){
  .expense-owner-row{
    align-items:flex-start;
    flex-direction:column;
    gap:8px;
  }
  .expense-owner-inputs{
    width:100%;
  }
  .expense-owner-inputs .expense-owner-input{
    flex:1;
    width:100%!important;
  }
}



/* Modern dark mode refresh */
html[data-theme="dark"]{
  --bg:#080b14;
  --bg2:#0d1322;
  --bg3:#111a2e;
  --card:#121a2b;
  --border:#243047;
  --accent:#2dd4bf;
  --accent2:#8b5cf6;
  --text:#e6edf7;
  --muted:#8b98ad;
  --ready:#2dd4bf;
  --playing:#f6b35f;
  --rest:#8b8cff;
  --out:#fb7185;
  --teamA:#60a5fa;
  --teamB:#fb7185;
}

html[data-theme="dark"] body{
  background:
    radial-gradient(circle at 16% -10%, rgba(45,212,191,.18) 0, rgba(45,212,191,0) 32%),
    radial-gradient(circle at 92% 8%, rgba(139,92,246,.16) 0, rgba(139,92,246,0) 34%),
    linear-gradient(180deg,#080b14 0%,#0b1020 48%,#080b14 100%)!important;
  color:var(--text)!important;
}

html[data-theme="dark"] .topbar{
  background:rgba(13,19,34,.78)!important;
  border-bottom:1px solid rgba(148,163,184,.14)!important;
  box-shadow:0 12px 32px rgba(0,0,0,.18)!important;
  backdrop-filter:blur(18px);
}

html[data-theme="dark"] .bottom-nav{
  background:rgba(13,19,34,.82)!important;
  border-top:1px solid rgba(148,163,184,.14)!important;
  box-shadow:0 -12px 34px rgba(0,0,0,.2)!important;
  backdrop-filter:blur(18px);
}

html[data-theme="dark"] .card,
html[data-theme="dark"] .court-card,
html[data-theme="dark"] .stat-card{
  background:
    linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012)),
    rgba(18,26,43,.88)!important;
  border:1px solid rgba(148,163,184,.16)!important;
  box-shadow:0 18px 44px rgba(0,0,0,.24)!important;
}

html[data-theme="dark"] .court-header{
  background:rgba(17,26,46,.92)!important;
  border-bottom:1px solid rgba(148,163,184,.14)!important;
}

html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .secret-expense-btn,
html[data-theme="dark"] .icon-back-btn,
html[data-theme="dark"] .court-icon-btn{
  background:rgba(17,26,46,.78)!important;
  border-color:rgba(148,163,184,.18)!important;
  color:#aab7ca!important;
  box-shadow:0 10px 24px rgba(0,0,0,.16)!important;
}

html[data-theme="dark"] .theme-toggle:hover,
html[data-theme="dark"] .secret-expense-btn:hover,
html[data-theme="dark"] .icon-back-btn:hover,
html[data-theme="dark"] .court-icon-btn:hover{
  color:var(--accent)!important;
  border-color:rgba(45,212,191,.42)!important;
  background:rgba(45,212,191,.10)!important;
}

html[data-theme="dark"] input[type=text],
html[data-theme="dark"] input[type=number],
html[data-theme="dark"] input[type=password],
html[data-theme="dark"] select,
html[data-theme="dark"] .player-chip,
html[data-theme="dark"] .player-avatar,
html[data-theme="dark"] .btn-secondary{
  background:rgba(17,26,46,.78)!important;
  border-color:rgba(148,163,184,.16)!important;
  color:var(--text)!important;
}

html[data-theme="dark"] input:focus,
html[data-theme="dark"] select:focus{
  border-color:rgba(45,212,191,.62)!important;
  box-shadow:0 0 0 4px rgba(45,212,191,.11)!important;
}

html[data-theme="dark"] input::placeholder{
  color:#607088!important;
}

html[data-theme="dark"] .btn-primary{
  background:linear-gradient(135deg,#2dd4bf,#14b8a6)!important;
  color:#06110f!important;
  box-shadow:0 12px 24px rgba(20,184,166,.18)!important;
}

html[data-theme="dark"] .btn-primary:hover{
  background:linear-gradient(135deg,#5eead4,#2dd4bf)!important;
}

html[data-theme="dark"] .score-row + .btn-group .btn-primary:first-child{
  background:linear-gradient(135deg,#f6c177,#f59e0b)!important;
  color:#171006!important;
  border:1px solid rgba(245,158,11,.22)!important;
  box-shadow:0 12px 24px rgba(245,158,11,.14)!important;
}

html[data-theme="dark"] .btn-secondary:hover{
  background:rgba(30,42,68,.88)!important;
  border-color:rgba(148,163,184,.24)!important;
}

html[data-theme="dark"] .court-opt{
  background:rgba(18,26,43,.78)!important;
  border-color:rgba(148,163,184,.16)!important;
}

html[data-theme="dark"] .court-opt.active{
  background:rgba(45,212,191,.10)!important;
  border-color:rgba(45,212,191,.55)!important;
  box-shadow:inset 0 0 0 1px rgba(45,212,191,.08)!important;
}

html[data-theme="dark"] .stats-tabs{
  background:rgba(8,11,20,.42)!important;
  border-color:rgba(148,163,184,.14)!important;
}

html[data-theme="dark"] .stats-tab.active{
  background:rgba(18,26,43,.95)!important;
  box-shadow:0 10px 24px rgba(0,0,0,.18)!important;
}

html[data-theme="dark"] .player-row,
html[data-theme="dark"] .match-row,
html[data-theme="dark"] .lb-row,
html[data-theme="dark"] .status-item,
html[data-theme="dark"] .expense-owner-row,
html[data-theme="dark"] .expense-result-row,
html[data-theme="dark"] .mini-rank-row{
  border-bottom-color:rgba(148,163,184,.12)!important;
}

html[data-theme="dark"] .toast{
  background:rgba(18,26,43,.96)!important;
  border-color:rgba(148,163,184,.18)!important;
  box-shadow:0 18px 46px rgba(0,0,0,.30)!important;
}

html[data-theme="dark"] .collapse-chevron::before,
html[data-theme="dark"] .collapse-chevron::after{
  background:#aab7ca!important;
}

html[data-theme="dark"] .sync-dot{
  background:#fb7185!important;
  box-shadow:0 0 0 4px rgba(251,113,133,.14)!important;
}

html[data-theme="dark"] .sync-dot.ok{
  background:var(--accent)!important;
  box-shadow:0 0 0 4px rgba(45,212,191,.14)!important;
}

html[data-theme="dark"] .status-select{
  background:rgba(17,26,46,.78)!important;
}

html[data-theme="dark"] .sel-ready{
  background:rgba(45,212,191,.10)!important;
  color:#5eead4!important;
  border-color:rgba(45,212,191,.36)!important;
}

html[data-theme="dark"] .sel-playing{
  background:rgba(246,179,95,.11)!important;
  color:#f6c177!important;
  border-color:rgba(246,179,95,.34)!important;
}

html[data-theme="dark"] .sel-rest{
  background:rgba(139,140,255,.12)!important;
  color:#b8b9ff!important;
  border-color:rgba(139,140,255,.34)!important;
}

html[data-theme="dark"] .sel-out{
  background:rgba(251,113,133,.12)!important;
  color:#fda4af!important;
  border-color:rgba(251,113,133,.32)!important;
}

html[data-theme="dark"] .court-live-badge{
  background:rgba(246,179,95,.13)!important;
  color:#f6c177!important;
}

html[data-theme="dark"] .stat-num,
html[data-theme="dark"] .lb-games,
html[data-theme="dark"] .mini-rank-games,
html[data-theme="dark"] .topbar-logo{
  color:var(--accent)!important;
}

html[data-theme="dark"] .expense-total-grid div{
  background:rgba(17,26,46,.72)!important;
  border-color:rgba(148,163,184,.14)!important;
}

html[data-theme="dark"] .empty-icon{
  background:rgba(17,26,46,.68)!important;
  border-color:rgba(148,163,184,.16)!important;
}

html[data-theme="dark"] #loading{
  background:rgba(8,11,20,.82)!important;
  backdrop-filter:blur(8px);
}



/* Expense shuttle simplified fields */
.expense-owner-inputs .expense-owner-input{
  width:104px!important;
}
.expense-owner-input::placeholder{
  font-size:12px;
}
.expense-shuttle-note{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
  padding:8px 0 12px;
}
@media(max-width:420px){
  .expense-owner-inputs{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
}



/* Expense save/copy actions */
.expense-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:14px;
}
.expense-actions .btn{
  padding:10px 12px;
  font-size:13px;
}
.expense-save-note{
  margin-top:10px;
  font-size:12px;
  color:var(--ready);
  font-weight:700;
  text-align:center;
}
@media(max-width:420px){
  .expense-actions{
    grid-template-columns:1fr;
  }
}



/* Deleted players restore */
.title-actions{
  display:flex;
  align-items:center;
  gap:6px;
}
.deleted-player-row{
  display:flex;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
  gap:12px;
  opacity:.82;
}
.deleted-player-row:last-child{
  border-bottom:0;
}
.deleted-player-row .player-avatar{
  color:var(--muted)!important;
  border-color:rgba(125,132,145,.25)!important;
}
.restore-btn{
  flex-shrink:0;
}
html[data-theme="dark"] .deleted-player-row{
  border-bottom-color:rgba(148,163,184,.12)!important;
}
@media(max-width:420px){
  .title-actions{
    }
  .title-actions .btn-sm{
    padding:6px 9px;
    font-size:12px;
  }
}



/* Deleted players modal */
.icon-action-btn{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .15s;
  flex-shrink:0;
}
.icon-action-btn svg{
  width:15px;
  height:15px;
}
.icon-action-btn:hover{
  color:var(--out);
  border-color:rgba(220,38,38,.22);
  background:rgba(220,38,38,.07);
}
.icon-action-btn:active{transform:scale(.94)}

.modal-backdrop{
  position:fixed;
  inset:0;
  z-index:500;
  background:rgba(8,11,20,.42);
  backdrop-filter:blur(10px);
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:16px;
}
.modal-backdrop.hidden{
  display:none!important;
}
.modal-sheet{
  width:100%;
  max-width:520px;
  max-height:82vh;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:24px 24px 18px 18px;
  box-shadow:0 -18px 54px rgba(31,41,55,.18);
  overflow:hidden;
  animation:modalSlideUp .18s ease-out;
}
@keyframes modalSlideUp{
  from{transform:translateY(18px);opacity:.7}
  to{transform:translateY(0);opacity:1}
}
.modal-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:18px 18px 14px;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.modal-title{
  font-size:18px;
  font-weight:800;
  letter-spacing:-.25px;
}
.modal-subtitle{
  font-size:12px;
  color:var(--muted);
  margin-top:2px;
}
.modal-close-btn{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--border);
  background:transparent;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex-shrink:0;
}
.modal-close-btn svg{
  width:16px;
  height:16px;
}
.modal-close-btn:hover{
  color:var(--text);
  background:rgba(125,132,145,.08);
}
.modal-body{
  padding:8px 18px 18px;
  overflow:auto;
  max-height:calc(82vh - 80px);
}
.deleted-player-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.deleted-player-card:last-child{
  border-bottom:0;
}
.deleted-player-main{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  flex:1;
}
.deleted-avatar{
  color:var(--muted)!important;
  border-color:rgba(125,132,145,.24)!important;
  filter:saturate(.55);
}
.restore-chip-btn{
  border:1px solid rgba(17,184,154,.22);
  background:rgba(17,184,154,.08);
  color:var(--ready);
  border-radius:999px;
  padding:7px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  flex-shrink:0;
}
.restore-chip-btn:hover{
  background:rgba(17,184,154,.13);
  border-color:rgba(17,184,154,.34);
}
.deleted-empty{
  text-align:center;
  color:var(--muted);
  padding:34px 14px;
}
body.modal-open{
  overflow:hidden;
}
html[data-theme="dark"] .modal-backdrop{
  background:rgba(0,0,0,.52);
}
html[data-theme="dark"] .modal-sheet{
  background:rgba(18,26,43,.98);
  border-color:rgba(148,163,184,.16);
  box-shadow:0 -18px 54px rgba(0,0,0,.35);
}
html[data-theme="dark"] .modal-header,
html[data-theme="dark"] .deleted-player-card{
  border-color:rgba(148,163,184,.12);
}
html[data-theme="dark"] .icon-action-btn,
html[data-theme="dark"] .modal-close-btn{
  background:rgba(17,26,46,.78);
  border-color:rgba(148,163,184,.16);
}
@media(min-width:640px){
  .modal-backdrop{
    align-items:center;
  }
  .modal-sheet{
    border-radius:24px;
  }
}



/* Permanent delete action in Deleted Players modal */
.deleted-player-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}
.permanent-delete-btn{
  border:1px solid rgba(220,38,38,.20);
  background:rgba(220,38,38,.06);
  color:var(--out);
  border-radius:999px;
  padding:7px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
}
.permanent-delete-btn:hover{
  background:rgba(220,38,38,.11);
  border-color:rgba(220,38,38,.32);
}
.permanent-delete-btn:active{
  transform:scale(.96);
}
html[data-theme="dark"] .permanent-delete-btn{
  background:rgba(251,113,133,.10);
  border-color:rgba(251,113,133,.24);
  color:#fda4af;
}
html[data-theme="dark"] .permanent-delete-btn:hover{
  background:rgba(251,113,133,.16);
  border-color:rgba(251,113,133,.36);
}
@media(max-width:420px){
  .deleted-player-card{
    align-items:flex-start;
    flex-direction:column;
  }
  .deleted-player-actions{
    width:100%;
    justify-content:flex-end;
  }
}



/* Expense history */
.expense-history-list{
  display:grid;
  gap:8px;
}
.expense-history-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.expense-history-row:last-child{
  border-bottom:0;
}
.expense-history-main{
  min-width:0;
  flex:1;
}
.expense-history-date{
  font-weight:800;
  color:var(--text);
  font-size:14px;
}
.expense-history-meta,
.expense-history-players{
  color:var(--muted);
  font-size:11.5px;
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.expense-history-side{
  flex-shrink:0;
  text-align:right;
}
.expense-history-total{
  color:var(--accent);
  font-size:14px;
  font-weight:900;
  margin-bottom:7px;
}
.expense-history-actions{
  display:flex;
  align-items:center;
  gap:6px;
  justify-content:flex-end;
}
.history-reuse-btn,
.history-delete-btn{
  border-radius:999px;
  padding:6px 10px;
  font-family:inherit;
  font-size:11.5px;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
}
.history-reuse-btn{
  border:1px solid rgba(17,184,154,.22);
  background:rgba(17,184,154,.08);
  color:var(--ready);
}
.history-reuse-btn:hover{
  background:rgba(17,184,154,.13);
}
.history-delete-btn{
  border:1px solid rgba(220,38,38,.18);
  background:rgba(220,38,38,.06);
  color:var(--out);
}
.history-delete-btn:hover{
  background:rgba(220,38,38,.10);
}
html[data-theme="dark"] .expense-history-row{
  border-color:rgba(148,163,184,.12);
}
html[data-theme="dark"] .history-reuse-btn{
  border-color:rgba(45,212,191,.25);
  background:rgba(45,212,191,.10);
  color:#5eead4;
}
html[data-theme="dark"] .history-delete-btn{
  border-color:rgba(251,113,133,.24);
  background:rgba(251,113,133,.10);
  color:#fda4af;
}
@media(max-width:420px){
  .expense-history-row{
    flex-direction:column;
    gap:8px;
  }
  .expense-history-side{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    text-align:left;
  }
}



/* Expense history modal + accordion */
.expense-title-wrap{
  min-width:0;
  flex:1;
}
.expense-title-row{
  display:flex;
  align-items:center;
  gap:8px;
}
.expense-history-icon-btn{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .15s;
  flex-shrink:0;
}
.expense-history-icon-btn svg{
  width:16px;
  height:16px;
}
.expense-history-icon-btn:hover{
  color:var(--accent);
  border-color:rgba(17,184,154,.32);
  background:rgba(17,184,154,.08);
}
.expense-history-modal-sheet{
  max-height:86vh;
}
.accordion-history-list{
  display:grid;
  gap:10px;
}
.expense-accordion-item{
  border:1px solid rgba(125,132,145,.14);
  background:rgba(125,132,145,.04);
  border-radius:16px;
  overflow:hidden;
}
.expense-accordion-head{
  width:100%;
  border:0;
  background:transparent;
  color:var(--text);
  font-family:inherit;
  text-align:left;
  padding:13px 14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
}
.expense-accordion-main{
  min-width:0;
  flex:1;
}
.expense-accordion-side{
  flex-shrink:0;
  text-align:right;
  display:flex;
  align-items:center;
  gap:10px;
}
.expense-accordion-chevron{
  width:20px;
  height:20px;
  border-radius:999px;
  position:relative;
}
.expense-accordion-chevron::before,
.expense-accordion-chevron::after{
  content:"";
  position:absolute;
  top:9px;
  width:8px;
  height:1.7px;
  background:var(--muted);
  border-radius:999px;
  transition:transform .18s ease;
}
.expense-accordion-chevron::before{left:4px;transform:rotate(40deg)}
.expense-accordion-chevron::after{right:4px;transform:rotate(-40deg)}
.expense-accordion-item.open .expense-accordion-chevron::before{transform:rotate(-40deg)}
.expense-accordion-item.open .expense-accordion-chevron::after{transform:rotate(40deg)}
.expense-accordion-body{
  display:none;
  padding:0 14px 14px;
}
.expense-accordion-item.open .expense-accordion-body{
  display:block;
}
.expense-detail-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-bottom:12px;
}
.expense-detail-grid div{
  background:rgba(125,132,145,.07);
  border:1px solid rgba(125,132,145,.10);
  border-radius:12px;
  padding:10px;
}
.expense-detail-grid span{
  display:block;
  color:var(--muted);
  font-size:11px;
  margin-bottom:3px;
}
.expense-detail-grid strong{
  color:var(--text);
  font-size:14px;
}
.expense-detail-section{
  padding:10px 0;
  border-top:1px solid rgba(125,132,145,.12);
}
.expense-detail-title{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
  margin-bottom:7px;
  text-transform:uppercase;
  letter-spacing:.4px;
}
.expense-detail-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:6px 0;
  font-size:13px;
}
.expense-detail-line span{
  color:var(--text);
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.expense-detail-line strong{
  font-size:13px;
  white-space:nowrap;
}
.expense-detail-line.pay strong{color:var(--out)}
.expense-detail-line.receive strong{color:var(--ready)}
.expense-detail-empty{
  color:var(--muted);
  font-size:12px;
  padding:4px 0;
}
.expense-summary-text{
  border-top:1px solid rgba(125,132,145,.12);
  padding-top:10px;
  margin-top:4px;
}
.expense-summary-text summary{
  cursor:pointer;
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
.expense-summary-text pre{
  white-space:pre-wrap;
  word-break:break-word;
  margin-top:8px;
  padding:10px;
  border-radius:12px;
  background:rgba(125,132,145,.07);
  color:var(--text);
  font-family:inherit;
  font-size:12px;
  line-height:1.55;
}
.accordion-actions{
  padding-top:12px;
  justify-content:flex-end;
}
html[data-theme="dark"] .expense-history-icon-btn{
  background:rgba(17,26,46,.78);
  border-color:rgba(148,163,184,.16);
}
html[data-theme="dark"] .expense-accordion-item{
  background:rgba(17,26,46,.48);
  border-color:rgba(148,163,184,.14);
}
html[data-theme="dark"] .expense-detail-grid div,
html[data-theme="dark"] .expense-summary-text pre{
  background:rgba(8,11,20,.30);
  border-color:rgba(148,163,184,.10);
}
html[data-theme="dark"] .expense-detail-section,
html[data-theme="dark"] .expense-summary-text{
  border-color:rgba(148,163,184,.12);
}
@media(max-width:420px){
  .expense-accordion-head{
    padding:12px;
  }
  .expense-detail-grid{
    grid-template-columns:1fr;
  }
  .expense-detail-line{
    align-items:flex-start;
    flex-direction:column;
    gap:2px;
  }
  .expense-detail-line strong{
    white-space:normal;
  }
}



/* Expense title history button spacing fix */
.expense-header{
  align-items:flex-start!important;
}

.expense-title-wrap{
  flex:1!important;
  min-width:0!important;
}

.expense-title-row{
  width:100%!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
}

.expense-title-row .dashboard-title{
  min-width:0;
  flex:1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.expense-history-icon-btn{
  margin-left:auto!important;
  flex-shrink:0!important;
}

@media(max-width:420px){
  .expense-title-row{
    gap:10px!important;
  }

  .expense-history-icon-btn{
    width:36px!important;
    height:36px!important;
  }
}



/* Expense calculator page transition */
.stats-panel.expense-panel{
  transform-origin:center top;
  will-change:transform,opacity;
}

.stats-panel.expense-panel.expense-slide-in{
  animation:expenseSlideIn .34s cubic-bezier(.22,1,.36,1);
}

.stats-panel.expense-panel.expense-slide-out{
  display:block!important;
  animation:expenseSlideOut .18s ease-in forwards;
}

@keyframes expenseSlideIn{
  from{
    opacity:0;
    transform:translateX(26px) scale(.985);
    filter:blur(3px);
  }
  to{
    opacity:1;
    transform:translateX(0) scale(1);
    filter:blur(0);
  }
}

@keyframes expenseSlideOut{
  from{
    opacity:1;
    transform:translateX(0) scale(1);
  }
  to{
    opacity:0;
    transform:translateX(18px) scale(.99);
  }
}

@media (prefers-reduced-motion: reduce){
  .stats-panel.expense-panel.expense-slide-in,
  .stats-panel.expense-panel.expense-slide-out{
    animation:none!important;
  }
}



/* Expense history pagination */
.expense-history-pagination{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 0 4px;
}
.expense-history-pagination button{
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  border-radius:999px;
  padding:8px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  transition:all .15s;
}
.expense-history-pagination button:hover:not(:disabled){
  color:var(--accent);
  border-color:rgba(17,184,154,.34);
  background:rgba(17,184,154,.08);
}
.expense-history-pagination button:disabled{
  opacity:.42;
  cursor:not-allowed;
}
.expense-history-pagination span{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
}
.expense-history-count{
  color:var(--muted);
  font-size:11.5px;
  font-weight:700;
  text-align:center;
  padding-top:4px;
}
html[data-theme="dark"] .expense-history-pagination button{
  background:rgba(17,26,46,.78);
  border-color:rgba(148,163,184,.16);
}
@media(max-width:420px){
  .expense-history-pagination{
    gap:8px;
  }
  .expense-history-pagination button{
    padding:8px 10px;
  }
}



/* Clearer expense access in stats tabs */
.stats-tabs{
  grid-template-columns:repeat(4,1fr)!important;
}
@media(max-width:420px){
  .stats-tab{
    font-size:11.5px!important;
    padding:8px 4px!important;
  }
}

/* Queue filter tabs */
.queue-filter-tabs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:7px;
  margin:0 0 12px;
  background:rgba(125,132,145,.08);
  border:1px solid rgba(125,132,145,.12);
  padding:5px;
  border-radius:999px;
}
.queue-filter-btn{
  border:0;
  background:transparent;
  color:var(--muted);
  border-radius:999px;
  padding:8px 6px;
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .15s;
}
.queue-filter-btn span{
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:999px;
  background:rgba(125,132,145,.12);
  color:var(--muted);
  font-size:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.queue-filter-btn.active{
  background:var(--card);
  color:var(--text);
  box-shadow:0 8px 18px rgba(70,76,90,.08);
}
.queue-filter-btn.active span{
  background:rgba(17,184,154,.12);
  color:var(--accent);
}
html[data-theme="dark"] .queue-filter-tabs{
  background:rgba(8,11,20,.42);
  border-color:rgba(148,163,184,.14);
}
html[data-theme="dark"] .queue-filter-btn.active{
  background:rgba(18,26,43,.95);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
html[data-theme="dark"] .queue-filter-btn.active span{
  background:rgba(45,212,191,.12);
  color:#5eead4;
}
@media(max-width:380px){
  .queue-filter-btn{
    font-size:11px;
    padding:8px 4px;
  }
}



/* Settings page */
.settings-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.settings-section-title{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.65px;
  margin:18px 2px 10px;
}
.court-profile-form{
  display:grid;
  gap:12px;
}
.court-profile-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.court-profile-row:last-child{
  border-bottom:0;
}
.court-profile-main{
  min-width:0;
  flex:1;
}
.court-profile-name{
  font-weight:800;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.court-profile-rate{
  color:var(--accent);
  font-size:12px;
  font-weight:800;
  margin-top:2px;
}
.court-profile-delete-btn{
  border:1px solid rgba(220,38,38,.18);
  background:rgba(220,38,38,.06);
  color:var(--out);
  border-radius:999px;
  padding:7px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  flex-shrink:0;
}
.court-profile-delete-btn:hover{
  background:rgba(220,38,38,.11);
  border-color:rgba(220,38,38,.30);
}
html[data-theme="dark"] .court-profile-row{
  border-bottom-color:rgba(148,163,184,.12);
}
html[data-theme="dark"] .court-profile-delete-btn{
  background:rgba(251,113,133,.10);
  border-color:rgba(251,113,133,.24);
  color:#fda4af;
}
@media(max-width:420px){
  .court-profile-row{
    align-items:flex-start;
    flex-direction:column;
    gap:8px;
  }
  .court-profile-delete-btn{
    align-self:flex-end;
  }
}



/* Settings sub tabs UX */
.settings-tabs{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  background:rgba(125,132,145,.08);
  border:1px solid rgba(125,132,145,.12);
  padding:5px;
  border-radius:999px;
  margin-bottom:14px;
}
.settings-tab{
  border:0;
  background:transparent;
  color:var(--muted);
  border-radius:999px;
  padding:10px 8px;
  font-family:inherit;
  font-size:13px;
  font-weight:800;
  cursor:pointer;
  transition:all .15s;
}
.settings-tab.active{
  color:var(--text);
  background:var(--card);
  box-shadow:0 8px 18px rgba(70,76,90,.08);
}
.settings-panel{
  display:none;
}
.settings-panel.active{
  display:block;
  animation:settingsPanelIn .22s ease-out;
}
@keyframes settingsPanelIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.settings-panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin:4px 2px 12px;
}
.settings-panel-title{
  font-size:15px;
  font-weight:900;
  color:var(--text);
  letter-spacing:-.1px;
}
.settings-panel-subtitle{
  font-size:12px;
  color:var(--muted);
  margin-top:2px;
  line-height:1.45;
}
.danger-zone-card .help{
  margin-bottom:14px;
}
.danger-zone-card .btn-reset{
  width:100%;
}
html[data-theme="dark"] .settings-tabs{
  background:rgba(8,11,20,.42);
  border-color:rgba(148,163,184,.14);
}
html[data-theme="dark"] .settings-tab.active{
  background:rgba(18,26,43,.95);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
@media(max-width:380px){
  .settings-tab{
    font-size:12px;
    padding:9px 4px;
  }
}



/* Bottom nav: expense moved into settings */
.bottom-nav{
  grid-template-columns:repeat(3,1fr)!important;
}
.bottom-nav .nav-btn{
  min-width:0;
  font-size:11.5px;
}
.bottom-nav .nav-btn svg{
  width:19px;
  height:19px;
}
.stats-tabs{
  grid-template-columns:repeat(3,1fr)!important;
}
@media(max-width:380px){
  .bottom-nav .nav-btn{
    font-size:10.5px;
  }
}



/* Separate expense page */
.expense-page{
  animation:expenseSlideIn .28s cubic-bezier(.22,1,.36,1);
}
.expense-page .expense-header{
  margin-bottom:14px;
}
.expense-page .expense-title-row{
  justify-content:space-between;
}



/* Bulk player edit */
.title-actions .btn.active{
  color:var(--accent);
  border-color:rgba(17,184,154,.32);
  background:rgba(17,184,154,.08);
}
.bulk-action-bar{
  border:1px solid rgba(125,132,145,.14);
  background:rgba(125,132,145,.05);
  border-radius:16px;
  padding:10px;
  margin:10px 0 4px;
}
.bulk-action-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:9px;
}
.bulk-selected-count{
  font-size:12px;
  font-weight:900;
  color:var(--text);
}
.bulk-action-links{
  display:flex;
  gap:8px;
}
.bulk-action-links button{
  border:0;
  background:transparent;
  color:var(--muted);
  font-family:inherit;
  font-size:11.5px;
  font-weight:800;
  cursor:pointer;
  padding:2px 0;
}
.bulk-action-links button:hover{
  color:var(--accent);
}
.bulk-action-buttons{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:7px;
}
.bulk-chip{
  border-radius:999px;
  padding:8px 7px;
  font-family:inherit;
  font-size:11.5px;
  font-weight:900;
  cursor:pointer;
  border:1px solid transparent;
}
.bulk-chip.ready{
  background:rgba(17,184,154,.09);
  color:var(--ready);
  border-color:rgba(17,184,154,.20);
}
.bulk-chip.rest{
  background:rgba(139,140,255,.09);
  color:var(--rest);
  border-color:rgba(139,140,255,.20);
}
.bulk-chip.out{
  background:rgba(125,132,145,.09);
  color:var(--muted);
  border-color:rgba(125,132,145,.16);
}
.bulk-chip.danger{
  background:rgba(220,38,38,.06);
  color:var(--out);
  border-color:rgba(220,38,38,.18);
}
.bulk-mode-row{
  gap:10px;
}
.bulk-selected{
  background:rgba(17,184,154,.045);
}
.bulk-check-wrap{
  width:28px;
  height:28px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.bulk-check{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.bulk-check-wrap span{
  width:20px;
  height:20px;
  border-radius:7px;
  border:1.8px solid rgba(125,132,145,.35);
  background:rgba(255,255,255,.35);
  position:relative;
  transition:all .15s;
}
.bulk-check:checked + span{
  border-color:var(--accent);
  background:var(--accent);
}
.bulk-check:checked + span::after{
  content:"";
  position:absolute;
  left:6px;
  top:3px;
  width:5px;
  height:10px;
  border:solid #fff;
  border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.bulk-check:disabled + span{
  opacity:.35;
  cursor:not-allowed;
}
html[data-theme="dark"] .bulk-action-bar{
  background:rgba(17,26,46,.48);
  border-color:rgba(148,163,184,.14);
}
html[data-theme="dark"] .bulk-selected{
  background:rgba(45,212,191,.075);
}
html[data-theme="dark"] .bulk-check-wrap span{
  background:rgba(17,26,46,.78);
  border-color:rgba(148,163,184,.26);
}
@media(max-width:420px){
  .bulk-action-buttons{
    grid-template-columns:1fr 1fr;
  }
  .bulk-action-top{
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }
}



/* Admin PIN guard modal */
.admin-pin-sheet{
  max-width:420px;
}
.admin-pin-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
}
.admin-pin-error{
  color:var(--out);
  font-size:12px;
  font-weight:800;
  margin-top:8px;
}
#admin-pin-input{
  text-align:center;
  letter-spacing:8px;
  font-size:22px;
  font-weight:900;
}
.pin-shake{
  animation:pinShake .24s ease-in-out;
}
@keyframes pinShake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-5px)}
  75%{transform:translateX(5px)}
}
html[data-theme="dark"] .admin-pin-sheet{
  background:rgba(18,26,43,.98);
}



/* Queue ready players collapse */
.ready-players-card{
  margin-top:12px;
}
.ready-count-pill{
  margin-left:auto;
  margin-right:8px;
  min-width:24px;
  height:22px;
  padding:0 8px;
  border-radius:999px;
  background:rgba(17,184,154,.11);
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:900;
}
.ready-player-list{
  display:grid;
  gap:8px;
  padding-top:4px;
}
.ready-player-chip{
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 0;
  border-bottom:1px solid rgba(125,132,145,.12);
}
.ready-player-chip:last-child{
  border-bottom:0;
}
.ready-player-avatar{
  width:34px!important;
  height:34px!important;
  font-size:13px!important;
}
.ready-player-info{
  min-width:0;
  flex:1;
}
.ready-player-name{
  font-size:14px;
  font-weight:800;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.ready-player-meta{
  font-size:11.5px;
  color:var(--muted);
  margin-top:1px;
}
html[data-theme="dark"] .ready-count-pill{
  background:rgba(45,212,191,.12);
  color:#5eead4;
}
html[data-theme="dark"] .ready-player-chip{
  border-bottom-color:rgba(148,163,184,.12);
}



/* Compact ready queue list */
.ready-players-card{
  margin-top:10px!important;
  padding:0!important;
  border-radius:16px!important;
}

.ready-players-card .collapse-toggle{
  min-height:44px!important;
  padding:10px 12px!important;
  font-size:13px!important;
}

.ready-players-card .collapse-content.open{
  padding:0 12px 10px!important;
}

.ready-count-pill{
  min-width:22px!important;
  height:20px!important;
  padding:0 7px!important;
  font-size:11px!important;
  margin-right:6px!important;
}

.ready-player-list{
  gap:4px!important;
  padding-top:0!important;
}

.ready-player-chip{
  gap:8px!important;
  padding:7px 0!important;
}

.ready-player-avatar{
  width:28px!important;
  height:28px!important;
  font-size:12px!important;
}

.ready-player-name{
  font-size:13px!important;
}

.ready-player-meta{
  font-size:10.5px!important;
}



/* Check-in modal */
.queue-main-actions{
  display:grid;
  grid-template-columns:1fr 1.35fr;
  gap:10px;
}
.checkin-entry-btn{
  white-space:nowrap;
}
.checkin-sheet{
  max-width:520px;
}
.checkin-alert{
  border:1px solid rgba(245,158,11,.24);
  background:rgba(245,158,11,.10);
  color:#b45309;
  border-radius:14px;
  padding:10px 12px;
  font-size:12px;
  font-weight:800;
  margin-bottom:12px;
}
.checkin-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  margin:8px 0 10px;
}
.checkin-toolbar button{
  border:0;
  background:transparent;
  color:var(--accent);
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  padding:2px 0;
}
.checkin-list{
  display:grid;
  gap:8px;
  max-height:45vh;
  overflow:auto;
  padding-right:2px;
}
.checkin-player-row{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid rgba(125,132,145,.14);
  background:rgba(125,132,145,.045);
  border-radius:14px;
  padding:9px 10px;
  cursor:pointer;
  transition:all .15s;
}
.checkin-player-row.selected{
  border-color:rgba(17,184,154,.32);
  background:rgba(17,184,154,.08);
}
.checkin-player-row input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.checkin-box{
  width:20px;
  height:20px;
  border-radius:7px;
  border:1.8px solid rgba(125,132,145,.35);
  background:rgba(255,255,255,.35);
  position:relative;
  flex-shrink:0;
}
.checkin-player-row input:checked + .checkin-box{
  border-color:var(--accent);
  background:var(--accent);
}
.checkin-player-row input:checked + .checkin-box::after{
  content:"";
  position:absolute;
  left:6px;
  top:3px;
  width:5px;
  height:10px;
  border:solid #fff;
  border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.checkin-avatar{
  width:34px!important;
  height:34px!important;
  font-size:13px!important;
}
.checkin-player-info{
  min-width:0;
  flex:1;
}
.checkin-player-name{
  color:var(--text);
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.checkin-player-meta{
  color:var(--muted);
  font-size:11.5px;
  margin-top:1px;
}
.checkin-footer{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:14px;
}
.checkin-count{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  flex:1;
}
.checkin-footer .btn{
  width:auto;
  min-width:150px;
}
html[data-theme="dark"] .checkin-alert{
  color:#fbbf24;
}
html[data-theme="dark"] .checkin-player-row{
  background:rgba(17,26,46,.48);
  border-color:rgba(148,163,184,.14);
}
html[data-theme="dark"] .checkin-player-row.selected{
  background:rgba(45,212,191,.09);
  border-color:rgba(45,212,191,.32);
}
html[data-theme="dark"] .checkin-box{
  background:rgba(17,26,46,.78);
  border-color:rgba(148,163,184,.26);
}
@media(max-width:420px){
  .queue-main-actions{
    grid-template-columns:1fr;
  }
  .checkin-footer{
    align-items:stretch;
    flex-direction:column;
  }
  .checkin-footer .btn{
    width:100%;
  }
}



/* Check-in gate + minimal button */
.checkin-mini-btn{
  border:1px solid rgba(125,132,145,.18);
  background:rgba(125,132,145,.06);
  color:var(--muted);
  border-radius:999px;
  padding:9px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
}
.checkin-mini-btn:hover{
  color:var(--accent);
  border-color:rgba(17,184,154,.28);
  background:rgba(17,184,154,.07);
}
.queue-main-actions{
  grid-template-columns:auto 1fr!important;
  align-items:center;
}
.checkin-gate{
  text-align:center;
  padding:18px 4px 8px;
}
.checkin-gate-icon{
  width:58px;
  height:58px;
  border-radius:20px;
  margin:0 auto 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(17,184,154,.10);
  color:var(--accent);
  border:1px solid rgba(17,184,154,.18);
}
.checkin-gate-icon svg{
  width:28px;
  height:28px;
}
.checkin-gate-title{
  color:var(--text);
  font-size:18px;
  font-weight:900;
  letter-spacing:-.2px;
  margin-bottom:6px;
}
.checkin-gate-desc{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.55;
  max-width:360px;
  margin:0 auto 16px;
}
.checkin-form-wrap.hidden{
  display:none!important;
}
html[data-theme="dark"] .checkin-mini-btn{
  background:rgba(17,26,46,.58);
  border-color:rgba(148,163,184,.16);
}
html[data-theme="dark"] .checkin-gate-icon{
  background:rgba(45,212,191,.10);
  border-color:rgba(45,212,191,.20);
  color:#5eead4;
}
@media(max-width:420px){
  .queue-main-actions{
    grid-template-columns:1fr!important;
  }
  .checkin-mini-btn{
    width:100%;
    padding:9px 10px;
  }
}



/* Check-in forced gate actions */
.checkin-gate-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  max-width:340px;
  margin:0 auto;
}
@media(max-width:420px){
  .checkin-gate-actions{
    grid-template-columns:1fr;
  }
}



/* Allow bottom nav while Check-in modal is open */
.bottom-nav{
  z-index:700!important;
}

#checkin-modal.modal-backdrop{
  padding-bottom:86px!important;
}

#checkin-modal .modal-sheet{
  position:relative;
  z-index:610;
}



/* Check-in initial modal + mobile centering + no expense tab animation */
#checkin-modal.modal-backdrop{
  align-items:center!important;
  justify-content:center!important;
  padding:16px 16px 96px!important;
}

#checkin-modal .modal-sheet{
  margin:auto!important;
}

.expense-page{
  animation:none!important;
}

@media(max-width:420px){
  #checkin-modal.modal-backdrop{
    align-items:center!important;
    justify-content:center!important;
    padding:14px 14px 88px!important;
  }

  #checkin-modal .modal-sheet{
    border-radius:22px!important;
  }
}



/* Player management search */
.player-search-wrap{
  margin:12px 0 8px;
}
.player-search-box{
  position:relative;
}
.player-search-box input{
  width:100%;
  padding-right:42px!important;
}
.player-search-clear{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  width:30px;
  height:30px;
  border:0;
  border-radius:999px;
  background:transparent;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.player-search-clear svg{
  width:15px;
  height:15px;
}
.player-search-clear:hover{
  background:rgba(125,132,145,.08);
  color:var(--text);
}
html[data-theme="dark"] .player-search-clear:hover{
  background:rgba(148,163,184,.10);
}



/* Admin PIN modal mobile centering */
#admin-pin-modal.modal-backdrop{
  align-items:center!important;
  justify-content:center!important;
  padding:16px!important;
}

#admin-pin-modal .modal-sheet{
  margin:auto!important;
  max-width:420px!important;
  width:100%!important;
  border-radius:22px!important;
}

@media(max-width:420px){
  #admin-pin-modal.modal-backdrop{
    align-items:center!important;
    justify-content:center!important;
    padding:14px!important;
    padding-bottom:88px!important;
  }

  #admin-pin-modal .modal-sheet{
    transform:none!important;
  }
}

/* More visible but still minimal expense history button */
.expense-history-pill-btn{
  width:auto!important;
  height:34px!important;
  min-width:auto!important;
  padding:0 12px!important;
  gap:6px!important;
  border-radius:999px!important;
  color:var(--accent)!important;
  border-color:rgba(17,184,154,.28)!important;
  background:rgba(17,184,154,.08)!important;
  font-size:12px!important;
  font-weight:900!important;
}

.expense-history-pill-btn svg{
  width:15px!important;
  height:15px!important;
}

.expense-history-pill-btn span{
  display:inline-block;
  line-height:1;
}

.expense-history-pill-btn:hover{
  background:rgba(17,184,154,.13)!important;
  border-color:rgba(17,184,154,.40)!important;
  transform:none;
}

html[data-theme="dark"] .expense-history-pill-btn{
  color:#5eead4!important;
  background:rgba(45,212,191,.10)!important;
  border-color:rgba(45,212,191,.26)!important;
}

@media(max-width:360px){
  .expense-history-pill-btn span{
    display:none;
  }

  .expense-history-pill-btn{
    width:34px!important;
    padding:0!important;
  }
}



/* Edit player + previews + UX polish */
.icon-btn-edit{
  width:30px;
  height:30px;
  border:0;
  background:transparent;
  color:var(--muted);
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.icon-btn-edit svg{
  width:17px;
  height:17px;
}
.icon-btn-edit:hover{
  color:var(--accent);
  background:rgba(17,184,154,.08);
}
.edit-player-actions,
.expense-preview-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
}
.expense-preview-text{
  white-space:pre-wrap;
  word-break:break-word;
  margin:0;
  padding:12px;
  border:1px solid rgba(125,132,145,.14);
  border-radius:14px;
  background:rgba(125,132,145,.06);
  color:var(--text);
  font-family:inherit;
  font-size:13px;
  line-height:1.65;
  max-height:48vh;
  overflow:auto;
}
.today-summary-card .help{
  margin-bottom:12px;
}
html[data-theme="dark"] .expense-preview-text{
  background:rgba(8,11,20,.30);
  border-color:rgba(148,163,184,.12);
}



/* Expense draft + reuse feedback */
.reuse-highlight{
  animation:reuseHighlight .9s ease-out;
}
@keyframes reuseHighlight{
  0%{box-shadow:0 0 0 0 rgba(17,184,154,.34);border-color:rgba(17,184,154,.50)}
  100%{box-shadow:0 0 0 16px rgba(17,184,154,0);border-color:var(--border)}
}



/* Stats layout guard */
#page-stats .stats-panel{
  width:100%;
}

#page-stats .today-summary-card{
  margin-top:12px;
}



/* Toast should stay above all modals */
.toast,
#toast{
  z-index:9999!important;
  position:fixed!important;
}

#toast.show,
.toast.show{
  z-index:9999!important;
}



/* Reset day CTA polish */
.reset-day-card{
  border-color:rgba(245,158,11,.28)!important;
  background:
    linear-gradient(180deg, rgba(245,158,11,.08), rgba(245,158,11,.035)),
    var(--card)!important;
}

.reset-card-title{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  color:var(--text)!important;
}

.reset-title-dot{
  width:9px;
  height:9px;
  border-radius:999px;
  background:var(--playing);
  box-shadow:0 0 0 4px rgba(245,158,11,.12);
  flex-shrink:0;
}

.reset-day-card .help{
  color:var(--muted);
  line-height:1.6;
  margin-bottom:14px!important;
}

.reset-day-main-btn{
  width:100%!important;
  min-height:56px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  border-radius:16px!important;
  border:1px solid rgba(245,158,11,.38)!important;
  background:linear-gradient(135deg, rgba(245,158,11,.92), rgba(251,146,60,.86))!important;
  color:#171717!important;
  box-shadow:0 12px 28px rgba(245,158,11,.18)!important;
  font-weight:900!important;
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease!important;
}

.reset-day-main-btn:hover{
  transform:none;
  filter:saturate(1.05);
  box-shadow:0 16px 34px rgba(245,158,11,.24)!important;
}

.reset-day-main-btn:active{
  transform:scale(.985);
}

.reset-btn-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  background:rgba(255,255,255,.30);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.reset-btn-icon svg{
  width:18px;
  height:18px;
}

.reset-day-main-btn span:last-child{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  line-height:1.2;
}

.reset-day-main-btn strong{
  font-size:14px;
}

.reset-day-main-btn small{
  font-size:11px;
  opacity:.78;
  font-weight:800;
  margin-top:2px;
}

html[data-theme="dark"] .reset-day-card{
  border-color:rgba(251,191,36,.24)!important;
  background:
    linear-gradient(180deg, rgba(245,158,11,.10), rgba(245,158,11,.035)),
    rgba(18,26,43,.96)!important;
}

html[data-theme="dark"] .reset-day-main-btn{
  background:linear-gradient(135deg, #fbbf24, #fb923c)!important;
  color:#111827!important;
}

@media(max-width:420px){
  .reset-day-main-btn{
    min-height:58px!important;
  }
}



/* Court profile default */
.court-profile-actions{
  display:flex;
  align-items:center;
  gap:7px;
  flex-shrink:0;
}
.court-profile-default-btn{
  border:1px solid rgba(17,184,154,.22);
  background:rgba(17,184,154,.07);
  color:var(--accent);
  border-radius:999px;
  padding:7px 10px;
  font-family:inherit;
  font-size:11.5px;
  font-weight:900;
  cursor:pointer;
  white-space:nowrap;
}
.court-profile-default-btn:disabled{
  opacity:1;
  cursor:default;
  background:rgba(17,184,154,.14);
}
.default-badge{
  display:inline-flex;
  margin-left:5px;
  padding:2px 7px;
  border-radius:999px;
  background:rgba(17,184,154,.12);
  color:var(--accent);
  font-size:10px;
  font-weight:900;
  vertical-align:middle;
}
.court-profile-default{
  background:rgba(17,184,154,.035);
}

/* History copy action */
.history-copy-btn{
  border:1px solid rgba(17,184,154,.22);
  background:rgba(17,184,154,.07);
  color:var(--accent);
  border-radius:999px;
  padding:6px 10px;
  font-family:inherit;
  font-size:11.5px;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
}
.history-copy-btn:hover{
  background:rgba(17,184,154,.12);
}

/* Smarter empty state */
.smart-empty{
  padding:30px 14px!important;
}
.smart-empty p strong{
  color:var(--text);
  font-size:14px;
}
.empty-action-btn{
  margin-top:12px;
  border:1px solid rgba(17,184,154,.24);
  background:rgba(17,184,154,.08);
  color:var(--accent);
  border-radius:999px;
  padding:8px 14px;
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}

/* Modal consistency */
.modal-sheet{
  max-height:86vh;
  display:flex;
  flex-direction:column;
}
.modal-header{
  flex-shrink:0;
}
.modal-body{
  overflow:auto;
}
.modal-body .btn{
  min-height:44px;
}
.modal-title{
  letter-spacing:-.15px;
}
.modal-subtitle{
  line-height:1.45;
}


html[data-theme="dark"] .court-profile-default{
  background:rgba(45,212,191,.045);
}
html[data-theme="dark"] .court-profile-default-btn,
html[data-theme="dark"] .history-copy-btn,
html[data-theme="dark"] .empty-action-btn{
  color:#5eead4;
  border-color:rgba(45,212,191,.24);
  background:rgba(45,212,191,.09);
}

@media(max-width:420px){
  .court-profile-row{
    align-items:flex-start;
  }
  .court-profile-actions{
    width:100%;
    justify-content:flex-end;
    flex-wrap:wrap;
  }
  .accordion-actions{
    flex-wrap:wrap;
  }
}



/* Bottom nav refined active state */
.bottom-nav .nav-btn{
  position:relative;
  border-radius:12px;
  color:var(--muted);
  transition:color .15s ease, transform .15s ease;
}

.bottom-nav .nav-btn.active{
  color:var(--accent);
  background:transparent!important;
  transform:none;
}

.bottom-nav .nav-btn.active svg{
  stroke-width:2.05;
}

.bottom-nav .nav-btn.active::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:5px;
  transform:translateX(-50%);
  width:22px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:.9;
}

.bottom-nav .nav-btn:not(.active):hover{
  color:var(--text);
}

html[data-theme="dark"] .bottom-nav .nav-btn.active{
  color:#5eead4;
}

html[data-theme="dark"] .bottom-nav .nav-btn.active::after{
  background:linear-gradient(90deg, transparent, #5eead4, transparent);
}






/* Responsive layout: mobile vs desktop */
html{
  scrollbar-gutter:stable;
}

body{
  overflow-x:hidden;
}

/* Mobile first: app-like full width */
.topbar{
  width:100%;
  max-width:none;
  left:0!important;
  right:0!important;
  transform:none!important;
  margin:0;
}

.page{
  width:100%;
  max-width:none;
  margin:0;
  padding-left:14px!important;
  padding-right:14px!important;
  box-sizing:border-box;
}

.bottom-nav{
  width:100%;
  max-width:none;
  left:0!important;
  right:0!important;
  transform:none!important;
  box-sizing:border-box;
}

.bottom-nav .nav-btn,
.bottom-nav .nav-btn.active{
  transform:none!important;
}

/* Tablet / small desktop */
@media(min-width:720px){
  body{
    background:
      radial-gradient(circle at 50% -10%, rgba(17,184,154,.08), transparent 34%),
      var(--bg);
  }

  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 40px), 760px);
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
    box-sizing:border-box;
  }

  .topbar{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    border-left:1px solid var(--border);
    border-right:1px solid var(--border);
    border-radius:0 0 20px 20px;
  }

  .page{
    padding-left:20px!important;
    padding-right:20px!important;
  }

  .bottom-nav{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    border-left:1px solid var(--border)!important;
    border-right:1px solid var(--border)!important;
    border-radius:20px 20px 0 0!important;
    overflow:hidden;
  }

  .stats-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .expense-form-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .expense-full{
    grid-column:1 / -1;
  }
}

/* Desktop: wider working area */
@media(min-width:1024px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 64px), 920px);
    max-width:920px;
  }

  .page{
    padding-left:24px!important;
    padding-right:24px!important;
  }

  #page-settings .settings-panel.active{
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
  }

  #settings-panel-expense .card,
  #page-stats .card{
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
  }

  #page-queue .card,
  #page-queue .section-heading,
  #page-queue .queue-filter-tabs,
  #page-queue #active-courts{
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
  }

  #page-queue .section-heading{
    margin-top:18px;
    margin-bottom:10px;
  }
}

/* Large desktop */
@media(min-width:1280px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 96px), 1040px);
    max-width:1040px;
  }
}



/* Tablet responsive layer */
@media(min-width:768px) and (max-width:1023px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 48px), 820px)!important;
    max-width:820px!important;
  }

  .page{
    padding-left:22px!important;
    padding-right:22px!important;
  }

  /* Tablet keeps content breathable but avoids overly wide single cards */
  #page-queue .card,
  #page-queue .section-heading,
  #page-queue .queue-filter-tabs,
  #page-queue #active-courts,
  #settings-panel-expense .card,
  #page-stats .card,
  #page-settings .settings-panel.active{
    max-width:720px!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  /* Tablet: allow two columns where useful */
  .stats-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
    gap:12px!important;
  }

  .expense-form-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
    gap:12px!important;
  }

  .expense-full{
    grid-column:1 / -1!important;
  }

  .court-selector{
    grid-template-columns:repeat(3, minmax(0, 1fr))!important;
  }

  .queue-main-actions{
    grid-template-columns:auto 1fr!important;
  }

  .bottom-nav .nav-btn{
    min-height:58px;
  }

  .modal-sheet{
    width:min(92vw, 620px)!important;
  }

  .checkin-sheet,
  .expense-history-modal-sheet{
    width:min(92vw, 680px)!important;
  }
}

/* Small tablets / large phones */
@media(min-width:600px) and (max-width:767px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 32px), 680px)!important;
    max-width:680px!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  .topbar{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    border-left:1px solid var(--border);
    border-right:1px solid var(--border);
    border-radius:0 0 18px 18px;
  }

  .bottom-nav{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    border-left:1px solid var(--border)!important;
    border-right:1px solid var(--border)!important;
    border-radius:18px 18px 0 0!important;
    overflow:hidden!important;
  }

  .page{
    padding-left:18px!important;
    padding-right:18px!important;
  }

  .stats-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
  }

  .expense-form-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
  }

  .expense-full{
    grid-column:1 / -1!important;
  }
}



/* Tablet/header stability fix */
.topbar{
  display:grid!important;
  grid-template-columns:44px minmax(0,1fr) 44px!important;
  align-items:center!important;
  gap:8px!important;
}

.topbar-logo{
  min-width:0!important;
  text-align:center!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

.theme-toggle{
  justify-self:start!important;
}

.sync-dot{
  justify-self:end!important;
}

/* Safer breakpoint widths using calc() for better browser support */
@media(min-width:600px) and (max-width:767px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 32px), 680px)!important;
  }
}

@media(min-width:768px) and (max-width:1023px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 48px), 820px)!important;
  }
}

@media(min-width:1024px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 64px), 920px)!important;
  }
}

@media(min-width:1280px){
  .topbar,
  .page,
  .bottom-nav{
    width:min(calc(100% - 96px), 1040px)!important;
  }
}

/* Keep expense form from becoming too cramped on small tablets */
@media(min-width:600px) and (max-width:767px){
  #settings-panel-expense .card{
    max-width:640px!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  .expense-form-grid{
    grid-template-columns:1fr!important;
  }

  .expense-full{
    grid-column:auto!important;
  }
}



/* Header center alignment fix */
@media(min-width:600px){
  .topbar{
    left:auto!important;
    right:auto!important;
    transform:none!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }
}

/* Keep fixed bottom nav centered separately */
@media(min-width:600px){
  .bottom-nav{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
  }
}



/* =========================================================
   Mobile modal fit fix — scoped to modals only
   Based on the uploaded 3-file version.
   ========================================================= */

/* Base modal behavior */
.modal-backdrop{
  box-sizing:border-box!important;
  align-items:center!important;
  justify-content:center!important;
  padding:14px 12px calc(88px + env(safe-area-inset-bottom))!important;
  overflow:hidden!important;
}

/* Every modal sheet must fit inside the visible viewport */
.modal-backdrop .modal-sheet{
  width:min(100%,520px)!important;
  max-width:520px!important;
  max-height:calc(100dvh - 128px - env(safe-area-inset-bottom))!important;
  margin:auto!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  border-radius:24px!important;
}

/* Header stays visible, body becomes scrollable */
.modal-backdrop .modal-header{
  flex:0 0 auto!important;
}

.modal-backdrop .modal-body{
  flex:1 1 auto!important;
  min-height:0!important;
  max-height:none!important;
  overflow:auto!important;
  -webkit-overflow-scrolling:touch!important;
  padding-bottom:16px!important;
}

/* Keep normal modals above bottom nav */
#admin-pin-modal,
#deleted-players-modal,
#expense-history-modal,
#edit-player-modal{
  z-index:900!important;
}

#admin-pin-modal .modal-sheet,
#deleted-players-modal .modal-sheet,
#expense-history-modal .modal-sheet,
#edit-player-modal .modal-sheet{
  position:relative!important;
  z-index:910!important;
}

/* Check-in modal is special: bottom tabs should remain clickable */
#checkin-modal{
  z-index:500!important;
}

#checkin-modal .modal-sheet{
  position:relative!important;
  z-index:610!important;
}

/* Make bottom nav clickable over Check-in only, while still staying behind other modals */
.bottom-nav{
  z-index:700!important;
}

/* Deleted players modal: prevent card/actions from pushing below viewport */
#deleted-players-modal .deleted-player-card{
  min-width:0!important;
}

#deleted-players-modal .deleted-player-main{
  min-width:0!important;
  flex:1 1 auto!important;
}

#deleted-players-modal .deleted-player-actions{
  flex-shrink:0!important;
}

/* Admin PIN modal: compact and scroll-safe */
#admin-pin-modal .admin-pin-sheet{
  max-width:420px!important;
}

#admin-pin-modal #admin-pin-input{
  font-size:20px!important;
  letter-spacing:6px!important;
  min-height:52px!important;
}

/* Expense history modal: accordion details can scroll inside body */
#expense-history-modal .expense-history-modal-sheet{
  max-height:calc(100dvh - 128px - env(safe-area-inset-bottom))!important;
}

/* Small mobile refinements */
@media(max-width:420px){
  .modal-backdrop{
    padding:10px 10px calc(82px + env(safe-area-inset-bottom))!important;
  }

  .modal-backdrop .modal-sheet{
    width:100%!important;
    max-height:calc(100dvh - 108px - env(safe-area-inset-bottom))!important;
    border-radius:22px!important;
  }

  .modal-backdrop .modal-header{
    padding:15px 15px 11px!important;
  }

  .modal-backdrop .modal-title{
    font-size:17px!important;
    line-height:1.25!important;
  }

  .modal-backdrop .modal-subtitle{
    font-size:11.5px!important;
    line-height:1.4!important;
  }

  .modal-backdrop .modal-body{
    padding:10px 15px 14px!important;
  }

  /* Deleted players modal mobile card layout */
  #deleted-players-modal .deleted-player-card{
    display:flex!important;
    align-items:center!important;
    gap:10px!important;
  }

  #deleted-players-modal .deleted-player-main{
    min-width:0!important;
  }

  #deleted-players-modal .deleted-player-actions{
    width:auto!important;
    justify-content:flex-end!important;
    flex-direction:column!important;
    gap:6px!important;
  }

  #deleted-players-modal .restore-chip-btn,
  #deleted-players-modal .permanent-delete-btn{
    padding:6px 10px!important;
    font-size:11px!important;
    white-space:nowrap!important;
  }

  /* Admin PIN modal should not be hidden behind bottom nav */
  #admin-pin-modal .admin-pin-actions{
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
    margin-top:12px!important;
  }

  #admin-pin-modal .admin-pin-actions .btn{
    padding:10px 8px!important;
    font-size:13px!important;
  }

  #admin-pin-modal #admin-pin-input{
    font-size:18px!important;
    letter-spacing:5px!important;
  }

  /* Expense history modal */
  #expense-history-modal .expense-accordion-head{
    padding:11px 12px!important;
  }

  #expense-history-modal .expense-detail-grid{
    grid-template-columns:1fr!important;
  }
}

/* Very short screens */
@media(max-height:700px){
  .modal-backdrop{
    align-items:center!important;
    padding-top:8px!important;
    padding-bottom:calc(78px + env(safe-area-inset-bottom))!important;
  }

  .modal-backdrop .modal-sheet{
    max-height:calc(100dvh - 96px - env(safe-area-inset-bottom))!important;
  }
}

/* Custom player pick before starting game */
.player-chip-pick{
  font-family:inherit;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  color:var(--text);
  transition:all .15s ease;
}
.player-chip-pick:hover{
  border-color:var(--accent)!important;
  background:rgba(17,184,154,.08)!important;
  color:var(--accent);
}
.player-chip-pick:active{transform:scale(.98)}
.custom-court-hint{
  margin-top:12px;
  font-size:12px;
  color:var(--muted);
  text-align:center;
  background:rgba(125,132,145,.08);
  border:1px dashed rgba(125,132,145,.22);
  border-radius:10px;
  padding:8px 10px;
}
.custom-player-sheet{max-height:86vh}
.custom-player-help{
  font-size:12px;
  color:var(--muted);
  margin:-4px 0 10px;
}
.custom-player-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:52vh;
  overflow:auto;
  padding-right:2px;
}
.custom-player-option{
  width:100%;
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--bg3);
  color:var(--text);
  font-family:inherit;
  text-align:left;
  cursor:pointer;
  transition:all .15s ease;
}
.custom-player-option:hover{
  border-color:var(--accent);
  background:rgba(17,184,154,.08);
}
.custom-player-option:active{transform:scale(.99)}
.custom-player-option.is-current{
  border-color:rgba(17,184,154,.42);
  background:rgba(17,184,154,.08);
}
.custom-player-avatar{width:38px;height:38px;font-size:14px}
.custom-player-info{flex:1;min-width:0}
.custom-player-name{font-size:14px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.custom-player-meta{font-size:12px;color:var(--muted);margin-top:2px}
.custom-current-pill{
  display:inline-flex;
  align-items:center;
  padding:1px 7px;
  border-radius:999px;
  background:rgba(17,184,154,.12);
  color:var(--accent);
  font-size:10px;
  font-weight:800;
  margin-left:5px;
  vertical-align:middle;
}
html[data-theme="dark"] .custom-court-hint{
  background:rgba(136,136,170,.07);
  border-color:rgba(136,136,170,.18);
}
html[data-theme="dark"] .custom-player-option{
  background:var(--bg3);
}
html[data-theme="dark"] .custom-player-option:hover,
html[data-theme="dark"] .custom-player-option.is-current{
  background:rgba(0,212,170,.10);
}

/* Expense shortcut lives in the Settings header as a light secondary action */
.settings-tabs{
  grid-template-columns:repeat(3,1fr)!important;
}
.settings-expense-entry{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid rgba(125,132,145,.22);
  background:rgba(255,255,255,.54);
  color:var(--muted);
  border-radius:999px;
  padding:8px 11px;
  font-family:inherit;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  cursor:pointer;
  white-space:nowrap;
  font-size:12px;
  font-weight:800;
  line-height:1;
  box-shadow:none;
  min-height:34px;
  flex-shrink:0;
}
.settings-expense-entry:active{transform:scale(.97)}
.settings-expense-entry.active{
  color:var(--accent);
  border-color:rgba(17,184,154,.35);
  background:rgba(17,184,154,.08);
}
.settings-expense-icon{
  width:16px;
  height:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.settings-expense-icon svg{width:16px;height:16px}
html[data-theme="dark"] .settings-expense-entry{
  background:rgba(22,33,62,.55);
  border-color:rgba(136,136,170,.25);
  color:var(--muted);
}
html[data-theme="dark"] .settings-expense-entry.active{
  background:rgba(0,212,170,.10);
  border-color:rgba(0,212,170,.35);
  color:var(--accent);
}
@media(max-width:380px){
  .settings-expense-entry{padding:8px 9px;font-size:11px}
  .settings-expense-icon{width:15px;height:15px}
  .settings-expense-icon svg{width:15px;height:15px}
}


/* Expense shortcut: slightly more prominent accent tone */
.settings-expense-entry{
  border-color:rgba(17,184,154,.42)!important;
  background:linear-gradient(135deg, rgba(17,184,154,.16), rgba(109,93,252,.10))!important;
  color:var(--accent)!important;
  box-shadow:0 8px 22px rgba(17,184,154,.13)!important;
}
.settings-expense-entry:hover{
  border-color:rgba(17,184,154,.62)!important;
  background:linear-gradient(135deg, rgba(17,184,154,.22), rgba(109,93,252,.13))!important;
}
.settings-expense-entry.active{
  color:#ffffff!important;
  border-color:rgba(17,184,154,.75)!important;
  background:linear-gradient(135deg, var(--accent), var(--accent2))!important;
  box-shadow:0 10px 26px rgba(17,184,154,.22)!important;
}
.settings-expense-icon{
  color:inherit!important;
}
html[data-theme="dark"] .settings-expense-entry{
  border-color:rgba(0,212,170,.42)!important;
  background:linear-gradient(135deg, rgba(0,212,170,.18), rgba(124,58,237,.16))!important;
  color:var(--accent)!important;
  box-shadow:0 10px 26px rgba(0,0,0,.22)!important;
}
html[data-theme="dark"] .settings-expense-entry:hover{
  border-color:rgba(0,212,170,.62)!important;
  background:linear-gradient(135deg, rgba(0,212,170,.24), rgba(124,58,237,.20))!important;
}
html[data-theme="dark"] .settings-expense-entry.active{
  color:#0f0f1a!important;
  border-color:rgba(0,212,170,.78)!important;
  background:linear-gradient(135deg, var(--accent), #7c3aed)!important;
}

/* Edit player modal: delete moved inside modal + compact layout */
.player-actions{
  gap:4px!important;
}
.player-actions .icon-btn-delete{
  display:none!important;
}
#edit-player-modal .modal-sheet{
  width:min(100%,420px)!important;
  max-width:420px!important;
}
#edit-player-modal .modal-header{
  padding:14px 16px 10px!important;
}
#edit-player-modal .modal-title{
  font-size:16px!important;
}
#edit-player-modal .modal-subtitle{
  font-size:11px!important;
  margin-top:0!important;
}
#edit-player-modal .modal-close-btn{
  width:30px!important;
  height:30px!important;
}
#edit-player-modal .modal-body{
  padding:10px 16px 14px!important;
}
#edit-player-modal .form-group{
  margin-bottom:9px!important;
}
#edit-player-modal .form-label{
  margin-bottom:4px!important;
  font-size:12px!important;
}
#edit-player-modal input[type=text],
#edit-player-modal select{
  padding:9px 12px!important;
  font-size:14px!important;
}
#edit-player-modal .edit-player-actions{
  margin-top:10px!important;
  gap:8px!important;
}
#edit-player-modal .edit-player-actions .btn{
  min-height:40px!important;
  padding:9px 12px!important;
  font-size:14px!important;
}
.edit-player-delete-link{
  width:100%;
  margin-top:8px;
  border:0;
  background:transparent;
  color:var(--out);
  font-family:inherit;
  font-size:13px;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
}
.edit-player-delete-link svg{
  width:15px;
  height:15px;
}
.edit-player-delete-link:hover{
  background:rgba(220,38,38,.08);
}
html[data-theme="dark"] .edit-player-delete-link:hover{
  background:rgba(239,68,68,.10);
}
@media(max-width:520px){
  #edit-player-modal .modal-sheet{
    max-height:calc(100dvh - 116px - env(safe-area-inset-bottom))!important;
  }
}

/* Fix: Admin PIN modal must appear above Edit Player modal when deleting from inside edit modal */
#admin-pin-modal.modal-backdrop,
#admin-pin-modal{
  z-index:1400!important;
}

#admin-pin-modal .modal-sheet,
#admin-pin-modal .admin-pin-sheet{
  position:relative!important;
  z-index:1410!important;
}

/* Keep edit modal underneath PIN confirmation instead of hiding the PIN behind it */
#edit-player-modal.pin-confirm-underlay{
  z-index:900!important;
}

/* Compact stats overview */
.stats-overview-compact{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.compact-status-card,
.compact-list-card{
  padding:13px 14px!important;
  margin-bottom:0!important;
}
.compact-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.compact-card-head .card-title{
  margin-bottom:0!important;
}
.compact-card-head-stack{
  align-items:flex-start;
}
.compact-card-subtitle{
  color:var(--muted);
  font-size:11.5px;
  line-height:1.45;
  margin-top:3px;
}
.compact-link-btn{
  appearance:none;
  border:1px solid rgba(17,184,154,.28);
  background:rgba(17,184,154,.08);
  color:var(--accent);
  border-radius:999px;
  padding:4px 10px;
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
}
.compact-link-btn:active{transform:scale(.96)}
.status-mini-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;
}
.status-mini-item{
  min-width:0;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:10px;
  padding:7px 6px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  font-size:11px;
  color:var(--muted);
  white-space:nowrap;
}
.status-mini-item strong{
  color:var(--text);
  font-size:13px;
  margin-left:2px;
}
.overview-rank-row,
.overview-match-row{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:34px;
  padding:7px 0;
  border-bottom:1px solid var(--border);
}
.overview-rank-row:last-child,
.overview-match-row:last-child{border-bottom:none}
.overview-rank-no{
  width:24px;
  height:24px;
  border-radius:999px;
  background:var(--bg3);
  color:var(--muted);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:900;
  flex-shrink:0;
}
.overview-rank-no.top{
  color:var(--accent);
  background:rgba(17,184,154,.10);
}
.overview-rank-main{
  flex:1;
  min-width:0;
}
.overview-rank-title-line{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
}
.overview-rank-name{
  flex:1;
  min-width:0;
  font-size:13px;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.overview-rank-meta{
  color:var(--muted);
  font-size:11px;
  line-height:1.4;
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.overview-rank-side{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:1px;
  flex-shrink:0;
}
.overview-rank-games{
  color:var(--accent);
  font-size:16px;
  line-height:1;
  font-weight:900;
  white-space:nowrap;
}
.overview-rank-games-sub{
  color:var(--muted);
  font-size:10px;
  font-weight:700;
  white-space:nowrap;
}
.stats-late-note-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(245,158,11,.11);
  color:#b45309;
  border:1px solid rgba(245,158,11,.18);
  font-size:10.5px;
  font-weight:900;
  line-height:1;
  flex-shrink:0;
}
.stats-late-note-badge.inline{
  margin-left:6px;
  vertical-align:middle;
}
html[data-theme="dark"] .stats-late-note-badge{
  background:rgba(246,179,95,.12);
  color:#f6c177;
  border-color:rgba(246,179,95,.22);
}
.overview-match-main{
  flex:1;
  min-width:0;
}
.overview-match-teams{
  display:flex;
  align-items:center;
  min-width:0;
  font-size:12px;
  line-height:1.35;
  color:var(--muted);
}
.overview-match-teams strong{
  color:var(--text);
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.overview-match-meta{
  font-size:10px;
  color:var(--muted);
  margin-top:1px;
}
.overview-match-score{
  font-size:14px;
  font-weight:900;
  color:var(--accent);
  background:rgba(17,184,154,.08);
  border-radius:999px;
  padding:3px 8px;
  white-space:nowrap;
}
.compact-empty{
  padding:14px 10px!important;
}
@media(max-width:380px){
  .status-mini-grid{grid-template-columns:repeat(2,1fr)}
  .compact-card-head-stack{
    flex-direction:column;
    align-items:flex-start;
  }
  .compact-card-head-stack .compact-link-btn{
    align-self:flex-start;
  }
  .overview-rank-row{
    align-items:flex-start;
  }
  .overview-rank-title-line{
    flex-wrap:wrap;
  }
  .overview-rank-meta{
    white-space:normal;
  }
}

/* Stats overview responsive column layout */
#page-stats{
  width:100%;
}
#page-stats .dashboard-summary{
  gap:8px;
  margin-bottom:12px;
}
#page-stats .dashboard-summary .stat-card{
  padding:11px 8px!important;
  margin-bottom:0!important;
}
#page-stats .dashboard-summary .stat-num{
  font-size:24px;
  line-height:1.05;
}
#page-stats .dashboard-summary .stat-label{
  font-size:11px;
  line-height:1.25;
}
.stats-overview-compact{
  display:grid!important;
  grid-template-columns:1fr;
  gap:10px;
  align-items:start;
}
.stats-overview-compact .card{
  min-width:0;
}
.compact-status-card{
  grid-column:1 / -1;
}
.compact-list-card{
  min-height:0;
}
@media(min-width:390px){
  #page-stats .dashboard-summary{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .stats-overview-compact{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .compact-status-card{
    grid-column:1 / -1;
  }
  .status-mini-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .overview-rank-row,
  .overview-match-row{
    min-height:32px;
    padding:6px 0;
  }
  .overview-match-teams{
    font-size:11px;
  }
}
@media(min-width:720px){
  #page-stats{
    max-width:960px!important;
  }
  .stats-overview-compact{
    grid-template-columns:.72fr 1fr 1.2fr;
    gap:12px;
  }
  .compact-status-card{
    grid-column:auto;
  }
  .status-mini-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:389px){
  #page-stats .dashboard-summary{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

/* Desktop stats overview: stack cards again so the page feels balanced on wide screens */
@media(min-width:720px){
  #page-stats{
    max-width:620px!important;
  }
  .stats-overview-compact{
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .compact-status-card,
  .compact-list-card{
    grid-column:1 / -1!important;
    width:100%;
  }
  .status-mini-grid{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
  }
  .compact-list-card{
    min-height:auto!important;
  }
  .overview-rank-row,
  .overview-match-row{
    min-height:34px;
    padding:7px 0;
  }
  .overview-match-teams{
    font-size:12px;
  }
}

/* Stats overview leaderboard expand: rank tab removed, inline expand instead */
.stats-tabs.stats-tabs-two{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
}
#overview-leaderboard.is-expanded .overview-rank-row{
  min-height:34px;
}
#overview-leaderboard-toggle[aria-expanded="true"]{
  background:var(--accent)!important;
  color:#fff!important;
  border-color:var(--accent)!important;
}
html[data-theme="dark"] #overview-leaderboard-toggle[aria-expanded="true"]{
  color:#0f0f1a!important;
}

/* Winner select mode: replace score input with simple win/loss picker */
.winner-select-panel{
  margin-top:14px;
  background:rgba(99,102,241,.06);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px;
}
.winner-select-label{
  display:block;
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  margin-bottom:7px;
}
.winner-select{
  width:100%;
  font-weight:800;
  text-align:center;
  text-align-last:center;
  border-radius:12px!important;
}
.winner-select-help{
  margin-top:7px;
  font-size:11px;
  line-height:1.45;
  color:var(--muted);
}
html[data-theme="light"] .winner-select-panel{
  background:rgba(17,184,154,.06);
  border-color:rgba(17,184,154,.18);
}
html[data-theme="dark"] .winner-select-panel{
  background:rgba(0,212,170,.06);
  border-color:rgba(0,212,170,.16);
}

/* Winner button mode: tap one side instead of dropdown */
.winner-pick-panel{
  margin-top:14px;
  background:rgba(17,184,154,.055);
  border:1px solid rgba(17,184,154,.18);
  border-radius:14px;
  padding:12px;
}
.winner-pick-title{
  font-size:12px;
  font-weight:900;
  color:var(--muted);
  margin-bottom:8px;
  letter-spacing:.2px;
}
.winner-pick-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.winner-pick-card{
  appearance:none;
  -webkit-appearance:none;
  border:1.5px solid var(--border);
  border-radius:13px;
  background:var(--card);
  color:var(--text);
  font-family:inherit;
  min-height:64px;
  padding:10px 8px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  cursor:pointer;
  transition:transform .14s ease, border-color .14s ease, background .14s ease, box-shadow .14s ease, color .14s ease;
}
.winner-pick-card:active{transform:scale(.98)}
.winner-pick-card .winner-pick-kicker{
  font-size:11px;
  font-weight:900;
  color:var(--muted);
}
.winner-pick-card strong{
  font-size:18px;
  line-height:1.05;
}
.winner-pick-card.team-a-win{border-color:rgba(79,127,223,.28)}
.winner-pick-card.team-b-win{border-color:rgba(224,82,117,.28)}
.winner-pick-card.team-a-win.selected{
  background:linear-gradient(135deg, rgba(79,127,223,.18), rgba(79,127,223,.08));
  border-color:var(--teamA);
  color:var(--teamA);
  box-shadow:0 10px 24px rgba(79,127,223,.16);
}
.winner-pick-card.team-b-win.selected{
  background:linear-gradient(135deg, rgba(224,82,117,.18), rgba(224,82,117,.08));
  border-color:var(--teamB);
  color:var(--teamB);
  box-shadow:0 10px 24px rgba(224,82,117,.16);
}
.winner-pick-card.selected .winner-pick-kicker{color:currentColor}
.winner-pick-help{
  margin-top:8px;
  font-size:11px;
  line-height:1.45;
  color:var(--muted);
}
.btn-start-game{
  background:linear-gradient(135deg,#18c5a8,#0ea889)!important;
  color:#fff!important;
  border:1px solid rgba(17,184,154,.35)!important;
}
.btn-save-result{
  background:linear-gradient(135deg,#f59e0b,#d97706)!important;
  color:#fff!important;
  border:1px solid rgba(217,119,6,.35)!important;
}
.btn-save-result:active,
.btn-start-game:active{transform:scale(.98)}
html[data-theme="dark"] .winner-pick-panel{
  background:rgba(0,212,170,.055);
  border-color:rgba(0,212,170,.16);
}
html[data-theme="dark"] .winner-pick-card{
  background:var(--bg3);
}
html[data-theme="dark"] .winner-pick-card.team-a-win.selected{
  background:linear-gradient(135deg, rgba(59,130,246,.28), rgba(59,130,246,.10));
  box-shadow:0 10px 24px rgba(59,130,246,.12);
}
html[data-theme="dark"] .winner-pick-card.team-b-win.selected{
  background:linear-gradient(135deg, rgba(244,63,94,.28), rgba(244,63,94,.10));
  box-shadow:0 10px 24px rgba(244,63,94,.12);
}
html[data-theme="dark"] .btn-start-game{
  background:var(--accent)!important;
  color:#0f0f1a!important;
}

/* Result display: show winner label instead of 1-0 / 0-1 */
.team-chip-a,
.team-a .player-chip{
  border-color:rgba(79,127,223,.42)!important;
  background:linear-gradient(135deg, rgba(79,127,223,.14), rgba(79,127,223,.045))!important;
  color:var(--teamA)!important;
}
.team-chip-b,
.team-b .player-chip{
  border-color:rgba(224,82,117,.42)!important;
  background:linear-gradient(135deg, rgba(224,82,117,.14), rgba(224,82,117,.045))!important;
  color:var(--teamB)!important;
}
.team-a .team-label{
  background:rgba(79,127,223,.10);
  border:1px solid rgba(79,127,223,.20);
  color:var(--teamA)!important;
  border-radius:999px;
  padding:3px 8px;
  width:max-content;
}
.team-b .team-label{
  background:rgba(224,82,117,.10);
  border:1px solid rgba(224,82,117,.20);
  color:var(--teamB)!important;
  border-radius:999px;
  padding:3px 8px;
  width:max-content;
  align-self:flex-end;
}
.match-team-name,
.overview-match-teams strong{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:2px 7px;
  max-width:100%;
}
.team-a-name{
  color:var(--teamA)!important;
  background:rgba(79,127,223,.09);
}
.team-b-name{
  color:var(--teamB)!important;
  background:rgba(224,82,117,.09);
}
.match-result-line{
  margin-top:6px;
}
.winner-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  font-weight:900;
  line-height:1.2;
  white-space:nowrap;
}
.winner-badge.team-a-result{
  color:var(--teamA);
  background:rgba(79,127,223,.12);
  border:1px solid rgba(79,127,223,.24);
}
.winner-badge.team-b-result{
  color:var(--teamB);
  background:rgba(224,82,117,.12);
  border:1px solid rgba(224,82,117,.24);
}
.winner-badge.draw-result{
  color:var(--muted);
  background:var(--bg3);
  border:1px solid var(--border);
}
.overview-winner-badge{
  flex-shrink:0;
  padding:4px 9px;
  font-size:11px;
}
html[data-theme="dark"] .team-chip-a,
html[data-theme="dark"] .team-a .player-chip{
  background:linear-gradient(135deg, rgba(59,130,246,.22), rgba(59,130,246,.07))!important;
  border-color:rgba(59,130,246,.46)!important;
}
html[data-theme="dark"] .team-chip-b,
html[data-theme="dark"] .team-b .player-chip{
  background:linear-gradient(135deg, rgba(244,63,94,.22), rgba(244,63,94,.07))!important;
  border-color:rgba(244,63,94,.46)!important;
}

/* Fix: keep Team A/B player chips visibly colored in light mode too */
html[data-theme="light"] .team-col.team-a .player-chip,
html[data-theme="light"] .team-col.team-a .player-chip-pick,
html[data-theme="light"] .player-chip.team-chip-a,
html[data-theme="light"] button.player-chip.team-chip-a,
html[data-theme="light"] button.player-chip-pick.team-chip-a{
  color:#2563eb!important;
  background:linear-gradient(135deg, rgba(37,99,235,.12), rgba(37,99,235,.035))!important;
  border-color:rgba(37,99,235,.38)!important;
  box-shadow:inset 0 0 0 1px rgba(37,99,235,.03)!important;
}
html[data-theme="light"] .team-col.team-b .player-chip,
html[data-theme="light"] .team-col.team-b .player-chip-pick,
html[data-theme="light"] .player-chip.team-chip-b,
html[data-theme="light"] button.player-chip.team-chip-b,
html[data-theme="light"] button.player-chip-pick.team-chip-b{
  color:#e11d48!important;
  background:linear-gradient(135deg, rgba(225,29,72,.12), rgba(225,29,72,.035))!important;
  border-color:rgba(225,29,72,.38)!important;
  box-shadow:inset 0 0 0 1px rgba(225,29,72,.03)!important;
}
html[data-theme="light"] .team-col.team-a .player-chip-pick:hover,
html[data-theme="light"] button.player-chip-pick.team-chip-a:hover{
  color:#1d4ed8!important;
  background:linear-gradient(135deg, rgba(37,99,235,.18), rgba(37,99,235,.06))!important;
  border-color:rgba(37,99,235,.55)!important;
}
html[data-theme="light"] .team-col.team-b .player-chip-pick:hover,
html[data-theme="light"] button.player-chip-pick.team-chip-b:hover{
  color:#be123c!important;
  background:linear-gradient(135deg, rgba(225,29,72,.18), rgba(225,29,72,.06))!important;
  border-color:rgba(225,29,72,.55)!important;
}


/* Player Dashboard modal */
.player-dashboard-sheet{
  max-width:620px;
}
.player-dashboard-body{
  padding-top:12px!important;
}
.overview-rank-clickable{
  cursor:pointer;
  border-radius:10px;
  padding-left:4px;
  padding-right:4px;
  transition:background .15s ease, transform .15s ease;
}
.overview-rank-clickable:hover{
  background:rgba(17,184,154,.07);
}
.overview-rank-clickable:active{
  transform:scale(.99);
}
.player-dashboard-open-btn{
  appearance:none;
  border:1px solid rgba(17,184,154,.28);
  background:rgba(17,184,154,.08);
  color:var(--accent);
  border-radius:999px;
  padding:3px 9px;
  font-family:inherit;
  font-size:11px;
  font-weight:900;
  cursor:pointer;
  flex-shrink:0;
}
.player-dashboard-profile{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  border:1px solid var(--border);
  background:var(--bg3);
  border-radius:16px;
  margin-bottom:12px;
}
.player-dashboard-avatar{
  width:48px;
  height:48px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(17,184,154,.12);
  color:var(--accent);
  border:1px solid rgba(17,184,154,.25);
  font-size:20px;
  font-weight:900;
  flex-shrink:0;
}
.player-dashboard-profile-main{
  min-width:0;
}
.player-dashboard-name{
  font-size:18px;
  font-weight:900;
  line-height:1.25;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.player-dashboard-meta{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
}
.player-dashboard-kpi-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:8px;
  margin-bottom:14px;
}
.player-kpi-card{
  min-width:0;
  padding:10px 8px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
  text-align:center;
}
.player-kpi-card strong{
  display:block;
  font-size:20px;
  font-weight:950;
  line-height:1.1;
  color:var(--text);
}
.player-kpi-card span{
  display:block;
  margin-top:4px;
  font-size:11px;
  color:var(--muted);
  white-space:nowrap;
}
.player-kpi-card.win strong{color:var(--ready)}
.player-kpi-card.loss strong{color:var(--out)}
.player-kpi-card.rate strong{color:var(--accent)}
.player-kpi-card.days strong{color:var(--rest)}
.player-dashboard-section{
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--card);
  overflow:hidden;
}
.player-dashboard-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px 6px;
}
.player-dashboard-section-head .card-title{
  margin-bottom:0!important;
}
.player-dashboard-note{
  font-size:11px;
  color:var(--muted);
  white-space:nowrap;
}
.player-dashboard-history{
  padding:0 12px 8px;
}
.player-history-row{
  padding:10px 0;
  border-top:1px solid var(--border);
}
.player-history-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:5px;
}
.player-history-date{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
}
.player-result-pill,
.player-side-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:2px 8px;
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
}
.player-result-win{
  color:var(--ready);
  background:rgba(17,184,154,.10);
  border:1px solid rgba(17,184,154,.22);
}
.player-result-loss{
  color:var(--out);
  background:rgba(220,91,91,.08);
  border:1px solid rgba(220,91,91,.20);
}
.team-a-mini{
  color:var(--teamA);
  background:rgba(79,127,223,.10);
  border:1px solid rgba(79,127,223,.22);
}
.team-b-mini{
  color:var(--teamB);
  background:rgba(224,82,117,.10);
  border:1px solid rgba(224,82,117,.22);
}
.player-history-detail{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  color:var(--text);
  min-width:0;
}
.player-history-opponents{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}


/* Partner Performance in Player Dashboard */
.partner-performance-section{
  margin-bottom:12px;
}
.partner-performance-section .player-dashboard-section-head{
  align-items:flex-start;
}
.partner-note{
  margin-top:2px;
  white-space:normal!important;
}
.partner-best-badge{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 9px;
  border-radius:999px;
  font-size:10px;
  font-weight:950;
  color:var(--accent);
  border:1px solid rgba(17,184,154,.24);
  background:rgba(17,184,154,.08);
}
.partner-performance-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 190px;
  gap:10px;
  padding:0 12px 10px;
}
.partner-best-card,
.partner-chart-card{
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--bg3);
  padding:12px;
  min-width:0;
}
.partner-best-label,
.partner-chart-title{
  font-size:11px;
  font-weight:800;
  color:var(--muted);
  margin-bottom:5px;
}
.partner-best-name{
  font-size:18px;
  font-weight:950;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.partner-best-rate{
  font-size:28px;
  font-weight:950;
  line-height:1.15;
  color:var(--ready);
  margin-top:5px;
}
.partner-best-sub{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
}
.partner-best-alt{
  margin-top:9px;
  padding-top:8px;
  border-top:1px solid var(--border);
  font-size:11px;
  color:var(--muted);
}

.partner-challenging-card .partner-best-rate{
  color:var(--out);
  font-size:24px;
}
.partner-challenging-card{
  border-color:rgba(220,91,91,.16);
  background:linear-gradient(180deg, rgba(220,91,91,.04), rgba(220,91,91,.02));
}
.partner-challenging-card .partner-best-label{
  color:rgba(220,91,91,.88);
}
.partner-challenging-card .partner-best-sub,
.partner-challenging-card .partner-best-alt{
  color:var(--muted);
}

.partner-primary-card{
  border-color:rgba(17,184,154,.30);
  background:linear-gradient(180deg, rgba(17,184,154,.11), rgba(17,184,154,.04));
  box-shadow:0 10px 24px rgba(17,184,154,.08);
}
.partner-primary-card .partner-best-label{
  color:var(--ready);
  font-weight:900;
}
.partner-primary-card .partner-best-name{
  font-size:18px;
}
.partner-primary-card .partner-best-rate{
  font-size:32px;
  color:var(--ready);
}
.partner-primary-card .partner-best-sub{
  color:var(--text);
}
.partner-primary-card .partner-best-alt{
  border-top-color:rgba(17,184,154,.16);
}
.partner-chart-wrap{
  height:174px;
  position:relative;
}
.partner-chart-fallback{
  font-size:12px;
  color:var(--muted);
  text-align:center;
  padding:16px 8px;
}
.partner-table-wrap{
  padding:0 12px 12px;
}
.partner-table{
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  background:var(--card);
}
.partner-table-head,
.partner-table-row{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) .55fr .55fr .55fr .7fr;
  gap:6px;
  align-items:center;
  padding:8px 10px;
}
.partner-table-head{
  background:var(--bg3);
  color:var(--muted);
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.4px;
}
.partner-table-row{
  border-top:1px solid var(--border);
  font-size:12px;
  font-weight:800;
  color:var(--text);
}
.partner-table-head span:not(:first-child),
.partner-table-row span:not(:first-child){
  text-align:right;
}
.partner-name-cell{
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.partner-name-cell em{
  display:inline-flex;
  margin-left:5px;
  color:var(--muted);
  font-size:10px;
  font-style:normal;
  font-weight:800;
}
.partner-low-sample{
  opacity:.82;
}
.partner-win-cell{color:var(--ready)}
.partner-loss-cell{color:var(--out)}
.partner-rate-cell{color:var(--accent)}
@media(max-width:520px){
  .partner-performance-grid{
    grid-template-columns:1fr;
  }
  .partner-chart-wrap{
    height:190px;
  }
  .partner-table-head,
  .partner-table-row{
    grid-template-columns:minmax(0,1.25fr) .5fr .5fr .5fr .65fr;
    padding:8px 8px;
    gap:4px;
  }
}

@media(max-width:520px){
  .player-dashboard-kpi-grid{
    grid-template-columns:repeat(3,1fr);
  }
  .player-kpi-card.days{
    grid-column:auto;
  }
  .player-kpi-card strong{
    font-size:18px;
  }
  .player-kpi-card span{
    font-size:10px;
  }
}
@media(max-width:380px){
  .player-dashboard-kpi-grid{
    grid-template-columns:repeat(2,1fr);
  }
}


/* All-time stats player list */
.today-history-card{
  margin-top:12px;
}
.alltime-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.alltime-subtitle{
  color:var(--muted);
  font-size:12px;
  margin-top:-6px;
}
.alltime-total-pill{
  flex-shrink:0;
  border:1px solid rgba(17,184,154,.28);
  color:var(--accent);
  background:rgba(17,184,154,.08);
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
  font-weight:900;
}
.alltime-player-row{
  width:100%;
  appearance:none;
  border:0;
  border-bottom:1px solid var(--border);
  background:transparent;
  color:var(--text);
  font-family:inherit;
  text-align:left;
  display:grid;
  grid-template-columns:42px minmax(0,1fr) auto auto;
  gap:10px;
  align-items:center;
  padding:11px 0;
  cursor:pointer;
}
.alltime-player-row:last-child{border-bottom:none}
.alltime-player-row{
  border-radius:14px;
  padding-left:8px;
  padding-right:8px;
  margin:0 -8px;
  transition:background .15s ease, transform .15s ease, border-color .15s ease;
}
.alltime-player-row:hover,
.alltime-player-row:focus-visible{
  background:rgba(17,184,154,.08);
  outline:none;
}
html[data-theme="dark"] .alltime-player-row:hover,
html[data-theme="dark"] .alltime-player-row:focus-visible{
  background:rgba(0,212,170,.10);
}
.alltime-player-row:hover .alltime-kebab,
.alltime-player-row:focus-visible .alltime-kebab{
  color:var(--accent);
  border-color:rgba(17,184,154,.36);
  background:rgba(17,184,154,.12);
}
.alltime-avatar{
  width:38px!important;
  height:38px!important;
  font-size:14px!important;
}
.alltime-player-main{
  min-width:0;
}
.alltime-player-name{
  font-size:14px;
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.alltime-player-meta{
  color:var(--muted);
  font-size:12px;
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.alltime-player-stats{
  display:flex;
  align-items:center;
  gap:6px;
}
.alltime-player-stats>div{
  min-width:48px;
  border:1px solid var(--border);
  background:var(--bg3);
  border-radius:10px;
  padding:5px 7px;
  text-align:center;
}
.alltime-player-stats strong{
  display:block;
  font-size:14px;
  line-height:1.1;
}
.alltime-player-stats span{
  display:block;
  color:var(--muted);
  font-size:10px;
  margin-top:2px;
}
.alltime-win strong{color:var(--ready)}
.alltime-rate strong{color:var(--accent)}
.alltime-kebab{
  width:34px;
  height:34px;
  border:1px solid var(--border);
  color:var(--muted);
  background:var(--bg3);
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:3px;
  transition:.15s ease;
}
.alltime-kebab span{
  width:4px;
  height:4px;
  border-radius:999px;
  background:currentColor;
  display:block;
}

@media(max-width:620px){
  .alltime-card-head{
    align-items:flex-start;
  }
  .alltime-player-row{
    grid-template-columns:38px minmax(0,1fr) auto;
  }
  .alltime-player-stats{
    grid-column:2 / -1;
    justify-content:flex-start;
    flex-wrap:wrap;
    margin-top:-4px;
  }
  .alltime-kebab{
    grid-column:3;
    grid-row:1;
    width:32px;
    height:32px;
  }
}

/* Check-in search collapsed by default */
.checkin-search-collapse{
  margin:0 0 10px;
}
.checkin-search-toggle{
  width:100%;
  border:1px solid var(--border);
  background:rgba(255,255,255,.66);
  color:var(--text);
  border-radius:14px;
  min-height:42px;
  padding:9px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-family:inherit;
  cursor:pointer;
  transition:background .15s,border-color .15s,transform .15s;
}
.checkin-search-toggle:active{transform:scale(.99)}
.checkin-search-toggle.open,
.checkin-search-toggle:hover{
  border-color:rgba(17,184,154,.34);
  background:rgba(17,184,154,.07);
}
.checkin-search-toggle-left{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-width:0;
  font-weight:900;
  font-size:13px;
  color:var(--text);
}
.checkin-search-toggle-left svg{
  width:16px;
  height:16px;
  color:var(--accent);
  flex-shrink:0;
}
.checkin-search-hint{
  font-size:11px;
  font-weight:800;
  color:var(--muted);
  white-space:nowrap;
  max-width:46%;
  overflow:hidden;
  text-overflow:ellipsis;
}
.checkin-search-panel{
  display:none;
  padding-top:8px;
}
.checkin-search-panel.open{display:block}
.checkin-search-box{
  position:relative;
}
.checkin-search-box input{
  padding-right:42px!important;
}
.checkin-search-clear{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  width:28px;
  height:28px;
  border:0;
  border-radius:999px;
  background:transparent;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.checkin-search-clear:hover{
  background:rgba(220,38,38,.08);
  color:var(--out);
}
.checkin-search-clear svg{
  width:15px;
  height:15px;
}
html[data-theme="dark"] .checkin-search-toggle{
  background:rgba(22,33,62,.78);
  border-color:var(--border);
}
html[data-theme="dark"] .checkin-search-toggle.open,
html[data-theme="dark"] .checkin-search-toggle:hover{
  background:rgba(0,212,170,.08);
  border-color:rgba(0,212,170,.28);
}


/* Settings player search uses the same collapsed UX as Check-in search */
.settings-player-search-collapse{
  margin:12px 0 8px;
}
.settings-player-search-panel{
  padding-top:8px;
}
.settings-player-search-toggle{
  min-height:42px;
}
.settings-player-search-panel .player-search-box input{
  padding-right:42px!important;
}
.settings-player-search-panel .player-search-clear:hover{
  background:rgba(220,38,38,.08);
  color:var(--out);
}

/* All-time player search uses the same compact collapse pattern as Check-in / Settings */
.alltime-search-collapse{
  margin:2px 0 10px;
}
.alltime-search-panel .checkin-search-box input{
  font-size:14px;
}

/* Player Dashboard: overall winrate chart */
.player-dashboard-overview-grid{
  display:grid;
  grid-template-columns:210px minmax(0,1fr);
  gap:10px;
  margin-bottom:14px;
}
.player-overall-chart-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--card);
  padding:12px;
  min-width:0;
}
.player-overall-chart-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  margin-bottom:8px;
}
.player-overall-chart-title{
  font-size:12px;
  font-weight:950;
  color:var(--text);
  line-height:1.25;
}
.player-overall-chart-sub{
  font-size:10px;
  font-weight:700;
  color:var(--muted);
  margin-top:2px;
}
.player-overall-chart-wrap{
  height:178px;
  position:relative;
}
.player-overall-chart-fallback{
  font-size:12px;
  color:var(--muted);
  text-align:center;
  padding:16px 8px;
}
.player-dashboard-overview-grid .player-dashboard-kpi-grid{
  margin-bottom:0;
  grid-template-columns:repeat(2,1fr);
  align-content:start;
}
.player-dashboard-overview-grid .player-kpi-card.days{
  grid-column:1 / -1;
}
.partner-performance-grid-no-chart{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
}
.partner-performance-grid-no-chart .partner-best-card{
  padding:14px;
}
.partner-performance-grid-no-chart .partner-best-label{
  margin-bottom:2px;
}
.partner-performance-grid-no-chart .partner-best-name{
  font-size:17px;
}
.partner-performance-grid-no-chart .partner-best-rate{
  font-size:28px;
  margin-top:8px;
  text-align:left;
}
.partner-performance-grid-no-chart .partner-primary-card .partner-best-rate{
  font-size:32px;
}
.partner-performance-grid-no-chart .partner-challenging-card .partner-best-rate{
  font-size:24px;
}
.partner-performance-grid-no-chart .partner-best-sub{
  text-align:left;
}
.partner-performance-grid-no-chart .partner-best-alt{
  grid-column:auto;
}
@media(max-width:640px){
  .partner-performance-grid-no-chart{
    grid-template-columns:1fr!important;
  }
}

@media(max-width:520px){
  .player-dashboard-overview-grid{
    grid-template-columns:1fr;
  }
  .player-overall-chart-wrap{
    height:190px;
  }
  .player-dashboard-overview-grid .player-dashboard-kpi-grid{
    grid-template-columns:repeat(3,1fr);
  }
  .player-dashboard-overview-grid .player-kpi-card.days{
    grid-column:auto;
  }
}
@media(max-width:380px){
  .player-dashboard-overview-grid .player-dashboard-kpi-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

/* Player Dashboard: fit overall winrate frame */
.player-dashboard-overview-grid{
  align-items:stretch!important;
}
.player-dashboard-overview-grid .player-overall-chart-card{
  height:100%;
  display:flex;
  flex-direction:column;
}
.player-dashboard-overview-grid .player-overall-chart-wrap{
  flex:1;
  min-height:0;
  height:auto!important;
  display:flex;
  align-items:center;
  justify-content:center;
}
.player-dashboard-overview-grid .player-overall-chart-wrap canvas{
  max-height:170px!important;
}
.player-dashboard-overview-grid .player-dashboard-kpi-grid{
  height:100%;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  grid-template-rows:repeat(3,minmax(0,1fr));
  align-content:stretch!important;
  gap:10px;
}
.player-dashboard-overview-grid .player-kpi-card{
  min-height:0;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:10px 8px;
}
.player-dashboard-overview-grid .player-kpi-card.days{
  grid-column:1 / -1!important;
}
@media(max-width:520px){
  .player-dashboard-overview-grid .player-overall-chart-wrap{
    height:190px!important;
    flex:none;
  }
  .player-dashboard-overview-grid .player-dashboard-kpi-grid{
    height:auto;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:auto;
  }
  .player-dashboard-overview-grid .player-kpi-card.days{
    grid-column:auto!important;
  }
}
@media(max-width:380px){
  .player-dashboard-overview-grid .player-dashboard-kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .player-dashboard-overview-grid .player-kpi-card.days{
    grid-column:1 / -1!important;
  }
}


/* =========================================================
   Check-in modal hard fix v2
   - No nested modal/body scroll jump
   - Footer pinned to the bottom of the modal
   - Checking players does not rebuild the list
   ========================================================= */
#checkin-modal.modal-backdrop{
  overflow:hidden!important;
  align-items:center!important;
  justify-content:center!important;
  padding:12px 12px calc(88px + env(safe-area-inset-bottom))!important;
}

#checkin-modal .checkin-sheet{
  width:min(100%,520px)!important;
  height:min(760px,calc(100dvh - 116px - env(safe-area-inset-bottom)))!important;
  max-height:calc(100dvh - 116px - env(safe-area-inset-bottom))!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  border-radius:24px!important;
}

@supports not (height:100dvh){
  #checkin-modal .checkin-sheet{
    height:min(760px,calc(100vh - 116px - env(safe-area-inset-bottom)))!important;
    max-height:calc(100vh - 116px - env(safe-area-inset-bottom))!important;
  }
}

#checkin-modal .modal-header{
  flex:0 0 auto!important;
}

#checkin-modal .modal-body{
  flex:1 1 auto!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  max-height:none!important;
  padding:0!important;
}

#checkin-modal .checkin-gate{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow:auto!important;
  padding:18px 18px!important;
}

#checkin-modal .checkin-gate.hidden{
  display:none!important;
}

#checkin-modal .checkin-form-wrap{
  flex:1 1 auto!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:10px 18px 0!important;
}

#checkin-modal .checkin-form-wrap.hidden{
  display:none!important;
}

#checkin-modal .checkin-alert,
#checkin-modal .checkin-search-collapse,
#checkin-modal .checkin-toolbar{
  flex:0 0 auto!important;
}

#checkin-modal .checkin-list{
  flex:1 1 auto!important;
  min-height:0!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  align-content:start!important;
  padding:0 2px 12px 0!important;
}

#checkin-modal .checkin-player-row{
  position:relative!important;
  flex:0 0 auto!important;
}

#checkin-modal .checkin-player-row input[type="checkbox"]{
  position:absolute!important;
  left:12px!important;
  top:50%!important;
  width:1px!important;
  height:1px!important;
  margin:0!important;
  opacity:0!important;
  overflow:hidden!important;
  clip:rect(0 0 0 0)!important;
  clip-path:inset(50%)!important;
  pointer-events:none!important;
}

#checkin-modal .checkin-footer{
  flex:0 0 auto!important;
  position:sticky!important;
  bottom:0!important;
  z-index:5!important;
  display:flex!important;
  flex-direction:row!important;
  align-items:center!important;
  gap:10px!important;
  margin:0 -18px!important;
  padding:12px 18px calc(12px + env(safe-area-inset-bottom))!important;
  background:var(--card)!important;
  border-top:1px solid rgba(125,132,145,.16)!important;
  box-shadow:0 -10px 24px rgba(31,41,55,.08)!important;
}

#checkin-modal .checkin-count{
  min-width:0!important;
  font-size:12px!important;
  line-height:1.35!important;
}

#checkin-modal .checkin-footer .btn{
  width:auto!important;
  min-width:142px!important;
  flex:0 0 auto!important;
  white-space:nowrap!important;
}

#checkin-modal #checkin-confirm-btn:disabled,
#checkin-modal #checkin-confirm-btn.is-disabled{
  background:#d1d5db!important;
  color:#ffffff!important;
  cursor:not-allowed!important;
  opacity:1!important;
  transform:none!important;
}

html[data-theme="dark"] #checkin-modal .checkin-footer{
  background:rgba(18,26,43,.98)!important;
  border-top-color:rgba(148,163,184,.16)!important;
  box-shadow:0 -10px 24px rgba(0,0,0,.24)!important;
}

html[data-theme="dark"] #checkin-modal #checkin-confirm-btn:disabled,
html[data-theme="dark"] #checkin-modal #checkin-confirm-btn.is-disabled{
  background:#475569!important;
  color:#cbd5e1!important;
}

@media(max-width:420px){
  #checkin-modal.modal-backdrop{
    padding:10px 10px calc(82px + env(safe-area-inset-bottom))!important;
  }

  #checkin-modal .checkin-sheet{
    height:calc(100dvh - 102px - env(safe-area-inset-bottom))!important;
    max-height:calc(100dvh - 102px - env(safe-area-inset-bottom))!important;
    border-radius:22px!important;
  }

  #checkin-modal .checkin-form-wrap{
    padding:9px 14px 0!important;
  }

  #checkin-modal .checkin-footer{
    margin:0 -14px!important;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom))!important;
    gap:8px!important;
  }

  #checkin-modal .checkin-count{
    font-size:11px!important;
  }

  #checkin-modal .checkin-footer .btn{
    min-width:126px!important;
    padding:11px 12px!important;
    font-size:13px!important;
  }
}


/* =========================================================
   Check-in modal gate-size fix v3
   - First forced Check-in screen fits its content
   - Player selection screen still uses the full-height stable layout
   ========================================================= */
#checkin-modal.checkin-gate-mode .checkin-sheet{
  height:auto!important;
  min-height:0!important;
  max-height:calc(100dvh - 116px - env(safe-area-inset-bottom))!important;
}

@supports not (height:100dvh){
  #checkin-modal.checkin-gate-mode .checkin-sheet{
    max-height:calc(100vh - 116px - env(safe-area-inset-bottom))!important;
  }
}

#checkin-modal.checkin-gate-mode .modal-body{
  flex:0 1 auto!important;
  min-height:0!important;
  overflow:visible!important;
}

#checkin-modal.checkin-gate-mode .checkin-gate{
  flex:0 1 auto!important;
  min-height:auto!important;
  overflow:visible!important;
  padding:22px 18px 28px!important;
}

@media(max-width:420px){
  #checkin-modal.checkin-gate-mode .checkin-sheet{
    height:auto!important;
    min-height:0!important;
    max-height:calc(100dvh - 102px - env(safe-area-inset-bottom))!important;
  }

  #checkin-modal.checkin-gate-mode .checkin-gate{
    padding:20px 14px 24px!important;
  }
}

/* V7: lightweight CSS micro-interactions only - no external animation library */
html{
  scroll-behavior:smooth;
}

.page.active{
  animation:pageSoftIn .18s ease-out both;
}

@keyframes pageSoftIn{
  from{opacity:.96;transform:translateY(4px)}
  to{opacity:1;transform:translateY(0)}
}

.modal-backdrop:not(.hidden){
  animation:modalBackdropIn .14s ease-out both;
}

.modal-backdrop:not(.hidden) .modal-sheet{
  animation:modalSheetIn .2s cubic-bezier(.2,.9,.2,1) both;
  will-change:opacity,transform;
}

@keyframes modalBackdropIn{
  from{opacity:0}
  to{opacity:1}
}

@keyframes modalSheetIn{
  from{opacity:0;transform:translateY(12px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.btn,
.nav-btn,
.court-icon-btn,
.icon-action-btn,
.icon-btn-edit,
.checkin-player-row,
.queue-filter-btn,
.settings-tab,
.court-opt{
  transition:
    transform .15s ease,
    opacity .15s ease,
    background-color .15s ease,
    border-color .15s ease,
    color .15s ease,
    box-shadow .15s ease;
}

.nav-btn.active svg{
  transform:translateY(-1px);
  transition:transform .15s ease;
}

.checkin-player-row.selected .checkin-box{
  animation:checkinTickPop .18s ease-out both;
}

@keyframes checkinTickPop{
  0%{transform:scale(.82)}
  70%{transform:scale(1.08)}
  100%{transform:scale(1)}
}

.court-live-badge{
  animation:liveBadgePulse 1.8s ease-in-out infinite;
}

@keyframes liveBadgePulse{
  0%,100%{opacity:1}
  50%{opacity:.72}
}

@media (hover:hover){
  .btn:hover,
  .court-icon-btn:hover,
  .icon-action-btn:hover,
  .icon-btn-edit:hover,
  .queue-filter-btn:hover,
  .settings-tab:hover,
  .court-opt:hover{
    transform:translateY(-1px);
  }
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    scroll-behavior:auto!important;
    transition-duration:.001ms!important;
  }
}


/* V13: Remove mobile tap highlight / focus highlight */
html,
body,
button,
a,
input,
select,
textarea,
.nav-btn,
.settings-tab,
.settings-expense-entry,
.theme-toggle,
.btn,
.icon-action-btn,
.court-opt {
  -webkit-tap-highlight-color: transparent;
}

button,
a,
.nav-btn,
.settings-tab,
.settings-expense-entry,
.theme-toggle,
.btn,
.icon-action-btn,
.court-opt {
  outline: none;
  -webkit-touch-callout: none;
  user-select: none;
}

button:focus-visible,
a:focus-visible,
.nav-btn:focus-visible,
.settings-tab:focus-visible,
.settings-expense-entry:focus-visible,
.theme-toggle:focus-visible,
.btn:focus-visible,
.icon-action-btn:focus-visible,
.court-opt:focus-visible {
  outline: 2px solid rgba(17, 184, 154, 0.45);
  outline-offset: 3px;
}

* {
  -webkit-tap-highlight-color: transparent;
}


/* Settings player status filter */
.player-status-filter-bar{
  display:flex;
  gap:7px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:2px 1px 10px;
  margin:0 0 4px;
}
.player-status-filter-bar::-webkit-scrollbar{display:none}
.player-filter-chip{
  flex:0 0 auto;
  border:1px solid var(--border);
  background:rgba(255,255,255,.68);
  color:var(--muted);
  border-radius:999px;
  padding:7px 10px;
  min-height:34px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  transition:background .15s,border-color .15s,color .15s,transform .15s;
}
.player-filter-chip:active{transform:scale(.97)}
.player-filter-chip strong{
  min-width:22px;
  height:22px;
  padding:0 7px;
  border-radius:999px;
  background:rgba(125,132,145,.10);
  color:var(--text);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:900;
  line-height:1;
}
.player-filter-chip.active{
  color:var(--accent);
  border-color:rgba(17,184,154,.36);
  background:rgba(17,184,154,.09);
}
.player-filter-chip.active strong{
  background:rgba(17,184,154,.14);
  color:var(--accent);
}
.player-filter-chip.ready.active{color:var(--ready);border-color:rgba(17,184,154,.36);background:rgba(17,184,154,.09)}
.player-filter-chip.queued.active{color:var(--playing);border-color:rgba(229,155,34,.34);background:rgba(229,155,34,.09)}
.player-filter-chip.playing.active{color:var(--playing);border-color:rgba(229,155,34,.34);background:rgba(229,155,34,.09)}
.player-filter-chip.rest.active{color:var(--rest);border-color:rgba(124,131,238,.34);background:rgba(124,131,238,.09)}
.player-filter-chip.out.active{color:var(--out);border-color:rgba(220,91,91,.30);background:rgba(220,91,91,.07)}
html[data-theme="dark"] .player-filter-chip{
  background:rgba(22,33,62,.70);
  border-color:var(--border);
}
html[data-theme="dark"] .player-filter-chip strong{
  background:rgba(136,136,170,.13);
  color:var(--text);
}
html[data-theme="dark"] .player-filter-chip.active{
  border-color:rgba(0,212,170,.30);
  background:rgba(0,212,170,.08);
}

/* v16 Session + Queue explanation */
.session-summary-card{
  margin:12px 0 14px;
  border:1px solid rgba(17,184,154,.18);
  background:linear-gradient(135deg, rgba(17,184,154,.08), rgba(124,131,238,.05));
  border-radius:16px;
  padding:12px;
}
.session-summary-empty{
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
.session-summary-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.session-label{
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.session-title{
  color:var(--text);
  font-size:14px;
  font-weight:900;
  margin-top:2px;
}
.session-status-pill{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--accent);
  background:rgba(17,184,154,.10);
  border:1px solid rgba(17,184,154,.22);
  border-radius:999px;
  padding:4px 9px;
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
}
.session-meta-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:10px;
}
.session-meta-grid>div{
  background:rgba(255,255,255,.45);
  border:1px solid rgba(125,132,145,.12);
  border-radius:12px;
  padding:8px;
  min-width:0;
}
.session-meta-grid strong{
  display:block;
  color:var(--text);
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.session-meta-grid span{
  display:block;
  color:var(--muted);
  font-size:10.5px;
  font-weight:700;
  margin-top:1px;
}
html[data-theme="dark"] .session-summary-card{
  background:linear-gradient(135deg, rgba(0,212,170,.10), rgba(99,102,241,.06));
  border-color:rgba(0,212,170,.22);
}
html[data-theme="dark"] .session-meta-grid>div{
  background:rgba(22,33,62,.52);
  border-color:rgba(148,163,184,.12);
}
.court-info-btn{
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(17,184,154,.26);
  background:rgba(17,184,154,.08);
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:ui-serif, Georgia, serif;
  font-size:15px;
  font-style:italic;
  font-weight:900;
  cursor:pointer;
  transition:all .15s;
}
.court-info-btn:hover{
  background:rgba(17,184,154,.14);
  transform:translateY(-1px);
}
.court-info-btn:active{transform:scale(.95)}
.queue-explain-sheet{max-width:560px}
.queue-explain-content{display:grid;gap:12px}
.queue-explain-section{
  border:1px solid rgba(125,132,145,.14);
  background:var(--bg3);
  border-radius:16px;
  padding:12px;
}
.queue-explain-title{
  color:var(--muted);
  font-size:11.5px;
  font-weight:900;
  letter-spacing:.45px;
  text-transform:uppercase;
  margin-bottom:9px;
}
.queue-explain-player-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.queue-explain-player{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:9px;
  min-width:0;
}
.queue-explain-player strong{
  display:block;
  color:var(--text);
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.queue-explain-player span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:700;
  margin-top:2px;
}
.queue-explain-rules{
  padding-left:18px;
  color:var(--text);
  font-size:13px;
  font-weight:650;
}
.queue-explain-rules li{margin:5px 0}
.queue-explain-teams{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.queue-explain-team{
  border-radius:14px;
  padding:10px;
  border:1px solid var(--border);
  background:var(--card);
  min-width:0;
}
.queue-explain-team span{
  display:block;
  font-size:11px;
  font-weight:900;
  letter-spacing:.4px;
  text-transform:uppercase;
}
.queue-explain-team strong{
  display:block;
  color:var(--text);
  font-size:13px;
  font-weight:900;
  margin-top:2px;
  overflow:hidden;
  text-overflow:ellipsis;
}
.queue-explain-team em{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-style:normal;
  font-weight:700;
  margin-top:2px;
}
.team-a-explain span{color:var(--teamA)}
.team-b-explain span{color:var(--teamB)}
.queue-explain-metric-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;
  margin-top:9px;
}
.queue-explain-metric-grid>div{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:8px 5px;
  text-align:center;
  min-width:0;
}
.queue-explain-metric-grid strong{
  display:block;
  color:var(--accent);
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.queue-explain-metric-grid span{
  display:block;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  margin-top:1px;
}
.queue-alt-list{display:grid;gap:7px}
.queue-alt-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:9px;
}
.queue-alt-row.best{
  border-color:rgba(17,184,154,.34);
  background:rgba(17,184,154,.06);
}
.queue-alt-row strong{
  display:block;
  color:var(--text);
  font-size:12px;
  font-weight:900;
}
.queue-alt-row span{
  display:block;
  color:var(--muted);
  font-size:10.5px;
  font-weight:750;
  margin-top:1px;
}
.queue-alt-row em{
  flex-shrink:0;
  color:var(--accent);
  background:rgba(17,184,154,.10);
  border-radius:999px;
  padding:3px 8px;
  font-size:10.5px;
  font-style:normal;
  font-weight:900;
}
.queue-explain-actions{margin-top:12px}
@media(max-width:420px){
  .session-meta-grid,
  .queue-explain-player-list,
  .queue-explain-teams{grid-template-columns:1fr}
  .queue-explain-metric-grid{grid-template-columns:1fr 1fr}
  .queue-alt-row{align-items:flex-start;flex-direction:column}
}

/* v16.1 hotfix: reset/session button is intentionally clickable even when muted */
.reset-day-main-btn{cursor:pointer!important;opacity:1!important}
.reset-day-main-btn.has-active-courts{border-color:rgba(217,119,6,.32)!important;background:rgba(217,119,6,.06)!important;color:var(--playing)!important}
.reset-day-main-btn.is-disabled{opacity:.72!important;cursor:not-allowed!important}


/* v16.2 Session lifecycle refinement */
.session-summary-empty strong{
  display:block;
  font-size:14px;
  color:var(--text);
  margin-bottom:4px;
}
.session-summary-empty span{
  display:block;
  font-size:12px;
  color:var(--muted);
}
.session-status-pill.is-stale{
  background:rgba(245,158,11,.14)!important;
  color:var(--playing)!important;
  border-color:rgba(245,158,11,.35)!important;
}
.session-stale-note{
  margin-top:10px;
  padding:9px 11px;
  border-radius:12px;
  background:rgba(245,158,11,.08);
  border:1px solid rgba(245,158,11,.20);
  color:var(--muted);
  font-size:12px;
}

/* V17: Session history / ดูสรุปย้อนหลัง */
.session-history-card{border-color:rgba(17,184,154,.18)!important}
.session-history-card-title{align-items:center}
.session-history-main-btn{
  margin-top:14px;
  justify-content:flex-start;
  text-align:left;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
}
.session-history-main-btn small{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-top:2px}
.session-history-btn-icon{
  width:34px;height:34px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(17,184,154,.1);color:var(--accent);flex-shrink:0;
}
.session-history-btn-icon svg{width:18px;height:18px}
.session-history-modal-sheet{max-width:720px;width:min(94vw,720px)}
.session-history-list{display:flex;flex-direction:column;gap:10px}
.session-accordion-head .expense-accordion-side{min-width:96px}
.session-history-expense-total{font-size:12px;font-weight:800;color:var(--accent);margin-top:2px;white-space:nowrap}
.session-status-mini{
  display:inline-flex;align-items:center;justify-content:center;
  margin-top:5px;padding:2px 8px;border-radius:999px;
  font-size:10px;font-weight:800;border:1px solid var(--border);white-space:nowrap;
}
.session-status-mini.active{color:var(--accent);background:rgba(17,184,154,.08);border-color:rgba(17,184,154,.28)}
.session-status-mini.closed{color:var(--muted);background:rgba(125,132,145,.08)}
.session-summary-grid{grid-template-columns:repeat(4,1fr)}
.session-player-list{display:flex;flex-wrap:wrap;gap:6px}
.session-player-list span{
  padding:5px 9px;border-radius:999px;background:var(--bg3);
  border:1px solid var(--border);font-size:12px;font-weight:700;color:var(--text);
}
.session-player-list em{font-style:normal;color:var(--muted);font-size:13px}
.session-match-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:rgba(255,255,255,.42)}
.session-match-row{padding:10px 12px;border-bottom:1px solid var(--border)}
.session-match-row:last-child{border-bottom:0}
.session-match-main{display:flex;gap:7px;align-items:center;flex-wrap:wrap;font-size:13px;font-weight:800}
.session-match-main span{color:var(--muted);font-weight:700}
.session-match-meta{font-size:11px;color:var(--muted);margin-top:3px;display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.session-match-meta .winner-badge{padding:1px 7px;font-size:10px;border-radius:999px}
.session-more-note{padding:9px 12px;font-size:12px;color:var(--muted);background:var(--bg3);text-align:center}
.session-expense-section{display:flex;flex-direction:column;gap:10px}
.session-expense-card{
  border:1px solid var(--border);border-radius:16px;padding:13px;
  background:rgba(255,255,255,.52);
}
.session-expense-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.session-expense-title{font-size:14px;font-weight:900;color:var(--text)}
.session-expense-subtitle{font-size:11px;color:var(--muted);margin-top:2px}
.session-expense-total{font-size:16px;font-weight:900;color:var(--accent);white-space:nowrap}
.session-expense-grid{grid-template-columns:repeat(3,1fr);margin-bottom:12px}
.session-expense-line{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 0;border-bottom:1px solid var(--border);font-size:13px;
}
.session-expense-line:last-child{border-bottom:0}
.session-expense-line span{color:var(--text);font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.session-expense-line strong{font-size:13px;white-space:nowrap}
.session-expense-line.pay strong{color:var(--out)}
.session-expense-line.receive strong{color:var(--accent)}
.session-expense-line.clear strong{color:var(--muted)}
.session-expense-actions{margin-top:10px;display:flex;justify-content:flex-end}

html[data-theme="dark"] .session-match-list,
html[data-theme="dark"] .session-expense-card{background:rgba(22,33,62,.42)}

@media(max-width:560px){
  .session-summary-grid,.session-expense-grid{grid-template-columns:1fr 1fr}
  .session-expense-head{flex-direction:column}
  .session-expense-total{font-size:15px}
  .session-accordion-head .expense-accordion-side{min-width:86px}
  .session-expense-line{align-items:flex-start;flex-direction:column;gap:2px}
  .session-expense-line strong{white-space:normal}
}

/* V17.1: Cleaner session summary history layout */
.session-history-card .card-title{margin-bottom:8px}
.session-history-main-btn{margin-top:12px;background:linear-gradient(180deg,rgba(255,255,255,.75),rgba(255,255,255,.45))!important;border-color:rgba(17,184,154,.22)!important}
html[data-theme="dark"] .session-history-main-btn{background:rgba(22,33,62,.5)!important}
.session-history-modal-sheet{max-width:760px;width:min(94vw,760px)}
.session-history-list{gap:12px}
.session-history-item{border-radius:18px!important;overflow:hidden;background:rgba(255,255,255,.72)!important;border-color:rgba(226,232,240,.9)!important;box-shadow:0 12px 28px rgba(70,76,90,.06)}
html[data-theme="dark"] .session-history-item{background:rgba(30,30,53,.88)!important;border-color:var(--border)!important;box-shadow:none}
.session-history-head{display:flex!important;align-items:stretch!important;justify-content:space-between!important;gap:14px!important;padding:15px!important;text-align:left!important;background:transparent!important}
.session-history-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.session-history-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;min-width:0}
.session-history-title{font-size:16px!important;font-weight:900!important;color:var(--text);min-width:0;flex:1;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
.session-status-mini{flex-shrink:0;align-self:flex-start;max-width:96px;text-align:center}
.session-history-meta-row{font-size:12px;color:var(--muted);line-height:1.55}
.session-history-players-row{font-size:12px;color:var(--text);line-height:1.55;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.86}
.session-history-metrics{display:flex;align-items:center;gap:8px;flex-shrink:0}
.session-history-metric{min-width:66px;padding:8px 10px;border-radius:13px;background:var(--bg3);border:1px solid var(--border);text-align:center}
.session-history-metric strong{display:block;font-size:14px;font-weight:900;color:var(--text);white-space:nowrap;max-width:108px;overflow:hidden;text-overflow:ellipsis}
.session-history-metric span{display:block;font-size:10px;color:var(--muted);font-weight:800;margin-top:2px}
.session-history-metric.accent strong{color:var(--accent)}
.session-history-head .expense-accordion-chevron{align-self:center;margin-left:2px}
.session-history-expand-hint{display:none;align-items:center;justify-content:space-between;gap:10px;width:100%;margin-top:2px;padding:10px 4px 2px;border-top:1px dashed rgba(17,184,154,.2);color:var(--muted);font-size:12px;font-weight:800;letter-spacing:.01em}
.session-history-expand-hint .session-hint-label{display:inline-flex;align-items:center;gap:6px;min-width:0}
.session-history-expand-hint .session-hint-open{display:none}
.session-history-expand-hint .session-hint-arrow{flex:0 0 auto;color:var(--accent);background:transparent!important}
.session-history-item.open .session-hint-closed{display:none}
.session-history-item.open .session-hint-open{display:inline-flex}
.session-history-item.open .session-history-expand-hint .session-hint-arrow::before{transform:rotate(-40deg)}
.session-history-item.open .session-history-expand-hint .session-hint-arrow::after{transform:rotate(40deg)}
.session-history-head:hover .session-history-expand-hint{border-color:rgba(17,184,154,.34);color:var(--text)}
html[data-theme="dark"] .session-history-expand-hint{border-top-color:rgba(94,234,212,.22);color:rgba(230,238,252,.72)}
.session-accordion-body{padding:0 15px 15px!important;background:transparent!important}
.session-summary-grid{grid-template-columns:repeat(5,1fr);gap:8px;margin-top:2px;margin-bottom:14px}
.session-summary-grid>div,.session-expense-grid>div{border-radius:14px!important;padding:11px!important;background:var(--bg3)!important;border:1px solid var(--border)!important}
.compact-section{margin-top:12px!important;padding-top:12px!important;border-top:1px solid var(--border)}
.session-player-list{gap:7px}
.session-player-list span{background:rgba(17,184,154,.08);border-color:rgba(17,184,154,.18);color:var(--text)}
.session-match-list{border-radius:14px;background:rgba(255,255,255,.5);border-color:var(--border)}
.session-expense-card{padding:14px;border-radius:18px;background:rgba(255,255,255,.58);box-shadow:0 10px 24px rgba(70,76,90,.05)}
html[data-theme="dark"] .session-expense-card{background:rgba(22,33,62,.42);box-shadow:none}
.session-expense-venue-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;margin-bottom:10px;border-radius:14px;background:rgba(17,184,154,.07);border:1px solid rgba(17,184,154,.18)}
.session-expense-venue-row span{font-size:12px;font-weight:800;color:var(--muted)}
.session-expense-venue-row strong{font-size:14px;font-weight:900;color:var(--text);text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.session-expense-subgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
.session-expense-subgrid .expense-detail-section{margin-top:0!important;padding-top:0!important;border-top:0!important}
.session-expense-line{padding:8px 0}
.session-expense-actions{border-top:1px solid var(--border);padding-top:10px}

@media(max-width:820px){
  .session-history-head{flex-direction:column;gap:11px!important}
  .session-history-metrics{width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
  .session-history-metric{min-width:0}
  .session-history-metric strong{max-width:100%}
  .session-history-head .expense-accordion-chevron{display:none}
  .session-history-expand-hint{display:flex}
}
@media(max-width:680px){
  .session-history-title{font-size:15px!important;-webkit-line-clamp:2}
  .session-history-topline{gap:8px}
  .session-status-mini{max-width:none}
  .session-history-metrics{grid-template-columns:1fr 1fr 1.2fr}
  .session-summary-grid{grid-template-columns:1fr 1fr}
  .session-expense-subgrid{grid-template-columns:1fr}
}
@media(max-width:520px){
  .session-history-topline{align-items:flex-start}
  .session-history-title{font-size:15px!important;line-height:1.32}
  .session-history-metrics{grid-template-columns:1fr 1fr;align-items:stretch}
  .session-history-metric.accent{grid-column:span 2}
}
@media(max-width:420px){
  .session-history-expand-hint{padding:9px 2px 1px;font-size:11.5px}
  .session-expense-venue-row{align-items:flex-start;flex-direction:column;gap:2px}
  .session-expense-venue-row strong{text-align:left;white-space:normal}
}


/* V17.2: Move summary history entry to Stats + cleaner session summary cards */
.stats-history-entry-btn{
  appearance:none;
  border:1px solid rgba(17,184,154,.24);
  background:linear-gradient(135deg,rgba(17,184,154,.12),rgba(109,93,252,.06));
  color:var(--text);
  border-radius:18px;
  padding:10px 13px;
  font-family:inherit;
  display:inline-flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  min-width:188px;
  justify-content:flex-start;
  box-shadow:0 12px 26px rgba(70,76,90,.07);
}
.stats-history-entry-btn:active{transform:scale(.98)}
.stats-history-entry-icon{
  width:34px;height:34px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(17,184,154,.12);color:var(--accent);flex-shrink:0;
}
.stats-history-entry-icon svg{width:18px;height:18px}
.stats-history-entry-btn strong{display:block;font-size:13px;font-weight:900;line-height:1.15;white-space:nowrap}
.stats-history-entry-btn small{display:block;font-size:11px;font-weight:700;color:var(--muted);line-height:1.25;margin-top:2px;white-space:nowrap}
html[data-theme="dark"] .stats-history-entry-btn{
  background:linear-gradient(135deg,rgba(0,212,170,.10),rgba(124,58,237,.10));
  border-color:rgba(0,212,170,.22);
  box-shadow:none;
}

.session-summary-grid{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
}
.session-summary-grid>div{
  min-width:0;
  min-height:74px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
}
.session-summary-grid>div:first-child{
  grid-column:span 2;
}
.session-summary-grid>div span{
  display:block;
  font-size:11px!important;
  line-height:1.25!important;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:var(--muted)!important;
}
.session-summary-grid>div strong{
  display:block;
  font-size:15px!important;
  line-height:1.35!important;
  word-break:keep-all;
  overflow-wrap:normal;
}
.session-summary-grid>div:not(:first-child) strong{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

@media(max-width:680px){
  .stats-dashboard-head{flex-direction:column;align-items:stretch}
  .stats-history-entry-btn{width:100%;justify-content:center;min-width:0}
  .session-summary-grid{grid-template-columns:1fr 1fr!important}
  .session-summary-grid>div:first-child{grid-column:1 / -1}
}
@media(max-width:420px){
  .session-summary-grid{grid-template-columns:1fr!important}
  .session-summary-grid>div:first-child{grid-column:auto}
  .session-summary-grid>div{min-height:auto;align-items:flex-start}
  .session-summary-grid>div:not(:first-child) strong{white-space:normal}
}


/* V17.4: Main flow navigation + header settings */
.topbar{position:sticky!important;top:0!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0 56px!important}
.topbar-actions{position:absolute;right:14px;display:flex;align-items:center;gap:12px}
.header-settings-btn{width:36px;height:36px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;box-shadow:0 8px 24px rgba(31,41,55,.08)}
.header-settings-btn svg{width:18px;height:18px}
.header-settings-btn:hover,.header-settings-btn.active{color:var(--accent);border-color:rgba(17,184,154,.38);background:rgba(17,184,154,.08)}
.header-settings-btn:active{transform:scale(.96)}
.header-settings-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(17,184,154,.16)}
.topbar-actions .sync-dot{position:static!important;right:auto!important;flex:0 0 auto}
.main-bottom-nav .nav-btn{font-size:11px;font-weight:800}
.main-bottom-nav .nav-btn#nav-expense.active{color:var(--accent)}
.main-bottom-nav .nav-btn#nav-expense.active svg{filter:drop-shadow(0 4px 10px rgba(17,184,154,.18))}
.page.is-expense-mode .settings-head,
.page.is-expense-mode .settings-tabs{display:none!important}
.page.is-expense-mode .settings-expense-panel{padding-top:0}
.page.is-expense-mode .expense-header{margin-top:0}
html[data-theme="dark"] .header-settings-btn{background:rgba(22,33,62,.86);border-color:var(--border);color:var(--muted);box-shadow:none}
html[data-theme="dark"] .header-settings-btn:hover,
html[data-theme="dark"] .header-settings-btn.active{color:var(--accent);background:rgba(0,212,170,.10);border-color:rgba(0,212,170,.32)}
@media(max-width:420px){
  .topbar{padding:0 54px!important}
  .topbar-logo{font-size:15px!important;max-width:210px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .topbar-actions{right:10px;gap:10px}
  .header-settings-btn{width:34px;height:34px}
}

/* V17.4: Make expense save action more prominent */
.expense-actions{grid-template-columns:1.18fr .92fr!important;gap:10px!important;margin-top:16px!important}
.expense-actions .btn{min-height:48px!important;border-radius:14px!important;font-size:14px!important}
.btn-expense-save{background:linear-gradient(135deg,#15c8aa,#0ea889)!important;color:#fff!important;border:1px solid rgba(17,184,154,.42)!important;font-weight:900!important;box-shadow:0 12px 28px rgba(17,184,154,.24)!important}
.btn-expense-save:hover{transform:translateY(-1px);box-shadow:0 16px 32px rgba(17,184,154,.28)!important}
.btn-expense-save:active{transform:scale(.985)!important}
.btn-expense-copy{background:rgba(255,255,255,.72)!important;color:var(--text)!important;border:1px solid var(--border)!important;font-weight:800!important}
html[data-theme="dark"] .btn-expense-copy{background:rgba(22,33,62,.72)!important;color:var(--text)!important;border-color:var(--border)!important}
@media(max-width:420px){
  .expense-actions{grid-template-columns:1fr!important}
  .btn-expense-save{min-height:52px!important;font-size:15px!important}
}


/* V17.5: Expense save completion CTA */
.expense-save-cta-sheet{max-width:480px;width:min(94vw,480px)}
.expense-save-cta-card{display:flex;gap:12px;align-items:flex-start;padding:14px;border-radius:18px;background:linear-gradient(135deg,rgba(17,184,154,.12),rgba(17,184,154,.04));border:1px solid rgba(17,184,154,.22);margin-bottom:14px}
.expense-save-cta-icon{width:42px;height:42px;border-radius:999px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 10px 22px rgba(17,184,154,.24)}
.expense-save-cta-icon svg{width:22px;height:22px}
.expense-save-cta-heading{font-size:16px;font-weight:900;color:var(--text);line-height:1.3;margin-bottom:3px}
.expense-save-cta-text{font-size:13px;color:var(--muted);line-height:1.55}
.expense-save-cta-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.expense-save-cta-actions .btn{min-height:48px;border-radius:14px;font-size:14px;font-weight:900}
.expense-close-session-btn{background:linear-gradient(135deg,#15c8aa,#0ea889)!important;color:#fff!important;box-shadow:0 12px 26px rgba(17,184,154,.22)!important}
.expense-save-cta-later{grid-column:1 / -1;background:transparent!important;border:1px solid transparent!important;color:var(--muted)!important;font-weight:800!important}
.expense-save-cta-later:hover{background:rgba(125,132,145,.08)!important;border-color:rgba(125,132,145,.12)!important;color:var(--text)!important}
html[data-theme="dark"] .expense-save-cta-card{background:linear-gradient(135deg,rgba(0,212,170,.14),rgba(22,33,62,.42));border-color:rgba(0,212,170,.22)}
html[data-theme="dark"] .expense-save-cta-icon{color:#0f0f1a}
@media(max-width:420px){
  .expense-save-cta-actions{grid-template-columns:1fr}
  .expense-save-cta-later{grid-column:auto}
}


/* V17.6: Header polish - balanced app bar and compact settings/status cluster */
.topbar{
  height:64px!important;
  padding:0 max(14px,calc((100vw - 520px)/2 + 14px))!important;
  display:grid!important;
  grid-template-columns:42px minmax(0,1fr) 42px!important;
  align-items:center!important;
  justify-content:normal!important;
  gap:10px!important;
}
.theme-toggle{
  position:static!important;
  grid-column:1!important;
  justify-self:start!important;
  width:38px!important;
  height:38px!important;
  border-radius:999px!important;
  box-shadow:0 10px 26px rgba(31,41,55,.09)!important;
}
.topbar-logo{
  grid-column:2!important;
  justify-self:center!important;
  max-width:100%!important;
  text-align:center!important;
  font-size:15px!important;
  line-height:1.2!important;
  font-weight:900!important;
  letter-spacing:-.2px!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  padding:0 4px!important;
}
.topbar-actions{
  position:relative!important;
  right:auto!important;
  grid-column:3!important;
  justify-self:end!important;
  width:42px!important;
  height:42px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:0!important;
}
.header-settings-btn{
  width:38px!important;
  height:38px!important;
  border-radius:999px!important;
  box-shadow:0 10px 26px rgba(31,41,55,.09)!important;
}
.header-settings-btn svg{width:18px!important;height:18px!important}
.topbar-actions .sync-dot{
  position:absolute!important;
  right:2px!important;
  top:8px!important;
  width:9px!important;
  height:9px!important;
  border:2px solid var(--card)!important;
  box-shadow:none!important;
  pointer-events:none!important;
}
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .header-settings-btn{
  box-shadow:none!important;
}
html[data-theme="dark"] .topbar-actions .sync-dot{
  border-color:#1a1a2e!important;
}
@media(max-width:420px){
  .topbar{
    height:60px!important;
    padding:0 12px!important;
    grid-template-columns:38px minmax(0,1fr) 38px!important;
    gap:8px!important;
  }
  .theme-toggle,
  .header-settings-btn{
    width:35px!important;
    height:35px!important;
  }
  .topbar-actions{width:38px!important;height:38px!important;right:auto!important;gap:0!important}
  .topbar-logo{font-size:14px!important;max-width:100%!important;padding:0!important}
  .topbar-actions .sync-dot{right:1px!important;top:7px!important;width:8px!important;height:8px!important}
}


/* V17.7: Desktop header alignment fix
   - Remove oversized dynamic padding from v17.6
   - Make header and bottom nav use the same container width
   - Keep title centered and buttons balanced on desktop/tablet/mobile
*/
.topbar{
  box-sizing:border-box!important;
  position:sticky!important;
  top:0!important;
  z-index:100!important;
  height:64px!important;
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  padding:0 14px!important;
  display:grid!important;
  grid-template-columns:42px minmax(0,1fr) 42px!important;
  align-items:center!important;
  gap:10px!important;
  left:auto!important;
  right:auto!important;
  transform:none!important;
  border-left:0!important;
  border-right:0!important;
  border-radius:0 0 20px 20px!important;
}

.topbar .theme-toggle{
  grid-column:1!important;
  justify-self:start!important;
  width:38px!important;
  height:38px!important;
  margin:0!important;
}

.topbar-logo{
  grid-column:2!important;
  justify-self:center!important;
  min-width:0!important;
  max-width:100%!important;
  padding:0 8px!important;
  text-align:center!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  font-size:15px!important;
  font-weight:900!important;
  line-height:1.2!important;
}

.topbar-actions{
  grid-column:3!important;
  justify-self:end!important;
  position:relative!important;
  right:auto!important;
  width:42px!important;
  height:42px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:0!important;
}

.header-settings-btn{
  width:38px!important;
  height:38px!important;
  margin:0!important;
  flex:0 0 auto!important;
}

.topbar-actions .sync-dot{
  position:absolute!important;
  right:2px!important;
  top:7px!important;
  width:9px!important;
  height:9px!important;
  border:2px solid var(--card)!important;
  box-shadow:none!important;
  flex:0 0 auto!important;
  pointer-events:none!important;
}

@media(min-width:720px){
  .topbar,
  .bottom-nav{
    width:min(calc(100% - 40px),760px)!important;
    max-width:760px!important;
  }
  .topbar{
    margin-left:auto!important;
    margin-right:auto!important;
    padding:0 16px!important;
    border-left:1px solid var(--border)!important;
    border-right:1px solid var(--border)!important;
    border-radius:0 0 22px 22px!important;
  }
  .bottom-nav{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
  }
}

@media(min-width:768px) and (max-width:1023px){
  .topbar,
  .bottom-nav{
    width:min(calc(100% - 48px),820px)!important;
    max-width:820px!important;
  }
}

@media(min-width:1024px){
  .topbar,
  .bottom-nav{
    width:min(calc(100% - 64px),920px)!important;
    max-width:920px!important;
  }
  .topbar{
    height:62px!important;
    grid-template-columns:44px minmax(0,1fr) 44px!important;
    padding:0 18px!important;
  }
  .topbar-logo{font-size:16px!important;letter-spacing:-.25px!important}
}

@media(min-width:1280px){
  .topbar,
  .bottom-nav{
    width:min(calc(100% - 96px),1040px)!important;
    max-width:1040px!important;
  }
}

@media(max-width:420px){
  .topbar{
    height:60px!important;
    padding:0 12px!important;
    grid-template-columns:38px minmax(0,1fr) 38px!important;
    gap:8px!important;
  }
  .topbar .theme-toggle,
  .header-settings-btn{
    width:35px!important;
    height:35px!important;
  }
  .topbar-actions{width:38px!important;height:38px!important}
  .topbar-logo{font-size:14px!important;padding:0 4px!important}
  .topbar-actions .sync-dot{right:1px!important;top:6px!important;width:8px!important;height:8px!important}
}


/* v17.12: Closed/idle visual state for no active Session */
.session-summary-empty{
  border:1px solid rgba(148,163,184,.30)!important;
  background:linear-gradient(135deg, rgba(148,163,184,.13), rgba(248,113,113,.055))!important;
  border-radius:16px!important;
  padding:16px 18px!important;
  position:relative!important;
  overflow:hidden!important;
}
.session-summary-empty::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  background:#94a3b8;
  position:absolute;
  top:17px;
  right:17px;
  box-shadow:0 0 0 4px rgba(148,163,184,.14);
}
.session-summary-empty::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:radial-gradient(circle at 100% 0%, rgba(148,163,184,.12), transparent 34%);
}
.session-summary-empty strong{
  display:block;
  font-size:14px;
  font-weight:900;
  color:var(--text);
  margin-bottom:4px;
  padding-right:28px;
}
.session-summary-empty span{
  display:block;
  font-size:12px;
  color:var(--muted);
  line-height:1.5;
  padding-right:28px;
}
html[data-theme="dark"] .session-summary-empty{
  background:linear-gradient(135deg, rgba(71,85,105,.26), rgba(127,29,29,.10))!important;
  border-color:rgba(148,163,184,.20)!important;
}
html[data-theme="dark"] .session-summary-empty::before{
  background:#94a3b8;
  box-shadow:0 0 0 4px rgba(148,163,184,.12);
}
html[data-theme="dark"] .session-summary-empty::after{
  background:radial-gradient(circle at 100% 0%, rgba(148,163,184,.12), transparent 36%);
}

/* V17.13: Session history slide-to-detail flow */
.session-history-modal-sheet{
  max-width:820px!important;
  width:min(94vw,820px)!important;
}
.session-history-list{
  display:block!important;
  overflow:hidden!important;
}
.session-history-slider{
  width:200%;
  display:flex;
  align-items:flex-start;
  transition:transform .28s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.session-history-slider.show-detail{
  transform:translateX(-50%);
}
.session-history-panel{
  width:50%;
  flex:0 0 50%;
  min-width:0;
}
.session-history-panel-list,
.session-history-panel-detail{
  padding:0;
}
.session-history-list-stack{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.session-history-head{
  cursor:pointer;
  align-items:center!important;
}
.session-history-main{
  gap:8px!important;
}
.session-history-topline{
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:14px!important;
}
.session-history-title{
  flex:1 1 auto!important;
  min-width:0!important;
  display:block!important;
  overflow:visible!important;
  text-overflow:clip!important;
  white-space:normal!important;
  word-break:normal!important;
  overflow-wrap:anywhere;
  -webkit-line-clamp:unset!important;
  -webkit-box-orient:unset!important;
  line-height:1.32!important;
}
.session-status-mini{
  margin-top:0!important;
  margin-left:auto!important;
  flex:0 0 auto!important;
  align-self:flex-start!important;
}
.session-history-meta-row{
  display:none!important;
}
.session-history-players-row{
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden!important;
}
.session-history-next-chevron{
  transform:rotate(-90deg);
  margin-left:2px;
}
.session-history-head:hover .session-history-next-chevron::before,
.session-history-head:hover .session-history-next-chevron::after{
  background:var(--accent);
}
.session-history-expand-hint .session-hint-open{
  display:none!important;
}
.session-history-item.open .session-hint-closed{
  display:inline-flex!important;
}
.session-history-item.open .session-history-expand-hint .session-hint-arrow::before,
.session-history-item.open .session-history-expand-hint .session-hint-arrow::after{
  transform:initial!important;
}

.session-detail-view{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-left:2px;
}
.session-detail-nav{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.session-detail-back-btn{
  appearance:none;
  border:1px solid var(--border);
  background:var(--bg3);
  color:var(--text);
  border-radius:999px;
  padding:8px 12px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  transition:.15s ease;
}
.session-detail-back-btn:hover{
  border-color:rgba(17,184,154,.28);
  background:rgba(17,184,154,.08);
  transform:translateX(-1px);
}
.session-detail-back-btn span{
  color:var(--accent);
  font-size:14px;
  line-height:1;
}
.session-detail-back-btn strong{
  font-size:12px;
  font-weight:900;
}
.session-detail-hero{
  border:1px solid rgba(17,184,154,.20);
  background:linear-gradient(135deg,rgba(17,184,154,.10),rgba(109,93,252,.045));
  border-radius:20px;
  padding:16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.session-detail-title-wrap{
  min-width:0;
  flex:1;
}
.session-detail-kicker{
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  letter-spacing:.45px;
  text-transform:uppercase;
  margin-bottom:4px;
}
.session-detail-title{
  color:var(--text);
  font-size:20px;
  font-weight:950;
  line-height:1.25;
  overflow-wrap:anywhere;
}
.session-detail-players{
  margin-top:8px;
  color:var(--muted);
  font-size:13px;
  font-weight:750;
  line-height:1.45;
}
.session-detail-summary-grid{
  margin-top:0!important;
}
.session-detail-actions{
  justify-content:flex-end;
}
.session-detail-empty{
  border:1px dashed var(--border);
  border-radius:18px;
  padding:24px;
  text-align:center;
  color:var(--muted);
  background:var(--bg3);
}
html[data-theme="dark"] .session-detail-hero{
  background:linear-gradient(135deg,rgba(17,184,154,.12),rgba(99,102,241,.10));
  border-color:rgba(94,234,212,.22);
}

@media(max-width:820px){
  .session-history-head{
    align-items:stretch!important;
  }
  .session-history-next-chevron{
    display:none!important;
  }
  .session-history-expand-hint .session-hint-arrow{
    transform:rotate(-90deg);
  }
  .session-history-title{
    font-size:15px!important;
    line-height:1.35!important;
  }
}
@media(max-width:680px){
  .session-history-modal-sheet{
    width:min(94vw,620px)!important;
  }
  .session-detail-title{
    font-size:18px;
  }
  .session-detail-hero{
    padding:14px;
    border-radius:18px;
  }
}
@media(max-width:520px){
  .session-detail-hero{
    flex-direction:column;
    gap:10px;
  }
  .session-detail-hero .session-status-mini{
    margin-left:0!important;
  }
}


/* V17.15: Session history slide animation + minimal match expand/collapse */
.session-history-slider{
  transform:translateX(0);
  transition:transform .34s cubic-bezier(.22,.61,.36,1)!important;
}
.session-history-slider.show-detail{
  transform:translateX(-50%);
}
.session-history-slider.is-animating .session-history-panel{
  transition:opacity .24s ease, transform .34s cubic-bezier(.22,.61,.36,1);
}
.session-history-slider:not(.show-detail).is-animating .session-history-panel-detail,
.session-history-slider.show-detail.is-animating .session-history-panel-list{
  opacity:.28;
  transform:scale(.985);
}
.session-history-slider.show-detail.is-animating .session-history-panel-detail,
.session-history-slider:not(.show-detail).is-animating .session-history-panel-list{
  opacity:1;
  transform:scale(1);
}
.session-match-main-rows,
.session-match-extra-wrap{
  display:flex;
  flex-direction:column;
}
.session-match-extra-wrap{
  max-height:0;
  opacity:0;
  overflow:hidden;
  transition:max-height .22s ease, opacity .18s ease;
}
.session-match-list.is-expanded .session-match-extra-wrap{
  max-height:2400px;
  opacity:1;
}
.session-match-list.is-collapsed .session-match-main-rows .session-match-row:last-child{
  border-bottom:0;
}
.session-match-list.is-expanded .session-match-extra-wrap .session-match-row:last-child{
  border-bottom:0;
}
.session-match-toggle-link{
  margin:8px auto 0;
  padding:5px 4px;
  border:0;
  background:transparent;
  color:var(--muted);
  font-family:inherit;
  font-size:12px;
  font-weight:800;
  line-height:1.2;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:color .15s ease, opacity .15s ease;
}
.session-match-toggle-link:hover{
  color:var(--accent);
}
.session-match-toggle-link:active{
  opacity:.72;
}
.session-match-toggle-link.open .session-match-toggle-link.open html[data-theme="dark"] .session-match-toggle-link{
  color:rgba(230,238,252,.62);
}
html[data-theme="dark"] .session-match-toggle-link:hover{
  color:var(--accent);
}
@media(prefers-reduced-motion:reduce){
  .session-history-slider,
  .session-history-slider.is-animating .session-history-panel,
  .session-match-extra-wrap,
  }


/* V17.18: text-only match history expand/collapse */
.session-match-toggle-link{
  gap:0!important;
  display:inline-flex!important;
  width:auto!important;
}
.session-match-toggle-link .session-match-toggle-text{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.session-match-toggle-link .session-match-chevron,
.session-match-toggle-link .collapse-chevron{
  display:none!important;
}

/* =========================================================
   Check-in fairness update v18.3
   - ปุ่มเดียวสำหรับเริ่มรอบและอัปเดตผู้เข้าร่วมภายหลัง
   - ล็อกผู้เล่นที่เริ่มเล่น / อยู่ในคิว เพื่อป้องกันสถิติเพี้ยน
   ========================================================= */
.queue-generate-btn{
  white-space:nowrap;
}
.checkin-mode-note{
  border:1px solid rgba(245,158,11,.24);
  background:rgba(245,158,11,.09);
  color:#92400e;
  border-radius:14px;
  padding:10px 12px;
  font-size:12px;
  line-height:1.55;
  margin-bottom:12px;
}
.checkin-mode-note strong,
.checkin-mode-note b{
  font-weight:900;
}
.late-checkin-badge,
.checkin-lock-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:2px 7px;
  margin-left:5px;
  font-size:10.5px;
  font-weight:900;
  vertical-align:middle;
  white-space:nowrap;
}
.late-checkin-badge{
  background:rgba(245,158,11,.12);
  color:#b45309;
  border:1px solid rgba(245,158,11,.22);
}
.checkin-lock-badge{
  background:rgba(125,132,145,.10);
  color:var(--muted);
  border:1px solid rgba(125,132,145,.20);
}
.ready-player-chip.is-late-player{
  background:rgba(245,158,11,.045);
  border-radius:12px;
  padding-left:7px!important;
  padding-right:7px!important;
}
#checkin-modal.checkin-update-mode .checkin-player-row.will-join-later.selected{
  border-color:rgba(245,158,11,.38)!important;
  background:rgba(245,158,11,.10)!important;
}
#checkin-modal.checkin-update-mode .checkin-player-row.will-join-later input:checked + .checkin-box{
  border-color:#f59e0b!important;
  background:#f59e0b!important;
}
.checkin-player-row.is-locked{
  cursor:not-allowed;
  opacity:.78;
}
.checkin-player-row.is-locked .checkin-box{
  border-color:rgba(125,132,145,.32)!important;
  background:rgba(125,132,145,.22)!important;
}
.checkin-player-row.is-locked input:checked + .checkin-box::after{
  border-color:var(--muted)!important;
}
html[data-theme="dark"] .checkin-mode-note{
  color:#f6c177;
  border-color:rgba(246,179,95,.25);
  background:rgba(246,179,95,.11);
}
html[data-theme="dark"] .late-checkin-badge{
  color:#f6c177;
  border-color:rgba(246,179,95,.26);
  background:rgba(246,179,95,.13);
}
html[data-theme="dark"] .checkin-lock-badge{
  background:rgba(148,163,184,.10);
  border-color:rgba(148,163,184,.22);
  color:#aab7ca;
}
html[data-theme="dark"] .ready-player-chip.is-late-player{
  background:rgba(246,179,95,.065);
}
@media(max-width:520px){
  .checkin-player-name{
    white-space:normal!important;
    line-height:1.35;
  }
  .checkin-player-meta{
    line-height:1.45;
  }
}

/* V18.1: reuse previous session players for new Check-in */
.session-player-section-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.session-player-section-head .expense-detail-title{
  margin-bottom:2px!important;
}
.session-reuse-hint{
  color:var(--muted);
  font-size:11.5px;
  font-weight:700;
  line-height:1.45;
}
.session-reuse-checkin-btn{
  border:1px solid rgba(17,184,154,.24);
  background:rgba(17,184,154,.08);
  color:var(--accent);
  border-radius:999px;
  padding:8px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  white-space:nowrap;
  transition:all .15s;
  flex-shrink:0;
}
.session-reuse-checkin-btn:hover:not(:disabled){
  background:rgba(17,184,154,.14);
  border-color:rgba(17,184,154,.36);
  transform:translateY(-1px);
}
.session-reuse-checkin-btn:disabled{
  opacity:.42;
  cursor:not-allowed;
  filter:saturate(.5);
}
html[data-theme="dark"] .session-reuse-checkin-btn{
  background:rgba(45,212,191,.10);
  border-color:rgba(45,212,191,.25);
  color:#5eead4;
}
html[data-theme="dark"] .session-reuse-checkin-btn:hover:not(:disabled){
  background:rgba(45,212,191,.16);
  border-color:rgba(45,212,191,.38);
}
@media(max-width:560px){
  .session-player-section-head{
    flex-direction:column;
    align-items:stretch;
  }
  .session-reuse-checkin-btn{
    width:100%;
    justify-content:center;
  }
}

/* v19 Auth Gate + Room Context */
body.auth-checking,
body.auth-required,
body.auth-no-access{min-height:100vh;overflow:hidden;}
body.auth-checking .topbar,
body.auth-checking .page,
body.auth-checking .bottom-nav,
body.auth-required .topbar,
body.auth-required .page,
body.auth-required .bottom-nav,
body.auth-no-access .topbar,
body.auth-no-access .page,
body.auth-no-access .bottom-nav{display:none!important;}
.auth-screen{display:none;position:fixed;inset:0;z-index:450;padding:22px;align-items:center;justify-content:center;overflow:auto;background:radial-gradient(circle at 15% 15%, rgba(17,184,154,.18), transparent 34%),radial-gradient(circle at 88% 8%, rgba(139,124,246,.18), transparent 32%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);}
body.auth-checking .auth-screen,body.auth-required .auth-screen,body.auth-no-access .auth-screen{display:flex!important;}
body.auth-ready .auth-screen{display:none!important;}
.auth-bg-orb{position:absolute;border-radius:999px;filter:blur(2px);pointer-events:none;opacity:.55;}
.auth-orb-a{width:220px;height:220px;left:-70px;top:10%;background:rgba(17,184,154,.18);}
.auth-orb-b{width:260px;height:260px;right:-90px;bottom:8%;background:rgba(139,124,246,.14);}
.auth-card{position:relative;width:min(100%,440px);border:1px solid rgba(125,132,145,.18);background:rgba(255,255,255,.82);backdrop-filter:blur(18px);border-radius:28px;box-shadow:0 24px 70px rgba(31,41,55,.14);padding:22px;}
.auth-theme-toggle{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:999px;border:1px solid rgba(125,132,145,.18);background:rgba(255,255,255,.58);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;box-shadow:0 10px 24px rgba(31,41,55,.08);}
.auth-theme-toggle svg{width:17px;height:17px;}
.auth-theme-toggle:hover{color:var(--accent);border-color:rgba(17,184,154,.32);background:rgba(17,184,154,.08);}
.auth-theme-toggle:active{transform:scale(.96);}
.auth-brand{display:flex;align-items:center;gap:13px;margin-bottom:18px;padding-right:48px;}
.auth-logo-mark{width:48px;height:48px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(17,184,154,.16),rgba(139,124,246,.12));border:1px solid rgba(17,184,154,.18);font-size:13px;font-weight:950;letter-spacing:-.25px;color:var(--accent);}
.auth-title{font-size:20px;font-weight:900;letter-spacing:-.45px;color:var(--text);line-height:1.2;}
.auth-subtitle{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.45;}
.auth-panel{border:1px solid rgba(125,132,145,.14);background:rgba(255,255,255,.62);border-radius:22px;padding:16px;}
.auth-panel-title{font-size:17px;font-weight:900;color:var(--text);letter-spacing:-.25px;}
.auth-panel-desc{font-size:12.5px;color:var(--muted);margin:3px 0 14px;line-height:1.45;}
.auth-field{margin-bottom:12px;}
.auth-field label{display:block;font-size:12px;font-weight:900;color:var(--muted);margin-bottom:6px;}
.auth-field input{width:100%;background:var(--bg3)!important;border:1px solid var(--border)!important;color:var(--text)!important;border-radius:14px!important;padding:12px 14px!important;font-family:inherit;font-size:15px;}
.auth-error{margin:8px 0 12px;border:1px solid rgba(220,38,38,.18);background:rgba(220,38,38,.07);color:var(--out);border-radius:14px;padding:10px 12px;font-size:12px;font-weight:800;}
.auth-submit-btn,.auth-secondary-btn{width:100%;border:0;border-radius:15px;padding:12px 14px;font-family:inherit;font-size:15px;font-weight:900;cursor:pointer;transition:transform .15s ease, opacity .15s ease;}
.auth-submit-btn{background:linear-gradient(135deg,#18c5a8,#0ea889);color:#fff;box-shadow:0 14px 28px rgba(17,184,154,.18);}
.auth-secondary-btn{background:var(--bg3);color:var(--text);border:1px solid var(--border);margin-top:12px;}
.auth-submit-btn:active,.auth-secondary-btn:active{transform:scale(.98);}
.auth-submit-btn:disabled{opacity:.65;cursor:not-allowed;}
.auth-footnote{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:12px;text-align:center;}
.auth-room-list{display:grid;gap:9px;margin-top:8px;}
.auth-room-card{width:100%;border:1px solid var(--border);background:var(--bg3);color:var(--text);border-radius:16px;padding:11px 12px;display:grid;grid-template-columns:36px minmax(0,1fr) auto;gap:10px;align-items:center;text-align:left;font-family:inherit;cursor:pointer;}
.auth-room-icon{width:36px;height:36px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(17,184,154,.10);color:var(--accent);font-size:13px;font-weight:950;letter-spacing:-.2px;border:1px solid rgba(17,184,154,.14);}
.auth-room-main{min-width:0;}.auth-room-main strong{display:block;font-size:14px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.auth-room-main em{display:block;font-style:normal;color:var(--muted);font-size:11.5px;margin-top:1px;}.auth-room-arrow{color:var(--accent);font-size:22px;font-weight:900;line-height:1;}
.room-user-chip{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;min-width:0;max-width:190px;border:1px solid var(--border);background:var(--card);border-radius:999px;padding:5px 11px;line-height:1.1;}
.room-user-chip span,.room-user-chip small{display:block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.room-user-chip span{font-size:11.5px;font-weight:900;color:var(--text);}.room-user-chip small{font-size:10px;color:var(--muted);margin-top:2px;}
.header-logout-btn{width:36px;height:36px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;}.header-logout-btn svg{width:17px;height:17px;}.header-logout-btn:hover{color:var(--out);border-color:rgba(220,38,38,.24);background:rgba(220,38,38,.07);}
html[data-theme="dark"] .auth-screen{background:radial-gradient(circle at 15% 15%, rgba(45,212,191,.16), transparent 34%),radial-gradient(circle at 88% 8%, rgba(139,92,246,.18), transparent 32%),linear-gradient(180deg,#080b14 0%,#0b1020 100%)!important;}
html[data-theme="dark"] .auth-card,html[data-theme="dark"] .auth-panel{background:rgba(18,26,43,.86);border-color:rgba(148,163,184,.16);box-shadow:0 24px 70px rgba(0,0,0,.34);}
html[data-theme="dark"] .auth-theme-toggle{background:rgba(17,26,46,.78);border-color:rgba(148,163,184,.16);color:#aab7ca;box-shadow:0 10px 24px rgba(0,0,0,.18);}
html[data-theme="dark"] .auth-theme-toggle:hover{color:var(--accent);border-color:rgba(45,212,191,.34);background:rgba(45,212,191,.10);}
html[data-theme="dark"] .auth-logo-mark,html[data-theme="dark"] .auth-room-icon{background:rgba(45,212,191,.10);border-color:rgba(45,212,191,.18);color:#5eead4;}
html[data-theme="dark"] .auth-submit-btn{color:#06110f;background:linear-gradient(135deg,#2dd4bf,#14b8a6);} 
html[data-theme="dark"] .auth-room-card,html[data-theme="dark"] .auth-secondary-btn,html[data-theme="dark"] .room-user-chip,html[data-theme="dark"] .header-logout-btn{background:rgba(17,26,46,.78);border-color:rgba(148,163,184,.16);}
@media(max-width:720px){.room-user-chip{display:none!important;}}
@media(max-width:520px){.auth-screen{padding:14px;align-items:flex-start;}.auth-card{margin-top:18px;border-radius:24px;padding:18px;}.auth-theme-toggle{top:14px;right:14px;width:36px;height:36px;}.auth-brand{padding-right:44px;}.auth-title{font-size:18px;}.auth-panel{border-radius:20px;padding:14px;}.auth-footnote{text-align:left;}.topbar-actions{gap:7px!important;}.header-logout-btn,.header-settings-btn{width:34px!important;height:34px!important;}}
.topbar-actions{width:auto!important;height:auto!important;right:14px!important;display:flex!important;align-items:center!important;gap:10px!important;}
@media(max-width:520px){.topbar-actions{width:auto!important;height:auto!important;right:10px!important;gap:7px!important;}.topbar-logo{padding:0 8px!important;}}

/* v20 Access management + Guest view */
.auth-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.auth-register-btn{border-color:rgba(99,102,241,.24)!important;color:var(--rest)!important;background:rgba(99,102,241,.08)!important}.auth-success-note{font-size:12px;color:var(--ready);font-weight:800;text-align:center;margin-top:8px}.guest-mode .header-settings-btn,.guest-mode #nav-expense,.guest-mode .queue-main-actions,.guest-mode .ready-players-card .collapse-toggle[onclick*="toggleReadyPlayers"] + .collapse-content .ready-player-chip button,.guest-mode .court-selector,.guest-mode .player-actions,.guest-mode .title-actions,.guest-mode .settings-tabs,.guest-mode .expense-actions,.guest-mode .match-delete-btn,.guest-mode .court-header-actions button,.guest-mode .winner-pick-panel,.guest-mode .custom-court-hint,.guest-mode .btn-start-game,.guest-mode .btn-save-result,.guest-mode .checkin-mini-btn{display:none!important}.guest-mode .bottom-nav{grid-template-columns:repeat(2,1fr)!important}.guest-mode #nav-queue,.guest-mode #nav-stats{display:flex!important}.guest-mode .topbar-logo::after{content:'View only';display:inline-flex;margin-left:8px;padding:3px 8px;border-radius:999px;background:rgba(99,102,241,.10);color:var(--rest);font-size:10px;font-weight:900;vertical-align:middle}.access-management-panel .settings-panel-head{align-items:center}.access-grid{display:grid;grid-template-columns:1fr;gap:12px}.access-form-grid{display:grid;grid-template-columns:1fr;gap:10px}.generated-password-card{margin-top:12px;border:1px solid rgba(17,184,154,.22);background:rgba(17,184,154,.08);border-radius:16px;padding:12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.generated-password-card span{display:block;font-size:11px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.45px}.generated-password-card strong{font-size:16px;color:var(--text);word-break:break-all}.generated-password-card button,.access-approve-btn,.access-reject-btn,.access-remove-btn{border-radius:999px;padding:7px 12px;font-family:inherit;font-size:12px;font-weight:900;cursor:pointer;border:1px solid transparent;white-space:nowrap}.generated-password-card button,.access-approve-btn{background:rgba(17,184,154,.10);border-color:rgba(17,184,154,.24);color:var(--ready)}.access-reject-btn,.access-remove-btn{background:rgba(220,38,38,.07);border-color:rgba(220,38,38,.18);color:var(--out)}.access-list{display:grid;gap:8px}.access-row{border:1px solid rgba(125,132,145,.14);background:rgba(125,132,145,.045);border-radius:16px;padding:12px;display:flex;gap:12px;align-items:center;justify-content:space-between}.access-main{min-width:0;flex:1}.access-name{font-size:14px;font-weight:900;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.access-meta{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.access-date{font-size:10.5px;color:var(--muted);margin-top:4px}.access-actions{display:flex;align-items:center;gap:7px;flex-wrap:wrap;justify-content:flex-end}.access-role-select{min-width:112px!important;padding:7px 10px!important;font-size:12px!important;border-radius:999px!important}.access-avatar{width:38px;height:38px;border-radius:999px;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--accent);font-weight:900;flex-shrink:0}.access-member-side{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.access-role-pill,.access-self-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:900;border:1px solid var(--border);background:var(--bg3);color:var(--muted)}.access-self-badge{margin-left:6px;color:var(--accent);background:rgba(17,184,154,.09);border-color:rgba(17,184,154,.20)}.access-role-pill.role-owner{color:#b45309;background:rgba(245,158,11,.11);border-color:rgba(245,158,11,.20)}.access-role-pill.role-admin{color:var(--rest);background:rgba(99,102,241,.10);border-color:rgba(99,102,241,.20)}.access-role-pill.role-member{color:var(--ready);background:rgba(17,184,154,.09);border-color:rgba(17,184,154,.20)}.access-role-pill.role-viewer{color:var(--muted)}html[data-theme="dark"] .access-row{background:rgba(17,26,46,.48);border-color:rgba(148,163,184,.14)}html[data-theme="dark"] .generated-password-card{background:rgba(45,212,191,.10);border-color:rgba(45,212,191,.22)}@media(min-width:720px){.access-grid{grid-template-columns:.9fr 1.1fr}.access-form-grid{grid-template-columns:1fr 1fr}.access-form-grid .form-group:last-child{grid-column:1 / -1}.access-management-panel{max-width:860px;margin:0 auto}}@media(max-width:520px){.auth-action-grid{grid-template-columns:1fr}.access-row{align-items:flex-start;flex-direction:column}.access-actions,.access-member-side{width:100%;justify-content:flex-start}.access-role-select{width:100%!important}.access-approve-btn,.access-reject-btn,.access-remove-btn{flex:1}.generated-password-card{align-items:flex-start;flex-direction:column}.generated-password-card button{width:100%}}

/* v20.5 Access Management polish + edit user modal */
input[type=email]{
  width:100%;
  background:var(--bg3)!important;
  border:1px solid var(--border)!important;
  border-radius:var(--radius-sm);
  color:var(--text)!important;
  font-family:inherit;
  font-size:15px;
  padding:11px 14px;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input[type=email]:focus{
  border-color:var(--accent)!important;
  box-shadow:0 0 0 3px rgba(45,212,191,.10)!important;
}
html[data-theme="light"] input[type=email]{
  background:#f7f8fb!important;
  border-color:#e2e8f0!important;
  color:var(--text)!important;
}
html[data-theme="dark"] input[type=email]{
  background:rgba(17,26,46,.78)!important;
  border-color:rgba(148,163,184,.16)!important;
  color:var(--text)!important;
}
html[data-theme="dark"] input[type=email]:focus{
  border-color:rgba(45,212,191,.62)!important;
  box-shadow:0 0 0 4px rgba(45,212,191,.11)!important;
}

.settings-tab.access-tab-btn{
  position:relative;
  overflow:hidden;
}
.settings-tab.access-tab-btn::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:999px;
  background:var(--accent);
  display:inline-block;
  margin-right:7px;
  box-shadow:0 0 0 5px rgba(45,212,191,.10);
  vertical-align:middle;
}
.settings-tab.access-tab-btn.active{
  color:#06110f!important;
  background:linear-gradient(135deg,#5eead4,#2dd4bf)!important;
  box-shadow:0 12px 26px rgba(45,212,191,.18)!important;
}
.settings-tab.access-tab-btn.active::before{
  background:#06110f;
  box-shadow:none;
}
html[data-theme="light"] .settings-tab.access-tab-btn.active{
  color:#064e45!important;
  background:linear-gradient(135deg,#d9fff7,#9ff5e7)!important;
  border:1px solid rgba(17,184,154,.22);
}

.access-management-panel .settings-panel-head{
  border:1px solid rgba(148,163,184,.12);
  background:linear-gradient(135deg,rgba(45,212,191,.10),rgba(139,92,246,.07));
  border-radius:22px;
  padding:16px;
}
.access-management-panel .settings-panel-title{
  font-size:18px;
  letter-spacing:-.25px;
}
.access-management-panel .btn-sm{
  border-radius:999px;
}
.access-grid{
  gap:14px!important;
}
.access-card{
  border-radius:22px!important;
}
.access-card .card-title{
  color:var(--text);
  font-size:12px;
  letter-spacing:.7px;
}
.access-form-grid{
  gap:12px!important;
}
.access-form-grid .form-group{
  margin-bottom:0;
}
.access-card .btn-primary[onclick="createAccessUser()"]{
  min-height:48px;
  border-radius:14px!important;
  margin-top:14px;
  box-shadow:0 14px 28px rgba(20,184,166,.16)!important;
}
.generated-password-card{
  border-radius:18px!important;
}
.access-list{
  gap:10px!important;
}
.access-row{
  border-radius:18px!important;
  padding:14px!important;
  transition:transform .15s ease, border-color .15s ease, background .15s ease;
}
.access-row:hover{
  transform:translateY(-1px);
  border-color:rgba(45,212,191,.28)!important;
  background:rgba(45,212,191,.055)!important;
}
.access-avatar{
  width:42px!important;
  height:42px!important;
  background:linear-gradient(135deg,rgba(45,212,191,.15),rgba(139,92,246,.12))!important;
}
.access-member-side{
  gap:7px!important;
}
.access-edit-btn{
  border-radius:999px;
  padding:7px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  border:1px solid rgba(99,102,241,.22);
  background:rgba(99,102,241,.08);
  color:var(--rest);
  white-space:nowrap;
}
.access-edit-btn:hover{
  background:rgba(99,102,241,.14);
  border-color:rgba(99,102,241,.35);
}
.access-remove-btn{
  padding-left:11px!important;
  padding-right:11px!important;
}
.access-edit-sheet{
  max-width:480px;
}
.access-edit-form{
  display:grid;
  gap:12px;
}
.access-edit-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:16px;
}
#access-edit-role:disabled{
  opacity:.72;
  cursor:not-allowed;
}
html[data-theme="dark"] .access-management-panel .settings-panel-head{
  border-color:rgba(148,163,184,.14);
  background:linear-gradient(135deg,rgba(45,212,191,.10),rgba(139,92,246,.09));
}
html[data-theme="dark"] .access-row:hover{
  background:rgba(45,212,191,.075)!important;
}
html[data-theme="dark"] .access-edit-btn{
  background:rgba(139,140,255,.12);
  border-color:rgba(139,140,255,.26);
  color:#b8b9ff;
}
@media(min-width:720px){
  .access-form-grid{grid-template-columns:1fr 1.15fr!important;align-items:end;}
  .access-form-grid .form-group:last-child{grid-column:1 / -1;}
}
@media(max-width:520px){
  .settings-tabs{grid-template-columns:repeat(2,1fr)!important;border-radius:22px!important;}
  .settings-tab{border-radius:16px!important;}
  .access-management-panel .settings-panel-head{align-items:flex-start;flex-direction:column;}
  .access-card .btn-primary[onclick="createAccessUser()"]{width:100%;}
  .access-edit-actions{grid-template-columns:1fr;}
  .access-edit-btn,.access-remove-btn{flex:1;text-align:center;}
}


/* v20.6 Room picker role display fix */
.auth-room-card{
  grid-template-columns:36px minmax(0,1fr) auto auto!important;
  gap:10px!important;
}
.auth-room-main em{
  color:var(--muted)!important;
  font-size:11.5px!important;
}
.auth-room-role{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:64px;
  height:28px;
  padding:0 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:950;
  letter-spacing:.1px;
  border:1px solid rgba(125,132,145,.14);
  background:rgba(125,132,145,.08);
  color:var(--muted);
  white-space:nowrap;
}
.auth-room-role.role-owner{
  color:#b45309;
  background:rgba(245,158,11,.12);
  border-color:rgba(245,158,11,.24);
}
.auth-room-role.role-admin{
  color:#2563eb;
  background:rgba(59,130,246,.10);
  border-color:rgba(59,130,246,.20);
}
.auth-room-role.role-member{
  color:var(--accent);
  background:rgba(17,184,154,.10);
  border-color:rgba(17,184,154,.20);
}
.auth-room-role.role-viewer{
  color:var(--rest);
  background:rgba(99,102,241,.10);
  border-color:rgba(99,102,241,.20);
}
html[data-theme="dark"] .auth-room-role.role-owner{color:#fbbf24;background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.26)}
html[data-theme="dark"] .auth-room-role.role-admin{color:#93c5fd;background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.28)}
html[data-theme="dark"] .auth-room-role.role-member{color:#5eead4;background:rgba(45,212,191,.12);border-color:rgba(45,212,191,.26)}
@media(max-width:420px){
  .auth-room-card{grid-template-columns:36px minmax(0,1fr) auto!important;}
  .auth-room-role{grid-column:2 / 3;justify-self:start;margin-top:2px;height:24px;min-width:56px;font-size:10.5px;}
  .auth-room-arrow{grid-column:3;grid-row:1 / span 2;align-self:center;}
}

/* v20.7 System password management + collapsible danger action */
.system-collapse-card{
  padding:0!important;
  overflow:hidden;
}
.system-collapse-toggle{
  padding:15px 16px!important;
  align-items:center!important;
}
.system-collapse-toggle > span:first-child{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  gap:2px!important;
  min-width:0;
}
.system-collapse-toggle strong{
  display:flex;
  align-items:center;
  gap:7px;
  color:var(--text);
  font-size:14.5px;
  line-height:1.25;
}
.system-collapse-toggle small{
  color:var(--muted);
  font-size:11.5px;
  font-weight:700;
  line-height:1.35;
  text-align:left;
}
.system-collapse-content.open{
  padding:0 16px 16px!important;
}
.password-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.password-card .btn-primary{
  margin-top:2px;
}
.reset-session-toggle strong{
  color:var(--out);
}
#password-reset-member:disabled{
  opacity:.65;
  cursor:not-allowed;
}
html[data-theme="dark"] .system-collapse-card{
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012)),rgba(18,26,43,.88)!important;
  border-color:rgba(148,163,184,.16)!important;
}
@media(max-width:520px){
  .password-form-grid{
    grid-template-columns:1fr;
    gap:0;
  }
  .system-collapse-toggle{
    padding:14px!important;
  }
  .system-collapse-content.open{
    padding:0 14px 14px!important;
  }
}

/* v20.8 Membership request password badges */
.request-password-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-left:7px;
  padding:3px 8px;
  border-radius:999px;
  font-size:10.5px;
  font-weight:900;
  vertical-align:middle;
  border:1px solid transparent;
  white-space:nowrap;
}
.request-password-badge.ok{
  color:var(--ready);
  background:rgba(17,184,154,.10);
  border-color:rgba(17,184,154,.22);
}
.request-password-badge.warn{
  color:var(--playing);
  background:rgba(245,158,11,.11);
  border-color:rgba(245,158,11,.24);
}
.request-row.request-legacy{
  opacity:.82;
}
html[data-theme="dark"] .request-password-badge.ok{
  color:#5eead4;
  background:rgba(45,212,191,.12);
  border-color:rgba(45,212,191,.26);
}
html[data-theme="dark"] .request-password-badge.warn{
  color:#f6c177;
  background:rgba(246,179,95,.12);
  border-color:rgba(246,179,95,.26);
}
@media(max-width:420px){
  .request-password-badge{
    margin-left:0;
    margin-top:4px;
  }
  .request-row .access-name{
    display:flex;
    flex-wrap:wrap;
    gap:4px 6px;
    align-items:center;
  }
}


/* v20.9 Login polish: remove the decorative BQ logo block for a cleaner non-AI-looking auth header */
.auth-brand{
  gap:0!important;
  padding-right:52px!important;
  margin-bottom:20px!important;
}
.auth-logo-mark{
  display:none!important;
}
.auth-title{
  letter-spacing:-.35px!important;
}
@media(max-width:520px){
  .auth-brand{padding-right:44px!important;}
}


/* v21.1 Register request success UX */
.auth-register-success-panel{
  text-align:center;
  animation:authSuccessIn .26s cubic-bezier(.22,1,.36,1);
}
@keyframes authSuccessIn{
  from{opacity:0;transform:translateY(10px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.register-success-icon{
  width:62px;
  height:62px;
  margin:0 auto 14px;
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,rgba(45,212,191,.18),rgba(20,184,166,.08));
  border:1px solid rgba(45,212,191,.28);
  color:var(--accent);
  box-shadow:0 16px 34px rgba(45,212,191,.12);
}
.register-success-icon svg{
  width:30px;
  height:30px;
}
.register-success-title{
  margin-bottom:4px;
}
.register-success-desc{
  max-width:380px;
  margin:0 auto 14px;
  line-height:1.65;
}
.register-success-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(125,132,145,.07);
  border:1px solid rgba(125,132,145,.14);
  margin:14px 0 12px;
  text-align:left;
}
.register-success-summary span{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
.register-success-summary strong{
  color:var(--text);
  font-size:13px;
  font-weight:900;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.register-success-steps{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin:0 0 14px;
}
.register-success-steps div{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px;
  border-radius:14px;
  background:rgba(45,212,191,.06);
  border:1px solid rgba(45,212,191,.13);
  text-align:left;
}
.register-success-steps strong{
  width:24px;
  height:24px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent);
  color:#06110f;
  font-size:12px;
  font-weight:900;
  flex-shrink:0;
}
.register-success-steps span{
  color:var(--text);
  font-size:12px;
  font-weight:800;
  line-height:1.35;
}
html[data-theme="light"] .register-success-icon{
  background:linear-gradient(135deg,rgba(17,184,154,.18),rgba(17,184,154,.07));
  border-color:rgba(17,184,154,.28);
}
html[data-theme="light"] .register-success-steps div{
  background:rgba(17,184,154,.06);
  border-color:rgba(17,184,154,.14);
}
@media(max-width:420px){
  .register-success-steps{
    grid-template-columns:1fr;
  }
  .register-success-summary{
    align-items:flex-start;
    flex-direction:column;
    gap:4px;
  }
}

/* v21.5 Access UX polish */
.settings-tabs{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  align-items:stretch;
  gap:10px!important;
  padding:7px!important;
  border-radius:28px!important;
  overflow:visible!important;
}
.settings-tab{
  min-width:0;
  min-height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  line-height:1.25;
  white-space:normal;
  word-break:break-word;
  padding:12px 10px!important;
}
.settings-tab span{
  display:block;
  width:100%;
}
@media(max-width:920px){
  .settings-tabs{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    border-radius:24px!important;
  }
}
@media(max-width:520px){
  .settings-tabs{
    gap:8px!important;
    padding:6px!important;
  }
  .settings-tab{
    min-height:48px;
    font-size:12.5px!important;
    border-radius:16px!important;
  }
}

.request-row{
  display:grid!important;
  grid-template-columns:1fr;
  gap:14px!important;
  align-items:stretch!important;
}
.request-top-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.request-identity{min-width:0;flex:1;}
.request-name-row{
  display:flex!important;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  white-space:normal!important;
  overflow:visible!important;
}
.request-user-name{
  display:inline-block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}
.request-email{
  margin-top:4px!important;
  white-space:normal!important;
  word-break:break-word;
}
.request-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.request-detail-item{
  border:1px solid rgba(125,132,145,.14);
  background:rgba(125,132,145,.06);
  border-radius:14px;
  padding:10px 12px;
  min-width:0;
}
.request-note-item{grid-column:1 / -1;}
.request-detail-label{
  display:block;
  font-size:10.5px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.45px;
  margin-bottom:4px;
  font-weight:800;
}
.request-detail-item strong{
  display:block;
  font-size:13px;
  line-height:1.45;
  color:var(--text);
  font-weight:800;
  word-break:break-word;
}
.request-actions-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:end;
}
.request-role-field{margin-bottom:0!important;}
.request-role-field .form-label{margin-bottom:6px;}
.request-actions{
  justify-content:flex-end!important;
  gap:8px!important;
  flex-wrap:nowrap!important;
}
.request-actions .access-approve-btn,
.request-actions .access-reject-btn{
  min-width:96px;
  min-height:40px;
}
.request-row .access-role-select{
  width:100%;
  min-width:0!important;
  min-height:42px;
  border-radius:14px!important;
}
@media(max-width:720px){
  .request-detail-grid{grid-template-columns:1fr;}
  .request-actions-panel{grid-template-columns:1fr;}
  .request-actions{justify-content:stretch!important;}
  .request-actions .access-approve-btn,
  .request-actions .access-reject-btn{flex:1;}
}

.access-edit-block{
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid rgba(125,132,145,.16);
}
.access-edit-block:first-of-type{
  margin-top:14px;
}
.access-edit-block-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.access-edit-block-title{
  font-size:13px;
  font-weight:900;
  color:var(--text);
  letter-spacing:.2px;
}
.access-edit-block-subtitle{
  margin-top:2px;
  font-size:12px;
  color:var(--muted);
  line-height:1.45;
}
.access-edit-reset-block .btn-primary{
  margin-top:4px;
}
.access-edit-reset-block .generated-password-card{
  margin-top:14px;
}
.access-edit-sheet{
  max-width:560px!important;
}
@media(max-width:520px){
  .access-edit-block{
    margin-top:16px;
    padding-top:14px;
  }
}

/* v21.6 Removed Access Trash */
.access-card-title-actions{
  gap:10px;
}
.access-trash-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  border:1px solid rgba(125,132,145,.18);
  background:rgba(125,132,145,.06);
  color:var(--muted);
  border-radius:999px;
  padding:7px 11px;
  font-family:inherit;
  font-size:11.5px;
  font-weight:900;
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
}
.access-trash-btn svg{
  width:15px;
  height:15px;
}
.access-trash-btn:hover{
  color:var(--out);
  background:rgba(220,38,38,.07);
  border-color:rgba(220,38,38,.20);
}
.removed-access-sheet{
  max-width:640px!important;
}
.removed-access-note{
  border:1px solid rgba(125,132,145,.14);
  background:rgba(125,132,145,.055);
  color:var(--muted);
  border-radius:16px;
  padding:12px 14px;
  font-size:12px;
  font-weight:700;
  line-height:1.55;
  margin-bottom:12px;
}
.removed-access-row{
  align-items:flex-start!important;
}
.removed-access-avatar{
  opacity:.72;
  filter:saturate(.55);
}
.removed-access-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
  flex-shrink:0;
}
.access-restore-btn,
.access-permanent-delete-btn{
  border-radius:999px;
  padding:7px 12px;
  font-family:inherit;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  border:1px solid transparent;
  white-space:nowrap;
  transition:all .15s;
}
.access-restore-btn{
  background:rgba(17,184,154,.10);
  border-color:rgba(17,184,154,.24);
  color:var(--ready);
}
.access-restore-btn:hover:not(:disabled){
  background:rgba(17,184,154,.15);
  border-color:rgba(17,184,154,.34);
}
.access-restore-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
  filter:saturate(.6);
}
.access-permanent-delete-btn{
  background:rgba(220,38,38,.07);
  border-color:rgba(220,38,38,.18);
  color:var(--out);
}
.access-permanent-delete-btn:hover{
  background:rgba(220,38,38,.12);
  border-color:rgba(220,38,38,.30);
}
html[data-theme="dark"] .access-trash-btn{
  background:rgba(17,26,46,.72);
  border-color:rgba(148,163,184,.16);
}
html[data-theme="dark"] .removed-access-note{
  background:rgba(17,26,46,.48);
  border-color:rgba(148,163,184,.14);
}
html[data-theme="dark"] .access-restore-btn{
  background:rgba(45,212,191,.10);
  border-color:rgba(45,212,191,.24);
  color:#5eead4;
}
html[data-theme="dark"] .access-permanent-delete-btn{
  background:rgba(251,113,133,.10);
  border-color:rgba(251,113,133,.24);
  color:#fda4af;
}
@media(max-width:620px){
  .access-trash-btn span{display:none;}
  .removed-access-row{align-items:flex-start!important;flex-direction:column!important;}
  .removed-access-actions{width:100%;justify-content:flex-start;}
  .access-restore-btn,.access-permanent-delete-btn{flex:1;text-align:center;}
}

/* v22 Desktop / tablet-landscape left navigation inspired by compact app sidebar */
.desktop-sidebar{display:none;}
.desktop-theme-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;}
.desktop-theme-icon svg{width:18px;height:18px;}

@media (min-width:900px) and (min-height:560px), (min-width:768px) and (orientation:landscape) and (min-height:560px){
  :root{--desktop-sidebar-width:280px;--desktop-shell-gap:28px;}

  body.auth-ready{
    padding-left:calc(var(--desktop-sidebar-width) + var(--desktop-shell-gap));
    min-height:100vh;
  }

  body.auth-ready .topbar,
  body.auth-ready .bottom-nav{
    display:none!important;
  }

  body.auth-ready .desktop-sidebar{
    display:flex;
    position:fixed;
    left:22px;
    top:22px;
    bottom:22px;
    width:var(--desktop-sidebar-width);
    z-index:180;
    flex-direction:column;
    overflow:hidden;
    border-radius:28px;
    border:1px solid rgba(125,132,145,.16);
    background:rgba(255,255,255,.76);
    box-shadow:0 28px 70px rgba(31,41,55,.13);
    backdrop-filter:blur(22px);
    -webkit-backdrop-filter:blur(22px);
  }

  html[data-theme="dark"] body.auth-ready .desktop-sidebar{
    background:rgba(12,18,30,.84);
    border-color:rgba(148,163,184,.16);
    box-shadow:0 28px 80px rgba(0,0,0,.36);
  }

  .desktop-window-dots{
    display:flex;
    align-items:center;
    gap:8px;
    padding:18px 20px 8px;
    flex:0 0 auto;
  }
  .desktop-window-dots span{width:10px;height:10px;border-radius:999px;display:block;}
  .desktop-window-dots span:nth-child(1){background:#ef6a5b;}
  .desktop-window-dots span:nth-child(2){background:#f6bf4f;}
  .desktop-window-dots span:nth-child(3){background:#63c96b;}

  .desktop-brand{
    display:flex;
    align-items:center;
    gap:12px;
    padding:16px 20px 18px;
    min-width:0;
  }
  .desktop-brand-mark{
    width:42px;height:42px;border-radius:15px;
    display:flex;align-items:center;justify-content:center;
    color:var(--text);
    background:rgba(17,184,154,.10);
    border:1px solid rgba(17,184,154,.14);
    flex:0 0 auto;
  }
  .desktop-brand-mark svg{width:24px;height:24px;}
  .desktop-brand strong{
    display:block;
    color:var(--text);
    font-size:18px;
    font-weight:950;
    letter-spacing:-.45px;
    line-height:1.15;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .desktop-brand span{
    display:block;
    color:var(--muted);
    font-size:12px;
    font-weight:800;
    margin-top:3px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:180px;
  }
  html[data-theme="dark"] .desktop-brand-mark{
    background:rgba(45,212,191,.11);
    border-color:rgba(45,212,191,.16);
    color:#e6edf7;
  }

  .desktop-nav-scroll{
    flex:1;
    min-height:0;
    overflow:auto;
    padding:2px 14px 14px;
    scrollbar-width:none;
  }
  .desktop-nav-scroll::-webkit-scrollbar{display:none;}
  .desktop-nav-section{
    padding:12px 0;
    border-top:1px solid rgba(125,132,145,.14);
  }
  .desktop-nav-section:first-child{border-top:0;padding-top:4px;}
  html[data-theme="dark"] .desktop-nav-section{border-top-color:rgba(148,163,184,.13);}
  .desktop-nav-label{
    color:var(--muted);
    font-size:12px;
    font-weight:900;
    letter-spacing:.7px;
    text-transform:uppercase;
    padding:0 6px 8px;
    opacity:.78;
  }

  .desktop-nav-item{
    width:100%;
    min-height:44px;
    border:1px solid transparent;
    border-radius:16px;
    background:transparent;
    color:var(--text);
    font-family:inherit;
    font-size:13.5px;
    font-weight:800;
    display:flex;
    align-items:center;
    gap:12px;
    padding:0 12px;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease;
    text-align:left;
    position:relative;
  }
  .desktop-nav-item + .desktop-nav-item{margin-top:5px;}
  .desktop-nav-item svg{width:19px;height:19px;flex:0 0 auto;stroke:currentColor;}
  .desktop-nav-item span:last-child,
  .desktop-nav-item > span:not(.desktop-theme-icon){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .desktop-nav-item:hover{
    background:rgba(125,132,145,.075);
    border-color:rgba(125,132,145,.10);
    transform:translateX(1px);
  }
  .desktop-nav-item.active{
    color:var(--text);
    background:rgba(255,255,255,.66);
    border-color:rgba(125,132,145,.22);
    box-shadow:0 12px 28px rgba(31,41,55,.08);
  }
  .desktop-nav-item.active::before{
    content:"";
    position:absolute;
    left:6px;
    width:4px;
    height:20px;
    border-radius:999px;
    background:linear-gradient(180deg,var(--accent),var(--accent2));
  }
  .desktop-nav-item.active svg,
  .desktop-nav-item:hover svg{color:var(--accent);}
  .desktop-nav-danger:hover{
    color:var(--out);
    background:rgba(220,38,38,.075);
    border-color:rgba(220,38,38,.14);
  }

  html[data-theme="dark"] .desktop-nav-item{color:#d7e1ee;}
  html[data-theme="dark"] .desktop-nav-item:hover{
    background:rgba(45,212,191,.07);
    border-color:rgba(45,212,191,.10);
  }
  html[data-theme="dark"] .desktop-nav-item.active{
    background:rgba(255,255,255,.055);
    border-color:rgba(148,163,184,.18);
    box-shadow:0 16px 34px rgba(0,0,0,.22);
  }

  .desktop-user-card{
    margin:0 14px 14px;
    min-height:58px;
    padding:9px 10px;
    border-radius:18px;
    background:rgba(125,132,145,.09);
    border:1px solid rgba(125,132,145,.12);
    display:flex;
    align-items:center;
    gap:10px;
    flex:0 0 auto;
  }
  .desktop-user-avatar{
    width:40px;height:40px;border-radius:999px;
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,rgba(17,184,154,.18),rgba(99,102,241,.14));
    border:1px solid rgba(125,132,145,.18);
    color:var(--text);
    font-weight:950;
    flex:0 0 auto;
  }
  .desktop-user-info{min-width:0;flex:1;line-height:1.15;}
  .desktop-user-info strong,
  .desktop-user-info span{
    display:block;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .desktop-user-info strong{font-size:13px;color:var(--text);font-weight:950;}
  .desktop-user-info span{font-size:11px;color:var(--muted);margin-top:3px;}
  .desktop-sync-dot{flex:0 0 auto;width:9px;height:9px;}
  html[data-theme="dark"] .desktop-user-card{
    background:rgba(255,255,255,.055);
    border-color:rgba(148,163,184,.14);
  }

  body.auth-ready .page{
    width:min(calc(100vw - var(--desktop-sidebar-width) - 78px), 1060px)!important;
    max-width:1060px!important;
    margin:0 auto!important;
    padding:30px 22px 48px!important;
  }
  body.auth-ready #page-queue .card,
  body.auth-ready #page-queue .section-heading,
  body.auth-ready #page-queue .queue-filter-tabs,
  body.auth-ready #page-queue #active-courts,
  body.auth-ready #settings-panel-expense .card,
  body.auth-ready #page-stats .card,
  body.auth-ready #page-settings .settings-panel.active{
    max-width:900px!important;
  }
  body.auth-ready .settings-tabs{
    display:none!important;
  }
  body.auth-ready .settings-head,
  body.auth-ready .stats-dashboard-head,
  body.auth-ready .expense-header{
    max-width:900px!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }
  body.auth-ready .dashboard-title{font-size:28px;letter-spacing:-.75px;}
  body.auth-ready .dashboard-subtitle{font-size:13px;}
  body.auth-ready .toast{bottom:28px;}

  .guest-mode .desktop-nav-member-only,
  .guest-mode .desktop-nav-item[data-nav-target="expense"],
  .guest-mode .desktop-nav-item[data-nav-target^="settings-"]{
    display:none!important;
  }
}

@media (min-width:900px) and (max-width:1099px) and (min-height:560px), (min-width:768px) and (max-width:1099px) and (orientation:landscape) and (min-height:560px){
  :root{--desktop-sidebar-width:244px;--desktop-shell-gap:22px;}
  body.auth-ready .desktop-sidebar{left:16px;top:16px;bottom:16px;border-radius:24px;}
  .desktop-brand{padding-left:16px;padding-right:16px;}
  .desktop-brand strong{font-size:16px;}
  .desktop-brand span{max-width:145px;}
  .desktop-nav-scroll{padding-left:10px;padding-right:10px;}
  .desktop-nav-item{font-size:13px;padding-left:10px;padding-right:10px;gap:10px;}
  body.auth-ready .page{width:min(calc(100vw - var(--desktop-sidebar-width) - 58px), 860px)!important;padding-left:18px!important;padding-right:18px!important;}
}

body.auth-checking .desktop-sidebar,
body.auth-required .desktop-sidebar,
body.auth-no-access .desktop-sidebar{
  display:none!important;
}


/* v23 Desktop layout refinement: tighter sidebar-to-content spacing + desktop-wide polish
   Mobile portrait stays untouched because everything below runs only inside the desktop/tablet-landscape breakpoint. */
@media (min-width:900px) and (min-height:560px), (min-width:768px) and (orientation:landscape) and (min-height:560px){
  :root{
    --desktop-sidebar-width:280px;
    --desktop-sidebar-left:16px;
    --desktop-sidebar-y:16px;
    --desktop-content-gap:14px;
    --desktop-content-right:24px;
    --desktop-content-left:calc(var(--desktop-sidebar-left) + var(--desktop-sidebar-width) + var(--desktop-content-gap));
  }

  body.auth-ready{
    padding-left:var(--desktop-content-left)!important;
    padding-right:var(--desktop-content-right)!important;
  }

  body.auth-ready .desktop-sidebar{
    left:var(--desktop-sidebar-left)!important;
    top:var(--desktop-sidebar-y)!important;
    bottom:var(--desktop-sidebar-y)!important;
    width:var(--desktop-sidebar-width)!important;
    border-radius:26px!important;
  }

  body.auth-ready .page{
    width:min(calc(100vw - var(--desktop-content-left) - var(--desktop-content-right)), 1180px)!important;
    max-width:1180px!important;
    margin:0!important;
    padding:18px 0 48px!important;
  }

  /* Remove the old centered-card feeling on desktop so the content visually belongs to the left nav. */
  body.auth-ready #page-queue .card,
  body.auth-ready #page-queue .section-heading,
  body.auth-ready #page-queue .queue-filter-tabs,
  body.auth-ready #page-queue #active-courts,
  body.auth-ready #settings-panel-expense .card,
  body.auth-ready #page-stats .card,
  body.auth-ready #page-settings .settings-panel.active,
  body.auth-ready .settings-head,
  body.auth-ready .stats-dashboard-head,
  body.auth-ready .expense-header,
  body.auth-ready .access-management-panel{
    max-width:none!important;
    width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
  }

  body.auth-ready .settings-head,
  body.auth-ready .stats-dashboard-head,
  body.auth-ready .expense-header{
    margin-bottom:16px!important;
  }

  body.auth-ready .dashboard-title{
    font-size:26px!important;
    letter-spacing:-.6px!important;
  }

  body.auth-ready .dashboard-subtitle{
    font-size:13px!important;
    max-width:720px;
  }

  body.auth-ready .card,
  body.auth-ready .court-card,
  body.auth-ready .stat-card{
    border-radius:20px!important;
  }

  body.auth-ready .card{
    padding:18px!important;
    margin-bottom:14px!important;
  }

  body.auth-ready .court-card{
    margin-bottom:14px!important;
  }

  body.auth-ready .queue-filter-tabs,
  body.auth-ready .stats-tabs{
    margin-bottom:14px!important;
  }

  /* Better use of desktop width without making each form feel stretched. */
  body.auth-ready .stats-grid{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
    gap:12px!important;
  }

  body.auth-ready .access-grid{
    grid-template-columns:minmax(320px,.9fr) minmax(360px,1.1fr)!important;
    gap:14px!important;
  }

  body.auth-ready .access-form-grid,
  body.auth-ready .password-form-grid,
  body.auth-ready .court-profile-form{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px!important;
  }

  body.auth-ready .access-form-grid .form-group:last-child{
    grid-column:auto!important;
  }

  body.auth-ready .access-row,
  body.auth-ready .deleted-player-card,
  body.auth-ready .expense-history-row{
    padding:14px!important;
    border-radius:18px!important;
    border:1px solid rgba(125,132,145,.13)!important;
    background:rgba(255,255,255,.46)!important;
  }

  html[data-theme="dark"] body.auth-ready .access-row,
  html[data-theme="dark"] body.auth-ready .deleted-player-card,
  html[data-theme="dark"] body.auth-ready .expense-history-row{
    background:rgba(17,26,46,.46)!important;
    border-color:rgba(148,163,184,.14)!important;
  }

  body.auth-ready .toast{
    left:calc(var(--desktop-content-left) + 50vw - (var(--desktop-content-left) / 2));
    bottom:24px!important;
  }
}

@media (min-width:900px) and (max-width:1099px) and (min-height:560px), (min-width:768px) and (max-width:1099px) and (orientation:landscape) and (min-height:560px){
  :root{
    --desktop-sidebar-width:244px;
    --desktop-sidebar-left:14px;
    --desktop-sidebar-y:14px;
    --desktop-content-gap:12px;
    --desktop-content-right:16px;
  }

  body.auth-ready .page{
    width:min(calc(100vw - var(--desktop-content-left) - var(--desktop-content-right)), 920px)!important;
    padding-top:14px!important;
  }

  body.auth-ready .stats-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }

  body.auth-ready .access-grid{
    grid-template-columns:1fr!important;
  }
}


/* v24 QBAD Pro logo integration */
:root{--logo-main:var(--text);--logo-accent:var(--accent);}
.qbad-brand,.topbar-logo,.desktop-brand-logo{display:flex;align-items:center;}
.qbad-brand-mark,.topbar-brand-mark,.desktop-qbad-mark{display:block;flex-shrink:0;color:var(--logo-main);}
.qbad-wordmark{display:inline-flex;align-items:baseline;gap:.34em;line-height:1;white-space:nowrap;}
.qbad-word{color:var(--logo-main);font-weight:900;letter-spacing:-.05em;}
.qbad-pro{color:var(--logo-accent);font-weight:900;font-style:italic;letter-spacing:-.04em;}
.qbad-auth-brand{padding-right:48px!important;}
.qbad-brand-auth{gap:14px;align-items:center;}
.auth-brand-mark-wrap{width:58px;height:58px;border-radius:18px;background:linear-gradient(180deg, rgba(17,184,154,.12), rgba(17,184,154,.03));border:1px solid rgba(17,184,154,.14);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(17,184,154,.08);}
.auth-brand-mark{width:44px;height:44px;}
.auth-brand-copy{min-width:0;}
.auth-wordmark{font-size:34px;letter-spacing:-.04em;margin-bottom:6px;}
.topbar-logo{display:flex!important;align-items:center!important;justify-content:center!important;gap:9px;color:var(--logo-main)!important;min-width:0!important;}
.topbar-brand-mark{width:28px;height:28px;}
.topbar-wordmark{font-size:24px;}
.desktop-brand{padding-left:18px!important;padding-right:18px!important;}
.desktop-brand-logo{gap:12px;min-width:0;width:100%;}
.desktop-brand-mark{width:48px!important;height:48px!important;border-radius:16px!important;background:linear-gradient(180deg, rgba(17,184,154,.12), rgba(17,184,154,.03))!important;border:1px solid rgba(17,184,154,.12)!important;display:flex!important;align-items:center!important;justify-content:center!important;color:var(--logo-main)!important;}
.desktop-qbad-mark{width:34px;height:34px;}
.desktop-brand-copy{min-width:0;display:flex;flex-direction:column;gap:2px;}
.desktop-brand-wordmark{display:inline-flex;align-items:baseline;gap:.3em;font-size:24px!important;line-height:1!important;letter-spacing:-.04em!important;}
.desktop-brand span#desktop-room-name{max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.guest-mode .topbar-logo::after{margin-left:4px!important;}
html[data-theme="dark"] .auth-brand-mark-wrap,
html[data-theme="dark"] .desktop-brand-mark{background:linear-gradient(180deg, rgba(45,212,191,.12), rgba(45,212,191,.04))!important;border-color:rgba(45,212,191,.16)!important;box-shadow:0 14px 30px rgba(0,0,0,.18)!important;}
@media (max-width:520px){.auth-wordmark{font-size:28px;}.auth-brand-mark-wrap{width:50px;height:50px;border-radius:16px;}.auth-brand-mark{width:38px;height:38px;}.topbar-brand-mark{width:24px;height:24px;}.topbar-wordmark{font-size:20px;}}
@media (max-width:420px){.topbar-logo{gap:6px!important;}.topbar-brand-mark{width:22px;height:22px;}.topbar-wordmark{font-size:18px;}}
@media (min-width:900px) and (min-height:560px), (min-width:768px) and (orientation:landscape) and (min-height:560px){.topbar-logo{justify-content:flex-start!important;}.desktop-brand-wordmark{font-size:22px!important;}.desktop-brand span#desktop-room-name{max-width:170px;}}


/* v25 Desktop balance pass + no-frame QBAD logo
   Scope: desktop / tablet landscape only. Mobile portrait keeps the existing layout. */

/* Remove decorative frame around the logo everywhere. The SVG itself remains theme-aware. */
.auth-brand-mark-wrap,
.desktop-brand-mark{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
}
html[data-theme="dark"] .auth-brand-mark-wrap,
html[data-theme="dark"] .desktop-brand-mark{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.auth-brand-mark-wrap{width:56px!important;height:56px!important;}
.auth-brand-mark{width:54px!important;height:54px!important;}
.desktop-brand-mark{width:44px!important;height:44px!important;}
.desktop-qbad-mark{width:42px!important;height:42px!important;}

/* Queue wrappers should not affect mobile. */
.desktop-queue-layout,
.desktop-queue-left,
.desktop-queue-right{display:contents;}

@media (min-width:900px) and (min-height:560px), (min-width:768px) and (orientation:landscape) and (min-height:560px){
  :root{
    --desktop-sidebar-width:280px;
    --desktop-sidebar-left:16px;
    --desktop-sidebar-y:16px;
    --desktop-content-gap:18px;
    --desktop-content-right:28px;
    --desktop-content-left:calc(var(--desktop-sidebar-left) + var(--desktop-sidebar-width) + var(--desktop-content-gap));
    --desktop-work-max:1380px;
  }

  body.auth-ready{
    padding-left:var(--desktop-content-left)!important;
    padding-right:var(--desktop-content-right)!important;
  }

  body.auth-ready .page,
  body.auth-ready #page-queue,
  body.auth-ready #page-stats,
  body.auth-ready #page-settings{
    width:min(calc(100vw - var(--desktop-content-left) - var(--desktop-content-right)), var(--desktop-work-max))!important;
    max-width:var(--desktop-work-max)!important;
    margin:0!important;
    padding:18px 0 52px!important;
  }

  body.auth-ready .topbar{
    display:none!important;
  }

  /* Global desktop card rhythm */
  body.auth-ready .card,
  body.auth-ready .court-card,
  body.auth-ready .stat-card{
    border-radius:22px!important;
  }
  body.auth-ready .card{padding:18px!important;margin-bottom:0!important;}

  /* ---------- Queue page ---------- */
  body.auth-ready #page-queue.page.active{
    display:block!important;
  }
  body.auth-ready #page-queue .desktop-queue-layout{
    display:grid!important;
    grid-template-columns:minmax(320px, 420px) minmax(520px, 1fr);
    gap:18px;
    align-items:start;
  }
  body.auth-ready #page-queue .desktop-queue-left,
  body.auth-ready #page-queue .desktop-queue-right{
    display:grid!important;
    gap:14px;
    align-items:start;
    min-width:0;
  }
  body.auth-ready #page-queue .desktop-queue-right{
    grid-template-rows:auto auto 1fr;
  }
  body.auth-ready #page-queue .card,
  body.auth-ready #page-queue .section-heading,
  body.auth-ready #page-queue .queue-filter-tabs,
  body.auth-ready #page-queue #active-courts{
    max-width:none!important;
    width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
  }
  body.auth-ready #page-queue .section-heading{
    margin:2px 0 0!important;
    min-height:46px;
    align-items:center;
  }
  body.auth-ready #page-queue .queue-filter-tabs{
    margin:0!important;
  }
  body.auth-ready #page-queue #active-courts{
    display:grid;
    gap:14px;
  }

  /* ---------- Stats page ---------- */
  body.auth-ready #page-stats{
    display:none!important;
  }
  body.auth-ready #page-stats.page.active{
    display:block!important;
    max-width:var(--desktop-work-max)!important;
  }
  body.auth-ready #page-stats .stats-dashboard-head,
  body.auth-ready #page-stats .dashboard-summary,
  body.auth-ready #page-stats .stats-tabs,
  body.auth-ready #page-stats .stats-panel,
  body.auth-ready #page-stats .card{
    max-width:none!important;
    width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
  }
  body.auth-ready #page-stats .stats-dashboard-head{
    display:flex!important;
    align-items:flex-start!important;
    justify-content:space-between!important;
    gap:18px!important;
    margin-bottom:16px!important;
  }
  body.auth-ready #page-stats .dashboard-summary{
    grid-template-columns:repeat(4,minmax(150px,1fr))!important;
    gap:14px!important;
    margin-bottom:14px!important;
  }
  body.auth-ready #page-stats .stats-tabs{
    max-width:640px!important;
    margin-bottom:16px!important;
  }
  body.auth-ready #page-stats .stats-overview-compact{
    display:grid!important;
    grid-template-columns:minmax(250px,.78fr) minmax(320px,1fr) minmax(360px,1.14fr)!important;
    gap:14px!important;
    align-items:stretch!important;
  }
  body.auth-ready #page-stats .compact-status-card,
  body.auth-ready #page-stats .compact-list-card{
    grid-column:auto!important;
    min-height:154px;
  }
  body.auth-ready #page-stats .status-mini-grid{
    grid-template-columns:1fr 1fr!important;
    padding-left:0!important;
    padding-right:0!important;
  }
  body.auth-ready #page-stats .today-history-card{
    margin-top:14px!important;
  }
  body.auth-ready #page-stats #stats-panel-alltime .alltime-players-card{
    max-width:none!important;
    width:100%!important;
  }

  /* ---------- Settings pages ---------- */
  body.auth-ready #page-settings .settings-head,
  body.auth-ready #page-settings .settings-tabs,
  body.auth-ready #page-settings .settings-panel.active{
    max-width:none!important;
    width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
  }
  body.auth-ready #page-settings .settings-tabs{
    margin-bottom:16px!important;
  }
  body.auth-ready #settings-panel-players.active,
  body.auth-ready #settings-panel-courts.active{
    display:grid!important;
    grid-template-columns:minmax(320px, 420px) minmax(560px, 1fr)!important;
    gap:16px!important;
    align-items:start!important;
  }
  body.auth-ready #settings-panel-players .settings-panel-head,
  body.auth-ready #settings-panel-courts .settings-panel-head{
    grid-column:1 / -1!important;
    margin-bottom:0!important;
  }
  body.auth-ready #settings-panel-players > .add-player-card,
  body.auth-ready #settings-panel-courts > .add-player-card{
    grid-column:1!important;
  }
  body.auth-ready #settings-panel-players > .card:not(.add-player-card),
  body.auth-ready #settings-panel-courts > .card:not(.add-player-card){
    grid-column:2!important;
  }
  body.auth-ready #settings-panel-system.active{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:16px!important;
    align-items:start!important;
  }
  body.auth-ready #settings-panel-system .settings-panel-head{
    grid-column:1 / -1!important;
  }
  body.auth-ready #settings-panel-access.active{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:16px!important;
  }
  body.auth-ready #settings-panel-access .access-grid{
    grid-template-columns:minmax(340px,.9fr) minmax(440px,1.1fr)!important;
    gap:16px!important;
  }

  /* Expense is a settings sub-page; give it a dashboard layout instead of one narrow column. */
  body.auth-ready #settings-panel-expense.active{
    display:grid!important;
    grid-template-columns:minmax(340px,.9fr) minmax(460px,1.1fr)!important;
    gap:16px!important;
    align-items:start!important;
    max-width:none!important;
    width:100%!important;
  }
  body.auth-ready #settings-panel-expense .expense-header{
    grid-column:1 / -1!important;
    margin-bottom:0!important;
  }
  body.auth-ready #settings-panel-expense > .card{
    max-width:none!important;
    width:100%!important;
    margin:0!important;
  }
  body.auth-ready #settings-panel-expense > .card:nth-of-type(1),
  body.auth-ready #settings-panel-expense > .card:nth-of-type(2){
    grid-column:1!important;
  }
  body.auth-ready #settings-panel-expense > .card:nth-of-type(3){
    grid-column:2!important;
    grid-row:2 / span 2!important;
    position:sticky;
    top:18px;
  }

  /* Desktop logo sizing without frame */
  body.auth-ready .desktop-brand{padding:18px 18px 12px!important;}
  body.auth-ready .desktop-brand-logo{gap:10px!important;}
  body.auth-ready .desktop-brand-wordmark{font-size:23px!important;}
  body.auth-ready .desktop-brand span#desktop-room-name{max-width:178px!important;}
}

@media (min-width:900px) and (max-width:1120px) and (min-height:560px), (min-width:768px) and (max-width:1120px) and (orientation:landscape) and (min-height:560px){
  :root{
    --desktop-sidebar-width:244px;
    --desktop-sidebar-left:14px;
    --desktop-sidebar-y:14px;
    --desktop-content-gap:14px;
    --desktop-content-right:16px;
    --desktop-work-max:980px;
  }
  body.auth-ready #page-queue .desktop-queue-layout,
  body.auth-ready #settings-panel-players.active,
  body.auth-ready #settings-panel-courts.active,
  body.auth-ready #settings-panel-expense.active,
  body.auth-ready #settings-panel-access .access-grid{
    grid-template-columns:1fr!important;
  }
  body.auth-ready #settings-panel-players > .add-player-card,
  body.auth-ready #settings-panel-courts > .add-player-card,
  body.auth-ready #settings-panel-players > .card:not(.add-player-card),
  body.auth-ready #settings-panel-courts > .card:not(.add-player-card),
  body.auth-ready #settings-panel-expense > .card:nth-of-type(1),
  body.auth-ready #settings-panel-expense > .card:nth-of-type(2),
  body.auth-ready #settings-panel-expense > .card:nth-of-type(3){
    grid-column:1!important;
    grid-row:auto!important;
    position:static!important;
  }
  body.auth-ready #page-stats .stats-overview-compact{
    grid-template-columns:1fr 1fr!important;
  }
  body.auth-ready #page-stats .compact-status-card{
    grid-column:1 / -1!important;
  }
  body.auth-ready #page-stats .dashboard-summary{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}


/* v26 logo proportion fix + check-in modal layering polish */
.qbad-brand-mark,
.auth-brand-mark,
.topbar-brand-mark,
.desktop-qbad-mark{
  display:block!important;
  flex:0 0 auto!important;
  width:auto;
  height:auto;
  min-width:0;
  min-height:0;
  aspect-ratio:1 / 1;
  object-fit:contain;
  overflow:visible!important;
  transform:none!important;
}

.qbad-brand-auth,
.topbar-logo,
.desktop-brand-logo{
  flex-wrap:nowrap!important;
}

.auth-brand-mark-wrap,
.desktop-brand-mark{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 auto!important;
}

.auth-brand-mark-wrap{
  width:56px!important;
  height:56px!important;
  min-width:56px!important;
  min-height:56px!important;
}

.auth-brand-mark{
  width:52px!important;
  height:52px!important;
  min-width:52px!important;
  min-height:52px!important;
}

.topbar-brand-mark{
  width:28px!important;
  height:28px!important;
  min-width:28px!important;
  min-height:28px!important;
}

.desktop-brand-mark{
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
}

.desktop-qbad-mark{
  width:38px!important;
  height:38px!important;
  min-width:38px!important;
  min-height:38px!important;
}

.auth-brand-copy,
.desktop-brand-copy{
  min-width:0!important;
}

.qbad-wordmark,
.desktop-brand-wordmark,
.topbar-wordmark,
.auth-wordmark{
  line-height:1!important;
  white-space:nowrap!important;
  flex:0 1 auto!important;
}

.topbar{
  z-index:720!important;
}

/* Desktop sidebar should stay above the special Check-in modal, but below regular modals */
@media (min-width:900px) and (min-height:560px), (min-width:768px) and (orientation:landscape) and (min-height:560px){
  body.auth-ready .desktop-sidebar{
    z-index:820!important;
  }
}

/* Mobile: keep the header visible and tappable while Check-in modal is open */
@media (max-width:767px){
  body.auth-ready .topbar{
    display:flex!important;
    z-index:720!important;
  }

  #checkin-modal.modal-backdrop{
    padding-top:calc(72px + env(safe-area-inset-top))!important;
    padding-bottom:calc(88px + env(safe-area-inset-bottom))!important;
  }

  #checkin-modal .checkin-sheet{
    height:min(760px,calc(100dvh - 176px - env(safe-area-inset-top) - env(safe-area-inset-bottom)))!important;
    max-height:calc(100dvh - 176px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  }
}

@supports not (height:100dvh){
  @media (max-width:767px){
    #checkin-modal .checkin-sheet{
      height:min(760px,calc(100vh - 176px - env(safe-area-inset-top) - env(safe-area-inset-bottom)))!important;
      max-height:calc(100vh - 176px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    }
  }
}

@media (max-width:520px){
  .topbar-logo{
    gap:8px!important;
  }

  .topbar-brand-mark{
    width:26px!important;
    height:26px!important;
    min-width:26px!important;
    min-height:26px!important;
  }

  .topbar-wordmark{
    font-size:19px!important;
  }

  .auth-brand-mark-wrap{
    width:54px!important;
    height:54px!important;
    min-width:54px!important;
    min-height:54px!important;
  }

  .auth-brand-mark{
    width:50px!important;
    height:50px!important;
    min-width:50px!important;
    min-height:50px!important;
  }
}


/* v27: use uploaded SVG file as the single source of truth for QBAD Pro logo */
.qbad-logo-img{
  display:block!important;
  object-fit:contain!important;
  object-position:center!important;
  max-width:100%!important;
  max-height:100%!important;
  flex:0 0 auto!important;
  aspect-ratio:1 / 1!important;
  transform:none!important;
  filter:none;
}

.auth-brand-mark-wrap,
.desktop-brand-mark{
  overflow:visible!important;
}

.auth-brand-mark{
  width:52px!important;
  height:52px!important;
}

.topbar-brand-mark{
  width:28px!important;
  height:28px!important;
}

.desktop-qbad-mark{
  width:38px!important;
  height:38px!important;
}

/* Keep the uploaded file looking crisp on dark backgrounds without adding any frame. */
html[data-theme="dark"] .qbad-logo-img{
  filter:drop-shadow(0 6px 14px rgba(0,0,0,.18));
}

@media(max-width:520px){
  .auth-brand-mark{width:50px!important;height:50px!important;}
  .topbar-brand-mark{width:26px!important;height:26px!important;}
}


/* v28 Desktop navbar polish + SVG logo dark-mode white */
.desktop-window-dots{
  display:none!important;
}

html[data-theme="dark"] .qbad-logo-img{
  filter:brightness(0) invert(1) drop-shadow(0 8px 16px rgba(0,0,0,.20))!important;
  opacity:.96;
}

/* Keep uploaded SVG crisp and proportional */
.qbad-logo-img,
.auth-brand-mark,
.topbar-brand-mark,
.desktop-qbad-mark{
  object-fit:contain!important;
  object-position:center!important;
  aspect-ratio:1 / 1!important;
}

/* Make the brand block fit better inside desktop sidebar */
@media (min-width:900px) and (min-height:560px), (min-width:768px) and (orientation:landscape) and (min-height:560px){
  body.auth-ready .desktop-brand{
    padding:22px 18px 14px!important;
  }

  body.auth-ready .desktop-brand-logo{
    gap:12px!important;
    align-items:center!important;
  }

  body.auth-ready .desktop-brand-mark{
    width:38px!important;
    height:38px!important;
    min-width:38px!important;
    min-height:38px!important;
  }

  body.auth-ready .desktop-qbad-mark{
    width:36px!important;
    height:36px!important;
    min-width:36px!important;
    min-height:36px!important;
  }

  body.auth-ready .desktop-brand-copy{
    gap:3px!important;
  }

  body.auth-ready .desktop-brand-wordmark{
    font-size:19px!important;
    line-height:1!important;
    letter-spacing:-.03em!important;
  }

  body.auth-ready .desktop-brand span#desktop-room-name{
    max-width:170px!important;
    font-size:11.5px!important;
    margin-top:0!important;
    color:var(--muted)!important;
  }

  /* Gear moved from Management into the user card */
  body.auth-ready .desktop-user-card{
    min-height:60px!important;
    padding:9px 9px 9px 10px!important;
    gap:9px!important;
  }

  .desktop-user-settings-btn{
    width:34px;
    height:34px;
    border-radius:999px;
    border:1px solid rgba(125,132,145,.18);
    background:rgba(255,255,255,.46);
    color:var(--muted);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    transition:all .15s ease;
    flex:0 0 auto;
  }

  .desktop-user-settings-btn svg{
    width:17px;
    height:17px;
  }

  .desktop-user-settings-btn:hover,
  .desktop-user-settings-btn.active{
    color:var(--accent);
    border-color:rgba(17,184,154,.32);
    background:rgba(17,184,154,.10);
  }

  html[data-theme="dark"] .desktop-user-settings-btn{
    background:rgba(255,255,255,.055);
    border-color:rgba(148,163,184,.16);
    color:#aab7ca;
  }

  html[data-theme="dark"] .desktop-user-settings-btn:hover,
  html[data-theme="dark"] .desktop-user-settings-btn.active{
    color:var(--accent);
    border-color:rgba(45,212,191,.36);
    background:rgba(45,212,191,.10);
  }
}

@media(max-width:520px){
  html[data-theme="dark"] .topbar-brand-mark,
  html[data-theme="dark"] .auth-brand-mark{
    filter:brightness(0) invert(1) drop-shadow(0 6px 12px rgba(0,0,0,.18))!important;
  }
}


/* v29 Responsive header fit polish
   Scope: mobile + portrait/tablet header only. Desktop sidebar layout remains unchanged. */
@media (max-width:899px), (orientation:portrait){
  body.auth-ready .topbar,
  .topbar{
    height:60px!important;
    min-height:60px!important;
    width:100%!important;
    max-width:none!important;
    margin:0!important;
    padding:0 12px!important;
    display:grid!important;
    grid-template-columns:38px minmax(0,1fr) auto!important;
    gap:8px!important;
    align-items:center!important;
    border-radius:0 0 18px 18px!important;
    border-left:0!important;
    border-right:0!important;
  }

  .topbar .theme-toggle{
    grid-column:1!important;
    justify-self:start!important;
    width:36px!important;
    height:36px!important;
    min-width:36px!important;
    min-height:36px!important;
    margin:0!important;
  }

  .topbar-logo{
    grid-column:2!important;
    justify-self:center!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    gap:7px!important;
    min-width:0!important;
    max-width:100%!important;
    padding:0!important;
    overflow:hidden!important;
  }

  .topbar-brand-mark{
    width:25px!important;
    height:25px!important;
    min-width:25px!important;
    min-height:25px!important;
  }

  .topbar-wordmark{
    font-size:20px!important;
    line-height:1!important;
    max-width:118px!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
  }

  .topbar-actions{
    grid-column:3!important;
    justify-self:end!important;
    position:relative!important;
    right:auto!important;
    width:auto!important;
    height:40px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:flex-end!important;
    gap:6px!important;
    min-width:0!important;
  }

  .header-logout-btn,
  .header-settings-btn{
    width:36px!important;
    height:36px!important;
    min-width:36px!important;
    min-height:36px!important;
    margin:0!important;
    padding:0!important;
    flex:0 0 36px!important;
  }

  .header-logout-btn svg,
  .header-settings-btn svg,
  .topbar .theme-toggle svg{
    width:17px!important;
    height:17px!important;
  }

  .topbar-actions .sync-dot{
    position:absolute!important;
    right:-1px!important;
    top:5px!important;
    width:8px!important;
    height:8px!important;
    border:2px solid var(--card)!important;
    box-shadow:none!important;
    pointer-events:none!important;
  }

  .topbar-actions .room-user-chip{
    display:none!important;
  }
}

@media (max-width:380px){
  .topbar{
    padding:0 10px!important;
    grid-template-columns:36px minmax(0,1fr) auto!important;
    gap:6px!important;
  }

  .topbar .theme-toggle,
  .header-logout-btn,
  .header-settings-btn{
    width:34px!important;
    height:34px!important;
    min-width:34px!important;
    min-height:34px!important;
    flex-basis:34px!important;
  }

  .topbar-logo{gap:6px!important;}
  .topbar-brand-mark{width:23px!important;height:23px!important;min-width:23px!important;min-height:23px!important;}
  .topbar-wordmark{font-size:18px!important;max-width:104px!important;}
  .topbar-actions{gap:5px!important;height:38px!important;}
}

@media (max-width:340px){
  .topbar-wordmark{max-width:92px!important;font-size:17px!important;}
  .topbar-brand-mark{width:22px!important;height:22px!important;min-width:22px!important;min-height:22px!important;}
  .topbar-actions{gap:4px!important;}
}

/* v30 Responsive wordmark clipping fix
   Fix: italic "Pro" could be clipped by overflow/max-width in mobile header. */
.topbar-wordmark,
.qbad-wordmark{
  overflow:visible!important;
  text-overflow:clip!important;
  padding-right:.16em!important;
}

.qbad-pro{
  display:inline-block!important;
  padding-right:.14em!important;
  margin-right:-.04em!important;
  line-height:1.12!important;
}

.qbad-word{
  display:inline-block!important;
  line-height:1.12!important;
}

@media (max-width:899px), (orientation:portrait){
  .topbar-logo{
    overflow:visible!important;
  }
  .topbar-wordmark{
    max-width:none!important;
    min-width:max-content!important;
    line-height:1.12!important;
  }
}

@media (max-width:380px){
  .topbar-wordmark{
    max-width:none!important;
    font-size:17.5px!important;
  }
}

@media (max-width:340px){
  .topbar-wordmark{
    max-width:none!important;
    font-size:16.5px!important;
  }
}


/* =========================================================
   QBAD Pro v31
   Desktop Navbar Settings + Account UX Polish
   Desktop only — does not affect responsive/mobile navigation
   ========================================================= */

@media (min-width:900px) and (min-height:560px),
       (min-width:768px) and (orientation:landscape) and (min-height:560px){

  /* Rename is handled in index.html: Management -> Settings */

  .desktop-account-actions{
    padding-top:10px!important;
    padding-bottom:4px!important;
    margin-top:2px!important;
    border-top:1px solid rgba(125,132,145,.12)!important;
  }

  html[data-theme="dark"] .desktop-account-actions{
    border-top-color:rgba(148,163,184,.10)!important;
  }

  .desktop-account-actions .desktop-nav-label{
    font-size:10.5px!important;
    letter-spacing:.8px!important;
    opacity:.48!important;
    padding-bottom:6px!important;
  }

  .desktop-account-actions .desktop-nav-item{
    min-height:38px!important;
    border-radius:13px!important;
    padding-left:10px!important;
    padding-right:10px!important;
    gap:10px!important;
    font-size:12.5px!important;
    font-weight:700!important;
    color:var(--muted)!important;
    opacity:.64!important;
    background:transparent!important;
    border-color:transparent!important;
    box-shadow:none!important;
    transform:none!important;
  }

  .desktop-account-actions .desktop-nav-item + .desktop-nav-item{
    margin-top:3px!important;
  }

  .desktop-account-actions .desktop-nav-item svg,
  .desktop-account-actions .desktop-theme-icon{
    width:17px!important;
    height:17px!important;
    opacity:.78!important;
  }

  .desktop-account-actions .desktop-nav-item:hover{
    opacity:.94!important;
    background:rgba(125,132,145,.065)!important;
    border-color:rgba(125,132,145,.08)!important;
    color:var(--text)!important;
    transform:none!important;
  }

  html[data-theme="dark"] .desktop-account-actions .desktop-nav-item:hover{
    background:rgba(255,255,255,.045)!important;
    border-color:rgba(148,163,184,.10)!important;
  }

  .desktop-account-actions .desktop-theme-action:hover svg,
  .desktop-account-actions .desktop-theme-action:hover .desktop-theme-icon{
    color:var(--accent)!important;
  }

  .desktop-account-actions .desktop-logout-action{
    color:var(--muted)!important;
    opacity:.50!important;
  }

  .desktop-account-actions .desktop-logout-action:hover{
    color:var(--out)!important;
    opacity:.86!important;
    background:rgba(220,38,38,.055)!important;
    border-color:rgba(220,38,38,.10)!important;
  }

  .desktop-user-card{
    margin-top:4px!important;
  }
}

/* =========================================================
   Modal Header Theme Fix
   Keeps Light Mode modal headers light, Dark Mode headers dark
   ========================================================= */

html[data-theme="light"] .modal-header,
html[data-theme="light"] .history-modal-header{
  background:rgba(255,255,255,.94)!important;
  color:var(--text)!important;
  border-bottom:1px solid rgba(15,23,42,.08)!important;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}

html[data-theme="light"] .modal-header h2,
html[data-theme="light"] .history-modal-header h2,
html[data-theme="light"] .modal-header p,
html[data-theme="light"] .history-modal-header p,
html[data-theme="light"] .modal-title,
html[data-theme="light"] .history-modal-title{
  color:var(--text)!important;
}

html[data-theme="light"] .modal-header .muted,
html[data-theme="light"] .history-modal-header .muted,
html[data-theme="light"] .modal-subtitle,
html[data-theme="light"] .history-modal-subtitle{
  color:var(--muted)!important;
}

html[data-theme="dark"] .modal-header,
html[data-theme="dark"] .history-modal-header{
  background:rgba(7,12,24,.92)!important;
  color:#f8fafc!important;
  border-bottom:1px solid rgba(255,255,255,.06)!important;
}


/* =========================================================
   QBAD Pro v32 - Desktop top-right account action section
   Desktop only: move Theme + Logout out of sidebar
   ========================================================= */

.desktop-top-actions{
  display:none;
}

@media (min-width:900px) and (min-height:560px),
       (min-width:768px) and (orientation:landscape) and (min-height:560px){

  body.auth-ready .desktop-top-actions{
    position:fixed;
    top:18px;
    right:22px;
    z-index:830;
    display:flex;
    align-items:center;
    gap:8px;
    padding:8px;
    border-radius:22px;
    background:rgba(255,255,255,.74);
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 18px 44px rgba(15,23,42,.10);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
  }

  html[data-theme="dark"] body.auth-ready .desktop-top-actions{
    background:rgba(10,16,30,.70);
    border-color:rgba(148,163,184,.16);
    box-shadow:0 18px 48px rgba(0,0,0,.28);
  }

  body.auth-checking .desktop-top-actions,
  body.auth-required .desktop-top-actions,
  body.auth-no-access .desktop-top-actions{
    display:none!important;
  }

  .desktop-top-action-btn{
    height:38px;
    min-width:38px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:0 12px;
    border-radius:16px;
    border:1px solid rgba(15,23,42,.10);
    background:rgba(15,23,42,.045);
    color:var(--text);
    font:inherit;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
    transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease;
    opacity:1;
  }

  .desktop-top-action-btn:hover{
    opacity:1;
    color:var(--text);
    background:rgba(15,23,42,.08);
    border-color:rgba(15,23,42,.14);
    transform:translateY(-1px);
  }

  html[data-theme="dark"] .desktop-top-action-btn{
    border-color:rgba(255,255,255,.10);
    background:rgba(255,255,255,.07);
    color:var(--text);
  }

  html[data-theme="dark"] .desktop-top-action-btn:hover{
    background:rgba(255,255,255,.12);
    border-color:rgba(255,255,255,.18);
  }

  .desktop-top-action-btn svg,
  .desktop-top-action-btn .desktop-theme-icon{
    width:18px;
    height:18px;
    flex:0 0 18px;
  }

  .desktop-top-logout-action{
    color:rgb(220,38,38);
    opacity:1;
  }

  .desktop-top-logout-action:hover{
    color:rgb(220,38,38);
    background:rgba(239,68,68,.10);
    border-color:rgba(239,68,68,.18);
    opacity:1;
  }

  html[data-theme="dark"] .desktop-top-logout-action{
    color:rgb(248,113,113);
    opacity:1;
  }

  html[data-theme="dark"] .desktop-top-logout-action:hover{
    color:rgb(248,113,113);
    background:rgba(248,113,113,.12);
    border-color:rgba(248,113,113,.20);
  }

  .desktop-top-theme-action .desktop-theme-icon{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
  }

  @media (max-width:1180px){
    body.auth-ready .desktop-top-actions{
      right:16px;
      top:16px;
      padding:7px;
      gap:6px;
    }
    .desktop-top-action-btn{
      width:38px;
      padding:0;
    }
    .desktop-top-action-btn span:not(.desktop-theme-icon){
      display:none;
    }
  }
}

@media (max-width:899px), (orientation:portrait){
  .desktop-top-actions{
    display:none!important;
  }
}


/* =========================================================
   QBAD Pro v36 — Member Permission + User Card Status Dot Fix
   Scope: visual permission only; JS guard still protects actions.
   ========================================================= */

/* Remove unclear red status dot from desktop user card */
.desktop-user-card .sync-dot,
.desktop-user-card .desktop-sync-dot{
  display:none !important;
}

/* Member role: hide owner/admin-only entry points */
body.role-member-mode #nav-expense,
body.role-member-mode [data-nav-target="expense"],
body.role-member-mode [data-nav-target="settings-courts"],
body.role-member-mode #settings-tab-courts,
body.role-member-mode #settings-panel-players .add-player-card,
body.role-member-mode .deleted-open-btn,
body.role-member-mode .edit-player-delete-link,
body.role-member-mode .bulk-chip.danger{
  display:none !important;
}

/* Guest keeps the same restricted UX */
body.guest-mode #nav-expense,
body.guest-mode [data-nav-target="expense"],
body.guest-mode [data-nav-target="settings-courts"],
body.guest-mode #settings-tab-courts,
body.guest-mode #settings-panel-players .add-player-card,
body.guest-mode .deleted-open-btn,
body.guest-mode .edit-player-delete-link,
body.guest-mode .bulk-chip.danger{
  display:none !important;
}

/* Keep user card visually balanced after removing the status dot */
.desktop-user-card{
  gap:10px;
}

.desktop-user-settings-btn{
  margin-left:auto;
}

/* =========================================================
   QBAD Pro v37 — Desktop top actions overlap fix
   Fix: prevent the top-right Theme/Logout action box from overlapping
   the Stats "ดูสรุปย้อนหลัง" button and Expense history button.
   Scope: Desktop / tablet landscape only. Mobile is untouched.
   ========================================================= */

@media (min-width:900px) and (min-height:560px),
       (min-width:768px) and (orientation:landscape) and (min-height:560px){

  /* Reserve the right-top action area on desktop pages that have header actions */
  body.auth-ready #page-stats .stats-dashboard-head,
  body.auth-ready #page-settings .settings-expense-panel .expense-title-row{
    box-sizing:border-box!important;
    padding-right:190px!important;
  }

  body.auth-ready #page-stats .stats-history-entry-btn,
  body.auth-ready #page-settings .settings-expense-panel .expense-history-pill-btn{
    position:relative!important;
    z-index:1!important;
    margin-left:auto!important;
  }

  /* Keep the account action box above background but visually separate */
  body.auth-ready .desktop-top-actions{
    z-index:840!important;
  }
}

@media (min-width:900px) and (max-width:1180px) and (min-height:560px),
       (min-width:768px) and (max-width:1180px) and (orientation:landscape) and (min-height:560px){

  /* Top actions become icon-only in this range, so reserve less space */
  body.auth-ready #page-stats .stats-dashboard-head,
  body.auth-ready #page-settings .settings-expense-panel .expense-title-row{
    padding-right:116px!important;
  }
}

@media (min-width:900px) and (max-width:980px) and (min-height:560px),
       (min-width:768px) and (max-width:980px) and (orientation:landscape) and (min-height:560px){

  /* Very narrow landscape/tablet: stack page header actions for safe layout */
  body.auth-ready #page-stats .stats-dashboard-head{
    align-items:flex-start!important;
  }

  body.auth-ready #page-stats .stats-history-entry-btn{
    min-width:0!important;
    max-width:240px!important;
  }
}

/* =========================================================
   QBAD Pro v41 — Responsive history modal layer fix
   Fix: session/expense history modal must not be hidden behind
   mobile header or bottom navigation. Check-in modal behavior is untouched.
   ========================================================= */

@media (max-width:899px), (orientation:portrait){

  /* History/detail modals are primary overlays on mobile */
  #session-history-modal,
  #expense-history-modal,
  #deleted-players-modal,
  #edit-player-modal,
  #admin-pin-modal{
    z-index:1400!important;
    align-items:center!important;
    justify-content:center!important;
    padding:
      calc(12px + env(safe-area-inset-top))
      12px
      calc(12px + env(safe-area-inset-bottom))!important;
    overflow:hidden!important;
  }

  #session-history-modal .modal-sheet,
  #expense-history-modal .modal-sheet,
  #deleted-players-modal .modal-sheet,
  #edit-player-modal .modal-sheet,
  #admin-pin-modal .modal-sheet{
    position:relative!important;
    z-index:1410!important;
    width:min(100%, 520px)!important;
    max-width:520px!important;
    max-height:
      calc(
        100dvh
        - 24px
        - env(safe-area-inset-top)
        - env(safe-area-inset-bottom)
      )!important;
    margin:0 auto!important;
    display:flex!important;
    flex-direction:column!important;
    overflow:hidden!important;
  }

  #session-history-modal .modal-header,
  #expense-history-modal .modal-header,
  #deleted-players-modal .modal-header,
  #edit-player-modal .modal-header,
  #admin-pin-modal .modal-header{
    flex:0 0 auto!important;
    position:relative!important;
    z-index:2!important;
  }

  #session-history-modal .modal-body,
  #expense-history-modal .modal-body,
  #deleted-players-modal .modal-body,
  #edit-player-modal .modal-body,
  #admin-pin-modal .modal-body{
    flex:1 1 auto!important;
    min-height:0!important;
    overflow-y:auto!important;
    overscroll-behavior:contain!important;
    -webkit-overflow-scrolling:touch!important;
    padding-bottom:18px!important;
  }

  /* Make sure app chrome never floats over these modals */
  body:has(#session-history-modal:not(.hidden)) .topbar,
  body:has(#expense-history-modal:not(.hidden)) .topbar,
  body:has(#deleted-players-modal:not(.hidden)) .topbar,
  body:has(#edit-player-modal:not(.hidden)) .topbar,
  body:has(#admin-pin-modal:not(.hidden)) .topbar,
  body:has(#session-history-modal:not(.hidden)) .bottom-nav,
  body:has(#expense-history-modal:not(.hidden)) .bottom-nav,
  body:has(#deleted-players-modal:not(.hidden)) .bottom-nav,
  body:has(#edit-player-modal:not(.hidden)) .bottom-nav,
  body:has(#admin-pin-modal:not(.hidden)) .bottom-nav{
    z-index:300!important;
    pointer-events:none!important;
  }

  /* Keep Check-in modal special: bottom nav can remain clickable there */
  #checkin-modal{
    z-index:500!important;
  }

  #checkin-modal .modal-sheet{
    z-index:610!important;
  }
}

@media (max-width:420px){
  #session-history-modal,
  #expense-history-modal,
  #deleted-players-modal,
  #edit-player-modal,
  #admin-pin-modal{
    padding:
      calc(8px + env(safe-area-inset-top))
      8px
      calc(8px + env(safe-area-inset-bottom))!important;
  }

  #session-history-modal .modal-sheet,
  #expense-history-modal .modal-sheet,
  #deleted-players-modal .modal-sheet,
  #edit-player-modal .modal-sheet,
  #admin-pin-modal .modal-sheet{
    max-height:
      calc(
        100dvh
        - 16px
        - env(safe-area-inset-top)
        - env(safe-area-inset-bottom)
      )!important;
  }
}

/* =========================================================
   QBAD Pro v42 — Player Dashboard responsive modal layer fix
   Fix: player dashboard modal must not sit under mobile topbar/bottom nav.
   Scope: mobile/tablet portrait only. Desktop unchanged.
   ========================================================= */

@media (max-width:899px), (orientation:portrait){

  #player-dashboard-modal{
    z-index:1400!important;
    align-items:center!important;
    justify-content:center!important;
    padding:
      calc(12px + env(safe-area-inset-top))
      12px
      calc(12px + env(safe-area-inset-bottom))!important;
    overflow:hidden!important;
  }

  #player-dashboard-modal .modal-sheet,
  #player-dashboard-modal .player-dashboard-sheet{
    position:relative!important;
    z-index:1410!important;
    width:min(100%, 520px)!important;
    max-width:520px!important;
    max-height:
      calc(
        100dvh
        - 24px
        - env(safe-area-inset-top)
        - env(safe-area-inset-bottom)
      )!important;
    margin:0 auto!important;
    display:flex!important;
    flex-direction:column!important;
    overflow:hidden!important;
    border-radius:26px!important;
  }

  @supports not (height:100dvh){
    #player-dashboard-modal .modal-sheet,
    #player-dashboard-modal .player-dashboard-sheet{
      max-height:
        calc(
          100vh
          - 24px
          - env(safe-area-inset-top)
          - env(safe-area-inset-bottom)
        )!important;
    }
  }

  #player-dashboard-modal .modal-header{
    flex:0 0 auto!important;
    position:relative!important;
    z-index:2!important;
  }

  #player-dashboard-modal .modal-body,
  #player-dashboard-modal .player-dashboard-body{
    flex:1 1 auto!important;
    min-height:0!important;
    overflow-y:auto!important;
    overscroll-behavior:contain!important;
    -webkit-overflow-scrolling:touch!important;
    padding-bottom:18px!important;
  }

  body:has(#player-dashboard-modal:not(.hidden)) .topbar,
  body:has(#player-dashboard-modal:not(.hidden)) .bottom-nav{
    z-index:300!important;
    pointer-events:none!important;
  }
}

@media (max-width:420px){
  #player-dashboard-modal{
    padding:
      calc(8px + env(safe-area-inset-top))
      8px
      calc(8px + env(safe-area-inset-bottom))!important;
  }

  #player-dashboard-modal .modal-sheet,
  #player-dashboard-modal .player-dashboard-sheet{
    max-height:
      calc(
        100dvh
        - 16px
        - env(safe-area-inset-top)
        - env(safe-area-inset-bottom)
      )!important;
    border-radius:24px!important;
  }
}

/* =========================================================
   QBAD Pro v44
   Premium Stats Segmented Control + Icons
   Scope: Stats page only
========================================================= */

#page-stats .stats-tabs{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  width:min(100%, 680px) !important;
  padding:6px !important;
  margin:18px 0 18px !important;
  border-radius:22px !important;
  background:rgba(10,18,35,.72) !important;
  border:1px solid rgba(255,255,255,.07) !important;
  box-shadow:0 10px 30px rgba(0,0,0,.18) !important;
  backdrop-filter:blur(16px) !important;
  -webkit-backdrop-filter:blur(16px) !important;
}

#page-stats .stats-tab{
  position:relative !important;
  flex:1 1 0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  min-width:0 !important;
  height:52px !important;
  padding:0 18px !important;
  border-radius:16px !important;
  border:1px solid transparent !important;
  background:transparent !important;
  color:var(--muted) !important;
  font-family:inherit !important;
  font-size:15px !important;
  font-weight:800 !important;
  letter-spacing:-.02em !important;
  cursor:pointer !important;
  box-shadow:none !important;
  transition:background .22s ease,border-color .22s ease,color .22s ease,transform .22s ease,box-shadow .22s ease !important;
}

#page-stats .stats-tab i{
  font-size:14px !important;
  line-height:1 !important;
  opacity:.92 !important;
}

#page-stats .stats-tab.active{
  color:#fff !important;
  background:linear-gradient(135deg, rgba(34,211,238,.18), rgba(99,102,241,.14)) !important;
  border-color:rgba(34,211,238,.20) !important;
  box-shadow:0 8px 30px rgba(34,211,238,.13), inset 0 1px 0 rgba(255,255,255,.08) !important;
  transform:translateY(-1px) !important;
}

#page-stats .stats-tab:not(.active):hover{
  background:rgba(255,255,255,.05) !important;
  color:var(--text) !important;
}

html[data-theme="light"] #page-stats .stats-tabs{
  background:rgba(255,255,255,.76) !important;
  border-color:rgba(15,23,42,.07) !important;
  box-shadow:0 10px 30px rgba(15,23,42,.08) !important;
}

html[data-theme="light"] #page-stats .stats-tab{
  color:#64748b !important;
}

html[data-theme="light"] #page-stats .stats-tab.active{
  color:#0f172a !important;
  background:linear-gradient(135deg, rgba(20,184,166,.14), rgba(59,130,246,.10)) !important;
  border-color:rgba(20,184,166,.18) !important;
  box-shadow:0 8px 24px rgba(20,184,166,.12), inset 0 1px 0 rgba(255,255,255,.70) !important;
}

html[data-theme="light"] #page-stats .stats-tab:not(.active):hover{
  background:rgba(15,23,42,.045) !important;
  color:#0f172a !important;
}

@media(max-width:899px), (orientation:portrait){
  #page-stats .stats-tabs{
    width:100% !important;
    margin-top:14px !important;
    margin-bottom:16px !important;
    border-radius:20px !important;
  }

  #page-stats .stats-tab{
    height:48px !important;
    padding:0 12px !important;
    font-size:14px !important;
    gap:8px !important;
    border-radius:15px !important;
  }

  #page-stats .stats-tab i{
    font-size:13px !important;
  }
}

@media(max-width:360px){
  #page-stats .stats-tab{
    font-size:13px !important;
    gap:6px !important;
  }
}


/* =========================================================
   QBAD Pro v45
   Stats tabs desktop fit + All-time date range filter
   Scope: Stats page only
========================================================= */

#page-stats .stats-tabs.stats-tabs-two{
  width:100% !important;
  max-width:none !important;
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  margin:16px 0 18px !important;
  padding:6px !important;
}

@media (min-width:900px) and (orientation:landscape){
  #page-stats .stats-tabs.stats-tabs-two{
    min-height:58px !important;
  }

  #page-stats .stats-tabs.stats-tabs-two .stats-tab{
    height:46px !important;
  }
}

.alltime-range-filter{
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
  margin:14px 0 12px;
  padding:6px;
  border-radius:18px;
  background:rgba(10,18,35,.48);
  border:1px solid rgba(255,255,255,.06);
}

.alltime-range-btn{
  flex:1 1 0;
  min-width:0;
  height:38px;
  border:1px solid transparent;
  border-radius:14px;
  background:transparent;
  color:var(--muted);
  font:inherit;
  font-size:13px;
  font-weight:800;
  letter-spacing:-.01em;
  cursor:pointer;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease;
}

.alltime-range-btn:hover{
  color:var(--text);
  background:rgba(255,255,255,.05);
}

.alltime-range-btn.active{
  color:#fff;
  background:linear-gradient(135deg, rgba(34,211,238,.18), rgba(20,184,166,.14));
  border-color:rgba(34,211,238,.20);
  box-shadow:0 8px 24px rgba(34,211,238,.11), inset 0 1px 0 rgba(255,255,255,.07);
  transform:translateY(-1px);
}

html[data-theme="light"] .alltime-range-filter{
  background:rgba(248,250,252,.78);
  border-color:rgba(15,23,42,.07);
}

html[data-theme="light"] .alltime-range-btn{
  color:#64748b;
}

html[data-theme="light"] .alltime-range-btn:hover{
  color:#0f172a;
  background:rgba(15,23,42,.045);
}

html[data-theme="light"] .alltime-range-btn.active{
  color:#0f172a;
  background:linear-gradient(135deg, rgba(20,184,166,.14), rgba(59,130,246,.10));
  border-color:rgba(20,184,166,.18);
  box-shadow:0 8px 22px rgba(20,184,166,.10), inset 0 1px 0 rgba(255,255,255,.75);
}

@media(max-width:899px), (orientation:portrait){
  #page-stats .stats-tabs.stats-tabs-two{
    width:100% !important;
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }

  .alltime-range-filter{
    gap:6px;
    padding:5px;
    border-radius:16px;
  }

  .alltime-range-btn{
    height:36px;
    font-size:12px;
    border-radius:12px;
  }
}

/* =========================================================
   QBAD Pro v46
   Desktop Stats Tabs Fit Fix
   Scope: Stats page only
   Purpose: make Today / All-time segmented control align with
   the same content width as stat cards and all-time filter.
========================================================= */

/* Strong override for the main stats view switcher */
#page-stats .stats-tabs,
#page-stats .stats-tabs.stats-tabs-two,
body.auth-ready #page-stats .stats-tabs,
body.auth-ready #page-stats .stats-tabs.stats-tabs-two{
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
  box-sizing:border-box !important;
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  align-items:center !important;
  gap:8px !important;
  margin:16px 0 18px !important;
  padding:6px !important;
}

#page-stats .stats-tabs .stats-tab,
#page-stats .stats-tabs.stats-tabs-two .stats-tab,
body.auth-ready #page-stats .stats-tabs .stats-tab,
body.auth-ready #page-stats .stats-tabs.stats-tabs-two .stats-tab{
  width:100% !important;
  min-width:0 !important;
  max-width:none !important;
  justify-self:stretch !important;
}

/* Desktop / tablet landscape polish */
@media (min-width:900px) and (orientation:landscape){
  #page-stats .stats-tabs,
  #page-stats .stats-tabs.stats-tabs-two,
  body.auth-ready #page-stats .stats-tabs,
  body.auth-ready #page-stats .stats-tabs.stats-tabs-two{
    min-height:58px !important;
    border-radius:22px !important;
  }

  #page-stats .stats-tabs .stats-tab,
  #page-stats .stats-tabs.stats-tabs-two .stats-tab{
    height:46px !important;
    border-radius:16px !important;
  }
}

/* Keep mobile compact and full width */
@media(max-width:899px), (orientation:portrait){
  #page-stats .stats-tabs,
  #page-stats .stats-tabs.stats-tabs-two{
    width:100% !important;
    max-width:none !important;
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    margin:14px 0 16px !important;
  }
}

/* =========================================================
   QBAD Pro v50
   iPad / Tablet Landscape Overflow Fix
   - Prevent settings/player panels from overflowing to the right
   - Keep mobile portrait untouched
========================================================= */

@media (min-width:768px) and (max-width:1194px) and (orientation:landscape) and (min-height:560px){
  :root{
    --desktop-sidebar-width:232px !important;
    --desktop-sidebar-left:12px !important;
    --desktop-sidebar-y:12px !important;
    --desktop-content-gap:12px !important;
    --desktop-content-right:12px !important;
    --desktop-work-max:calc(100vw - var(--desktop-sidebar-left) - var(--desktop-sidebar-width) - var(--desktop-content-gap) - var(--desktop-content-right)) !important;
  }

  html,
  body{
    max-width:100%;
    overflow-x:hidden !important;
  }

  body.auth-ready{
    padding-left:calc(var(--desktop-sidebar-left) + var(--desktop-sidebar-width) + var(--desktop-content-gap)) !important;
    padding-right:var(--desktop-content-right) !important;
  }

  body.auth-ready .desktop-sidebar{
    width:var(--desktop-sidebar-width) !important;
    left:var(--desktop-sidebar-left) !important;
    top:var(--desktop-sidebar-y) !important;
    bottom:var(--desktop-sidebar-y) !important;
    border-radius:22px !important;
  }

  body.auth-ready .page,
  body.auth-ready #page-queue,
  body.auth-ready #page-stats,
  body.auth-ready #page-settings{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    margin:0 !important;
    padding-left:0 !important;
    padding-right:0 !important;
    box-sizing:border-box !important;
    overflow-x:hidden !important;
  }

  body.auth-ready .desktop-top-actions{
    right:12px !important;
    max-width:calc(100vw - var(--desktop-sidebar-left) - var(--desktop-sidebar-width) - 36px) !important;
  }

  body.auth-ready .desktop-brand{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  body.auth-ready .desktop-brand-wordmark{
    font-size:18px !important;
  }

  body.auth-ready .desktop-nav-scroll{
    padding-left:8px !important;
    padding-right:8px !important;
  }

  body.auth-ready .desktop-nav-item{
    min-height:42px !important;
    padding-left:9px !important;
    padding-right:9px !important;
    gap:9px !important;
    font-size:12.5px !important;
  }

  body.auth-ready .desktop-user-card{
    margin-left:10px !important;
    margin-right:10px !important;
    padding-left:8px !important;
    padding-right:8px !important;
  }

  body.auth-ready .desktop-user-info span{
    max-width:120px !important;
  }

  /* Settings page: switch tablet landscape to a clean single-column flow */
  body.auth-ready #settings-panel-players.active,
  body.auth-ready #settings-panel-courts.active,
  body.auth-ready #settings-panel-system.active,
  body.auth-ready #settings-panel-expense.active,
  body.auth-ready #settings-panel-access.active,
  body.auth-ready #settings-panel-access .access-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:14px !important;
    max-width:100% !important;
    width:100% !important;
    min-width:0 !important;
    overflow:hidden !important;
  }

  body.auth-ready #settings-panel-players > *,
  body.auth-ready #settings-panel-courts > *,
  body.auth-ready #settings-panel-system > *,
  body.auth-ready #settings-panel-expense > *,
  body.auth-ready #settings-panel-access > *,
  body.auth-ready #settings-panel-access .access-grid > *{
    grid-column:1 !important;
    grid-row:auto !important;
    position:static !important;
    max-width:100% !important;
    min-width:0 !important;
    width:100% !important;
    box-sizing:border-box !important;
  }

  /* Prevent wide player list controls from pushing outside viewport */
  body.auth-ready #page-settings .card,
  body.auth-ready #page-settings .settings-head,
  body.auth-ready #page-settings .settings-panel.active,
  body.auth-ready #settings-panel-players .player-list,
  body.auth-ready #settings-panel-players .player-row,
  body.auth-ready #settings-panel-players .players-list,
  body.auth-ready #settings-panel-players .settings-player-search-panel,
  body.auth-ready #settings-panel-players .player-search-box,
  body.auth-ready #settings-panel-players .status-filter-tabs,
  body.auth-ready #settings-panel-players .player-filter-tabs,
  body.auth-ready #settings-panel-players .search-box,
  body.auth-ready #settings-panel-players .toolbar,
  body.auth-ready #settings-panel-players .card-head,
  body.auth-ready #settings-panel-players .player-list-head{
    max-width:100% !important;
    min-width:0 !important;
    width:100% !important;
    box-sizing:border-box !important;
    overflow-x:hidden !important;
  }

  body.auth-ready #settings-panel-players .status-filter-tabs,
  body.auth-ready #settings-panel-players .player-filter-tabs{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:8px !important;
  }

  body.auth-ready #settings-panel-players .card-head,
  body.auth-ready #settings-panel-players .player-list-head,
  body.auth-ready #settings-panel-players .settings-panel-head{
    align-items:flex-start !important;
    gap:10px !important;
  }

  body.auth-ready #settings-panel-players .card-head .actions,
  body.auth-ready #settings-panel-players .player-actions,
  body.auth-ready #settings-panel-players .bulk-actions,
  body.auth-ready #settings-panel-players .title-actions{
    flex-wrap:wrap !important;
    justify-content:flex-start !important;
    max-width:100% !important;
  }

  /* Queue and stats should never create horizontal scroll on tablet landscape */
  body.auth-ready #page-queue .desktop-queue-layout,
  body.auth-ready #page-stats .stats-overview-compact,
  body.auth-ready #page-stats .dashboard-summary{
    min-width:0 !important;
    max-width:100% !important;
  }

  body.auth-ready #page-queue .desktop-queue-layout{
    grid-template-columns:1fr !important;
  }

  body.auth-ready #page-stats .stats-overview-compact{
    grid-template-columns:1fr !important;
  }

  body.auth-ready #page-stats .dashboard-summary{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}

/* =========================================================
   QBAD Pro v51
   Court-based Queue Empty Slot UX
   ========================================================= */

.court-empty-slot{
  min-height: 280px;
  border: 1.8px dashed rgba(148,163,184,.28) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.018)) !important;
  box-shadow: none !important;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:
    border-color .22s ease,
    background .22s ease,
    transform .22s ease,
    box-shadow .22s ease;
}

.court-empty-slot:hover{
  border-color: rgba(34,211,238,.46) !important;
  background:
    linear-gradient(180deg, rgba(34,211,238,.075), rgba(99,102,241,.035)) !important;
  box-shadow: 0 18px 48px rgba(15,23,42,.18) !important;
  transform: translateY(-1px);
}

.court-empty-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 18px 18px 0;
}

.court-empty-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:26px;
  padding:0 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:-.01em;
  color:var(--muted);
  background:rgba(148,163,184,.10);
  border:1px solid rgba(148,163,184,.16);
}

.court-empty-body{
  flex:1;
  min-height:190px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: 22px 18px 28px;
}

.court-empty-icon{
  width:58px;
  height:58px;
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(34,211,238,.92);
  background:
    linear-gradient(135deg, rgba(34,211,238,.12), rgba(99,102,241,.10));
  border:1px solid rgba(34,211,238,.18);
  margin-bottom:16px;
}

.court-empty-icon svg{
  width:26px;
  height:26px;
}

.court-empty-queue-btn{
  min-height:46px;
  padding:0 18px;
  border-radius:16px;
  border:1px solid rgba(34,211,238,.24);
  background:
    linear-gradient(135deg, rgba(34,211,238,.18), rgba(99,102,241,.14));
  color:var(--text);
  font:inherit;
  font-size:14px;
  font-weight:850;
  letter-spacing:-.02em;
  cursor:pointer;
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    background .18s ease,
    opacity .18s ease;
}

.court-empty-queue-btn:hover:not(:disabled){
  transform: translateY(-1px);
  border-color:rgba(34,211,238,.40);
  box-shadow:0 12px 28px rgba(34,211,238,.12);
}

.court-empty-queue-btn:disabled{
  cursor:not-allowed;
  opacity:.48;
  filter:saturate(.65);
}

.court-empty-body p{
  margin:10px 0 0;
  max-width:240px;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}

html[data-theme="light"] .court-empty-slot{
  border-color:rgba(15,23,42,.14) !important;
  background:rgba(255,255,255,.62) !important;
}

html[data-theme="light"] .court-empty-slot:hover{
  border-color:rgba(20,184,166,.38) !important;
  background:linear-gradient(180deg, rgba(20,184,166,.07), rgba(59,130,246,.035)) !important;
  box-shadow:0 18px 44px rgba(15,23,42,.08) !important;
}

html[data-theme="light"] .court-empty-badge{
  color:#64748b;
  background:rgba(15,23,42,.045);
  border-color:rgba(15,23,42,.08);
}

html[data-theme="light"] .court-empty-queue-btn{
  color:#0f172a;
  background:linear-gradient(135deg, rgba(20,184,166,.14), rgba(59,130,246,.10));
  border-color:rgba(20,184,166,.18);
}

@media (max-width: 899px){
  .court-empty-slot{
    min-height:240px;
  }
  .court-empty-body{
    min-height:160px;
    padding:18px 16px 24px;
  }
  .court-empty-icon{
    width:52px;
    height:52px;
    border-radius:20px;
  }
}


/* =========================================================
   QBAD Pro v52
   Court count availability + clickable empty court slot
   ========================================================= */

.court-opt.is-disabled{
  opacity:.42!important;
  filter:saturate(.55);
  cursor:not-allowed!important;
  border-style:dashed!important;
  background:rgba(148,163,184,.06)!important;
  color:var(--muted)!important;
}

.court-opt.is-disabled:hover{
  transform:none!important;
  box-shadow:none!important;
}

.court-empty-slot{
  cursor:pointer;
  transition:
    border-color .2s ease,
    background .2s ease,
    transform .2s ease,
    box-shadow .2s ease;
}

.court-empty-slot:hover{
  transform:translateY(-1px);
  border-color:rgba(34,211,238,.36)!important;
  background:rgba(34,211,238,.055)!important;
  box-shadow:0 18px 44px rgba(34,211,238,.08);
}

.court-empty-slot:focus-visible{
  outline:none;
  box-shadow:
    0 0 0 3px rgba(34,211,238,.18),
    0 18px 44px rgba(34,211,238,.08);
}

.court-empty-slot.is-disabled{
  cursor:not-allowed;
  opacity:.58;
  filter:saturate(.65);
}

.court-empty-slot.is-disabled:hover{
  transform:none;
  box-shadow:none;
  border-color:var(--border)!important;
  background:rgba(255,255,255,.02)!important;
}

.court-empty-slot .court-empty-icon{
  pointer-events:none;
}

.court-empty-slot .court-empty-queue-btn{
  position:relative;
  z-index:2;
}

html[data-theme="light"] .court-empty-slot:hover{
  background:rgba(20,184,166,.07)!important;
  border-color:rgba(20,184,166,.30)!important;
  box-shadow:0 18px 44px rgba(15,23,42,.07);
}


/* =========================================================
   QBAD Pro v53
   4-Court support + 2-column court board on Desktop/Tablet Landscape
   ========================================================= */

/* Court selector: support 4 options without squeezing labels */
.court-selector{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
}

.court-opt{
  min-width:0;
  white-space:nowrap;
}

/* Desktop / tablet landscape: show courts as 2 columns when selected courts > 1 */
@media (min-width:900px) and (min-height:560px),
       (min-width:768px) and (orientation:landscape) and (min-height:560px){

  body.auth-ready #page-queue #active-courts{
    display:grid !important;
    gap:14px !important;
    align-items:stretch !important;
  }

  body.auth-ready #page-queue #active-courts[data-court-count="1"]{
    grid-template-columns:1fr !important;
  }

  body.auth-ready #page-queue #active-courts[data-court-count="2"],
  body.auth-ready #page-queue #active-courts[data-court-count="3"],
  body.auth-ready #page-queue #active-courts[data-court-count="4"]{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  }

  body.auth-ready #page-queue #active-courts .court-card{
    width:100% !important;
    margin-bottom:0 !important;
    min-width:0 !important;
  }

  body.auth-ready #page-queue #active-courts .court-empty-slot{
    min-height:260px;
  }

  body.auth-ready #page-queue #active-courts .court-empty-body{
    min-height:160px;
  }
}

/* Tablet landscape with narrower content: keep 2 columns but compact cards slightly */
@media (min-width:768px) and (max-width:1099px) and (orientation:landscape){
  body.auth-ready #page-queue #active-courts[data-court-count="2"],
  body.auth-ready #page-queue #active-courts[data-court-count="3"],
  body.auth-ready #page-queue #active-courts[data-court-count="4"]{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:12px !important;
  }

  body.auth-ready #page-queue #active-courts .court-empty-slot{
    min-height:230px;
  }
}

/* Mobile portrait: always stack courts vertically for readability */
@media (max-width:899px) and (orientation:portrait){
  #page-queue #active-courts{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
  }

  .court-selector{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  }
}

/* =========================================================
   QBAD Pro v56
   Stats Latest Tab + 3-Way Segmented Control Polish
   ========================================================= */

#page-stats .stats-tabs.stats-tabs-three{
  width:100% !important;
  max-width:none !important;
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:8px !important;
}

#page-stats .stats-tabs.stats-tabs-three .stats-tab{
  width:100% !important;
  min-width:0 !important;
}

.latest-stats-card .alltime-card-head{
  margin-bottom:18px;
}

@media (max-width:768px){
  #page-stats .stats-tabs.stats-tabs-three{
    gap:6px !important;
    padding:5px !important;
  }

  #page-stats .stats-tabs.stats-tabs-three .stats-tab{
    font-size:12px !important;
    gap:6px !important;
    padding:0 8px !important;
  }

  #page-stats .stats-tabs.stats-tabs-three .stats-tab i{
    font-size:12px !important;
  }
}


/* Security v22: Turnstile anti-abuse widget */
.auth-turnstile-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  margin:10px 0 12px;
}
.register-turnstile{
  min-height:65px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.auth-turnstile-note{
  width:100%;
  border:1px solid rgba(245,158,11,.24);
  background:rgba(245,158,11,.09);
  color:#b45309;
  border-radius:12px;
  padding:9px 11px;
  font-size:12px;
  font-weight:700;
  text-align:left;
}
html[data-theme="dark"] .auth-turnstile-note{
  color:#fbbf24;
  background:rgba(245,158,11,.12);
  border-color:rgba(245,158,11,.24);
}
