:root{--bg:#f8fafc;--surface:#ffffff;--surface2:#f1f5f9;--surface3:#e2e8f0;--border:#cbd5e1;--border2:#94a3b8;--accent:#2563eb;--accent2:#1d4ed8;--accent-dim:rgba(37,99,235,.1);--accent-dim2:rgba(37,99,235,.22);--text:#0f172a;--text2:#334155;--text3:#64748b;--red:#dc2626;--red-dim:rgba(220,38,38,.1);--gold:#92400e;--gold-dim:rgba(146,64,14,.12);--blue:#0369a1;--blue-dim:rgba(3,105,161,.1);--purple:#7c3aed;--purple-dim:rgba(124,58,237,.1);--r:6px;--r2:10px;--btn-text:#fff;--shadow:rgba(0,0,0,.07);--spectator-bracket-card-width:220px}[data-theme=dark]{--bg:#0d0f0a;--surface:#141710;--surface2:#1c2016;--surface3:#242a1c;--border:#2e3826;--border2:#3d4f2a;--accent:#a8d44a;--accent2:#c8f060;--accent-dim:rgba(168,212,74,.12);--accent-dim2:rgba(168,212,74,.25);--text:#e8f0d8;--text2:#9aab80;--text3:#5a6b44;--red:#e05555;--red-dim:rgba(224,85,85,.15);--gold:#e8c84a;--gold-dim:rgba(232,200,74,.15);--blue:#4ab8e8;--blue-dim:rgba(74,184,232,.12);--purple:#b48ae8;--purple-dim:rgba(180,138,232,.12);--btn-text:#0d0f0a;--shadow:rgba(0,0,0,.3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,sans-serif;font-size:15px;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--surface);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:100;gap:10px;flex-wrap:wrap}.logo{font-family:Bebas Neue,sans-serif;font-size:26px;letter-spacing:3px;color:var(--accent);line-height:1;flex-shrink:0}.logo span{color:var(--text2)}.header-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.phase-badge{font-family:DM Mono,monospace;font-size:12px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--border2);padding:3px 10px;border-radius:99px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap}nav{display:flex;gap:4px;padding:10px 24px;background:var(--surface);border-bottom:2px solid var(--border);overflow-x:auto}nav button{font-family:DM Sans,sans-serif;font-size:15px;font-weight:500;padding:7px 15px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;background:transparent;color:var(--text2);transition:all .15s;white-space:nowrap}nav button:hover{color:var(--text);background:var(--surface2)}nav button.active{background:var(--accent-dim);border-color:var(--border2);color:var(--accent);font-weight:600}main{padding:24px;max-width:1280px;margin:0 auto}.page{display:none}.page.active{display:block}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}@media(max-width:680px){.grid-2,.grid-3{grid-template-columns:1fr}}.flex-row{display:flex;align-items:center}.flex-end{justify-content:flex-end}.flex-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb18{margin-bottom:18px}.mt8{margin-top:8px}.mt12{margin-top:12px}hr{border:none;border-top:2px solid var(--border);margin:16px 0}.section-title{font-family:Bebas Neue,sans-serif;font-size:32px;letter-spacing:2px;color:var(--text);margin-bottom:4px}.section-sub{font-size:14px;color:var(--text3);margin-bottom:18px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:18px;margin-bottom:14px;box-shadow:0 1px 4px var(--shadow)}.card-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:12px}label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:5px}input,select{width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:9px 12px;font-family:DM Sans,sans-serif;font-size:15px;color:var(--text);outline:none;transition:border-color .15s}input:focus,select:focus{border-color:var(--accent)}select option{background:var(--surface2)}.form-row{margin-bottom:13px}.form-row-inline{display:flex;gap:10px;align-items:flex-end}.form-row-inline>*{flex:1}.btn{font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;padding:9px 18px;border-radius:var(--r);border:none;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px}.btn-primary{background:var(--accent);color:var(--btn-text)}.btn-primary:hover{background:var(--accent2);transform:translateY(-1px)}.btn-outline{background:transparent;border:1.5px solid var(--border2);color:var(--text2)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--red-dim);border:1.5px solid rgba(220,38,38,.3);color:var(--red)}.btn-danger:hover{background:#dc262633}.btn-ghost{background:transparent;border:1px solid transparent;color:var(--text3)}.btn-ghost:hover{color:var(--text2);background:var(--surface2)}.btn-sm{padding:6px 11px;font-size:13px}.btn-full{width:100%;justify-content:center}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.toggle-group{display:flex;gap:3px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r);padding:3px}.toggle-group button{flex:1;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;padding:6px 13px;border-radius:5px;border:none;cursor:pointer;background:transparent;color:var(--text3);transition:all .15s}.toggle-group button.active{background:var(--accent);color:var(--btn-text)}.skill-badge{font-family:DM Mono,monospace;font-size:12px;font-weight:600;padding:2px 7px;border-radius:4px;margin-left:5px}.skill-1,.skill-2{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(3,105,161,.3)}.skill-3{background:var(--accent-dim);color:var(--accent);border:1px solid var(--border2)}.skill-4{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(146,64,14,.3)}.skill-5{background:var(--red-dim);color:var(--red);border:1px solid rgba(220,38,38,.3)}.team-item{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);margin-bottom:7px;transition:border-color .15s}.team-item:hover{border-color:var(--border2)}.team-name{font-size:15px;font-weight:600}.team-meta{font-size:13px;color:var(--text3);margin-top:2px}.group-container{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.group-card{flex:1;min-width:190px;max-width:290px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r2);padding:14px;transition:border-color .15s,background .15s}.group-card.drag-over{border-color:var(--accent);background:var(--accent-dim)}.group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.group-label{font-family:Bebas Neue,sans-serif;font-size:19px;letter-spacing:1px;color:var(--accent)}.group-count{font-family:DM Mono,monospace;font-size:12px;color:var(--text3)}.group-team{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:5px;font-size:14px;font-weight:500;cursor:grab;-webkit-user-select:none;user-select:none;transition:all .15s}.group-team:active{cursor:grabbing}.group-team.dragging{opacity:.35;border-style:dashed;border-color:var(--accent)}.group-team:hover{border-color:var(--border2)}.unassigned-pool{background:var(--surface);border:2px dashed var(--border2);border-radius:var(--r2);padding:14px;margin-top:14px;transition:border-color .15s,background .15s}.unassigned-pool.drag-over{border-color:var(--accent);background:var(--accent-dim)}.match-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r2);padding:14px;margin-bottom:10px;transition:border-color .15s}.match-card.active-match{border-color:var(--accent)}.match-card.completed{opacity:.8}.match-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:7px;flex-wrap:wrap}.match-label{font-family:DM Mono,monospace;font-size:12px;color:var(--text3);letter-spacing:1px;font-weight:600}.match-meta{display:flex;align-items:center;gap:6px}.match-status-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:3px 8px;border-radius:99px}.status-pending{background:var(--surface2);color:var(--text3);border:1.5px solid var(--border)}.status-live{background:#2563eb26;color:var(--accent);border:1.5px solid var(--border2);animation:pulse 2s infinite}.status-done{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(146,64,14,.3)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.court-badge{font-family:DM Mono,monospace;font-size:11px;padding:3px 8px;border-radius:4px;background:var(--purple-dim);color:var(--purple);border:1px solid rgba(124,58,237,.3);font-weight:600}.time-badge{font-family:DM Mono,monospace;font-size:11px;padding:3px 8px;border-radius:4px;background:var(--surface2);color:var(--text2);border:1px solid var(--border);font-weight:600}.teams-row{display:flex;align-items:center;gap:10px}.team-slot{flex:1;padding:10px 12px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r);text-align:center}.team-slot.winner{border-color:var(--accent);background:var(--accent-dim)}.team-slot-name{font-size:14px;font-weight:700}.team-slot-score{font-family:Bebas Neue,sans-serif;font-size:34px;color:var(--accent);line-height:1;margin-top:2px}.team-slot-score.loser-score{color:var(--text3)}.vs-sep{font-family:Bebas Neue,sans-serif;font-size:18px;color:var(--text3);flex-shrink:0}.standings-table{width:100%;border-collapse:collapse;font-size:14px}.standings-table th{text-align:left;padding:8px 10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text2);border-bottom:2px solid var(--border)}.standings-table td{padding:10px;border-bottom:1px solid var(--border)}.standings-table tr:last-child td{border-bottom:none}.standings-table tr:hover td{background:var(--surface2)}.rank-num{font-family:DM Mono,monospace;color:var(--text3);font-weight:600}.rank-1{color:var(--gold)}.rank-2{color:var(--text2)}.rank-3{color:#b45309}.pts-cell{font-family:DM Mono,monospace;font-weight:700;color:var(--accent)}.bracket-wrapper{overflow-x:auto;padding-bottom:12px}.bracket{display:flex;align-items:stretch;min-width:max-content;gap:0}.bracket-round-col{display:flex;flex-direction:column}.bracket-round-title{height:48px;display:flex;align-items:center;justify-content:center;font-family:Bebas Neue,sans-serif;font-size:16px;letter-spacing:1px;color:var(--text2);padding:0 10px;text-align:center;flex-shrink:0}.bracket-round-body{flex:1;display:flex;flex-direction:column;justify-content:space-around;padding:6px 0}.bracket-match{margin:5px 8px}.bracket-match-inner{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);width:210px;overflow:hidden;box-shadow:0 1px 4px var(--shadow);transition:border-color .2s,box-shadow .2s}.bracket-match-inner.winner-decided{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim),0 2px 8px var(--shadow)}.bracket-slot{padding:8px 11px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;transition:background .15s,color .15s}.bracket-slot:last-child{border-bottom:none}.bracket-slot.winner-slot{background:var(--accent-dim);color:var(--accent);border-left:3px solid var(--accent)}.bracket-slot-score{font-family:DM Mono,monospace;font-size:12px;color:var(--text3);font-weight:700}.bracket-slot.winner-slot .bracket-slot-score{color:var(--accent)}.bracket-match-action{padding:5px 8px;text-align:center;background:var(--surface2)}.bracket-connector-col{display:flex;flex-direction:column;width:32px;flex-shrink:0;align-self:stretch}.bracket-connector-header{height:48px;flex-shrink:0}.bracket-connector-body{flex:1;display:flex;flex-direction:column}.bc-group{display:flex;flex-direction:column;flex:1;position:relative}.bc-top-half{flex:1;border-right:2px solid var(--border2);border-bottom:2px solid var(--border2)}.bc-bottom-half{flex:1;border-right:2px solid var(--border2);border-top:2px solid var(--border2)}.bc-group:after{content:"";position:absolute;right:-1px;top:50%;width:16px;height:2px;background:var(--border2);transform:translateY(-50%)}.bracket-3p-sep{width:1px;background:repeating-linear-gradient(to bottom,var(--border2) 0,var(--border2) 6px,transparent 6px,transparent 12px);margin:0 16px;flex-shrink:0}.bracket-group-badge{font-family:DM Mono,monospace;font-size:10px;padding:1px 5px;border-radius:3px;background:var(--surface2);color:var(--text3);border:1px solid var(--border);margin-left:4px;white-space:nowrap;flex-shrink:0;font-weight:600}.bracket-slot.winner-slot .bracket-group-badge{background:var(--accent-dim2);color:var(--accent);border-color:var(--border2)}.schedule-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px}.court-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r2);overflow:hidden}.court-header{padding:10px 14px;background:var(--surface2);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.court-name{font-family:Bebas Neue,sans-serif;font-size:19px;letter-spacing:1px;color:var(--purple)}.court-slot{padding:10px 14px;border-bottom:1px solid var(--border);font-size:14px}.court-slot:last-child{border-bottom:none}.court-slot-time{font-family:DM Mono,monospace;font-size:12px;color:var(--text3);margin-bottom:3px;font-weight:600}.court-slot-match{font-weight:600}.court-slot.empty-slot{color:var(--text3);font-style:italic;font-size:13px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.setting-item:last-child{border-bottom:none}.setting-label{font-size:15px;font-weight:600}.setting-desc{font-size:13px;color:var(--text3);margin-top:2px}.num-control{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}.num-control button{width:34px;height:34px;background:var(--surface2);border:none;color:var(--text);cursor:pointer;font-size:18px;transition:background .15s}.num-control button:hover{background:var(--surface3)}.num-control span{font-family:DM Mono,monospace;font-size:15px;font-weight:700;padding:0 14px;color:var(--accent);min-width:46px;text-align:center}.alert{padding:12px 15px;border-radius:var(--r);margin-bottom:14px;font-size:14px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}.alert-info{background:var(--blue-dim);border:1.5px solid rgba(3,105,161,.25);color:var(--blue)}.alert-success{background:var(--accent-dim);border:1.5px solid var(--border2);color:var(--accent2)}.alert-warn{background:var(--gold-dim);border:1.5px solid rgba(146,64,14,.3);color:var(--gold)}.empty-state{text-align:center;padding:48px 20px;color:var(--text3);font-size:15px}.empty-state .ei{font-size:40px;margin-bottom:10px}.empty-state strong{display:block;font-size:17px;color:var(--text2);margin-bottom:6px;font-weight:700}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c2;z-index:200;align-items:center;justify-content:center;padding:16px}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r2);padding:24px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-title{font-family:Bebas Neue,sans-serif;font-size:24px;letter-spacing:2px;color:var(--text);margin-bottom:16px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}.score-game-block{padding:13px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r);margin-bottom:10px}.score-game-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:10px}.score-inputs{display:flex;gap:10px;align-items:flex-end}.score-inputs>div{flex:1}.score-inputs input{text-align:center;font-family:Bebas Neue,sans-serif;font-size:30px;height:54px}.score-sep{flex:0;padding-bottom:10px;font-size:18px;color:var(--text3);font-weight:700}.game-pip{font-family:DM Mono,monospace;font-size:12px;padding:3px 7px;border-radius:4px;border:1px solid var(--border);background:var(--surface2);color:var(--text3);font-weight:600}.game-pip.win{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.game-pip.loss{border-color:#dc26264d;color:var(--red);background:var(--red-dim)}.history-entry{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px}.history-entry:last-child{border-bottom:none}.history-time{font-family:DM Mono,monospace;font-size:12px;color:var(--text3);white-space:nowrap;padding-top:1px;min-width:72px;font-weight:600}.history-text{flex:1;color:var(--text2)}.history-text strong{color:var(--text)}.spec-banner{background:var(--surface2);border:1.5px solid var(--border2);border-radius:var(--r2);padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:11px}.live-dot{width:9px;height:9px;background:var(--red);border-radius:50%;animation:blink-red 1s infinite;flex-shrink:0}@keyframes blink-red{0%,to{opacity:1;box-shadow:0 0 6px var(--red)}50%{opacity:.2;box-shadow:none}}.sync-indicator{font-family:DM Mono,monospace;font-size:12px;padding:4px 12px;border-radius:99px;border:1.5px solid var(--border);background:var(--surface2);color:var(--text3);white-space:nowrap;transition:all .3s;font-weight:600}.sync-indicator.connected{background:var(--accent-dim);border-color:var(--border2);color:var(--accent)}.sync-indicator.syncing{background:var(--gold-dim);border-color:#92400e4d;color:var(--gold)}.sync-indicator.error{background:var(--red-dim);border-color:#dc26264d;color:var(--red)}.spec-section{margin-bottom:24px}.spec-section-title{font-family:Bebas Neue,sans-serif;font-size:20px;letter-spacing:1px;color:var(--text2);margin-bottom:12px;padding-bottom:6px;border-bottom:2px solid var(--border)}.welcome-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:150;display:flex;align-items:center;justify-content:center;padding:24px}.welcome-card{background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r2);padding:36px;max-width:480px;width:100%;text-align:center}.spectator-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:120;display:none;flex-direction:column;overflow:auto;box-sizing:border-box;width:100%;max-width:100vw}.spectator-overlay.open{display:flex}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:none;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.celebration-overlay.open{display:flex;pointer-events:all}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.spectator-panels{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto;max-width:100%}.spectator-panels>div{word-break:break-word;overflow-wrap:break-word;max-width:100%;box-sizing:border-box}.spectator-standings{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.spectator-standings-group{min-width:0}.spectator-bracket-scroll{overflow-x:auto;overflow-y:visible;max-width:100%}.spectator-bracket-track{display:flex;align-items:stretch;gap:0;flex-wrap:nowrap;min-width:max-content}.spectator-overlay .spectator-bracket-track .bracket-round-col{flex-shrink:0;min-width:auto}.spectator-overlay .spectator-bracket-track .spectator-bracket-match-card{width:var(--spectator-bracket-card-width);max-width:none}.spectator-overlay .spectator-bracket-track .bracket-match-inner{max-width:none;word-break:normal}.spectator-overlay .spectator-bracket-track .bracket-slot{word-break:normal;overflow-wrap:anywhere;white-space:normal}@media(max-width:640px){header{padding:10px 14px;gap:6px}.header-clock{display:none}.header-actions{gap:4px}.header-actions .btn-sm{padding:5px 8px;font-size:12px}.no-mobile{display:none!important}nav{padding:8px 12px;gap:2px}nav button{padding:5px 9px;font-size:13px}main{padding:14px}.section-title{font-size:24px}.grid-2,.grid-3{grid-template-columns:1fr}.setting-item{flex-wrap:wrap;gap:8px}.form-row-inline{flex-direction:column}.group-card{min-width:100%;max-width:100%}.flex-between{flex-wrap:wrap;gap:6px}.team-slot-score{font-size:26px}.modal{padding:16px;margin:8px}.modal-overlay{padding:8px;align-items:flex-end}.modal{border-radius:var(--r2) var(--r2) 0 0;max-height:95vh}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%;justify-content:center}.score-inputs input{font-size:24px;height:46px}.spectator-panels{grid-template-columns:1fr;grid-template-rows:unset}.spectator-panels>div{background:#fff!important;padding:0!important;border:none!important}.spectator-panels>div>div:first-child{border-bottom:none!important;padding-bottom:10px!important;margin-bottom:16px!important}}@media(max-width:640px){.spectator-standings{grid-template-columns:1fr!important}.spectator-standings-group{width:100%!important;min-width:unset!important}}@media(max-width:400px){.logo{font-size:20px;letter-spacing:2px}.phase-badge{display:none}}@media print{body{background:#fff;color:#000}header,nav,.no-print{display:none!important}.page{display:block!important}.card,.match-card,.bracket-match-inner,.group-card{border:1px solid #ccc;background:#fff}.standings-table th,.standings-table td{border-color:#ccc}.section-title,.logo,.group-label,.court-name,.bracket-round-title{color:#000}.match-status-badge,.skill-badge{border:1px solid #999;color:#333;background:#eee}.team-slot-score{color:#333}.btn{display:none!important}.bracket-slot{border-color:#ccc}}
