@font-face{font-family:OptimaModoki;src:url(/fonts/OptimaModoki.ttf) format("truetype");font-weight:400 700;font-style:normal;font-display:swap}:root{--sat: env(safe-area-inset-top, 0px);--sar: env(safe-area-inset-right, 0px);--sab: env(safe-area-inset-bottom, 0px);--sal: env(safe-area-inset-left, 0px);--gold: #D4AF37;--gold-light: #F0D870;--gold-dim: rgba(212, 175, 55, .55);--gold-faint: rgba(212, 175, 55, .12);--gold-border: rgba(212, 175, 55, .7);--red: #8B0000;--red-bright: #C00000;--red-glow: rgba(139, 0, 0, .55);--red-glow-bright: rgba(192, 0, 0, .7);--black: #080808;--dark: #0D0A05;--dark-panel: rgba(14, 10, 4, .96);--dark-panel-border: rgba(212, 175, 55, .18);--text-gold: #D4AF37;--text-light: rgba(230, 210, 140, .9);--text-muted: rgba(230, 210, 140, .9);--text-dim: rgba(212, 175, 55, .28);--font-display: "OptimaModoki", sans-serif;--font-title: "OptimaModoki", sans-serif;--font-body: "OptimaModoki", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}img,svg{-webkit-touch-callout:none;pointer-events:none}button img,a img,button svg,a svg{pointer-events:none}html{width:100%;height:100%;overflow:hidden;overscroll-behavior:none;background:url(/bg.png) center top / cover no-repeat #040202}body,#root{width:100%;height:100%;overflow:hidden;background:transparent;overscroll-behavior:none}button{cursor:pointer;border:none;background:none;font:inherit}input{font:inherit}.app-shell{width:100%;height:100dvh;min-height:-webkit-fill-available;display:flex;justify-content:center;align-items:stretch;background:#040202}.app-viewport{width:100%;height:100%;position:relative;overflow:hidden;background:url(/bg.png) center top / cover no-repeat}.app-viewport:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000085;z-index:0;pointer-events:none}.screen{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;position:relative;background:transparent;z-index:1;scrollbar-width:none;overscroll-behavior:none;-webkit-overflow-scrolling:touch}.screen::-webkit-scrollbar{display:none}.atmos-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.atmos-bg-moon{position:absolute;top:8%;right:18%;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(220,200,140,.18) 0%,rgba(180,160,100,.08) 40%,transparent 70%);filter:blur(8px)}.atmos-bg-red-glow{position:absolute;top:20%;right:-10%;width:60%;height:55%;background:radial-gradient(ellipse,rgba(120,0,0,.45) 0%,transparent 65%);filter:blur(20px)}.atmos-bg-ground{position:absolute;bottom:0;left:0;right:0;height:45%;background:linear-gradient(to top,rgba(80,0,0,.35) 0%,transparent 100%)}.atmos-bg-fog{position:absolute;bottom:0;left:0;right:0;height:30%;background:radial-gradient(ellipse at 50% 100%,rgba(30,0,0,.5) 0%,transparent 70%)}.lang-switcher{display:flex;align-items:center;gap:6px;background:#0a0602d1;border:1px solid var(--gold-dim);border-radius:8px;padding:6px 8px;z-index:10;flex-shrink:0}.lang-switcher-abs{position:absolute;top:calc(var(--sat) + 12px);right:calc(var(--sar) + 16px)}.btn-back-safe{position:absolute;top:calc(var(--sat) + 12px);left:calc(var(--sal) + 16px);z-index:10}.lang-flag-btn{background:none;border:none;padding:2px;border-radius:4px;cursor:pointer;opacity:.45;transition:opacity .2s,box-shadow .2s;line-height:0;display:block}.lang-flag-btn.active{opacity:1;box-shadow:0 0 0 1.5px var(--gold);border-radius:4px}.lang-flag-btn:active{opacity:.8}.lang-flag-sep{width:1px;height:16px;background:var(--gold-dim);opacity:.5}.home-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:calc(var(--sat) + 48px) calc(var(--sar) + 24px) calc(var(--sab) + 24px) calc(var(--sal) + 24px);position:relative;overflow:hidden;background:radial-gradient(ellipse at 72% 18%,rgba(140,0,0,.45) 0%,transparent 46%),radial-gradient(ellipse at 50% 100%,rgba(110,0,0,.5) 0%,transparent 42%),linear-gradient(to bottom,#0000002e,#0000000d,#00000040)}.home-logo-area{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:1;width:100%}.home-logo-ring{position:relative;width:300px;height:300px;margin-bottom:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.home-logo-ring img{object-fit:contain;object-position:center center;width:300px;height:300px;display:block;margin:0}.home-title{font-family:OptimaModoki,sans-serif;font-size:clamp(54px,14vw,72px);font-weight:900;color:var(--gold);line-height:1;margin-top:-48px;margin-bottom:6px;position:relative;z-index:2;text-align:center;width:100%;display:flex;justify-content:center}.home-title-inner{letter-spacing:.1em;margin-right:-.1em;display:inline-block}.home-subtitle-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px;width:100%}.home-subtitle-line{width:44px;height:1px;background:linear-gradient(to right,transparent,var(--gold-dim))}.home-subtitle-line.right{background:linear-gradient(to left,transparent,var(--gold-dim))}.home-subtitle{font-family:var(--font-title);font-size:14px;font-weight:400;letter-spacing:.28em;color:var(--gold-dim)}.home-diamond{width:9px;height:9px;background:var(--gold-dim);transform:rotate(45deg);margin-top:12px}.home-cta{position:relative;width:100%;z-index:1;display:flex;flex-direction:column;gap:10px}.btn-primary-wrap{filter:drop-shadow(0 0 22px rgba(160,0,0,.8)) drop-shadow(0 0 48px rgba(120,0,0,.45)) drop-shadow(0 4px 12px rgba(0,0,0,.7))}.home-secondary-row{display:flex;gap:10px;width:100%}.home-secondary-row .home-join-btn,.home-secondary-row .home-htp-btn{flex:1;width:auto;padding:13px 8px}.home-htp-btn{width:100%;font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.14em;color:#d4af37a6;background:transparent;border:1px solid rgba(212,175,55,.3);border-radius:10px;padding:13px 20px;text-align:center;cursor:pointer;transition:border-color .2s,color .2s,transform .1s}.home-htp-btn:active{border-color:var(--gold-dim);color:var(--gold);transform:scale(.98)}.btn-primary-wrap{position:relative;display:block;width:100%;padding:2.5px;background:linear-gradient(175deg,#f2dc68,#c8a028 18%,#7a5a0a 42%,#6a4a08,#7a5a0a 58%,#b89020 78%,#ead060);clip-path:polygon(16px 0%,calc(100% - 16px) 0%,100% 16px,100% calc(100% - 16px),calc(100% - 16px) 100%,16px 100%,0% calc(100% - 16px),0% 16px);cursor:pointer}.btn-primary-wrap:before{content:"";position:absolute;top:-1px;left:18%;right:18%;height:4px;background:radial-gradient(ellipse at center,rgba(255,130,60,1) 0%,rgba(230,70,10,.75) 45%,transparent 80%);filter:blur(1.5px);z-index:5;pointer-events:none}.btn-primary-wrap:after{content:"";position:absolute;bottom:-1px;left:28%;right:28%;height:3px;background:radial-gradient(ellipse at center,rgba(220,80,20,.75) 0%,transparent 70%);filter:blur(1px);z-index:5;pointer-events:none}.btn-primary{position:relative;display:block;width:100%;z-index:1;font-family:var(--font-title);font-size:26px;font-weight:700;letter-spacing:.22em;color:#d4af37;text-shadow:0 0 28px rgba(212,175,55,.75),0 0 10px rgba(212,175,55,.4),0 2px 6px rgba(0,0,0,.98);text-align:center;background:radial-gradient(ellipse at 50% 0%,rgba(110,8,0,.5) 0%,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(70,0,0,.3) 0%,transparent 55%),linear-gradient(to bottom,#7e0202,#5c0000 38%,#680000 68%,#520000);clip-path:polygon(13px 0%,calc(100% - 13px) 0%,100% 13px,100% calc(100% - 13px),calc(100% - 13px) 100%,13px 100%,0% calc(100% - 13px),0% 13px);padding:0 24px;height:68px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:filter .15s,transform .1s}.btn-primary:active{filter:brightness(.78);transform:scale(.975)}.home-features{display:flex;gap:0;width:100%;background:#0a0602b8;border:1px solid var(--dark-panel-border);border-radius:14px;overflow:hidden;position:relative;z-index:1}.home-feature{flex:1;display:flex;flex-direction:column;align-items:center;padding:20px 8px 18px;gap:9px;min-height:120px;border-right:1px solid var(--dark-panel-border)}.home-feature:last-child{border-right:none}.home-feature-icon{width:46px;height:46px;display:flex;align-items:center;justify-content:center}.home-feature-label{font-family:var(--font-title);font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--gold);text-align:center;min-height:2.4em;line-height:1.2;display:flex;align-items:center;justify-content:center}.home-feature-sub{font-family:var(--font-body);font-size:9px;font-weight:400;letter-spacing:.06em;min-height:2.4em;line-height:1.2;display:flex;align-items:center;justify-content:center;color:var(--text-muted);text-align:center}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:calc(var(--sat) + 14px) calc(var(--sar) + 16px) 0 calc(var(--sal) + 16px);position:relative;z-index:5;min-height:calc(var(--sat) + 54px)}.top-bar-title{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:.12em;color:var(--gold);text-align:center;text-shadow:0 0 20px rgba(212,175,55,.4);flex:1}.top-bar-left,.top-bar-right{width:80px;display:flex}.top-bar-left{justify-content:flex-start}.top-bar-right{justify-content:flex-end}.btn-back{width:36px;height:36px;border-radius:50%;border:1px solid var(--gold-dim);background:#0a0602cc;display:flex;align-items:center;justify-content:center;color:var(--gold);transition:border-color .2s,box-shadow .2s}.btn-back:active{box-shadow:0 0 12px var(--gold-dim)}.screen-decorative-line{width:60%;height:1px;background:linear-gradient(to right,transparent,var(--gold-dim),transparent);margin:6px auto 0}.screen-diamond{width:6px;height:6px;background:var(--gold-dim);transform:rotate(45deg);margin:4px auto 0}.counter-section{background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:14px 16px 12px;margin:0 16px}.counter-label{font-family:var(--font-title);font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--gold-dim);text-align:center;margin-bottom:8px}.counter-row{display:flex;align-items:center;justify-content:center;gap:20px}.counter-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--gold-dim);background:#140e04e6;color:var(--gold);font-size:22px;font-weight:300;display:flex;align-items:center;justify-content:center;transition:border-color .2s,box-shadow .2s,opacity .2s;line-height:1;padding-bottom:1px}.counter-btn:active{box-shadow:0 0 12px var(--gold-dim);border-color:var(--gold)}.counter-btn:disabled{opacity:.25}.counter-value{font-family:var(--font-display);font-size:38px;font-weight:700;color:var(--gold);text-shadow:0 0 20px rgba(212,175,55,.4);min-width:54px;text-align:center;line-height:1}.counter-note{font-family:var(--font-body);font-size:11px;font-weight:400;color:var(--text-muted);text-align:center;margin-top:6px;letter-spacing:.02em}.setup-screen{min-height:100%;background:radial-gradient(ellipse at 70% 15%,rgba(100,0,0,.38) 0%,transparent 45%),radial-gradient(ellipse at 50% 100%,rgba(80,0,0,.42) 0%,transparent 40%),linear-gradient(to bottom,#00000038,#0000001a,#00000047);padding-bottom:32px}.setup-sections{display:flex;flex-direction:column;gap:10px;margin-top:18px}.auto-roles-panel{display:flex;align-items:center;gap:12px;background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:12px 16px;margin:0 16px}.auto-roles-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.auto-roles-text{font-family:var(--font-title);font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--gold)}.role-summary-section{margin:0 16px;background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:14px 14px 12px}.rs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.rs-total{font-family:var(--font-title);font-size:11px;font-weight:700;color:var(--gold-dim);letter-spacing:.08em;white-space:nowrap}.rs-total span{font-size:9px;letter-spacing:.14em}.rs-team{margin-bottom:10px}.rs-team:last-child{margin-bottom:0}.rs-team-header{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-title);font-size:9.5px;font-weight:700;letter-spacing:.2em;padding:5px 8px;border-radius:5px;margin-bottom:4px}.rs-team-mafia{background:#8b000033;color:#dc5050e6;border:1px solid rgba(180,40,40,.25)}.rs-team-citizen{background:#d4af3714;color:var(--gold-dim);border:1px solid rgba(212,175,55,.14)}.rs-team-neutral{background:#c85a001f;color:#d27828d9;border:1px solid rgba(200,90,0,.2)}.rs-role-row{display:flex;align-items:center;gap:8px;padding:4px 8px}.rs-role-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rs-role-name{flex:1;font-family:var(--font-title);font-size:10px;font-weight:600;letter-spacing:.12em;color:var(--text-muted)}.rs-role-count{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--gold-dim);min-width:16px;text-align:right}.section-label{font-family:var(--font-title);font-size:10px;font-weight:600;letter-spacing:.25em;color:var(--text-muted);text-align:center;margin-bottom:12px;display:flex;align-items:center;gap:8px}.section-label:before,.section-label:after{content:"";flex:1;height:1px;background:var(--gold-dim);opacity:.4}.adv-roles-section{margin:0 16px;background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:14px 12px 12px}.adv-roles-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.adv-role-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px 12px;border-radius:9px;border:1.5px solid rgba(212,175,55,.1);background:#120c04d9;cursor:pointer;transition:border-color .22s,background .22s,box-shadow .22s;position:relative;overflow:hidden}.adv-role-card.enabled{border-color:var(--gold-dim);background:#1a1204f2;box-shadow:0 0 14px #d4af371a}.adv-role-card.locked{cursor:default;opacity:.35;border-color:#d4af3712;border-style:dashed}.adv-role-active-dot{position:absolute;top:7px;right:7px;width:5px;height:5px;border-radius:50%;background:var(--gold);box-shadow:0 0 6px #d4af37b3}.adv-role-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center}.adv-role-name{font-family:var(--font-title);font-size:10px;font-weight:700;letter-spacing:.16em;color:var(--text-muted);text-align:center;transition:color .22s}.adv-role-card.enabled .adv-role-name{color:var(--gold)}.adv-role-badge{font-family:var(--font-body);font-size:8px;font-weight:600;letter-spacing:.08em;color:var(--text-dim);background:#d4af3712;border:1px solid rgba(212,175,55,.12);border-radius:3px;padding:2px 7px;transition:color .22s,background .22s}.adv-role-badge.on{color:var(--gold);background:#d4af372e;border-color:var(--gold-dim)}.adv-role-badge.locked-badge{color:#d4af3740;background:transparent;border-color:#d4af371a;letter-spacing:.06em}.player-names-section{margin:0 16px;background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:14px 12px 12px}.player-name-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}.player-name-row{display:flex;align-items:center;gap:10px}.player-name-number{font-family:var(--font-title);font-size:11px;font-weight:600;color:var(--text-muted);min-width:22px;text-align:right}.player-name-input{flex:1;background:#140e04e6;border:1px solid var(--dark-panel-border);border-radius:6px;padding:9px 12px;color:var(--text-light);font-family:var(--font-body);font-size:13px;font-weight:400;letter-spacing:.02em;outline:none;transition:border-color .2s}.player-name-input::placeholder{color:var(--text-dim);font-style:italic}.player-name-input:focus{border-color:var(--gold-dim)}.player-name-input.filled{border-color:#d4af3747}.bottom-cta{margin:18px 16px 0}.btn-start{display:block;width:100%;font-family:var(--font-title);font-size:16px;font-weight:700;letter-spacing:.2em;color:#fff;background:linear-gradient(to bottom,#9a0000,#6b0000,#8b0000);border:2px solid var(--gold);border-radius:8px;padding:18px 20px;text-shadow:0 1px 4px rgba(0,0,0,.6);box-shadow:0 0 24px #8b000080,0 0 48px #8b000033,inset 0 1px #ffffff12;text-align:center;transition:box-shadow .2s,transform .1s,opacity .2s;position:relative;overflow:hidden}.btn-start:after{content:"";position:absolute;bottom:-6px;left:15%;right:15%;height:2px;background:radial-gradient(ellipse,var(--red-glow-bright),transparent 70%);filter:blur(2px)}.btn-start:disabled{opacity:.35;box-shadow:none;cursor:not-allowed}.btn-start:not(:disabled):active{transform:scale(.98);box-shadow:0 0 10px #8b0000b3}.btn-outline{display:block;width:100%;font-family:var(--font-title);font-size:14px;font-weight:700;letter-spacing:.2em;color:var(--gold);background:#0e0a04e6;border:1.5px solid var(--gold-dim);border-radius:8px;padding:15px 20px;text-align:center;transition:border-color .2s,box-shadow .2s,transform .1s}.btn-outline:active{border-color:var(--gold);box-shadow:0 0 12px var(--gold-dim);transform:scale(.98)}.validation-msg{font-family:var(--font-body);font-size:11px;color:#dc6450e6;text-align:center;margin-top:8px;letter-spacing:.04em}.reveal-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:calc(var(--sat) + 56px) calc(var(--sar) + 20px) calc(var(--sab) + 28px) calc(var(--sal) + 20px);gap:0;overflow:hidden;background:radial-gradient(ellipse at 70% 15%,rgba(100,0,0,.4) 0%,transparent 46%),radial-gradient(ellipse at 50% 95%,rgba(90,0,0,.45) 0%,transparent 42%),linear-gradient(to bottom,#0003,#00000014,#0000004d);position:relative}.reveal-top{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.reveal-card-group{display:flex;flex-direction:column;align-items:center;gap:28px;flex:1;justify-content:center}.reveal-player-title{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--gold);text-shadow:0 0 30px rgba(212,175,55,.45);text-align:center;padding:0 20px;line-height:1.15}.reveal-role-label{font-family:var(--font-title);font-size:11px;font-weight:600;letter-spacing:.3em;color:var(--text-muted);text-align:center;margin-top:4px}.card-action-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;background:#060301e0;border:1.5px solid rgba(212,175,55,.4);border-radius:8px;padding:14px 32px;font-family:var(--font-title);font-size:14px;font-weight:700;letter-spacing:.22em;color:#ffffffeb;cursor:pointer;transition:filter .15s,transform .1s;white-space:nowrap;animation:revealBtnAppear .4s ease .3s both}@keyframes revealBtnAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.card-action-btn.card-action-btn-next{background:#6e0000e0;border-color:#c0000080}.card-action-btn:active{filter:brightness(.8);transform:translate(-50%,-50%) scale(.97)}.reveal-action-slot{position:relative;width:100%;height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center}.reveal-action-slot .reveal-privacy-note{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;height:fit-content}.reveal-action-slot .reveal-actions{position:absolute;top:0;right:0;bottom:0;left:0}.card-scene{perspective:1600px;width:calc(100vw - 80px);height:calc((100vw - 80px)*1.4);max-height:calc(100dvh - 260px);max-width:calc((100dvh - 260px) / 1.4);flex-shrink:0;cursor:pointer}.card-3d{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.4,0,.2,1)}.card-3d.flipped{transform:rotateY(180deg)}.card-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:12px;overflow:hidden}.card-face-front-face{transform:rotateY(180deg)}.card-shell{width:100%;height:100%;border-radius:12px;border:2px solid var(--gold-border);position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.card-shell:before{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border:1px solid rgba(212,175,55,.2);border-radius:8px;pointer-events:none}.card-corner{position:absolute;width:20px;height:20px}.card-corner.tl{top:10px;left:10px;border-top:1.5px solid var(--gold-dim);border-left:1.5px solid var(--gold-dim)}.card-corner.tr{top:10px;right:10px;border-top:1.5px solid var(--gold-dim);border-right:1.5px solid var(--gold-dim)}.card-corner.bl{bottom:10px;left:10px;border-bottom:1.5px solid var(--gold-dim);border-left:1.5px solid var(--gold-dim)}.card-corner.br{bottom:10px;right:10px;border-bottom:1.5px solid var(--gold-dim);border-right:1.5px solid var(--gold-dim)}.card-back-bg{background:radial-gradient(ellipse at 50% 0%,rgba(212,175,55,.06) 0%,transparent 60%),linear-gradient(160deg,#100c04,#1a1408,#100c04);box-shadow:0 0 0 1px #d4af371a,0 0 30px #d4af3714,0 0 60px var(--red-glow),inset 0 0 40px #00000080}.card-back-bg:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:8px;background-image:url(/icons/hat.svg);background-size:28px 28px;background-repeat:repeat;opacity:.07;pointer-events:none;z-index:0}.card-role-citizen{background:radial-gradient(ellipse at 50% 0%,rgba(180,0,0,.45) 0%,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(120,0,0,.3) 0%,transparent 50%),linear-gradient(160deg,#1e0000,#340000,#1e0000);box-shadow:0 0 60px #ff28288c,0 0 120px #c800004d,inset 0 0 50px #78000033;border-color:#ff4646b3}.card-role-sheriff{background:radial-gradient(ellipse at 50% 0%,rgba(200,60,0,.45) 0%,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(150,30,0,.3) 0%,transparent 50%),linear-gradient(160deg,#1e0500,#360a00,#1e0500);box-shadow:0 0 60px #ff5a1499,0 0 120px #dc3c0059,inset 0 0 50px #821e0033;border-color:#ff6e28bf}.card-role-doctor{background:radial-gradient(ellipse at 50% 0%,rgba(160,0,0,.45) 0%,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(100,0,0,.3) 0%,transparent 50%),linear-gradient(160deg,#1a0000,#2c0000,#1a0000);box-shadow:0 0 60px #dc14148c,0 0 120px #a000004d,inset 0 0 50px #50000033;border-color:#dc2828ad}.card-role-mafia{background:radial-gradient(ellipse at 50% 0%,rgba(140,0,0,.25) 0%,transparent 45%),linear-gradient(160deg,#000,#050000,#000);box-shadow:0 0 60px #b400008c,0 0 120px #7800004d,inset 0 0 40px #3c000026;border-color:#b41414a6}.card-role-don{background:radial-gradient(ellipse at 50% 0%,rgba(160,0,0,.2) 0%,transparent 40%),radial-gradient(ellipse at 50% 100%,rgba(100,60,0,.12) 0%,transparent 40%),linear-gradient(160deg,#000,#040200,#000);box-shadow:0 0 70px #c8000099,0 0 140px #96000059,0 0 30px #d4af372e,inset 0 0 50px #28000033;border-color:#d4af3780}.card-role-killer{background:radial-gradient(ellipse at 50% 0%,rgba(180,80,0,.3) 0%,transparent 55%),linear-gradient(160deg,#060200,#0e0500,#060200);box-shadow:0 0 60px #ff780080,0 0 120px #c8500047,inset 0 0 50px #501e0026;border-color:#ff8700a6}.card-role-citizen .card-glow-line{background:linear-gradient(to right,transparent,rgba(255,70,70,.9),transparent)}.card-role-sheriff .card-glow-line{background:linear-gradient(to right,transparent,rgba(255,110,40,.9),transparent)}.card-role-doctor .card-glow-line{background:linear-gradient(to right,transparent,rgba(220,40,40,.9),transparent)}.card-role-mafia .card-glow-line{background:linear-gradient(to right,transparent,rgba(200,20,20,.9),transparent)}.card-role-don .card-glow-line{background:linear-gradient(to right,transparent,rgba(212,175,55,.85),transparent)}.card-role-killer .card-glow-line{background:linear-gradient(to right,transparent,rgba(255,135,0,.9),transparent)}.card-glow-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent);opacity:.6}.card-glow-line-red{background:linear-gradient(to right,transparent,var(--red-bright),transparent)}.card-role-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px;gap:12px;width:100%;height:100%;position:relative;z-index:1}.card-role-title{font-family:var(--font-display);font-size:26px;font-weight:900;letter-spacing:.15em;color:var(--gold);text-shadow:0 0 20px rgba(212,175,55,.5);text-align:center;line-height:1}.card-role-title-mafia{color:#d4af37;text-shadow:0 0 30px rgba(212,175,55,.6),0 0 60px rgba(139,0,0,.4)}.card-role-title-don{color:var(--gold);text-shadow:0 0 30px rgba(212,175,55,.7),0 0 60px rgba(200,0,0,.4)}.card-role-divider{display:flex;align-items:center;gap:6px;width:80%}.card-role-divider-line{flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold-dim))}.card-role-divider-line.right{background:linear-gradient(to left,transparent,var(--gold-dim))}.card-role-divider-diamond{width:5px;height:5px;background:var(--gold-dim);transform:rotate(45deg);flex-shrink:0}.card-role-icon-wrap{display:flex;align-items:center;justify-content:center;flex:1;width:100%;min-height:0;overflow:hidden}.card-role-icon-wrap img{width:100%;height:100%;object-fit:contain}.card-role-desc{font-family:var(--font-body);font-size:12px;font-weight:400;color:var(--text-muted);text-align:center;line-height:1.5;letter-spacing:.02em;max-width:90%}.card-role-desc-divider{display:flex;align-items:center;gap:6px;width:70%}.card-role-desc-divider-dot{width:4px;height:4px;background:var(--gold-dim);transform:rotate(45deg);flex-shrink:0}.card-role-desc-divider-line{flex:1;height:1px;background:var(--gold-dim);opacity:.4}.card-back-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.reveal-hint{font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--text-muted);text-align:center;letter-spacing:.06em}.reveal-hint-divider{display:flex;align-items:center;justify-content:center;gap:6px}.reveal-privacy-note{display:flex;align-items:center;gap:8px;background:#0e0a04d9;border:1px solid var(--dark-panel-border);border-radius:24px;padding:8px 16px;width:100%}.reveal-privacy-icon{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:11px;font-weight:700;color:var(--gold-dim);flex-shrink:0}.reveal-privacy-text{font-family:var(--font-body);font-size:11px;color:var(--text-muted);letter-spacing:.02em}.reveal-actions{display:flex;gap:10px;width:100%}.reveal-actions .btn-outline{flex:1;font-size:12px;padding:13px 8px}.reveal-actions .btn-start{flex:1;font-size:13px;padding:13px 8px}.btn-reveal-dark{display:block;width:100%;font-family:var(--font-title);font-size:16px;font-weight:700;letter-spacing:.2em;color:#ffffffe6;background:#060402eb;border:1.5px solid rgba(212,175,55,.3);border-radius:8px;padding:18px 20px;text-align:center;cursor:pointer;transition:border-color .2s,color .2s,transform .1s}.btn-reveal-dark:active{border-color:var(--gold-dim);color:#fff;transform:scale(.98)}.reveal-tap-hint{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-family:var(--font-body);font-size:12px;font-weight:400;letter-spacing:.08em;font-style:italic;width:100%;justify-content:center}.reveal-tap-hint-line{flex:1;height:1px;background:linear-gradient(to right,transparent,rgba(212,175,55,.25))}.reveal-tap-hint-line+span+.reveal-tap-hint-line{background:linear-gradient(to left,transparent,rgba(212,175,55,.25))}.started-screen{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 40%,rgba(120,0,0,.45) 0%,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(90,0,0,.5) 0%,transparent 45%),linear-gradient(to bottom,#0000004d,#00000026,#00000059);padding:calc(var(--sat) + 40px) calc(var(--sar) + 24px) calc(var(--sab) + 40px) calc(var(--sal) + 24px);gap:20px;position:relative}.started-title{font-family:var(--font-display);font-size:36px;font-weight:900;letter-spacing:.15em;color:var(--gold);text-shadow:0 0 40px rgba(212,175,55,.55),0 0 80px rgba(139,0,0,.3);text-align:center}.started-subtitle{font-family:var(--font-body);font-size:14px;font-weight:300;letter-spacing:.12em;color:var(--text-muted);text-align:center;font-style:italic}.started-divider{width:60%;height:1px;background:linear-gradient(to right,transparent,var(--gold-dim),transparent)}.started-coming-soon{font-family:var(--font-title);font-size:12px;font-weight:600;letter-spacing:.2em;color:var(--text-dim);text-align:center}.started-back{margin-top:20px;width:100%}.game-mode-section{margin:0 16px;background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:14px 12px 12px}.game-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.game-mode-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 10px 14px;border-radius:9px;border:1.5px solid rgba(212,175,55,.14);background:#120c04d9;cursor:pointer;transition:border-color .22s,background .22s,box-shadow .22s;position:relative;overflow:hidden}.game-mode-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,rgba(212,175,55,.04),transparent);opacity:0;transition:opacity .22s}.game-mode-card.active{border-color:var(--gold-dim);background:#1a1204f2;box-shadow:0 0 16px #d4af371a,inset 0 1px #d4af3714}.game-mode-card.active:before{opacity:1}.game-mode-icon{width:38px;height:38px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.game-mode-name{font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.18em;color:var(--text-muted);text-align:center;transition:color .22s;position:relative;z-index:1}.game-mode-card.active .game-mode-name{color:var(--gold)}.game-mode-desc{font-family:var(--font-body);font-size:10px;font-weight:400;letter-spacing:.04em;color:var(--text-dim);text-align:center;transition:color .22s;position:relative;z-index:1;min-height:2.8em;line-height:1.4;display:flex;align-items:center;justify-content:center}.game-mode-card.active .game-mode-desc{color:var(--text-muted)}.game-mode-recommend{font-family:var(--font-body);font-size:9px;letter-spacing:.06em;color:var(--gold-dim);text-align:center;margin-top:4px;opacity:.8}.game-mode-active-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);position:absolute;top:8px;right:8px;box-shadow:0 0 6px #d4af3799}.names-edit-btn{display:flex;align-items:center;justify-content:space-between;width:100%;margin:10px 0 0;padding:10px 14px;background:#140e04d9;border:1px solid var(--dark-panel-border);border-radius:8px;cursor:pointer;transition:border-color .2s,background .2s;gap:10px}.names-edit-btn:active{border-color:var(--gold-dim);background:#1e1406f2}.names-edit-btn-left{display:flex;align-items:center;gap:8px}.names-edit-btn-label{font-family:var(--font-title);font-size:11px;font-weight:600;letter-spacing:.16em;color:var(--gold-dim)}.names-edit-btn-badge{font-family:var(--font-title);font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-muted);background:#d4af371a;border:1px solid rgba(212,175,55,.2);border-radius:20px;padding:2px 8px;transition:color .2s,background .2s}.names-hint{font-family:var(--font-body);font-size:10.5px;font-weight:400;color:var(--text-dim);text-align:center;line-height:1.55;margin-top:8px;padding:0 4px;font-style:italic;letter-spacing:.02em}.names-edit-btn-badge.complete{color:var(--gold);background:#d4af372e;border-color:var(--gold-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:100;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;transition:background .3s ease}.modal-overlay.modal-overlay-open{background:#000000b8;pointer-events:all;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.modal-sheet{width:100%;max-width:430px;max-height:82vh;background:linear-gradient(to bottom,#140e04fa,#0c0802fc);border-top:1.5px solid var(--gold-dim);border-left:1px solid rgba(212,175,55,.12);border-right:1px solid rgba(212,175,55,.12);border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(100%);opacity:0;transition:transform .38s cubic-bezier(.32,.72,0,1),opacity .25s ease;box-shadow:0 -8px 40px #0009,0 -2px 20px #d4af370f}.modal-sheet.modal-sheet-open{transform:translateY(0);opacity:1}.modal-handle{width:40px;height:4px;background:#d4af3740;border-radius:2px;margin:12px auto 0;flex-shrink:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0;flex-shrink:0}.modal-title{font-family:var(--font-title);font-size:13px;font-weight:700;letter-spacing:.22em;color:var(--gold)}.modal-subtitle{display:flex;align-items:center}.modal-count{font-family:var(--font-title);font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--text-muted);transition:color .2s}.modal-count.modal-count-done{color:var(--gold)}.modal-divider{height:1px;background:linear-gradient(to right,transparent,var(--gold-dim),transparent);margin:12px 20px 0;flex-shrink:0;opacity:.5}.modal-body{flex:1;overflow-y:auto;padding:12px 20px 4px;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin;scrollbar-color:var(--gold-dim) transparent}.modal-body::-webkit-scrollbar{width:2px}.modal-body::-webkit-scrollbar-thumb{background:var(--gold-dim);border-radius:1px}.modal-name-row{display:flex;align-items:center;gap:10px}.modal-name-number{font-family:var(--font-title);font-size:11px;font-weight:600;color:var(--text-dim);min-width:20px;text-align:right;flex-shrink:0}.modal-name-input{flex:1;background:#161005e6;border:1px solid rgba(212,175,55,.15);border-radius:7px;padding:10px 14px;color:var(--text-light);font-family:var(--font-body);font-size:14px;font-weight:400;outline:none;transition:border-color .2s,background .2s;-webkit-appearance:none}.modal-name-input::placeholder{color:var(--text-dim);font-style:italic}.modal-name-input:focus{border-color:var(--gold-dim);background:#1e1606f2}.modal-name-input.filled{border-color:#d4af374d}.modal-name-input.duplicate{border-color:#c83c3cb3;background:#1e0808f2}.modal-dupe-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.modal-dupe-msg{font-family:var(--font-body);font-size:11px;color:#dc5050e6;text-align:center;padding:6px 0 2px;letter-spacing:.04em}.modal-footer{padding:14px 20px 28px;flex-shrink:0;border-top:1px solid rgba(212,175,55,.1);margin-top:8px}.modal-done-btn{display:block;width:100%;font-family:var(--font-title);font-size:15px;font-weight:700;letter-spacing:.22em;color:#fff;background:linear-gradient(to bottom,#9a0000,#6b0000,#8b0000);border:1.5px solid var(--gold-dim);border-radius:8px;padding:16px 20px;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.6);box-shadow:0 0 20px #8b000073,inset 0 1px #ffffff12;transition:filter .15s,transform .1s;cursor:pointer}.modal-done-btn:active{filter:brightness(.82);transform:scale(.98)}.night-result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:150;display:flex;align-items:center;justify-content:center;padding:24px;animation:nr-fade-in .22s ease}@keyframes nr-fade-in{0%{opacity:0}to{opacity:1}}.night-result-card{width:100%;max-width:360px;background:linear-gradient(160deg,#160e04fa,#0a0602fc);border:1px solid rgba(212,175,55,.25);border-radius:18px;padding:24px 20px 20px;display:flex;flex-direction:column;gap:0;box-shadow:0 20px 60px #000000b3,0 0 40px #d4af370d;animation:nr-scale-in .26s cubic-bezier(.34,1.3,.64,1)}@keyframes nr-scale-in{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}.night-result-title{font-family:var(--font-title);font-size:13px;font-weight:700;letter-spacing:.12em;color:var(--gold);text-align:center;margin-bottom:16px}.night-result-divider{height:1px;background:linear-gradient(to right,transparent,rgba(212,175,55,.25),transparent);margin-bottom:20px}.night-result-body{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}.night-result-no-kill{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px 0 4px;font-family:var(--font-title);font-size:11px;letter-spacing:.08em;color:#d4af378c;text-align:center}.night-result-subtitle{font-family:var(--font-title);font-size:10px;letter-spacing:.12em;color:#c85050b3;text-align:center;margin-bottom:2px}.night-result-row{display:flex;align-items:center;gap:12px;background:#b414141f;border:1px solid rgba(200,40,40,.22);border-radius:12px;padding:13px 16px}.night-result-num{font-family:var(--font-title);font-size:11px;color:#d4af3773;min-width:18px}.night-result-name{font-family:var(--font-title);font-size:14px;font-weight:600;letter-spacing:.06em;color:#e6c8b4eb}.night-result-btn{width:100%;padding:13px;background:transparent;border:1px solid rgba(212,175,55,.35);border-radius:10px;font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.12em;color:var(--gold);cursor:pointer;transition:background .18s ease,border-color .18s ease}.night-result-btn:active{background:#d4af3714;border-color:#d4af3799}.sp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none}.sp-overlay.sp-open{pointer-events:all}.sp-page{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:radial-gradient(ellipse at 70% 15%,rgba(100,0,0,.38) 0%,transparent 48%),radial-gradient(ellipse at 30% 80%,rgba(60,0,0,.2) 0%,transparent 45%),linear-gradient(to bottom,#0a0504,#070403);transform:translate(100%);transition:transform .38s cubic-bezier(.32,.72,0,1);overflow:hidden}.sp-overlay.sp-open .sp-page{transform:translate(0)}.sp-header{display:flex;align-items:center;justify-content:space-between;padding:calc(var(--sat) + 14px) 16px 0;flex-shrink:0}.sp-title{font-family:var(--font-title);font-size:16px;font-weight:700;letter-spacing:.2em;color:var(--gold);text-shadow:0 0 20px rgba(212,175,55,.4)}.sp-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px 16px calc(var(--sab) + 24px);display:flex;flex-direction:column;gap:6px;scrollbar-width:none;overscroll-behavior:none}.sp-body::-webkit-scrollbar{display:none}.sp-section-label{font-family:var(--font-title);font-size:9px;font-weight:700;letter-spacing:.3em;color:var(--text-dim);padding:10px 4px 4px}.sp-card{background:#0e0a04e0;border:1px solid var(--dark-panel-border);border-radius:12px;overflow:hidden}.sp-lang-row{display:flex;gap:10px;padding:12px}.sp-divider{height:1px;background:#d4af371a;margin:0 16px}.sp-row{display:flex;align-items:center;gap:14px;width:100%;padding:15px 16px;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s;-webkit-tap-highlight-color:transparent}.sp-row:active{background:#d4af370f}.sp-row-disabled{cursor:default}.sp-row-disabled:active{background:none}.sp-row-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sp-row-label{flex:1;font-family:var(--font-body);font-size:14px;font-weight:400;color:#e6d28cd9;letter-spacing:.02em}.sp-row-right{display:flex;align-items:center;flex-shrink:0}.sp-badge-premium{display:flex;align-items:center;gap:4px;background:#d4af3724;border:1px solid var(--gold-dim);border-radius:20px;padding:3px 8px 3px 5px}.sp-badge-premium span{font-family:var(--font-title);font-size:9px;font-weight:700;letter-spacing:.14em;color:var(--gold)}.sp-version-text{font-family:var(--font-body);font-size:13px;color:var(--text-dim);letter-spacing:.06em}.sp-toast{position:absolute;bottom:calc(var(--sab) + 32px);left:50%;transform:translate(-50%);background:#140e04f2;border:1px solid var(--gold-dim);border-radius:20px;padding:8px 20px;font-family:var(--font-body);font-size:12px;color:var(--text-muted);letter-spacing:.06em;white-space:nowrap;pointer-events:none;animation:toastIn .25s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.htp-intro{font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--text-light);line-height:1.6;letter-spacing:.02em;text-align:center;padding:4px 4px 12px;font-style:italic}.htp-list{display:flex;flex-direction:column;gap:8px}.htp-section{background:#0e0a04e0;border:1px solid var(--dark-panel-border);border-radius:10px;overflow:hidden;transition:border-color .2s}.htp-section-open{border-color:#d4af374d}.htp-section-header{display:flex;align-items:center;gap:12px;width:100%;padding:16px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.htp-section-header:active{background:#d4af370a}.htp-section-number{font-family:var(--font-title);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--gold-dim);flex-shrink:0;min-width:22px}.htp-section-title{flex:1;font-family:var(--font-title);font-size:13px;font-weight:600;letter-spacing:.12em;color:var(--gold)}.htp-section-body{padding:0 16px 16px;border-top:1px solid rgba(212,175,55,.1)}.htp-section-body p{font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--text-light);line-height:1.65;letter-spacing:.02em;padding-top:12px}.settings-body{padding:16px 20px 8px;display:flex;flex-direction:column;gap:12px}.settings-section-label{font-family:var(--font-title);font-size:9px;font-weight:700;letter-spacing:.28em;color:var(--text-muted)}.settings-lang-row{display:flex;gap:10px}.settings-lang-btn{flex:1;display:flex;align-items:center;gap:10px;padding:10px 14px;background:#140e04d9;border:1.5px solid rgba(212,175,55,.14);border-radius:8px;cursor:pointer;transition:border-color .2s,background .2s}.settings-lang-btn.active{border-color:var(--gold-dim);background:#1e1404f2}.settings-lang-btn span{font-family:var(--font-title);font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--text-muted);transition:color .2s}.settings-lang-btn.active span{color:var(--gold)}.btn-settings{width:36px;height:36px;border-radius:50%;border:1px solid var(--gold-dim);background:#0a0602cc;display:flex;align-items:center;justify-content:center;color:var(--gold);cursor:pointer;transition:border-color .2s,box-shadow .2s;flex-shrink:0}.btn-settings:active{box-shadow:0 0 12px var(--gold-dim)}.btn-settings-abs{position:absolute;top:calc(var(--sat) + 12px);right:calc(var(--sar) + 16px);z-index:10}.tap-icon{font-size:22px;opacity:.6}.gold-dot{width:5px;height:5px;background:var(--gold-dim);transform:rotate(45deg);flex-shrink:0}@media (max-width: 768px){html,.app-viewport{background-position:75% top}}.host-version-toggle-panel{display:flex;align-items:center;justify-content:space-between;background:#0e0a04b3;border:1px solid rgba(212,175,55,.2);border-radius:10px;padding:14px 16px;margin:0 16px}.host-version-toggle-left{display:flex;align-items:center;gap:12px}.host-version-toggle-title{font-family:var(--font-display);font-size:14px;letter-spacing:.08em;color:var(--gold)}.host-version-toggle-desc{font-family:var(--font-body);font-size:11px;color:var(--text-muted);margin-top:2px}.host-toggle-btn{width:44px;height:26px;border-radius:13px;border:1px solid rgba(212,175,55,.3);background:#140e06e6;position:relative;cursor:pointer;transition:background .25s,border-color .25s;flex-shrink:0}.host-toggle-btn.on{background:#8b000099;border-color:var(--gold-dim)}.host-toggle-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#d4af3780;transition:transform .25s,background .25s}.host-toggle-btn.on .host-toggle-knob{transform:translate(18px);background:var(--gold)}.hv-screen{display:flex;flex-direction:column;min-height:100%;padding:calc(var(--sat) + 12px) calc(var(--sar) + 16px) calc(var(--sab) + 20px) calc(var(--sal) + 16px);gap:0}.hv-header{display:flex;align-items:center;gap:12px;padding-bottom:12px}.hv-header-center{flex:1;text-align:center}.hv-title{font-family:var(--font-display);font-size:18px;letter-spacing:.12em;color:var(--gold)}.hv-subtitle{font-family:var(--font-body);font-size:10px;color:var(--text-muted);margin-top:2px}.hv-panel{background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;overflow:hidden;flex-shrink:0}.hv-controls{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(212,175,55,.1)}.hv-new-day-btn{display:flex;align-items:center;gap:7px;padding:7px 12px;background:#8b000040;border:1px solid rgba(212,175,55,.3);border-radius:7px;font-family:var(--font-display);font-size:13px;letter-spacing:.08em;color:var(--gold);cursor:pointer;transition:background .2s;flex-shrink:0}.hv-new-day-btn:active{background:#8b000080}.hv-day-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;background:#d4af3726;border:1px solid rgba(212,175,55,.35);border-radius:10px;font-family:var(--font-body);font-size:12px;color:var(--gold);font-weight:600}.hv-timer{flex:1;text-align:center;font-family:var(--font-display);font-size:22px;letter-spacing:.06em;color:var(--gold);background:none;border:1px solid rgba(212,175,55,.18);border-radius:7px;height:34px;padding:0 8px;display:flex;align-items:center;justify-content:center;transition:color .3s,border-color .3s}.hv-timer.hv-timer-warning{color:#dc3232f2;border-color:#dc323266}.hv-play-stop-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#d4af370f;border:1px solid rgba(212,175,55,.2);border-radius:7px;cursor:pointer;transition:background .2s;flex-shrink:0}.hv-play-stop-btn:active{background:#d4af3726}.hv-table-header{display:flex;align-items:center;padding:6px 10px;border-bottom:1px solid rgba(212,175,55,.12);background:#d4af370a}.hv-table-header .hv-cell{font-family:var(--font-display);font-size:10px;letter-spacing:.1em;color:var(--text-muted)}.hv-row{display:flex;align-items:center;padding:7px 10px;border-bottom:1px solid rgba(212,175,55,.07);transition:background .15s}.hv-row:last-child{border-bottom:none}.hv-row-eliminated{opacity:.4;pointer-events:none}.hv-row-eliminated .hv-cell-name span{text-decoration:line-through;text-decoration-color:#d4af3780}.hv-cell{display:flex;align-items:center}.hv-cell-num{width:22px;font-family:var(--font-body);font-size:11px;color:var(--text-muted);flex-shrink:0}.hv-cell-name{flex:1;gap:5px;font-family:var(--font-body);font-size:13px;color:var(--text-light);min-width:0}.hv-cell-name span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hv-mute-badge{display:flex;align-items:center;flex-shrink:0}.hv-cell-remarks{width:108px;flex-shrink:0;justify-content:center}.hv-cell-cand{width:72px;flex-shrink:0;justify-content:center}.hv-remark-dots{display:flex;gap:5px;align-items:center}.hv-remark-dot{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(212,175,55,.35);background:#d4af370d;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s;padding:0}.hv-remark-dot.filled{background:#a0141473;border-color:#c82828b3}.hv-remark-dot:not(:disabled):active{background:#b41e1e99}.hv-remark-dot:disabled{cursor:default}.hv-cand-btn{width:26px;height:26px;border-radius:5px;border:1.5px solid rgba(212,175,55,.25);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s;padding:0}.hv-cand-btn.nominated{background:#d4af371f;border-color:var(--gold-dim)}.hv-cand-btn:disabled{opacity:.3;cursor:default}.hv-dash{color:var(--text-dim);font-size:14px;line-height:1}.hv-info-panel{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-top:1px solid rgba(212,175,55,.1);background:#d4af3708}.hv-info-icon{flex-shrink:0;margin-top:1px}.hv-info-rules{display:flex;flex-direction:column;gap:5px;flex:1}.hv-info-rule{display:flex;align-items:center;gap:7px}.hv-info-rule span{font-family:var(--font-body);font-size:11px;color:var(--text-muted)}.hv-dot{width:7px;height:7px;border-radius:50%;border:1.5px solid rgba(212,175,55,.4);flex-shrink:0}.hv-dot.filled{background:#d4af374d;border-color:var(--gold-dim)}.hv-cand-section{margin-top:14px;background:#0c0803bf;border:1px solid rgba(212,175,55,.13);border-radius:12px;padding:12px 14px;flex-shrink:0}.hv-cand-title{font-family:var(--font-display);font-size:13px;letter-spacing:.1em;color:var(--gold)}.hv-cand-subtitle{font-family:var(--font-body);font-size:10px;color:var(--text-muted);margin-top:2px;margin-bottom:10px}.hv-cand-chips{display:flex;flex-wrap:wrap;gap:7px}.hv-cand-empty{font-family:var(--font-body);font-size:12px;color:var(--text-dim);font-style:italic}.hv-cand-chip{display:flex;align-items:center;gap:6px;padding:5px 10px 5px 7px;background:#8b000033;border:1px solid rgba(212,175,55,.3);border-radius:20px}.hv-cand-chip-num{width:20px;height:20px;border-radius:50%;background:#d4af3726;border:1px solid rgba(212,175,55,.4);display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:11px;color:var(--gold);font-weight:600;flex-shrink:0}.hv-cand-chip-name{font-family:var(--font-body);font-size:12px;color:var(--text-light);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hv-voting-wrap{margin-top:14px;padding-bottom:4px;flex-shrink:0}.hv-voting-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;background:linear-gradient(135deg,#8b000080,#64000059);border:1px solid rgba(212,175,55,.45);border-radius:10px;font-family:var(--font-display);font-size:16px;letter-spacing:.12em;color:var(--gold);cursor:pointer;transition:background .2s,box-shadow .2s;box-shadow:0 2px 18px #8b000040}.hv-voting-btn:active{background:linear-gradient(135deg,#8b0000b3,#6400008c);box-shadow:0 2px 24px #8b000073}.hv-day-display{display:flex;align-items:center;gap:7px;height:34px;padding:0 12px;background:#0e0a0499;border:1px solid rgba(212,175,55,.2);border-radius:7px;font-family:var(--font-display);font-size:13px;letter-spacing:.08em;color:var(--text-muted);flex-shrink:0}.vm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#040200e0;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding-bottom:var(--sab)}.vm-panel{width:100%;max-width:480px;background:linear-gradient(180deg,#0e0a04,#0a0602);border:1px solid rgba(212,175,55,.25);border-bottom:none;border-radius:18px 18px 0 0;padding:20px 20px calc(var(--sab) + 20px);max-height:90vh;overflow-y:auto}.vm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.vm-title{font-family:var(--font-display);font-size:18px;letter-spacing:.12em;color:var(--gold)}.vm-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#d4af3712;border:1px solid rgba(212,175,55,.2);border-radius:50%;cursor:pointer}.vm-divider{height:1px;background:#d4af371f;margin:12px 0}.vm-empty{text-align:center;font-family:var(--font-body);font-size:13px;color:var(--text-muted);padding:24px 0}.vm-votes-info{display:flex;align-items:baseline;gap:6px;margin-bottom:14px}.vm-votes-total{font-family:var(--font-display);font-size:28px;color:var(--gold);line-height:1}.vm-votes-label{font-family:var(--font-body);font-size:12px;color:var(--text-muted)}.vm-candidates{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.vm-cand-row{display:flex;align-items:center;gap:10px;background:#d4af370a;border:1px solid rgba(212,175,55,.13);border-radius:9px;padding:10px 12px}.vm-cand-id{width:28px;height:28px;border-radius:50%;background:#d4af371f;border:1px solid rgba(212,175,55,.35);display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--gold);flex-shrink:0}.vm-cand-name{flex:1;font-family:var(--font-body);font-size:14px;color:var(--text-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vm-vote-ctrl{display:flex;align-items:center;gap:8px;flex-shrink:0}.vm-vote-btn{width:30px;height:30px;border-radius:6px;border:1px solid rgba(212,175,55,.3);background:#d4af3714;color:var(--gold);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.vm-vote-btn:active{background:#d4af3733}.vm-vote-num{font-family:var(--font-display);font-size:22px;color:var(--gold);min-width:28px;text-align:center}.vm-vote-auto{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex-shrink:0}.vm-vote-auto-label{font-family:var(--font-body);font-size:9px;letter-spacing:.08em;color:var(--text-dim);text-transform:uppercase}.vm-tie-header{font-family:var(--font-display);font-size:15px;letter-spacing:.1em;color:var(--gold);margin-bottom:10px;text-align:center}.vm-tie-info{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:18px}.vm-tie-name{font-family:var(--font-body);font-size:12px;color:var(--text-muted);padding:4px 10px;border-radius:12px;border:1px solid rgba(212,175,55,.15)}.vm-tie-name.active{color:var(--gold);border-color:var(--gold-dim);background:#d4af371a}.vm-tie-speaking{text-align:center;margin-bottom:18px}.vm-tie-label{font-family:var(--font-body);font-size:11px;letter-spacing:.1em;color:var(--text-muted);margin-bottom:4px}.vm-tie-player{font-family:var(--font-display);font-size:20px;color:var(--gold);margin-bottom:10px}.vm-tie-timer{font-family:var(--font-display);font-size:42px;color:var(--gold);transition:color .3s}.vm-tie-timer.warning{color:#dc3232f2}.vm-tie-done-text{font-family:var(--font-body);font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:18px}.vm-result-wrap{text-align:center;margin-bottom:20px}.vm-result-label{font-family:var(--font-body);font-size:11px;letter-spacing:.12em;color:var(--text-muted);margin-bottom:10px}.vm-result-player{display:flex;align-items:center;justify-content:center;gap:12px}.vm-result-num{width:44px;height:44px;border-radius:50%;background:#8b00004d;border:2px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;color:var(--gold)}.vm-result-name{font-family:var(--font-display);font-size:22px;color:var(--gold)}.vm-result-votes{font-family:var(--font-body);font-size:12px;color:var(--text-muted);margin-top:8px}.vm-actions{display:flex;flex-direction:column;gap:10px}.vm-primary-btn{width:100%;padding:14px;background:#d4af371f;border:1px solid var(--gold-dim);border-radius:10px;font-family:var(--font-display);font-size:15px;letter-spacing:.1em;color:var(--gold);cursor:pointer;transition:background .2s}.vm-primary-btn:active{background:#d4af3738}.vm-eliminate-btn{width:100%;padding:14px;background:linear-gradient(135deg,#8b00008c,#64000066);border:1px solid rgba(212,175,55,.5);border-radius:10px;font-family:var(--font-display);font-size:15px;letter-spacing:.1em;color:var(--gold);cursor:pointer;box-shadow:0 2px 16px #8b00004d;transition:background .2s}.vm-eliminate-btn:active{background:#8b0000b3}.vm-secondary-btn{width:100%;padding:12px;background:transparent;border:1px solid rgba(212,175,55,.18);border-radius:10px;font-family:var(--font-body);font-size:13px;color:var(--text-muted);cursor:pointer;transition:border-color .2s}.vm-secondary-btn:active{border-color:var(--gold-dim)}.night-roles-panel{background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:14px;margin-bottom:12px}.night-section-label{font-family:var(--font-display);font-size:10px;letter-spacing:.12em;color:var(--text-muted);margin-bottom:8px}.night-role-cards{display:flex;flex-wrap:wrap;gap:7px}.night-role-card{display:flex;align-items:center;gap:8px;height:40px;padding:0 10px;background:#d4af370d;border:1px solid rgba(212,175,55,.2);border-radius:8px}.night-role-card.eliminated{opacity:.35;text-decoration:line-through}.night-role-num{width:24px;height:24px;border-radius:50%;background:#d4af371f;border:1px solid rgba(212,175,55,.35);display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--gold);flex-shrink:0}.night-role-name{font-family:var(--font-body);font-size:13px;color:var(--text-light)}.night-role-tag{font-family:var(--font-display);font-size:9px;letter-spacing:.1em;padding:2px 7px;border-radius:10px;flex-shrink:0}.night-role-tag.mafia,.night-role-tag.don{background:#8b000059;border:1px solid rgba(212,175,55,.3);color:var(--gold)}.night-role-tag.sheriff{background:#d4af371f;border:1px solid rgba(212,175,55,.3);color:var(--gold)}.night-role-tag.doctor{background:#00643c40;border:1px solid rgba(0,180,100,.3);color:#00c878e6}.night-none{font-family:var(--font-body);font-size:13px;color:var(--text-dim)}.night-kill-panel{background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:14px;margin-bottom:12px}.night-kill-title{font-family:var(--font-display);font-size:13px;letter-spacing:.1em;color:var(--gold);margin-bottom:12px}.night-victim-grid{display:flex;flex-direction:column;gap:7px}.night-victim-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#d4af370a;border:1px solid rgba(212,175,55,.15);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s;text-align:left}.night-victim-btn.selected{background:#8b00004d;border-color:var(--gold-dim)}.night-victim-btn.no-kill{font-family:var(--font-body);font-size:13px;color:var(--text-muted);justify-content:center;border-style:dashed}.night-victim-btn.no-kill.selected{color:var(--gold)}.night-victim-num{width:24px;height:24px;border-radius:50%;background:#d4af371a;border:1px solid rgba(212,175,55,.3);display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--gold);flex-shrink:0}.night-victim-name{font-family:var(--font-body);font-size:13px;color:var(--text-light)}.game-over-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:calc(var(--sat) + 40px) 24px calc(var(--sab) + 40px);gap:32px}.game-over-banner{width:100%;text-align:center;padding:40px 24px;border-radius:16px;border:1px solid rgba(212,175,55,.3)}.game-over-banner.mafia{background:linear-gradient(160deg,#50000080,#140804e6);box-shadow:0 0 60px #8b000040}.game-over-banner.citizen{background:linear-gradient(160deg,#1e3c0a66,#0a1404e6);box-shadow:0 0 60px #32641433}.game-over-title{font-family:var(--font-display);font-size:32px;letter-spacing:.14em;color:var(--gold);margin-bottom:14px}.game-over-desc{font-family:var(--font-body);font-size:14px;color:var(--text-muted);line-height:1.6}.game-over-btn{width:100%}.fn-instruction-card{background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:18px 16px;margin-bottom:14px}.fn-instruction-text{font-family:var(--font-body);font-size:14px;line-height:1.7;color:var(--text-light);margin:0}.fn-timer-row{margin-bottom:10px}.fn-timer{position:relative;width:100%;text-align:center;font-family:var(--font-display);font-size:42px;letter-spacing:.06em;color:var(--gold);background:#0c0803d1;border:1px solid rgba(212,175,55,.18);border-radius:10px;padding:12px 52px;transition:color .3s,border-color .3s}.fn-timer-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%)}.fn-timer.warning{color:#dc3232f2;border-color:#dc323266}.fn-skip-btn{width:100%;padding:11px;background:transparent;border:1px solid rgba(212,175,55,.15);border-radius:9px;font-family:var(--font-body);font-size:13px;color:var(--text-muted);cursor:pointer;margin-bottom:8px;transition:border-color .2s,color .2s}.fn-skip-btn:active{color:var(--gold);border-color:var(--gold-dim)}.fn-good-morning-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 20px;background:linear-gradient(135deg,#d4af372e,#a0821e1f);border:1px solid var(--gold-dim);border-radius:10px;font-family:var(--font-display);font-size:18px;letter-spacing:.14em;color:var(--gold);cursor:pointer;box-shadow:0 2px 20px #d4af3726;transition:background .2s,box-shadow .2s}.fn-good-morning-btn:active{background:#d4af3747;box-shadow:0 2px 28px #d4af374d}.fn-divider{height:1px;background:#d4af371f;margin:6px 0 14px}.vm-tie-timer-row{display:flex;flex-direction:column;align-items:center;gap:12px}.vm-leave-icon{background:#a0141459;border-color:#c8282880;color:#dc5050e6;font-size:12px}.vm-stay-icon{background:#1e641e40;border-color:#32a03266;color:#50c850e6;font-size:14px}.vm-final-players{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:4px}.hv-players-left{display:flex;align-items:center;gap:4px;height:34px;padding:0 9px;background:#d4af370f;border:1px solid rgba(212,175,55,.18);border-radius:7px;flex-shrink:0}.hv-players-left-num{font-family:var(--font-display);font-size:15px;color:var(--gold);line-height:1}.night-role-tag.killer{background:#3c003c59;border:1px solid rgba(160,80,200,.4);color:#c882ffe6}.fn-civil-role-card{width:100%}.fn-instruction-line{margin:0;padding:5px 0;border-bottom:1px solid rgba(212,175,55,.08)}.fn-instruction-line:last-child{border-bottom:none;padding-bottom:0}.fn-instruction-line:first-child{padding-top:0}.fn-mafia-panel{display:flex;background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;overflow:hidden;margin-bottom:12px}.fn-mafia-left{flex:1;padding:14px;border-right:1px solid rgba(212,175,55,.1);min-width:0}.fn-mafia-cards{display:flex;flex-direction:column;gap:7px;margin-top:8px}.fn-mafia-right{width:96px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:14px 10px}.fn-panel-timer{font-family:var(--font-display);font-size:28px;letter-spacing:.04em;color:var(--gold);text-align:center;transition:color .3s}.fn-panel-timer.warning{color:#dc3232f2}.fn-special-roles-panel{gap:0}.fn-special-roles-panel .fn-mafia-cards{margin-top:0}.night-kill-panel-killer{border-color:#a050c840}.night-kill-panel-killer .night-kill-title{color:#c882ffd9}.night-kill-panel-doctor{border-color:#00b46440}.night-kill-panel-doctor .night-kill-title{color:#00c878d9}.night-victim-no-repeat{opacity:.35;cursor:not-allowed}.night-tab-switcher{display:flex;gap:6px;margin-bottom:12px}.night-tab-btn{flex:1;padding:8px 6px;border-radius:8px;border:1px solid rgba(212,175,55,.2);background:#d4af370a;font-family:var(--font-display);font-size:12px;letter-spacing:.08em;color:var(--text-muted);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.night-tab-btn.night-tab-mafia.active{background:#8b00004d;border-color:var(--gold-dim);color:var(--gold)}.night-tab-btn.night-tab-doctor.active{background:#00643c4d;border-color:#00b46480;color:#00d278e6}.night-tab-btn.night-tab-killer.active{background:#3c003c4d;border-color:#a050c880;color:#c882ffe6}.night-tab-desc{font-family:var(--font-body);font-size:12px;color:var(--text-muted);margin-bottom:12px}.night-tab-desc-mafia{color:#d4af3799}.night-tab-desc-doctor{color:#00be6eb3}.night-tab-desc-killer{color:#be78ffb3}.game-over-banner.killer{background:linear-gradient(160deg,#3c005080,#140414e6);box-shadow:0 0 60px #a050c840}.elim-confirm-panel{padding-top:24px}.elim-confirm-player{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px}.elim-confirm-msg{font-family:var(--font-body);font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:20px}.htp-mode-switcher{display:flex;gap:8px;margin-bottom:16px}.htp-mode-btn{flex:1;padding:9px 8px;border-radius:8px;border:1px solid rgba(212,175,55,.2);background:#d4af370a;font-family:var(--font-display);font-size:13px;letter-spacing:.1em;color:var(--text-muted);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.htp-mode-btn.active{background:#8b000040;border-color:var(--gold-dim);color:var(--gold)}.htp-bullets{list-style:none;padding:0;margin:8px 0;display:flex;flex-direction:column;gap:7px}.htp-bullets li{font-family:var(--font-body);font-size:13px;color:var(--text-light);line-height:1.55;padding-left:14px;position:relative}.htp-bullets li:before{content:"—";position:absolute;left:0;color:var(--gold-dim);font-size:11px}.htp-roles{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:280px;gap:8px;margin:10px 0}.htp-role-card{border-radius:10px;padding:16px 10px 12px;border:1px solid rgba(212,175,55,.15);display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;overflow:hidden}.htp-role-card-mafia{background:linear-gradient(160deg,#120e0cfa,#080604);border-color:#d4af372e}.htp-role-card-citizen{background:linear-gradient(160deg,#b4000073,#3c0000e6);border-color:#dc282880}.htp-role-card-special{background:linear-gradient(160deg,#1e2d3c80,#080c12f7);border-color:#5078a073}.htp-role-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:6px}.htp-role-tag{font-size:8px!important;padding:2px 6px!important;white-space:nowrap;flex-shrink:0;margin-top:1px}.htp-role-name{font-family:var(--font-display);font-size:14px;letter-spacing:.1em;color:var(--gold)}.htp-role-desc{font-family:var(--font-body);font-size:11px;color:var(--text-light);line-height:1.5;margin:0;opacity:.85;text-align:center;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.nb-screen{display:flex;flex-direction:column;align-items:center;min-height:100%;padding:calc(var(--sat) + 40px) 24px calc(var(--sab) + 24px);gap:0}.nb-moon{margin-bottom:20px;opacity:.9}.nb-title{font-family:var(--font-display);font-size:36px;letter-spacing:.16em;color:var(--gold);text-align:center}.nb-subtitle{font-family:var(--font-body);font-size:14px;color:var(--text-muted);text-align:center;margin-top:6px;margin-bottom:28px}.nb-instruction-card{width:100%;background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:20px 16px;display:flex;flex-direction:column;gap:16px;margin-bottom:28px}.nb-step{display:flex;align-items:flex-start;gap:14px}.nb-step-num{width:26px;height:26px;border-radius:50%;background:#d4af371f;border:1px solid rgba(212,175,55,.3);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:13px;color:var(--gold);flex-shrink:0;margin-top:1px}.nb-step p{font-family:var(--font-body);font-size:13px;color:var(--text-light);line-height:1.6;margin:0}.nb-actions{width:100%;display:flex;flex-direction:column;gap:10px;margin-top:auto}.nb-reveal-btn{font-size:15px;letter-spacing:.1em}.nb-back-btn{font-size:12px}.htp-subheading{font-family:var(--font-display);font-size:12px;letter-spacing:.1em;color:var(--gold);margin-top:14px;margin-bottom:-4px;opacity:.85}.htp-role-icon{width:56px;height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:.85}.night-role-tag.htp-special{background:#1e3c5073;border:1px solid rgba(80,140,180,.5);color:#82bedce6}.home-settings-btn{position:absolute;top:calc(var(--sat) + 12px);left:calc(var(--sal) + 16px);z-index:10}.sp-subpage-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;background:radial-gradient(ellipse at 70% 15%,rgba(100,0,0,.38) 0%,transparent 48%),radial-gradient(ellipse at 30% 80%,rgba(60,0,0,.2) 0%,transparent 45%),linear-gradient(to bottom,#0a0504,#070403)}.sp-subpage{display:flex;flex-direction:column;height:100%}.og-list{display:flex;flex-direction:column;gap:10px}.og-card{display:flex;align-items:center;gap:14px;background:#d4af370a;border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:12px 14px}.og-icon{width:52px;height:52px;border-radius:12px;border:1px solid rgba(212,175,55,.2);flex-shrink:0;overflow:hidden;-webkit-mask-image:-webkit-radial-gradient(white,black);transform:translateZ(0)}.og-icon-img{width:100%;height:100%;object-fit:cover}.og-info{flex:1;min-width:0}.og-name{font-family:var(--font-display);font-size:14px;letter-spacing:.06em;color:var(--gold);margin-bottom:3px}.og-tagline{font-family:var(--font-body);font-size:11px;color:var(--text-muted)}.og-badge-current{font-family:var(--font-display);font-size:10px;letter-spacing:.08em;color:#50c864d9;white-space:nowrap}.og-badge-download{font-family:var(--font-display);font-size:10px;letter-spacing:.08em;color:var(--gold);padding:4px 10px;border:1px solid var(--gold-dim);border-radius:10px;white-space:nowrap;text-decoration:none;background:#d4af3714}.og-badge-soon{font-family:var(--font-display);font-size:10px;letter-spacing:.08em;color:var(--text-muted);padding:3px 8px;border:1px solid rgba(212,175,55,.2);border-radius:10px;white-space:nowrap}.game-over-players{display:flex;flex-direction:column;gap:8px;margin-top:20px}.game-over-player-chip{display:flex;align-items:center;gap:10px;background:#0003;border:1px solid rgba(212,175,55,.15);border-radius:10px;padding:9px 12px}.game-over-player-num{width:28px;height:28px;border-radius:50%;background:#d4af371f;border:1px solid rgba(212,175,55,.3);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:14px;color:var(--gold);flex-shrink:0}.game-over-player-name{flex:1;font-family:var(--font-body);font-size:14px;color:var(--text-light);text-align:left}.gs-screen{display:flex;flex-direction:column;min-height:100%;padding:calc(var(--sat) + 12px) 16px calc(var(--sab) + 24px);gap:14px}.gs-screen-centered{justify-content:center}.gs-centered-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.gs-enjoy-msg{font-family:var(--font-body);font-size:15px;color:#d4af3773;text-align:center;letter-spacing:.04em;margin-top:8px}.gs-section{background:#0c0803d1;border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:14px}.gs-section-label{font-family:var(--font-display);font-size:10px;letter-spacing:.12em;color:var(--text-muted);margin-bottom:12px}.gs-role-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.gs-role-chip{display:flex;align-items:center;gap:7px;padding:7px 12px;border-radius:8px;border:1px solid}.gs-role-chip-count{font-family:var(--font-display);font-size:18px;line-height:1}.gs-role-chip-label{font-family:var(--font-body);font-size:12px;letter-spacing:.04em}.gs-total-row{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid rgba(212,175,55,.1);font-family:var(--font-body);font-size:12px;color:var(--text-muted)}.gs-total-value{font-family:var(--font-display);font-size:16px;color:var(--gold)}.gs-steps{display:flex;flex-direction:column;gap:12px}.gs-step{display:flex;align-items:flex-start;gap:12px}.gs-step-num{width:26px;height:26px;border-radius:50%;background:#d4af371a;border:1px solid rgba(212,175,55,.28);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:12px;color:var(--gold);flex-shrink:0;margin-top:2px}.gs-step-final{background:#d4af3726;border-color:var(--gold-dim);font-size:14px}.gs-step p{font-family:var(--font-body);font-size:13px;color:var(--text-light);line-height:1.6;margin:0}.gs-step p em{color:var(--gold);font-style:normal}.gs-home-btn{width:100%;margin-top:auto}.gs-pro-card{background:linear-gradient(145deg,#1e1204f7,#120a02fc);border:1px solid rgba(212,175,55,.4);border-radius:14px;padding:18px 16px;display:flex;flex-direction:column;gap:14px;box-shadow:0 0 32px #d4af3714}.gs-pro-top{display:flex;align-items:center;gap:10px}.gs-pro-badge{font-family:var(--font-display);font-size:11px;letter-spacing:.14em;color:#0a0600;background:var(--gold);padding:3px 9px;border-radius:6px;flex-shrink:0}.gs-pro-heading{font-family:var(--font-display);font-size:15px;letter-spacing:.06em;color:var(--gold);line-height:1.3}.gs-pro-desc{font-family:var(--font-body);font-size:12px;color:var(--text-light);line-height:1.6;opacity:.85}.gs-pro-features{display:flex;flex-direction:column;gap:7px}.gs-pro-feature{display:flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:12px;color:var(--text-light)}.gs-pro-feature svg{flex-shrink:0}.gs-pro-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:var(--gold);border:none;border-radius:10px;font-family:var(--font-display);font-size:14px;letter-spacing:.1em;color:#0a0600;cursor:pointer;transition:opacity .2s;box-shadow:0 4px 20px #d4af374d}.gs-pro-btn:active{opacity:.85}.pro-feature{position:relative}.pro-badge-corner{position:absolute;top:8px;right:8px;font-family:var(--font-display);font-size:9px;letter-spacing:.1em;color:#0a0600;background:var(--gold);padding:2px 6px;border-radius:4px;line-height:1.4}.pro-badge-inline{font-family:var(--font-display);font-size:9px;letter-spacing:.1em;color:#0a0600;background:var(--gold);padding:2px 6px;border-radius:4px;flex-shrink:0;align-self:center;margin-right:4px;line-height:1.4}.host-version-toggle-panel.pro-feature{display:flex;align-items:center;gap:6px}.pro-toggle-badge{font-family:var(--font-display);font-size:11px;letter-spacing:.12em;color:#0a0600;background:var(--gold);border:none;padding:5px 10px;border-radius:6px;cursor:pointer;flex-shrink:0;transition:opacity .2s}.pro-toggle-badge:active{opacity:.8}.htp-mode-btn{display:flex;align-items:center;justify-content:center;gap:6px}.htp-mode-tag{font-family:var(--font-display);font-size:8px;letter-spacing:.1em;padding:2px 5px;border-radius:4px;line-height:1.4}.htp-mode-tag.free{background:#ffffff0f;border:1px solid rgba(255,255,255,.2);color:#e6e6e6b3}.htp-mode-tag.pro{background:#d4af3726;border:1px solid rgba(212,175,55,.4);color:var(--gold)}.htp-host-note{display:flex;align-items:flex-start;gap:8px;margin-top:14px;padding:12px 14px;background:#d4af370a;border:1px solid rgba(212,175,55,.15);border-radius:10px}.htp-host-note-text{font-family:var(--font-body);font-size:11px;color:var(--text-muted)}.rl-screen{display:flex;flex-direction:column;min-height:100%;padding:0 0 calc(var(--sab) + 32px)}.rl-header{display:flex;align-items:center;justify-content:space-between;padding:calc(var(--sat) + 16px) 16px 12px}.rl-header-title{font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--gold)}.rl-code-block{display:flex;flex-direction:column;align-items:center;padding:20px 20px 16px;gap:10px}.rl-qr-wrap{padding:16px;background:#d4af370d;border:1px solid rgba(212,175,55,.18);border-radius:16px}.rl-code-label{font-family:var(--font-title);font-size:9px;letter-spacing:.16em;color:#d4af3780;margin-top:4px}.rl-code-digits{display:flex;gap:8px}.rl-digit{width:44px;height:52px;display:flex;align-items:center;justify-content:center;background:#d4af3712;border:1.5px solid rgba(212,175,55,.3);border-radius:10px;font-family:var(--font-title);font-size:26px;font-weight:700;color:var(--gold);letter-spacing:0}.rl-join-hint{font-family:var(--font-body);font-size:11px;color:#d4af3766}.rl-players-section{flex:1;padding:0 16px}.rl-players-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.rl-players-label{font-family:var(--font-title);font-size:10px;letter-spacing:.12em;color:#d4af3780}.rl-players-count{font-family:var(--font-title);font-size:10px;letter-spacing:.08em;color:var(--gold)}.rl-player-list{display:flex;flex-direction:column;gap:6px}.rl-empty{display:flex;justify-content:center;padding:20px 0}.rl-empty-dots{display:flex;gap:6px}.rl-empty-dots span{width:6px;height:6px;border-radius:50%;background:#d4af3740;animation:rl-pulse 1.2s ease-in-out infinite}.rl-empty-dots span:nth-child(2){animation-delay:.2s}.rl-empty-dots span:nth-child(3){animation-delay:.4s}@keyframes rl-pulse{0%,to{opacity:.3}50%{opacity:1}}.rl-player-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#d4af370a;border:1px solid rgba(212,175,55,.12);border-radius:10px;transition:background .2s,border-color .2s}.rl-player-row.revealed{background:#d4af3714;border-color:#d4af3740}.rl-player-slot{font-family:var(--font-title);font-size:10px;color:#d4af3766;min-width:16px}.rl-player-name{flex:1;font-family:var(--font-title);font-size:12px;font-weight:600;letter-spacing:.05em;color:#e6d28cf2}.rl-player-status{margin-left:auto}.rl-actions{padding:16px 16px 0;display:flex;flex-direction:column;gap:10px;align-items:center}.rl-start-btn{width:100%;padding:15px;background:linear-gradient(135deg,#d4af372e,#d4af3714);border:1.5px solid rgba(212,175,55,.5);border-radius:12px;font-family:var(--font-title);font-size:13px;font-weight:700;letter-spacing:.14em;color:var(--gold);cursor:pointer;transition:all .18s ease}.rl-start-btn:disabled{opacity:.35;cursor:not-allowed}.rl-start-btn:not(:disabled):active{background:#d4af3740}.rl-reveal-status{font-family:var(--font-title);font-size:11px;letter-spacing:.08em;color:#d4af378c}.rl-waiting-hint{font-family:var(--font-title);font-size:11px;letter-spacing:.06em;color:#d4af378c;text-align:center;line-height:1.4;padding:0 8px}.rl-begin-outline-btn{width:100%;padding:14px;background:transparent;border:1px solid rgba(212,175,55,.3);border-radius:12px;font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.12em;color:#d4af3799;cursor:pointer}.rl-begin-outline-btn:active{background:#d4af370f}.rl-begin-outline-btn:disabled{opacity:.35;cursor:not-allowed}.jr-screen{display:flex;flex-direction:column;min-height:100%;padding:0 0 40px;position:relative;overflow:hidden;background:radial-gradient(ellipse at 72% 18%,rgba(140,0,0,.45) 0%,transparent 46%),radial-gradient(ellipse at 30% 90%,rgba(110,0,0,.4) 0%,transparent 42%),linear-gradient(to bottom,#0000002e,#0000000d,#00000040)}.jr-header{display:flex;align-items:center;padding:calc(var(--sat) + 16px) 16px 12px;gap:8px}.jr-header-center{flex:1;text-align:center}.jr-title{font-family:var(--font-display);font-size:20px;letter-spacing:.12em;color:var(--gold)}.jr-subtitle{font-family:var(--font-body);font-size:11px;color:var(--text-muted);margin-top:3px}.jr-form{flex:1;padding:32px 24px;display:flex;flex-direction:column;gap:24px}.jr-field{display:flex;flex-direction:column;gap:10px}.jr-field-label{font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.14em;color:#d4af37a6}.jr-input{width:100%;padding:16px 18px;background:#0e0a04b3;border:1.5px solid rgba(212,175,55,.25);border-radius:12px;font-family:var(--font-title);font-size:16px;color:#e6d28cf2;outline:none;box-sizing:border-box;transition:border-color .2s,background .2s;-webkit-appearance:none}.jr-input.code-input{font-size:32px;letter-spacing:.35em;text-align:center;padding:20px 18px}.jr-input:focus{border-color:#d4af378c;background:#0e0a04d9}.jr-input::placeholder{color:#d4af3733}.jr-error{font-family:var(--font-body);font-size:13px;color:#dc5050e6;text-align:center}.jr-join-btn{width:100%;padding:17px;background:linear-gradient(135deg,#d4af372e,#d4af3714);border:1.5px solid rgba(212,175,55,.5);border-radius:12px;font-family:var(--font-title);font-size:14px;font-weight:700;letter-spacing:.16em;color:var(--gold);cursor:pointer;transition:all .18s;margin-top:4px}.jr-join-btn:disabled{opacity:.35;cursor:not-allowed}.jr-join-btn:not(:disabled):active{background:#d4af3747}.jr-waiting{align-items:center;justify-content:center;gap:20px}.jr-wait-icon{margin-bottom:8px}.jr-wait-name{font-family:var(--font-display);font-size:22px;letter-spacing:.08em;color:var(--gold)}.jr-wait-text{font-family:var(--font-body);font-size:14px;color:var(--text-muted);text-align:center;max-width:240px;line-height:1.5}.jr-wait-code{font-family:var(--font-title);font-size:12px;letter-spacing:.2em;color:#d4af3759;margin-top:12px}.jr-live-icon{margin-bottom:8px}.jr-live-title{font-family:var(--font-display);font-size:22px;letter-spacing:.12em;color:var(--gold);text-align:center}.jr-live-text{font-family:var(--font-body);font-size:14px;color:var(--text-muted);text-align:center;max-width:240px;line-height:1.6}.jr-live-role-reminder{font-family:var(--font-title);font-size:11px;letter-spacing:.1em;color:#d4af3766;margin-top:16px;text-align:center}.jr-live-role-reminder span{color:#d4af37bf;font-weight:700}.jr-reveal-phase{align-items:center;justify-content:center;gap:28px}.jr-reveal-hint{font-family:var(--font-title);font-size:10px;letter-spacing:.12em;color:#d4af3780;text-align:center}.jr-card-wrap{width:200px;height:280px;perspective:900px;cursor:pointer}.jr-card-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.45,.05,.55,.95)}.jr-card-wrap.flipped .jr-card-inner{transform:rotateY(180deg)}.jr-card-front,.jr-card-back{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:18px;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.jr-card-front{background:linear-gradient(160deg,#160e04f2,#0a0602fa);border:1.5px solid rgba(212,175,55,.2);box-shadow:0 12px 40px #00000080}.jr-card-front-label{font-family:var(--font-title);font-size:56px;font-weight:700;color:#d4af3726;line-height:1}.jr-card-back{border:1.5px solid;transform:rotateY(180deg);box-shadow:0 12px 40px #00000080}.jr-card-role-name{font-family:var(--font-title);font-size:16px;font-weight:700;letter-spacing:.14em}.jr-done-phase{align-items:center;justify-content:center;gap:20px}.jr-done-card{width:180px;height:240px;border-radius:18px;border:1.5px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;box-shadow:0 12px 40px #0006}.jr-done-role{font-family:var(--font-title);font-size:14px;font-weight:700;letter-spacing:.14em}.jr-done-msg{font-family:var(--font-title);font-size:10px;letter-spacing:.1em;color:#d4af3780;text-align:center}.jr-done-name{font-family:var(--font-title);font-size:13px;color:#d4af3766}.home-join-btn{background:transparent;border:1px solid rgba(212,175,55,.3);border-radius:10px;padding:13px 20px;font-family:var(--font-title);font-size:12px;font-weight:700;letter-spacing:.14em;color:#d4af37a6;cursor:pointer;transition:border-color .18s,color .18s}.home-join-btn:active{border-color:#d4af3799;color:var(--gold)}.pc-screen{display:flex;flex-direction:column;min-height:100%;background:radial-gradient(ellipse at 72% 18%,rgba(140,0,0,.45) 0%,transparent 46%),radial-gradient(ellipse at 30% 90%,rgba(110,0,0,.4) 0%,transparent 42%),linear-gradient(to bottom,#0000002e,#0000000d,#00000040)}.pc-header{padding:calc(var(--sat) + 16px) 16px 0}.pc-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:0 32px 40px}.pc-title{font-family:var(--font-display);font-size:22px;letter-spacing:.1em;color:var(--gold);text-align:center}.pc-divider{display:flex;align-items:center;gap:10px;width:100%;max-width:200px}.pc-divider-line{flex:1;height:1px;background:linear-gradient(to right,transparent,rgba(212,175,55,.3))}.pc-divider-line:last-child{background:linear-gradient(to left,transparent,rgba(212,175,55,.3))}.pc-divider-diamond{width:6px;height:6px;background:#d4af3780;transform:rotate(45deg);flex-shrink:0}.pc-counter-wrap{width:100%}.pc-hint{font-family:var(--font-title);font-size:10px;letter-spacing:.14em;color:#d4af3759}.pc-footer{padding:0 24px calc(var(--sab) + 32px)}.pc-continue-btn{width:100%;display:flex;align-items:center;justify-content:center;padding:17px;background:linear-gradient(135deg,#d4af372e,#d4af3714);border:1.5px solid rgba(212,175,55,.5);border-radius:14px;font-family:var(--font-title);font-size:14px;font-weight:700;letter-spacing:.16em;color:var(--gold);cursor:pointer;transition:all .18s}.pc-continue-btn:active{background:#d4af3747}.ms-screen{display:flex;flex-direction:column;min-height:100%;background:radial-gradient(ellipse at 72% 18%,rgba(140,0,0,.45) 0%,transparent 46%),radial-gradient(ellipse at 30% 90%,rgba(110,0,0,.4) 0%,transparent 42%),linear-gradient(to bottom,#0000002e,#0000000d,#00000040)}.ms-header{display:flex;align-items:center;padding:calc(var(--sat) + 16px) 16px 12px;gap:8px}.ms-header-center{flex:1;text-align:center}.ms-title{font-family:var(--font-display);font-size:18px;letter-spacing:.1em;color:var(--gold)}.ms-cards{flex:1;display:flex;flex-direction:column;gap:14px;padding:28px 20px}.ms-card{display:flex;align-items:center;gap:16px;padding:22px 20px;background:#0e0a04bf;border:1.5px solid rgba(212,175,55,.22);border-radius:16px;cursor:pointer;transition:border-color .2s,background .2s;text-align:left;width:100%}.ms-card:active{background:#d4af3714;border-color:#d4af3780}.ms-card-icon{flex-shrink:0}.ms-card-content{flex:1}.ms-card-title{font-family:var(--font-display);font-size:16px;letter-spacing:.1em;color:var(--gold);margin-bottom:6px}.ms-card-desc{font-family:var(--font-body);font-size:12px;color:var(--text-muted);line-height:1.5}.ms-card-arrow{flex-shrink:0;opacity:.5}.host-mgmt-section{margin:0 16px;background:#0e0a04e6;border:1px solid var(--dark-panel-border);border-radius:10px;padding:14px 12px 12px}.host-mgmt-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.host-mgmt-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px 12px;border-radius:9px;border:1.5px solid rgba(212,175,55,.14);background:#120c04d9;cursor:pointer;position:relative;overflow:hidden;transition:border-color .22s,background .22s,box-shadow .22s}.host-mgmt-card.active{border-color:var(--gold-dim);background:#1a1204f2;box-shadow:0 0 16px #d4af371a,inset 0 1px #d4af3714}.host-mgmt-title{font-family:var(--font-title);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--gold);text-align:center}.host-mgmt-desc{font-family:var(--font-body);font-size:10px;color:var(--text-muted);text-align:center;line-height:1.4}
