*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark:#0b0e1a;--bg-card:#141932d9;--bg-card-hover:#1e2646f2;--impostor-red:#ff1744;--impostor-glow:#ff174480;--crewmate-blue:#00b0ff;--crewmate-glow:#00b0ff66;--accent-green:#00e676;--accent-yellow:#ffd740;--accent-orange:#ff9100;--accent-purple:#b388ff;--text-primary:#e8eaf6;--text-secondary:#9fa8da;--text-muted:#5c6bc0;--border-subtle:#ffffff14;--border-glow:#00b0ff4d;--font-display:"Russo One", sans-serif;--font-body:"Inter", sans-serif;--radius:16px;--radius-sm:10px;--shadow-card:0 8px 32px #0006;--shadow-glow-red:0 0 30px var(--impostor-glow), 0 0 60px #ff174433;--shadow-glow-blue:0 0 30px var(--crewmate-glow), 0 0 60px #00b0ff26}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg-dark);color:var(--text-primary);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.starfield{z-index:0;background:radial-gradient(at 20%,#0d1333 0%,#0b0e1a 50%,#060812 100%);position:fixed;inset:0;overflow:hidden}.starfield:before,.starfield:after{content:"";background-image:radial-gradient(1px 1px at 10% 20%,#fff9,#0000),radial-gradient(1px 1px at 30% 60%,#fff6,#0000),radial-gradient(1.5px 1.5px at 50% 10%,#ffffffb3,#0000),radial-gradient(1px 1px at 70% 80%,#ffffff80,#0000),radial-gradient(1px 1px at 90% 40%,#ffffff4d,#0000),radial-gradient(1.5px 1.5px at 15% 90%,#fff9,#0000),radial-gradient(1px 1px at 60% 30%,#fff6,#0000),radial-gradient(1px 1px at 80% 70%,#ffffff80,#0000);animation:4s ease-in-out infinite alternate twinkle;position:absolute;inset:0}.starfield:after{opacity:.5;animation-delay:2s;transform:scale(1.5)}@keyframes twinkle{0%{opacity:.4}50%{opacity:1}to{opacity:.6}}.app-container{z-index:1;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;max-width:520px;padding:40px;animation:.5s cubic-bezier(.16,1,.3,1) cardEnter}.card--wide{max-width:700px}.card--full{max-width:900px}@keyframes cardEnter{0%{opacity:0;transform:translateY(30px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.title{font-family:var(--font-display);text-align:center;background:linear-gradient(135deg, var(--impostor-red), var(--accent-orange));-webkit-text-fill-color:transparent;text-shadow:none;filter:drop-shadow(0 0 20px #ff17444d);-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2.4rem}.subtitle{font-family:var(--font-display);color:var(--text-secondary);text-align:center;letter-spacing:2px;text-transform:uppercase;margin-bottom:32px;font-size:1rem}.section-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:16px;font-size:1.2rem}.btn{border-radius:var(--radius-sm);width:100%;font-family:var(--font-display);cursor:pointer;letter-spacing:.5px;border:none;justify-content:center;align-items:center;gap:10px;padding:14px 24px;font-size:1rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1a,#0000);position:absolute;inset:0}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn--red{color:#fff;background:linear-gradient(135deg,#e01535,#ff1744);box-shadow:0 4px 20px #ff174466}.btn--red:hover{box-shadow:0 6px 30px #ff174499}.btn--blue{color:#fff;background:linear-gradient(135deg,#0091ea,#00b0ff);box-shadow:0 4px 20px #00b0ff4d}.btn--blue:hover{box-shadow:0 6px 30px #00b0ff80}.btn--green{color:#0b0e1a;background:linear-gradient(135deg,#00c853,#00e676);box-shadow:0 4px 20px #00e6764d}.btn--green:hover{box-shadow:0 6px 30px #00e67680}.btn--orange{color:#fff;background:linear-gradient(135deg,#e65100,#ff9100);box-shadow:0 4px 20px #ff91004d}.btn--ghost{color:var(--text-secondary);border:1px solid var(--border-subtle);background:#ffffff0d}.btn--ghost:hover{color:var(--text-primary);background:#ffffff1a}.btn--sm{padding:10px 16px;font-size:.85rem}.btn--pulse{animation:2s ease-in-out infinite btnPulse}@keyframes btnPulse{0%,to{box-shadow:0 4px 20px #00e6764d}50%{box-shadow:0 4px 40px #00e676b3,0 0 60px #00e67633}}.input-group{margin-bottom:16px}.input-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.input{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-body);background:#ffffff0d;outline:none;padding:12px 16px;font-size:1rem;transition:all .2s}.input:focus{border-color:var(--crewmate-blue);background:#ffffff14;box-shadow:0 0 0 3px #00b0ff26}.input::placeholder{color:var(--text-muted)}.player-list{flex-direction:column;gap:8px;display:flex}.player-item{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#ffffff0a;align-items:center;gap:12px;padding:12px 16px;transition:all .2s;animation:.3s ease-out both playerSlideIn;display:flex}.player-item:first-child{animation-delay:50ms}.player-item:nth-child(2){animation-delay:.1s}.player-item:nth-child(3){animation-delay:.15s}.player-item:nth-child(4){animation-delay:.2s}.player-item:nth-child(5){animation-delay:.25s}.player-item:nth-child(6){animation-delay:.3s}@keyframes playerSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.player-avatar{background:linear-gradient(135deg, var(--crewmate-blue), var(--accent-purple));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:700;display:flex}.player-name{flex:1;font-size:.95rem;font-weight:600}.player-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:3px 8px;font-size:.7rem;font-weight:700}.player-badge--host{color:var(--accent-yellow);background:#ffd74026;border:1px solid #ffd7404d}.player-badge--you{color:var(--crewmate-blue);background:#00b0ff26;border:1px solid #00b0ff4d}.room-code-display{text-align:center;border-radius:var(--radius-sm);border:1px dashed var(--border-glow);background:#ffffff08;margin-bottom:24px;padding:20px}.room-code-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:.75rem}.room-code-value{font-family:var(--font-display);color:var(--crewmate-blue);letter-spacing:8px;text-shadow:0 0 20px var(--crewmate-glow);font-size:2.5rem}.qr-container{border-radius:var(--radius-sm);background:#fff;flex-direction:column;align-items:center;max-width:200px;margin:16px auto;padding:16px;display:flex}.divider{background:var(--border-subtle);height:1px;margin:24px 0}.error-msg{color:var(--impostor-red);text-align:center;margin-top:8px;font-size:.85rem;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.game-header{text-align:center;border-radius:var(--radius);margin-bottom:24px;padding:20px}.game-header--impostor{box-shadow:var(--shadow-glow-red);background:linear-gradient(135deg,#ff174426,#ff17440d);border:1px solid #ff17444d}.game-header--crewmate{box-shadow:var(--shadow-glow-blue);background:linear-gradient(135deg,#00b0ff26,#00b0ff0d);border:1px solid #00b0ff4d}.role-title{font-family:var(--font-display);margin-bottom:8px;font-size:1.8rem}.role-title--impostor{color:var(--impostor-red)}.role-title--crewmate{color:var(--crewmate-blue)}.word-display{font-family:var(--font-display);border-radius:var(--radius-sm);margin-top:8px;padding:12px 24px;font-size:1.6rem;display:inline-block}.word-display--word{color:var(--accent-green);background:#00e6761a;border:1px solid #00e6764d}.word-display--hidden{color:var(--impostor-red);background:#ff17441a;border:1px solid #ff17444d}.turn-indicator{text-align:center;border-radius:var(--radius-sm);margin-bottom:20px;padding:16px}.turn-indicator--active{background:linear-gradient(135deg,#ffd74026,#ff91001a);border:2px solid #ffd74066;animation:2s ease-in-out infinite glowPulse}.turn-indicator--waiting{border:1px solid var(--border-subtle);background:#ffffff08}@keyframes glowPulse{0%,to{box-shadow:0 0 10px #ffd74033}50%{box-shadow:0 0 30px #ffd74066}}.turn-text{font-family:var(--font-display);color:var(--accent-yellow);font-size:1.2rem}.turn-text--waiting{color:var(--text-secondary);font-size:1rem}.speak-box{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#ffffff08;margin-bottom:20px;padding:20px}.desc-log{margin-bottom:20px}.desc-item{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#ffffff08;align-items:flex-start;gap:12px;margin-bottom:6px;padding:10px 14px;display:flex}.desc-player{color:var(--crewmate-blue);white-space:nowrap;font-size:.9rem;font-weight:700}.desc-text{color:var(--text-primary);font-size:.9rem;font-style:italic}.vote-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:16px;display:grid}.vote-card{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);cursor:pointer;font-family:var(--font-body);color:var(--text-primary);background:#ffffff0d;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;font-size:.9rem;font-weight:600;transition:all .25s;display:flex}.vote-card:hover:not(.vote-card--disabled){background:#ff17441a;border-color:#ff174466;transform:translateY(-3px);box-shadow:0 8px 25px #ff174433}.vote-card--disabled{opacity:.4;cursor:not-allowed}.vote-card--voted{border-color:var(--impostor-red);background:#ff174426;box-shadow:0 0 20px #ff174433}.overlay{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000d9;justify-content:center;align-items:center;animation:.3s overlayIn;display:flex;position:fixed;inset:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.overlay-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-subtle);width:90%;max-width:450px;box-shadow:var(--shadow-card);text-align:center;padding:40px;animation:.5s cubic-bezier(.16,1,.3,1) overlayCardIn}@keyframes overlayCardIn{0%{opacity:0;transform:scale(.8)translateY(30px)}to{opacity:1;transform:scale(1)translateY(0)}}.end-screen{text-align:center}.end-title{font-family:var(--font-display);margin-bottom:12px;font-size:2.2rem}.end-title--win{color:var(--crewmate-blue)}.end-title--lose{color:var(--impostor-red)}.end-impostor-reveal{border-radius:var(--radius-sm);margin:20px 0;padding:24px;animation:.6s revealPulse}@keyframes revealPulse{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.end-impostor-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:.8rem}.end-impostor-name{font-family:var(--font-display);color:var(--impostor-red);font-size:2rem}.end-word{color:var(--text-secondary);margin-top:16px;font-size:.9rem}.end-word strong{color:var(--accent-green);font-family:var(--font-display)}.impostor-reveal-anim{z-index:200;background:#0b0e1a;flex-direction:column;justify-content:center;align-items:center;animation:3s forwards flashRed;display:flex;position:fixed;inset:0}@keyframes flashRed{0%{background:#0b0e1a}10%{background:#1a0005}20%{background:#0b0e1a}30%{background:#2a0008}40%{background:#0b0e1a}50%{background:#1a0005}to{background:#0b0e1af2}}.impostor-reveal-text{font-family:var(--font-display);color:var(--impostor-red);text-shadow:0 0 40px var(--impostor-glow), 0 0 80px #ff17444d;font-size:3rem;animation:1s .5s both revealText}.crewmate-reveal-text{font-family:var(--font-display);color:var(--crewmate-blue);text-shadow:0 0 40px var(--crewmate-glow);font-size:3rem;animation:1s .5s both revealText}@keyframes revealText{0%{opacity:0;letter-spacing:20px;transform:scale(2)}to{opacity:1;letter-spacing:2px;transform:scale(1)}}.reveal-subtitle{color:var(--text-secondary);margin-top:16px;font-size:1.1rem;animation:.8s 1.2s both revealText}.waiting-dots:after{content:"";animation:1.5s infinite dots}@keyframes dots{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}.among-char{border-radius:30px 30px 5px 5px;width:60px;height:75px;margin:0 auto 20px;position:relative}.among-char--red{background:var(--impostor-red)}.among-char--blue{background:var(--crewmate-blue)}.among-char-visor{background:#c5e8f7;border:2px solid #0003;border-radius:10px;width:30px;height:18px;position:absolute;top:15px;right:-5px}.among-char-backpack{border-radius:8px 0 0 8px;width:15px;height:25px;position:absolute;top:25px;left:-12px}.among-char-backpack--red{background:#c13}.among-char-backpack--blue{background:#08c}.among-char-leg-l,.among-char-leg-r{border-radius:0 0 8px 8px;width:22px;height:15px;position:absolute;bottom:-10px}.among-char-leg-l{left:5px}.among-char-leg-r{right:5px}.among-char-leg-l--red,.among-char-leg-r--red{background:var(--impostor-red)}.among-char-leg-l--blue,.among-char-leg-r--blue{background:var(--crewmate-blue)}.float{animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (width<=600px){.card{margin:10px;padding:24px}.title{font-size:1.8rem}.room-code-value{letter-spacing:4px;font-size:1.8rem}.role-title{font-size:1.4rem}.vote-grid{grid-template-columns:repeat(2,1fr)}.end-title{font-size:1.6rem}.impostor-reveal-text,.crewmate-reveal-text{font-size:2rem}}.btn-row{gap:10px;margin-top:16px;display:flex}.btn-row .btn{flex:1}.info-text{color:var(--text-muted);text-align:center;margin-top:12px;font-size:.85rem}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--crewmate-blue);border-radius:50%;width:24px;height:24px;margin:0 auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.vote-progress{text-align:center;margin-top:16px}.vote-progress-bar{background:#ffffff14;border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.vote-progress-fill{background:linear-gradient(90deg, var(--crewmate-blue), var(--accent-green));border-radius:3px;height:100%;transition:width .5s}.vote-progress-text{color:var(--text-muted);font-size:.8rem}
