*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0f;--surface:#333;--border:#444;--text:#e8e8e8;--text-muted:#bbb;--sub-text:#88e1ec;--accent:#e8c44a;--accent-hover:#f0d060;--danger:#e05252;--radius:8px;--font:system-ui, -apple-system, sans-serif}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,a:focus-visible{border-radius:var(--radius)}.app-layout{flex-direction:column;min-height:100vh;display:flex}.nav-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:2rem;height:44px;padding:0 1.5rem;display:flex;position:sticky;top:0}.nav-brand a{color:var(--accent);letter-spacing:.02em;font-size:1.2rem;font-weight:700}.nav-links{flex:1;gap:1.25rem;display:flex}.nav-links a{color:var(--text-muted);font-size:.95rem;transition:color .15s}.nav-links a:hover{color:var(--text)}.nav-user{align-items:center;gap:1rem;margin-left:auto;display:flex}.nav-username{color:var(--accent);margin:0 1rem;font-size:1.05rem;font-weight:600}.logout-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.35rem .85rem;font-size:.85rem;transition:border-color .15s,color .15s}.logout-btn:hover{border-color:var(--text-muted);color:var(--text)}.fullscreen-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;background:0 0;align-items:center;padding:.3rem .45rem;transition:border-color .15s,color .15s;display:flex}.fullscreen-btn:hover{border-color:var(--text-muted);color:var(--text)}.main-content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:.75rem}.dashboard h2{margin-bottom:.5rem;font-size:1.5rem}.dashboard p{color:var(--text-muted)}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:380px;padding:2.5rem 2rem}.login-title{text-align:center;color:var(--accent);margin-bottom:1.75rem;font-size:1.75rem;font-weight:700}.login-form{flex-direction:column;gap:1rem;display:flex}.form-label{color:var(--text-muted);flex-direction:column;gap:.4rem;font-size:.875rem;display:flex}.form-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;padding:.6rem .75rem;font-size:1rem;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.form-error{border-radius:var(--radius);color:var(--danger);background:#e052521a;border:1px solid #e052524d;padding:.6rem .75rem;font-size:.875rem}.btn-primary{background:var(--accent);border-radius:var(--radius);color:#000;cursor:pointer;border:none;margin-top:.25rem;padding:.7rem;font-size:1rem;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:1.25rem 0;font-size:.875rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.btn-google{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;text-align:center;justify-content:center;align-items:center;padding:.65rem;font-size:.95rem;transition:border-color .15s,background .15s;display:flex}.btn-google:hover{border-color:var(--text-muted);background:var(--surface)}.loading-screen{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.btn-as-link{justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.btn-primary.btn-as-link{padding:.55rem 1.25rem;font-size:.9rem}.btn-secondary{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.5rem 1rem;font-size:.9rem;transition:border-color .15s,color .15s}.btn-secondary:hover:not(:disabled){border-color:var(--text-muted);color:var(--text)}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.page-header h1{font-size:1.5rem;font-weight:700}.badge{text-transform:uppercase;letter-spacing:.05em;text-align:center;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-active{color:#48bb78;background:#48bb7826;border:1px solid #48bb784d}.badge-complete{color:var(--text-muted);border:1px solid var(--border);background:#8888881a}.badge-spectating{color:var(--accent);background:#e8c44a1a;border:1px solid #e8c44a4d}.match-top-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.match-top-bar .match-info-banner{flex:1;margin-bottom:0}.match-top-bar .input-mode-bar{margin-bottom:0}.back-link{color:var(--text-muted);white-space:nowrap;align-items:center;gap:.4rem;font-size:.875rem;text-decoration:none;transition:color .15s;display:inline-flex}.back-link:hover{color:var(--text)}.empty-state{color:var(--text-muted);padding:1rem 0;font-size:.9rem}.lobby-section{margin-bottom:2.5rem}.lobby-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.8rem;font-weight:600}.match-list{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.75rem;display:grid}.match-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:inherit;grid-template-columns:2fr 1fr;align-items:center;gap:.25rem 1rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .15s;display:grid}.match-card:hover{border-color:var(--accent)}.match-card-active{background:#48bb780f;border-color:#48bb784d}.match-card-active:hover{border-color:#48bb78}.match-card-players{font-size:1rem;font-weight:600}.match-card-meta{color:var(--text-muted);font-size:.825rem}.match-card-badges{justify-content:flex-end;align-items:center;gap:.4rem;display:flex}.match-card-time{color:var(--text-muted);justify-self:end;font-size:.8rem}.create-match-page{max-width:860px}.cm-settings-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;display:flex}.cm-settings-field{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.cm-settings-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:600}.cm-players-layout{grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.75rem;display:grid}@media (width<=600px){.cm-players-layout{grid-template-columns:1fr}.cm-settings-row{flex-wrap:wrap}.cm-settings-field{flex:calc(50% - .75rem)}}.cm-col-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.78rem;font-weight:600}.form-section{margin-bottom:1.75rem}.form-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.5rem;font-size:.8rem;font-weight:600}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-muted);font-size:.875rem}.form-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;outline:none;width:100%;padding:.55rem .75rem;font-size:.95rem;transition:border-color .15s}.form-select:focus{border-color:var(--accent)}.form-number{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;width:100%;padding:.55rem .75rem;font-size:.95rem;transition:border-color .15s}.form-number:focus{border-color:var(--accent)}.player-list{flex-direction:column;gap:.5rem;max-height:280px;display:flex;overflow-y:auto}.player-checkbox{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.65rem;padding:.65rem .75rem;transition:border-color .15s;display:flex}.player-checkbox:hover{border-color:var(--accent)}.player-checkbox.selected{border-color:var(--accent);background:#e8c44a0f}.player-checkbox input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent)}.player-checkbox-name{font-size:.9rem}.form-hint{color:var(--text-muted);margin-top:.5rem;font-size:.8rem}.form-actions{align-items:center;gap:.75rem;margin-top:2rem;display:flex}.match-layout{grid-template-columns:190px 1fr;align-items:start;gap:1.25rem;display:grid}@media (width<=900px){.match-layout{grid-template-columns:1fr;grid-template-areas:"right""left"}.match-right{grid-area:right}.match-left{flex-flow:wrap;grid-area:left;align-items:flex-start}.match-left .score-card{flex:1;min-width:120px}.match-left>:not(.score-card){flex:0 0 100%}.dartboard-svg{max-width:100%;height:min(100dvh - 120px,100vw)}.btn-grid{height:min(100dvh - 120px,100vw)}}@media (width<=500px){.match-left{flex-direction:column}.match-left .score-card{flex:none;min-width:0}.match-left>:not(.score-card){flex:none}}.match-left{flex-direction:column;gap:.5rem;display:flex}.match-right{min-width:0}.dartboard-svg{height:calc(100dvh - 120px)}.score-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem .9rem}.score-card-header{justify-content:space-between;align-items:baseline;gap:.5rem;margin-bottom:.3rem;display:flex}.score-card-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:600;overflow:hidden}.score-card-record{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.78rem;font-weight:600}.score-card-score{text-align:center;margin-bottom:.1rem;font-size:2.25rem;font-weight:700;line-height:1}.current-turn-info{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:.9rem 1.25rem}.current-turn-label{color:var(--text-muted);margin-bottom:.2rem;font-size:.75rem}.current-turn-name{font-size:1rem;font-weight:600}.checkout-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:.9rem 1.25rem}.checkout-panel-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.75rem;font-weight:600}.checkout-darts{flex-wrap:wrap;gap:.5rem;display:flex}.checkout-dart{color:var(--accent);background:#e8c44a1a;border:1px solid #e8c44a4d;border-radius:4px;padding:.2rem .55rem;font-family:monospace;font-size:.875rem;font-weight:600}.match-info-banner{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:.6rem;padding:.5rem .85rem;font-size:.82rem;display:flex}.match-info-sep{color:var(--border);-webkit-user-select:none;user-select:none}.match-info-parts{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.match-info-badges{margin-left:auto}.checkout-inline{border-radius:var(--radius);background:#e8c44a0d;border:1px solid #e8c44a33;align-items:center;gap:.6rem;margin-bottom:.75rem;padding:.6rem .85rem;display:flex}.checkout-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:.72rem;font-weight:700}.dart-slots{justify-content:center;gap:.4rem;min-height:26px;margin-top:.65rem;display:flex}.dart-slot{border:1px solid #0000;border-radius:3px;padding:.15rem .5rem;font-family:monospace;font-size:.9rem;font-weight:700}.dart-empty{color:var(--border);border-color:var(--border);background:0 0}.dart-s{color:var(--text);background:#ffffff0d;border-color:#444}.dart-d{color:#4db86a;background:#1a7a3514;border-color:#4db86a66}.dart-t{color:#e05555;background:#cc282814;border-color:#e0555566}.dart-bull{color:#2eaa5a;background:#2eaa5a14;border-color:#2eaa5a66}.dart-dbull{color:#e05555;background:#e0555514;border-color:#e0555566}.dart-miss{color:var(--text-muted);border-color:var(--border);opacity:.6;background:0 0}.scoring-placeholder{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--text-muted);margin-top:.75rem;padding:2rem;font-size:.875rem}.reconnecting-banner{border-radius:var(--radius);color:var(--accent);text-align:center;background:#e8c44a14;border:1px solid #e8c44a40;margin-bottom:.75rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;animation:1.5s ease-in-out infinite pulse-opacity}@keyframes pulse-opacity{0%,to{opacity:.6}50%{opacity:1}}.checkout-warning{border-radius:var(--radius);color:var(--danger);background:#e0525214;border:1px solid #e052524d;align-items:center;gap:.5rem;padding:.55rem .9rem;font-size:.82rem;display:flex}.checkout-warning-soft{border-color:var(--border);color:var(--text-muted);background:#8888880f}.checkout-warning-label{text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:.72rem;font-weight:700}.bust-banner{border-radius:var(--radius);color:var(--danger);text-align:center;background:#e052521f;border:1px solid #e0525266;margin-bottom:.75rem;padding:.75rem 1rem;font-size:1rem;font-weight:700;animation:.3s bust-flash}@keyframes bust-flash{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.match-complete-banner{border-radius:var(--radius);color:#48bb78;text-align:center;background:#48bb781a;border:1px solid #48bb7859;margin-bottom:1rem;padding:1rem;font-size:1.1rem;font-weight:700}.scoring-area{margin-top:.5rem}.input-mode-bar{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.mode-tab{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;padding:.4rem .9rem;font-size:.85rem;transition:border-color .15s,color .15s,background .15s}.mode-tab:hover{border-color:var(--text-muted);color:var(--text)}.mode-tab.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}.input-mode-bar .btn-undo{margin:auto .75rem}.btn-undo{background:var(--surface);border:1px solid var(--danger);border-radius:var(--radius);color:var(--danger);cursor:pointer;padding:.4rem .9rem;font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s}.btn-undo:hover:not(:disabled){border-color:var(--text-muted);color:var(--text)}.btn-undo:disabled{opacity:.4;cursor:not-allowed}.spectator-notice{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;color:var(--text-muted);padding:1.5rem;font-size:.9rem}.btn-grid{flex-direction:column;gap:.5rem;height:calc(100dvh - 120px);display:flex}.btn-grid-columns{flex:1;gap:0;min-height:0;display:flex}.btn-grid-col{flex-direction:column;flex:1;gap:5px;min-height:0;display:flex}.btn-grid-divider{background:var(--border);flex-shrink:0;width:1px;margin:0 .5rem}.btn-grid-row{flex:1;grid-template-columns:1fr 1fr 1fr;gap:5px;min-height:0;display:grid}.btn-seg{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:100%;min-width:0;height:100%;font-size:1.5rem;font-weight:600;transition:background .1s,border-color .1s;display:flex}.btn-seg:hover:not(:disabled){border-color:var(--text-muted);background:#2a2a2a}.btn-seg:disabled{opacity:.35;cursor:not-allowed}.btn-seg-d{color:#4db86a;background:#1a7a351f;border-color:#1a5c2a}.btn-seg-t{color:#e05555;background:#cc28281f;border-color:#7a2020}.btn-seg-s:hover:not(:disabled){color:var(--text)}.btn-seg-d:hover:not(:disabled){color:#6ed48a;background:#1a7a3538;border-color:#1a7a35}.btn-seg-t:hover:not(:disabled){color:#ff7070;background:#cc282838;border-color:#cc2828}.btn-seg-readonly,.btn-seg-readonly:hover{cursor:default;background:var(--surface)}.btn-seg-readonly.btn-seg-d:hover{background:#1a7a351f}.btn-seg-readonly.btn-seg-t:hover{background:#cc28281f}.btn-seg-marked{position:relative}.btn-marker-badge{color:#111;border-radius:3px;padding:1px 3px;font-size:.6rem;font-weight:700;line-height:1;position:absolute;top:2px;right:4px}.btn-grid-specials{border-top:1px solid var(--border);grid-template-columns:1fr 1fr 1fr;gap:5px;height:6rem;padding-top:.5rem;display:grid}.btn-special{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;justify-content:center;align-items:center;gap:.35rem;height:100%;padding:0;font-size:1.5rem;font-weight:600;transition:background .1s,border-color .1s;display:flex}.btn-special:hover:not(:disabled){border-color:var(--text-muted);background:#2a2a2a}.btn-special:disabled{opacity:.35;cursor:not-allowed}.btn-special.btn-seg-readonly:hover{cursor:default}.btn-special.btn-seg-readonly.btn-bull:hover{color:#4db86a;background:#1a7a351f;border-color:#1a5c2a}.btn-special.btn-seg-readonly.btn-dbull:hover{color:#e05555;background:#cc28281f;border-color:#7a2020}.btn-special.btn-seg-readonly.btn-miss:hover{color:var(--text)}.btn-special-score{opacity:.7;font-size:.75rem}.btn-bull{color:#4db86a;background:#1a7a351f;border-color:#1a5c2a}.btn-bull:hover:not(:disabled){color:#6ed48a;background:#1a7a3538;border-color:#1a7a35}.btn-dbull{color:#e05555;background:#cc28281f;border-color:#7a2020}.btn-dbull:hover:not(:disabled){color:#ff7070;background:#cc282838;border-color:#cc2828}.btn-miss:hover:not(:disabled){color:var(--text-muted)}.player-order-list{flex-direction:column;gap:.4rem;display:flex}.player-order-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:.75rem;padding:.55rem .75rem;display:flex}.player-order-num{color:var(--text-muted);text-align:right;flex-shrink:0;width:20px;font-size:.8rem;font-weight:700}.player-order-name{flex:1;font-size:.9rem;font-weight:500}.player-order-btns{flex-shrink:0;gap:.25rem;display:flex}.btn-order{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:.2rem .5rem;font-size:.8rem;line-height:1;transition:border-color .15s,color .15s}.btn-order:hover:not(:disabled){border-color:var(--text-muted);color:var(--text)}.btn-order:disabled{opacity:.25;cursor:not-allowed}.leg-complete-banner{border-radius:var(--radius);color:#60a5fa;background:#60a5fa1a;border:1px solid #60a5fa59;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:1rem;font-weight:700;animation:.25s slide-in;display:flex}.banner-dismiss{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 .25rem;font-size:1.25rem;line-height:1}.banner-dismiss:hover{opacity:1}.set-complete-banner{border-radius:var(--radius);color:#a78bfa;text-align:center;background:#a78bfa1a;border:1px solid #a78bfa59;margin-bottom:1rem;padding:.75rem 1rem;font-size:1rem;font-weight:700;animation:.25s slide-in}.match-winner-banner{border-radius:var(--radius);background:#48bb7814;border:1px solid #48bb7859;align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem 1.25rem;display:flex}.match-winner-label{text-transform:uppercase;letter-spacing:.08em;color:#48bb78;flex-shrink:0;font-size:.75rem;font-weight:700}.match-winner-name{color:#48bb78;flex:1;font-size:1.25rem;font-weight:700}.match-winner-link{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);white-space:nowrap;padding:.3rem .75rem;font-size:.85rem;text-decoration:none;transition:color .15s,border-color .15s}.match-winner-link:hover{color:var(--text);border-color:var(--text-muted)}@keyframes slide-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.match-stats-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.match-stats-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:.88rem}.match-stats-table th,.match-stats-table td{text-align:left;padding:.45rem .75rem}.match-stats-table th{color:var(--text-muted);border-bottom:1px solid var(--border);font-size:.78rem;font-weight:600}.match-stats-table th:not(:first-child){color:var(--text);font-size:1.2rem}.match-stats-table th.stat-header-winner{color:var(--accent)}.match-stats-table tr+tr td{border-top:1px solid #2e2e2e80}.match-stats-table td.muted{white-space:nowrap;width:150px;min-width:150px}.cricket-scoreboard{border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;margin-bottom:.75rem;font-size:.95rem}.cricket-scoreboard th,.cricket-scoreboard td{text-align:center;padding:.5rem .75rem}.cricket-scoreboard th{color:var(--text-muted);border-bottom:1px solid var(--border);font-size:.85rem;font-weight:600}.cricket-scoreboard th.stat-header-winner{color:var(--accent)}.cricket-scoreboard td.muted{text-align:left;color:var(--text-muted);white-space:nowrap;font-weight:600}.cricket-scoreboard tr+tr td{border-top:1px solid #2e2e2e80}.cricket-marks{font-variant-numeric:tabular-nums;font-size:1.3rem;font-weight:700}.cricket-points{font-variant-numeric:tabular-nums;font-size:1.2rem;font-weight:700}.stats-tabs{flex-wrap:wrap;gap:.4rem;margin-bottom:.85rem;display:flex}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.78rem;font-weight:600}.leaderboard-table-wrap{border-radius:var(--radius);border:1px solid var(--border);margin-top:1.25rem;overflow-x:auto}.leaderboard-table{border-collapse:collapse;width:100%;font-size:.88rem}.leaderboard-table th,.leaderboard-table td{text-align:center;white-space:nowrap;padding:.55rem .85rem}.leaderboard-table th{background:var(--surface);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);font-size:.75rem;font-weight:600}.leaderboard-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.leaderboard-table th.sortable:hover{color:var(--text)}.leaderboard-table th.sortable.active{color:var(--accent)}.sort-arrow{font-size:.7em;display:inline-block}.leaderboard-table tbody tr{transition:background .1s}.leaderboard-table tbody tr:hover{background:#ffffff08}.leaderboard-table tbody tr+tr td{border-top:1px solid #2e2e2e80}.rank-col{width:40px;text-align:center!important}.stat-num{font-variant-numeric:tabular-nums}.stat-num.accent{color:var(--accent);font-weight:600}.muted{color:var(--text-muted)}.player-link{color:var(--text);font-weight:600;text-decoration:none;transition:color .15s}.player-link:hover{color:var(--accent)}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.period-tabs{gap:.5rem;margin-bottom:.5rem;display:flex}.filter-bar .period-tabs{margin-bottom:0}.period-tab{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;padding:.35rem .9rem;font-size:.85rem;transition:border-color .15s,color .15s,background .15s}.period-tab:hover{border-color:var(--text-muted);color:var(--text)}.period-tab.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}.player-profile-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.player-profile-name{margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.player-profile-since{color:var(--text-muted);font-size:.85rem}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;display:grid}.stat-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.25rem;padding:.9rem 1rem;display:flex}.stat-value{font-variant-numeric:tabular-nums;color:var(--accent);text-align:center;font-size:1.5rem;font-weight:700}.stat-sub{color:var(--text);text-align:center;font-variant-numeric:tabular-nums;font-size:1rem}.stat-label{color:var(--text-muted);text-align:center;text-transform:uppercase;font-size:.75rem}.result-win{color:#48bb78;font-weight:600}.result-loss{color:var(--text-muted)}.compare-selectors{flex-wrap:wrap;align-items:center;gap:.75rem;max-width:900px;margin-bottom:1.5rem;display:flex}.compare-player-row{align-items:center;gap:.5rem;display:flex}.compare-selectors .form-select{min-width:180px}.compare-vs{color:var(--text-muted);flex-shrink:0;font-size:.85rem;font-weight:700}.compare-table-wrap{border-radius:var(--radius);border:1px solid var(--border);max-width:100%;overflow-x:auto}.compare-table{border-collapse:collapse;width:100%;font-size:.88rem}.compare-table th,.compare-table td{text-align:left;padding:.55rem .85rem}.compare-table thead th{background:var(--surface);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);font-size:.75rem;font-weight:700}.compare-table thead .compare-player-col{color:var(--text);text-transform:none;letter-spacing:0;font-size:.95rem}.compare-stat-col{min-width:160px}.compare-player-col{width:auto;min-width:110px;text-align:center!important}.compare-stat-label{color:var(--text-muted);font-size:.85rem}.compare-val{text-align:center;font-variant-numeric:tabular-nums}.compare-winner{color:var(--accent);font-weight:700}.compare-table tbody tr+tr td{border-top:1px solid #2e2e2e80}.compare-table tbody tr:hover td{background:#ffffff05}.admin-section-title{font-size:1.1rem;font-weight:700}.admin-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.25rem;padding:1.25rem}.admin-form-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.admin-form-row .form-group{flex:1;min-width:140px}.admin-form-submit{min-width:unset!important;flex:none!important}.admin-required{color:var(--danger)}.admin-table-wrap{border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.88rem}.admin-table th,.admin-table td{text-align:left;white-space:nowrap;padding:.55rem .85rem}.admin-table th{background:var(--surface);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);font-size:.75rem;font-weight:600}.admin-table tbody tr+tr td{border-top:1px solid #2e2e2e80}.admin-table tbody tr:hover td{background:#ffffff05}.admin-row-inactive td{opacity:.5}.admin-username{font-weight:600}.admin-date{font-size:.82rem}.admin-actions{justify-content:flex-end;gap:.4rem;display:flex}.admin-inline-input{width:100%;min-width:90px;padding:.35rem .5rem!important;font-size:.85rem!important}.admin-inline-error{color:var(--danger);margin-left:.5rem;font-size:.8rem}.btn-sm{padding:.3rem .7rem!important;font-size:.8rem!important}.btn-danger{color:var(--danger);border-radius:var(--radius);cursor:pointer;background:0 0;border:1px solid #e0525266;padding:.5rem 1rem;font-size:.9rem;transition:border-color .15s,background .15s}.btn-danger:hover:not(:disabled){border-color:var(--danger);background:#e0525214}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.badge-admin{color:var(--accent);background:#e8c44a1f;border:1px solid #e8c44a4d}.badge-inactive{color:var(--danger);background:#e052521a;border:1px solid #e0525240}.admin-filters{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.admin-filter-select{min-width:160px;width:auto!important}.admin-health-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin-bottom:2rem;display:grid}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem}.admin-stat-value{color:var(--accent);font-variant-numeric:tabular-nums;margin-bottom:.2rem;font-size:1.6rem;font-weight:700}.admin-stat-label{color:var(--text-muted);font-size:.78rem}.admin-health-section{margin-bottom:2rem}.admin-setting-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:1rem;max-width:500px;padding:1rem 1.25rem;display:flex}.admin-setting-label{margin-bottom:.2rem;font-size:.95rem;font-weight:600}.admin-setting-desc{font-size:.82rem}.admin-toggle{background:var(--border);cursor:pointer;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .2s;position:relative}.admin-toggle.admin-toggle-on{background:var(--accent)}.admin-toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;display:block;position:absolute;top:3px;left:3px}.admin-toggle.admin-toggle-on .admin-toggle-knob{transform:translate(20px)}
