.toast-container{position:fixed;z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none;padding:var(--space-4)}.toast-container--top-center{top:0;left:50%;transform:translate(-50%)}.toast-container--top-right{top:0;right:0}.toast-container--top-left{top:0;left:0}.toast-container--bottom-center{bottom:0;left:50%;transform:translate(-50%);flex-direction:column-reverse}.toast-container--bottom-right{bottom:0;right:0;flex-direction:column-reverse}.toast-container--bottom-left{bottom:0;left:0;flex-direction:column-reverse}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface-100);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:280px;max-width:400px;pointer-events:auto;animation:toast-enter .3s cubic-bezier(.34,1.56,.64,1)}.toast--inline{position:static;animation:none}.toast--success{border-color:var(--color-success-500);background:linear-gradient(135deg,var(--color-surface-100) 0%,rgba(16,185,129,.1) 100%)}.toast--error{border-color:var(--color-error-500);background:linear-gradient(135deg,var(--color-surface-100) 0%,rgba(244,63,94,.1) 100%)}.toast--warning{border-color:var(--color-warning-500);background:linear-gradient(135deg,var(--color-surface-100) 0%,rgba(251,191,36,.1) 100%)}.toast--info{border-color:var(--color-info-500);background:linear-gradient(135deg,var(--color-surface-100) 0%,rgba(59,130,246,.1) 100%)}.toast__icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-bold);flex-shrink:0}.toast--success .toast__icon{background:var(--color-success-500);color:#fff}.toast--error .toast__icon{background:var(--color-error-500);color:#fff}.toast--warning .toast__icon{background:var(--color-warning-500);color:var(--color-text-inverse)}.toast--info .toast__icon{background:var(--color-info-500);color:#fff}.toast__message{flex:1;font-size:var(--text-sm);color:var(--color-text-primary);line-height:var(--leading-snug)}.toast__close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-tertiary);font-size:var(--text-lg);line-height:1;cursor:pointer;transition:var(--transition-colors);flex-shrink:0}.toast__close:hover{background:var(--color-surface-200);color:var(--color-text-primary)}@keyframes toast-enter{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-exit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@media(prefers-reduced-motion:reduce){.toast{animation:none}}@media(max-width:640px){.toast-container{left:var(--space-3)!important;right:var(--space-3)!important;transform:none!important;width:auto}.toast{min-width:unset;max-width:unset;width:100%}}.lobby-header{position:fixed;top:32px;left:0;right:0;height:64px;background:linear-gradient(135deg,#0f172a33,#1e293b40,#0f172a33);border-bottom:1px solid rgba(99,102,241,.15);z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);gap:var(--space-4);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 2px 15px #0003,0 1px #ffffff08 inset}.lobby-header-logo{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.logo-icon{font-size:1.75rem;line-height:1}.logo-text{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lobby-header-center{display:flex;align-items:center;gap:var(--space-2);flex:1;max-width:240px;justify-content:center}.lobby-header-center input{height:40px;padding:0 var(--space-3);background:linear-gradient(145deg,#1e293b99,#0f172ab3);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--text-base);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;text-align:center;box-shadow:2px 2px 4px #0003,-1px -1px 3px #ffffff05}.lobby-header-center input:focus{outline:none;border-color:#6366f180;box-shadow:0 0 20px #6366f133,2px 2px 6px #0000004d}.lobby-header-center input::placeholder{color:var(--color-text-muted)}.lobby-header-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.lobby-header .btn{height:40px;white-space:nowrap}@media(max-width:640px){.lobby-header{padding:0 var(--space-3);gap:var(--space-2)}.logo-text{font-size:var(--text-base)}.lobby-header-center{max-width:140px}.lobby-header-center input{font-size:var(--text-sm);padding:0 var(--space-2)}.lobby-secondary-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);min-width:auto}}.lobby-content{min-height:100vh;padding-top:112px;padding-bottom:120px;max-width:1200px;margin:0 auto;padding-left:var(--space-4);padding-right:var(--space-4)}.game-section{display:flex;flex-direction:column;gap:var(--space-5)}.game-section-header{text-align:center;margin-bottom:var(--space-4);padding-top:var(--space-2)}.game-section-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);margin:0;font-weight:var(--font-medium)}.game-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-3);padding:var(--space-4)}.filter-chip{padding:var(--space-2) var(--space-4);background:linear-gradient(145deg,#1e293bcc,#0f172ae6);border:1px solid rgba(99,102,241,.1);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;box-shadow:4px 4px 8px #0003,-2px -2px 6px #ffffff05}.filter-chip:hover{border-color:#6366f14d;color:var(--color-text-primary);box-shadow:6px 6px 12px #0000004d,-2px -2px 6px #ffffff08,0 0 15px #6366f126;transform:translateY(-2px)}.filter-chip.active{background:linear-gradient(145deg,#6366f1e6,#8b5cf6f2);border-color:#6366f166;color:#fff;box-shadow:0 0 20px #6366f166,4px 4px 8px #0003}.search-container{max-width:400px;margin:0 auto;width:100%}.search-input{width:100%;height:52px;padding:0 var(--space-5);background:linear-gradient(145deg,#1e293b99,#0f172ab3);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-full);color:var(--color-text-primary);font-size:var(--text-base);transition:all .3s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:4px 4px 8px #0003,-2px -2px 6px #ffffff05,0 0 0 1px #6366f10d inset}.search-input:focus{outline:none;border-color:#6366f180;box-shadow:0 0 25px #6366f140,4px 4px 12px #0000004d,-2px -2px 8px #ffffff08;transform:translateY(-2px)}.search-input::placeholder{color:var(--color-text-muted)}.game-select{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}@media(max-width:640px){.game-select{grid-template-columns:repeat(2,1fr)}}.game-card{position:relative;background:linear-gradient(145deg,#1e293be6,#0f172af2);border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-xl);padding:var(--space-4);text-align:center;cursor:pointer;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);animation:card-appear .6s ease-out backwards;animation-delay:calc(var(--card-i, 0) * .04s);box-shadow:8px 8px 16px #0000004d,-8px -8px 16px #ffffff05,0 0 0 1px #6366f11a inset;overflow:hidden}.game-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(99,102,241,.1) 0%,transparent 50%,rgba(139,92,246,.05) 100%);opacity:0;transition:opacity .3s ease;border-radius:var(--radius-xl);pointer-events:none}@keyframes card-appear{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.game-card:hover{border-color:#6366f166;box-shadow:12px 12px 24px #0006,-4px -4px 12px #ffffff08,0 0 30px #6366f133;transform:translateY(-6px) scale(1.02)}.game-card.selected{background:linear-gradient(145deg,#6366f1e6,#8b5cf6f2);border-color:#6366f199;box-shadow:0 0 40px #6366f166,0 4px 20px #0000004d,0 0 0 1px #ffffff1a inset;transform:translateY(-4px)}.game-card-icon{font-size:2.5rem;line-height:1;margin-bottom:var(--space-1);transition:transform var(--duration-fast) var(--ease-bounce)}.game-card:hover .game-card-icon{transform:scale(1.1)}.game-card-name{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);line-height:1.3}.game-card.selected .game-card-name{color:#fff}.game-card-badge{font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-surface-200);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.game-card.selected .game-card-badge{background:#fff3;color:#ffffffe6}.game-card-rules{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-200);border:none;border-radius:var(--radius-full);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--font-bold);cursor:pointer;opacity:0;transition:var(--transition-all)}.game-card:hover .game-card-rules{opacity:1}.game-card-rules:hover{background:var(--color-primary-500);color:#fff}.lobby-footer{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#0f172a33,#1e293b40);border-top:1px solid rgba(99,102,241,.15);padding:var(--space-3) var(--space-4);z-index:var(--z-sticky);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);box-shadow:0 -4px 20px #0003,0 -1px #ffffff08 inset}.lobby-footer-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}@media(max-width:768px){.lobby-footer-content{flex-direction:column;gap:var(--space-3)}}.selected-game-info{display:flex;align-items:center;gap:var(--space-3)}.selected-game-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg)}.selected-game-details{display:flex;flex-direction:column;gap:var(--space-1)}.selected-game-name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary)}.selected-game-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.room-settings-expand{display:flex;align-items:center;gap:var(--space-2)}.room-settings-toggle{padding:var(--space-2) var(--space-3);background:var(--color-surface-200);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;transition:var(--transition-colors);display:flex;align-items:center;gap:var(--space-2)}.room-settings-toggle:hover{background:var(--color-surface-300);color:var(--color-text-primary)}.room-settings-panel{position:absolute;bottom:100%;left:0;right:0;background:var(--color-surface-100);border-top:1px solid var(--color-border-subtle);padding:var(--space-4);animation:slide-up .3s ease-out}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.room-settings-panel input{height:44px;padding:0 var(--space-3);background:var(--color-bg-primary);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--text-base);width:100%;margin-bottom:var(--space-3)}.room-settings-panel input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f133}.mafia-footer-settings{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center}.mafia-players-slider{display:flex;align-items:center;gap:var(--space-3)}.mafia-players-slider label{font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap}.mafia-players-slider input[type=range]{width:120px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-surface-300);border-radius:var(--radius-full);outline:none}.mafia-players-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--gradient-primary);border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--shadow-md)}.mafia-ai-option{display:flex;align-items:center;gap:var(--space-2)}.mafia-ai-option label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-primary)}.mafia-ai-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary-500)}.lobby-main-btn{min-width:200px;height:52px;font-size:var(--text-lg);font-weight:var(--font-bold);background:linear-gradient(145deg,#6366f1,#8b5cf6,#6366f1);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 30px #6366f166,0 4px 15px #0000004d,0 0 0 1px #fff3 inset,0 -2px #0003 inset;display:flex;align-items:center;justify-content:center;gap:var(--space-2);position:relative;overflow:hidden}.lobby-main-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.lobby-main-btn:hover:before{left:100%}.lobby-main-btn:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 0 50px #6366f199,0 8px 25px #0006,0 0 0 1px #ffffff4d inset}.lobby-main-btn:active:not(:disabled){transform:translateY(-1px) scale(.98);box-shadow:0 0 20px #6366f14d,0 2px 10px #0000004d}.lobby-main-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.lobby-secondary-btn{min-width:140px;height:44px;background:var(--color-surface-200);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:var(--transition-all)}.lobby-secondary-btn:hover{background:var(--color-surface-300);border-color:var(--color-border-default)}.join-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172acc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.join-modal{width:100%;max-width:400px;background:var(--color-surface-100);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl);padding:var(--space-5);animation:modal-pop .3s ease-out}@keyframes modal-pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.join-modal h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--space-4);text-align:center}.join-modal input{width:100%;height:48px;padding:0 var(--space-3);background:var(--color-bg-primary);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--text-lg);text-align:center;text-transform:uppercase;letter-spacing:2px;margin-bottom:var(--space-3)}.join-modal input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f133}.join-modal-buttons{display:flex;gap:var(--space-3)}.join-modal-buttons .btn{flex:1;height:44px}.rooms-popover{position:absolute;top:100%;right:0;margin-top:var(--space-2);width:280px;max-height:300px;overflow-y:auto;background:var(--color-surface-100);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-3);box-shadow:var(--shadow-xl);z-index:var(--z-popover)}.rooms-popover-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin:0 0 var(--space-2)}.room-item{width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);text-align:left;cursor:pointer;transition:var(--transition-colors);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-item:hover{background:var(--color-surface-200);color:var(--color-text-primary)}.how-it-works{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border-subtle)}@media(max-width:768px){.how-it-works{grid-template-columns:1fr}}.how-step{text-align:center;padding:var(--space-4)}.how-step-num{width:40px;height:40px;margin:0 auto var(--space-3);display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-full);color:#fff;font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold)}.how-step-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.how-step-desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.donation-section{margin-top:var(--space-8);text-align:center;padding:var(--space-6);background:var(--gradient-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl)}.donation-icon{font-size:3rem;margin-bottom:var(--space-3)}.donation-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2)}.donation-text{color:var(--color-text-secondary);margin-bottom:var(--space-4)}.donation-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--gradient-secondary);border-radius:var(--radius-lg);color:#fff;font-weight:var(--font-semibold);text-decoration:none;transition:var(--transition-all);box-shadow:var(--shadow-md)}.donation-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.lobby-page-footer{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border-subtle);text-align:center;padding-bottom:var(--space-6)}.footer-links{display:flex;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap}.footer-links a{color:var(--color-text-muted);font-size:var(--text-sm);text-decoration:none;transition:var(--transition-colors)}.footer-links a:hover{color:var(--color-primary-400)}.lobby-page-footer p{color:var(--color-text-muted);font-size:var(--text-sm);margin:0}.player-count-filter{margin:var(--space-2) 0;padding:var(--space-2) var(--space-3);background:linear-gradient(145deg,#1e293b66,#0f172a80);border-radius:var(--radius-md);border:1px solid rgba(99,102,241,.15);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.filter-label{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);white-space:nowrap}.player-count-presets{display:flex;gap:var(--space-1);flex-wrap:wrap}.player-count-chip{padding:var(--space-1) var(--space-2);background:#1e293b99;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-xs);font-weight:var(--font-medium);cursor:pointer;transition:all .15s ease;min-width:28px;line-height:1}.player-count-chip:hover{background:#6366f133;border-color:#6366f166}.player-count-chip.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:transparent;box-shadow:0 2px 8px #6366f14d}@media(max-width:768px){.lobby-header{height:auto;min-height:56px;padding:var(--space-2) var(--space-3);flex-wrap:wrap;gap:var(--space-2)}.lobby-header-center{flex-direction:column;max-width:none;width:100%;order:3;gap:var(--space-1)}.alone-checkbox{font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.logo-text{font-size:var(--text-base)}.lobby-header-right{gap:var(--space-1)}.lobby-secondary-btn{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);min-width:auto;height:36px}}@media(max-width:480px){.lobby-header{top:28px;padding:var(--space-2)}.logo-icon{font-size:1.25rem}.logo-text{font-size:var(--text-sm)}.lobby-header-center input{height:36px;font-size:var(--text-sm)}}@media(max-width:768px){.lobby-content{padding-top:140px;padding-bottom:100px;padding-left:var(--space-3);padding-right:var(--space-3)}.game-section-subtitle{font-size:var(--text-base)}}@media(max-width:480px){.lobby-content{padding-top:130px;padding-left:var(--space-2);padding-right:var(--space-2)}}@media(max-width:1024px){.game-select{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.game-select{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.game-card{padding:var(--space-3)}.game-card-icon{font-size:2.5rem}.game-card-name{font-size:var(--text-base)}.game-card-badge{font-size:var(--text-xs)}}@media(max-width:480px){.game-select{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.game-card{padding:var(--space-2);min-height:100px}.game-card-icon{font-size:2rem}.game-card-name{font-size:var(--text-sm)}.game-card-rules{width:20px;height:20px;font-size:var(--text-xs)}}@media(max-width:360px){.game-select{grid-template-columns:1fr}}@media(max-width:768px){.game-filters{padding:var(--space-2);gap:var(--space-2)}.filter-chip{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.player-count-filter{padding:var(--space-2);gap:var(--space-2)}.player-count-presets{gap:var(--space-1)}.player-count-chip{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);min-width:24px}}@media(max-width:768px){.lobby-footer{padding:var(--space-2) var(--space-3)}.lobby-footer-content{flex-direction:column;gap:var(--space-2);align-items:stretch}.selected-game-info{justify-content:center}.selected-game-icon{width:40px;height:40px;font-size:1.5rem}.selected-game-name{font-size:var(--text-base)}.selected-game-desc{font-size:var(--text-xs)}.mafia-footer-settings{justify-content:center;gap:var(--space-3)}.room-settings-expand{display:flex;justify-content:center}.lobby-main-btn{min-width:auto;width:100%;height:48px;font-size:var(--text-base)}}@media(max-width:480px){.lobby-footer{padding:var(--space-2)}.mafia-players-slider{flex-direction:column;gap:var(--space-1)}.mafia-players-slider input[type=range]{width:100px}}@media(max-width:768px){.join-modal{margin:var(--space-3);padding:var(--space-4)}.rooms-popover{width:240px;right:-20px}}@media(max-width:480px){.join-modal{padding:var(--space-3)}.join-modal h3{font-size:var(--text-lg)}.join-modal input{height:44px;font-size:var(--text-base)}}@media(max-width:768px){.how-it-works{grid-template-columns:1fr;gap:var(--space-3);margin-top:var(--space-6)}.how-step{padding:var(--space-3)}.how-step-num{width:32px;height:32px;font-size:var(--text-base)}.how-step-title{font-size:var(--text-base)}}@media(max-width:768px){.donation-section{padding:var(--space-4);margin-top:var(--space-6)}.donation-icon{font-size:2rem}.donation-title{font-size:var(--text-lg)}.donation-text{font-size:var(--text-sm)}.donation-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}}@media(pointer:coarse){.game-card:hover{transform:none}.game-card:active{transform:scale(.98)}.filter-chip:hover{transform:none}.filter-chip:active{transform:scale(.95)}.game-card-rules{opacity:1;width:28px;height:28px}}.alone-checkbox{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-xs);color:var(--text-secondary);transition:all .2s ease;white-space:nowrap}.alone-checkbox:hover{background:#6366f133;border-color:#6366f14d}.alone-checkbox input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary-500);cursor:pointer}.alone-checkbox span{font-weight:var(--font-medium)}@supports (padding-top: env(safe-area-inset-top)){.lobby-header{padding-top:max(var(--space-2),env(safe-area-inset-top))}.lobby-footer{padding-bottom:max(var(--space-2),env(safe-area-inset-bottom))}.lobby-content{padding-left:max(var(--space-4),env(safe-area-inset-left));padding-right:max(var(--space-4),env(safe-area-inset-right))}}.mafia-table-container{position:relative;width:100%;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-5)}.mafia-table{position:relative;width:min(90vw,700px);height:min(70vw,500px);border-radius:50%;background:radial-gradient(ellipse 100% 100% at 50% 50%,#1e293be6,#0f172af2 70%),radial-gradient(ellipse 80% 60% at 50% 50%,rgba(99,102,241,.08) 0%,transparent 60%);border:2px solid var(--border-subtle);box-shadow:0 0 60px #00000080,inset 0 0 80px #0000004d}.table-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);pointer-events:none}.phase-indicator{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.1em}.player-seat{position:absolute;width:100px;height:140px;transform-origin:center bottom;transition:all .5s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;align-items:center;cursor:default}.player-seat.targetable{cursor:pointer}.player-seat.targetable:hover{transform:scale(1.08)}.player-avatar{width:64px;height:64px;border-radius:50%;border:3px solid var(--border-color, var(--accent));box-shadow:0 0 20px var(--glow-color, rgba(99, 102, 241, .3)),inset 0 0 20px #0000004d;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--text-primary);transition:all .3s ease}.player-seat.alive .player-avatar{--border-color: var(--accent);--glow-color: rgba(0, 245, 212, .25)}.player-seat.dead .player-avatar{--border-color: #333;--glow-color: transparent;filter:grayscale(100%);opacity:.7}.player-seat.poisoned .player-avatar{--border-color: #9c27b0;--glow-color: rgba(156, 39, 176, .4);animation:poison-pulse 2s infinite}.player-seat.disconnected .player-avatar{--border-color: #666;opacity:.6}.player-seat.targeted .player-avatar{--border-color: var(--error-red);--glow-color: rgba(255, 82, 82, .5);animation:target-pulse 1s infinite}.player-name{margin-top:var(--space-2);font-size:.8rem;font-weight:600;color:var(--text-primary);text-align:center;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-seat.dead .player-name{color:var(--text-muted)}.player-status-badge{font-size:.65rem;margin-top:2px;padding:2px 6px;border-radius:4px;background:#0006}.phase-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;transition:background .8s ease}.phase-overlay.night{background:radial-gradient(circle at 30% 50%,rgba(0,245,212,.05) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(120,80,255,.05) 0%,transparent 50%),transparent;animation:night-breathing 4s ease-in-out infinite}.phase-overlay.day{background:radial-gradient(ellipse at 50% 0%,rgba(255,215,0,.06) 0%,transparent 50%),transparent}.phase-overlay.voting{background:radial-gradient(ellipse at 50% 50%,rgba(255,0,0,.04) 0%,transparent 70%);animation:voting-pulse 10s ease-in-out infinite}.timer-ring{width:80px;height:80px}.timer-ring circle{fill:none;stroke-width:6;stroke-linecap:round}.timer-track{stroke:#ffffff1a}.timer-progress{transform:rotate(-90deg);transform-origin:center;transition:stroke-dashoffset .5s linear,stroke .3s ease}.timer-text{font-family:var(--font-display);font-size:1.5rem;font-weight:700;fill:var(--text-primary)}.timer-ring.urgent .timer-progress{animation:timer-urgent-pulse 1s infinite}.mafia-action-panel{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);min-width:280px;max-width:90vw;padding:var(--space-4);background:#0f172af2;border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100}.mafia-action-panel h4{margin:0 0 var(--space-3);font-size:1rem;color:var(--text-primary)}.mafia-action-panel p{margin:0 0 var(--space-3);font-size:.9rem;color:var(--text-muted)}.mafia-action-panel .btn{margin-top:var(--space-2)}.role-card-3d{perspective:1000px;width:200px;height:300px;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.role-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.175,.885,.32,1.275)}.role-card-3d .role-card-inner.flipped{transform:rotateY(180deg)}.role-card-front,.role-card-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:16px;box-shadow:0 20px 60px #0006;display:flex;flex-direction:column;align-items:center;justify-content:center}.role-card-front{background:linear-gradient(135deg,#1e293b,#0f172a);border:2px solid var(--border-subtle)}.card-pattern{position:absolute;top:8px;right:8px;bottom:8px;left:8px;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.03) 10px,rgba(255,255,255,.03) 20px);border-radius:12px}.card-logo{font-size:4rem;z-index:1}.role-card-back{transform:rotateY(180deg);background:linear-gradient(135deg,var(--role-color, var(--accent)) 0%,#1a1a2e 100%);border:2px solid var(--role-color, var(--accent));padding:var(--space-4)}.role-card-back .role-icon{font-size:3rem;margin-bottom:var(--space-2)}.role-card-back .role-name{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--text-primary);text-align:center}.role-card-back .role-team{font-size:.8rem;color:var(--text-muted);margin-top:var(--space-1)}.role-card-back .role-desc{font-size:.75rem;color:var(--text-muted);margin-top:var(--space-2);text-align:center;max-width:90%}.role-mafia-mates{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid rgba(255,255,255,.2)}.role-mafia-mates-label{font-size:.7rem;font-weight:600;color:var(--text-muted);margin-bottom:4px}.role-mafia-mates-list{font-size:.75rem;color:var(--text-primary);opacity:.9}.holographic-shine{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.1) 45%,rgba(255,255,255,.25) 50%,rgba(255,255,255,.1) 55%,transparent 60%);animation:holographic-shift 3s infinite;pointer-events:none;border-radius:inherit}.role-card-dismiss{margin-top:var(--space-3)}.death-reveal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;pointer-events:none;display:flex;flex-direction:column;align-items:center;justify-content:center}.death-cracks{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(255,0,0,.1) 0%,transparent 50%);opacity:.5;animation:cracks-appear .3s forwards}.death-player-card{position:relative;width:120px;padding:var(--space-4);background:var(--surface);border-radius:var(--radius);border:2px solid var(--error-red);box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;align-items:center;transform-style:preserve-3d;perspective:500px}.death-card-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.death-card-name{margin-top:var(--space-2);font-weight:600;color:var(--text-primary)}.death-role-reveal{position:absolute;bottom:20%;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:#0f172af2;border-radius:var(--radius);border:1px solid var(--border-subtle)}.death-role-label{font-size:.8rem;color:var(--text-muted)}.death-role-value{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.death-cause{font-size:.75rem;color:var(--error-red)}.vote-booth{padding:var(--space-4);background:#0f172af2;border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.vote-booth h3{margin:0 0 var(--space-4);font-size:1rem;color:var(--text-primary);text-align:center}.vote-candidates{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-4)}.vote-candidate{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-3);min-width:80px;background:var(--surface);border:2px solid var(--border-subtle);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;color:var(--text-primary);position:relative}.vote-candidate:hover:not(:disabled){border-color:var(--accent);box-shadow:0 0 20px #6366f14d}.vote-candidate:disabled{cursor:default}.vote-candidate-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700}.vote-candidate-name{font-size:.65rem;text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vote-count{position:absolute;top:-4px;right:-4px;min-width:24px;height:24px;padding:0 6px;background:var(--accent);border-radius:12px;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.vote-results{display:flex;flex-direction:column;gap:var(--space-2)}.vote-bar-container{display:flex;align-items:center;gap:var(--space-3)}.vote-bar{height:8px;min-width:4px;background:var(--accent);border-radius:4px;transition:width .5s ease}.vote-bar-label{font-size:.8rem;color:var(--text-muted);min-width:120px}.mafia-chat-toggle{position:fixed;left:0;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:0 12px 12px 0;background:#0a0a14e6;border:1px solid rgba(255,0,0,.3);color:var(--text-primary);font-size:1.5rem;cursor:pointer;z-index:90;transition:all .2s ease}.mafia-chat-toggle:hover{background:#141428f2;border-color:#ff000080}.mafia-chat{position:fixed;left:0;top:50%;transform:translateY(-50%);width:300px;height:400px;background:#0a0a14f2;border:1px solid rgba(255,0,0,.3);border-radius:0 16px 16px 0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:4px 0 24px #00000080;z-index:95;display:flex;flex-direction:column}.mafia-chat-header{padding:var(--space-3);border-bottom:1px solid rgba(255,0,0,.2);font-weight:600;color:var(--text-primary)}.mafia-chat-messages{flex:1;overflow-y:auto;padding:var(--space-2)}.mafia-message{padding:8px 12px;margin:4px 8px;background:#ff00001a;border-left:2px solid rgba(255,0,0,.5);border-radius:0 8px 8px 0;font-size:.9rem;animation:message-fade-in .3s ease;text-shadow:0 0 4px rgba(255,0,0,.2)}.mafia-message.system{background:#ffffff0d;border-left-color:var(--border-subtle)}.mafia-chat-input{display:flex;gap:var(--space-2);padding:var(--space-3);border-top:1px solid rgba(255,0,0,.2)}.mafia-chat-input input{flex:1;padding:var(--space-2) var(--space-3);background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:.9rem}.mafia-lastwill-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.mafia-lastwill-window{position:relative;width:90%;max-width:400px;padding:var(--space-5);background:var(--surface);border-radius:var(--radius);border:1px solid var(--border-subtle);box-shadow:0 24px 80px #00000080;cursor:default}.mafia-lastwill-window .mafia-lastwill-crack{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(255,0,0,.05) 0%,transparent 60%);border-radius:inherit;pointer-events:none}.mafia-lastwill-window h4{margin:0 0 var(--space-2);font-size:1.2rem;color:var(--text-primary)}.mafia-lastwill-window p{font-size:.9rem;color:var(--text-muted);margin-bottom:var(--space-3)}.mafia-lastwill-window textarea{width:100%;padding:var(--space-3);background:var(--bg-deep);color:var(--text-primary);border:1px solid var(--border-subtle);border-radius:8px;margin-bottom:var(--space-3);resize:vertical;min-height:100px}.mafia-lastwill-window .btn{width:100%}.mafia-role-reveal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:50;pointer-events:auto}.mafia-vote-booth-wrapper{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);z-index:100;max-width:90vw}@media(max-width:768px){.mafia-table-container{padding:var(--space-3);min-height:320px}.mafia-table{width:95vw;height:auto;min-height:280px;border-radius:24px}.player-seat{width:64px;height:90px}.player-avatar{width:44px;height:44px;font-size:1.1rem}.player-name{font-size:.65rem}.mafia-action-panel{bottom:var(--space-4);left:var(--space-4);right:var(--space-4);transform:none;min-width:auto}.mafia-vote-booth-wrapper{bottom:var(--space-4);left:var(--space-4);right:var(--space-4);transform:none}.vote-booth{max-height:50vh;overflow-y:auto}.vote-candidate{min-width:64px;padding:var(--space-2)}.mafia-chat{width:100%;max-width:100%;height:50vh;border-radius:16px 16px 0 0;top:auto;bottom:0;transform:translateY(0)}.mafia-chat-toggle{bottom:80px;top:auto;left:var(--space-4);transform:none}.role-card-3d{width:160px;height:240px}.role-card-back .role-icon{font-size:2.5rem}.role-card-back .role-name{font-size:1rem}.mafia-table-container .holographic-shine{animation-duration:5s;opacity:.5}}@keyframes night-breathing{0%,to{opacity:1}50%{opacity:.85}}@keyframes voting-pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes poison-pulse{0%,to{opacity:1;box-shadow:0 0 20px #9c27b066}50%{opacity:.9;box-shadow:0 0 30px #9c27b099}}@keyframes target-pulse{0%,to{box-shadow:0 0 20px #ff525280}50%{box-shadow:0 0 35px #ff5252cc}}@keyframes timer-urgent-pulse{0%,to{filter:drop-shadow(0 0 10px currentColor)}50%{filter:drop-shadow(0 0 25px currentColor)}}@keyframes holographic-shift{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes card-fall{to{transform:perspective(500px) rotateX(75deg) translateY(200px);opacity:0}}@keyframes cracks-appear{to{opacity:1}}@keyframes message-fade-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.mafia-table-container.rainbow-mode .player-seat.alive .player-avatar{animation:rainbow-glow 3s linear infinite}@keyframes rainbow-glow{0%{box-shadow:0 0 25px #f009}16%{box-shadow:0 0 25px #ff7f0099}33%{box-shadow:0 0 25px #ff09}50%{box-shadow:0 0 25px #0f09}66%{box-shadow:0 0 25px #007fff99}83%{box-shadow:0 0 25px #8b00ff99}to{box-shadow:0 0 25px #f009}}.mafia-table-container.theme-noir .mafia-table{background:radial-gradient(ellipse 100% 100% at 50% 50%,#141419f2,#0a0a0d 70%),radial-gradient(ellipse 80% 60% at 50% 50%,rgba(255,255,255,.03) 0%,transparent 60%);border-color:#ffffff1f;box-shadow:0 0 80px #000000b3,inset 0 0 60px #0006}.mafia-table-container.theme-noir .player-seat.alive .player-avatar{--border-color: rgba(255, 255, 255, .6);--glow-color: rgba(255, 255, 255, .15)}.mafia-table-container.theme-noir .player-seat.targeted .player-avatar{--border-color: #c41e3a;--glow-color: rgba(196, 30, 58, .4)}.mafia-table-container.theme-noir .phase-overlay.night{background:radial-gradient(circle at 30% 50%,rgba(255,255,255,.03) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(255,255,255,.02) 0%,transparent 50%),transparent}.mafia-table-container.theme-noir .phase-overlay.voting{background:radial-gradient(ellipse at 50% 50%,rgba(196,30,58,.06) 0%,transparent 70%)}.mafia-table-container.theme-noir .timer-progress{stroke:#fffc}.mafia-table-container.theme-noir .mafia-action-panel,.mafia-table-container.theme-noir .vote-booth{background:#0a0a0dfa;border-color:#ffffff1a}.mafia-table-container.theme-noir .mafia-chat{background:#0a0a0dfa;border-color:#ffffff26}.mafia-table-container.theme-noir .mafia-message{background:#ffffff0f;border-left-color:#ffffff4d}.mafia-table-container.theme-cyber .mafia-table{background:radial-gradient(ellipse 100% 100% at 50% 50%,#0a1428f2,#050810 70%),radial-gradient(ellipse 80% 60% at 50% 50%,rgba(0,255,255,.06) 0%,transparent 60%);border:2px solid rgba(0,255,255,.3);box-shadow:0 0 80px #00ffff26,inset 0 0 60px #ff00800d}.mafia-table-container.theme-cyber .player-seat.alive .player-avatar{--border-color: #00ffff;--glow-color: rgba(0, 255, 255, .4);box-shadow:0 0 25px #0ff6,inset 0 0 20px #0000004d}.mafia-table-container.theme-cyber .player-seat.targeted .player-avatar{--border-color: #ff00ff;--glow-color: rgba(255, 0, 255, .6);animation:cyber-pulse .8s infinite}.mafia-table-container.theme-cyber .phase-overlay.night{background:radial-gradient(circle at 30% 50%,rgba(0,255,255,.08) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(255,0,128,.06) 0%,transparent 50%),transparent}.mafia-table-container.theme-cyber .phase-overlay.voting{background:radial-gradient(ellipse at 50% 50%,rgba(255,0,128,.1) 0%,transparent 70%)}.mafia-table-container.theme-cyber .timer-progress{stroke:#0ff;filter:drop-shadow(0 0 8px rgba(0,255,255,.8))}.mafia-table-container.theme-cyber .mafia-action-panel,.mafia-table-container.theme-cyber .vote-booth{background:#050a19f2;border:1px solid rgba(0,255,255,.3);box-shadow:0 0 30px #00ffff1a}.mafia-table-container.theme-cyber .mafia-chat{background:#050a19fa;border-color:#ff008066;box-shadow:4px 0 30px #ff00801a}.mafia-table-container.theme-cyber .mafia-message{background:#ff008014;border-left-color:#ff008099}@keyframes cyber-pulse{0%,to{box-shadow:0 0 20px #ff00ff80}50%{box-shadow:0 0 40px #ff00ffe6}}.timer{display:inline-flex;flex-direction:column;align-items:center;gap:var(--space-2)}.timer__ring{position:relative;display:flex;align-items:center;justify-content:center}.timer__svg{transform:rotate(-90deg)}.timer__content{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center}.timer__value{font-family:var(--font-mono);font-weight:var(--font-bold);line-height:1;color:var(--color-text-primary)}.timer__unit{font-family:var(--font-body);font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase}.timer--sm .timer__svg{width:48px;height:48px}.timer--sm .timer__value{font-size:var(--text-xl)}.timer--md .timer__svg{width:64px;height:64px}.timer--md .timer__value{font-size:var(--text-2xl)}.timer--lg .timer__svg{width:80px;height:80px}.timer--lg .timer__value{font-size:var(--text-3xl)}.timer__bar{width:100%;height:4px;background:var(--color-surface-300);border-radius:var(--radius-full);overflow:hidden}.timer__bar-fill{height:100%;border-radius:var(--radius-full);transition:width 1s linear,background-color .3s ease}.timer--urgent .timer__value{color:var(--color-error-500);animation:timer-pulse 1s ease-in-out infinite}.timer--urgent .timer__svg circle:last-child{animation:timer-pulse-stroke 1s ease-in-out infinite}.timer--paused{opacity:.6}.timer--paused .timer__bar-fill{animation:none}.mini-timer{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-secondary);background:var(--color-surface-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);white-space:nowrap}.mini-timer--urgent{color:var(--color-error-500);background:var(--color-error-50);animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes timer-pulse-stroke{0%,to{stroke-opacity:1}50%{stroke-opacity:.6}}@media(prefers-reduced-motion:reduce){.timer--urgent .timer__value,.timer--urgent .timer__svg circle:last-child,.mini-timer--urgent{animation:none}.timer__bar-fill{transition:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-body);font-weight:var(--font-semibold);text-align:center;text-decoration:none;white-space:nowrap;vertical-align:middle;cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid transparent;border-radius:var(--radius-lg);transition:var(--transition-colors),var(--transform),box-shadow .2s ease;position:relative;overflow:hidden}.btn__text{position:relative;z-index:1}.btn__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn__icon--left{margin-left:calc(-1 * var(--space-1))}.btn__icon--right{margin-right:calc(-1 * var(--space-1))}.btn--sm{height:32px;padding:0 var(--space-3);font-size:var(--text-sm)}.btn--sm .btn__icon{width:16px;height:16px}.btn--md{height:40px;padding:0 var(--space-4);font-size:var(--text-base)}.btn--md .btn__icon{width:20px;height:20px}.btn--lg{height:48px;padding:0 var(--space-6);font-size:var(--text-lg)}.btn--lg .btn__icon{width:24px;height:24px}.btn--primary{background:var(--gradient-primary);color:#fff;border:none;box-shadow:var(--shadow-primary)}.btn--primary:hover:not(:disabled){box-shadow:var(--shadow-primary-lg);filter:brightness(1.1);transform:translateY(-1px)}.btn--primary:active:not(:disabled){transform:scale(.98) translateY(0);box-shadow:var(--shadow-primary)}.btn--secondary{background:var(--color-surface-200);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.btn--secondary:hover:not(:disabled){background:var(--color-surface-300);border-color:var(--color-border-default)}.btn--secondary:active:not(:disabled){transform:scale(.98);background:var(--color-surface-100)}.btn--ghost{background:transparent;color:var(--color-text-secondary);border:1px solid transparent}.btn--ghost:hover:not(:disabled){background:var(--color-surface-100);color:var(--color-text-primary)}.btn--ghost:active:not(:disabled){transform:scale(.98);background:var(--color-surface-200)}.btn--danger{background:var(--color-error-600);color:#fff;border:none;box-shadow:var(--shadow-error)}.btn--danger:hover:not(:disabled){background:var(--color-error-500);box-shadow:0 4px 14px #f43f5e80;transform:translateY(-1px)}.btn--danger:active:not(:disabled){transform:scale(.98) translateY(0)}.btn--icon{padding:0;width:var(--size-md);height:var(--size-md);border-radius:var(--radius-lg)}.btn--icon.btn--sm{width:var(--size-sm);height:var(--size-sm)}.btn--icon.btn--lg{width:var(--size-lg);height:var(--size-lg)}.btn--game{min-width:200px;text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:var(--font-bold)}.btn--game.btn--active{box-shadow:var(--glow-primary);animation:game-button-pulse 2s ease-in-out infinite}.btn--disabled,.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn--loading{cursor:wait}.btn--loading .btn__text,.btn--loading .btn__icon{opacity:0}.btn__spinner{position:absolute;width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:button-spin .8s linear infinite}.btn:focus-visible{outline:2px solid var(--color-primary-400);outline-offset:2px}@keyframes button-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes game-button-pulse{0%,to{box-shadow:var(--shadow-primary)}50%{box-shadow:var(--shadow-primary-lg),var(--glow-primary)}}@media(prefers-reduced-motion:reduce){.btn,.btn__spinner{transition:none;animation:none}.btn:hover:not(:disabled){transform:none}.btn:active:not(:disabled){transform:none}}@media(hover:none){.btn:hover:not(:disabled){transform:none}}.dictionary-status{position:fixed;top:100px;left:50%;transform:translate(-50%) translateY(-20px);z-index:1000;padding:12px 24px;border-radius:12px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 20px #0000004d;transition:all .3s ease;opacity:0;pointer-events:none}.dictionary-status.visible{opacity:1;transform:translate(-50%) translateY(0)}.dictionary-status.hidden{opacity:0;transform:translate(-50%) translateY(-20px)}.dictionary-status.loading{background:linear-gradient(135deg,#6366f1e6,#8b5cf6e6);border:1px solid rgba(99,102,241,.5)}.dictionary-status.loaded{background:linear-gradient(135deg,#22c55ee6,#16a34ae6);border:1px solid rgba(34,197,94,.5)}.dictionary-status-content{display:flex;align-items:center;gap:10px;color:#fff;font-weight:600;font-size:14px}.dictionary-spinner{display:inline-block;animation:spin 1s linear infinite}.dictionary-check{display:inline-block;animation:bounce .5s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}@media(max-width:768px){.dictionary-status{top:80px;padding:10px 18px;font-size:13px}}.room-page{min-height:100vh;padding-top:72px}.room-id-container{display:block;text-align:center;padding:var(--space-5)}.room-title{margin:0 0 var(--space-1);font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--color-text-primary)}.room-code-display{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-primary-400);letter-spacing:var(--tracking-wide);margin-bottom:var(--space-3)}.room-copy-buttons{display:flex;gap:var(--space-2);justify-content:center;flex-wrap:wrap}.game-hud{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface-100);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);margin-bottom:var(--space-4)}.game-hud-label{color:var(--color-text-tertiary);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.game-hud-value{color:var(--color-text-primary);font-weight:600}.game-area{background:var(--color-surface-100);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-4);margin-top:var(--space-4)}.game-area-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-4);text-align:center}.hat-game{text-align:center}.hat-words-input{width:100%;min-height:80px;padding:var(--space-3);background:var(--color-surface-200);color:var(--color-text-primary);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);font-size:var(--text-base);resize:vertical;margin-bottom:var(--space-3)}.hat-words-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f133}.hat-status{margin-bottom:var(--space-4);font-size:var(--text-base);color:var(--color-text-secondary)}.hat-explainer-view{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.hat-word-display{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:700;color:var(--color-text-primary);padding:var(--space-6);background:var(--gradient-card);border:2px solid var(--color-border-accent);border-radius:var(--radius-2xl);min-width:200px;text-align:center;transition:all .3s ease}.hat-word-display--panic{filter:blur(12px) brightness(.3);transform:scale(.98)}.hat-word-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}.hat-panic-hint{font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-surface-200);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);margin-top:var(--space-2)}.hat-panic-indicator{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);background:var(--color-warning-500);color:var(--color-text-inverse);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:600;z-index:var(--z-tooltip);animation:panic-blink .4s ease}@keyframes panic-blink{0%,to{opacity:1}50%{opacity:.3}}.hat-guesser-view{padding:var(--space-4);background:var(--color-surface-200);border-radius:var(--radius-lg);color:var(--color-text-secondary)}.assoc-game{position:relative}.assoc-words-input{width:100%;min-height:80px;padding:var(--space-3);background:var(--color-surface-200);color:var(--color-text-primary);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);font-size:var(--text-base);resize:vertical;margin-bottom:var(--space-3)}.assoc-status{margin-bottom:var(--space-4);font-size:var(--text-base)}.assoc-input-row{display:flex;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.assoc-input{flex:1;min-width:150px}.assoc-voting-block{margin-top:var(--space-4);padding:var(--space-4);background:var(--color-surface-200);border-radius:var(--radius-lg)}.assoc-cards-scene{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap}.assoc-card{background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-6);min-width:120px;text-align:center;font-weight:600;transition:all .3s ease}.assoc-card.selected{border-color:var(--color-primary-500);box-shadow:var(--shadow-primary)}.assoc-link-line{flex:1;max-width:100px;height:4px;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-400));border-radius:var(--radius-full);position:relative}.assoc-link-line:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:var(--color-primary-500);border-radius:50%;box-shadow:var(--glow-primary)}.assoc-vote-cards{display:flex;gap:var(--space-4);justify-content:center}.assoc-vote-card{flex:1;max-width:150px;padding:var(--space-4);background:var(--color-surface-100);border:2px solid var(--color-border-default);border-radius:var(--radius-xl);text-align:center;cursor:pointer;transition:all .2s ease}.assoc-vote-card:hover{border-color:var(--color-primary-400);transform:translateY(-2px)}.assoc-vote-card.selected.yes{background:var(--color-success-500);border-color:var(--color-success-600);color:#fff}.assoc-vote-card.selected.no{background:var(--color-error-500);border-color:var(--color-error-600);color:#fff}.assoc-result{text-align:center;margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius-lg);font-weight:600}.assoc-result--success{background:#10b98133;color:var(--color-success-400)}.assoc-result--fail{background:#f43f5e33;color:var(--color-error-400)}.croc-game{text-align:center}.croc-status{margin-bottom:var(--space-4);font-size:var(--text-base);color:var(--color-text-secondary)}.croc-canvas-wrapper{margin-bottom:var(--space-4);border:2px solid var(--color-border-subtle);border-radius:var(--radius-xl);overflow:hidden}.croc-word-section{margin-top:var(--space-4)}.croc-word-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}.croc-word{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:600;color:var(--color-text-primary);padding:var(--space-6);background:var(--gradient-card);border:2px solid var(--color-border-accent);border-radius:var(--radius-2xl);min-height:70px;display:flex;align-items:center;justify-content:center}.croc-hint{color:var(--color-text-secondary);font-size:var(--text-base);margin-top:var(--space-4)}.croc-score{margin-top:var(--space-4)}.croc-score-item{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle)}.generic-game{text-align:center}.generic-status{margin-bottom:var(--space-4);font-size:var(--text-base);color:var(--color-text-secondary)}.generic-word-display{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--color-text-primary);padding:var(--space-6);background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-2xl);margin-bottom:var(--space-4);min-height:50px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--space-2)}.generic-items-list{margin-top:var(--space-4);text-align:left}.generic-item{padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:center;gap:var(--space-2)}.generic-input-form{display:flex;gap:var(--space-3);margin-top:var(--space-4);flex-wrap:wrap}.generic-input{flex:1;min-width:150px}.generic-voting{margin-top:var(--space-4)}.generic-voting-label{margin-bottom:var(--space-3);color:var(--color-text-secondary);font-size:var(--text-sm)}.generic-voting-options{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.generic-score{margin-top:var(--space-4)}.generic-score-item{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle)}.quiz-question{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-6);text-align:center;min-height:50px}.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.quiz-option{padding:var(--space-4);background:var(--color-surface-200);border:2px solid var(--color-border-subtle);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all .2s ease;font-size:var(--text-base)}.quiz-option:hover{border-color:var(--color-primary-400)}.quiz-option.selected{background:var(--color-primary-500);border-color:var(--color-primary-600);color:#fff}@media(max-width:640px){.quiz-options{grid-template-columns:1fr}}.meme-game{position:relative}.meme-prompt-container{position:relative;margin-bottom:var(--space-4)}.meme-prompt{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--color-text-primary);text-align:center;padding:var(--space-6);background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-2xl);min-height:80px;display:flex;align-items:center;justify-content:center}.meme-rofl-btn{position:absolute;top:var(--space-2);right:var(--space-2);width:40px;height:40px;background:var(--color-surface-200);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);font-size:var(--text-xl);cursor:pointer;transition:all .2s ease;z-index:10}.meme-rofl-btn:hover{background:var(--color-primary-500);transform:scale(1.1)}.meme-rofl-tooltip{position:absolute;top:calc(100% + var(--space-2));right:0;background:var(--color-surface-200);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);max-width:250px;z-index:20;box-shadow:var(--shadow-lg)}.meme-input-row{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.meme-voting{margin-top:var(--space-4)}.meme-voting-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.meme-vote-options{display:flex;flex-direction:column;gap:var(--space-3)}.meme-vote-option{padding:var(--space-4);background:var(--color-surface-200);border:2px solid var(--color-border-subtle);border-radius:var(--radius-lg);text-align:left;cursor:pointer;transition:all .2s ease}.meme-vote-option:hover{border-color:var(--color-primary-400)}.meme-winner{text-align:center;padding:var(--space-6);background:linear-gradient(135deg,#fbbf2433,#fbbf241a);border:2px solid var(--color-warning-500);border-radius:var(--radius-2xl);margin-bottom:var(--space-4)}.meme-winner-text{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--color-warning-400);margin-bottom:var(--space-2)}.meme-winner-author{color:var(--color-text-secondary);font-size:var(--text-sm)}.spy-role{text-align:center;padding:var(--space-6);background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-2xl);margin-bottom:var(--space-4);font-size:var(--text-xl)}.spy-role--spy{border-color:var(--color-error-500);background:linear-gradient(135deg,rgba(244,63,94,.1) 0%,var(--color-surface-100) 100%)}.spy-role--location{border-color:var(--color-success-500);background:linear-gradient(135deg,rgba(16,185,129,.1) 0%,var(--color-surface-100) 100%)}.spy-voting{margin-top:var(--space-4)}.spy-voting-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.spy-players-grid{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.truths-facts-list{margin-bottom:var(--space-4)}.truths-fact-input{width:100%;margin-bottom:var(--space-3)}.truths-lie-selector{margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.truths-guessing{text-align:center}.truths-guessing-title{margin-bottom:var(--space-4);font-size:var(--text-lg);color:var(--color-text-secondary)}.truths-fact-option{width:100%;margin-bottom:var(--space-2);text-align:left;justify-content:flex-start}.story-display{background:var(--color-surface-200);padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4);min-height:60px;line-height:1.6;white-space:pre-wrap;text-align:left}.story-input-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.story-input{flex:1;min-width:200px}.story-current-writer{text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);margin-top:var(--space-3)}.emoji-display{font-size:3rem;text-align:center;margin-bottom:var(--space-2);min-height:70px;display:flex;align-items:center;justify-content:center}.emoji-category{text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);margin-bottom:var(--space-4)}.emoji-hint{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-4)}.whoami-characters{margin-bottom:var(--space-4)}.whoami-character-item{padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle)}.whoami-input-row{display:flex;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.whoami-input{flex:1;min-width:150px}.fakeartist-role{text-align:center;padding:var(--space-4);background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-2xl);margin-bottom:var(--space-4)}.fakeartist-role--fake{border-color:var(--color-error-500);background:linear-gradient(135deg,rgba(244,63,94,.1) 0%,var(--color-surface-100) 100%)}.fakeartist-hint-section{margin-top:var(--space-4)}.fakeartist-hint-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.fakeartist-hint-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.fakeartist-hint-input{flex:1;min-width:150px}.fakeartist-voting{margin-top:var(--space-4)}.fakeartist-voting-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.fakeartist-players-grid{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.fakeartist-guess-section{margin-top:var(--space-4)}.fakeartist-guess-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.fakeartist-guess-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.fakeartist-guess-input{flex:1;min-width:150px}.chameleon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}@media(max-width:640px){.chameleon-grid{grid-template-columns:repeat(2,1fr)}}.chameleon-word-cell{padding:var(--space-3);background:var(--color-surface-200);border:2px solid var(--color-border-subtle);border-radius:var(--radius-lg);text-align:center;font-size:var(--text-sm);transition:all .2s ease}.chameleon-word-cell--secret{background:#10b98133;border-color:var(--color-success-500)}.chameleon-role{text-align:center;padding:var(--space-4);background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-2xl);margin-bottom:var(--space-4)}.chameleon-role--chameleon{border-color:var(--color-error-500);background:linear-gradient(135deg,rgba(244,63,94,.1) 0%,var(--color-surface-100) 100%)}.chameleon-clue-section{margin-top:var(--space-4)}.chameleon-clue-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.chameleon-clue-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.chameleon-clue-input{flex:1;min-width:150px}.chameleon-voting{margin-top:var(--space-4)}.chameleon-voting-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.chameleon-players-grid{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.chameleon-guess-section{margin-top:var(--space-4)}.chameleon-guess-label{margin-bottom:var(--space-3);color:var(--color-text-secondary)}.chameleon-guess-grid{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.debate-topic{text-align:center;padding:var(--space-4);background:var(--gradient-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-2xl);margin-bottom:var(--space-4);font-size:var(--text-lg);min-height:50px}.debate-players{display:flex;gap:var(--space-4);justify-content:center;margin-bottom:var(--space-4);flex-wrap:wrap}.debate-player{text-align:center}.debate-player-name{font-weight:600;color:var(--color-text-primary)}.debate-player-side{font-size:var(--text-sm);color:var(--color-text-muted)}.debate-voting{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.waiting-state{text-align:center;padding:var(--space-6)}.waiting-message{color:var(--color-text-muted);margin-top:var(--space-4)}.nickname-change{margin-top:var(--space-4);max-width:320px;margin-left:auto;margin-right:auto}.nickname-row{display:flex;gap:var(--space-3)}.nickname-input{flex:1}.mafia-night-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172af2;z-index:var(--z-modal-backdrop);pointer-events:none}.ai-narrator{max-height:200px;overflow-y:auto}.ai-msg{padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle);font-size:var(--text-sm)}.ai-msg:last-child{border-bottom:none}.assoc-flash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);pointer-events:none;opacity:0;transition:opacity .15s ease}.assoc-flash-overlay.active{opacity:.3}.laugh-container{position:relative}.laugh-disco{animation:disco-flash .5s ease infinite}@keyframes disco-flash{0%,to{background:var(--color-surface-100)}50%{background:#6366f11a}}@media(prefers-reduced-motion:reduce){.laugh-disco{animation:none}.hat-word-display,.assoc-card,.quiz-option,.meme-vote-option{transition:none}}:root{--primary: #6366F1;--secondary: #F472B6;--accent: #6366F1;--accent-amber: #FBBF24;--bg-deep: #0F172A;--surface: #1E293B;--success: #10B981;--error: #F43F5E;--error-red: #F43F5E;--success-green: #10B981;--text-primary: #F8FAFC;--text-muted: #94A3B8;--border-subtle: rgba(255, 255, 255, .08);--border-accent: rgba(99, 102, 241, .4);--accent-dim: rgba(99, 102, 241, .15);--secondary-dim: rgba(244, 114, 182, .15);--accent-gold: #FBBF24;--accent-gold-dim: rgba(251, 191, 36, .15);--gradient-hero: linear-gradient(135deg, #6366F1 0%, #F472B6 100%);--gradient-card: linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,0) 100%);--shadow-primary: 0 4px 14px rgba(99, 102, 241, .4);--shadow-primary-hover: 0 8px 24px rgba(99, 102, 241, .5);--glow-primary: 0 0 40px rgba(99, 102, 241, .2);--font-display: "Outfit", "Space Grotesk", sans-serif;--font-body: "Inter", -apple-system, sans-serif;--font-logo: "Creepster", cursive;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-8: 48px;--space-10: 64px;--radius: 16px;--radius-lg: 24px;--transition: .3s cubic-bezier(.4, 0, .2, 1)}*{font-family:var(--font-body)}body{margin:0;padding:0;background:var(--bg-deep)!important;color:var(--text-primary)!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 120% 80% at 20% 10%,rgba(99,102,241,.12) 0%,transparent 50%),radial-gradient(ellipse 100% 100% at 80% 20%,rgba(244,114,182,.08) 0%,transparent 50%),radial-gradient(ellipse 80% 60% at 60% 90%,rgba(251,191,36,.05) 0%,transparent 45%),linear-gradient(180deg,#0f172a,#0c1222,#0f172a);z-index:-2;pointer-events:none}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.04) 1px,transparent 0);background-size:40px 40px;z-index:-1;pointer-events:none}.page-wrap{position:relative;min-height:100vh;display:flex;justify-content:center}.page-side{position:fixed;top:0;bottom:0;width:min(22vw,320px);z-index:0;pointer-events:none}.page-side-left{left:0;background:radial-gradient(ellipse 80% 60% at 0% 30%,rgba(99,102,241,.15) 0%,transparent 55%),radial-gradient(ellipse 60% 80% at 10% 70%,rgba(244,114,182,.08) 0%,transparent 50%),linear-gradient(180deg,transparent 0%,rgba(99,102,241,.03) 50%,transparent 100%)}.page-side-right{right:0;background:radial-gradient(ellipse 80% 60% at 100% 40%,rgba(244,114,182,.12) 0%,transparent 55%),radial-gradient(ellipse 60% 80% at 90% 80%,rgba(251,191,36,.06) 0%,transparent 50%),linear-gradient(180deg,transparent 0%,rgba(244,114,182,.02) 50%,transparent 100%)}.page-side:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:32px 32px;opacity:.5}.page-side-left:after{content:"";position:absolute;right:0;top:15%;bottom:15%;width:1px;background:linear-gradient(180deg,transparent,rgba(99,102,241,.2),transparent)}.page-side-right:after{content:"";position:absolute;left:0;top:20%;bottom:20%;width:1px;background:linear-gradient(180deg,transparent,rgba(244,114,182,.15),transparent)}.page-wrap>.container{flex:1;max-width:1280px}.container{max-width:1280px;margin:0 auto;padding:var(--space-6) var(--space-6);position:relative;z-index:10}.header{text-align:center;padding:var(--space-10) var(--space-6);margin-bottom:var(--space-8);position:relative;overflow:hidden;border-radius:var(--radius-lg);background:linear-gradient(135deg,#6366f114,#1e293b99,#f472b60a);border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 24px 48px #0000004d}.header:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-hero);opacity:.8}.header h1{font-family:var(--font-logo)!important;font-size:clamp(2.5rem,8vw,4rem)!important;font-weight:400!important;margin:0 0 var(--space-2)!important;letter-spacing:.02em!important;text-transform:none!important;background:var(--gradient-hero)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important;animation:titleEntrance .6s cubic-bezier(.2,.8,.2,1)}.header-tagline{font-family:var(--font-display)!important;font-size:clamp(1.1rem,2.5vw,1.5rem)!important;font-weight:600!important;color:var(--text-muted)!important;margin:0!important;letter-spacing:-.02em;line-height:1.5;animation:titleEntrance .6s .1s cubic-bezier(.2,.8,.2,1) both}.header-tagline-hero{font-size:clamp(1.25rem,3vw,1.75rem)!important;color:var(--text-primary)!important;max-width:520px;margin:var(--space-4) auto 0!important;font-weight:500}.header:after,.game-area:before,.phase:after,.toast:after,.footer:before{display:none!important}.connection-bar{background:#0f172ae6!important;border-bottom:1px solid var(--border-subtle)!important;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:var(--space-3) var(--space-5)}.connection-bar.connected .connection-dot{background:var(--success)!important;box-shadow:0 0 12px #10b98180}.connection-bar.disconnected .connection-dot{background:var(--error)}.connection-text{color:var(--text-muted)}.connection-bar.connected .connection-text{color:var(--success)}.lobby{padding:var(--space-5) 0!important}.lobby-grid{display:grid;grid-template-columns:340px 1fr;gap:var(--space-8);align-items:start;max-width:100%;margin:0 auto;position:relative}.lobby-grid:before{content:"";position:absolute;top:-40px;right:-24px;bottom:-40px;left:-24px;background:radial-gradient(ellipse 40% 30% at 15% 20%,rgba(99,102,241,.1) 0%,transparent 55%),radial-gradient(ellipse 45% 35% at 80% 35%,rgba(244,114,182,.08) 0%,transparent 60%),radial-gradient(ellipse 35% 30% at 60% 90%,rgba(251,191,36,.05) 0%,transparent 60%),linear-gradient(120deg,rgba(255,255,255,.03) 0%,transparent 35%,rgba(255,255,255,.02) 65%,transparent 100%);border-radius:32px;opacity:.8;pointer-events:none;filter:blur(.2px)}.lobby-sidebar{position:sticky;top:60px;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);z-index:2}.lobby-sidebar>.name-input-container,.lobby-sidebar>.last-rooms-dropdown,.lobby-sidebar>.history-rooms{position:relative;transform:translateZ(0);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.lobby-sidebar>.name-input-container:nth-of-type(1){transform:rotate(-.25deg)}.lobby-sidebar>.name-input-container:nth-of-type(2){transform:rotate(.25deg)}.lobby-sidebar>.last-rooms-dropdown{transform:rotate(-.15deg)}.lobby-sidebar>.history-rooms{transform:rotate(.15deg)}.lobby-sidebar>.name-input-container:hover,.lobby-sidebar>.last-rooms-dropdown:hover,.lobby-sidebar>.history-rooms:hover{transform:translateY(-2px) rotate(0);box-shadow:0 16px 40px #00000042;border-color:#6366f138!important}.lobby-sidebar>.name-input-container{grid-column:1 / -1}.lobby-sidebar>.game-select-title{grid-column:1 / -1;margin:0!important}.lobby-sidebar>.last-rooms-dropdown{margin:0!important}.lobby-sidebar>.history-rooms{margin:0!important}.lobby-main{min-width:0}.rooms-label{font-size:.82rem;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}.btn{font-family:var(--font-display)!important;padding:14px 24px!important;font-size:1rem!important;font-weight:600!important;border-radius:var(--radius)!important;border:2px solid transparent!important;transition:transform var(--transition),box-shadow var(--transition),background var(--transition)!important;min-width:160px}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn:active:not(:disabled){transform:scale(.98)}.btn:focus-visible{outline:none!important;box-shadow:0 0 0 3px var(--accent-dim),var(--shadow-primary)!important}.btn-primary-action{background:var(--gradient-hero)!important;color:#fff!important;border:none!important;box-shadow:var(--shadow-primary)!important}.btn-primary-action:hover:not(:disabled){box-shadow:var(--shadow-primary-hover)!important;color:#fff!important}.btn:not(.btn-primary-action){background:transparent!important;border-color:var(--primary)!important;color:var(--primary)!important}.btn:not(.btn-primary-action):hover:not(:disabled){background:#6366f11a!important;color:var(--primary)!important}.btn:disabled{opacity:.5;cursor:not-allowed}@media(hover:none){.btn:hover:not(:disabled){transform:none}.game-card:hover{transform:none!important}.how-step:hover{transform:none}}.btn-sm{padding:10px 20px!important;font-size:.9rem!important}.name-input-container,.game-area,.room-id-container,.chat,.last-rooms-dropdown,.donation-collapse-trigger,.donation-block{background:var(--surface)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--radius)!important;box-shadow:0 4px 24px #0003!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.name-input-container{margin-bottom:var(--space-4)!important;padding:var(--space-4)!important}.name-input-container label{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--text-muted);margin-bottom:var(--space-2);display:block}.name-input-container input,.input-area input,select{background:#0f172a99!important;border:1px solid var(--border-subtle)!important;border-radius:12px!important;color:var(--text-primary)!important;padding:14px 18px!important;font-size:1rem!important;transition:border-color var(--transition),box-shadow var(--transition)}.name-input-container input:focus,.input-area input:focus,select:focus{outline:none!important;border-color:var(--primary)!important;box-shadow:0 0 0 3px var(--accent-dim)!important}.name-input-container input::placeholder{color:var(--text-muted)}.game-select-title{font-family:var(--font-display)!important;font-size:1.5rem!important;font-weight:600!important;color:var(--text-primary)!important;margin:var(--space-6) 0 var(--space-4)!important;letter-spacing:-.02em}.game-select{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important;gap:var(--space-4)!important;margin:var(--space-5) 0!important;max-width:100%}.game-card{--card-i: 0;background:var(--surface)!important;background-image:var(--gradient-card)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--radius)!important;padding:var(--space-5) var(--space-4)!important;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)!important;animation:cardStagger .4s cubic-bezier(.2,.8,.2,1) both;animation-delay:calc(.05s * var(--card-i));position:relative;overflow:hidden}.game-card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;background:radial-gradient(120px 80px at var(--mx, 30%) var(--my, 20%),rgba(255,255,255,.12) 0%,transparent 60%);opacity:0;transition:opacity var(--transition);pointer-events:none}.game-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.06) 45%,transparent 60%);transform:translate(-120%);opacity:0;transition:transform .52s cubic-bezier(.2,.8,.2,1),opacity .52s cubic-bezier(.2,.8,.2,1);pointer-events:none}.lobby-main:not(.in-view) .game-card{animation:none;opacity:0}.game-card:hover{transform:translateY(-4px) scale(1.02)!important;box-shadow:0 12px 32px #0000004d,0 0 24px #6366f126!important;border-color:#6366f14d!important}.game-card:hover:before{opacity:1}.game-card:hover:after{opacity:1;transform:translate(120%)}.game-card:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-dim),0 12px 32px #0000004d;border-color:#6366f173!important}.game-card:nth-child(6n+1){transform:translateY(2px)}.game-card:nth-child(6n+2){transform:translateY(-3px)}.game-card:nth-child(6n+3){transform:translateY(4px)}.game-card:nth-child(6n+4){transform:translateY(-2px)}.game-card:nth-child(6n+5){transform:translateY(1px)}.game-card:nth-child(6n+6){transform:translateY(-1px)}.game-card:hover:nth-child(n){transform:translateY(-4px) scale(1.02)!important}.game-card.selected{border-color:var(--primary)!important;background:linear-gradient(135deg,#6366f133,#f472b614)!important;box-shadow:0 0 32px #6366f140!important;color:var(--text-primary)!important}.game-card>div:nth-child(2){font-size:2.5rem!important;margin-bottom:var(--space-3)!important;transition:transform var(--transition)}.game-card:hover>div:nth-child(2){transform:scale(1.08)}.game-card-badge{font-size:.8rem!important;color:var(--text-muted)!important;margin-top:var(--space-2);font-weight:500}.game-card-rules{position:absolute;top:var(--space-2);right:var(--space-2);width:28px;height:28px;border-radius:50%;border:1px solid var(--border-subtle);background:#ffffff0d;color:var(--text-muted);font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.game-card-rules:hover{border-color:var(--primary);color:var(--primary)}.game-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-4)}.filter-chip{padding:6px 14px;border-radius:999px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--transition);font-family:var(--font-display);white-space:nowrap}.filter-chip:hover{border-color:#6366f14d;color:var(--text-primary)}.filter-chip.active{background:var(--gradient-hero);border-color:transparent;color:#fff;box-shadow:0 2px 12px #6366f14d}.filter-chip:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-dim)}.lobby-main{opacity:0;transform:translateY(24px);transition:opacity .5s cubic-bezier(.2,.8,.2,1),transform .5s cubic-bezier(.2,.8,.2,1)}.lobby-main.in-view{opacity:1;transform:translateY(0)}@keyframes cardStagger{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes titleEntrance{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.how-it-works{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);margin:var(--space-8) 0}.how-step{text-align:center;padding:var(--space-5);background:var(--surface);border-radius:var(--radius);border:1px solid var(--border-subtle);position:relative;transition:transform var(--transition),box-shadow var(--transition)}.how-step:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0003}.how-step-num{width:40px;height:40px;border-radius:50%;background:var(--gradient-hero);color:#fff;font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-3)}.how-step-title{font-family:var(--font-display);font-weight:600;font-size:1.1rem;margin-bottom:var(--space-2);color:var(--text-primary)}.how-step-desc{font-size:.9rem;color:var(--text-muted);line-height:1.5}.last-rooms-dropdown.rooms-compact{padding:var(--space-4)!important;max-height:220px;overflow-y:auto}.rooms-muted{opacity:.8;border-style:dashed!important}.history-rooms{margin:var(--space-4) auto;max-width:420px;text-align:center}.history-toggle{width:100%;padding:var(--space-3) var(--space-4);background:transparent;border:1px dashed var(--border-subtle);border-radius:var(--radius);color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.history-toggle:hover{color:var(--primary);border-color:var(--primary)}.last-room-btn{padding:var(--space-3) var(--space-4)!important;margin:var(--space-2) 0!important;font-size:.95rem!important;border-radius:12px!important;text-align:left!important;transition:all var(--transition)}.last-room-btn:hover{background:var(--accent-dim)!important;border-color:#6366f14d!important}.donation-collapse{margin-top:var(--space-6)!important}.donation-collapse-trigger{padding:var(--space-4)!important;border-radius:var(--radius)!important;color:var(--text-muted);font-weight:500;transition:all var(--transition)}.donation-collapse-trigger:hover{color:var(--accent-amber);border-color:#fbbf244d!important}.donation-block:not(.donation-block-collapsed){padding:var(--space-5)!important;border-radius:var(--radius)!important;background:linear-gradient(145deg,#fbbf2414,#fbbf2405)!important;border:1px solid rgba(251,191,36,.2)!important;max-height:400px!important;overflow:visible!important;margin-top:var(--space-3)!important}.donation-icon{font-size:2rem;margin-bottom:var(--space-3);animation:donationPulse 2.5s ease-in-out infinite}@keyframes donationPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.donation-title{font-family:var(--font-display);font-size:1.2rem!important;font-weight:600!important}.donation-text{font-size:.9rem!important;color:var(--text-muted)!important;margin-bottom:var(--space-4)!important}.donation-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:14px 28px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#0f172a;font-weight:600;border-radius:999px;text-decoration:none;box-shadow:0 4px 20px #fbbf2466;transition:transform var(--transition),box-shadow var(--transition)}.donation-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 28px #fbbf2480}.donation-btn-arrow{transition:transform var(--transition)}.donation-btn:hover .donation-btn-arrow{transform:translate(4px)}.donation-heart{transition:transform var(--transition)}.donation-btn:hover .donation-heart{transform:scale(1.2);display:inline-block}.footer{margin-top:var(--space-8)!important;padding:var(--space-6) var(--space-5)!important;border-top:1px solid var(--border-subtle)!important;background:transparent!important;text-align:center}.footer a{color:var(--primary)!important;font-weight:500}.footer a:hover{color:var(--secondary)!important}.footer p{color:var(--text-muted);font-size:.9rem;margin:var(--space-2) 0}.modal-backdrop{background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-content{background:var(--surface)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--radius-lg)!important;box-shadow:0 24px 64px #0006;animation:modalIn .3s cubic-bezier(.2,.8,.2,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header h2{font-family:var(--font-display);font-weight:600}.modal-close:hover{background:var(--error)!important;color:#fff!important}.phase{font-family:var(--font-display);color:var(--primary)!important;font-weight:700;font-size:1.15rem;margin-bottom:var(--space-3);letter-spacing:-.01em}.room-content-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:var(--space-5);align-items:start}.room-content-grid>:not(.room-side-stack){grid-column:1}.room-side-stack{grid-column:2;grid-row:1 / span 200;position:sticky;top:92px;align-self:start;display:grid;gap:var(--space-4)}.room-side-stack .players{margin:0;display:grid;grid-template-columns:1fr;gap:10px;justify-content:stretch}.room-side-stack .chat{margin:0;max-height:min(46vh,520px)}.room-side-stack .input-area{margin-top:0}.room-side-stack .input-area input{padding:12px 14px!important}.room-side-stack .btn{min-width:0}.room-side-stack .game-area{margin:0!important}.room-exit-bar{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);text-align:center;z-index:50}.room-exit-bar .btn{min-width:160px;box-shadow:0 4px 20px #0000004d}.container:has(.room-exit-bar){padding-bottom:80px}.player{background:var(--surface)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--radius)!important;padding:10px 14px!important;transition:all var(--transition);animation:playerEnter .3s ease both}@keyframes playerEnter{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.player:hover{border-color:#6366f14d!important;transform:translateY(-2px);box-shadow:0 6px 20px #0003}.player.active{border-color:var(--primary)!important;background:linear-gradient(135deg,#6366f126,#f472b614)!important;box-shadow:0 0 20px #6366f126}.player.disconnected{opacity:.45;filter:grayscale(.5)}.player-avatar{width:32px!important;height:32px!important;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0;background:var(--gradient-hero);box-shadow:0 2px 8px #6366f14d}.players{display:flex;flex-wrap:wrap;gap:10px;margin:var(--space-4) 0;justify-content:center}.room-id-container{position:relative;overflow:hidden}.room-id-container:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-hero);opacity:.6}.room-id{background:#6366f114!important;border:2px dashed rgba(99,102,241,.3)!important;border-radius:var(--radius)!important;color:var(--primary)!important;font-size:1.5rem;letter-spacing:.15em;font-weight:800;padding:14px 24px;font-family:var(--font-display)}.room-copy-buttons{display:flex;gap:8px;justify-content:center;margin-top:var(--space-3)}.game-area{position:relative;overflow:hidden;padding:var(--space-5)!important;margin:var(--space-4) 0!important;animation:fadeSlideUp .35s ease both}.game-area:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.3),transparent)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.word{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;color:var(--text-primary);background:linear-gradient(135deg,#6366f11a,#f472b60f);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);padding:var(--space-5);text-align:center;display:flex;align-items:center;justify-content:center;min-height:80px;animation:wordReveal .4s cubic-bezier(.2,.8,.2,1);position:relative}.word:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);box-shadow:inset 0 0 30px #6366f10d;pointer-events:none}@keyframes wordReveal{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.chat{border-radius:var(--radius)!important;padding:var(--space-4)!important;max-height:280px;overflow-y:auto;scroll-behavior:smooth;margin:var(--space-4) 0}.chat::-webkit-scrollbar{width:4px}.chat::-webkit-scrollbar-track{background:transparent}.chat::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}.message{padding:8px 12px;margin:4px 0;border-radius:10px;background:#ffffff08;border-left:2px solid transparent;animation:msgIn .2s ease;font-size:.95rem;line-height:1.5}@keyframes msgIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.message.system{border-left-color:var(--primary);background:#6366f10f;color:var(--text-muted);font-style:italic}.message.bot-msg{border-left-color:var(--secondary);background:#f472b60a}.message.host-msg{border-left-color:var(--accent-gold)}.msg-author{color:var(--primary)!important;font-weight:600}.input-area{display:flex;gap:10px;margin-top:var(--space-4)}.input-area input{flex:1;border-radius:12px!important}.error{color:var(--error);background:#f43f5e1a;border-left:3px solid var(--error);padding:12px 16px;border-radius:var(--radius);margin:var(--space-3) 0;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:8px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.role-badge.mafia,.role-badge.don{background:#f43f5e26;color:#f43f5e}.role-badge.civilian,.role-badge.citizen{background:#10b98126;color:#10b981}.role-badge.sheriff{background:#6366f126;color:#6366f1}.role-badge.doctor{background:#fbbf2426;color:#fbbf24}.role-badge.maniac{background:#a855f726;color:#a855f7}.role-badge.poisoner{background:#22c55e26;color:#22c55e;border:1px dashed rgba(34,197,94,.3)}.role-badge.putana{background:#f472b626;color:#f472b6}.role-badge.dead{background:#ffffff0d;color:var(--text-muted);text-decoration:line-through}.score-table{display:grid;gap:4px;margin-top:var(--space-3)}.score-row{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;border-radius:8px;background:#ffffff05;font-size:.92rem;transition:background var(--transition)}.score-row:first-child{background:#6366f11a;font-weight:600}.score-row:hover{background:#ffffff0d}.score-value{font-weight:700;color:var(--primary);font-family:var(--font-display)}.voice-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;font-size:.8rem;font-weight:500}.voice-status.connected{background:#10b9811a;color:var(--success)}.voice-status.error{background:#f43f5e1a;color:var(--error)}.voice-panel{position:relative;background:#08080cf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:16px;padding:16px 24px;display:flex;flex-direction:column;gap:12px;min-width:280px;max-width:100%;box-shadow:0 20px 60px #00000080}.voice-panel--dead{opacity:.7;border-color:#ff52524d}.voice-panel--connecting,.voice-panel--error{display:flex;align-items:center;gap:10px;color:var(--text-muted)}.voice-spinner{width:20px;height:20px;border:2px solid var(--border-subtle);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.voice-speakers{display:flex;flex-wrap:wrap;gap:8px;min-height:32px}.voice-speaker-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--accent-dim, rgba(99, 102, 241, .15));border-radius:20px;font-size:.85rem;color:var(--primary);animation:speaker-pulse 1s ease-in-out infinite}.voice-speaker-wave{width:16px;height:16px;background:var(--primary);border-radius:50%;animation:wave 1s ease-in-out infinite}@keyframes wave{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}@keyframes speaker-pulse{0%,to{opacity:1}50%{opacity:.85}}.voice-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.voice-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-card, rgba(30, 41, 59, .5));border:1px solid var(--border-subtle);border-radius:12px;color:var(--text-primary);cursor:pointer;transition:all .2s}.voice-btn:hover:not(:disabled){background:var(--bg-card-hover, rgba(51, 65, 85, .5));transform:translateY(-2px)}.voice-btn--muted{background:#ff525233;border-color:#ff525266;color:var(--error, #f43f5e)}.voice-channel-indicator{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#ff00001a;border-radius:8px;font-size:.85rem;color:#f44}.channel-dot{width:8px;height:8px;border-radius:50%;background:#333;transition:all .3s}.channel-dot.active{background:#f44;box-shadow:0 0 10px #f44;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.voice-dead-notice{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem}.voice-queue-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.voice-queue-row{margin-bottom:8px;font-size:.9rem}.voice-host-controls{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.role-badge.role-hidden{color:var(--text-muted);font-style:italic;opacity:.5;background:#ffffff0d}.night-waiting{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;opacity:.85}.night-atmosphere{position:relative;width:120px;height:80px}.night-waiting .moon{font-size:48px;animation:moon-float 4s ease-in-out infinite}@keyframes moon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.night-waiting .stars{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(2px 2px at 20px 20px,rgba(255,255,255,.6),transparent),radial-gradient(2px 2px at 50px 40px,rgba(255,255,255,.4),transparent),radial-gradient(2px 2px at 80px 60px,rgba(255,255,255,.5),transparent);animation:twinkle 3s ease-in-out infinite}@keyframes twinkle{0%,to{opacity:1}50%{opacity:.5}}.night-waiting .waiting-text{margin:12px 0 8px;font-size:.9rem;color:var(--text-muted)}.night-waiting .sleep-indicator{display:flex;gap:4px}.night-waiting .zzz{font-size:20px;color:var(--text-muted);animation:zzz-float 2s ease-in-out infinite}.night-waiting .zzz:nth-child(2){animation-delay:.3s}.night-waiting .zzz:nth-child(3){animation-delay:.6s}@keyframes zzz-float{0%,to{transform:translateY(0);opacity:.3}50%{transform:translateY(-12px);opacity:1}}.ai-narrator{position:relative;padding:var(--space-4) var(--space-5)!important;margin:var(--space-3) 0!important;background:linear-gradient(135deg,#fbbf240f,#f472b608)!important;border-left:3px solid var(--accent-gold)!important;border-radius:0 var(--radius) var(--radius) 0!important}.ai-narrator .phase{color:var(--accent-gold)!important;font-size:.85rem}.ai-msg{padding:3px 0;font-size:.93rem;line-height:1.5;animation:aiMsgIn .3s ease}.ai-msg:last-child{color:var(--text-primary)}.ai-msg:not(:last-child){color:var(--text-muted)}@keyframes aiMsgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.timer-display{display:inline-flex;align-items:center;justify-content:center;min-width:48px;padding:4px 12px;border-radius:8px;font-weight:700;font-size:1.1rem;font-family:var(--font-display);background:#6366f11a;color:var(--primary);border:1px solid rgba(99,102,241,.2)}.timer-display.urgent{background:#f43f5e1f;color:var(--error);border-color:#f43f5e4d;animation:timerPulse .8s ease infinite}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.6}}.host-panel{margin-top:var(--space-4);padding:var(--space-4);background:#6366f10d;border:1px solid rgba(99,102,241,.15);border-radius:var(--radius)}.host-panel-title{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3)}.game-hud{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;padding:var(--space-3) var(--space-4);background:#0f172a80;border:1px solid var(--border-subtle);border-radius:var(--radius);margin-bottom:var(--space-4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.game-hud-label{font-size:.82rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.game-hud-value{font-family:var(--font-display);font-weight:700;color:var(--text-primary)}@media(max-width:1024px){.how-it-works{grid-template-columns:1fr}}@media(max-width:1200px){.page-side{width:min(18vw,200px);opacity:.8}}@media(max-width:900px){.page-side{width:12vw;opacity:.5}.lobby-grid{grid-template-columns:1fr}.lobby-sidebar{position:static;grid-template-columns:1fr}.room-content-grid{grid-template-columns:1fr}.room-side-stack{grid-column:1;grid-row:auto;position:static}}@media(max-width:640px){.page-side{display:none}}@media(max-width:768px){.container{padding:var(--space-4) var(--space-4)}.header{padding:var(--space-6) var(--space-4)!important}.lobby-grid{gap:var(--space-5)}.game-select{grid-template-columns:repeat(2,1fr)!important;gap:var(--space-3)!important}.btn{width:100%;min-width:0}}@media(max-width:640px){.game-select{grid-template-columns:1fr!important}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--color-primary-50: #EEF2FF;--color-primary-100: #E0E7FF;--color-primary-200: #C7D2FE;--color-primary-300: #A5B4FC;--color-primary-400: #818CF8;--color-primary-500: #6366F1;--color-primary-600: #4F46E5;--color-primary-700: #4338CA;--color-primary-800: #3730A3;--color-primary-900: #312E81;--color-secondary-50: #FDF2F8;--color-secondary-100: #FCE7F3;--color-secondary-200: #FBCFE8;--color-secondary-300: #F9A8D4;--color-secondary-400: #F472B6;--color-secondary-500: #EC4899;--color-secondary-600: #DB2777;--color-secondary-700: #BE185D;--color-success-50: #ECFDF5;--color-success-100: #D1FAE5;--color-success-200: #A7F3D0;--color-success-300: #6EE7B7;--color-success-400: #34D399;--color-success-500: #10B981;--color-success-600: #059669;--color-success-700: #047857;--color-error-50: #FEF2F2;--color-error-100: #FEE2E2;--color-error-200: #FECACA;--color-error-300: #FCA5A5;--color-error-400: #F87171;--color-error-500: #EF4444;--color-error-600: #DC2626;--color-error-700: #B91C1C;--color-error-800: #F43F5E;--color-warning-50: #FFFBEB;--color-warning-100: #FEF3C7;--color-warning-200: #FDE68A;--color-warning-300: #FCD34D;--color-warning-400: #FBBF24;--color-warning-500: #F59E0B;--color-warning-600: #D97706;--color-warning-700: #B45309;--color-info-50: #EFF6FF;--color-info-100: #DBEAFE;--color-info-200: #BFDBFE;--color-info-300: #93C5FD;--color-info-400: #60A5FA;--color-info-500: #3B82F6;--color-info-600: #2563EB;--color-bg-primary: #0F172A;--color-bg-secondary: #1E293B;--color-bg-tertiary: #334155;--color-bg-elevated: #1E293B;--color-bg-overlay: rgba(15, 23, 42, .8);--color-bg-modal: rgba(15, 23, 42, .95);--color-surface-100: #1E293B;--color-surface-200: #334155;--color-surface-300: #475569;--color-text-primary: #F8FAFC;--color-text-secondary: #CBD5E1;--color-text-tertiary: #94A3B8;--color-text-muted: #64748B;--color-text-inverse: #0F172A;--color-border-subtle: rgba(255, 255, 255, .08);--color-border-default: rgba(255, 255, 255, .12);--color-border-accent: rgba(99, 102, 241, .4);--color-border-focus: rgba(99, 102, 241, .8);--color-mafia-red: #DC2626;--color-mafia-black: #1F2937;--color-crocodile-green: #10B981;--color-hat-yellow: #FBBF24;--color-spy-purple: #8B5CF6;--font-display: "Outfit", "Space Grotesk", system-ui, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-logo: "Creepster", cursive;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--size-xs: 24px;--size-sm: 32px;--size-md: 40px;--size-lg: 48px;--size-xl: 56px;--size-2xl: 64px;--touch-target-min: 44px;--radius-none: 0;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-primary: 0 4px 14px 0 rgba(99, 102, 241, .4);--shadow-primary-lg: 0 8px 24px 0 rgba(99, 102, 241, .5);--shadow-success: 0 4px 14px 0 rgba(16, 185, 129, .4);--shadow-error: 0 4px 14px 0 rgba(244, 63, 94, .4);--glow-primary: 0 0 40px rgba(99, 102, 241, .3);--glow-success: 0 0 40px rgba(16, 185, 129, .3);--glow-error: 0 0 40px rgba(244, 63, 94, .3);--duration-instant: 0ms;--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .5s;--duration-slower: .7s;--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--transition-colors: color var(--duration-fast) var(--ease-in-out), background-color var(--duration-fast) var(--ease-in-out), border-color var(--duration-fast) var(--ease-in-out);--transform: transform var(--duration-normal) var(--ease-out);--transition-opacity: opacity var(--duration-fast) var(--ease-in-out);--transition-all: all var(--duration-normal) var(--ease-out);--z-hide: -1;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--z-max: 9999;--gradient-primary: linear-gradient(135deg, #6366F1 0%, #818CF8 100%);--gradient-secondary: linear-gradient(135deg, #F472B6 0%, #EC4899 100%);--gradient-success: linear-gradient(135deg, #34D399 0%, #10B981 100%);--gradient-error: linear-gradient(135deg, #F87171 0%, #EF4444 100%);--gradient-hero: linear-gradient(135deg, #6366F1 0%, #F472B6 100%);--gradient-card: linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,0) 100%);--gradient-surface: linear-gradient(180deg, rgba(255,255,255,.03) 0%, transparent 100%);--timer-size-sm: 48px;--timer-size-md: 64px;--timer-size-lg: 80px;--timer-stroke-width: 4px;--timer-color-normal: var(--color-primary-500);--timer-color-warning: var(--color-warning-500);--timer-color-danger: var(--color-error-500);--card-padding-sm: var(--space-3);--card-padding-md: var(--space-4);--card-padding-lg: var(--space-6);--card-border-width: 1px;--btn-height-sm: 32px;--btn-height-md: 40px;--btn-height-lg: 48px;--btn-padding-sm: 0 var(--space-3);--btn-padding-md: 0 var(--space-4);--btn-padding-lg: 0 var(--space-6);--input-height: 44px;--input-padding: 0 var(--space-4);--input-border-width: 1px;--breakpoint-xs: 320px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px}[data-theme=dark]{color-scheme:dark}@media(prefers-reduced-motion:reduce){:root{--duration-fast: 0ms;--duration-normal: 0ms;--duration-slow: 0ms;--duration-slower: 0ms}}@media(prefers-contrast:high){:root{--color-border-subtle: rgba(255, 255, 255, .3);--color-border-default: rgba(255, 255, 255, .5);--color-text-muted: #CBD5E1}}
