@import url(https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Mono:wght@400;500&display=swap);:root{--bg:#0f0f11;--surface:#18181c;--surface2:#222228;--border:#2e2e38;--text:#f0f0f5;--muted:#7a7a8c;--accent:#e8c547;--accent-dim:#e8c5471f;--red:#e85454;--red-dim:#e8545426;--red-strong:#e854546b;--blue:#5490e8;--blue-dim:#5490e826;--blue-strong:#5490e86b;--green:#54c98a;--radius:10px;--font:"Syne",sans-serif;--mono:"DM Mono",monospace}[data-theme=light]{--bg:#f4f4f8;--surface:#fff;--surface2:#ebebf0;--border:#d8d8e4;--text:#18181c;--muted:#68687c;--accent:#9a7200;--accent-dim:#9a72001a;--red:#c83232;--red-dim:#c832321a;--red-strong:#c832323d;--blue:#2458b8;--blue-dim:#2458b81a;--blue-strong:#2458b83d;--green:#1e8c5c}[data-theme=light] .btn-google:hover{background:#222228;background:var(--surface2);border-color:#2e2e38;border-color:var(--border)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#0f0f11;background:var(--bg);color:#f0f0f5;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font);min-height:100vh}.login-page{align-items:center;background:radial-gradient(ellipse 60% 50% at 50% -10%,#e8c5471f 0,#0000 70%),#0f0f11;background:radial-gradient(ellipse 60% 50% at 50% -10%,#e8c5471f 0,#0000 70%),var(--bg);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;gap:18px;max-width:400px;padding:40px 36px;width:100%}.login-logo{margin-bottom:8px;text-align:center}.logo-icon{display:block;font-size:3rem;margin-bottom:8px}.login-logo h1{color:#e8c547;color:var(--accent);font-size:2rem;font-weight:800;letter-spacing:-.03em}.logo-sub{color:#7a7a8c;color:var(--muted);font-size:.9rem;margin-top:2px}.btn-google{align-items:center;background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#f0f0f5;color:var(--text);cursor:pointer;display:flex;font-family:Syne,sans-serif;font-family:var(--font);font-size:.95rem;font-weight:600;gap:10px;justify-content:center;padding:12px 20px;transition:background .15s,border-color .15s;width:100%}.btn-google:hover{background:#2a2a32;border-color:#3e3e4a}.divider{align-items:center;color:#7a7a8c;color:var(--muted);display:flex;font-size:.8rem;gap:12px}.divider:after,.divider:before{background:#2e2e38;background:var(--border);content:"";flex:1 1;height:1px}.email-input{background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#f0f0f5;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font);font-size:.95rem;outline:none;padding:12px 16px;transition:border-color .15s;width:100%}.email-input:focus{border-color:#e8c547;border-color:var(--accent)}.email-input::placeholder{color:#7a7a8c;color:var(--muted)}.btn-magic{background:#e8c547;background:var(--accent);border:none;border-radius:10px;border-radius:var(--radius);color:#111;cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font);font-size:.95rem;font-weight:700;margin-top:4px;padding:13px 20px;transition:opacity .15s,transform .1s;width:100%}.btn-magic:hover{opacity:.9}.btn-magic:active{transform:scale(.98)}.btn-magic:disabled{cursor:not-allowed;opacity:.5}.error-msg{background:#e8545426;background:var(--red-dim);border:1px solid #e8545440;border-radius:8px;color:#e85454;color:var(--red);font-size:.85rem;padding:10px 14px}.success-msg{color:#54c98a;color:var(--green);font-size:.85rem}.sent-message{align-items:center;display:flex;flex-direction:column;gap:12px;text-align:center}.sent-icon{font-size:2.5rem}.sent-message h2{font-weight:700}.sent-message p{color:#7a7a8c;color:var(--muted);line-height:1.5}.onboarding-choices{gap:12px}.btn-choice,.onboarding-choices{display:flex;flex-direction:column}.btn-choice{align-items:flex-start;background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#f0f0f5;color:var(--text);cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font);gap:2px;padding:16px 20px;text-align:left;transition:border-color .15s,background .15s}.btn-choice:hover{background:#e8c5471f;background:var(--accent-dim);border-color:#e8c547;border-color:var(--accent)}.btn-choice span{font-size:1.5rem}.btn-choice strong{font-size:1rem;font-weight:700}.btn-choice small{font-size:.82rem}.back-btn,.btn-choice small{color:#7a7a8c;color:var(--muted)}.back-btn{background:none;border:none;cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font);font-size:.85rem;margin-bottom:4px;padding:0;text-align:left}.back-btn:hover{color:#f0f0f5;color:var(--text)}.field-label{color:#7a7a8c;color:var(--muted);display:block;font-size:.8rem;font-weight:600;letter-spacing:.06em;margin-bottom:6px;margin-top:8px;text-transform:uppercase}.loading-spinner{animation:pulse 1.2s ease-in-out infinite;font-size:3rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#18181c;background:var(--surface);border-bottom:1px solid #2e2e38;border-bottom:1px solid var(--border);height:60px;justify-content:space-between;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-header,.header-left{align-items:center;display:flex}.header-left{color:inherit;gap:10px}.logo-icon-sm{font-size:1.4rem}.header-team{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.header-nav{align-items:center;display:flex;gap:12px}.nav-link{background:none;border:none;border-radius:8px;color:#7a7a8c;color:var(--muted);cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font);font-size:.88rem;font-weight:600;padding:6px 10px;text-decoration:none;transition:color .15s,background .15s}.nav-link:hover{background:#222228;background:var(--surface2);color:#f0f0f5;color:var(--text)}.btn-log{color:#111!important;font-weight:700!important;padding:7px 14px!important}.btn-log,.btn-log:hover{background:#e8c547!important;background:var(--accent)!important}.btn-log:hover{opacity:.88}.sign-out-btn{color:#7a7a8c;color:var(--muted)}.theme-toggle{font-size:1rem;padding:6px 8px!important}.login-theme-toggle{position:fixed;right:16px;top:16px}.main-content{display:flex;flex:1 1;flex-direction:column;gap:40px;margin:0 auto;max-width:860px;padding:32px 24px 60px;width:100%}.section-title{color:#e8c547;color:var(--accent);font-size:1.1rem;font-size:.82rem;font-weight:800;letter-spacing:-.02em;letter-spacing:.1em;margin-bottom:16px;text-transform:uppercase}.leaderboard-table-wrap{border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow-x:auto}.leaderboard-table{border-collapse:collapse;font-size:.92rem;width:100%}.leaderboard-table thead tr{background:#222228;background:var(--surface2);border-bottom:1px solid #2e2e38;border-bottom:1px solid var(--border)}.leaderboard-table th{color:#7a7a8c;color:var(--muted);font-size:.75rem;font-weight:700;letter-spacing:.07em;padding:11px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.leaderboard-table td{border-bottom:1px solid #2e2e38;border-bottom:1px solid var(--border);padding:13px 16px;vertical-align:middle}.leaderboard-table tbody tr:last-child td{border-bottom:none}.leaderboard-table tbody tr{background:#18181c;background:var(--surface);transition:background .12s}.leaderboard-table tbody tr:hover{background:#222228;background:var(--surface2)}.leaderboard-table tbody tr.top-row{background:#e8c5470a}.rank-cell{font-size:1.1rem;width:48px}.name-cell{font-weight:700}.wl{font-family:DM Mono,monospace;font-family:var(--mono);font-size:.9rem}.sm-cell{color:#7a7a8c;color:var(--muted)}.sm-cell,.win-pct{font-family:DM Mono,monospace;font-family:var(--mono);font-size:.88rem}.win-pct{display:block;margin-bottom:4px}.pct-bar{background:#2e2e38;background:var(--border);border-radius:2px;height:4px;overflow:hidden;width:80px}.pct-fill{background:#e8c547;background:var(--accent);border-radius:2px;height:100%;transition:width .4s ease}.streak-badge{background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:6px;font-family:DM Mono,monospace;font-family:var(--mono);font-size:.82rem;font-weight:500;padding:3px 8px}.streak-w{background:#54c98a26;border-color:#54c98a4d;color:#54c98a;color:var(--green)}.streak-l{background:#e8545426;background:var(--red-dim);border-color:#e854544d;color:#e85454;color:var(--red)}.team-section-block{border-bottom:1px solid #2e2e38;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:40px;margin-bottom:48px;padding-bottom:40px}.team-section-block:last-child{border-bottom:none;margin-bottom:0}.team-section-heading{color:#f0f0f5;color:var(--text);font-size:1.3rem;font-weight:800;letter-spacing:-.03em;margin-bottom:20px}.game-cards{display:flex;flex-direction:column;gap:12px}.game-card{background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:16px 20px}.game-card-date{align-items:center;color:#7a7a8c;color:var(--muted);display:flex;font-size:.8rem;font-weight:600;gap:10px;margin-bottom:12px}.winner-tag{border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:2px 8px;text-transform:uppercase}.winner-tag.red{background:#e8545426;background:var(--red-dim);color:#e85454;color:var(--red)}.winner-tag.blue{background:#5490e826;background:var(--blue-dim);color:#5490e8;color:var(--blue)}.game-sides{align-items:center;gap:12px}.game-side,.game-sides{display:flex;flex-wrap:wrap}.game-side{flex:1 1;gap:6px;min-width:120px}.vs-divider{color:#7a7a8c;color:var(--muted);font-size:.75rem;font-weight:700}.player-chip{align-items:center;border-radius:20px;display:inline-flex;font-size:.82rem;font-weight:600;gap:4px;padding:3px 10px}.red-side .player-chip{background:#e8545426;background:var(--red-dim);border:1px solid #e8545433;color:#e85454;color:var(--red)}.blue-side .player-chip{background:#5490e826;background:var(--blue-dim);border:1px solid #5490e833;color:#5490e8;color:var(--blue)}.sm-badge{font-size:.75rem}.game-notes{color:#7a7a8c;color:var(--muted);font-size:.82rem;font-style:italic;margin-top:10px}.invite-section{margin-top:8px}.invite-label{color:#7a7a8c;color:var(--muted);font-size:.78rem;font-weight:600;letter-spacing:.07em;margin-bottom:8px;text-transform:uppercase}.invite-code-display{align-items:center;background:#18181c;background:var(--surface);border:1px dashed #e8c547;border:1px dashed var(--accent);border-radius:10px;border-radius:var(--radius);color:#e8c547;color:var(--accent);cursor:pointer;display:inline-flex;font-family:DM Mono,monospace;font-family:var(--mono);font-size:1.4rem;gap:14px;letter-spacing:.2em;padding:12px 20px;transition:background .15s}.invite-code-display:hover{background:#e8c5471f;background:var(--accent-dim)}.invite-code-display.large{font-size:1.8rem}.copy-hint{color:#7a7a8c;color:var(--muted);font-family:Syne,sans-serif;font-family:var(--font);font-size:.72rem;letter-spacing:normal}.log-game-main{max-width:700px}.log-form{display:flex;flex-direction:column;gap:24px}.log-section{background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:20px 24px}.log-section-title{color:#7a7a8c;color:var(--muted);font-size:.8rem;font-weight:700;letter-spacing:.08em;margin-bottom:14px;text-transform:uppercase}.optional{font-size:.8rem;font-weight:400;letter-spacing:normal;text-transform:none}.winner-toggle{display:flex;gap:12px}.winner-btn{background:#222228;background:var(--surface2);border:2px solid #2e2e38;border:2px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#7a7a8c;color:var(--muted);cursor:pointer;flex:1 1;font-family:Syne,sans-serif;font-family:var(--font);font-size:1rem;font-weight:700;padding:14px 20px;transition:all .15s}.winner-btn.red-btn.active{background:#e8545426;background:var(--red-dim);border-color:#e85454;border-color:var(--red);color:#e85454;color:var(--red)}.winner-btn.blue-btn.active{background:#5490e826;background:var(--blue-dim);border-color:#5490e8;border-color:var(--blue);color:#5490e8;color:var(--blue)}.winner-btn:hover:not(.active){border-color:#444;color:#f0f0f5;color:var(--text)}.teams-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:600px){.teams-grid{grid-template-columns:1fr}}.red-section{border-color:#e854544d}.blue-section{border-color:#5490e84d}.player-row{align-items:center;display:flex;gap:8px;margin-bottom:10px}.player-select,.role-select{background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:8px;color:#f0f0f5;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font);font-size:.85rem;outline:none;padding:8px 10px}.player-select{flex:1 1}.role-select{flex-shrink:0}.player-select:focus,.role-select:focus{border-color:#e8c547;border-color:var(--accent)}.remove-player-btn{background:none;border:1px solid #2e2e38;border:1px solid var(--border);border-radius:6px;color:#7a7a8c;color:var(--muted);cursor:pointer;font-size:.75rem;padding:6px 8px;transition:color .15s,border-color .15s}.remove-player-btn:hover{border-color:#e85454;border-color:var(--red);color:#e85454;color:var(--red)}.add-player-btn{background:none;border:1px dashed #2e2e38;border:1px dashed var(--border);border-radius:8px;color:#7a7a8c;color:var(--muted);cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font);font-size:.82rem;font-weight:600;padding:8px 14px;transition:color .15s,border-color .15s;width:100%}.add-player-btn:hover{border-color:#e8c547;border-color:var(--accent);color:#e8c547;color:var(--accent)}.submit-btn{margin-top:4px}.members-list{display:flex;flex-direction:column;gap:8px}.member-row{background:#222228;background:var(--surface2);border-radius:8px;gap:12px;justify-content:space-between;padding:12px 16px}.member-name,.member-row{align-items:center;display:flex}.member-name{font-weight:600;gap:8px}.admin-badge{background:#e8c5471f;background:var(--accent-dim);color:#e8c547;color:var(--accent);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.admin-badge,.you-badge{border-radius:4px;font-size:.7rem;padding:2px 7px}.you-badge{background:#18181c;background:var(--surface);color:#7a7a8c;color:var(--muted)}.member-actions{display:flex;gap:8px}.action-btn{background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:6px;color:#f0f0f5;color:var(--text);cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font);font-size:.8rem;padding:6px 12px;transition:border-color .15s,color .15s}.action-btn:hover{border-color:#e8c547;border-color:var(--accent);color:#e8c547;color:var(--accent)}.danger-btn:hover{border-color:#e85454!important;border-color:var(--red)!important;color:#e85454!important;color:var(--red)!important}.empty-state{color:#7a7a8c;color:var(--muted);padding:40px 20px;text-align:center}.empty-state p{margin-bottom:16px}.loading-state{padding:60px;text-align:center}.loading-state,.muted{color:#7a7a8c;color:var(--muted)}.muted{font-size:.9rem}.inline-btn{display:inline-block;padding:10px 24px;width:auto}select option{background:#222228;background:var(--surface2);color:#f0f0f5;color:var(--text)}.seed-table-wrap{border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow-x:auto}.seed-table{border-collapse:collapse;font-size:.88rem;width:100%}.seed-table thead tr{background:#222228;background:var(--surface2);border-bottom:1px solid #2e2e38;border-bottom:1px solid var(--border)}.seed-table th{color:#7a7a8c;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.07em;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.seed-table td{border-bottom:1px solid #2e2e38;border-bottom:1px solid var(--border);padding:8px 10px;vertical-align:middle}.seed-table tbody tr:last-child td{border-bottom:none}.seed-row{background:#18181c;background:var(--surface);transition:background .12s}.seed-row.dirty{background:#e8c5470a}.seed-name{align-items:center;display:flex;font-weight:600;gap:6px;min-width:100px;white-space:nowrap}.seed-input{background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:6px;color:#f0f0f5;color:var(--text);font-family:DM Mono,monospace;font-family:var(--mono);font-size:.88rem;outline:none;padding:6px 8px;text-align:center;transition:border-color .15s;width:56px}.seed-input:focus{border-color:#e8c547;border-color:var(--accent)}.seed-select{background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:6px;color:#f0f0f5;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font);font-size:.88rem;outline:none;padding:6px 8px;transition:border-color .15s}.seed-select:focus{border-color:#e8c547;border-color:var(--accent)}.save-seed-btn{white-space:nowrap}.dirty-btn{border-color:#e8c547!important;border-color:var(--accent)!important;color:#e8c547!important;color:var(--accent)!important}.emeritus-badge{background:#7a7a8c26;border-radius:4px;color:#7a7a8c;color:var(--muted);font-size:.7rem;font-weight:700;letter-spacing:.05em;margin-left:6px;padding:2px 7px;text-transform:uppercase}.angel-badge{font-size:.85rem;margin-left:6px}.member-group-label{color:#7a7a8c;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.leaderboard-table tbody tr.inactive-row td{opacity:.55}.flash-msg{animation:fadeIn .2s ease;background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);font-size:.9rem;padding:12px 18px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.delete-game-btn{background:none;border:1px solid #0000;border-radius:6px;color:#7a7a8c;color:var(--muted);cursor:pointer;font-size:.75rem;line-height:1.4;margin-left:auto;padding:2px 7px;transition:color .15s,border-color .15s,background .15s}.delete-game-btn:hover{background:#e8545426;background:var(--red-dim);border-color:#e85454;border-color:var(--red);color:#e85454;color:var(--red)}.delete-game-btn:disabled{cursor:not-allowed;opacity:.4}.game-card-deleting{opacity:.4;pointer-events:none;transition:opacity .2s}.join-link-row{align-items:center;background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);display:flex;gap:12px;padding:12px 16px}.join-link-display{background:none;border:none;color:#7a7a8c;color:var(--muted);flex:1 1;font-family:DM Mono,monospace;font-family:var(--mono);font-size:.82rem;outline:none;word-break:break-all}.play-game-list{display:flex;flex-direction:column;gap:10px}.play-game-row{align-items:center;background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#f0f0f5;color:var(--text);cursor:pointer;display:flex;font-family:Syne,sans-serif;font-family:var(--font);gap:16px;padding:14px 18px;text-align:left;transition:background .12s,border-color .12s;width:100%}.play-game-row:hover{background:#222228;background:var(--surface2);border-color:#e8c547;border-color:var(--accent)}.play-game-row-main{align-items:center;display:flex;flex:1 1;gap:10px;min-width:0}.play-game-row-status{font-size:.9rem;font-weight:700}.play-game-row-time{color:#7a7a8c;color:var(--muted);font-family:DM Mono,monospace;font-family:var(--mono);font-size:.78rem;white-space:nowrap}.play-status-dot{background:#7a7a8c;background:var(--muted);border-radius:50%;flex-shrink:0;height:10px;width:10px}.play-status-dot.lobby{background:#e8c547;background:var(--accent)}.play-status-dot.active{background:#54c98a;background:var(--green);box-shadow:0 0 0 3px #e8c5471f;box-shadow:0 0 0 3px var(--accent-dim)}.play-status-dot.finished{background:#7a7a8c;background:var(--muted)}.play-game-row-counts{display:flex;flex-shrink:0;gap:10px}.play-side-count{font-family:DM Mono,monospace;font-family:var(--mono);font-size:.82rem;font-weight:600}.play-side-count.red{color:#e85454;color:var(--red)}.play-side-count.blue{color:#5490e8;color:var(--blue)}.play-roster-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:24px}@media (max-width:600px){.play-roster-grid{grid-template-columns:1fr}}.play-roster-col{background:#222228;background:var(--surface2);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:16px}.play-roster-red{border-color:#e854544d}.play-roster-blue{border-color:#5490e84d}.play-roster-heading{font-size:1rem;font-weight:800;margin-bottom:14px}.play-roster-role{margin-bottom:14px}.play-roster-role:last-child{margin-bottom:0}.play-roster-role-label{color:#7a7a8c;color:var(--muted);display:block;font-size:.72rem;font-weight:700;letter-spacing:.08em;margin-bottom:6px;text-transform:uppercase}.play-roster-names{display:flex;flex-direction:column;gap:4px;list-style:none;margin-bottom:8px}.play-roster-names li{font-size:.88rem;font-weight:600}.play-roster-names li.play-roster-me{color:#e8c547;color:var(--accent)}.play-roster-empty{color:#7a7a8c!important;color:var(--muted)!important;font-style:italic;font-weight:400!important}.play-roster-tag{color:#e8c547;color:var(--accent);font-size:.78rem;font-weight:700}.play-lobby-actions{align-items:center;display:flex;gap:16px;justify-content:space-between}.play-active,.play-finished{display:flex;flex-direction:column;gap:20px}.play-score-bar{display:flex;gap:12px}.play-score{align-items:center;background:#18181c;background:var(--surface);border:2px solid #2e2e38;border:2px solid var(--border);border-radius:10px;border-radius:var(--radius);display:flex;flex:1 1;font-weight:700;justify-content:space-between;padding:14px 18px;transition:border-color .2s,background .2s}.play-score-label{font-size:.9rem}.play-score-value{font-family:DM Mono,monospace;font-family:var(--mono);font-size:1.2rem}.play-score-red .play-score-value{color:#e85454;color:var(--red)}.play-score-blue .play-score-value{color:#5490e8;color:var(--blue)}.play-score-red.play-score-active{background:#e8545426;background:var(--red-dim);border-color:#e85454;border-color:var(--red)}.play-score-blue.play-score-active{background:#5490e826;background:var(--blue-dim);border-color:#5490e8;border-color:var(--blue)}.play-turn-banner{align-items:center;display:flex;justify-content:center;position:relative}.play-turn-banner .sign-out-btn{font-size:.78rem;padding:6px 12px;position:absolute;right:0}.play-turn-pill{border:2px solid #0000;border-radius:24px;display:inline-block;font-size:1rem;font-weight:800;letter-spacing:.07em;padding:11px 30px;text-transform:uppercase}.play-turn-red{background:#e854546b;background:var(--red-strong);border-color:#e85454;border-color:var(--red);color:#e85454;color:var(--red)}.play-turn-blue{background:#5490e86b;background:var(--blue-strong);border-color:#5490e8;border-color:var(--blue);color:#5490e8;color:var(--blue)}.play-turn-pill-mine.play-turn-red{animation:turnPulseRed 1.8s ease-in-out infinite}.play-turn-pill-mine.play-turn-blue{animation:turnPulseBlue 1.8s ease-in-out infinite}@keyframes turnPulseRed{0%,to{box-shadow:0 0 0 0 #e8545480;transform:scale(1)}50%{box-shadow:0 0 0 10px #e8545400;transform:scale(1.035)}}@keyframes turnPulseBlue{0%,to{box-shadow:0 0 0 0 #5490e880;transform:scale(1)}50%{box-shadow:0 0 0 10px #5490e800;transform:scale(1.035)}}.play-turn-flash{animation:turnChangeFlash .7s cubic-bezier(.22,.8,.3,1)}@keyframes turnChangeFlash{0%{filter:brightness(1.6);transform:scale(1.22)}to{filter:brightness(1);transform:scale(1)}}.play-clue-banner{align-items:baseline;background:#18181c;background:var(--surface);border:1px solid #e8c547;border:1px solid var(--accent);border-radius:10px;border-radius:var(--radius);display:flex;gap:12px;justify-content:center;padding:14px 20px;text-align:center}.play-clue-word{color:#e8c547;color:var(--accent);font-size:1.3rem;font-weight:800}.play-clue-number{font-family:DM Mono,monospace;font-family:var(--mono);font-size:1.1rem;font-weight:700}.play-clue-by{color:#7a7a8c;color:var(--muted);font-size:.82rem}.play-board{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(5,1fr)}@media (max-width:560px){.play-board{gap:6px}}.play-card{align-items:center;aspect-ratio:4/3;background:linear-gradient(180deg,#222228,#18181c);background:linear-gradient(180deg,var(--surface2),var(--surface));border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 2px #0000001f;cursor:default;display:flex;flex-direction:column;font-family:Syne,sans-serif;font-family:var(--font);gap:6px;justify-content:center;padding:10px 8px;position:relative;transition:transform .15s ease,border-color .15s ease,background .15s ease,box-shadow .15s ease}.play-card-word{color:#f0f0f5;color:var(--text);font-size:.8rem;font-weight:700;letter-spacing:.04em;line-height:1.25;text-align:center;text-transform:uppercase;transition:opacity .15s ease,color .15s ease;word-break:break-word}.play-card-icon{font-size:1rem;line-height:1}.play-card-tappable{cursor:pointer}.play-card-tappable:hover{background:linear-gradient(180deg,#222228,#e8c5471f);background:linear-gradient(180deg,var(--surface2),var(--accent-dim));border-color:#e8c547;border-color:var(--accent);box-shadow:0 4px 14px #00000038;transform:translateY(-2px)}.play-card-tappable:active{box-shadow:0 1px 2px #0000001f;transform:translateY(0) scale(.97)}.play-card-voted{border-color:#e8c547;border-color:var(--accent);box-shadow:0 0 0 2px #e8c5471f;box-shadow:0 0 0 2px var(--accent-dim)}.play-card-votes{display:flex;gap:3px;position:absolute;right:6px;top:6px}.play-vote-badge{align-items:center;background:#e8c547;background:var(--accent);border:1.5px solid #18181c;border:1.5px solid var(--surface);border-radius:50%;box-shadow:0 1px 3px #0000004d;color:#0f0f11;color:var(--bg);display:flex;font-size:.66rem;font-weight:800;height:20px;justify-content:center;width:20px}.play-confirm-banner{align-items:center;background:#18181c;background:var(--surface);border:1px solid #e8c547;border:1px solid var(--accent);border-radius:10px;border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:12px 18px}.play-confirm-text{font-size:.92rem;font-weight:700}.play-confirm-banner .btn-magic{padding:9px 22px;width:auto}.play-card-flash{animation:cardRevealFlash .85s cubic-bezier(.22,.8,.3,1)}@keyframes cardRevealFlash{0%{box-shadow:0 0 0 4px #fff6,0 10px 26px #00000059;transform:scale(1.12)}to{box-shadow:inset 0 1px 0 #ffffff0a,0 1px 2px #0000001f;transform:scale(1)}}.play-card-hint{border-width:1px;box-shadow:inset 0 0 0 1px #0000,0 0 0 3px #0000}.play-card-hint-red{background:linear-gradient(180deg,#222228,#e854546b);background:linear-gradient(180deg,var(--surface2),var(--red-strong));border-color:#e85454;border-color:var(--red);box-shadow:0 0 0 1px #e854546b;box-shadow:0 0 0 1px var(--red-strong)}.play-card-hint-blue{background:linear-gradient(180deg,#222228,#5490e86b);background:linear-gradient(180deg,var(--surface2),var(--blue-strong));border-color:#5490e8;border-color:var(--blue);box-shadow:0 0 0 1px #5490e86b;box-shadow:0 0 0 1px var(--blue-strong)}.play-card-hint-neutral{border-color:#2e2e38;border-color:var(--border)}.play-card-hint-assassin{background:linear-gradient(180deg,#222228,#222228);background:linear-gradient(180deg,var(--surface2),var(--surface2));border-color:#f0f0f5;border-color:var(--text);box-shadow:0 0 0 1px #ffffff1f}.play-card-revealed{border-width:2px;box-shadow:inset 0 1px 0 #ffffff0a,0 1px 2px #0000001f;cursor:default}.play-card-revealed .play-card-word{opacity:.7}.play-card-red{background:linear-gradient(180deg,#e854546b,#e8545426);background:linear-gradient(180deg,var(--red-strong),var(--red-dim));border-color:#e85454;border-color:var(--red)}.play-card-blue{background:linear-gradient(180deg,#5490e86b,#5490e826);background:linear-gradient(180deg,var(--blue-strong),var(--blue-dim));border-color:#5490e8;border-color:var(--blue)}.play-card-neutral{background:#222228;background:var(--surface2);border-color:#2e2e38;border-color:var(--border)}.play-card-neutral .play-card-word{opacity:.4}.play-card-assassin{background:#f0f0f5;background:var(--text);border-color:#f0f0f5;border-color:var(--text)}.play-card-assassin .play-card-word{color:#0f0f11;color:var(--bg);opacity:.9}.play-clue-form{align-items:center;display:flex;gap:10px}.play-event-log{background:#18181c;background:var(--surface);border:1px solid #2e2e38;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:16px 20px}.play-event-log ul{display:flex;flex-direction:column;gap:6px;list-style:none;margin-top:8px}.play-event-log li{font-size:.85rem}.play-event-red{color:#e85454;color:var(--red)}.play-event-blue{color:#5490e8;color:var(--blue)}.play-event-neutral{color:#7a7a8c;color:var(--muted)}.play-winner-banner{background:#18181c;background:var(--surface);border:2px solid #2e2e38;border:2px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:32px 20px;text-align:center}.play-winner-banner h2{font-size:1.6rem;font-weight:800;margin:8px 0 6px}.play-winner-emoji{font-size:2.2rem}.play-winner-red{background:#e8545426;background:var(--red-dim);border-color:#e85454;border-color:var(--red)}.play-winner-blue{background:#5490e826;background:var(--blue-dim);border-color:#5490e8;border-color:var(--blue)}
/*# sourceMappingURL=main.a7c421c1.css.map*/