@font-face{font-family:SF Pro Display;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/SFPRODISPLAYREGULAR.OTF) format("opentype")}@font-face{font-family:SF Pro Display;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/SFPRODISPLAYMEDIUM.OTF) format("opentype")}@font-face{font-family:SF Pro Display;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/SFPRODISPLAYBOLD.OTF) format("opentype")}@font-face{font-family:SF Pro Display;font-style:italic;font-weight:600;font-display:swap;src:url(/fonts/SFPRODISPLAYSEMIBOLDITALIC.OTF) format("opentype")}@font-face{font-family:SF Pro Display;font-style:italic;font-weight:800;font-display:swap;src:url(/fonts/SFPRODISPLAYHEAVYITALIC.OTF) format("opentype")}@font-face{font-family:SF Pro Display;font-style:italic;font-weight:900;font-display:swap;src:url(/fonts/SFPRODISPLAYBLACKITALIC.OTF) format("opentype")}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:SF Pro Display,SF Pro Display,system-ui,-apple-system,sans-serif;line-height:1.5}#root{min-height:100vh;display:flex;flex-direction:column}:root{--bg-primary: #0d0d14;--bg-secondary: #1a1a2a;--bg-surface: rgba(255, 255, 255, .07);--bg-surface-hover: rgba(255, 255, 255, .12);--bg-card: rgba(255, 255, 255, .08);--bg-card-hover: rgba(255, 255, 255, .13);--text-primary: #f0f0f8;--text-secondary: #c8c8e0;--text-muted: #a0a0c0;--accent-primary: #00d4ff;--accent-primary-glow: rgba(0, 212, 255, .35);--accent-danger: #ff2255;--accent-danger-glow: rgba(255, 34, 85, .35);--accent-success: #00ff88;--accent-success-glow: rgba(0, 255, 136, .35);--accent-warning: #facc15;--accent-warning-glow: rgba(250, 204, 21, .35);--accent-gold: #f0c674;--accent-gold-glow: rgba(240, 198, 116, .4);--accent-gold-dim: rgba(240, 198, 116, .15);--border-subtle: rgba(255, 255, 255, .1);--border-accent: rgba(0, 212, 255, .35);--blur-bg: blur(12px);--font-heading: "SF Pro Display", "Orbitron", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "SF Pro Display", "Fira Code", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 8px var(--accent-primary-glow)}50%{box-shadow:0 0 20px var(--accent-primary-glow)}}@keyframes pulseGlowDanger{0%,to{box-shadow:0 0 8px var(--accent-danger-glow)}50%{box-shadow:0 0 24px var(--accent-danger-glow)}}@keyframes pulseGlowSuccess{0%,to{box-shadow:0 0 8px var(--accent-success-glow)}50%{box-shadow:0 0 20px var(--accent-success-glow)}}@keyframes cardFlipIn{0%{transform:perspective(600px) rotateY(90deg);opacity:0}60%{transform:perspective(600px) rotateY(-10deg);opacity:1}to{transform:perspective(600px) rotateY(0);opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.app-container{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 20% 50%,rgba(0,212,255,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(255,0,68,.03) 0%,transparent 50%),var(--bg-primary)}.page{flex:1;display:flex;flex-direction:column;max-width:600px;width:100%;margin:0 auto;padding:var(--space-xl) var(--space-md) calc(var(--space-xl) + 2.5rem + var(--safe-bottom));gap:var(--space-lg);animation:fadeInUp var(--transition-slow) cubic-bezier(.2,.7,.2,1) both}.page--centered{align-items:center;justify-content:center;text-align:center}.page-header{text-align:center;animation:fadeInUp var(--transition-slow) ease both}.page-header__title{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--text-primary);letter-spacing:.05em;text-transform:uppercase;text-shadow:0 0 20px var(--accent-primary-glow)}.page-header--with-logo{display:flex;align-items:center;justify-content:center;gap:.75rem}.page-header__logo{width:38px;height:38px;border-radius:8px;-webkit-user-select:none;user-select:none}.page-header__subtitle{color:var(--text-muted);font-size:.85rem;margin-top:var(--space-xs);font-family:var(--font-mono);letter-spacing:.1em}.card{background:var(--bg-card);backdrop-filter:var(--blur-bg);-webkit-backdrop-filter:var(--blur-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-accent)}.card--glow-primary{box-shadow:0 0 20px var(--accent-primary-glow),inset 0 0 20px #00d4ff05}.card--glow-danger{box-shadow:0 0 20px var(--accent-danger-glow),inset 0 0 20px #ff004405}.card--glow-success{box-shadow:0 0 20px var(--accent-success-glow),inset 0 0 20px #00ff8805}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input{padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:#ffffff0a;color:var(--text-primary);font-size:1rem;font-family:SF Pro Display,sans-serif;transition:all var(--transition-fast);outline:none}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-primary-glow);background:#00d4ff0d}.input::placeholder{color:var(--text-muted)}.select{padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#0000004d;color:var(--text-primary);font-size:.9rem;cursor:pointer;font-family:SF Pro Display,sans-serif;transition:border-color var(--transition-fast);outline:none}.select:focus{border-color:var(--accent-primary)}.select option,.settings-panel__select option{background:#1a1a2a;color:var(--text-primary)}.custom-select{position:relative;display:inline-block;min-width:7.5rem;font-family:SF Pro Display,sans-serif}.custom-select--disabled{opacity:.5;pointer-events:none}.custom-select__trigger{width:100%;display:inline-flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#0000004d;color:var(--text-primary);font-size:.9rem;font-family:SF Pro Display,sans-serif;cursor:pointer;outline:none;transition:all var(--transition-fast)}.custom-select__trigger:hover{border-color:var(--accent-primary);background:#00d4ff14}.custom-select__trigger:focus-visible{border-color:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary-glow)}.custom-select--open .custom-select__trigger{border-color:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary-glow)}.custom-select__value{flex:1;text-align:left;font-weight:600;color:var(--text-primary)}.custom-select__chevron{color:var(--accent-primary);transition:transform var(--transition-fast);flex-shrink:0}.custom-select--open .custom-select__chevron{transform:rotate(180deg)}.custom-select__menu{z-index:1000;margin:0;padding:.3rem;list-style:none;background:#1a1a2a;border:1px solid var(--border-accent);border-radius:var(--radius-sm);box-shadow:0 8px 24px #0009,0 0 12px var(--accent-primary-glow);overflow-y:auto;animation:fadeIn .12s ease both}.custom-select__option{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.custom-select__option-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.custom-select__option--active,.custom-select__option:hover{background:#00d4ff1f;color:var(--text-primary)}.custom-select__option--selected{background:#00d4ff2e;color:var(--accent-primary);font-weight:700}.custom-select__option--selected.custom-select__option--active{background:#00d4ff47}.custom-select__option--disabled{opacity:.45;cursor:not-allowed;color:var(--text-muted)}.custom-select__option--disabled.custom-select__option--active,.custom-select__option--disabled:hover{background:transparent;color:var(--text-muted)}.custom-select__check{color:var(--accent-primary);flex-shrink:0}.select,.settings-panel__select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--accent-primary) 50%),linear-gradient(135deg,var(--accent-primary) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:1.75rem!important}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.75rem 1.5rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);font-family:SF Pro Display,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);background-size:200% 100%;transition:background-position .3s}.btn:hover:after{background-position:100% 100%}.btn:active{transform:scale(.97)}.btn:disabled,.btn[aria-disabled=true]{opacity:.6;cursor:not-allowed;transform:none;background:#ffffff0a;border-color:var(--border-subtle);color:var(--text-muted);box-shadow:none}.btn--primary:disabled,.btn--success:disabled,.btn--danger:disabled{opacity:.45;background:#ffffff0f;color:var(--text-muted);border-color:var(--border-subtle)}.btn--primary{background:linear-gradient(135deg,#00b8e6,#08c);border-color:transparent;color:#001520;font-weight:700;box-shadow:0 0 16px #00b8e640}.btn--primary:hover:not(:disabled){box-shadow:0 0 24px #00b8e673;background:linear-gradient(135deg,#00ccf0,#09d)}.btn--danger{background:linear-gradient(135deg,#c03,#990026);border-color:transparent;color:#fff;font-weight:700;box-shadow:0 0 16px #cc003340}.btn--danger:hover:not(:disabled){box-shadow:0 0 24px #cc003373;background:linear-gradient(135deg,#dd0038,#aa002a)}.btn--success{background:linear-gradient(135deg,#00cc6a,#00994f);border-color:transparent;color:#001a0d;font-weight:700;box-shadow:0 0 16px #00cc6a40}.btn--success:hover:not(:disabled){box-shadow:0 0 24px #00cc6a73}.btn--ghost{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--text-muted);color:var(--text-primary)}.btn--sm{padding:.4rem 1rem;font-size:.8rem}.btn--lg{padding:1rem 2rem;font-size:1.05rem}.btn--block{width:100%}.toggle-group{display:flex;gap:0;border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;background:#0003}.toggle-group__btn{flex:1;padding:.6rem 1.5rem;border:none;background:transparent;color:var(--text-muted);font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--transition-fast);font-family:SF Pro Display,sans-serif}.toggle-group__btn--active{background:var(--accent-primary);color:#000;text-shadow:0 0 8px rgba(0,212,255,.5)}.toggle-group__btn:hover:not(.toggle-group__btn--active){color:var(--text-primary);background:var(--bg-surface)}.game-header{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:.85rem 3rem .85rem 1rem;position:relative;background:#0d0d14d9;border-bottom:1px solid var(--border-subtle);backdrop-filter:var(--blur-bg);-webkit-backdrop-filter:var(--blur-bg)}.game-header__logo{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:8px;-webkit-user-select:none;user-select:none}.game-header__label{color:var(--text-muted);font-size:.8rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em}.game-header__code{font-family:var(--font-mono);font-weight:700;font-size:1rem;color:var(--accent-primary);letter-spacing:.15em;text-shadow:0 0 10px var(--accent-primary-glow);padding:.2rem .6rem;background:#00d4ff14;border:1px solid var(--border-accent);border-radius:var(--radius-sm)}.game-header__leave{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:#ff00441a;border:1px solid rgba(255,0,68,.4);border-radius:50%;color:var(--accent-danger);font-size:.95rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);line-height:1;padding:0}.game-header__leave:hover{background:#f043;border-color:var(--accent-danger);box-shadow:0 0 8px var(--accent-danger-glow);transform:translateY(-50%) scale(1.05)}.game-header__leave:active{transform:translateY(-50%) scale(.95)}.connection-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-xl);background:radial-gradient(ellipse at center,rgba(0,212,255,.06) 0%,transparent 60%),var(--bg-primary)}.connection-screen__logo{width:96px;height:96px;border-radius:16px;margin-bottom:var(--space-md);filter:drop-shadow(0 0 18px var(--accent-primary-glow));-webkit-user-select:none;user-select:none}.connection-screen__title{font-family:var(--font-heading);font-size:2.5rem;font-weight:800;color:var(--text-primary);letter-spacing:.05em;text-transform:uppercase;text-shadow:0 0 30px var(--accent-primary-glow);animation:fadeInScale .6s ease both}.connection-screen__error{color:var(--accent-danger);text-align:center;font-size:.9rem;animation:fadeIn .3s ease both}.connection-screen__text{color:var(--text-muted);text-align:center}.spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(0,212,255,.15);border-top-color:var(--accent-primary);animation:spin .8s linear infinite}.timer-bar{width:100%;height:2.5rem;background:#0000004d;border-radius:var(--radius-md);position:relative;border:1px solid var(--border-subtle);overflow:hidden}.timer-bar__fill{position:absolute;top:0;left:0;height:100%;border-radius:var(--radius-md);transition:width 1s linear,background var(--transition-normal);z-index:1}.timer-bar__fill--safe{background:linear-gradient(90deg,#00cc6a,#0f8);box-shadow:0 0 12px var(--accent-success-glow)}.timer-bar__fill--warning{background:linear-gradient(90deg,#ca0,#facc15);box-shadow:0 0 16px var(--accent-warning-glow);animation:pulseGlow 1.5s ease infinite}.timer-bar__fill--danger{background:linear-gradient(90deg,#c03,#f04);box-shadow:0 0 20px var(--accent-danger-glow);animation:pulseGlowDanger .8s ease infinite}.timer-bar__text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;color:#fff;font-family:var(--font-mono);letter-spacing:.1em;text-shadow:0 1px 4px rgba(0,0,0,.8);z-index:2;pointer-events:none}.player-list{display:flex;flex-direction:column;gap:var(--space-sm)}.player-list__empty{color:var(--text-muted);text-align:center;padding:var(--space-md);font-style:italic}.player-list__item{display:flex;align-items:center;gap:var(--space-md);padding:.65rem 1rem;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--transition-fast);animation:slideInLeft var(--transition-normal) ease both}.player-list__item:nth-child(1){animation-delay:.02s}.player-list__item:nth-child(2){animation-delay:.06s}.player-list__item:nth-child(3){animation-delay:.1s}.player-list__item:nth-child(4){animation-delay:.14s}.player-list__item:nth-child(5){animation-delay:.18s}.player-list__item:nth-child(6){animation-delay:.22s}.player-list__item:nth-child(7){animation-delay:.26s}.player-list__item:nth-child(8){animation-delay:.3s}.player-list__item:nth-child(9){animation-delay:.34s}.player-list__item:nth-child(10){animation-delay:.38s}.player-list__item:hover{background:var(--bg-card-hover);border-color:var(--border-accent)}.player-list__item--current{background:#00d4ff0f;border-color:var(--border-accent)}.player-list__status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.player-list__status-dot--active{background:var(--accent-success);box-shadow:0 0 6px var(--accent-success-glow)}.player-list__status-dot--spectator{background:var(--text-muted)}.player-list__status-dot--disconnected{background:var(--accent-danger);box-shadow:0 0 6px var(--accent-danger-glow)}.player-list__name{flex:1;font-weight:500;font-size:.95rem;color:var(--text-primary)}.player-list__badge{font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.player-list__badge--host{background:var(--accent-warning);color:#000}.player-list__badge--you{color:var(--text-muted);font-size:.8rem}.player-list__kick{margin-left:auto;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:50%;color:var(--text-muted);font-size:.8rem;cursor:pointer;padding:0;line-height:1;flex:0 0 auto;transition:all var(--transition-fast)}.player-list__kick:hover,.player-list__kick:focus-visible{background:#ff00441f;border-color:var(--accent-danger);color:var(--accent-danger);box-shadow:0 0 8px var(--accent-danger-glow);outline:none}.voting-table{display:flex;flex-direction:column;gap:var(--space-md);align-items:center;width:100%;animation:fadeIn var(--transition-normal) ease both}.voting-table__label{color:var(--text-muted);font-size:.9rem;font-weight:500}.voting-table__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-sm);width:100%;max-width:500px}.voting-table__player-btn{padding:1rem .5rem;border-radius:var(--radius-md);border:2px solid var(--border-subtle);background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-weight:500;font-size:.9rem;text-align:center;transition:all var(--transition-fast);font-family:SF Pro Display,sans-serif;position:relative}.voting-table__player-btn:hover:not(:disabled){border-color:var(--accent-primary);background:#00d4ff0f;box-shadow:0 0 12px var(--accent-primary-glow);transform:translateY(-2px)}.voting-table__player-btn--selected{border-color:var(--accent-danger)!important;background:#ff004414!important;box-shadow:0 0 16px var(--accent-danger-glow)!important;font-weight:700}.voting-table__player-btn:disabled{opacity:.5;cursor:not-allowed}.voting-table__selected-label{font-size:.65rem;color:var(--accent-danger);margin-top:var(--space-xs);letter-spacing:.1em;font-weight:700;text-transform:uppercase}.voting-table__me-label{font-size:.65rem;color:var(--accent-primary);margin-top:var(--space-xs);letter-spacing:.1em;font-weight:700;text-transform:uppercase;opacity:.7}.voting-table__player-btn--me{border-color:#00d4ff59;background:#00d4ff0a}.voting-table__player-btn--me:hover:not(:disabled){border-color:#00d4ffb3;background:#00d4ff1a}.voting-table__actions{display:flex;gap:var(--space-md);margin-top:var(--space-sm)}.voting-table__spectator-msg{text-align:center;padding:var(--space-xl);color:var(--text-secondary);font-style:italic}.voting-table__voted-msg{text-align:center;padding:1.25rem 1rem;background:#00ff8814;border:1px solid rgba(0,255,136,.35);border-radius:var(--radius-md);color:var(--accent-success);font-weight:700;font-size:1rem;letter-spacing:.05em;box-shadow:0 0 12px var(--accent-success-glow);animation:fadeInScale .25s ease both}.role-reveal{padding:2.5rem 2rem;border-radius:var(--radius-lg);text-align:center;max-width:400px;margin:0 auto;position:relative;overflow:hidden}.role-reveal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.08;background-image:radial-gradient(2px 2px at 20px 30px,#fff,transparent),radial-gradient(2px 2px at 40px 70px,#fff,transparent),radial-gradient(2px 2px at 50px 10px,#fff,transparent),radial-gradient(2px 2px at 90px 40px,#fff,transparent),radial-gradient(2px 2px at 130px 80px,#fff,transparent),radial-gradient(2px 2px at 160px 30px,#fff,transparent);background-size:200px 100px;pointer-events:none}.role-reveal--impostor{background:linear-gradient(135deg,#2a0a0a,#3d1111,#2a0a0a);border:2px solid var(--accent-danger);box-shadow:0 0 30px var(--accent-danger-glow),inset 0 0 40px #ff00440d;animation:cardFlipIn .6s ease both}.role-reveal--non-impostor{background:linear-gradient(135deg,#0a1a0a,#0d2d0d,#0a1a0a);border:2px solid var(--accent-success);box-shadow:0 0 30px var(--accent-success-glow),inset 0 0 40px #00ff880d;animation:cardFlipIn .6s ease both}.role-reveal__label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;margin-bottom:var(--space-md);font-family:var(--font-mono)}.role-reveal__label--impostor{color:#fca5a5}.role-reveal__label--safe{color:#86efac}.role-reveal__main{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;color:#fff;line-height:1.3;text-transform:uppercase;letter-spacing:.03em}.role-reveal__sub{margin-top:var(--space-md);font-size:.85rem;color:#fca5a5;opacity:.9}.role-reveal--waiting{padding:var(--space-xl);text-align:center;color:var(--text-muted)}.result-card{background:var(--bg-card);backdrop-filter:var(--blur-bg);-webkit-backdrop-filter:var(--blur-bg);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;border:1px solid var(--border-subtle);animation:fadeInScale .4s ease both}.result-card--impostor-found{border-color:var(--accent-success);box-shadow:0 0 20px var(--accent-success-glow)}.result-card--innocent-expelled{border-color:var(--accent-danger);box-shadow:0 0 20px var(--accent-danger-glow)}.result-card--no-expulsion{border-color:var(--border-subtle)}.result-card__title{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:#fff}.result-card__sub{font-size:1rem;font-weight:600;margin-top:var(--space-sm)}.result-card__sub--success{color:var(--accent-success)}.result-card__sub--danger{color:var(--accent-danger)}.result-card__sub--neutral{color:var(--accent-warning)}.result-card__info{color:var(--text-secondary);font-size:.9rem;margin-top:var(--space-sm)}.winner-banner{width:100%;padding:var(--space-xl) var(--space-md);border-radius:var(--radius-lg);text-align:center;position:relative;overflow:hidden;animation:fadeInScale .5s ease both}.winner-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.06;background-image:radial-gradient(2px 2px at 10px 20px,#fff,transparent),radial-gradient(2px 2px at 30px 60px,#fff,transparent),radial-gradient(2px 2px at 70px 15px,#fff,transparent),radial-gradient(2px 2px at 100px 45px,#fff,transparent),radial-gradient(2px 2px at 140px 80px,#fff,transparent);background-size:150px 100px;pointer-events:none}.winner-banner--non-impostors{background:linear-gradient(135deg,#0a2a0a,#0d3d0d);border:2px solid var(--accent-success);box-shadow:0 0 40px var(--accent-success-glow)}.winner-banner--impostors{background:linear-gradient(135deg,#2a0a0a,#3d1111);border:2px solid var(--accent-danger);box-shadow:0 0 40px var(--accent-danger-glow)}.winner-banner__title{font-family:var(--font-heading);font-size:2rem;font-weight:800;color:#fff;margin-bottom:var(--space-sm);text-shadow:0 0 20px rgba(255,255,255,.15)}.winner-banner__winner{font-size:1.3rem;font-weight:700}.winner-banner__winner--non-impostors{color:var(--accent-success);text-shadow:0 0 12px var(--accent-success-glow)}.winner-banner__winner--impostors{color:#fca5a5;text-shadow:0 0 12px var(--accent-danger-glow)}.stats-card{width:100%;background:var(--bg-card);backdrop-filter:var(--blur-bg);-webkit-backdrop-filter:var(--blur-bg);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);border:1px solid var(--border-subtle);animation:fadeInUp .5s ease both}.stats-card__row{display:flex;justify-content:space-between;align-items:center}.stats-card__label{color:var(--text-secondary);font-size:.9rem}.stats-card__value{font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.spectator-info{background:#ffffff0a;border-radius:var(--radius-md);padding:var(--space-md);text-align:center;border:1px solid var(--border-subtle);animation:fadeIn .3s ease both}.spectator-info__title{color:var(--accent-warning);font-weight:600;font-size:.9rem}.spectator-info__desc{color:var(--text-muted);font-size:.85rem;margin-top:var(--space-xs)}.settings-panel{background:var(--bg-card);backdrop-filter:var(--blur-bg);-webkit-backdrop-filter:var(--blur-bg);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);border:1px solid var(--border-subtle)}.settings-panel__title{color:var(--text-secondary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.settings-panel__row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.settings-panel__label{color:var(--text-secondary);font-size:.9rem}.settings-panel__value{color:var(--text-primary);font-size:.95rem;font-weight:700;font-family:var(--font-mono);padding:.4rem .75rem;background:#00000040;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-width:3rem;text-align:center}.settings-panel__category-controls{display:flex;align-items:center;gap:.5rem}.settings-panel__manage-btn{white-space:nowrap;font-size:.75rem;padding:.35rem .7rem}.settings-panel__hint{margin:0;padding:.4rem .5rem 0;color:var(--text-muted);font-size:.75rem;font-style:italic;line-height:1.3}.settings-panel__select{padding:.4rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#0000004d;color:var(--text-primary);font-size:.85rem;cursor:pointer;outline:none;font-family:SF Pro Display,sans-serif}.settings-panel__select:focus{border-color:var(--accent-primary)}.section-header{color:var(--text-muted);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-sm)}.room-code-display{display:flex;align-items:center;gap:var(--space-md);padding:.85rem 1.1rem;background:#00d4ff14;border:1px solid var(--border-accent);border-radius:var(--radius-md);box-shadow:0 0 16px #00d4ff26}.room-code-display__code{font-family:var(--font-mono);font-size:1.6rem;font-weight:700;color:var(--accent-primary);letter-spacing:.18em;text-shadow:0 0 10px var(--accent-primary-glow)}.player-count{color:var(--text-secondary);font-size:.9rem;font-family:var(--font-mono);font-weight:600}.entry-page{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:920px;margin:0 auto;padding:1.5rem 1.25rem calc(3rem + 2.5rem + var(--safe-bottom));gap:.85rem;min-height:100vh}.entry-page__lang{position:absolute;top:calc(.75rem + var(--safe-top));left:calc(.75rem + var(--safe-left));right:calc(.75rem + var(--safe-right));display:flex;align-items:center;justify-content:space-between;gap:1rem;z-index:5}.entry-page__hero{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.35rem;margin-bottom:.25rem}.entry-page__hero-row{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.25rem}.entry-page__title{font-size:clamp(2.4rem,6vw,3.4rem);font-weight:800;letter-spacing:.04em;color:var(--accent-primary);text-shadow:0 0 12px var(--accent-primary-glow),0 0 28px var(--accent-primary-glow);margin:0}.entry-page__hero-text{display:flex;flex-direction:column;gap:.35rem;text-align:left}.entry-page__logo{width:clamp(70px,11vw,100px);height:auto;flex:0 0 auto;filter:drop-shadow(0 0 18px var(--accent-primary-glow));-webkit-user-select:none;user-select:none}.entry-page__subtitle{color:var(--text-secondary);font-size:1rem;font-weight:500;margin:0}.entry-page__modes{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;width:100%;margin-top:.5rem}@media (max-width: 720px){.entry-page__modes{grid-template-columns:1fr}}.mode-card{position:relative;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.65rem;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.mode-card--active{border-color:var(--accent-primary);box-shadow:0 0 24px var(--accent-primary-glow)}.mode-card--active:hover{transform:translateY(-2px);box-shadow:0 0 32px var(--accent-primary-glow)}.mode-card--disabled{opacity:.55;cursor:not-allowed;filter:saturate(.6)}.mode-card__header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.mode-card__title{font-size:1.4rem;font-weight:700;margin:0;letter-spacing:.02em;color:var(--text-primary)}.mode-card--active .mode-card__title{text-shadow:0 0 12px var(--accent-primary-glow)}.mode-card__meta{font-size:.78rem;font-weight:700;color:var(--accent-secondary);background:#00000059;border:1px solid var(--border-subtle);padding:.18rem .55rem;border-radius:999px;font-family:var(--font-mono);white-space:nowrap}.mode-card__desc{color:var(--text-secondary);font-size:.92rem;line-height:1.45;margin:0;flex:0 0 auto}.mode-card__form{display:flex;flex-direction:column;gap:.7rem;margin-top:.35rem;border-top:1px solid var(--border-subtle);padding-top:.75rem}.mode-card__fields{display:flex;flex-direction:column;gap:.7rem}.mode-card__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.55rem .75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#00000038}.mode-card__row-label{color:var(--text-secondary);font-size:.88rem;font-weight:500}.mode-card__badge{margin-top:auto;align-self:center;font-size:.95rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-gold);border:1px dashed var(--accent-gold);padding:.55rem 1.2rem;border-radius:999px;background:var(--accent-gold-dim);text-shadow:0 0 10px var(--accent-gold-glow);box-shadow:inset 0 0 16px #f0c67414}.mode-card__checkbox{display:flex;align-items:center;gap:.65rem;padding:.65rem .85rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#00000038;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s ease,background .15s ease}.mode-card__checkbox:hover{border-color:var(--accent-primary);background:#00000052}.mode-card__checkbox input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;position:relative;width:20px;height:20px;margin:0;border:2px solid var(--border-subtle);border-radius:4px;background:#00000059;cursor:pointer;flex-shrink:0;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.mode-card__checkbox input[type=checkbox]:hover{border-color:var(--accent-primary)}.mode-card__checkbox input[type=checkbox]:checked{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary-glow)}.mode-card__checkbox input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:8px;height:12px;border:solid #0a1418;border-width:0 2px 2px 0;transform:rotate(45deg)}.mode-card__checkbox input[type=checkbox]:checked+span{color:var(--text-primary)}.public-rooms-section{width:100%;max-width:720px;margin:.25rem auto 0;padding:1rem 1rem 1.1rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:.75rem;box-shadow:0 0 18px #00000059}.public-rooms-section__head{display:flex;flex-direction:column;gap:.2rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.public-rooms-section__title{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:.02em}.public-rooms-section__subtitle{margin:0;color:var(--text-secondary);font-size:.88rem}.public-rooms-section__join-error{margin:0;padding:.55rem .75rem;border:1px solid rgba(255,80,80,.45);background:#ff50501a;color:#ffb3b3;border-radius:var(--radius-md);font-size:.85rem}.public-rooms-filters{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:center;gap:.85rem 1.1rem}.public-rooms-filters__field{display:flex;flex-direction:column;gap:.3rem;min-width:0}.public-rooms-filters__label{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.public-rooms-filters__lang{min-width:140px}.public-rooms-filters__checkbox{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#00000038;color:var(--text-secondary);font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none;height:38px;transition:border-color .15s ease,background .15s ease}.public-rooms-filters__checkbox:hover{border-color:var(--accent-primary);background:#00000052}.public-rooms-filters__checkbox input[type=checkbox]{width:16px;height:16px;margin:0;accent-color:var(--accent-primary);cursor:pointer}.public-rooms-filters__checkbox input[type=checkbox]:checked~span{color:var(--text-primary)}.public-rooms-filters__refresh{align-self:flex-end;height:38px;display:inline-flex;align-items:center}.public-rooms-list{display:flex;flex-direction:column;gap:.6rem}.public-rooms-list__items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.public-rooms-list__empty{margin:0;padding:1rem .75rem;text-align:center;color:var(--text-secondary);font-size:.92rem;background:#0000002e;border:1px dashed var(--border-subtle);border-radius:var(--radius-md)}.public-rooms-list__error{margin:0;padding:.75rem;background:#ff50501a;border:1px solid rgba(255,80,80,.45);color:#ffb3b3;border-radius:var(--radius-md);font-size:.85rem}.public-rooms-list__cap{margin:0;text-align:center;font-size:.78rem;color:var(--text-muted);font-style:italic}.public-room-card{display:flex;flex-direction:column;gap:.45rem;padding:.75rem .85rem;background:#00000047;border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color .15s ease,transform .15s ease}.public-room-card:hover{border-color:var(--accent-primary);transform:translateY(-1px)}.public-room-card__head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.public-room-card__code{font-family:var(--font-mono);font-size:1.05rem;font-weight:700;letter-spacing:.08em;color:var(--accent-secondary);background:#00000073;padding:.2rem .55rem;border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.public-room-card__meta,.public-room-card__foot{display:flex;align-items:center;gap:.4rem;color:var(--text-secondary);font-size:.82rem;flex-wrap:wrap}.public-room-card__host{color:var(--text-primary);font-weight:600}.public-room-card__locale{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-gold);background:var(--accent-gold-dim);padding:.05rem .4rem;border-radius:999px;border:1px solid var(--accent-gold)}.public-room-card__category{color:var(--text-secondary)}.public-room-card__dot{color:var(--text-muted)}.public-room-card__count,.public-room-card__age{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted)}.public-room-card__join{flex-shrink:0}.lang-selector{position:relative}.lang-selector__trigger{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-weight:700;font-size:.82rem;letter-spacing:.06em;padding:.4rem .75rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:999px;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);min-width:56px}.lang-selector__trigger:hover,.lang-selector__trigger:focus-visible{border-color:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary-glow);outline:none}.lang-selector__arrow{font-size:.7rem;opacity:.7}.lang-selector__menu{position:absolute;top:calc(100% + .4rem);right:0;margin:0;padding:.35rem;list-style:none;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000073;z-index:100;min-width:160px;animation:fadeIn .14s ease both}.lang-selector__option{display:flex;align-items:center;gap:.6rem;width:100%;padding:.45rem .6rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;text-align:left;font-size:.85rem;transition:background .12s ease}.lang-selector__option:hover{background:#00d4ff14}.lang-selector__option--active{color:var(--accent-primary);font-weight:700}.lang-selector__short{font-family:var(--font-mono);font-weight:700;font-size:.78rem;letter-spacing:.06em;min-width:28px;text-align:center;background:#0000004d;border:1px solid var(--border-subtle);border-radius:4px;padding:.15rem .3rem}.lang-selector__full{flex:1}.text-gold{color:var(--accent-gold);text-shadow:0 0 8px var(--accent-gold-glow)}.entry-page__footer{margin-top:1.5rem;font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.04em}.entry-page__footer-text{opacity:.7}.entry-page__footer-link{color:var(--accent-secondary);text-decoration:none;font-weight:700;border-bottom:1px solid transparent;transition:color .15s ease,border-color .15s ease,text-shadow .15s ease}.entry-page__footer-link:hover,.entry-page__footer-link:focus-visible{color:var(--accent-primary);border-bottom-color:var(--accent-primary);text-shadow:0 0 8px var(--accent-primary-glow);outline:none}.powered-by-footer{position:fixed;bottom:0;left:0;right:0;z-index:50;text-align:center;padding:.5rem 1rem calc(.5rem + var(--safe-bottom));font-size:.72rem;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.04em;background:linear-gradient(180deg,transparent 0%,rgba(13,13,20,.6) 100%);pointer-events:none;-webkit-user-select:none;user-select:none}.powered-by-footer__text{opacity:.65}.powered-by-footer__link{pointer-events:auto;color:var(--accent-secondary);text-decoration:none;font-weight:700;border-bottom:1px solid transparent;transition:color .15s ease,border-color .15s ease,text-shadow .15s ease}.powered-by-footer__link:hover,.powered-by-footer__link:focus-visible{color:var(--accent-primary);border-bottom-color:var(--accent-primary);text-shadow:0 0 8px var(--accent-primary-glow);outline:none}.auto-transition-info{text-align:center;color:var(--text-muted);font-size:.8rem;font-style:italic;animation:fadeIn 1s ease .5s both}.vote-count{text-align:center;color:var(--text-secondary);font-size:.9rem;font-family:var(--font-mono)}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}@media (max-width: 720px){.entry-page__modes{grid-template-columns:1fr}.settings-panel__row{flex-direction:column;align-items:stretch;gap:.5rem}.settings-panel__category-controls{flex-wrap:wrap}.settings-panel__category-controls>*{flex:1 1 200px}.public-rooms-filters{flex-direction:column;align-items:stretch;gap:.6rem}.public-rooms-filters__refresh{margin-left:0;align-self:stretch;width:100%}}@media (max-width: 480px){.page{padding:var(--space-lg) var(--space-sm);gap:var(--space-md)}.game-header{padding:.55rem calc(3rem + var(--safe-right)) .55rem calc(2.5rem + var(--safe-left));gap:.25rem}.game-header__logo{width:30px;height:30px;left:calc(.55rem + var(--safe-left))}.game-header__label{font-size:.75rem}.game-header__code{font-size:.95rem;letter-spacing:.05em}.game-header__leave{width:36px;height:36px;font-size:1.1rem;right:calc(.55rem + var(--safe-right))}.voting-table__player-btn{min-height:56px;padding:.85rem .5rem;font-size:.85rem}.voting-table__actions .btn{min-height:48px}.role-reveal{padding:1.5rem 1.25rem}.role-reveal__main{font-size:1.3rem}.winner-banner__title{font-size:1.5rem}.winner-banner__winner{font-size:1.05rem}.connection-screen__logo{width:76px;height:76px}.connection-screen__title{font-size:1.8rem}.entry-page__logo{width:clamp(80px,16vw,120px)}.entry-page__title{font-size:clamp(1.9rem,8vw,2.4rem)}.entry-page__subtitle{font-size:.9rem}.mode-card{padding:1rem .9rem 1.1rem}.mode-card__title{font-size:1.2rem}.mode-card__desc{font-size:.85rem}.toggle-group__btn{min-height:44px}.entry-page__footer{font-size:.72rem}.entry-page__hero{flex-direction:column;gap:.5rem}.entry-page__hero-text{text-align:center}.player-count{font-size:.8rem}}@media (max-width: 360px){.voting-table__grid{grid-template-columns:repeat(2,1fr)}.toggle-group__btn{padding:.5rem .75rem;font-size:.8rem}.game-header__code{font-size:.85rem}.entry-page{padding:3.5rem .75rem 2rem}}@media (max-height: 500px) and (orientation: landscape){.entry-page{min-height:100dvh;justify-content:flex-start;padding-top:calc(2.5rem + var(--safe-top));padding-bottom:2rem}.entry-page__hero{margin-bottom:.25rem}.entry-page__logo{width:80px}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease both}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease both}.animate-fade-in-scale{animation:fadeInScale var(--transition-slow) ease both}.stagger-item{animation:slideInLeft var(--transition-normal) ease both}.error-fallback{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--bg-primary)}.error-fallback__card{max-width:480px;width:100%;background:var(--bg-card);border:1px solid var(--accent-danger);border-radius:var(--radius-lg);padding:1.75rem 1.5rem;text-align:center;box-shadow:0 0 24px var(--accent-danger-glow);display:flex;flex-direction:column;gap:1rem}.error-fallback__title{font-size:1.4rem;font-weight:700;margin:0;color:var(--accent-danger);text-transform:uppercase;letter-spacing:.04em}.error-fallback__text{color:var(--text-secondary);margin:0;line-height:1.5}.toast-stack{position:fixed;bottom:calc(2.5rem + var(--safe-bottom));left:50%;transform:translate(-50%);z-index:1500;display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none;max-width:min(440px,calc(100vw - 2rem))}.toast{pointer-events:auto;display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem .7rem 1rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000073;font-size:.88rem;color:var(--text-primary);animation:toastIn .22s ease both;cursor:pointer;-webkit-user-select:none;user-select:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);max-width:100%}.toast--info{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary-glow),0 8px 24px #00000073}.toast--success{border-color:var(--accent-success);box-shadow:0 0 0 1px #22c55e4d,0 8px 24px #00000073}.toast--error{border-color:var(--accent-danger);box-shadow:0 0 0 1px var(--accent-danger-glow),0 8px 24px #00000073}.toast__message{flex:1 1 auto;line-height:1.4}.toast__close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:.1rem .35rem;border-radius:4px;flex:0 0 auto;line-height:1}.toast__close:hover{color:var(--text-primary);background:#ffffff0f}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:#000c;animation:fadeIn .18s ease both;padding:1rem}.modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto;background:linear-gradient(180deg,#16162a,#0d0d18);border:1px solid var(--border-accent);border-radius:var(--radius-lg);box-shadow:0 0 32px var(--accent-primary-glow),0 12px 40px #0009;animation:fadeInScale .22s ease both}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle)}.modal__title{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--accent-primary);margin:0;letter-spacing:.04em;text-transform:uppercase}.modal__close{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:50%;color:var(--text-secondary);font-size:.95rem;cursor:pointer;transition:all var(--transition-fast);line-height:1;padding:0;min-height:44px;min-width:44px}.modal__close:hover{background:#ff00441a;border-color:var(--accent-danger);color:var(--accent-danger)}.modal--small{max-width:420px}.modal--wide{max-width:560px}.contribute-modal__intro{margin:0 0 var(--space-md);color:var(--text-secondary);line-height:1.55}.contribute-modal__section-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-primary);margin:1rem 0 .5rem}.contribute-modal__ideas,.contribute-modal__steps{margin:0 0 .5rem;padding-left:1.25rem;color:var(--text-secondary);line-height:1.7}.contribute-modal__ideas li,.contribute-modal__steps li{margin-bottom:.25rem}.contribute-modal__note{margin:.75rem 0 0;padding:.6rem .85rem;background:var(--accent-primary-glow);border-left:2px solid var(--accent-primary);border-radius:4px;color:var(--text-primary);font-size:.85rem;display:flex;align-items:center;gap:.5rem}.contribute-modal__actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.25rem}.contribute-modal__actions .btn{flex:1 1 auto;min-width:180px;text-align:center;justify-content:center}.hardcore-help__intro{margin:0 0 var(--space-md);color:var(--text-secondary);line-height:1.5}.hardcore-help__bullets{margin:0;padding-left:1.25rem;color:var(--text-primary);line-height:1.7}.hardcore-help__bullets li{margin-bottom:.35rem}.settings-panel__row--hardcore{flex-direction:row;align-items:center;justify-content:space-between}.settings-panel__row--hardcore .settings-panel__label{display:inline-flex;align-items:center;gap:.5rem}.settings-panel__row--visibility{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-md)}.settings-panel__row--visibility .settings-panel__label{display:inline-flex;align-items:center;gap:.5rem}.settings-panel__visibility{display:inline-flex;align-items:stretch;background:#00000052;border:1px solid var(--border-subtle);border-radius:999px;padding:3px;gap:0;flex-shrink:0}.settings-panel__radio{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.35rem .95rem;border-radius:999px;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.02em;transition:color .18s ease,background .18s ease,box-shadow .18s ease;min-width:4.5rem;white-space:nowrap}.settings-panel__radio input[type=radio]{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}.settings-panel__radio:hover{color:var(--text-primary)}.settings-panel__radio--active{background:var(--accent-primary);color:#0a1418;box-shadow:0 0 12px var(--accent-primary-glow);text-shadow:0 0 6px rgba(255,255,255,.25)}.settings-panel__radio--active:hover{color:#0a1418}.settings-panel__radio:focus-within{outline:2px solid var(--accent-primary);outline-offset:2px}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);font-size:.72rem;font-weight:700;cursor:pointer;padding:0;line-height:1;transition:all .15s ease}.help-icon:hover,.help-icon:focus-visible{color:var(--accent-primary);border-color:var(--accent-primary);outline:none}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex:0 0 auto}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch__slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:999px;cursor:pointer;transition:all .2s ease}.toggle-switch__slider:before{content:"";position:absolute;left:3px;top:50%;transform:translateY(-50%);width:16px;height:16px;background:var(--text-muted);border-radius:50%;transition:all .2s ease}.toggle-switch input:checked+.toggle-switch__slider{background:var(--accent-warning);border-color:var(--accent-warning)}.toggle-switch input:checked+.toggle-switch__slider:before{transform:translateY(-50%) translate(20px);background:#1a1500}@media (max-width: 720px){.settings-panel__row--hardcore{flex-direction:row;align-items:center}.settings-panel__row--visibility{flex-direction:row;align-items:center;flex-wrap:wrap;row-gap:.4rem}}.version-badge{display:inline-flex;align-items:center;gap:.5rem;margin:0 auto .5rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em}.version-badge__pill{display:inline-block;padding:.2rem .55rem;border-radius:4px;font-weight:800;letter-spacing:.12em;font-size:.7rem}.version-badge__pill--beta{background:var(--accent-warning);color:#1a1500;box-shadow:0 0 8px var(--accent-warning-glow)}.version-badge__version{color:var(--text-muted)}.help-improve{margin-top:.5rem;text-align:center}.help-improve__btn{background:transparent;border:1px solid var(--border-subtle);border-radius:999px;padding:.55rem 1.1rem;color:var(--text-secondary);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:.4rem}.help-improve__btn:hover,.help-improve__btn:focus-visible{color:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 10px var(--accent-primary-glow);outline:none;transform:translateY(-1px)}.confirm-modal__message{margin:0 0 .5rem;color:var(--text-secondary);line-height:1.5}.confirm-modal__actions{display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}.modal__body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.modal__status{margin:0;padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500}.modal__status--ok{background:#00ff881a;color:var(--accent-success);border:1px solid rgba(0,255,136,.3)}.modal__status--err{background:#ff00441a;color:var(--accent-danger);border:1px solid rgba(255,0,68,.3)}.modal__divider{border:none;border-top:1px solid var(--border-subtle);margin:.25rem 0}.cat-form{display:flex;flex-direction:column;gap:.7rem}.cat-form__title{font-size:.85rem;font-weight:700;color:var(--accent-warning);text-transform:uppercase;letter-spacing:.06em;margin:0}.cat-form__label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:var(--text-secondary);font-weight:500}.cat-form__textarea{resize:vertical;font-family:var(--font-mono);font-size:.85rem;min-height:3.5rem}.cat-form__hint{font-size:.75rem;color:var(--text-muted);font-style:italic}.stagger-item:nth-child(1){animation-delay:.02s}.stagger-item:nth-child(2){animation-delay:.06s}.stagger-item:nth-child(3){animation-delay:.1s}.stagger-item:nth-child(4){animation-delay:.14s}.stagger-item:nth-child(5){animation-delay:.18s}.stagger-item:nth-child(6){animation-delay:.22s}.stagger-item:nth-child(7){animation-delay:.26s}.stagger-item:nth-child(8){animation-delay:.3s}.stagger-item:nth-child(9){animation-delay:.34s}.stagger-item:nth-child(10){animation-delay:.38s}.lobbies-page{position:relative;display:flex;flex-direction:column;align-items:center;width:100%;max-width:720px;margin:0 auto;padding:1.25rem 1.25rem calc(3rem + 2.5rem + var(--safe-bottom));gap:1.25rem;min-height:100vh;justify-content:center}.lobbies-page__panel{width:100%;display:flex;flex-direction:column;gap:1rem;padding:1.5rem 1.5rem 1.75rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:0 0 18px #00000059;min-height:60vh;max-height:80vh;overflow-y:auto}.lobbies-page__topbar{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}.lobbies-page__back{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary);padding:.45rem .85rem;border-radius:var(--radius-md);font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.lobbies-page__back:hover{border-color:var(--accent-primary);color:var(--text-primary);background:#00000038}.lobbies-page__head{text-align:center;display:flex;flex-direction:column;gap:.35rem;margin-bottom:.25rem}.lobbies-page__title{font-size:1.8rem;font-weight:800;margin:0;color:var(--text-primary);letter-spacing:.02em}.lobbies-page__subtitle{color:var(--text-secondary);font-size:.95rem;margin:0}.lobbies-page__username{width:100%;display:flex;flex-direction:column;gap:.35rem}.lobbies-page__username label{font-size:.85rem;color:var(--text-secondary);font-weight:600}.lobbies-page__username input{width:100%;padding:.7rem .85rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit}.lobbies-page__username input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-glow)}@media (max-width: 720px){.lobbies-page{padding:1rem 1rem calc(3rem + 2.5rem + var(--safe-bottom));justify-content:flex-start}.lobbies-page__panel{padding:1.25rem 1.1rem 1.4rem;min-height:auto;max-height:none}.lobbies-page__title{font-size:1.5rem}}.entry-page__lobbies-link{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;padding:.4rem .8rem;border-radius:var(--radius-md);transition:color .15s ease,background .15s ease,border-color .15s ease}.entry-page__lobbies-link:hover,.entry-page__lobbies-link:focus-visible{color:var(--text-primary);background:#00000038;border-color:var(--accent-primary);outline:none}.join-page{position:relative;display:flex;flex-direction:column;align-items:center;width:100%;max-width:520px;margin:0 auto;padding:1.25rem 1.25rem calc(3rem + 2.5rem + var(--safe-bottom));gap:1.25rem;min-height:100vh;justify-content:center}.join-page__topbar{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}.join-page__back{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary);padding:.45rem .85rem;border-radius:var(--radius-md);font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.join-page__back:hover{border-color:var(--accent-primary);color:var(--text-primary);background:#00000038}.join-page__head{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:.25rem;width:100%}.join-page__title{font-size:1.6rem;font-weight:800;margin:0;color:var(--text-primary);letter-spacing:.02em}.join-page__code-chip{display:inline-block;font-family:var(--font-mono);font-size:1.4rem;font-weight:700;letter-spacing:.1em;color:var(--accent-primary);background:#0006;border:1px solid var(--accent-primary);border-radius:var(--radius-md);padding:.3rem .85rem;text-shadow:0 0 12px var(--accent-primary-glow)}.join-page__subtitle{color:var(--text-secondary);font-size:.95rem;margin:0}.join-page__form{width:100%;display:flex;flex-direction:column;gap:1rem}.join-page__field{display:flex;flex-direction:column;gap:.4rem}.join-page__field label{font-size:.85rem;color:var(--text-secondary);font-weight:600}.join-page__field input{width:100%;padding:.7rem .85rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit}.join-page__field input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-glow)}@media (max-width: 720px){.join-page{padding:1rem 1rem calc(3rem + 2.5rem + var(--safe-bottom));justify-content:flex-start}.join-page__title{font-size:1.3rem}}
