*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--red:#e4261c;--red-dark:#b91c1c;--red-light:#fee2e2;--purple:#5b2d8e;--purple-dark:#3d1d62;--lime:#c2de00;--lime-dark:#a3bb00;--gold:#d4a843;--gold-light:#fef3c7;--maroon:#7a1e24;--bg:#f4f4f6;--card:#fff;--text:#111;--muted:#6b7280;--border:#e5e7eb;--radius:10px;--shadow:0 2px 10px #00000017}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.navbar{background:var(--red);color:#fff;z-index:100;justify-content:space-between;align-items:center;height:60px;padding:0 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 3px 12px #e4261c66}.navbar-brand a{color:#fff;letter-spacing:.5px;align-items:center;gap:.5rem;font-size:1.15rem;font-weight:800;text-decoration:none;display:flex}.navbar-brand a span.nav-accent{color:var(--lime)}.navbar-links{align-items:center;gap:.25rem;display:flex}.navbar-links a{color:#ffffffe0;border-radius:6px;padding:.35rem .75rem;font-size:.88rem;font-weight:500;text-decoration:none;transition:background .15s}.navbar-links a:hover{color:#fff;background:#ffffff26}.navbar-user{color:#ffffffb3;padding:0 .5rem;font-size:.82rem}.btn-logout{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;padding:.3rem .85rem;font-size:.82rem;font-weight:600;transition:background .15s}.btn-logout:hover{background:#ffffff40}.auth-container{background:radial-gradient(ellipse at 0% 0%, #5b2d8e99 0%, transparent 55%), radial-gradient(ellipse at 100% 100%, #c2de004d 0%, transparent 50%), linear-gradient(150deg, #b91c1c 0%, var(--red) 50%, #7a1e24 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:440px;padding:2.5rem 2rem;box-shadow:0 12px 40px #0003}.auth-logo{text-align:center;margin-bottom:1.5rem}.auth-logo-title{color:var(--red);letter-spacing:-.5px;font-size:2rem;font-weight:900;line-height:1}.auth-logo-title span{color:var(--purple)}.auth-logo-sub{color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:.25rem;font-size:.78rem;font-weight:500}.auth-card h2{text-align:center;color:var(--text);margin-bottom:1.5rem;font-size:1.1rem;font-weight:700}.auth-divider{border:none;border-top:1px solid var(--border);margin:0 0 1.5rem}.auth-link{text-align:center;color:var(--muted);margin-top:1.25rem;font-size:.88rem}.auth-link a{color:var(--red);font-weight:600;text-decoration:none}.auth-link a:hover{color:var(--red-dark)}.form-group{margin-bottom:1rem}.form-group label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.35rem;font-size:.8rem;font-weight:700;display:block}.form-group input,.form-group select{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;padding:.65rem .85rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus{border-color:var(--red);background:#fff;outline:none;box-shadow:0 0 0 3px #e4261c1f}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.btn-primary{background:var(--red);color:#fff;border-radius:var(--radius);cursor:pointer;letter-spacing:.3px;border:none;width:100%;margin-top:.5rem;padding:.75rem;font-size:1rem;font-weight:700;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--red-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-sm{cursor:pointer;border:none;border-radius:6px;padding:.35rem .75rem;font-size:.82rem}.error-msg{color:var(--red);border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:.75rem;padding:.65rem .85rem;font-size:.88rem;font-weight:500}.success-msg{color:#166534;border-radius:var(--radius);background:#f0fdf4;border:1px solid #bbf7d0;margin-bottom:1rem;padding:1rem}.success-msg h2{margin-bottom:.5rem}.main-content{max-width:1100px;margin:0 auto;padding:1.75rem 1rem}.page-title{color:var(--text);align-items:center;gap:.6rem;margin-bottom:1.75rem;font-size:1.5rem;font-weight:800;display:flex}.page-title:before{content:"";background:var(--red);border-radius:3px;width:5px;height:1.4em;display:inline-block}.page-loading{text-align:center;color:var(--muted);padding:3rem}.empty-state{text-align:center;color:var(--muted);border-radius:var(--radius);border:1px dashed var(--border);background:#fff;padding:3rem}.muted{color:var(--muted)}.stage-section{margin-bottom:2.5rem}.stage-title{text-transform:uppercase;letter-spacing:1.5px;color:var(--red);border-bottom:2px solid var(--red);align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;font-size:.75rem;font-weight:800;display:flex}.matches-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1rem;display:grid}.match-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:1rem 1rem .85rem;transition:transform .15s,box-shadow .15s}.match-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.match-card.card-unpredicted{border-top:3px solid #f59e0b}.match-card.card-partial{border-top:3px solid #3b82f6}.match-card.card-predicted{border-top:3px solid #22c55e}.match-card.card-locked{border-top:3px solid var(--muted);opacity:.82}.match-card.finished{border-top:3px solid var(--red)}.match-card.closing-soon{border-top:3px solid #f59e0b;animation:2s ease-in-out infinite pulse-border}@keyframes pulse-border{0%,to{box-shadow:var(--shadow)}50%{box-shadow:0 0 0 3px #f59e0b40}}.match-header{color:var(--muted);justify-content:space-between;margin-bottom:.75rem;font-size:.72rem;font-weight:500;display:flex}.match-number{color:var(--red);font-weight:700}.match-teams{justify-content:center;align-items:center;gap:.5rem;margin-bottom:.85rem;display:flex}.team-name{text-align:center;color:var(--text);flex-direction:column;flex:1;align-items:center;gap:.35rem;font-size:.82rem;font-weight:600;display:flex}.team-flag{border-radius:4px;width:38px;height:auto;box-shadow:0 1px 4px #00000040}.team-flag-sm{vertical-align:middle;border-radius:2px;width:20px;height:auto;margin-right:4px}.vs{color:var(--muted);letter-spacing:1px;padding:0 .25rem;font-size:.75rem;font-weight:700}.btn-match-preds{width:100%;color:var(--purple);cursor:pointer;text-align:center;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:6px;margin-bottom:.6rem;padding:.3rem 0;font-size:.78rem;font-weight:700;transition:background .15s;display:block}.btn-match-preds:hover:not(:disabled){background:#ede9fe}.match-venue{text-align:center;color:var(--muted);margin-bottom:.6rem;font-size:.72rem;font-weight:500}.admin-match-footer{border-top:1px solid var(--border);margin-top:.25rem;padding-top:.5rem}.admin-result-area{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;margin-top:.25rem;padding-top:.5rem;display:flex}.partial-badge{text-align:center;color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:.25rem .5rem;font-size:.75rem;font-weight:700}.finished-checkbox{color:var(--muted);cursor:pointer;justify-content:center;align-items:center;gap:.4rem;padding:.1rem 0;font-size:.78rem;font-weight:600;display:flex}.finished-checkbox input[type=checkbox]{width:15px;height:15px;accent-color:var(--red);cursor:pointer}.partial-banner{color:#1e40af;border-radius:var(--radius);background:#eff6ff;border:1.5px solid #93c5fd;border-left:4px solid #3b82f6;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.88rem}.leaderboard-table-wrap.is-partial{position:relative}.partial-watermark{color:#3b82f61a;pointer-events:none;white-space:nowrap;z-index:1;letter-spacing:6px;font-size:5rem;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-30deg)}.partial-pts-label{color:#3b82f6;font-size:.85em}.real-result{text-align:center;color:var(--muted);background:var(--bg);border-radius:6px;margin-bottom:.6rem;padding:.3rem .5rem;font-size:.88rem}.real-result b{color:var(--text);font-size:1rem}.points-badge{background:var(--lime);color:#333;border-radius:20px;margin-left:.4rem;padding:.1rem .55rem;font-size:.75rem;font-weight:800}.prediction-row{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:.5rem;margin-top:.25rem;padding-top:.5rem;display:flex}.score-input{text-align:center;border:1.5px solid var(--border);background:var(--bg);border-radius:6px;width:52px;padding:.4rem;font-size:1rem;font-weight:700;transition:border-color .15s}.score-input:focus{border-color:var(--red);background:#fff;outline:none}.score-sep{color:var(--muted);font-weight:800}.btn-save{border:1.5px solid var(--red);color:var(--red);cursor:pointer;background:#fff;border-radius:6px;padding:.4rem .85rem;font-size:.8rem;font-weight:700;transition:background .15s,color .15s}.btn-save.has-draft,.btn-save:hover:not(:disabled){background:var(--red);color:#fff}.pred-display{text-align:center;color:var(--muted);font-size:.88rem}.pred-display b{color:var(--text)}.pred-chip{text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:.2rem;width:100%;padding:.45rem 1.25rem;display:flex}.pred-chip-label{text-transform:uppercase;letter-spacing:.8px;font-size:.68rem;font-weight:700}.pred-chip-score{letter-spacing:1px;font-size:1.3rem;font-weight:900}.pred-chip--saved{background:#f0fdf4;border:1.5px solid #86efac}.pred-chip--saved .pred-chip-label{color:#166534}.pred-chip--saved .pred-chip-score{color:#15803d}.pred-chip--missing{border:1.5px dashed var(--border);background:#f9fafb}.pred-chip--missing .pred-chip-label{color:var(--muted)}.pred-chip--missing .pred-chip-score{color:#d1d5db}.locked-label{text-align:center;color:var(--muted);letter-spacing:.5px;margin-top:.5rem;font-size:.72rem}.closing-label{text-align:center;color:#d97706;letter-spacing:.3px;margin-top:.5rem;font-size:.72rem;font-weight:700}.view-tabs{gap:.5rem;margin-bottom:1.75rem;display:flex}.view-tab{border:2px solid var(--border);cursor:pointer;color:var(--muted);background:#fff;border-radius:8px;padding:.5rem 1.25rem;font-size:.88rem;font-weight:600;transition:all .15s}.view-tab.active{border-color:var(--red);color:var(--red);background:var(--red-light)}.view-tab:hover:not(.active){color:var(--text);border-color:#ccc}.group-progress{background:var(--lime);color:#333;border-radius:99px;margin-left:.5rem;padding:.1rem .5rem;font-size:.7rem;font-weight:800}.card-legend{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.legend-item{color:var(--muted);border:1.5px solid var(--border);background:#fff;border-radius:99px;align-items:center;gap:.4rem;padding:.25rem .7rem;font-size:.75rem;font-weight:600;display:flex}.legend-item:before{content:"";border-radius:3px;flex-shrink:0;width:10px;height:10px;display:inline-block}.legend-unpredicted:before{background:#f59e0b}.legend-predicted:before{background:#22c55e}.legend-locked:before{background:var(--muted)}.legend-finished:before{background:var(--red)}.progress-bar-wrap{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;margin-bottom:1.75rem;padding:.9rem 1.1rem}.progress-bar-label{color:var(--text);justify-content:space-between;margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:flex}.progress-bar-pct{color:var(--red);font-weight:800}.progress-bar-track{background:var(--bg);border-radius:99px;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--red) 0%, var(--purple) 100%);border-radius:99px;height:100%;transition:width .4s}.leaderboard-table-wrap{border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.leaderboard-table{border-collapse:collapse;border-radius:var(--radius);background:#fff;width:100%;overflow:hidden}.leaderboard-table th{background:var(--red);color:#fff;text-align:left;text-transform:uppercase;letter-spacing:.8px;padding:.85rem 1rem;font-size:.8rem;font-weight:700}.leaderboard-table td{border-bottom:1px solid var(--border);padding:.8rem 1rem;font-size:.9rem}.leaderboard-table tr:last-child td{border-bottom:none}.leaderboard-table tr.top-1 td{background:#fffbeb}.leaderboard-table tr.top-2 td{background:#f8fafc}.leaderboard-table tr.top-3 td{background:#fff7ed}.position-cell{width:48px;font-size:1.1rem}.points-cell{color:var(--red);font-size:1rem;font-weight:800}.admin-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.tab{border:2px solid var(--border);cursor:pointer;color:var(--muted);background:#fff;border-radius:8px;padding:.5rem 1.25rem;font-size:.88rem;font-weight:600;transition:all .15s}.tab.active{border-color:var(--red);color:var(--red);background:var(--red-light)}.tab:hover:not(.active){color:var(--text);border-color:#ccc}.badge{background:var(--red);color:#fff;border-radius:10px;margin-left:.35rem;padding:.1rem .45rem;font-size:.72rem;font-weight:700}.admin-section h2{color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.85rem;font-size:.95rem;font-weight:700}.admin-table{border-collapse:collapse;border-radius:var(--radius);width:100%;box-shadow:var(--shadow);background:#fff;margin-bottom:1.5rem;overflow:hidden}.admin-table th{background:var(--purple);color:#fff;text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:.65rem 1rem;font-size:.8rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--border);padding:.7rem 1rem;font-size:.88rem}.admin-table tr:last-child td{border-bottom:none}.pending-row td{background:#fffbeb}.btn-activate{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.3rem .85rem;font-size:.82rem;font-weight:700;transition:background .15s}.btn-activate:hover{background:var(--red-dark)}.modal-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:flex-start;padding:2rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-box{background:#fff;border-radius:14px;width:100%;max-width:820px;overflow:hidden;box-shadow:0 20px 60px #00000040}.modal-header{background:var(--purple);justify-content:space-between;align-items:flex-start;padding:1.1rem 1.4rem;display:flex}.modal-title{color:#fff;margin:0;font-size:1.05rem;font-weight:800}.modal-sub{color:#ffffffbf;margin:.2rem 0 0;font-size:.8rem}.modal-close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:1rem;transition:background .15s;display:flex}.modal-close:hover{background:#ffffff59}.modal-stage{padding:0 1.4rem 1rem}.modal-stage-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--red);border-bottom:1px solid var(--border);margin-bottom:.5rem;padding:.75rem 0 .4rem;font-size:.7rem;font-weight:800}.modal-pred-table{border-collapse:collapse;width:100%;font-size:.85rem}.modal-pred-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:.3rem .5rem;font-size:.72rem;font-weight:700}.modal-pred-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.45rem .5rem}.modal-pred-table tr:last-child td{border-bottom:none}.modal-pred-table tr.row-scored td{background:#f0fdf4}.modal-pred-table tr.row-zero td{background:#fff7ed}.cell-num{color:var(--red);white-space:nowrap;font-weight:700}.cell-match{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.cell-team{align-items:center;gap:.25rem;display:flex}.cell-vs{color:var(--muted);font-size:.72rem;font-weight:700}.cell-pred{text-align:center;white-space:nowrap}.cell-real{text-align:center;white-space:nowrap;color:var(--muted)}.cell-pts{text-align:center}.pts-zero{color:var(--muted);background:#f3f4f6;border-radius:20px;padding:.1rem .5rem;font-size:.75rem;font-weight:700}.btn-view-preds{color:var(--purple);cursor:pointer;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:6px;padding:.3rem .75rem;font-size:.82rem;font-weight:600;transition:background .15s}.btn-view-preds:hover:not(:disabled){background:#ede9fe}.btn-reset-pwd{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:.3rem .75rem;font-size:.82rem;font-weight:600;transition:background .15s}.btn-reset-pwd:hover:not(:disabled){background:#dbeafe}.btn-deactivate{color:var(--muted);border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:6px;padding:.3rem .75rem;font-size:.82rem;font-weight:600}.btn-deactivate:hover{border-color:#aaa}.result-inputs{align-items:center;gap:.4rem;display:flex}.btn-send-report{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.35rem .85rem;font-size:.82rem;font-weight:700;transition:background .15s}.btn-send-report:hover:not(:disabled){background:var(--purple-dark)}.btn-sent{background:var(--lime);color:#333;cursor:default;border:none;border-radius:6px;padding:.35rem .85rem;font-size:.82rem;font-weight:700}.admin-msg{background:var(--gold-light);color:#78350f;border-radius:var(--radius);border:1px solid #fcd34d;margin-bottom:1rem;padding:.75rem 1rem;font-weight:600}
