*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app-container{margin:0 auto;max-width:1400px;padding:20px}.app-header{margin-bottom:8px;padding:10px 0;text-align:center}.app-header h1{color:#333;margin-bottom:5px}.app-header p{color:#666;font-size:14px}.header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:0}.header-title{text-align:left}.btn-back-dashboard{align-items:center;background:#0000;border:1px solid #e0e0e0;border-radius:6px;color:#555;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s ease}.btn-back-dashboard:hover{background:#f5f5f5;border-color:#ccc;color:#333}.btn-back-dashboard:active{background:#eee;transform:scale(.98)}.page-title-section{margin-bottom:20px;text-align:center}.page-title-section h1{color:#333;font-size:24px;margin:0 0 5px}.page-title-section p{color:#666;font-size:14px;margin:0}.header-actions{flex-wrap:wrap}.login-button-container{position:relative}.login-button-container.loading{color:#666}.google-login-btn{align-items:center;background:#fff;border:1px solid #dadce0;border-radius:4px;box-shadow:0 1px 2px #0000001a;color:#3c4043;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 20px;transition:all .2s ease}.google-login-btn:hover{background:#f8f9fa;box-shadow:0 2px 4px #00000026}.google-icon{flex-shrink:0}.user-menu{position:relative}.user-menu-button{align-items:center;background:#fff;border:1px solid #dadce0;border-radius:24px;cursor:pointer;display:flex;gap:8px;padding:6px 12px;transition:all .2s ease}.user-menu-button:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.user-avatar{object-fit:cover}.user-avatar,.user-avatar-placeholder{border-radius:50%;height:32px;width:32px}.user-avatar-placeholder{align-items:center;background:#007bff;color:#fff;display:flex;font-size:14px;font-weight:600;justify-content:center}.user-name{color:#3c4043;font-size:14px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{color:#5f6368}.user-dropdown{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0003;min-width:200px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.user-dropdown-header{background:#f8f9fa;padding:12px 16px}.user-email{color:#5f6368;font-size:13px}.user-dropdown-divider{background:#e8eaed;height:1px}.user-dropdown-item{background:none;border:none;color:#3c4043;cursor:pointer;font-size:14px;padding:12px 16px;text-align:left;transition:background .2s;width:100%}.user-dropdown-item:hover{background:#f1f3f4}.dropdown-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.header-actions{display:flex;gap:10px;justify-content:center;margin-top:15px}.btn-outline{border:2px solid #007bff;border-radius:4px;color:#007bff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.btn-outline:hover{background:#007bff;color:#fff}.tournament-list-dropdown{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:15px;max-height:400px;overflow-y:auto;text-align:left}.tournament-list-empty{color:#666;padding:20px;text-align:center}.tournament-list{list-style:none;margin:0;padding:0}.tournament-list-item{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;gap:10px;padding:12px 16px;transition:background .2s ease}.tournament-list-item-content{flex:1 1;min-width:0}.tournament-delete-btn{background:#0000;border:none;border-radius:4px;color:#999;cursor:pointer;flex-shrink:0;font-size:20px;font-weight:700;line-height:1;padding:4px 8px;transition:all .2s ease}.tournament-delete-btn:hover{background:#dc3545;color:#fff}.tournament-list-item:last-child{border-bottom:none}.tournament-list-item:hover{background:#f5f5f5}.tournament-list-item.active{background:#e7f3ff;border-left:3px solid #007bff}.tournament-list-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.tournament-list-name{color:#333;font-size:14px;font-weight:600}.tournament-list-status{border-radius:10px;font-size:11px;font-weight:600;padding:2px 8px;text-transform:uppercase}.tournament-list-status.Active{background:#d4edda;color:#155724}.tournament-list-status.Completed{background:#cce5ff;color:#004085}.tournament-list-item-meta{color:#888;display:flex;font-size:12px;justify-content:space-between}.settings-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-height:80vh;max-width:500px;overflow-y:auto;text-align:left;width:90%}.settings-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 20px}.settings-header h3{color:#333;font-size:16px;margin:0}.settings-close-btn{background:#0000;border:none;color:#999;cursor:pointer;font-size:24px;line-height:1;padding:0}.settings-close-btn:hover{color:#333}.settings-content{padding:20px}.settings-section{margin-bottom:20px}.settings-section:last-child{margin-bottom:0}.settings-section h4{color:#333;font-size:15px;font-weight:700;letter-spacing:.5px;margin:0;text-transform:uppercase}.settings-section-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:4px;padding:8px 0}.settings-section-header:hover{opacity:.8}.settings-section-header h4{margin:0}.collapse-toggle{align-items:center;background:#e7f3ff;border-radius:4px;color:#007bff;display:flex;font-size:20px;font-weight:700;height:24px;justify-content:center;width:24px}.settings-section-content{margin-top:8px}.settings-placeholder{color:#888;font-size:14px;font-style:italic}.team-edit-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.team-edit-item{align-items:center;display:flex;gap:10px}.team-edit-number{color:#666;font-size:13px;font-weight:600;min-width:24px}.team-edit-input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:8px 10px;transition:border-color .2s ease}.team-edit-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.reopen-game-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.reopen-game-item{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;gap:12px;justify-content:space-between;padding:10px 12px}.reopen-game-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.reopen-game-info strong{color:#333;font-size:13px}.reopen-game-teams{color:#555;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reopen-game-status{font-size:11px;font-weight:500}.reopen-game-status.status-final{color:#28a745}.reopen-game-status.status-inprogress{color:#007bff}.reopen-game-status.status-ready{color:#856404}.reopen-game-status.status-pending{color:#888}.btn-sm{flex-shrink:0;font-size:12px;padding:6px 12px}.game-selector{margin-bottom:16px}.game-selector label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.game-selector select{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 10px;width:100%}.game-edit-form{border-top:1px solid #eee;margin-top:12px;padding-top:12px}.game-edit-row{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.game-edit-row label{color:#333;font-size:13px;font-weight:600}.game-edit-row input,.game-edit-row textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:8px 10px}.game-edit-row textarea{min-height:50px;resize:vertical}.game-edit-scores{margin-bottom:12px}.game-edit-scores>label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.score-inputs{align-items:center;display:flex;gap:12px;justify-content:center}.score-input-pair{align-items:center;display:flex;flex-direction:column;gap:4px}.score-input-pair span{color:#666;font-size:12px;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.score-input-pair input{-moz-appearance:textfield;border:1px solid #ddd;border-radius:4px;font-size:16px;padding:8px;text-align:center;width:60px}.score-input-pair input::-webkit-inner-spin-button,.score-input-pair input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.score-separator{color:#666;font-size:20px;font-weight:600}.game-edit-row.disabled label,.game-edit-scores.disabled>label{color:#999}.game-edit-row.disabled input,.game-edit-row.disabled textarea,.game-edit-scores.disabled input{background-color:#f5f5f5;color:#999;cursor:not-allowed}.game-state-message{border-radius:4px;font-size:13px;line-height:1.4;margin-bottom:12px;padding:10px 12px;text-align:center}.game-state-message.ended{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.game-state-message.pending{background:#fff3cd;border:1px solid #ffeeba;color:#856404}.game-state-message.ready{background:#cce5ff;border:1px solid #b8daff;color:#004085}.game-edit-buttons{display:flex;gap:10px;margin-top:12px}.game-edit-buttons .btn{flex:1 1}.game-ended-indicator{background:#d4edda;border-radius:4px;color:#155724;flex:1 1;font-size:13px;font-weight:600;padding:10px;text-align:center}.form-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:500px;padding:30px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:600;margin-bottom:8px}.form-group input{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:10px;width:100%}.tournament-type-options{display:flex;gap:10px}.tournament-type-option{border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;flex:1 1;flex-direction:column;padding:15px;text-align:center;transition:all .2s ease}.tournament-type-option:hover:not(.disabled){background:#f8f9ff;border-color:#007bff}.tournament-type-option.selected{background:#e7f3ff;border-color:#007bff}.tournament-type-option.disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.tournament-type-option input[type=radio]{display:none}.tournament-type-option .option-label{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.tournament-type-option .option-description{color:#666;font-size:12px}.tournament-type-option.selected .option-label{color:#007bff}.tournament-type-option.disabled .option-description{color:#999;font-style:italic}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.teams-list{border-top:1px solid #ddd;margin-top:20px;padding-top:20px}.teams-list h3{color:#333;font-size:16px;margin-bottom:15px}.team-item{align-items:center;background:#f9f9f9;border-radius:4px;display:flex;justify-content:space-between;margin-bottom:8px;padding:10px}.team-item span{color:#666;font-size:14px}.team-item button{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:5px 10px}.team-item button:hover{background:#c82333}.button-group{display:flex;gap:10px;margin-top:20px}.btn{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px;transition:all .3s ease}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover{background-color:#138496}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}:root{--col-gap:42px;--row-gap:2px;--match-w:160px;--match-h:54px;--line:#a8a8a8;--card:#fff;--border:#d7d7d7;--win:#0a6;--text:#222;--muted:#666;--bg:#f6f7f8}.bracket-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;overflow-y:visible;padding:30px}.bracket{background:#fff;border:1px solid #eee;border-radius:14px;margin:0 auto;max-width:100%;overflow:auto;padding:14px;position:relative}.bracket-4{width:604px;width:calc(var(--match-w)*3 + var(--col-gap)*2 + 40px)}.bracket-5,.bracket-6,.bracket-7,.bracket-8{width:806px;width:calc(var(--match-w)*4 + var(--col-gap)*3 + 40px)}.grid{grid-column-gap:42px;grid-column-gap:var(--col-gap);grid-row-gap:2px;grid-row-gap:var(--row-gap);column-gap:42px;column-gap:var(--col-gap);display:grid;grid-auto-rows:54px;grid-auto-rows:var(--match-h);padding:10px;position:relative;row-gap:2px;row-gap:var(--row-gap);z-index:1}.grid-4{grid-template-columns:repeat(3,160px);grid-template-columns:repeat(3,var(--match-w));min-width:564px;min-width:calc(var(--match-w)*3 + var(--col-gap)*2)}.grid-5,.grid-6,.grid-7,.grid-8{grid-template-columns:repeat(4,160px);grid-template-columns:repeat(4,var(--match-w));min-width:766px;min-width:calc(var(--match-w)*4 + var(--col-gap)*3)}.grid-de4{grid-template-columns:repeat(5,160px);grid-template-columns:repeat(5,var(--match-w));min-width:968px;min-width:calc(var(--match-w)*5 + var(--col-gap)*4)}.round-title{align-self:end;color:#666;color:var(--muted);font-size:12px;font-weight:650;letter-spacing:.02em;padding:0 4px 6px;text-transform:uppercase}.match{align-items:center;background:#fff;background:var(--card);border:1px solid #d7d7d7;border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 0 #0000000a;cursor:pointer;display:flex;flex-direction:row;gap:10px;justify-content:space-between;min-height:46px;padding:6px 12px}.match:hover{box-shadow:0 6px 18px #00000014;transform:translateY(-1px);transition:.12s ease}.team{display:flex;flex-direction:column;gap:2px;min-width:0}.team .name{font-weight:650;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team .name.tbd{color:#bbb;font-weight:500}.team .meta{color:#666;color:var(--muted);font-size:11px}.score{font-feature-settings:"tnum";flex-shrink:0;font-variant-numeric:tabular-nums;font-weight:750;min-width:26px;text-align:right}.winner{border-color:color-mix(in srgb,#0a6 50%,#d7d7d7);border-color:color-mix(in srgb,var(--win) 50%,var(--border));box-shadow:0 0 0 2px color-mix(in srgb,#0a6 20%,#0000);box-shadow:0 0 0 2px color-mix(in srgb,var(--win) 20%,#0000)}#champ.winner,.GameMiddle .match.winner{background:linear-gradient(135deg,gold,#ffec80 50%,gold);border:2px solid #b8960c;box-shadow:0 0 8px #ffd70066}#champ.winner .name,.GameMiddle .match.winner .name{color:#5c4a00;font-weight:700}#champ.winner .meta,.GameMiddle .match.winner .meta{color:#7a6200}.GameClass{display:flex;flex-direction:column}.GameBottom{margin-top:auto}.GameMiddle{justify-content:center}.GameTop{margin-bottom:auto}.game-info{align-items:center;display:flex;flex-direction:row;justify-content:center;min-height:20px;padding:2px 4px;position:relative}.game-info-icon{cursor:pointer;position:absolute;right:4px}.info-icon{align-items:center;background:#e0e0e0;border-radius:50%;color:#666;display:inline-flex;font-family:Georgia,serif;font-size:9px;font-style:italic;font-weight:600;height:14px;justify-content:center;transition:all .15s ease;width:14px}.game-info-icon:hover .info-icon{background:#007bff;color:#fff}.game-info-tooltip{background:#333;border-radius:6px;bottom:calc(100% + 6px);box-shadow:0 2px 8px #0003;color:#fff;font-size:11px;opacity:0;padding:6px 10px;position:absolute;right:0;transition:opacity .15s ease,visibility .15s ease;visibility:hidden;white-space:nowrap;z-index:100}.game-info-tooltip:after{border:5px solid #0000;border-top-color:#333;content:"";position:absolute;right:4px;top:100%}.game-info-icon:focus .game-info-tooltip,.game-info-icon:hover .game-info-tooltip{opacity:1;visibility:visible}.game-info-tooltip .tooltip-row{display:flex;gap:6px;line-height:1.4}.game-info-tooltip .tooltip-label{color:#aaa;font-size:10px;min-width:55px}.game-info-tooltip .tooltip-value{color:#fff;font-size:11px}.game-info-tooltip .tooltip-row:has(.tooltip-value:empty){display:none}.game-status{border-radius:4px;font-size:9px;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.game-status.status-pending{background:#f0f0f0;color:#888}.game-status.status-ready{background:#fff3cd;color:#856404}.game-status.status-in-progress{background:#cce5ff;color:#004085}.game-status.status-final{background:#d4edda;color:#155724}.game-status.status-not-needed{background:#e0e0e0;color:#666}svg.lines{left:0;pointer-events:none;position:absolute;top:0;z-index:0}.bracket-4 #tSF{grid-column:1;grid-row:1}.bracket-4 #tF{grid-column:2;grid-row:1}.bracket-4 #tC{grid-column:3;grid-row:1}.bracket-4 #Game01{grid-row:2/span 3}.bracket-4 #Game01,.bracket-4 #Game02{align-self:center;gap:10px;grid-column:1}.bracket-4 #Game02{grid-row:5/span 3}.bracket-4 #Game03{gap:10px;grid-column:2;grid-row:3/span 4}.bracket-4 #Game04{gap:10px;grid-column:3;grid-row:3/span 4}.bracket-5 #tR1{grid-column:1;grid-row:1}.bracket-5 #tSF{grid-column:2;grid-row:1}.bracket-5 #tF{grid-column:3;grid-row:1}.bracket-5 #tC{grid-column:4;grid-row:1}.bracket-5 #Game01{align-self:center;gap:10px;grid-column:1;grid-row:3/span 3}.bracket-5 #Game02{gap:10px;grid-column:2;grid-row:2/span 3}.bracket-5 #Game03{gap:10px;grid-column:2;grid-row:5/span 3}.bracket-5 #Game04{gap:10px;grid-column:3;grid-row:3/span 4}.bracket-5 #Game05{gap:10px;grid-column:4;grid-row:3/span 4}.bracket-6 #tR1{grid-column:1;grid-row:1}.bracket-6 #tSF{grid-column:2;grid-row:1}.bracket-6 #tF{grid-column:3;grid-row:1}.bracket-6 #tC{grid-column:4;grid-row:1}.bracket-6 #Game01{grid-row:3/span 3}.bracket-6 #Game01,.bracket-6 #Game02{align-self:center;gap:10px;grid-column:1}.bracket-6 #Game02{grid-row:6/span 3}.bracket-6 #Game03{gap:10px;grid-column:2;grid-row:2/span 3}.bracket-6 #Game04{gap:10px;grid-column:2;grid-row:7/span 3}.bracket-6 #Game05{gap:10px;grid-column:3;grid-row:3/span 6}.bracket-6 #Game06{gap:10px;grid-column:4;grid-row:3/span 6}.bracket-7 #tR1{grid-column:1;grid-row:1}.bracket-7 #tSF{grid-column:2;grid-row:1}.bracket-7 #tF{grid-column:3;grid-row:1}.bracket-7 #tC{grid-column:4;grid-row:1}.bracket-7 #Game01{grid-row:3/span 3}.bracket-7 #Game01,.bracket-7 #Game02{align-self:center;gap:10px;grid-column:1}.bracket-7 #Game02{grid-row:6/span 3}.bracket-7 #Game03{align-self:center;gap:10px;grid-column:1;grid-row:9/span 3}.bracket-7 #Game04{gap:10px;grid-column:2;grid-row:2/span 3}.bracket-7 #Game05{gap:10px;grid-column:2;grid-row:7/span 4}.bracket-7 #Game06{gap:10px;grid-column:3;grid-row:3/span 6}.bracket-7 #Game07{gap:10px;grid-column:4;grid-row:3/span 6}.bracket-8 #tQF{grid-column:1;grid-row:1}.bracket-8 #tSF{grid-column:2;grid-row:1}.bracket-8 #tF{grid-column:3;grid-row:1}.bracket-8 #tC{grid-column:4;grid-row:1}.bracket-8 #Game01{grid-row:2/span 3}.bracket-8 #Game01,.bracket-8 #Game02{align-self:center;gap:10px;grid-column:1}.bracket-8 #Game02{grid-row:5/span 3}.bracket-8 #Game03{grid-row:8/span 3}.bracket-8 #Game03,.bracket-8 #Game04{align-self:center;gap:10px;grid-column:1}.bracket-8 #Game04{grid-row:11/span 3}.bracket-8 #Game05{gap:10px;grid-column:2;grid-row:3/span 4}.bracket-8 #Game06{gap:10px;grid-column:2;grid-row:9/span 4}.bracket-8 #Game07{gap:10px;grid-column:3;grid-row:5/span 6}.bracket-8 #Game08{gap:10px;grid-column:4;grid-row:6/span 4}.bracket-de4{width:1008px;width:calc(var(--match-w)*5 + var(--col-gap)*4 + 40px)}.bracket-de4 #tWBR1{grid-column:1;grid-row:1}.bracket-de4 #tWBF{grid-column:2;grid-row:1}.bracket-de4 #tLBF{grid-column:3;grid-row:1}.bracket-de4 #tChamp{grid-column:4;grid-row:1}.bracket-de4 #tWinner{grid-column:5;grid-row:1}.bracket-de4 #Game01{grid-column:1;grid-row:2/span 3}.bracket-de4 #Game02{grid-column:1;grid-row:6/span 3}.bracket-de4 #Game03{grid-column:2;grid-row:3/span 5}.bracket-de4 #Game4{grid-column:1;grid-row:12/span 3}.bracket-de4 #Game5{grid-column:2;grid-row:10/span 4}.bracket-de4 #Game6{grid-column:3;grid-row:5/span 7}.bracket-de4 #Game7{grid-column:4;grid-row:8/span 6}.bracket-de4 #GameChamp{grid-column:5;grid-row:8/span 5}.bracket-de4 .section-label{align-self:end;color:#666;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.02em;padding:0 4px;text-transform:uppercase}.bracket-de4 #lblLB{grid-column:1;grid-row:8}.bracket-de4 #slotA{grid-row:9}.bracket-de4 #slotA,.bracket-de4 #slotB{align-self:center;grid-column:1;justify-self:end}.bracket-de4 #slotB{grid-row:11}.bracket-de4 .drop-indicator{color:#666;color:var(--muted);font-size:11px;padding:2px 6px}.bracket-de4 .not-necessary .match{background:#e9e9e9;cursor:default}.bracket-de4 .not-necessary .match:hover{background:#e9e9e9;transform:none}.bracket-de4 .not-necessary .match .name{color:#888;font-style:italic}.bracket-de4 .not-necessary .match .meta,.bracket-de4 .not-necessary .match .score{color:#aaa}.bracket-de4 .not-necessary .match.advancement-winner{background:linear-gradient(135deg,gold,#ffec80 50%,gold);border:2px solid #b8960c;box-shadow:0 0 8px #ffd70066;cursor:default}.bracket-de4 .not-necessary .match.advancement-winner .name{color:#5c4a00;font-style:normal;font-weight:700}.bracket-de4 .not-necessary .match.advancement-winner .meta{color:#7a6200}.bracket-de4 #GameChamp.not-necessary,.bracket-de4 .not-necessary .match.GameBottom{opacity:.5}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-width:420px;padding:24px;width:90%}.modal-header{border-bottom:1px solid #ddd;color:#333;font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:12px;text-align:center}.scores-row{gap:24px;margin-bottom:16px}.period-row,.scores-row{display:flex;justify-content:center}.period-row{margin-bottom:8px}.period-row .inline-input-group{align-items:center;flex-direction:column;gap:4px}.period-row .inline-input-group label{min-width:auto}.period-row .inline-input-group input{text-align:center;width:120px}.scores-row .score-input-group{flex:0 0 auto;margin-bottom:0;text-align:center}.score-input-group{margin-bottom:12px}.score-input-group label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:4px;text-align:center}.score-input-group input[type=number]{-moz-appearance:textfield;border:1px solid #ddd;border-radius:4px;font-size:16px;padding:8px;text-align:center;width:70px}.score-input-group input[type=number]::-webkit-inner-spin-button,.score-input-group input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.score-input-group input{border:1px solid #ddd;border-radius:4px;font-size:16px;padding:8px;width:100%}.modal-divider{border:none;border-top:1px solid #ddd;margin:16px 0}.inline-input-group{align-items:center;display:flex;gap:10px;margin-bottom:10px}.inline-input-group label{color:#333;flex-shrink:0;font-size:13px;font-weight:600;min-width:65px}.inline-input-group input,.inline-input-group input[type=datetime-local]{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:6px 8px}.inline-input-group input[type=datetime-local]{font-family:inherit}.inline-input-group input.input-error{border-color:#dc3545;box-shadow:0 0 0 2px #dc354526}.inline-input-group .field-error{color:#dc3545;flex-shrink:0;font-size:11px}.inline-input-group textarea{border:1px solid #ddd;border-radius:4px;flex:1 1;font-family:inherit;font-size:14px;min-height:40px;padding:6px 8px;resize:vertical}.modal-buttons{display:flex;gap:10px}.modal-buttons button{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:10px}.modal-buttons .btn-success{background-color:#28a745;color:#fff}.modal-buttons .btn-success:hover{background-color:#218838}.modal-buttons .btn-info{background-color:#17a2b8;color:#fff}.modal-buttons .btn-info:hover{background-color:#138496}.modal-buttons .btn-secondary{background-color:#6c757d;color:#fff}.modal-buttons .btn-secondary:hover{background-color:#5a6268}.game-details-section{margin-bottom:16px}.tournament-info{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.tournament-details h2.tournament-name{align-items:center;color:#333;cursor:pointer;display:inline-flex;font-size:24px;gap:8px;margin-bottom:2px}.tournament-details h2.tournament-name:hover{color:#007bff}.tournament-details h2.tournament-name .edit-icon{font-size:14px;opacity:0;transition:opacity .2s}.tournament-details h2.tournament-name:hover .edit-icon{opacity:.6}.tournament-name-edit{margin-bottom:8px}.tournament-name-input{border:2px solid #007bff;border-radius:4px;font-size:20px;font-weight:600;max-width:100%;padding:6px 12px;width:300px}.tournament-name-input:focus{box-shadow:0 0 0 3px #007bff33;outline:none}.tournament-name-actions{display:flex;gap:8px;margin-top:8px}.btn-save-name{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:4px 12px}.btn-save-name:hover{background:#218838}.btn-cancel-name{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:4px 12px}.btn-cancel-name:hover{background:#5a6268}.tournament-name-error{color:#dc3545;font-size:12px;margin-top:4px}.tournament-details p.tournament-id{color:#888;font-family:monospace;font-size:11px;margin-bottom:2px}.tournament-details p{color:#666;font-size:14px}.copy-url-btn{background:#17a2b8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:10px 15px}.copy-url-btn:hover{background:#138496}.copy-url-btn.copied{background:#28a745}.bracket-action-buttons{align-items:center;display:flex;gap:8px}.settings-btn{align-items:center;background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:10px 15px;transition:all .2s ease}.settings-btn:hover{background:#5a6268}.settings-btn.active{background:#4285f4}.loading{color:#666;padding:40px;text-align:center}.info-message{background-color:#cce5ff;border:1px solid #b8daff;border-radius:4px;color:#004085;font-size:14px;margin-bottom:16px}.error-message,.info-message{padding:12px;text-align:center}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:20px}.success-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724;margin-bottom:20px;padding:12px}.btn-warning{background-color:#ffc107;color:#212529}.btn-warning:hover{background-color:#e0a800}.btn-warning:disabled{background-color:#ffeaa7;cursor:not-allowed}.modal-content.game-ended{border-top:4px solid #28a745}.game-details-section.disabled label,.period-row.disabled label,.score-input-group.disabled label,.scores-row.disabled label{color:#999}.game-details-section.disabled input,.game-details-section.disabled textarea,.period-row.disabled input,.score-input-group.disabled input,.scores-row.disabled input{background-color:#f5f5f5;border-color:#e0e0e0;color:#999;cursor:not-allowed}.game-details-section.disabled,.period-row.disabled,.scores-row.disabled{opacity:.7}@media (max-width:768px){.app-container{padding:10px}.bracket-container{padding:15px}:root{--match-w:130px;--match-h:48px;--col-gap:24px}.team .name{font-size:12px;max-width:80px}.team .meta{font-size:10px}.score{font-size:12px;min-width:20px}.round-title{font-size:10px}.game-info{padding:1px 2px}.info-icon{font-size:8px;height:12px;width:12px}.game-status{font-size:8px;padding:1px 4px}.game-info-tooltip{font-size:10px;padding:4px 8px}.game-info-tooltip .tooltip-label{font-size:9px;min-width:50px}.game-info-tooltip .tooltip-value{font-size:10px}.tournament-info{flex-direction:column;gap:15px;text-align:center}.modal-content{padding:16px;width:95%}.scores-row{gap:10px}.inline-input-group{align-items:flex-start;flex-direction:column;gap:4px}.inline-input-group label{min-width:auto}.inline-input-group input,.inline-input-group textarea{width:100%}}.login-page{align-items:center;display:flex;justify-content:center;min-height:80vh}.login-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001f;max-width:420px;padding:50px 40px;text-align:center;width:100%}.login-card h1{color:#333;font-size:28px;margin-bottom:8px}.login-subtitle{color:#666;font-size:14px;margin-bottom:30px}.login-actions{display:flex;justify-content:center;margin-bottom:20px}.login-note{color:#888;font-size:12px;margin-top:20px}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dashboard-content{min-height:400px}.empty-state{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:60px 20px;text-align:center}.empty-state h3{color:#333;margin-bottom:8px}.empty-state p{color:#666;margin-bottom:20px}.tournament-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.tournament-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:20px;transition:all .2s ease}.tournament-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.tournament-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.tournament-card-header h3{color:#333;flex:1 1;font-size:18px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tournament-status{border-radius:4px;flex-shrink:0;font-size:11px;font-weight:600;margin-left:10px;padding:4px 8px;text-transform:uppercase}.tournament-status.Active{background:#cce5ff;color:#004085}.tournament-status.Completed{background:#d4edda;color:#155724}.tournament-status.Pending{background:#fff3cd;color:#856404}.tournament-card-meta{color:#666;display:flex;font-size:14px;gap:15px;margin-bottom:8px}.tournament-card-date{color:#888;font-size:12px;margin-bottom:16px}.tournament-card-actions{display:flex;gap:10px}.tournament-card-actions .btn{flex:none;font-size:12px;padding:6px 12px}.btn-sm{font-size:12px!important;padding:6px 12px!important}.btn-outline{background:#0000;border:1px solid #ddd;color:#666}.btn-outline:hover{background:#f8f9fa;border-color:#ccc}.btn-outline.active{background:#007bff;border-color:#007bff;color:#fff}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.error-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:60px 20px;text-align:center}.tournament-info:not(:has(.copy-url-btn)){justify-content:center}.tournament-info:not(:has(.copy-url-btn)) .tournament-details{text-align:center}.tournament-name:not(.editable){cursor:default}.tournament-name:not(.editable):hover{color:#333}
/*# sourceMappingURL=main.89c419c3.css.map*/