:root{--step--2: clamp(.64rem, .58rem + .29vw, .8rem);--step--1: clamp(.8rem, .73rem + .36vw, 1rem);--step-0: clamp(1rem, .91rem + .45vw, 1.25rem);--step-1: clamp(1.25rem, 1.14rem + .56vw, 1.563rem);--step-2: clamp(1.563rem, 1.42rem + .7vw, 1.953rem);--step-3: clamp(1.953rem, 1.78rem + .87vw, 2.441rem);--step-4: clamp(2.441rem, 2.22rem + 1.09vw, 3.052rem);--step-5: clamp(3.052rem, 2.78rem + 1.36vw, 3.815rem)}:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem}:focus-visible{outline:3px solid var(--accent-primary);outline-offset:2px}.focus-ring:focus-visible{outline:3px solid var(--accent-primary);outline-offset:2px;box-shadow:0 0 0 6px #d4b82e33}.focus-ring-inset:focus-visible{outline:none;box-shadow:inset 0 0 0 3px var(--accent-primary),0 0 0 3px #d4b82e4d}@media (prefers-contrast: more){:focus-visible{outline:3px solid #fff;outline-offset:2px;box-shadow:0 0 0 5px #000}}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img,picture,video,canvas,svg{display:block;max-width:100%}button{background:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only-focusable:focus,.sr-only-focusable:focus-within{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}:root{--font-heading: "Space Grotesk", system-ui, sans-serif;--font-body: "Outfit", system-ui, sans-serif;--bg-primary: #0f1419;--bg-secondary: #1a2634;--bg-surface: #21262d;--bg-elevated: #24303d;--text-primary: #f8fafc;--text-secondary: #c9d1d9;--text-muted: #8b949e;--accent-primary: #d4b82e;--accent-primary-light: #e8d44d;--accent-primary-dark: #c9a820;--accent-primary-muted: #b8941a;--accent-hover: #c9a820;--accent-secondary: #00bcd4;--accent-secondary-light: #4dd0e1;--accent-secondary-dark: #00acc1;--color-success: #3fb950;--color-success-bg: rgba(63, 185, 80, .15);--color-success-border: rgba(63, 185, 80, .3);--color-warning: #f5c518;--color-warning-bg: rgba(245, 197, 24, .15);--color-warning-border: rgba(245, 197, 24, .3);--color-error: #f85149;--color-error-bg: rgba(248, 81, 73, .15);--color-error-border: rgba(248, 81, 73, .3);--color-info: #58a6ff;--color-info-bg: rgba(88, 166, 255, .15);--color-info-border: rgba(88, 166, 255, .3);--glass-bg: rgba(30, 41, 59, .7);--glass-border: rgba(255, 255, 255, .1);--border-color: #30363d;--gradient-gold: linear-gradient(135deg, #e8d44d 0%, #d4b82e 50%, #c9a820 100%);--gradient-gold-hover: linear-gradient(135deg, #f0dc55 0%, #e8d44d 50%, #d4b82e 100%);--gradient-gold-glow: 0 0 30px rgba(212, 184, 46, .4);--gradient-night-sky: linear-gradient(180deg, #0f1419 0%, #1a2634 40%, #24303d 70%, #1a2634 100%);--transition-speed: .3s;--transition-fast: .15s;--transition-slow: .5s;--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--stagger-delay: 80ms;--lobby-col-name: 140px;--lobby-col-game: 80px;--lobby-col-players: 60px;--lobby-col-status: 90px;--lobby-col-type: 70px;--lobby-col-created: 70px;--lobby-col-gap: 12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;height:100vh;width:100vw}button{cursor:pointer;border:none;font-family:inherit;font-weight:600;transition:all var(--transition-speed) ease}input{font-family:inherit;outline:none;border:1px solid var(--glass-border);background:var(--bg-secondary);color:var(--text-primary);padding:.5rem 1rem;border-radius:.5rem;transition:border-color var(--transition-speed)}input:focus{border-color:var(--accent-primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;letter-spacing:-.025em}@keyframes stagger-fade-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes stagger-slide-in{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes stagger-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-content-in{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes button-press{0%{transform:scale(1)}50%{transform:scale(.96)}to{transform:scale(1)}}@keyframes star-twinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.8;transform:scale(1.15)}}@keyframes moon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.stagger-item{opacity:0;animation:stagger-fade-in .4s var(--ease-smooth) forwards;animation-delay:calc(var(--stagger-index, 0) * var(--stagger-delay))}.stagger-slide-item{opacity:0;animation:stagger-slide-in .4s var(--ease-smooth) forwards;animation-delay:calc(var(--stagger-index, 0) * var(--stagger-delay))}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.stagger-item,.stagger-slide-item{animation:none;opacity:1}}._badge_v61j8_4{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body);font-weight:500;white-space:nowrap;vertical-align:middle}._pill_v61j8_15{border-radius:9999px}._xs_v61j8_21{padding:.125rem .375rem;font-size:.7rem;line-height:1.2}._sm_v61j8_27{padding:.2rem .5rem;font-size:.75rem;line-height:1.3}._md_v61j8_33{padding:.25rem .75rem;font-size:.85rem;line-height:1.4}._default_v61j8_41{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-color)}._success_v61j8_47{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}._warning_v61j8_53{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}._error_v61j8_59{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error-border)}._info_v61j8_65{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}._gold_v61j8_71{background:linear-gradient(135deg,#d4b82e33,#c8a82026);color:var(--accent-primary);border:1px solid rgba(212,184,46,.4)}._purple_v61j8_77{background:linear-gradient(135deg,#9b59b633,#8e44ad26);color:#9b59b6;border:1px solid rgba(155,89,182,.4)}._glow_v61j8_85._success_v61j8_47{box-shadow:0 0 8px #3fb95066}._glow_v61j8_85._warning_v61j8_53{box-shadow:0 0 8px #f5c51866}._glow_v61j8_85._error_v61j8_59{box-shadow:0 0 8px #f8514966}._glow_v61j8_85._info_v61j8_65{box-shadow:0 0 8px #58a6ff66}._glow_v61j8_85._gold_v61j8_71{box-shadow:0 0 12px #d4b82e80}._glow_v61j8_85._purple_v61j8_77{box-shadow:0 0 12px #9b59b680}@keyframes _badge-pulse_v61j8_1{0%,to{opacity:1}50%{opacity:.7}}._badge_v61j8_4[data-pulsing=true]{animation:_badge-pulse_v61j8_1 1.5s ease-in-out infinite}@media (prefers-reduced-motion: reduce){._badge_v61j8_4[data-pulsing=true]{animation:none}}._button_uzagh_4{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-heading);font-weight:600;border-radius:10px;cursor:pointer;transition:all var(--transition-speed) ease;border:none;position:relative;white-space:nowrap}._button_uzagh_4:disabled{opacity:.5;cursor:not-allowed}._primary_uzagh_27{background:var(--gradient-gold);color:var(--bg-primary);box-shadow:0 4px 16px #d4b82e66}._primary_uzagh_27:hover:not(:disabled){background:var(--gradient-gold-hover);transform:translateY(-2px);box-shadow:0 6px 24px #d4b82e80}._primary_uzagh_27:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #d4b82e66}._secondary_uzagh_45{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-primary)}._secondary_uzagh_45:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--accent-primary)}._ghost_uzagh_58{background:transparent;border:1px solid transparent;color:var(--text-secondary)}._ghost_uzagh_58:hover:not(:disabled){background:#ffffff0d;color:var(--text-primary)}._danger_uzagh_70{background:var(--color-error);color:#fff}._danger_uzagh_70:hover:not(:disabled){background:#e53935;transform:translateY(-2px)}._sm_uzagh_82{padding:.45rem .85rem;font-size:.85rem}._md_uzagh_87{padding:.7rem 1.5rem;font-size:.95rem}._lg_uzagh_92{padding:.9rem 2rem;font-size:1.1rem}._fullWidth_uzagh_99{width:100%}._loading_uzagh_105{position:relative;pointer-events:none}._spinner_uzagh_110{position:absolute;width:1em;height:1em;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:_spin_uzagh_110 .6s linear infinite}._contentHidden_uzagh_120{visibility:hidden}@keyframes _spin_uzagh_110{to{transform:rotate(360deg)}}._button_uzagh_4:focus-visible{outline:3px solid var(--accent-primary);outline-offset:2px}._primary_uzagh_27:focus-visible{box-shadow:0 4px 16px #d4b82e66,0 0 0 6px #d4b82e33}@media (prefers-reduced-motion: reduce){._button_uzagh_4{transition:none}._button_uzagh_4:hover:not(:disabled){transform:none}._spinner_uzagh_110{animation:none;border-top-color:currentColor;border-right-color:currentColor}}._backdrop_1yb7c_4{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:_backdrop-in_1yb7c_1 .2s ease-out}@keyframes _backdrop-in_1yb7c_1{0%{opacity:0}to{opacity:1}}._modal_1yb7c_27{background:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d;max-height:calc(100vh - 2rem);overflow-y:auto;animation:_modal-in_1yb7c_1 .3s var(--ease-bounce)}._modal_1yb7c_27:focus{outline:none}@keyframes _modal-in_1yb7c_1{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}._sm_1yb7c_56{width:100%;max-width:400px}._md_1yb7c_61{width:100%;max-width:540px}._lg_1yb7c_66{width:100%;max-width:720px}._full_1yb7c_71{width:calc(100% - 2rem);max-width:1200px;max-height:calc(100vh - 4rem)}._danger_1yb7c_83{border-color:var(--color-error-border);box-shadow:0 25px 50px -12px #f8514933,0 0 0 1px #f851491a}._danger_1yb7c_83 ._header_1yb7c_90{background:var(--color-error-bg);border-bottom-color:var(--color-error-border)}._werewolf_1yb7c_95{border-color:#9b59b64d;background:linear-gradient(180deg,var(--bg-secondary) 0%,rgba(75,25,75,.3) 100%);box-shadow:0 25px 50px -12px #9b59b64d,0 0 0 1px #9b59b61a}._header_1yb7c_90{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-surface);border-radius:16px 16px 0 0}._title_1yb7c_119{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}._closeButton_1yb7c_127{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:all .15s ease}._closeButton_1yb7c_127:hover{background:#ffffff1a;color:var(--text-primary)}._closeButton_1yb7c_127:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}._body_1yb7c_157{padding:1.25rem}._footer_1yb7c_161{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color);background:var(--bg-surface);border-radius:0 0 16px 16px}@media (max-width: 480px){._backdrop_1yb7c_4{padding:.5rem;align-items:flex-end}._modal_1yb7c_27{border-radius:16px 16px 0 0;max-height:90vh}._sm_1yb7c_56,._md_1yb7c_61,._lg_1yb7c_66{max-width:100%}}@media (prefers-reduced-motion: reduce){._backdrop_1yb7c_4,._modal_1yb7c_27{animation:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes star-twinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}@keyframes moon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.toggle-switch{position:relative;width:48px!important;min-width:48px!important;height:26px!important;background:#30363de6!important;border:2px solid rgba(139,148,158,.5)!important;border-radius:13px!important;cursor:pointer;transition:all .3s ease;padding:0;flex-shrink:0}.toggle-switch:hover:not(:disabled){border-color:var(--accent-gold, #d4b82e)!important;background:#30363d!important}.toggle-switch.private{background:#d4b82e40!important;border-color:var(--accent-gold, #d4b82e)!important}.toggle-slider{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#c9d1d9!important;border-radius:50%;transition:all .3s ease;box-shadow:0 2px 4px #0006}.toggle-switch.private .toggle-slider{transform:translate(22px);background:var(--accent-gold, #d4b82e)!important;box-shadow:0 2px 8px #d4b82e99}.lobby-container{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;position:fixed;top:0;left:0;overflow:hidden;background:var(--gradient-night-sky, var(--bg-dark))}.game-stars{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0;pointer-events:none}.game-star{position:absolute;background:var(--accent-gold, #d4b82e);border-radius:50%;animation:star-twinkle ease-in-out infinite;box-shadow:0 0 4px 1px #d4a85540}.game-moon{position:fixed;top:12px;right:60px;width:28px;height:28px;z-index:1;pointer-events:none;animation:moon-float 10s ease-in-out infinite}.game-moon-surface{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:linear-gradient(135deg,#e8d44d,#d4b82e,#c9a820);box-shadow:inset -3px -3px 6px #00000026,0 0 12px #d4b82e59}.game-moon-glow{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;background:radial-gradient(circle,rgba(212,180,80,.2) 0%,rgba(212,180,80,.05) 50%,transparent 70%)}.game-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--bg-panel);border-bottom:1px solid var(--border-color);z-index:10;position:relative}.timer-section{display:flex;align-items:center}.timer-ring-container{position:relative;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.timer-ring{position:absolute;width:100%;height:100%;filter:drop-shadow(0 0 6px rgba(212,184,46,.4));transition:filter .3s ease}.timer-ring-bg{stroke:#d4b82e33}.timer-ring-progress{stroke:var(--accent-gold);transition:stroke .3s ease,stroke-dashoffset .15s linear}.timer-text{position:relative;z-index:1;font-size:1.1rem;font-weight:800;font-family:var(--font-heading, "Space Grotesk"),sans-serif;color:var(--accent-gold-light);text-shadow:0 0 8px rgba(212,184,46,.5)}.timer-ring-container.timer-warning .timer-ring{filter:drop-shadow(0 0 10px rgba(245,197,24,.6))}.timer-ring-container.timer-warning .timer-ring-progress{stroke:var(--color-warning)}.timer-ring-container.timer-warning .timer-text{color:var(--color-warning);text-shadow:0 0 10px rgba(245,197,24,.6);animation:timer-pulse-text .8s ease-in-out infinite}.timer-ring-container.timer-critical .timer-ring{filter:drop-shadow(0 0 14px rgba(248,81,73,.7));animation:timer-glow-critical .5s ease-in-out infinite}.timer-ring-container.timer-critical .timer-ring-progress{stroke:var(--color-error)}.timer-ring-container.timer-critical .timer-text{color:var(--color-error);text-shadow:0 0 12px rgba(248,81,73,.7);animation:timer-pulse-text .4s ease-in-out infinite}@keyframes timer-pulse-text{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.9}}@keyframes timer-glow-critical{0%,to{filter:drop-shadow(0 0 14px rgba(248,81,73,.7))}50%{filter:drop-shadow(0 0 20px rgba(248,81,73,.9))}}.timer-ended-badge{padding:.35rem .75rem;border-radius:16px;font-size:.75rem;font-weight:700;font-family:var(--font-heading, "Space Grotesk"),sans-serif;background:linear-gradient(135deg,#f8514933,#f851491a);color:var(--color-error);border:1px solid rgba(248,81,73,.4);animation:timer-ended-appear .3s ease}@keyframes timer-ended-appear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lobby-id{position:absolute;left:50%;transform:translate(-50%);font-size:1.2rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text-primary)}.game-status{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--accent-green);background:#3fb95026;padding:.25rem .75rem;border-radius:12px;border:1px solid rgba(63,185,80,.3)}.game-area{flex:1;display:flex;min-height:0;padding:.5rem;gap:.5rem}.player-list-section{display:none;width:200px;background:var(--bg-panel);border-radius:12px;border:1px solid var(--border-color);padding:.5rem;overflow-y:auto;flex-direction:column;gap:.5rem}.player-card{display:flex;align-items:center;background:var(--bg-surface);padding:.6rem .5rem;border-radius:10px;gap:.5rem;border:1px solid transparent;transition:all .2s ease;position:relative}.player-card:hover{background:var(--bg-elevated, #24303d)}.player-card .rank{font-weight:800;font-family:var(--font-heading, "Space Grotesk"),sans-serif;font-size:.85rem;min-width:28px;text-align:center;color:var(--text-muted)}.player-card:nth-child(1) .rank{color:gold;text-shadow:0 0 8px rgba(255,215,0,.5)}.player-card:nth-child(2) .rank{color:silver;text-shadow:0 0 6px rgba(192,192,192,.4)}.player-card:nth-child(3) .rank{color:#cd7f32;text-shadow:0 0 6px rgba(205,127,50,.4)}.player-card .avatar{font-size:1.2rem}.player-info{display:flex;flex-direction:column;flex:1;min-width:0}.player-info .name{font-weight:600;color:var(--text-primary);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-info .score{font-size:.7rem;color:var(--text-muted);font-weight:500}.canvas-section{flex:1;position:relative;background:#fff;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 1px var(--border-color),0 8px 24px #0006}.drawing-canvas{background:#f8fafc;cursor:crosshair;touch-action:none;box-shadow:0 0 0 1px #0000001a}.floating-chat{position:absolute;top:.5rem;right:.5rem;width:45%;max-width:220px;max-height:50%;display:flex;flex-direction:column;gap:.35rem;pointer-events:auto;z-index:5;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent;transition:opacity .3s ease;opacity:1}.floating-chat.faded{opacity:.25;pointer-events:none}.floating-chat:hover{opacity:1;pointer-events:auto}.floating-chat::-webkit-scrollbar{width:4px}.floating-chat::-webkit-scrollbar-track{background:transparent}.floating-chat::-webkit-scrollbar-thumb{background-color:#0003;border-radius:2px}.chat-bubble{background:linear-gradient(135deg,#1a2634eb,#161b22e0);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:.5rem .7rem;border-radius:12px 4px 12px 12px;box-shadow:0 2px 8px #0000004d,0 0 12px #d4b82e14,inset 0 1px #ffffff0d;animation:chatSlideIn .35s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:.15rem;border:1px solid rgba(255,255,255,.08);border-left:2px solid rgba(212,184,46,.4)}.chat-bubble.correct-guess{background:linear-gradient(135deg,#3fb95040,#1a2634e6);border-color:#3fb95066;border-left:3px solid var(--color-success);box-shadow:0 2px 8px #0000004d,0 0 16px #3fb95033,inset 0 1px #3fb9501a}.chat-bubble.correct-guess .bubble-sender{color:var(--color-success);text-shadow:0 0 8px rgba(63,185,80,.5)}.chat-bubble.correct-guess .bubble-text{color:#b8f0c8}.chat-bubble.system-message{background:linear-gradient(135deg,#d4b82e26,#1a2634e6);border-left-color:var(--accent-gold);font-style:italic}.chat-bubble.system-message .bubble-sender{display:none}.chat-bubble.system-message .bubble-text{color:var(--accent-gold-light);font-size:.75rem}@keyframes chatSlideIn{0%{opacity:0;transform:translate(20px) scale(.95)}50%{transform:translate(-3px) scale(1.01)}to{opacity:1;transform:translate(0) scale(1)}}.bubble-sender{font-size:.65rem;font-weight:700;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.5px}.bubble-text{font-size:.8rem;color:var(--text-primary);word-break:break-word;line-height:1.4}.bottom-bar{background:var(--bg-panel);border-top:1px solid var(--border-color);padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.toolbar{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:wrap}.color-picker{display:flex;gap:.4rem;padding:.4rem .6rem;background:#21262d99;border-radius:24px;border:1px solid var(--border-color);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.color-swatch{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2px solid transparent;position:relative;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.color-swatch:before{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:50%;background:inherit;opacity:0;filter:blur(4px);transition:opacity .15s ease}.color-swatch:hover{transform:scale(1.15);border-color:#ffffff4d}.color-swatch:hover:before{opacity:.5}.color-swatch.selected{transform:scale(1.2);border-color:var(--accent-gold);box-shadow:0 0 0 2px var(--bg-surface),0 0 0 4px var(--accent-gold),0 0 12px #d4b82e80}.color-swatch.selected:before{opacity:.7}.tool-btn{background:var(--bg-surface);border:1px solid var(--border-color);min-width:40px;height:40px;padding:0 .75rem;border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;white-space:nowrap}.tool-btn:hover{background:var(--bg-elevated, #24303d);border-color:var(--accent-gold);color:var(--text-primary);box-shadow:0 0 8px #d4b82e33}.tool-btn.active{border-color:var(--accent-gold);background:linear-gradient(135deg,#d4b82e33,#d4b82e1a);color:var(--accent-gold-light);box-shadow:0 0 12px #d4b82e40,inset 0 1px #ffffff0d}.tool-btn:disabled,.tool-btn.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(30%)}.tool-btn:disabled:hover,.tool-btn.disabled:hover{background:var(--bg-surface);border-color:var(--border-color);box-shadow:none}.chat-input-area{display:flex;gap:.5rem}.chat-input-area input{flex:1;padding:.75rem 1rem;border-radius:24px;border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-primary);font-size:1rem;outline:none;transition:border-color .2s ease}.chat-input-area input::placeholder{color:var(--text-muted)}.chat-input-area input:focus{border-color:var(--accent-gold)}.send-btn{width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent-gold-light),var(--accent-gold));color:#1a2634;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 4px 12px #d4b82e59}.send-btn:hover{background:linear-gradient(135deg,#f0dc55,var(--accent-gold-light));transform:scale(1.05);box-shadow:0 6px 16px #d4b82e73}.send-btn:active{transform:scale(.98)}@media (min-width: 768px){.player-list-section{display:flex}.floating-chat{max-width:280px}.chat-bubble{padding:.5rem .75rem}.bubble-text{font-size:.85rem}.bottom-bar{flex-direction:row;justify-content:space-between;padding:.75rem 1rem}.toolbar{flex:0 0 auto}.chat-input-area{flex:1;max-width:400px}.color-swatch{width:36px;height:36px}}@media (min-width: 1200px){.game-area{padding:1rem;gap:1rem}.player-list-section{width:250px}.floating-chat{max-width:320px;top:1rem;right:1rem;bottom:1rem}}@keyframes modalBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes modalContentIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.word-selection-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:modalBackdropIn .25s var(--ease-smooth, ease)}.word-selection-content{background:linear-gradient(180deg,var(--bg-panel) 0%,rgba(26,38,52,.95) 100%);border:1px solid rgba(212,184,46,.2);border-radius:20px;padding:2rem 2.5rem;text-align:center;animation:modalContentIn .35s var(--ease-bounce, cubic-bezier(.34, 1.56, .64, 1));box-shadow:0 20px 50px #0006,0 0 30px #d4b82e26}.word-selection-content h3{margin:0 0 1.5rem;color:var(--text-primary);font-size:1.3rem;font-family:var(--font-heading, "Space Grotesk"),sans-serif}.word-options{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.word-option-btn{padding:1rem 2rem;font-size:1.1rem;font-weight:600;font-family:var(--font-heading, "Space Grotesk"),sans-serif;border:2px solid var(--border-color);border-radius:12px;background:var(--bg-surface);color:var(--text-primary);cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.word-option-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(212,184,46,.15),transparent);opacity:0;transition:opacity .2s ease}.word-option-btn:hover{border-color:var(--accent-gold);background:var(--bg-surface);transform:translateY(-3px);box-shadow:0 8px 20px #d4b82e40}.word-option-btn:hover:before{opacity:1}.word-option-btn:active{transform:translateY(-1px)}.scoreboard-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.scoreboard-content{background:linear-gradient(180deg,var(--bg-panel),var(--bg-primary));border:1px solid var(--border-color);border-top:3px solid var(--accent-gold);border-radius:16px;padding:2rem;min-width:400px;max-width:90vw;max-height:80vh;overflow-y:auto;animation:modalScaleIn .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 40px #d4b82e26,0 20px 60px #00000080}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.scoreboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(212,184,46,.3)}.scoreboard-header h2{margin:0;color:var(--accent-gold-light);font-size:1.5rem;font-family:var(--font-heading, "Space Grotesk"),sans-serif;text-shadow:0 0 20px rgba(212,184,46,.3)}.close-scoreboard-btn{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.close-scoreboard-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.scoreboard-list{display:flex;flex-direction:column;gap:.75rem}.scoreboard-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:12px;transition:all .2s ease;position:relative;overflow:hidden}.scoreboard-row:nth-child(1){background:linear-gradient(135deg,rgba(255,215,0,.15),var(--bg-surface));border-color:#ffd70066}.scoreboard-row:nth-child(1) .scoreboard-rank{color:gold;text-shadow:0 0 10px rgba(255,215,0,.6)}.scoreboard-row:nth-child(2){background:linear-gradient(135deg,rgba(192,192,192,.12),var(--bg-surface));border-color:#c0c0c04d}.scoreboard-row:nth-child(2) .scoreboard-rank{color:silver;text-shadow:0 0 8px rgba(192,192,192,.5)}.scoreboard-row:nth-child(3){background:linear-gradient(135deg,rgba(205,127,50,.12),var(--bg-surface));border-color:#cd7f324d}.scoreboard-row:nth-child(3) .scoreboard-rank{color:#cd7f32;text-shadow:0 0 8px rgba(205,127,50,.5)}.scoreboard-row.is-you{border-color:var(--accent-gold);background:#d4b82e1a;box-shadow:0 0 15px #d4b82e33}.scoreboard-row.is-you:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-gold)}.scoreboard-rank{font-size:1.5rem;font-weight:800;font-family:var(--font-heading, "Space Grotesk"),sans-serif;min-width:50px;text-align:center;color:var(--text-muted)}.scoreboard-name{flex:1;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.scoreboard-score{font-size:1.2rem;font-weight:800;font-family:var(--font-heading, "Space Grotesk"),sans-serif;color:var(--accent-gold-light);text-shadow:0 0 8px rgba(212,184,46,.3)}.view-scoreboard-btn{padding:.5rem 1rem;font-size:.85rem;font-weight:600;border:1px solid var(--accent-gold);border-radius:8px;background:#d4b82e1a;color:var(--accent-gold-light);cursor:pointer;transition:all .2s ease}.view-scoreboard-btn:hover{background:#d4b82e33;box-shadow:0 0 12px #d4b82e4d}@media (max-width: 768px){.scoreboard-content{min-width:90vw;padding:1.5rem}.scoreboard-header h2{font-size:1.3rem}.scoreboard-rank{font-size:1.2rem;min-width:40px}.scoreboard-name,.scoreboard-score{font-size:1rem}}.size-picker{display:flex;gap:.25rem;align-items:center}.size-option{width:32px;height:32px;border-radius:50%;cursor:pointer;border:2px solid var(--bg-surface);background:var(--bg-surface);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.size-option:hover{border-color:var(--text-muted)}.size-option.selected{border-color:var(--accent-gold);background:#d4b82e26}.size-dot{border-radius:50%;background:var(--text-primary)}.word-display{flex:1;text-align:center;font-size:1.1rem}.word-hint{font-family:Courier New,monospace;font-size:1.5rem;font-weight:700;letter-spacing:2px;color:var(--text-primary)}.word-hint-row{display:flex;justify-content:center;padding:.25rem 1rem;background:var(--bg-panel);border-bottom:1px solid var(--border-color);text-align:center;font-size:1.1rem}.revealed-word{color:var(--accent-green)}.revealed-word strong{font-size:1.2rem}.drawer-selecting{color:var(--accent-teal);font-style:italic}.waiting-text{color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:1rem}.round-info{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--accent-gold-light);background:#d4b82e26;padding:.25rem .75rem;border-radius:12px;border:1px solid rgba(212,184,46,.3)}.settings-panel{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:.75rem 1rem;background:var(--bg-panel);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.settings-readonly{gap:2rem;color:var(--text-muted);font-size:.9rem}.waiting-for-leader{color:var(--accent-teal);font-weight:500}.setting-group{display:flex;align-items:center;gap:.5rem}.setting-group label{font-size:.85rem;color:var(--text-muted);font-weight:500}.setting-options{display:flex;gap:.25rem}.setting-btn{padding:.45rem .85rem;font-size:.85rem;font-weight:600;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-surface);color:var(--text-muted);cursor:pointer;transition:all .2s ease}.setting-btn:hover{border-color:var(--accent-gold);color:var(--text-primary);box-shadow:0 0 8px #d4b82e26}.setting-btn.active{border-color:var(--accent-gold);background:linear-gradient(135deg,#d4b82e40,#d4b82e1f);color:var(--accent-gold-light);box-shadow:0 0 10px #d4b82e33}.start-game-btn{padding:.7rem 1.75rem;font-size:1rem;font-weight:700;border:none;border-radius:10px;background:linear-gradient(135deg,#f0dc55,var(--accent-gold-light),var(--accent-gold));background-size:200% 200%;color:#1a2634;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #d4b82e66,inset 0 1px #ffffff4d;font-family:var(--font-heading, "Space Grotesk"),sans-serif;text-shadow:0 1px 0 rgba(255,255,255,.2);animation:goldShimmer 3s ease-in-out infinite}@keyframes goldShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.start-game-btn:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #d4b82e80,inset 0 1px #fff6}.start-game-btn:active:not(:disabled){transform:translateY(-1px) scale(1)}.start-game-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-surface);box-shadow:none;color:var(--text-muted);animation:none}@media (max-width: 767px){.settings-panel{flex-direction:column;gap:.75rem}.word-options{flex-direction:column}.word-hint{font-size:1.2rem;letter-spacing:2px}}.drawer-badge{margin-left:.3rem;font-size:.9rem;filter:drop-shadow(0 0 4px rgba(212,184,46,.6))}.you-badge{margin-left:.3rem;font-size:.7rem;color:var(--accent-teal);font-weight:500;opacity:.8}.guessed-badge{margin-left:.3rem;color:var(--accent-green);font-weight:700;text-shadow:0 0 6px rgba(63,185,80,.5)}.player-card.is-drawer{border:2px solid var(--accent-gold);background:linear-gradient(135deg,#d4b82e33,#d4b82e14);box-shadow:0 0 12px #d4b82e33}.player-card.is-drawer .name{color:var(--accent-gold-light)}.player-card.has-guessed{border-color:var(--accent-green);background:linear-gradient(135deg,#3fb95026,#3fb9500d)}.player-card.has-guessed:after{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--accent-green);border-radius:50%;box-shadow:0 0 8px #3fb95099}.player-card.has-guessed .score{color:var(--accent-green);font-weight:700}.player-card.is-disconnected{opacity:.5;border-color:var(--text-muted);filter:grayscale(30%)}.player-card.is-disconnected .name{color:var(--text-muted)}.disconnected-badge{margin-left:.3rem;font-size:.65rem;color:var(--text-muted);font-weight:400;font-style:italic}.floating-players{display:flex;position:absolute;top:.5rem;left:.5rem;flex-direction:column;gap:.25rem;z-index:5;pointer-events:auto;transition:opacity .3s ease;opacity:1;max-height:40%;overflow-y:auto;scrollbar-width:thin}.floating-players.faded{opacity:.25;pointer-events:none}.floating-players:hover{opacity:1;pointer-events:auto}.floating-player-card{display:flex;align-items:center;gap:.3rem;background:#161b22d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.3rem .5rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);font-size:.75rem;animation:fadeIn .3s ease}.floating-player-card.is-drawer{border-color:var(--accent-gold);background:#d4b82e4d}.floating-player-card.has-guessed{border-color:var(--accent-green)}.floating-player-card.is-disconnected{opacity:.5}.fp-avatar{font-size:.9rem}.fp-name{color:#fff;font-weight:500;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fp-drawer{font-size:.8rem}.fp-guessed{color:var(--accent-green);font-weight:700}.fp-score{color:var(--text-muted);font-size:.65rem;margin-left:auto}@media (min-width: 768px){.floating-players{display:none}}.queue-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f1419e6;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:modalBackdropIn .3s var(--ease-smooth, ease)}.queue-overlay-content{text-align:center;color:#fff;padding:2.5rem;background:linear-gradient(180deg,#1a2634f2,#0f1419e6);border-radius:20px;border:1px solid rgba(212,184,46,.2);max-width:400px;animation:modalContentIn .4s var(--ease-bounce, cubic-bezier(.34, 1.56, .64, 1));box-shadow:0 20px 50px #0006,0 0 30px #d4b82e1a}.queue-overlay-content h2{margin:1rem 0 .5rem;font-size:1.8rem;font-family:var(--font-heading, "Space Grotesk"),sans-serif;color:var(--accent-gold-light, #e8d44d);text-shadow:0 0 20px rgba(212,184,46,.4)}.queue-overlay-content p{margin:.5rem 0;font-size:1.1rem;color:#ffffffe6}.queue-overlay-content .queue-hint{margin-top:1rem;font-size:.9rem;color:var(--text-muted, rgba(255, 255, 255, .6));font-style:italic}.queue-spinner{width:50px;height:50px;border:4px solid rgba(212,184,46,.2);border-top-color:var(--accent-gold, #d4b82e);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto;box-shadow:0 0 15px #d4b82e4d}@keyframes spin{to{transform:rotate(360deg)}}.queued-badge{font-size:.75rem;color:var(--accent-gold, #d4b82e);margin-left:.25rem;font-style:italic}.player-card.is-queued{opacity:.7;border-left:3px solid var(--accent-gold, #d4b82e)}.floating-player-card.is-queued{opacity:.7}.chat-input-area input:disabled{background:#ffffff0d;cursor:not-allowed;opacity:.6}.chat-input-area .send-btn:disabled{background:#ffffff1a;cursor:not-allowed;opacity:.5}.trivia-sidebar{background:var(--surface);border-radius:12px;padding:1rem;min-width:200px}.trivia-sidebar h2{margin:0 0 1rem;font-size:1rem;color:var(--text-muted)}.trivia-sidebar .players-list{display:flex;flex-direction:column;gap:.5rem}.trivia-sidebar .player-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--surface-light);border-radius:8px;transition:opacity .2s}.trivia-sidebar .player-item.is-disconnected{opacity:.5}.trivia-sidebar .player-item.is-disconnected .player-name{color:var(--text-muted)}.trivia-sidebar .player-name{flex:1;font-weight:500}.trivia-sidebar .leader-badge{font-size:.9rem}.trivia-sidebar .you-badge{font-size:.75rem;color:var(--accent)}.trivia-sidebar .disconnected-badge{font-size:.7rem;color:var(--text-muted)}:root{--wolf-primary: #9b59b6;--wolf-primary-dark: #8e44ad;--wolf-night: #1a0a1e;--wolf-night-mid: #2d1b3d;--wolf-day: #fbbf24;--wolf-day-light: #fef3c7;--wolf-werewolf: #dc2626;--wolf-werewolf-light: #ef4444;--wolf-village: #3b82f6;--wolf-village-light: #60a5fa;--wolf-death: #991b1b;--wolf-hunter: #f59e0b;--wolf-seer: #a855f7;--wolf-doctor: #22c55e}.werewolf-container{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,var(--wolf-night) 0%,var(--wolf-night-mid) 50%,var(--wolf-night) 100%);color:#ecf0f1;position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden}.werewolf-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#0000004d;border-bottom:1px solid rgba(155,89,182,.3);position:relative;z-index:10}.werewolf-main{display:flex;flex:1;overflow:hidden;position:relative;z-index:5}.werewolf-night-bg{background:linear-gradient(180deg,#0a0a12,#0f0f1a 30%,#1a1a2e 70%,#0f0f1a);position:relative}.werewolf-day-bg{background:linear-gradient(180deg,rgba(251,191,36,.15) 0%,transparent 40%,rgba(251,191,36,.08) 100%);position:relative}.werewolf-role-card{display:flex;flex-direction:column;align-items:center;padding:1.5rem;border-radius:16px;border:2px solid;position:relative;overflow:hidden;min-width:200px;max-width:280px;margin:0 auto}.werewolf-role-card.village-team{background:linear-gradient(145deg,#3b82f626,#3b82f60d);border-color:#3b82f666;box-shadow:0 0 20px #3b82f633,inset 0 1px #ffffff1a}.werewolf-role-card.werewolf-team{background:linear-gradient(145deg,#7f1d1d66,#450a0a99);border-color:#ef444480;box-shadow:0 0 30px #ef44444d,inset 0 1px #ffffff0d}.werewolf-role-icon{font-size:3.5rem;margin-bottom:.75rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.werewolf-role-name{font-size:1.5rem;font-weight:700;font-family:Space Grotesk,sans-serif;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.werewolf-team-badge{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:.25rem .75rem;border-radius:12px;margin-bottom:1rem}.werewolf-team-badge.village{background:#3b82f64d;color:#93c5fd;border:1px solid rgba(59,130,246,.5)}.werewolf-team-badge.werewolf{background:#ef44444d;color:#fca5a5;border:1px solid rgba(239,68,68,.5)}.werewolf-player-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;padding:.5rem}.werewolf-player-grid.large{grid-template-columns:repeat(3,1fr)}.werewolf-player-grid.xlarge{grid-template-columns:repeat(4,1fr)}.werewolf-player-card{display:flex;flex-direction:column;align-items:center;padding:.75rem;border-radius:12px;background:#21262dcc;border:2px solid rgba(48,54,61,.8);position:relative;transition:all .2s ease;cursor:default;min-height:80px}.werewolf-player-card.alive{box-shadow:0 0 12px #3b82f626,inset 0 1px #ffffff0d;animation:werewolf-player-glow 3s ease-in-out infinite}.werewolf-player-card.dead{opacity:.5;filter:grayscale(40%);background:#21262d80;border-color:#8b949e4d}.werewolf-player-card.selected{border-color:var(--accent-gold, #d4b82e);box-shadow:0 0 0 3px #d4b82e4d,0 0 20px #d4b82e33;background:#d4b82e1a}.werewolf-player-card.selectable{cursor:pointer}.werewolf-player-card.selectable:hover{border-color:#d4b82e99;background:#d4b82e14;transform:translateY(-2px)}.werewolf-player-card.disconnected{border-color:#f5c51866;opacity:.7}.werewolf-player-name{font-size:.9rem;font-weight:600;color:var(--text-primary, #c9d1d9);text-align:center;margin-bottom:.25rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.werewolf-dead-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;opacity:.6;pointer-events:none}.werewolf-alive-indicator{width:8px;height:8px;border-radius:50%;background:var(--accent-green, #3fb950);box-shadow:0 0 6px #3fb95099}.werewolf-timer{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:12px;background:#8b5cf633;border:1px solid rgba(139,92,246,.4);font-size:1.5rem;font-weight:700;font-family:Space Grotesk,monospace;color:#a78bfa}.werewolf-timer.warning{color:#f59e0b;background:#f59e0b33;border-color:#f59e0b66}.werewolf-timer.critical{color:#dc2626;background:#dc262633;border-color:#dc262666;animation:werewolf-timer-pulse .5s ease-in-out infinite}.werewolf-vote-panel{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:400px;margin:0 auto}.werewolf-vote-candidate{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-radius:10px;border:2px solid rgba(48,54,61,.8);background:#21262dcc;color:var(--text-primary, #c9d1d9);cursor:pointer;transition:all .2s ease;font-size:1rem;font-weight:500}.werewolf-vote-candidate:hover{border-color:#9b59b699;background:#9b59b626;transform:translateY(-1px)}.werewolf-vote-candidate.selected{border-color:#9b59b6;background:#9b59b640;box-shadow:0 0 0 3px #9b59b633,0 0 15px #9b59b633}.werewolf-vote-count{display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 .5rem;border-radius:14px;background:#9b59b64d;color:#d8b4fe;font-size:.85rem;font-weight:700}.werewolf-abstain-btn{display:flex;align-items:center;justify-content:center;padding:.75rem 1rem;border-radius:10px;border:2px dashed rgba(139,148,158,.5);background:transparent;color:var(--text-muted, #8b949e);cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500;margin-top:.5rem}.werewolf-abstain-btn:hover{border-color:#f5c51880;color:#f5c518;background:#f5c5181a}.werewolf-abstain-btn.selected{border-color:#f5c518;border-style:solid;color:#f5c518;background:#f5c51833}.werewolf-game-end-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:2rem 1rem;z-index:1000;overflow:auto;animation:werewolf-fade-in .5s ease-out}.werewolf-game-end-overlay.village{background:linear-gradient(180deg,#3b82f633,#000000f2 30%)}.werewolf-game-end-overlay.werewolf{background:linear-gradient(180deg,#7f1d1d66,#000000f2 30%)}.werewolf-victory-banner{font-size:2.5rem;font-weight:800;font-family:Space Grotesk,sans-serif;text-align:center;margin-bottom:.5rem;animation:werewolf-victory-pulse 2s ease-in-out infinite;text-shadow:0 4px 12px rgba(0,0,0,.5)}.werewolf-victory-banner.village{color:#60a5fa;text-shadow:0 0 40px rgba(59,130,246,.6),0 4px 12px rgba(0,0,0,.5)}.werewolf-victory-banner.werewolf{color:#ef4444;text-shadow:0 0 40px rgba(239,68,68,.6),0 4px 12px rgba(0,0,0,.5)}.werewolf-hunter-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;z-index:1000;animation:werewolf-fade-in .3s ease-out}.werewolf-hunter-content{display:flex;flex-direction:column;align-items:center;padding:2rem;border-radius:16px;background:linear-gradient(145deg,#f59e0b26,#7f1d1d33);border:2px solid rgba(245,158,11,.5);box-shadow:0 0 40px #f59e0b4d,0 0 80px #ef444433;max-width:500px;width:100%}.werewolf-hunter-title{font-size:2rem;font-weight:800;font-family:Space Grotesk,sans-serif;color:#f59e0b;text-shadow:0 0 20px rgba(245,158,11,.5),0 4px 8px rgba(0,0,0,.5);margin-bottom:.5rem;text-align:center;animation:werewolf-hunter-pulse 1.5s ease-in-out infinite}.werewolf-crosshair{font-size:3rem;animation:werewolf-crosshair-target .5s ease-out}@keyframes werewolf-fade-in{0%{opacity:0}to{opacity:1}}@keyframes werewolf-victory-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes werewolf-player-glow{0%,to{box-shadow:0 0 12px #3b82f626,inset 0 1px #ffffff0d}50%{box-shadow:0 0 18px #3b82f640,inset 0 1px #ffffff14}}@keyframes werewolf-timer-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}@keyframes werewolf-hunter-pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes werewolf-crosshair-target{0%{transform:scale(.5) rotate(-90deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes werewolf-star-twinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}@keyframes werewolf-moon-glow{0%,to{box-shadow:0 0 60px #fde04766,0 0 120px #fde04733}50%{box-shadow:0 0 80px #fde04780,0 0 160px #fde0474d}}@keyframes werewolf-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes werewolf-confetti-fall{0%{transform:translateY(-10vh) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}@media (max-width: 768px){.werewolf-player-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.werewolf-role-card{padding:1rem;min-width:160px}.werewolf-role-icon{font-size:2.5rem}.werewolf-role-name{font-size:1.2rem}.werewolf-timer{font-size:1.2rem;padding:.4rem .8rem}.werewolf-header{padding:.75rem 1rem}.werewolf-victory-banner{font-size:1.8rem}.werewolf-hunter-title{font-size:1.5rem}}@media (min-width: 1200px){.werewolf-player-grid{grid-template-columns:repeat(4,1fr);gap:1rem}.werewolf-player-card{padding:1rem;min-height:100px}.werewolf-vote-panel{max-width:500px}}*{box-sizing:border-box}:root{--bg-dark: var(--bg-primary, #0f1419);--bg-panel: var(--bg-secondary, #1a2634);--bg-surface: var(--bg-surface, #21262d);--text-primary: var(--text-secondary, #c9d1d9);--text-muted: var(--text-muted, #8b949e);--accent-gold: var(--accent-primary, #d4b82e);--accent-gold-light: var(--accent-primary-light, #e8d44d);--accent-gold-dark: var(--accent-primary-dark, #c9a820);--accent-teal: var(--accent-secondary, #00bcd4);--accent-green: var(--color-success, #3fb950);--accent-warning: var(--color-warning, #f5c518);--accent-error: var(--color-error, #f85149);--border-color: var(--border-color, #30363d);--accent-purple: var(--accent-gold, #d4b82e);--accent-blue: var(--accent-teal, #00bcd4)}body{background-color:var(--bg-dark);color:var(--text-primary);margin:0;font-family:var(--font-body, "Outfit"),system-ui,sans-serif;overflow:hidden}.theresa-page{--valentine-pink: #ff69b4;--valentine-red: #e91e63;--valentine-light-pink: #ffc1e3;--valentine-dark-red: #c2185b;--valentine-white: #fff5f8;--valentine-gradient: linear-gradient(135deg, var(--valentine-light-pink) 0%, var(--valentine-pink) 50%, var(--valentine-red) 100%)}.theresa-page{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:var(--valentine-gradient);position:relative;overflow:hidden}.theresa-page--accepted{background:linear-gradient(135deg,var(--valentine-pink) 0%,var(--valentine-red) 50%,var(--valentine-dark-red) 100%)}.floating-hearts-container{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.floating-heart{position:absolute;bottom:-60px;width:40px;height:40px;background:var(--valentine-red);transform-origin:center;animation:float-up var(--duration, 8s) ease-in-out infinite;animation-delay:var(--delay, 0s);opacity:.7}.floating-heart:before,.floating-heart:after{content:"";position:absolute;width:40px;height:40px;background:inherit;border-radius:50%}.floating-heart:before{top:-20px;left:0}.floating-heart:after{top:0;left:20px}.floating-heart{background:none}.floating-heart:before{content:"❤️";font-size:40px;position:absolute;top:0;left:0;background:none;border-radius:0}.floating-heart:after{display:none}@keyframes float-up{0%{transform:translateY(0) rotate(0) scale(var(--scale, 1));opacity:.7}25%{transform:translateY(-25vh) rotate(10deg) translate(15px) scale(var(--scale, 1))}50%{transform:translateY(-50vh) rotate(-5deg) translate(-10px) scale(var(--scale, 1))}75%{transform:translateY(-75vh) rotate(15deg) translate(20px) scale(var(--scale, 1));opacity:.5}to{transform:translateY(-110vh) rotate(-10deg) translate(-15px) scale(var(--scale, 1));opacity:0}}.proposal-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;padding:3rem 4rem;text-align:center;box-shadow:0 20px 60px #00000026,0 0 40px #ff69b44d;z-index:1;position:relative;max-width:90vw;animation:card-appear .6s var(--ease-bounce, cubic-bezier(.34, 1.56, .64, 1))}@keyframes card-appear{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.proposal-heading{font-family:Georgia,Times New Roman,serif;font-size:clamp(2.5rem,8vw,4rem);font-weight:400;font-style:italic;color:var(--valentine-dark-red);margin-bottom:.5rem;letter-spacing:.02em}.proposal-question{font-family:var(--font-body, "Outfit", system-ui, sans-serif);font-size:clamp(1.25rem,4vw,1.75rem);color:#4a4a4a;margin-bottom:.5rem;font-weight:400}.proposal-signature{font-family:Georgia,Times New Roman,serif;font-size:clamp(1rem,3vw,1.25rem);color:var(--valentine-pink);font-style:italic;margin-bottom:2rem}.button-container{display:flex;gap:1.5rem;justify-content:center;align-items:center;flex-wrap:wrap;min-height:60px}.theresa-page .yes-button{background:linear-gradient(135deg,var(--valentine-pink) 0%,var(--valentine-red) 100%);border:none;color:#fff;font-weight:600;padding:1rem 3rem;font-size:1.25rem;box-shadow:0 4px 15px #e91e6366;transition:all .3s ease}.theresa-page .yes-button:hover{background:linear-gradient(135deg,var(--valentine-red) 0%,var(--valentine-dark-red) 100%);transform:scale(1.05);box-shadow:0 6px 20px #e91e6380}.theresa-page .yes-button:active{transform:scale(.98)}.theresa-page .no-button{position:relative;padding:1rem 3rem;font-size:1.25rem;will-change:transform;transform-origin:center center}.hint{font-size:.9rem;color:var(--valentine-dark-red);margin-top:1.5rem;font-style:italic;opacity:0;animation:fade-in .5s ease forwards}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:.8;transform:translateY(0)}}.success-message{text-align:center;z-index:1;animation:success-appear .8s var(--ease-bounce, cubic-bezier(.34, 1.56, .64, 1))}.success-message h1{font-family:Georgia,Times New Roman,serif;font-size:clamp(4rem,15vw,8rem);color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.2);margin-bottom:1rem}.success-message p{font-family:var(--font-body, "Outfit", system-ui, sans-serif);font-size:clamp(1.5rem,5vw,2.5rem);color:#fffffff2;text-shadow:0 2px 10px rgba(0,0,0,.15)}@keyframes success-appear{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.floating-heart{animation:none;opacity:.3}.proposal-card{animation:none}.hint{animation:none;opacity:.8}.success-message{animation:none}.theresa-page .yes-button:hover{transform:none}.theresa-page .no-button{transition:transform .3s cubic-bezier(.34,1.56,.64,1);will-change:auto}}@media (max-width: 480px){.proposal-card{padding:2rem 2.5rem;margin:1rem}.button-container{flex-direction:column;gap:1rem}.theresa-page .yes-button,.theresa-page .no-button{width:100%;min-width:200px}}
