:root{--primary: #0D9488;--primary-light: #14B8A6;--primary-dark: #0F766E;--primary-subtle: rgba(13, 148, 136, .08);--accent: #F59E0B;--accent-light: #FCD34D;--accent-subtle: rgba(245, 158, 11, .1);--success: #10B981;--success-subtle: rgba(16, 185, 129, .08);--danger: #EF4444;--danger-subtle: rgba(239, 68, 68, .08);--warning: #F59E0B;--bg-body: #F8FAFB;--bg-surface: #FFFFFF;--bg-surface-2: #F1F5F9;--bg-surface-3: #E2E8F0;--bg-elevated: #FFFFFF;--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94A3B8;--text-inverse: #FFFFFF;--border: #E2E8F0;--border-light: #F1F5F9;--border-focus: var(--primary);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 25px -3px rgba(0, 0, 0, .08), 0 4px 6px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 50px -12px rgba(0, 0, 0, .15);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration: .2s;--eggshell-white: #fffcee;--tennis-yellow: #d4a017;--sporty-orange: #e8612b;--court-green: #2A8C5B;--electric-blue: #2358B7;--charcoal-black: #141413}[data-theme=dark]{--bg-body: #0B1120;--bg-surface: #131B2E;--bg-surface-2: #1A2540;--bg-surface-3: #243352;--bg-elevated: #1A2540;--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-tertiary: #64748B;--text-inverse: #0F172A;--border: #1E293B;--border-light: #1A2540;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 50px rgba(0, 0, 0, .4)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-body);color:var(--text-primary);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:1440px;margin:0 auto;padding:var(--sp-4) var(--sp-5)}.header{background:var(--bg-surface);padding:var(--sp-5) var(--sp-6);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);text-align:center;border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative}.header h1{font-size:1.35rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--sp-1)}.header p{font-size:.8rem;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.08em}.connection-status{position:fixed;top:var(--sp-3);right:var(--sp-3);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:.7rem;font-weight:600;z-index:1000;letter-spacing:.02em;transition:all var(--duration) var(--ease-out);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.connection-status.online{background:#10b98126;color:var(--success);border:1px solid rgba(16,185,129,.25)}.connection-status.offline{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.25)}.live-courts{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-5)}.court-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-4);text-align:center;transition:all var(--duration) var(--ease-out)}.court-card:hover{box-shadow:var(--shadow-md)}.court-card.live{border-color:var(--accent);background:var(--accent-subtle);box-shadow:0 0 0 1px var(--accent),var(--shadow-sm)}.court-card.empty{opacity:.45}.court-name{font-weight:700;font-size:.85rem;color:var(--text-primary);margin-bottom:var(--sp-1);text-transform:uppercase;letter-spacing:.05em}.court-match{font-size:.7rem;color:var(--text-tertiary);font-weight:500}.court-players{font-size:.8rem;color:var(--text-secondary);margin:var(--sp-2) 0;font-weight:500}.court-score{font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:1.1rem;color:var(--primary);font-weight:700;letter-spacing:.02em}.court-status{font-size:.65rem;margin-top:var(--sp-2);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.court-status.live{color:var(--accent)}.court-status.empty{color:var(--text-tertiary)}.progress{display:flex;justify-content:center;align-items:center;gap:0;margin:var(--sp-5) 0}.step{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-surface);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--text-tertiary);transition:all .3s var(--ease-out);position:relative;z-index:1}.step.active{background:var(--primary);border-color:var(--primary);color:var(--text-inverse);box-shadow:0 0 0 4px var(--primary-subtle),var(--shadow-sm);transform:scale(1.1)}.step.done{background:var(--success);border-color:var(--success);color:var(--text-inverse)}.line{width:48px;height:2px;background:var(--border);transition:background .3s var(--ease-out)}.line.done{background:var(--success)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-6) var(--sp-8);margin-bottom:var(--sp-5);box-shadow:var(--shadow-sm)}.card h2{color:var(--text-primary);margin-bottom:var(--sp-6);font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.hidden{display:none!important}.form-group{margin-bottom:var(--sp-5)}.form-label{display:block;color:var(--text-secondary);font-size:.75rem;font-weight:600;margin-bottom:var(--sp-2);text-transform:uppercase;letter-spacing:.06em}.form-input,.form-select,.form-textarea{width:100%;padding:var(--sp-3) var(--sp-4);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--duration) var(--ease-out);outline:none}.form-input:hover,.form-select:hover{border-color:var(--text-tertiary)}.form-input:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-subtle)}.form-textarea{min-height:140px;font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:.85rem;resize:vertical}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-subtle)}.btn{padding:var(--sp-3) var(--sp-6);border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--duration) var(--ease-out);font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);line-height:1.4}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:var(--text-inverse);box-shadow:var(--shadow-xs)}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--bg-surface-2);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-surface-3);color:var(--text-primary);border-color:var(--text-tertiary)}.btn-orange{background:var(--sporty-orange);color:#fff;box-shadow:var(--shadow-xs)}.btn-orange:hover{background:#d4551f;box-shadow:var(--shadow-sm)}.btn-green{background:var(--success);color:#fff;box-shadow:var(--shadow-xs)}.btn-green:hover{background:#059669;box-shadow:var(--shadow-sm)}.btn-blue{background:var(--electric-blue);color:#fff;box-shadow:var(--shadow-xs)}.btn-blue:hover{background:#1d4da8;box-shadow:var(--shadow-sm)}.btn-red{background:var(--danger);color:#fff;box-shadow:var(--shadow-xs)}.btn-red:hover{background:#dc2626;box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-group{display:flex;gap:var(--sp-3);margin-top:var(--sp-6);flex-wrap:wrap}.upload-box{border:2px dashed var(--border);border-radius:var(--radius-md);padding:var(--sp-10) var(--sp-6);text-align:center;cursor:pointer;background:var(--bg-surface);transition:all var(--duration) var(--ease-out)}.upload-box:hover{border-color:var(--primary);background:var(--primary-subtle)}.upload-box input{display:none}.upload-box p{color:var(--text-secondary);margin-top:var(--sp-2)}.player-list{max-height:400px;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.player-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-light);transition:background var(--duration)}.player-item:last-child{border-bottom:none}.player-item:hover{background:var(--bg-surface-2)}.player-num{width:28px;height:28px;background:var(--bg-surface-2);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text-tertiary);flex-shrink:0}.player-name{flex:1;font-weight:500;font-size:.9rem;color:var(--text-primary)}.player-cb{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.seed-tag{background:var(--primary);color:#fff;padding:2px 8px;border-radius:var(--radius-full);font-size:.65rem;font-weight:700;letter-spacing:.03em}.player-meta{font-size:.75rem;color:var(--text-tertiary);margin-left:var(--sp-1)}.alert{padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-sm);margin-bottom:var(--sp-4);display:flex;align-items:center;gap:var(--sp-3);font-size:.85rem;font-weight:500}.alert-info{background:var(--primary-subtle);border:1px solid rgba(13,148,136,.2);color:var(--primary-dark)}.alert-success{background:var(--success-subtle);border:1px solid rgba(16,185,129,.2);color:#059669}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:var(--sp-5)}.modal-box{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--sp-8);max-width:650px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);border:1px solid var(--border)}.modal-box h3{font-size:1.15rem;font-weight:700;margin-bottom:var(--sp-2);color:var(--text-primary);letter-spacing:-.01em}.modal-box .modal-sub{font-size:.85rem;color:var(--text-tertiary);margin-bottom:var(--sp-5)}.col-map-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--border-light)}.col-map-row:last-child{border-bottom:none}.col-map-label{flex:1;font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-map-sample{flex:1;font-size:.8rem;color:var(--text-tertiary);font-style:italic;overflow:hidden;text-overflow:ellipsis}.col-map-select{width:180px;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.8rem;background:var(--bg-surface);color:var(--text-primary);font-family:inherit;transition:border-color var(--duration)}.col-map-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px var(--primary-subtle)}.col-preview{margin-top:var(--sp-4);overflow-x:auto}.col-preview table{width:100%;border-collapse:collapse;font-size:.8rem}.col-preview th{background:var(--bg-surface-2);padding:var(--sp-2) var(--sp-3);text-align:left;font-weight:600;border:1px solid var(--border);color:var(--text-secondary)}.col-preview td{padding:var(--sp-2) var(--sp-3);border:1px solid var(--border-light);color:var(--text-secondary)}.col-preview .mapped{background:var(--primary-subtle)}.bracket-wrapper{overflow-x:auto;padding:var(--sp-5) 0;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.bracket-wrapper::-webkit-scrollbar{height:6px}.bracket-wrapper::-webkit-scrollbar-track{background:transparent}.bracket-wrapper::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.bracket{display:flex;gap:0;min-width:max-content;position:relative}.round{display:flex;flex-direction:column;min-width:280px;position:relative}.round+.round{margin-left:60px}.bracket-connectors{position:absolute;top:0;left:0;pointer-events:none;z-index:1}.round-header{background:var(--primary);color:var(--text-inverse);text-align:center;padding:var(--sp-2) var(--sp-3);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.round-matches{display:flex;flex-direction:column;justify-content:space-around;flex:1;padding:var(--sp-2) 0}.match{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin:5px 0;overflow:hidden;cursor:pointer;transition:all var(--duration) var(--ease-out);box-shadow:var(--shadow-xs)}.match:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.match.completed{border-left:3px solid var(--success)}.match.live{border-left:3px solid var(--accent);box-shadow:0 0 0 1px #f59e0b26,var(--shadow-sm);animation:live-pulse 2.5s ease-in-out infinite}.match.pending{border-color:var(--border-light);opacity:.5;cursor:not-allowed;box-shadow:none}.match.pending:hover{transform:none;box-shadow:none;border-color:var(--border-light)}@keyframes live-pulse{0%,to{box-shadow:0 0 0 1px #f59e0b26,var(--shadow-sm)}50%{box-shadow:0 0 0 3px #f59e0b1f,var(--shadow-md)}}.match-head{background:var(--bg-surface-2);padding:3px var(--sp-2);display:flex;justify-content:space-between;align-items:center;font-size:.62rem;color:var(--text-tertiary);border-bottom:1px solid var(--border-light)}.match-num{color:var(--text-tertiary);font-weight:700;font-size:.62rem;letter-spacing:.03em}.match-status{font-size:.62rem;font-weight:600}.match-status.done{color:var(--success)}.match-status.live{color:var(--accent);font-weight:700}.match-court{background:var(--accent);color:#fff;padding:1px 6px;border-radius:var(--radius-full);font-size:.58rem;font-weight:700;letter-spacing:.03em}.match-player{display:flex;align-items:center;padding:0;gap:0;border-bottom:1px solid var(--border-light);min-height:32px;transition:background var(--duration)}.match-player:last-child{border-bottom:none}.match-player.winner{background:var(--success-subtle)}.match-player.winner .mp-name{font-weight:700;color:var(--text-primary)}.match-player.loser{background:var(--bg-surface)}.match-player.loser .mp-name{color:var(--text-tertiary)}.match-player.tbd{color:var(--text-tertiary);background:var(--bg-surface-2)}.mp-serial{font-size:.68rem;font-weight:600;color:var(--text-tertiary);min-width:18px;text-align:right;padding-right:4px;flex-shrink:0}.mp-seed{background:none;color:var(--primary);min-width:auto;height:auto;border-radius:0;font-size:.72rem;font-weight:800;margin-right:2px}.mp-name{flex:1;font-size:.8rem;font-weight:500;padding:6px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.mp-winner-mark{color:var(--success);font-size:.85rem;font-weight:700;padding:0 6px;display:flex;align-items:center}.mp-scores{display:flex;align-items:center;gap:0;margin-left:auto;border-left:1px solid var(--border-light)}.mp-set{min-width:26px;text-align:center;font-size:.8rem;font-weight:700;padding:6px 4px;color:var(--text-primary);border-right:1px solid var(--border-light);position:relative;font-family:SF Mono,Cascadia Code,monospace}.mp-set:last-child{border-right:none}.mp-set sup{font-size:.5rem;color:var(--text-tertiary);position:absolute;top:2px;right:1px}.mp-set.set-won{color:var(--text-primary)}.mp-set.set-lost{color:var(--text-tertiary)}.match-result-row{padding:2px 6px 4px;text-align:right}.match-result-btn{font-size:.62rem;padding:2px 8px;background:var(--bg-surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-weight:600;font-family:inherit;transition:all var(--duration)}.match-result-btn:hover{background:var(--primary-subtle);color:var(--primary);border-color:var(--primary)}.modal-bg{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--sp-5)}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--sp-6) var(--sp-8);width:100%;max-width:440px;box-shadow:var(--shadow-xl);animation:modal-enter .25s var(--ease-out)}@keyframes modal-enter{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal h3{color:var(--text-primary);margin-bottom:var(--sp-5);text-align:center;font-size:1.1rem;font-weight:700;letter-spacing:-.01em}.modal-player{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--sp-3);cursor:pointer;transition:all var(--duration) var(--ease-out)}.modal-player:hover{border-color:var(--text-tertiary);background:var(--bg-surface-2)}.modal-player.selected{border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 3px #0d94881a}.modal-player .name{flex:1;font-weight:600;color:var(--text-primary)}.modal-player .check{color:var(--primary);font-size:1.1rem;display:none}.modal-player.selected .check{display:block}.score-section{margin:var(--sp-5) 0}.score-section label{display:block;color:var(--text-tertiary);margin-bottom:var(--sp-3);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.score-row{display:flex;gap:var(--sp-4);align-items:center;margin-bottom:var(--sp-3);flex-wrap:wrap}.score-set{display:flex;align-items:center;gap:var(--sp-1)}.score-input{width:48px;height:48px;background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);text-align:center;font-size:1.2rem;font-weight:700;font-family:SF Mono,Cascadia Code,monospace;transition:all var(--duration);outline:none}.score-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-subtle)}.score-dash{color:var(--text-tertiary);font-weight:700;font-size:1.1rem}.set-label{color:var(--text-tertiary);font-size:.68rem;width:95px;text-align:center;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.modal-btns{display:flex;gap:var(--sp-3);margin-top:var(--sp-5)}.modal-btns .btn{flex:1}.result-quick-actions{margin-bottom:var(--sp-4);padding:var(--sp-3);background:var(--bg-surface-2);border-radius:var(--radius-md);border:1px solid var(--border-light)}.result-quick-label{font-size:.72rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--sp-2)}.result-quick-row{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-2)}.result-quick-row:last-child{margin-bottom:0}.btn-walkover{flex:1;padding:var(--sp-2) var(--sp-2);background:#fff3e0;color:#e65100;border:1px solid #ffcc80;border-radius:var(--radius-sm);font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--duration)}.btn-walkover:hover{background:#ffe0b2;border-color:#e65100}.btn-bye-action{flex:1;padding:var(--sp-2) var(--sp-2);background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;border-radius:var(--radius-sm);font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--duration)}.btn-bye-action:hover{background:#c8e6c9;border-color:#2e7d32}.court-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--sp-3);margin:var(--sp-4) 0}.court-option{padding:var(--sp-4) var(--sp-3);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:all var(--duration) var(--ease-out)}.court-option:hover:not(.busy){border-color:var(--primary);background:var(--primary-subtle)}.court-option.selected{border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 3px #0d94881a}.court-option.busy{opacity:.35;cursor:not-allowed;border-color:var(--danger)}.court-option .court-num{font-size:1.5rem;font-weight:800;color:var(--primary);font-family:SF Mono,Cascadia Code,monospace}.court-option.busy .court-num{color:var(--danger)}.court-option .court-label{font-size:.65rem;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:var(--sp-1)}.court-option.busy .court-label{color:var(--danger)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-5)}.info-box{background:var(--bg-surface-2);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.info-box label{display:block;color:var(--text-tertiary);font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:2px}.info-box span{font-weight:600;font-size:.9rem;color:var(--text-primary)}.format-option{padding:var(--sp-4);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration) var(--ease-out)}.format-option:hover{border-color:var(--text-tertiary);background:var(--bg-surface-2)}.format-option.selected{border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 3px #0d948814}.format-option .fo-title{font-weight:700;font-size:.88rem;margin-bottom:2px;color:var(--text-primary)}.format-option .fo-desc{font-size:.72rem;color:var(--text-tertiary);line-height:1.3}.format-option.selected .fo-title{color:var(--primary-dark)}.format-option.small{padding:var(--sp-3);flex:1;min-width:140px}.login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:2000}.login-modal{background:var(--bg-elevated);padding:var(--sp-8) var(--sp-8) var(--sp-6);border-radius:var(--radius-xl);border:1px solid var(--border);text-align:center;max-width:380px;width:90%;box-shadow:var(--shadow-xl);animation:modal-enter .3s var(--ease-out)}.login-modal h2{margin:0 0 var(--sp-2) 0;color:var(--text-primary);font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.login-modal p{margin:0 0 var(--sp-5) 0;color:var(--text-tertiary);font-size:.85rem}.login-input{width:100%;padding:var(--sp-3) var(--sp-4);font-size:.95rem;background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);margin-bottom:var(--sp-3);font-family:inherit;transition:all var(--duration);outline:none}.login-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-subtle)}.login-btn{width:100%;padding:var(--sp-3) var(--sp-4);font-size:.95rem;font-weight:600;border:none;border-radius:var(--radius-sm);background:var(--primary);color:#fff;cursor:pointer;transition:all var(--duration) var(--ease-out);font-family:inherit}.login-btn:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm)}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{color:var(--danger);font-size:.85rem;margin-top:var(--sp-3);font-weight:500}.user-badge{display:inline-flex;align-items:center;gap:var(--sp-2);background:var(--bg-surface-2);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:.78rem;margin-left:var(--sp-3);border:1px solid var(--border)}.user-badge .email{color:var(--text-primary);font-weight:600}.logout-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:.72rem;padding:2px 6px;font-weight:500;transition:color var(--duration)}.logout-btn:hover{color:var(--danger)}.save-indicator{position:fixed;bottom:var(--sp-4);right:var(--sp-4);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:.72rem;font-weight:600;z-index:900;transition:all .3s var(--ease-out);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.save-indicator.saving{background:#f59e0b26;color:var(--accent);border:1px solid rgba(245,158,11,.25)}.save-indicator.saved{background:#10b98126;color:var(--success);border:1px solid rgba(16,185,129,.25)}.save-indicator.error{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.25)}.category-tabs{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-4);overflow-x:auto;padding:var(--sp-1) 0;scrollbar-width:none}.category-tabs::-webkit-scrollbar{display:none}.cat-tab{padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-full);font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;background:var(--bg-surface);border:1.5px solid var(--border);color:var(--text-secondary);transition:all var(--duration) var(--ease-out);position:relative}.cat-tab:not(.add-tab){padding-right:28px}.cat-tab:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.cat-tab.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.cat-tab.add-tab{border-style:dashed;color:var(--text-tertiary)}.cat-tab.add-tab:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-subtle)}.cat-tab-del{position:absolute;right:7px;top:50%;transform:translateY(-50%);font-size:1rem;line-height:1;opacity:0;transition:opacity .15s;cursor:pointer}.cat-tab:hover .cat-tab-del{opacity:.5}.cat-tab.active .cat-tab-del{opacity:.7}.cat-tab-del:hover{opacity:1!important}.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-4)}.stat-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-3);text-align:center;transition:all var(--duration)}.stat-box:hover{box-shadow:var(--shadow-sm)}.stat-box .stat-num{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;font-family:SF Mono,Cascadia Code,monospace}.stat-box .stat-label{font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-top:var(--sp-1)}.stat-box.completed .stat-num{color:var(--success)}.stat-box.live .stat-num{color:var(--accent)}.stat-box.ready .stat-num{color:var(--primary)}.stat-box.total .stat-num{color:var(--text-primary)}.progress-track{height:4px;background:var(--bg-surface-3);border-radius:var(--radius-full);margin-bottom:var(--sp-5);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--success));border-radius:var(--radius-full);transition:width .6s var(--ease-out)}.dash-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--sp-4);overflow:hidden}.dash-panel-header{padding:var(--sp-3) var(--sp-4);background:var(--bg-surface-2);font-weight:700;font-size:.82rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);color:var(--text-primary)}.dash-panel-body{padding:0;max-height:300px;overflow-y:auto}.queue-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-light);transition:background var(--duration)}.queue-item:last-child{border-bottom:none}.queue-item:hover{background:var(--bg-surface-2)}.queue-item .qi-match{font-size:.72rem;color:var(--primary);font-weight:700;letter-spacing:.02em}.queue-item .qi-players{font-size:.85rem;color:var(--text-primary);font-weight:500}.queue-item .qi-btn{padding:var(--sp-1) var(--sp-3);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--duration);white-space:nowrap}.queue-item .qi-btn:hover{background:var(--primary-dark)}.delay-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:12px;white-space:nowrap;margin-left:8px}.delay-green{background:#dcfce7;color:#166534}.delay-yellow{background:#fef9c3;color:#854d0e}.delay-red{background:#fee2e2;color:#991b1b}.oop-panel .dash-panel-body{max-height:420px}.oop-header-actions{display:flex;align-items:center;gap:var(--sp-2)}.oop-count{font-size:.72rem;font-weight:400;color:var(--text-tertiary)}.oop-pdf-btn{padding:var(--sp-1) var(--sp-2);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.68rem;font-weight:600;cursor:pointer}.oop-pdf-btn:hover{background:var(--primary-dark)}.oop-tabs{display:flex;border-bottom:1px solid var(--border)}.oop-tab{flex:1;padding:var(--sp-2) var(--sp-3);background:none;border:none;border-bottom:2px solid transparent;font-size:.78rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;transition:all var(--duration)}.oop-tab:hover{color:var(--text-primary);background:var(--bg-surface-2)}.oop-tab--active{color:var(--primary);border-bottom-color:var(--primary)}.oop-filter-row{display:flex;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border-light);background:var(--bg-surface)}.oop-filter-btn{padding:2px var(--sp-2);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.68rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all var(--duration)}.oop-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.oop-filter-btn--active{background:var(--primary);color:#fff;border-color:var(--primary)}.oop-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border-light);transition:background var(--duration);font-size:.8rem;min-height:36px}.oop-item:last-child{border-bottom:none}.oop-item:hover{background:var(--bg-surface-2)}.oop-item--dragging{opacity:.4}.oop-item--drag-over{border-top:2px solid var(--primary)}.oop-handle{cursor:grab;color:var(--text-tertiary);font-size:.9rem;-webkit-user-select:none;user-select:none;flex-shrink:0;width:16px}.oop-handle:active{cursor:grabbing}.oop-pos{font-size:.68rem;color:var(--text-tertiary);font-weight:600;min-width:20px;text-align:center;flex-shrink:0}.oop-match{font-size:.72rem;color:var(--primary);font-weight:700;min-width:32px;flex-shrink:0}.oop-category-badge{padding:1px 6px;background:var(--bg-surface-3);border-radius:var(--radius-sm);font-size:.62rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.oop-round{font-size:.7rem;color:var(--text-tertiary);min-width:40px;flex-shrink:0}.oop-players{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-weight:500}.oop-time,.oop-court{flex-shrink:0;min-width:48px;text-align:center}.oop-time-display,.oop-court-display{cursor:pointer;color:var(--text-tertiary);font-size:.74rem;padding:2px 4px;border-radius:var(--radius-sm);transition:background var(--duration)}.oop-time-display:hover,.oop-court-display:hover{background:var(--bg-surface-3);color:var(--text-primary)}.oop-time-input,.oop-court-select{width:70px;padding:2px 4px;border:1px solid var(--primary);border-radius:var(--radius-sm);font-size:.72rem;outline:none;background:var(--bg-surface);color:var(--text-primary)}.oop-status{font-size:.66rem;font-weight:700;padding:1px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.oop-status--done{background:#dcf5e6;color:#1a7a3a}.oop-status--live{background:#fff0e6;color:#d4621a}.oop-status--ready{background:#e6f0ff;color:#1a5cb5}.oop-status--tbd{background:var(--bg-surface-2);color:var(--text-tertiary)}.oop-assign-btn{padding:2px var(--sp-2);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.66rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}.oop-assign-btn:hover{background:var(--primary-dark)}.history-table{width:100%;font-size:.8rem}.history-table th{padding:var(--sp-2) var(--sp-3);text-align:left;color:var(--text-tertiary);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600;border-bottom:1px solid var(--border)}.history-table td{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border-light);color:var(--text-secondary)}.history-table tr:hover td{background:var(--bg-surface-2)}.history-table .winner-name{color:var(--success);font-weight:600}.empty-panel{padding:var(--sp-6);text-align:center;color:var(--text-tertiary);font-size:.85rem}.notif-toast{position:fixed;bottom:var(--sp-5);left:50%;transform:translate(-50%) translateY(120px);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-4) var(--sp-5);z-index:1100;display:flex;align-items:center;gap:var(--sp-4);box-shadow:var(--shadow-xl);transition:transform .4s cubic-bezier(.175,.885,.32,1.275);max-width:500px;width:90%}.notif-toast.show{transform:translate(-50%) translateY(0)}.notif-toast .notif-text{flex:1}.notif-toast .notif-title{font-weight:700;color:var(--success);font-size:.88rem}.notif-toast .notif-sub{font-size:.78rem;color:var(--text-tertiary);margin-top:2px}.notif-toast .notif-actions{display:flex;gap:var(--sp-2)}.notif-toast .notif-btn{padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--duration)}.notif-btn.assign{background:var(--primary);color:#fff}.notif-btn.assign:hover{background:var(--primary-dark)}.notif-btn.dismiss{background:var(--bg-surface-2);color:var(--text-tertiary)}.notif-btn.dismiss:hover{background:var(--bg-surface-3)}.scoreboard-ctrl{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--sp-4);overflow:hidden}.scoreboard-ctrl .dash-panel-header{cursor:pointer;-webkit-user-select:none;user-select:none}.scoreboard-ctrl .dash-panel-header:hover{background:var(--bg-surface-3)}.ctrl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);padding:var(--sp-4)}.ctrl-court{background:var(--bg-surface-2);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:var(--sp-3);text-align:center}.ctrl-court .ctrl-name{font-weight:700;font-size:.82rem;margin-bottom:var(--sp-2);color:var(--text-primary)}.toggle-wrap{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);font-size:.72rem;color:var(--text-tertiary);font-weight:500}.toggle{width:36px;height:20px;background:var(--bg-surface-3);border-radius:var(--radius-full);position:relative;cursor:pointer;transition:background .25s var(--ease-out)}.toggle.on{background:var(--success)}.toggle:after{content:"";width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .25s var(--ease-out);box-shadow:0 1px 3px #00000026}.toggle.on:after{left:18px}.msg-input-wrap{padding:0 var(--sp-4) var(--sp-4)}.msg-input-row{display:flex;gap:var(--sp-2)}.msg-input-row input{flex:1;padding:var(--sp-2) var(--sp-3);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-family:inherit;transition:border-color var(--duration);outline:none}.msg-input-row input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-subtle)}.share-row{padding:0 var(--sp-4) var(--sp-4);display:flex;gap:var(--sp-2);align-items:center;flex-wrap:wrap}.dashboard-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-3);margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px solid var(--border-light)}.dashboard-actions{display:flex;gap:var(--sp-2);flex-wrap:wrap}.dashboard-actions .btn{padding:var(--sp-2) var(--sp-4);font-size:.82rem}.bracket-hint{color:var(--text-tertiary);margin-bottom:var(--sp-4);font-size:.82rem;font-weight:500}.end-tournament-section{margin-top:var(--sp-10);padding-top:var(--sp-5);border-top:1px solid var(--border);text-align:center}.end-tournament-hint{color:var(--text-tertiary);font-size:.85rem;margin-bottom:var(--sp-3)}@media (max-width: 768px){.container{padding:var(--sp-3)}.card{padding:var(--sp-4) var(--sp-5)}.btn-group{flex-direction:column}.btn{width:100%}.round{min-width:220px}.live-courts,.court-select-grid,.ctrl-grid{grid-template-columns:repeat(2,1fr)}#formatOptions{grid-template-columns:1fr!important}#deuceOptions,#finalSetOptions,#tbOptions{flex-direction:column}.modal,.modal-box,.login-modal{padding:var(--sp-5)}}@media (max-width: 480px){.round{min-width:200px}.stats-bar,.info-grid{grid-template-columns:repeat(2,1fr)}}
