@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;700&family=Libre+Baskerville:ital@0;1&family=DM+Sans:wght@400;500;600&display=swap";:root{color-scheme:light;--bg: #0d0d0f;--bg-accent: #1a1a1f;--ink: #f5f5f0;--muted: #9a9a94;--accent: #e8a54b;--accent-2: #5ba67d;--liberal: #4a90d9;--fascist: #c9503c;--hitler: #1a1a1f;--panel: rgba(26, 26, 31, .92);--border: rgba(245, 245, 240, .08);--shadow: 0 24px 48px rgba(0, 0, 0, .4)}*{box-sizing:border-box}body{margin:0;font-family:DM Sans,Noto Sans,sans-serif;color:var(--ink);min-height:100vh;min-height:100dvh;background:var(--bg);overscroll-behavior:none}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(232,165,75,.12),transparent 50%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(91,166,125,.08),transparent 40%),radial-gradient(circle at 20% 60%,rgba(74,144,217,.05),transparent 30%);pointer-events:none;z-index:-1}.app{max-width:520px;margin:0 auto;padding:2rem 1.25rem 3rem;min-height:100vh;min-height:100dvh;overflow-anchor:auto}.hero,.game-header{text-align:left;margin-bottom:2rem}.hero.centered{text-align:center}.eyebrow{text-transform:uppercase;letter-spacing:.35em;font-size:.7rem;color:var(--muted);margin:0 0 .5rem}.round-label{text-transform:uppercase;letter-spacing:.25em;font-size:1rem;font-weight:500;color:var(--muted);margin:.5rem 0 0}h1{font-family:Libre Baskerville,Fraunces,serif;font-size:clamp(2rem,5vw,2.8rem);font-weight:400;margin:0 0 .5rem;letter-spacing:-.02em}h1.game-code{font-family:DM Sans,monospace;font-size:clamp(2.4rem,8vw,3.2rem);font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}h2{margin:0 0 .6rem;font-size:1rem;font-weight:600;letter-spacing:.02em}h3{margin:0 0 .4rem;font-size:.85rem;font-weight:600;color:var(--muted)}.lead{font-size:1rem;color:var(--muted);margin:0;line-height:1.5}.grid{display:grid;gap:1.25rem}.mode-toggle{display:flex;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:.25rem;margin-bottom:1.25rem;gap:.25rem}.mode-btn{flex:1;padding:.75rem 1rem;border:none;border-radius:10px;background:transparent;color:var(--muted);font:inherit;font-weight:500;cursor:pointer;transition:all .2s ease}.mode-btn:hover{color:var(--ink)}.mode-btn.active{background:var(--accent);color:var(--bg)}.home-card{text-align:center;padding:2rem 1.5rem}.home-card h2{font-size:1.25rem;margin-bottom:.5rem}.home-card .muted{margin-bottom:1.5rem}.home-card .join-form{display:flex;flex-direction:column;gap:.75rem}.home-card input{text-align:center;font-size:1.1rem;letter-spacing:.1em;text-transform:lowercase}.card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:1.25rem;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:rise .5s ease both;margin-bottom:1rem}.card:last-child{margin-bottom:0}.join-card,.waiting-card,.ready-card,.assign-card,.role-card{text-align:center}.join-form{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.waiting-indicator{margin-bottom:1rem}.spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;margin:0 auto;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ready-indicator{width:56px;height:56px;background:var(--accent-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1rem;color:#fff}.player-name-display{font-family:Libre Baskerville,serif;font-size:1.8rem;font-style:italic;color:var(--ink);margin:.5rem 0 1rem}.player-count-display{display:flex;align-items:baseline;justify-content:center;gap:.4rem;margin:1rem 0}.player-count-display .count{font-size:2.5rem;font-weight:600;color:var(--accent)}.player-count-display .label{font-size:.9rem;color:var(--muted)}.start-btn,.assign-btn{margin-top:1rem;width:100%}.role-reveal{padding:1.5rem;border-radius:12px;background:#ffffff0a;border:1px dashed var(--border);font-size:1.1rem;line-height:1.6;margin-top:1rem;min-height:80px;display:flex;align-items:center;justify-content:center;text-align:center}.role-reveal.liberal{background:#4a90d926;border-color:#4a90d94d;color:#7ab3e8}.role-reveal.fascist{background:#c9503c26;border-color:#c9503c4d;color:#e0847a}.role-reveal.hitler{background:#e8a54b1a;border:2px solid rgba(201,80,60,.5);color:var(--accent)}.actions-card{padding:1.5rem}.action-buttons{margin-bottom:1.5rem}.assign-confirm{text-align:center;overflow-anchor:none}.confirm-text{font-size:1rem;color:var(--ink);margin:0 0 1rem}.confirm-buttons{display:flex;flex-direction:column;gap:.5rem}.confirm-buttons .btn{width:100%}.view-party-card{text-align:center;position:relative;z-index:10}.view-party-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.75rem}.dropdown{position:relative}.dropdown.disabled{opacity:.5;pointer-events:none}.dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem 1rem;background:#1a1a1f;border:1px solid var(--border);border-radius:10px;color:var(--ink);font-size:.9rem;cursor:pointer;transition:border-color .15s,box-shadow .15s}.dropdown-trigger:hover{border-color:var(--muted)}.dropdown-trigger:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #e8a54b33}.dropdown-value{flex:1;text-align:left}.dropdown-arrow{font-size:.65rem;color:var(--muted)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:200px;overflow-y:auto;background:#1a1a1f;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #00000080;list-style:none;margin:0;padding:.25rem;z-index:9999}.dropdown-option{width:100%;padding:.6rem .75rem;background:transparent;border:none;border-radius:6px;color:var(--ink);font-size:.9rem;text-align:left;cursor:pointer;transition:background .1s}.dropdown-option:hover{background:#252529}.dropdown-option.selected{background:#2a2520;color:var(--accent)}.view-result{margin-top:1rem;padding:.75rem;border-radius:8px;background:#5ba67d1f;color:var(--accent-2);text-align:center;overflow-anchor:none}.player-list{list-style:none;margin:0;padding:0;display:grid;gap:.35rem}.player-list li{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;background:#ffffff05}.player-list li.you{background:#e8a54b1a}.you-badge{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;padding:.2rem .5rem;border-radius:4px;background:var(--accent);color:var(--bg);font-weight:600;margin-left:auto}.activity-list{list-style:none;margin:0;padding:0;display:grid;gap:.25rem;font-size:.85rem;color:var(--muted);overflow-anchor:none}.activity-list li{overflow-anchor:none}.danger-zone{background:transparent;border:1px dashed rgba(201,80,60,.3);text-align:center;padding:1rem}.game-actions-card{display:grid;grid-template-columns:1fr 1fr;align-items:start;gap:.75rem;overflow-anchor:none}.players-compact{text-align:center}.players-line{margin:0 0 .5rem}.role-distribution{margin:0;color:var(--muted);font-size:.85rem}.footer-nav{margin-top:2rem;text-align:center}input,select{padding:.75rem .9rem;border-radius:10px;border:1px solid var(--border);background:#ffffff0f;font:inherit;color:var(--ink);transition:border-color .2s ease,background .2s ease}input:focus,select:focus{outline:none;border-color:var(--accent);background:#ffffff14}input::placeholder{color:var(--muted)}.btn{padding:.75rem 1.25rem;border-radius:10px;border:1px solid transparent;background:var(--accent);color:var(--bg);font-weight:600;letter-spacing:.02em;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.btn.large{padding:.9rem 1.4rem;font-size:1rem}.btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px #e8a54b40}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn.secondary{background:var(--accent-2);color:#fff}.btn.secondary:hover{box-shadow:0 8px 24px #5ba67d40}.btn.ghost{background:transparent;border-color:var(--border);color:var(--muted)}.btn.ghost:hover{border-color:var(--muted);color:var(--ink);box-shadow:none}.btn.danger{background:var(--fascist);color:#fff}.btn.danger:hover{box-shadow:0 8px 24px #c9503c4d}.btn.full-width{width:100%}.muted{color:var(--muted);font-size:.85rem;margin:0;line-height:1.5}.notice{margin-top:1rem;padding:.75rem 1rem;border-radius:10px;background:#c9503c1f;border:1px solid rgba(201,80,60,.2);color:#e0847a;font-size:.85rem;overflow-anchor:none}@keyframes rise{0%{opacity:0}to{opacity:1}}@media (max-width: 500px){.app{padding:1.5rem 1rem 2.5rem}.card{padding:1rem;border-radius:14px}.btn,.btn.large{width:100%}h1.game-code{font-size:2rem}}.dev-toggle{position:fixed;bottom:1rem;right:1rem;width:48px;height:48px;border-radius:50%;border:2px solid #e8a54b;background:linear-gradient(135deg,#1a1a2e,#16213e);font-size:1.25rem;cursor:pointer;z-index:9999;box-shadow:0 4px 20px #ff6b3566;transition:transform .2s ease,box-shadow .2s ease}.dev-toggle:hover{transform:scale(1.1);box-shadow:0 6px 28px #ff6b3580}.dev-panel{position:fixed;bottom:5rem;right:1rem;width:320px;max-height:70vh;overflow-y:auto;background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:1px solid #e8a54b;border-radius:12px;box-shadow:0 12px 48px #0009,0 0 0 1px #ff6b3533;z-index:9998;font-size:.85rem}.dev-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(255,107,53,.3);background:#ff6b351a}.dev-panel-header h3{margin:0;color:#e8a54b;font-size:.9rem;font-weight:600;letter-spacing:.05em}.dev-close{background:transparent;border:none;color:#888;font-size:1.5rem;cursor:pointer;line-height:1;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.dev-close:hover{color:#e8a54b}.dev-panel-content{padding:1rem}.dev-game-id{margin:0 0 1rem;color:#aaa}.dev-game-id code{background:#ff6b3526;padding:.2rem .5rem;border-radius:4px;color:#e8a54b;font-family:DM Sans,monospace;font-weight:600}.dev-warning{margin:0 0 1rem;color:#e8a54b;font-style:italic}.dev-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.dev-section:last-of-type{margin-bottom:0;padding-bottom:0;border-bottom:none}.dev-label{display:block;color:#ccc;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.dev-row{display:flex;gap:.5rem}.dev-input{flex:1;padding:.5rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:#fff;font:inherit;font-size:.85rem;max-width:80px}.dev-input:focus{outline:none;border-color:#e8a54b}.dev-btn{padding:.5rem 1rem;border-radius:6px;border:1px solid #e8a54b;background:#ff6b3526;color:#e8a54b;font-weight:600;font-size:.8rem;cursor:pointer;transition:background .2s ease}.dev-btn:hover:not(:disabled){background:#ff6b354d}.dev-btn:disabled{opacity:.4;cursor:not-allowed}.dev-btn.full{width:100%}.dev-message{margin:.75rem 0 0;padding:.5rem .75rem;border-radius:6px;background:#ffffff0d;color:#aaa;font-size:.8rem;word-break:break-word}.dev-roles{margin-top:.75rem;background:#0003;border-radius:8px;padding:.75rem}.dev-roles-header{margin:0 0 .5rem;font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.dev-roles-list{list-style:none;margin:0;padding:0}.dev-role-item{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.dev-role-item:last-child{border-bottom:none}.dev-role-name{color:#ddd}.dev-role-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .5rem;border-radius:4px;background:#ffffff1a;color:#888}.dev-role-badge.liberal{background:#4a90d933;color:#7ab3e8}.dev-role-badge.fascist{background:#c9503c33;color:#e0847a}.dev-role-badge.hitler{background:#e8a54b26;color:#e8a54b;border:1px solid rgba(201,80,60,.4)}@media (max-width: 400px){.dev-panel{width:calc(100vw - 2rem);left:1rem;right:1rem}}
