:root{--primary-color: #667eea;--secondary-color: #764ba2;--danger-color: #f44336;--success-color: #4CAF50;--warning-color: #ff9800;--background-dark: #0f0f23;--background-light: #1a1a2e;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .5)}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background:var(--background-dark);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;height:auto}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-bounce{animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(0);animation-timing-function:cubic-bezier(0,0,.2,1)}}.loader-logo{width:80px;height:80px;object-fit:contain;animation:loader-pulse 1.5s ease-in-out infinite}@keyframes loader-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.home-page{min-height:100vh;background:linear-gradient(180deg,#0a0a0f,#1a1a2e,#0d0d1a);padding:20px 20px 120px}.home-header{text-align:center;padding:20px 0 30px}.home-logo{width:160px;height:160px;margin:0 auto 20px;border-radius:50%;overflow:hidden;position:relative;box-shadow:0 10px 50px #ff6b6b66,0 0 80px #c445694d,inset 0 0 30px #ff6b6b33;animation:logoGlow 3s ease-in-out infinite;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#1a1a2e,#0a0a15);border:3px solid rgba(255,107,107,.3)}.home-logo img{width:100%;height:100%;object-fit:cover;border-radius:50%}.logo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.logo-fallback svg{width:100%;height:100%}@keyframes logoGlow{0%,to{box-shadow:0 10px 50px #ff6b6b66,0 0 80px #c445694d,inset 0 0 30px #ff6b6b33;transform:scale(1)}50%{box-shadow:0 15px 60px #ff6b6b99,0 0 100px #c4456980,inset 0 0 40px #ff6b6b4d;transform:scale(1.02)}}.home-header h1{font-size:42px;margin:0;font-weight:900;letter-spacing:8px;text-transform:uppercase;background:linear-gradient(180deg,#fff,#ff6b6b,#c44569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(255,107,107,.5);filter:drop-shadow(0 2px 4px rgba(0,0,0,.8))}.home-subtitle{color:#ffffffe6;margin-top:12px;font-size:14px;font-weight:500;letter-spacing:3px;text-transform:uppercase;background:linear-gradient(90deg,#a8edea,#fed6e3,#a8edea);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s linear infinite}@keyframes shimmer{to{background-position:200% center}}.home-section{margin-bottom:32px}.home-section h2{color:#fff;font-size:18px;margin-bottom:16px;font-weight:600}.btn{border:none;border-radius:16px;padding:16px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:12px;position:relative;overflow:hidden}.btn-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.btn--primary{background:linear-gradient(135deg,#ff6b6b,#c44569);color:#fff;width:100%;box-shadow:0 4px 20px #ff6b6b66}.btn--primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:.5s}.btn--primary:hover:before{left:100%}.btn--primary:hover{transform:translateY(-3px);box-shadow:0 10px 30px #ff6b6b80}.btn--primary:active{transform:translateY(-1px)}.btn--secondary{background:#ffffff1a;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.btn--secondary:hover{background:#fff3;border-color:#ffffff4d}.btn--large{padding:20px 32px;font-size:18px;border-radius:20px}.join-code{display:flex;gap:12px;margin-top:16px}.join-code input{flex:1;padding:16px;border-radius:16px;border:2px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff;font-size:18px;text-align:center;text-transform:uppercase;letter-spacing:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s}.join-code input::placeholder{color:#fff6;letter-spacing:normal;font-size:14px;text-transform:none}.join-code input:focus{outline:none;border-color:#ff6b6b;box-shadow:0 0 20px #ff6b6b4d}.rooms-list{display:flex;flex-direction:column;gap:12px}.room-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#ffffff0d;border-radius:16px;cursor:pointer;transition:all .3s;border:1px solid rgba(255,255,255,.1)}.room-item:hover{background:#ffffff1a;transform:translate(8px);border-color:#ff6b6b4d}.room-item__info h3{color:#fff;font-size:16px;margin:0 0 6px;font-weight:600}.room-item__info p{color:#fff9;font-size:13px;margin:0;display:flex;align-items:center;gap:8px}.room-item__icon{display:inline-flex;width:14px;height:14px;opacity:.6}.room-item__icon svg{width:100%;height:100%}.room-item__code{background:linear-gradient(135deg,#ff6b6b33,#c4456933);color:#ff6b6b;padding:10px 14px;border-radius:12px;font-family:Monaco,Consolas,monospace;font-size:14px;font-weight:700;letter-spacing:2px;border:1px solid rgba(255,107,107,.3)}.home-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:linear-gradient(180deg,#0000,#000000f2 20%);padding:20px 12px 16px;gap:8px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.home-nav button{flex:1;padding:12px 8px;border:none;background:#ffffff0d;color:#ffffffb3;font-size:11px;cursor:pointer;border-radius:16px;transition:all .3s;display:flex;flex-direction:column;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.1)}.home-nav button:hover{background:#ff6b6b26;color:#fff;border-color:#ff6b6b4d;transform:translateY(-2px)}.nav-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center}.nav-icon svg{width:100%;height:100%}.nav-label{font-weight:500}.audio-player{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#0000,#000000e6);padding:16px;z-index:1000}.audio-player__controls{display:flex;align-items:center;gap:12px;margin-bottom:12px}.audio-player__btn{width:48px;height:48px;border-radius:50%;border:none;background:#2196f3;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.audio-player__btn:hover{background:#1976d2;transform:scale(1.05)}.audio-player__btn--stop{background:#f44336}.audio-player__btn--stop:hover{background:#d32f2f}.audio-player__volume{display:flex;align-items:center;gap:8px;flex:1;color:#fff}.audio-player__slider{flex:1;height:4px;border-radius:2px;background:#ffffff4d;appearance:none;cursor:pointer}.audio-player__slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:#2196f3;cursor:pointer}.audio-player__subtitles{background:#000c;border-radius:8px;padding:12px 16px;max-height:120px;overflow-y:auto}.audio-player__subtitles p{margin:0;color:#fff;font-size:14px;line-height:1.5;text-align:center}.player-card{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff1a;border-radius:12px;transition:all .2s;position:relative}.player-card--selectable{cursor:pointer}.player-card--selectable:hover{background:#fff3}.player-card--selected{background:#2196f34d;border:2px solid #2196F3}.player-card--current{border:2px solid #4CAF50}.player-card--dead{opacity:.5;filter:grayscale(1)}.player-card__avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;position:relative;flex-shrink:0}.player-card__avatar img{width:100%;height:100%;object-fit:cover}.player-card__avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700}.player-card__dead-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;font-size:24px}.player-card__info{flex:1;min-width:0}.player-card__name{font-size:16px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-card__role{font-size:12px;padding:2px 8px;border-radius:4px;display:inline-block;margin-top:4px}.player-card__role--civilian{background:#4caf504d;color:#81c784}.player-card__role--mafia,.player-card__role--don{background:#f443364d;color:#ef5350}.player-card__role--sheriff{background:#2196f34d;color:#64b5f6}.player-card__role--doctor{background:#9c27b04d;color:#ba68c8}.player-card__username{font-size:12px;color:#fff9;margin-top:2px}.player-card__check{width:24px;height:24px;background:#4caf50;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700}.game-page{min-height:100vh;background:linear-gradient(180deg,#0f0f23,#1a1a2e);padding:20px 20px 120px}.game-page--loading{display:flex;flex-direction:column;align-items:center;justify-content:center}.loader{font-size:64px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.game-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#ffffff0d;border-radius:12px;margin-bottom:16px}.game-header__phase{font-size:18px;font-weight:700;color:#fff}.game-header__day{color:#ffffffb3;font-size:14px}.game-header__timer{background:#f44336;color:#fff;padding:8px 16px;border-radius:20px;font-weight:700;font-size:20px;animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.role-badge{text-align:center;padding:12px 24px;border-radius:20px;font-size:16px;font-weight:700;margin-bottom:16px}.role-badge--civilian{background:#4caf5033;color:#81c784;border:2px solid #4CAF50}.role-badge--mafia,.role-badge--don{background:#f4433633;color:#ef5350;border:2px solid #f44336}.role-badge--sheriff{background:#2196f333;color:#64b5f6;border:2px solid #2196F3}.role-badge--doctor{background:#9c27b033;color:#ba68c8;border:2px solid #9C27B0}.players-section{margin-bottom:20px}.players-section h3{color:#fff;font-size:16px;margin-bottom:12px}.players-grid{display:flex;flex-direction:column;gap:8px}.mafia-section{background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:12px;padding:16px;margin-bottom:20px}.mafia-section h3{color:#ef5350;font-size:14px;margin:0 0 8px}.mafia-members{display:flex;flex-wrap:wrap;gap:8px}.mafia-members span{background:#f4433633;color:#ef5350;padding:4px 12px;border-radius:12px;font-size:14px}.action-bar{position:fixed;bottom:80px;left:20px;right:20px}.btn--action{width:100%;padding:20px;font-size:18px;font-weight:700;background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff;border:none;border-radius:16px;cursor:pointer;transition:all .2s}.btn--action:hover{transform:translateY(-2px);box-shadow:0 10px 20px #f443364d}.game-over{position:fixed;inset:0;background:#000000e6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;padding:20px}.game-over h2{color:#fff;font-size:28px;text-align:center;margin-bottom:24px}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:#1a1a2e;border-radius:20px;padding:32px;max-width:400px;width:100%;text-align:center}.modal h2{color:#fff;margin:0 0 24px}.role-display{font-size:32px;padding:24px;border-radius:16px;margin-bottom:16px}.role-display--civilian{background:#4caf5033}.role-display--mafia,.role-display--don{background:#f4433633}.role-display--sheriff{background:#2196f333}.role-display--doctor{background:#9c27b033}.role-description{color:#fffc;line-height:1.6;margin-bottom:24px}.btn--primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s}.btn--primary:hover{transform:translateY(-2px)}.lobby-page{min-height:100vh;background:linear-gradient(180deg,#0f0f23,#1a1a2e);padding:20px 20px 140px}.lobby-page--loading{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ffffffb3}.loader{width:80px;height:80px;animation:pulse 1.5s ease-in-out infinite}.loader svg{width:100%;height:100%;stroke:#ff6b6b}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.lobby-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.btn-back{background:#ffffff1a;border:none;color:#fff;padding:10px 18px;border-radius:12px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px;font-size:14px}.btn-back:hover{background:#ff6b6b33;color:#ff6b6b}.lobby-title{color:#fff;font-size:22px;margin:0;flex:1;font-weight:700}.room-info{display:flex;justify-content:space-between;background:linear-gradient(145deg,#ffffff14,#ffffff08);border-radius:16px;padding:18px;margin-bottom:20px;border:1px solid rgba(255,255,255,.1)}.room-info__item{display:flex;flex-direction:column;align-items:center;gap:6px}.room-info__label{color:#ffffff80;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.room-info__value{color:#fff;font-size:20px;font-weight:700}.room-info__status{color:#4ade80;font-size:14px;font-weight:700;display:flex;align-items:center;gap:6px}.room-info__status:before{content:"";width:8px;height:8px;background:#4ade80;border-radius:50%;animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.invite-section{background:linear-gradient(135deg,#ff6b6b26,#c4456926);border:1px solid rgba(255,107,107,.3);border-radius:20px;padding:24px;text-align:center;margin-bottom:24px}.invite-section h3{color:#fff;margin:0 0 16px;font-size:16px;display:flex;align-items:center;justify-content:center;gap:8px}.invite-actions{display:flex;gap:12px;justify-content:center}.btn-invite{background:linear-gradient(135deg,#ff6b6b,#c44569);border:none;color:#fff;padding:14px 28px;border-radius:14px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:8px;box-shadow:0 4px 15px #ff6b6b4d}.btn-invite:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff6b6b66}.room-code{color:#ffffff80;font-size:13px;margin-top:16px}.room-code strong{color:#ff6b6b;font-family:Monaco,Consolas,monospace;letter-spacing:3px;font-size:16px;background:#ff6b6b1a;padding:4px 12px;border-radius:8px}.players-section{margin-bottom:24px}.players-section h3{color:#fff;font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.players-list{display:flex;flex-direction:column;gap:10px}.player-slot{display:flex;align-items:center;gap:14px;padding:14px 18px;background:linear-gradient(145deg,#ffffff14,#ffffff08);border-radius:14px;border:1px solid rgba(255,255,255,.1);transition:all .3s}.player-slot:hover{background:#ffffff1a}.player-slot--host{border-color:#ffd70066;background:linear-gradient(145deg,#ffd7001a,#ffd7000d)}.player-slot--empty{border:2px dashed rgba(255,255,255,.15);background:transparent}.player-slot__icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:10px}.player-slot__icon svg{width:20px;height:20px;stroke:#fff9}.player-slot--empty .player-slot__icon svg{stroke:#ffffff4d}.player-slot__text{color:#fffc;font-size:15px;font-weight:500}.player-slot--empty .player-slot__text{color:#ffffff4d}.warning-message{background:linear-gradient(135deg,#fbbf241a,#fbbf240d);border:1px solid rgba(251,191,36,.3);color:#fbbf24;padding:18px;border-radius:14px;text-align:center;margin-bottom:20px;font-size:14px}.warning-message span{color:#ffffff80;font-size:12px;display:block;margin-top:6px}.action-bar{position:fixed;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,rgba(15,15,35,.98),rgba(15,15,35,.8),transparent)}.btn-start{width:100%;padding:20px;font-size:17px;font-weight:700;background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border:none;border-radius:18px;cursor:pointer;transition:all .3s;box-shadow:0 4px 20px #4ade8066;display:flex;align-items:center;justify-content:center;gap:10px}.btn-start:hover:not(.btn-start--disabled){transform:translateY(-3px);box-shadow:0 8px 30px #4ade8080}.btn-start--disabled{background:#ffffff1a;color:#fff6;cursor:not-allowed;box-shadow:none}.waiting-message{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:12px;padding:24px 20px;background:linear-gradient(to top,rgba(15,15,35,.98),rgba(15,15,35,.8),transparent);color:#ffffffb3;font-size:14px}.waiting-icon{width:24px;height:24px;animation:rotate 2s linear infinite}.waiting-icon svg{width:100%;height:100%}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.invite-icon,.section-icon{display:inline-flex;width:20px;height:20px;vertical-align:middle}.invite-icon svg,.section-icon svg{width:100%;height:100%}.host-badge{display:inline-flex;width:18px;height:18px;color:gold;margin-left:6px;vertical-align:middle}.host-badge svg{width:100%;height:100%}.btn-icon{display:inline-flex;width:20px;height:20px}.btn-icon svg{width:100%;height:100%}.btn-back svg{width:16px;height:16px}.btn-invite svg{width:18px;height:18px}.settings-page{min-height:100vh;background:linear-gradient(180deg,#0f0f23,#1a1a2e);padding:20px 20px 100px}.settings-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.btn-back{background:#ffffff1a;border:none;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;transition:all .2s}.settings-title{color:#fff;font-size:24px;margin:0}.settings-section{background:#ffffff0d;border-radius:16px;padding:20px;margin-bottom:16px}.settings-section__title{color:#fff;font-size:16px;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05)}.setting-item:last-child{border-bottom:none}.setting-item--column{flex-direction:column;align-items:stretch;gap:12px}.setting-item__info{display:flex;flex-direction:column;gap:4px}.setting-item__label{color:#fff;font-size:14px}.setting-item__desc{color:#ffffff80;font-size:12px}.toggle{position:relative;display:inline-block;width:50px;height:28px}.toggle input{opacity:0;width:0;height:0}.toggle__slider{position:absolute;cursor:pointer;inset:0;background:#fff3;border-radius:28px;transition:.3s}.toggle__slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.toggle input:checked+.toggle__slider{background:linear-gradient(135deg,#667eea,#764ba2)}.toggle input:checked+.toggle__slider:before{transform:translate(22px)}.volume-slider{width:100%;height:6px;appearance:none;background:#fff3;border-radius:3px;outline:none}.volume-slider::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;cursor:pointer}.volume-slider::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;cursor:pointer;border:none}.voice-options{display:flex;gap:12px}.voice-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:#ffffff0d;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s}.voice-option--active{background:#667eea33;border-color:#667eea}.voice-option__icon{font-size:32px}.voice-option__icon-img{width:56px;height:56px;object-fit:contain;border-radius:50%}.voice-option__label{color:#fff;font-size:12px}.language-options{display:flex;flex-direction:column;gap:8px}.language-option{padding:16px;background:#ffffff0d;border:2px solid transparent;border-radius:12px;color:#fff;font-size:14px;text-align:left;cursor:pointer;transition:all .2s}.language-option--active{background:#667eea33;border-color:#667eea}.about-info{text-align:center;color:#ffffffb3;font-size:14px;line-height:1.8}.about-info strong{color:#fff;font-size:18px}.copyright{color:#fff6;font-size:12px;margin-top:8px}.action-bar{position:fixed;bottom:20px;left:20px;right:20px}.btn-save{width:100%;padding:18px;font-size:16px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;cursor:pointer;transition:all .2s}.btn-save:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.passport-section{background:transparent;padding:0;margin-bottom:100px}.passport-section .settings-section__title{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:14px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.passport-section .section-icon{width:24px;height:24px}.passport-card{position:relative;background:linear-gradient(145deg,#1a365d,#0c1929);border-radius:16px;overflow:hidden;border:3px solid #2563eb;box-shadow:0 0 0 1px #ffffff1a,0 20px 40px #0006,inset 0 1px #ffffff1a}.passport-card:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(37,99,235,.03) 2px,rgba(37,99,235,.03) 4px);pointer-events:none;z-index:1}.passport-header{background:linear-gradient(135deg,#1e40af,#1d4ed8,#2563eb);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #3b82f6;position:relative;z-index:2}.passport-header__emblem{font-size:1.8rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.passport-header__text{display:flex;flex-direction:column;align-items:center;gap:2px}.passport-header__country{color:#fff;font-size:.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase}.passport-header__type{color:#93c5fd;font-size:.85rem;font-weight:800;letter-spacing:3px}.passport-body{display:flex;gap:20px;padding:20px;position:relative;z-index:2}.passport-photo{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px}.passport-photo img{width:100px;height:120px;object-fit:cover;border:3px solid #3b82f6;border-radius:8px;box-shadow:0 4px 12px #0006,inset 0 0 0 1px #ffffff1a}.passport-photo__id{background:linear-gradient(90deg,#dc2626,#b91c1c);color:#fff;font-size:.7rem;font-weight:800;padding:4px 12px;border-radius:4px;letter-spacing:2px;font-family:Courier New,monospace}.passport-info{flex:1;display:flex;flex-direction:column;gap:10px}.passport-field{display:flex;flex-direction:column;gap:2px}.passport-field__label{color:#60a5fa;font-size:.6rem;font-weight:600;letter-spacing:1px;text-transform:uppercase}.passport-field__value{color:#fff;font-size:.95rem;font-weight:700;letter-spacing:1px;font-family:Arial,sans-serif}.passport-field__value--highlight{color:#fbbf24;font-size:.85rem}.passport-field--tech{margin-top:4px}.passport-tech-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.tech-badge{font-size:.55rem;font-weight:700;padding:3px 8px;border-radius:4px;letter-spacing:.5px;text-transform:uppercase;border:1px solid}.tech-badge--nodejs{background:#68a06333;color:#68a063;border-color:#68a063}.tech-badge--nestjs{background:#e0234e33;color:#e0234e;border-color:#e0234e}.tech-badge--express{background:#ffffff1a;color:#fff;border-color:#666}.tech-badge--postgres{background:#33679133;color:#336791;border-color:#336791}.tech-badge--mongo{background:#4db33d33;color:#4db33d;border-color:#4db33d}.tech-badge--prisma{background:#2d37484d;color:#5a67d8;border-color:#5a67d8}.tech-badge--redis{background:#dc262633;color:#dc382d;border-color:#dc382d}.passport-contacts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:16px 20px;background:#0000004d;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:2}.passport-contact{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#ffffff0d;border-radius:8px;color:#93c5fd;text-decoration:none;font-size:.75rem;font-weight:500;transition:all .2s ease;border:1px solid rgba(255,255,255,.1)}.passport-contact:hover{background:#3b82f633;border-color:#3b82f6;color:#fff;transform:translateY(-2px)}.passport-contact img{width:18px;height:18px}.passport-contact__icon{font-size:1rem}.passport-mrz{background:linear-gradient(180deg,#0f172a,#020617);padding:12px 20px;border-top:2px solid #1e40af;position:relative;z-index:2}.passport-mrz__line{font-family:OCR A,Courier New,monospace;font-size:.65rem;color:#64748b;letter-spacing:2px;line-height:1.6;word-break:break-all}.passport-stamp{position:absolute;bottom:80px;right:20px;z-index:3;transform:rotate(-15deg);opacity:.85}.passport-stamp__circle{width:70px;height:70px;border:3px solid #22c55e;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#22c55e1a;box-shadow:0 0 20px #22c55e4d}.passport-stamp__text{color:#22c55e;font-size:.55rem;font-weight:800;letter-spacing:1px}.passport-stamp__check{color:#22c55e;font-size:1.5rem;font-weight:700;line-height:1}.passport-card:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),rgba(255,255,255,.1),rgba(255,255,255,.05),transparent);animation:holographic 4s ease-in-out infinite;z-index:4;pointer-events:none}@keyframes holographic{0%{left:-100%}50%{left:100%}to{left:100%}}.stats-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px;color:#fff}.stats-page--loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh}.stats-page--loading .loader{font-size:4rem;animation:pulse 1s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.stats-header{display:flex;align-items:center;gap:15px;margin-bottom:25px}.stats-header h1{margin:0;font-size:1.5rem;display:flex;align-items:center;gap:10px}.header-icon{width:32px;height:32px}.section-icon{font-size:1.2rem;vertical-align:middle;margin-right:6px}.stats-user{display:flex;align-items:center;gap:15px;background:#ffffff1a;padding:20px;border-radius:15px;margin-bottom:25px}.stats-user__avatar{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:2rem;overflow:hidden}.stats-user__avatar img{width:100%;height:100%;object-fit:cover}.stats-user__info h2{margin:0 0 5px;font-size:1.3rem}.stats-user__info p{margin:0;color:#fff9}.stats-overview,.stats-roles,.stats-streaks{margin-bottom:25px}.stats-overview h3,.stats-roles h3,.stats-streaks h3{margin:0 0 15px;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{background:#ffffff1a;padding:20px;border-radius:12px;text-align:center;position:relative}.stat-card__icon{width:36px;height:36px;margin-bottom:10px}.stat-card--primary{border-left:4px solid #667eea}.stat-card--success{border-left:4px solid #2ecc71}.stat-card--danger{border-left:4px solid #e74c3c}.stat-card--info{border-left:4px solid #3498db}.stat-card__value{display:block;font-size:2rem;font-weight:700;margin-bottom:5px}.stat-card__label{font-size:.85rem;color:#ffffffb3}.role-stats{display:flex;flex-direction:column;gap:10px}.role-stat{display:flex;align-items:center;gap:15px;background:#ffffff1a;padding:15px;border-radius:10px}.role-stat__icon{font-size:1.8rem}.role-stat__info{display:flex;flex-direction:column}.role-stat__name{font-weight:600;margin-bottom:3px}.role-stat__value{font-size:.85rem;color:#fff9}.streak-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.streak-card{background:linear-gradient(135deg,#ff980033,#ff572233);padding:20px;border-radius:12px;text-align:center;border:1px solid rgba(255,152,0,.3)}.streak-card__icon{font-size:2rem;display:block;margin-bottom:10px}.streak-card__icon-img{width:40px;height:40px;display:block;margin:0 auto 10px}.streak-card__value{display:block;font-size:2rem;font-weight:700;color:#ff9800}.streak-card__label{font-size:.85rem;color:#ffffffb3}.stats-user__avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.role-stat__icon-img{width:48px;height:48px;object-fit:contain;border-radius:8px}.leaderboard-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px;color:#fff}.leaderboard-page--loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh}.leaderboard-page--loading .loader{font-size:4rem;animation:bounce .5s infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-15px)}}.leaderboard-header{display:flex;align-items:center;gap:15px;margin-bottom:20px}.leaderboard-header h1{margin:0;font-size:1.5rem}.filter-tabs{display:flex;gap:10px;margin-bottom:25px}.filter-tab{flex:1;padding:10px;background:#ffffff1a;border:none;color:#fff;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s}.filter-tab--active{background:linear-gradient(135deg,#667eea,#764ba2)}.podium{display:flex;justify-content:center;align-items:flex-end;gap:10px;margin-bottom:30px;padding:20px 0}.podium-item{display:flex;flex-direction:column;align-items:center;background:#ffffff1a;border-radius:12px;padding:15px 12px;width:95px}.podium-item--1{background:linear-gradient(135deg,#ffd7004d,#ffc10733);border:2px solid #ffd700;transform:scale(1.05);width:100px}.podium-item--2{background:linear-gradient(135deg,#c0c0c04d,#a9a9a933);border:2px solid #c0c0c0}.podium-item--3{background:linear-gradient(135deg,#cd7f324d,#b8733333);border:2px solid #cd7f32}.podium-order--1{order:2}.podium-order--2{order:1}.podium-order--3{order:3}.podium-item__avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:8px;overflow:hidden}.podium-item__avatar img{width:100%;height:100%;object-fit:cover}.podium-item__rank{font-size:1.3rem;margin-bottom:4px}.podium-item__name{font-weight:600;font-size:.8rem;text-align:center;margin-bottom:4px}.podium-item__stats{display:flex;flex-direction:column;align-items:center;font-size:.7rem;color:#ffffffb3;line-height:1.3}.leaders-list{display:flex;flex-direction:column;gap:10px}.leader-item{display:flex;align-items:center;gap:12px;background:#ffffff1a;padding:15px;border-radius:12px;transition:transform .2s}.leader-item:active{transform:scale(.98)}.leader-item--gold{background:linear-gradient(135deg,#ffd70033,#ffc1071a);border:1px solid rgba(255,215,0,.3)}.leader-item--silver{background:linear-gradient(135deg,#c0c0c033,#a9a9a91a);border:1px solid rgba(192,192,192,.3)}.leader-item--bronze{background:linear-gradient(135deg,#cd7f3233,#b873331a);border:1px solid rgba(205,127,50,.3)}.leader-item__rank{font-size:1.2rem;min-width:40px;text-align:center}.leader-item__avatar{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;overflow:hidden}.leader-item__avatar img{width:100%;height:100%;object-fit:cover}.leader-item__info{flex:1}.leader-item__name{font-weight:600;margin-bottom:2px}.leader-item__username{font-size:.8rem;color:#fff9}.leader-item__stats{text-align:right}.leader-item__wins{font-weight:600;margin-bottom:2px}.leader-item__rate{font-size:.85rem;color:#fff9}.rules-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px 20px 40px;color:#fff}.rules-header{display:flex;align-items:center;gap:15px;margin-bottom:25px}.rules-header h1{margin:0;font-size:1.5rem}.rules-section{margin-bottom:30px}.rules-section h2{font-size:1.2rem;margin:0 0 15px;color:#fff}.rules-section>p{color:#fffc;line-height:1.6}.role-card{display:flex;gap:15px;background:#ffffff1a;padding:15px;border-radius:12px;margin-bottom:10px;border-left:4px solid #3498db}.role-card--mafia{border-left-color:#e74c3c}.role-card--don{border-left-color:#9b59b6}.role-card--sheriff{border-left-color:#f39c12}.role-card--doctor{border-left-color:#2ecc71}.role-card__icon{font-size:2rem;min-width:50px;display:flex;align-items:center;justify-content:center}.role-card__icon-img{width:50px;height:50px;object-fit:contain;border-radius:8px}.role-card__content h3{margin:0 0 5px;font-size:1rem}.role-card__content p{margin:0;font-size:.9rem;color:#ffffffb3}.section-icon{width:24px;height:24px;vertical-align:middle;margin-right:8px}.phase-list{display:flex;flex-direction:column;gap:15px}.phase-item{display:flex;gap:15px;align-items:center}.phase-item__number{width:35px;height:35px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.phase-item__icon{width:48px;height:48px;border-radius:12px;flex-shrink:0}.phase-item__content{background:#ffffff1a;padding:15px;border-radius:10px;flex:1}.phase-item__content h4{margin:0 0 5px;font-size:.95rem}.phase-item__content p{margin:0;font-size:.85rem;color:#ffffffb3}.win-conditions{display:flex;flex-direction:column;gap:12px}.win-condition{display:flex;gap:15px;align-items:center;background:#ffffff1a;padding:15px;border-radius:12px}.win-condition--civilian{border:1px solid rgba(46,204,113,.3)}.win-condition--mafia{border:1px solid rgba(231,76,60,.3)}.win-condition__icon{font-size:2rem}.win-condition__icon-img{width:48px;height:48px;object-fit:contain;border-radius:8px}.win-condition__text h4{margin:0 0 3px;font-size:.95rem}.win-condition__text p{margin:0;font-size:.85rem;color:#fff9}.rules-list{list-style:none;padding:0;margin:0}.rules-list li{background:#ffffff1a;margin-bottom:8px;border-radius:8px;padding:12px 15px 12px 40px;position:relative}.rules-list li:before{content:"✓";position:absolute;left:15px;color:#2ecc71;font-weight:700}.create-room-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px 20px 100px;color:#fff}.create-room-header{display:flex;align-items:center;gap:15px;margin-bottom:25px}.create-room-header h1{margin:0;font-size:1.5rem}.btn-back{background:#ffffff1a;border:none;color:#fff;padding:8px 15px;border-radius:8px;cursor:pointer;transition:background .3s}.btn-back:hover{background:#fff3}.create-room-form{display:flex;flex-direction:column;gap:25px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-weight:600;font-size:1rem}.form-group input[type=text]{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:15px;color:#fff;font-size:1rem;transition:border-color .3s}.form-group input[type=text]:focus{outline:none;border-color:#667eea}.form-group input[type=text]::placeholder{color:#fff6}.form-hint{font-size:.85rem;color:#ffffff80;margin:5px 0 0}.player-count{display:flex;gap:20px}.player-count__item{flex:1;display:flex;flex-direction:column;gap:8px}.player-count__label{font-size:.85rem;color:#fff9}.number-input{display:flex;align-items:center;background:#ffffff1a;border-radius:10px;overflow:hidden}.number-input button{width:45px;height:45px;background:#ffffff1a;border:none;color:#fff;font-size:1.3rem;cursor:pointer;transition:background .3s}.number-input button:hover:not(:disabled){background:#fff3}.number-input button:disabled{opacity:.3;cursor:not-allowed}.number-input span{flex:1;text-align:center;font-size:1.3rem;font-weight:700}.time-setting{display:flex;align-items:center;justify-content:space-between;background:#ffffff1a;padding:12px 15px;border-radius:10px;margin-bottom:10px}.time-setting__info{display:flex;align-items:center;gap:10px}.time-setting__icon{font-size:1.3rem}.time-setting__label{font-size:.95rem}.time-setting select{background:#ffffff26;border:none;color:#fff;padding:8px 12px;border-radius:8px;font-size:.9rem;cursor:pointer}.time-setting select option{background:#1a1a2e;color:#fff}.story-variant{display:flex;align-items:center;gap:15px}.story-variant__btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;padding:12px 20px;border-radius:10px;cursor:pointer;font-size:1rem;transition:transform .2s}.story-variant__btn:active{transform:scale(.95)}.story-variant__current{font-size:1.1rem;font-weight:600;color:#667eea}.roles-preview{display:flex;flex-wrap:wrap;gap:10px}.role-preview{display:flex;align-items:center;gap:8px;background:#ffffff14;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.role-preview:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.role-preview__icon-wrap{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.role-preview__icon-wrap img{width:100%;height:100%;object-fit:cover;border-radius:10px}.role-preview__icon-wrap svg{width:24px;height:24px}.role-preview--civilian .role-preview__icon-wrap{background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 4px 12px #3498db66}.role-preview--mafia .role-preview__icon-wrap{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 12px #e74c3c66}.role-preview--don .role-preview__icon-wrap{background:linear-gradient(135deg,#9b59b6,#8e44ad);box-shadow:0 4px 12px #9b59b666}.role-preview--sheriff .role-preview__icon-wrap{background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 4px 12px #f39c1266}.role-preview--doctor .role-preview__icon-wrap{background:linear-gradient(135deg,#2ecc71,#27ae60);box-shadow:0 4px 12px #2ecc7166}.role-preview__count{font-weight:700;font-size:1.3rem;color:#fff;min-width:24px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.role-preview__name{font-size:.85rem;color:#fffc;font-weight:500}.create-room-actions{position:fixed;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,rgba(26,26,46,.98) 0%,rgba(26,26,46,.8) 50%,transparent 100%)}.btn-create{width:100%;padding:18px 24px;background:linear-gradient(135deg,#2ecc71,#27ae60);border:none;border-radius:14px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #2ecc7166;display:flex;align-items:center;justify-content:center;gap:10px}.btn-create svg{width:24px;height:24px}.btn-create:hover{transform:translateY(-2px);box-shadow:0 6px 25px #2ecc7180}.btn-create:active{transform:scale(.98)}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#0f0f23;color:#fff;min-height:100vh;overflow-x:hidden}.app{min-height:100vh;position:relative}.error-toast{position:fixed;top:20px;left:20px;right:20px;background:#f44336;color:#fff;padding:16px 20px;border-radius:12px;display:flex;align-items:center;justify-content:space-between;z-index:1000;animation:slideDown .3s ease-out;box-shadow:0 4px 20px #f4433666}.error-toast button{background:transparent;border:none;color:#fff;font-size:18px;cursor:pointer;padding:4px 8px}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-left-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@supports (padding: max(0px)){.app{padding-bottom:max(20px,env(safe-area-inset-bottom))}}
