:root{--bg: #0d1117;--surface: #161b22;--surface-2: #1f2937;--border: #30363d;--text: #e5e7eb;--muted: #9ca3af;--accent: #3b82f6;--accent-hover: #2563eb;--danger: #dc2626;--success: #16a34a;--warning: #f59e0b}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,sans-serif;min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border)}.brand{font-size:22px;font-weight:700;color:var(--text);letter-spacing:.5px}#app{max-width:1100px;margin:0 auto;padding:32px 24px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:none;border-radius:6px;background:var(--accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .12s}.btn:hover{background:var(--accent-hover)}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#b91c1c}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2)}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px;margin-bottom:16px}.user-pill{display:flex;align-items:center;gap:10px;padding:6px 12px;background:var(--surface-2);border-radius:999px}.user-pill img{width:28px;height:28px;border-radius:50%}.user-pill .admin-badge{font-size:11px;padding:2px 8px;background:var(--danger);border-radius:4px;font-weight:700;text-transform:uppercase}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-state h2{font-size:20px;color:var(--text);margin-bottom:8px}.error-banner{background:#2d1416;border:1px solid var(--danger);color:#fecaca;padding:12px 16px;border-radius:6px;margin-bottom:16px}.discord-login{text-align:center;padding:80px 20px}.discord-login h2{font-size:28px;margin-bottom:12px}.discord-login p{color:var(--muted);margin-bottom:32px}.btn-discord{background:#5865f2;font-size:16px;padding:14px 28px}.btn-discord:hover{background:#4752c4}.round-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.round-mode{display:inline-block;padding:4px 12px;background:var(--accent);color:#fff;border-radius:4px;font-weight:700;font-size:14px;letter-spacing:1px}.round-meta{color:var(--muted);font-size:13px;margin-top:6px}.round-status{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.round-status.status-lobby{background:#3b82f626;color:var(--accent);border:1px solid var(--accent)}.round-status.status-active{background:#16a34a26;color:var(--success);border:1px solid var(--success)}.round-status.status-finished{background:var(--surface-2);color:var(--muted)}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mode-btn{background:var(--surface-2);border:2px solid var(--border);border-radius:8px;padding:24px 16px;cursor:pointer;color:var(--text);text-align:center;transition:all .12s}.mode-btn:hover:not(:disabled){border-color:var(--accent);background:#3b82f614}.mode-btn:disabled{opacity:.5;cursor:wait}.mode-label{font-size:32px;font-weight:800;letter-spacing:2px;color:var(--accent)}.mode-desc{color:var(--muted);font-size:13px;margin-top:6px}.signup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}.signup-pill{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px}.signup-pill img{width:32px;height:32px;border-radius:50%}.signup-pill.is-me{border-color:var(--accent);background:#3b82f614}.signup-pill.is-npc{border-style:dashed;opacity:.85}.signup-pill.is-npc img{filter:grayscale(.6)}.me-badge{margin-left:auto;font-size:11px;padding:2px 8px;background:var(--accent);color:#fff;border-radius:4px;text-transform:uppercase;font-weight:700}.npc-badge{margin-left:auto;font-size:11px;padding:2px 8px;background:var(--surface);color:var(--muted);border:1px solid var(--border);border-radius:4px;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.signup-pill-kick{margin-left:4px;width:22px;height:22px;padding:0;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:50%;cursor:pointer;font-size:11px;line-height:20px;text-align:center}.signup-pill-kick:hover{color:var(--danger);border-color:var(--danger);background:#dc262614}.proposal-row{display:flex;gap:12px;padding:6px 0;align-items:center}.proposal-row strong{min-width:140px}.badge-mode{display:inline-block;padding:2px 10px;background:var(--accent);color:#fff;border-radius:4px;font-weight:700}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:480px;width:calc(100% - 32px);max-height:90vh;overflow-y:auto}.proposal-summary{background:var(--surface-2);border-radius:6px;padding:12px 16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.active-banner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px;background:#16a34a14;border:1px solid var(--success);border-radius:8px;margin-bottom:16px}.draw-stage{min-height:70vh;display:flex;flex-direction:column;align-items:center;padding:40px 20px;position:relative}.draw-stage-status{font-size:28px;font-weight:700;text-align:center;margin-bottom:32px;min-height:40px;letter-spacing:.5px;text-shadow:0 2px 12px rgba(59,130,246,.3)}.draw-teams{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%;max-width:900px}@media(max-width:700px){.draw-teams{grid-template-columns:1fr}}.draw-team{background:var(--surface);border-radius:12px;padding:20px;border:2px solid var(--border)}.draw-team-a{border-color:var(--accent)}.draw-team-b{border-color:var(--danger)}.draw-team h3{font-size:22px;margin-bottom:16px;text-align:center;letter-spacing:1px}.draw-team-list{display:flex;flex-direction:column;gap:10px;min-height:100px}.draw-reveal{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px 16px;opacity:0;transform:translateY(20px) scale(.9);transition:all .28s cubic-bezier(.4,0,.2,1)}.draw-reveal-active{opacity:1;transform:translateY(0) scale(1);box-shadow:0 0 24px #3b82f666;animation:revealPulse .6s ease-out}.draw-team-b .draw-reveal-active{box-shadow:0 0 24px #dc262666}@keyframes revealPulse{0%{transform:translateY(0) scale(1)}20%{transform:translateY(0) scale(1.06)}to{transform:translateY(0) scale(1)}}.draw-reveal-pos{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.draw-reveal-player{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600}.draw-reveal-player img{width:32px;height:32px;border-radius:50%}.draw-skip-hint{margin-top:32px;color:var(--muted);font-size:13px;font-style:italic}.match-teams{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}@media(max-width:700px){.match-teams{grid-template-columns:1fr}}.match-team-a{border-top:3px solid var(--accent)}.match-team-b{border-top:3px solid var(--danger)}.match-team-header{font-size:22px;letter-spacing:1px;margin-bottom:16px;text-align:center}.match-team-roster{display:flex;flex-direction:column;gap:8px}.lineup-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px}.lineup-row.is-me{border-color:var(--accent);background:#3b82f614}.lineup-pos{font-size:13px;color:var(--muted);font-weight:600}.lineup-player{display:flex;align-items:center;gap:10px}.lineup-player img{width:28px;height:28px;border-radius:50%}.match-score-display{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;margin-top:24px;padding:24px;background:var(--surface-2);border-radius:12px}.match-score-team{text-align:center}.match-score-team-label{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.match-score-team-value{font-size:56px;font-weight:800;line-height:1}.match-score-team.is-winner .match-score-team-value{color:var(--success)}.match-score-team.is-loser .match-score-team-value{color:var(--muted)}.match-score-team.is-draw .match-score-team-value{color:var(--warning)}.match-score-divider{font-size:32px;font-weight:700;color:var(--muted)}.winner-badge{display:inline-block;margin-left:8px;padding:2px 10px;background:var(--success);color:#fff;border-radius:4px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.draw-badge{display:inline-block;margin-left:8px;padding:2px 10px;background:var(--warning);color:#2a1a00;border-radius:4px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.score-inputs{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:end}.score-input-group{text-align:center}.score-input-group label{display:block;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.score-input-group input{width:100%;font-size:40px;font-weight:700;text-align:center;padding:12px;background:var(--surface-2);border:2px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit}.score-input-group input:focus{outline:none;border-color:var(--accent);background:#3b82f60d}.score-divider{font-size:32px;font-weight:700;color:var(--muted);padding-bottom:16px}.next-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.next-action-grid .btn{justify-content:center}.next-action-grid>button{padding:14px 16px;font-size:15px}.history-list{display:flex;flex-direction:column;gap:6px}.history-row{display:grid;grid-template-columns:auto auto auto 1fr auto;gap:12px;align-items:center;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);transition:all .12s}.history-row:hover{border-color:var(--accent);background:#3b82f60d}.history-row-num{font-weight:700;color:var(--muted);font-size:13px;min-width:36px}.history-row-mode{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.repeat-tag{font-size:11px;padding:2px 8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.history-row-score{font-weight:700;font-size:16px;text-align:right}.history-row-score.winner-a{color:var(--accent)}.history-row-score.winner-b{color:var(--danger)}.history-row-score.is-draw{color:var(--warning)}.history-row-winner{font-size:13px;color:var(--muted);min-width:70px;text-align:right}.topbar-right{display:flex;align-items:center;gap:24px}.topbar-nav{display:flex;gap:4px}.nav-link{display:inline-block;padding:8px 14px;border-radius:6px;color:var(--muted);text-decoration:none;font-weight:500;font-size:14px;transition:all .12s}.nav-link:hover,.nav-link-active{color:var(--text);background:var(--surface-2)}.archive-list{display:flex;flex-direction:column;gap:8px}.archive-row{display:grid;grid-template-columns:140px auto 1fr auto auto;gap:16px;align-items:center;padding:14px 18px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);transition:all .12s}.archive-row:hover{border-color:var(--accent);background:#3b82f60d}.archive-row-date{font-size:14px;color:var(--muted);font-weight:500}.archive-row-mode{display:flex}.archive-row-meta{font-size:13px;color:var(--muted)}.archive-row-score{font-weight:700;font-size:17px;text-align:right;min-width:70px}.archive-row-score.winner-a{color:var(--accent)}.archive-row-score.winner-b{color:var(--danger)}.archive-row-score.is-draw{color:var(--warning)}.archive-row-winner{font-size:13px;color:var(--muted);min-width:80px;text-align:right}@media(max-width:700px){.archive-row{grid-template-columns:1fr 1fr;gap:8px}.archive-row-date{grid-column:1 / -1}.archive-row-meta{display:none}}.screenshot-slots{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:600px){.screenshot-slots{grid-template-columns:1fr}}.screenshot-slot{display:flex;flex-direction:column;gap:8px}.screenshot-slot-label{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.screenshot-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:120px;padding:20px;background:var(--surface-2);border:2px dashed var(--border);border-radius:8px;cursor:pointer;text-align:center;transition:all .12s}.screenshot-dropzone:hover{border-color:var(--accent);background:#3b82f60d}.screenshot-dropzone-icon{font-size:28px}.screenshot-dropzone-text{font-weight:600;color:var(--text)}.screenshot-dropzone-hint{font-size:12px;color:var(--muted)}.screenshot-dropzone-uploading{color:var(--accent);font-weight:600}.screenshot-thumb-wrap{position:relative;border-radius:8px;overflow:hidden;background:var(--surface-2)}.screenshot-thumb{display:block;width:100%;height:160px;object-fit:cover;cursor:zoom-in;transition:opacity .15s}.screenshot-thumb:hover{opacity:.85}.screenshot-replace-btn{position:absolute!important;top:8px;right:8px;padding:4px 10px!important;font-size:12px!important;background:#000000b3!important;color:#fff!important}.lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:2000;display:flex;align-items:center;justify-content:center;padding:32px;animation:fadeIn .15s ease-out}.lightbox-content{max-width:100%;max-height:100%;display:flex;flex-direction:column;gap:12px}.lightbox-header{display:flex;justify-content:space-between;align-items:center;color:#fff;font-size:16px;font-weight:600}.lightbox-close{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:4px 12px;cursor:pointer;font-size:14px}.lightbox-close:hover{background:#ffffff1a}.lightbox-content img{max-width:100%;max-height:calc(100vh - 80px);object-fit:contain;border-radius:8px}
