:root{--night: #10142b;--night-deep: #070a1a;--frame: #f8f0d8;--frame-border: #3a3450;--accent: #ffcb05;--accent2: #7ec8e3;--danger: #e85d5d}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:Galmuri11,Galmuri9,monospace;background:linear-gradient(180deg,var(--night-deep) 0%,var(--night) 55%,#1c2247 100%);color:var(--frame);image-rendering:pixelated;overflow-x:hidden}img.sprite{image-rendering:pixelated;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.title-screen{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:24px 16px calc(24px + env(safe-area-inset-bottom));text-align:center}.logo{font-size:clamp(34px,8vw,64px);letter-spacing:4px;color:var(--accent);text-shadow:3px 3px 0 #7a5c00,6px 6px 0 rgba(0,0,0,.5);animation:float 3s ease-in-out infinite}.logo-sub{font-size:clamp(13px,3vw,18px);color:var(--accent2);letter-spacing:2px;margin-top:8px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.sprite-row{display:flex;align-items:flex-end;justify-content:center;gap:clamp(8px,3vw,28px);min-height:96px}.sprite-row .sprite{height:clamp(48px,10vw,96px);filter:drop-shadow(0 6px 4px rgba(0,0,0,.55))}.sprite-row .sprite.demon{filter:drop-shadow(0 0 10px rgba(160,80,220,.7)) drop-shadow(0 6px 4px rgba(0,0,0,.55))}.dialog{width:min(560px,94vw);background:var(--frame);color:#2a2440;border:4px solid var(--frame-border);border-radius:8px;box-shadow:0 0 0 4px var(--frame),0 0 0 8px var(--frame-border),0 10px 24px #0009;padding:18px 20px;font-size:clamp(14px,3.4vw,17px);line-height:1.7;text-align:left;min-height:86px;position:relative}.dialog .cursor{position:absolute;right:14px;bottom:8px;color:var(--danger);animation:blink .9s steps(1) infinite}@keyframes blink{0%,60%{opacity:1}61%,to{opacity:0}}.menu{display:flex;flex-direction:column;gap:12px;width:min(340px,88vw)}.menu button{font-family:inherit;font-size:clamp(15px,3.6vw,18px);letter-spacing:2px;padding:14px 18px;background:var(--night-deep);color:var(--frame);border:3px solid var(--frame);border-radius:6px;cursor:pointer;transition:transform .06s steps(2)}.menu button:hover,.menu button:focus-visible{background:var(--accent);color:#2a2440;border-color:#7a5c00;transform:translateY(-2px);outline:none}.menu button:active{transform:translateY(1px)}.status-line{font-size:12px;letter-spacing:1px;color:#f8f0d88c}.status-line .ok{color:#8fe388}.status-line .bad{color:var(--danger)}.form-box{display:flex;flex-direction:column;gap:12px}.form-title{color:#7a5c00;font-weight:700;letter-spacing:1px}.form-box label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#5a5470}.form-box input{font-family:inherit;font-size:16px;padding:10px 12px;border:3px solid var(--frame-border);border-radius:4px;background:#fffdf5;color:#2a2440}.form-box input:focus{outline:none;border-color:var(--accent)}.form-error{color:var(--danger);font-size:13px}.menu button.ghost{background:transparent;border-color:#f8f0d866;color:#f8f0d8cc}.room-screen{min-height:100%;display:flex;flex-direction:column;gap:10px;padding:10px 10px calc(12px + env(safe-area-inset-bottom));max-width:640px;margin:0 auto;transition:background 1.2s}.phase-night{background:linear-gradient(180deg,#05070f,#0b1024 60%,#141a38)}.topbar{display:flex;align-items:center;gap:12px;padding:6px 4px}.room-code{font-size:15px;color:var(--accent);letter-spacing:2px}.phase-label{flex:1;text-align:center;font-size:15px;letter-spacing:2px}.banner{background:#f8f0d81f;border:2px solid rgba(248,240,216,.35);border-radius:6px;padding:8px 12px;font-size:13px;line-height:1.5;animation:slide-in .25s steps(4)}.banner.danger{border-color:var(--danger);color:#ffb3b3}.banner.mew{border-color:#d98fd9;color:#f0c6f0}.banner.winner-good{border-color:var(--accent);color:var(--accent);font-size:16px}.banner.winner-evil{border-color:#a06ee0;color:#cdb0f5;font-size:16px}@keyframes slide-in{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}.circle-wrap{position:relative;width:min(92vw,420px);aspect-ratio:1;margin:4px auto}.circle-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:40px;opacity:.6}.seat{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;font-family:inherit;color:var(--frame);padding:0;width:calc(var(--seat-size, 46px) + 26px)}.seat-avatar{position:relative;width:var(--seat-size, 46px);height:var(--seat-size, 46px);border-radius:50%;background:#232a52;border:3px solid rgba(248,240,216,.5);display:flex;align-items:center;justify-content:center;font-size:14px;transition:transform .06s steps(2),border-color .2s}.seat:hover .seat-avatar{transform:scale(1.08)}.seat.me .seat-avatar{border-color:var(--accent)}.seat.selected .seat-avatar{border-color:var(--accent2);box-shadow:0 0 10px var(--accent2)}.seat.dead{opacity:.55}.seat.dead .seat-avatar{background:#16182b;border-style:dashed}.seat.about-to-die .seat-avatar{border-color:var(--danger);box-shadow:0 0 12px var(--danger);animation:pulse 1s infinite}.seat.clock-target .seat-avatar{border-color:var(--accent);box-shadow:0 0 14px var(--accent);transform:scale(1.15);animation:pulse-gold .8s infinite}@keyframes pulse-gold{0%,to{box-shadow:0 0 8px var(--accent)}50%{box-shadow:0 0 18px var(--accent)}}@keyframes pulse{0%,to{box-shadow:0 0 6px var(--danger)}50%{box-shadow:0 0 16px var(--danger)}}.pokeball{width:calc(var(--seat-size, 46px) * .56);height:calc(var(--seat-size, 46px) * .56);border-radius:50%;background:linear-gradient(180deg,#e8484a,#e8484a 43%,#2a2440 43%,#2a2440 57%,#f8f0d8 57%,#f8f0d8);border:2px solid #2a2440;position:relative}.pokeball:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:#f8f0d8;border:2px solid #2a2440}.seat-sprite{height:calc(var(--seat-size, 46px) - 4px);margin-top:-4px}.seat-sprite.dead-sprite{filter:grayscale(1) brightness(.55)}.skull-mark{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);font-size:13px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.9))}.chat-name{cursor:pointer;text-decoration:underline dotted rgba(126,200,227,.5)}.palette-panel{flex-direction:column;align-items:stretch}.palette-row{display:flex;flex-wrap:wrap;gap:6px}.palette-dot{background:#0000004d;border:2px solid rgba(248,240,216,.25);border-radius:8px;padding:4px;cursor:pointer;min-height:42px}.palette-dot.on{border-color:var(--accent);box-shadow:0 0 8px #ffcb0580}.palette-dot.taken{opacity:.3;cursor:not-allowed}.vote-timer{display:inline-block;min-width:22px;color:var(--danger);font-size:20px;animation:pulse 1s infinite}.seat-name{font-size:12px;max-width:calc(var(--seat-size, 46px) + 30px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hand{position:absolute;top:-12px;right:-10px;font-size:16px;animation:raise .2s steps(3)}@keyframes raise{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.crown{position:absolute;top:-14px;left:-6px;font-size:12px}.seat.ally .seat-avatar{border-color:var(--danger);box-shadow:0 0 10px #d9484a8c}.ally-badge{position:absolute;bottom:-6px;left:-8px;font-size:14px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.9))}.note-badge{position:absolute;bottom:-6px;right:-8px;font-size:12px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.8))}.note-text{width:100%;font-size:12px;color:#ffe9a8;background:#ffcb051a;border-left:3px solid rgba(255,203,5,.5);padding:5px 8px;border-radius:4px;word-break:break-all}.panel{background:#10142bd9;border:2px solid rgba(248,240,216,.35);border-radius:8px;padding:10px 12px;font-size:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.panel button{font-family:inherit;font-size:13px;min-height:42px;padding:8px 12px;background:var(--accent);color:#2a2440;border:2px solid #7a5c00;border-radius:5px;cursor:pointer}.panel button.ghost{background:transparent;color:#f8f0d8b3;border-color:#f8f0d859}.panel button.danger-btn{background:var(--danger);color:#fff;border-color:#7a1f1f}.panel button.mini,button.mini{font-size:12px;min-height:32px;padding:5px 9px}.vote-panel{flex-direction:column;align-items:stretch;text-align:center}.vote-panel .row{display:flex;gap:8px;justify-content:center}.vote-count{font-size:18px;color:var(--accent)}.stage-flow{display:flex;flex-wrap:nowrap;gap:4px;justify-content:flex-start;overflow-x:auto;padding-bottom:3px;scrollbar-width:none}.stage-flow::-webkit-scrollbar{display:none}.stage-flow .stage{flex-shrink:0}.assign-panel{flex-direction:column;align-items:stretch;gap:8px}.assign-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px}.assign-row select{font-family:inherit;font-size:13px;padding:8px;background:var(--night-deep);color:var(--frame);border:2px solid rgba(248,240,216,.4);border-radius:5px;max-width:60%}.stage-flow .stage{font-size:10px;padding:3px 7px;border-radius:4px;border:1px solid rgba(248,240,216,.3);color:#f8f0d880}.stage-flow .stage.active{background:var(--accent);color:#2a2440;border-color:#7a5c00;font-weight:700}.stage-hint{font-size:13px;color:var(--accent2)}.debug-tag{font-size:9px;line-height:1.2;padding:1px 4px;border-radius:3px;max-width:76px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-tag.evil{background:#d9484a59;border:1px solid #d9484a}.debug-tag.good{background:#4a90d959;border:1px solid #4a90d9}.result-line{font-size:12px;color:#f8f0d8bf}.mini-label{font-size:11px;opacity:.6;letter-spacing:1px}.guide-bar{background:#7ec8e31f;border:2px solid rgba(126,200,227,.45);border-radius:6px;padding:9px 12px;font-size:13px;letter-spacing:.5px;text-align:center;color:var(--accent2)}.night-tick{text-align:center;font-size:12px;letter-spacing:1px;color:#b4beffd9;animation:tick-in .5s steps(4),float 3s ease-in-out infinite}@keyframes tick-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.guide-bar.urgent{background:#ffcb0524;border-color:var(--accent);color:var(--accent);animation:pulse-gold .9s infinite}.brief-card .brief-body{white-space:pre-line;font-size:14px;line-height:1.8;color:#4a4460;text-align:left}.brief-card .brief-nav{background:#fffdf5}.check-label{display:flex;align-items:center;gap:6px;font-size:12px;color:#f8f0d8d9;cursor:pointer}.check-label input{width:18px;height:18px;accent-color:#ffcb05}.clock-hand{position:absolute;left:50%;bottom:50%;width:5px;height:33%;transform-origin:bottom center;background:linear-gradient(180deg,var(--accent) 0%,rgba(255,203,5,.15) 100%);border-radius:3px;box-shadow:0 0 8px #ffcb05b3;transition:transform .55s cubic-bezier(.3,1.3,.5,1);pointer-events:none;z-index:2}.clock-hand:before{content:"";position:absolute;bottom:-7px;left:50%;transform:translate(-50%);width:14px;height:14px;border-radius:50%;background:var(--frame);border:3px solid var(--frame-border)}.phase-transition{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;pointer-events:none;font-size:clamp(26px,7vw,46px);letter-spacing:4px;text-shadow:3px 3px 0 rgba(0,0,0,.6);animation:phase-fade 2.4s ease forwards}.phase-transition.dusk{background:radial-gradient(ellipse at 50% 20%,#1c2247f2,#05070ff7);color:var(--accent2)}.phase-transition.dawn{background:radial-gradient(ellipse at 50% 80%,#ffb05ceb,#462850f2);color:#fff3d6}@keyframes phase-fade{0%{opacity:0}12%{opacity:1}75%{opacity:1}to{opacity:0}}.reveal-card{background:var(--frame);color:#2a2440;border:4px solid var(--frame-border);border-radius:12px;box-shadow:0 0 0 4px var(--frame),0 0 0 8px var(--frame-border),0 20px 50px #000c;padding:26px 24px;width:min(380px,90vw);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;animation:card-flip .8s cubic-bezier(.3,1.4,.6,1)}@keyframes card-flip{0%{transform:rotateY(90deg) scale(.7);opacity:0}60%{transform:rotateY(-12deg) scale(1.04);opacity:1}to{transform:rotateY(0) scale(1)}}.reveal-title{font-size:12px;color:#7a5c00;letter-spacing:2px}.reveal-sprite{height:96px;filter:drop-shadow(0 8px 6px rgba(0,0,0,.35));animation:float 2.5s ease-in-out infinite}.reveal-name{font-size:22px;letter-spacing:2px}.reveal-card .role-ability{color:#4a4460;font-size:13px}.reveal-card button{font-family:inherit;font-size:15px;letter-spacing:2px;padding:12px 22px;min-height:44px;background:var(--accent);color:#2a2440;border:3px solid #7a5c00;border-radius:8px;cursor:pointer;margin-top:6px}.madness-vignette{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;box-shadow:inset 0 0 90px 30px #a050dc73;animation:madness-pulse 2.4s ease-in-out infinite}@keyframes madness-pulse{0%,to{box-shadow:inset 0 0 70px 22px #a050dc59}50%{box-shadow:inset 0 0 110px 42px #a050dc80}}.dead-banner{border-color:#f8f0d880;color:#f8f0d8bf}.collapse-head{font-family:inherit;font-size:12px;letter-spacing:1px;background:none;border:none;color:#f8f0d8d9;cursor:pointer;padding:4px 2px;text-align:left;width:100%;min-height:34px}.collapse-hint{opacity:.55;font-size:10px}.st-panel.collapsed,.log-panel.collapsed{padding:2px 10px}@media(min-width:1000px){.log-panel.collapsed{bottom:auto}}@media(min-width:1360px){.st-panel.collapsed{bottom:auto}}.discord-btn{font-size:18px;text-decoration:none;background:#5865f2;border:2px solid #3b45c4;border-radius:6px;padding:5px 10px;line-height:1;animation:float 3s ease-in-out infinite}.gauge{height:10px;border-radius:5px;background:#00000073;border:2px solid rgba(248,240,216,.3);overflow:hidden}.gauge-fill{height:100%;background:linear-gradient(90deg,var(--accent2),#4a90d9);transition:width 1s linear}.gauge-fill.low{background:linear-gradient(90deg,var(--danger),#ff8a5c);animation:pulse .8s infinite}.sec-select{font-family:inherit;font-size:12px;padding:7px 8px;background:var(--night-deep);color:var(--frame);border:2px solid rgba(248,240,216,.4);border-radius:5px}.role-card{align-items:center}.role-sprite{height:56px}.role-info{flex:1;min-width:0}.role-name{font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sub-role{font-size:12px;opacity:.8}.team-badge{font-size:11px;padding:2px 8px;border-radius:4px;color:#fff}.role-ability{font-size:12px;line-height:1.6;color:#f8f0d8d9;margin-top:4px}.role-hidden{flex:1;text-align:center;opacity:.6}.chat{display:flex;flex-direction:column;gap:6px;flex:1;min-height:140px}.chat-log{flex:1;min-height:90px;max-height:200px;overflow-y:auto;background:#0d1126;border:2px solid rgba(248,240,216,.2);border-radius:6px;padding:8px 10px;font-size:13px;line-height:1.7}.chat-log p{background:none;margin:0;word-break:break-all}.chat-log b{color:var(--accent2);margin-right:6px}.chat-log b.chat-me{color:var(--accent)}.whisper-line{color:#d8b0f0;background:#a050dc1f!important;border-radius:4px;padding:1px 5px}.whisper-line b{color:#e8c8ff}.sys-line{color:#f8f0d88c;font-style:italic}.chat-tabs{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.chat-tabs::-webkit-scrollbar{display:none}.chat-tabs button{flex-shrink:0;font-family:inherit;font-size:12px;padding:7px 11px;min-height:34px;border-radius:6px 6px 0 0;border:2px solid rgba(248,240,216,.25);border-bottom:none;background:#00000040;color:#f8f0d899;cursor:pointer;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-tabs button.on{background:#0d1126;color:var(--frame);border-color:#f8f0d866}.chat-tabs button.whisper-tab.on{color:#d8b0f0;border-color:#a050dc99}.tab-close{display:inline-block;margin-left:8px;padding:2px 6px;border-radius:4px;background:#e85d5d40;color:#ffb3b3;cursor:pointer}.tab-close:hover{background:#e85d5d80;color:#fff}.chat-input{display:flex;gap:6px}.chat-input input{flex:1;font-family:inherit;font-size:16px;padding:9px 12px;background:#00000059;border:2px solid rgba(248,240,216,.3);border-radius:6px;color:var(--frame)}.chat-input input:focus{outline:none;border-color:var(--accent2)}.chat-input button{font-family:inherit;background:var(--accent2);border:2px solid #33607a;border-radius:6px;color:#14263a;cursor:pointer}.dex-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;background:#070a1afa;display:flex;flex-direction:column;padding:12px 14px calc(14px + env(safe-area-inset-bottom))}.dex-head{display:flex;align-items:center;justify-content:space-between;font-size:15px;letter-spacing:1px;color:var(--accent);padding-bottom:10px;border-bottom:2px solid rgba(248,240,216,.2)}.dex-head button{font-family:inherit;background:var(--accent);color:#2a2440;border:2px solid #7a5c00;border-radius:6px;padding:8px 12px;min-height:40px;cursor:pointer}.dex-body{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px;padding-top:12px}.dex-section h3{font-size:14px;letter-spacing:1px;color:var(--accent2);margin-bottom:8px;position:sticky;top:0;background:#070a1afa;padding:4px 0}.dex-order{font-size:12px;line-height:1.9;color:#f8f0d8d9;margin-bottom:6px;word-break:keep-all}.dex-role{display:flex;gap:10px;align-items:flex-start;padding:8px 6px;border-bottom:1px solid rgba(248,240,216,.1)}.dex-role img{height:44px;flex-shrink:0}.dex-role b{font-size:13px;color:var(--frame)}.dex-role p{font-size:12px;line-height:1.6;color:#f8f0d8bf;margin-top:3px}.prompt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000005bf;display:flex;align-items:center;justify-content:center;z-index:20;padding:16px}.prompt-box{background:var(--frame);color:#2a2440;border:4px solid var(--frame-border);border-radius:10px;box-shadow:0 0 0 4px var(--frame),0 0 0 8px var(--frame-border),0 16px 40px #000c;padding:18px 20px;width:min(440px,92vw);display:flex;flex-direction:column;gap:12px;animation:slide-in .25s steps(4)}.prompt-role{font-size:13px;color:#7a5c00;letter-spacing:1px}.prompt-text{font-size:15px;line-height:1.7}.prompt-targets{display:flex;flex-wrap:wrap;gap:8px;max-height:40vh;overflow-y:auto}.prompt-targets button,.prompt-options button,.prompt-actions button{font-family:inherit;font-size:14px;padding:9px 13px;border-radius:6px;border:2px solid var(--frame-border);background:#fffdf5;color:#2a2440;cursor:pointer}.prompt-targets button.on{background:var(--accent);border-color:#7a5c00}.prompt-actions{display:flex;gap:8px;justify-content:flex-end}.prompt-actions button{background:var(--accent);border-color:#7a5c00}.prompt-actions button:disabled{opacity:.4;cursor:default}.prompt-actions button.ghost,.prompt-options button{background:#fffdf5}.debate-box.tall{width:min(500px,94vw);min-height:400px}.debate-box.tall .prompt-role{font-size:15px}.debate-box.tall .row:last-child{margin-top:auto}.debate-box .stage-flow .stage{border-color:#3a345059;color:#8a84a0}.debate-box .stage-flow .stage.active{background:var(--accent);color:#2a2440;border-color:#7a5c00;font-weight:700}.debate-box .stage-hint{color:#4a4460;font-size:14px}.debate-box .info-text{word-break:break-all;line-height:1.8}.debate-box .vote-count{color:#a56f00;font-size:17px}.debate-box .result-line{color:#6a6480;font-size:12px}.debate-box .row{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.debate-box .row button{font-family:inherit;font-size:15px;min-height:46px;padding:10px 18px;border-radius:6px;border:2px solid #7a5c00;background:var(--accent);color:#2a2440;cursor:pointer}.debate-box .row button.ghost{background:#fffdf5;border-color:var(--frame-border)}.debate-box .row button.mini{font-size:12px;min-height:34px;padding:6px 10px}.night-log{flex-direction:column;align-items:stretch;gap:4px}.night-log-entries{display:flex;flex-direction:column;gap:4px;font-size:12px;line-height:1.6;color:#f8f0d8e6;max-height:120px;overflow-y:auto}.night-log-entries p{animation:slide-in .2s steps(3)}.log-panel{background:#00000059;border:2px solid rgba(248,240,216,.25);border-radius:8px;padding:8px 10px;font-size:12px}.log-title{font-size:11px;letter-spacing:1px;opacity:.6;margin-bottom:6px}.log-entries{overflow-y:auto;max-height:130px;display:flex;flex-direction:column;gap:4px;line-height:1.55;color:#f8f0d8e0}.log-entries p{animation:slide-in .2s steps(3)}@media(min-width:1000px){.log-panel{position:fixed;right:14px;top:64px;bottom:14px;width:272px;display:flex;flex-direction:column}.log-entries{max-height:none;flex:1}}.st-panel{background:#1e0c0c8c;border:2px solid rgba(232,93,93,.4);border-radius:8px;padding:8px 10px;font-size:11px}.st-entries{overflow-y:auto;max-height:150px;display:flex;flex-direction:column;gap:3px;line-height:1.5;color:#ffe0d2e6;white-space:pre-wrap;word-break:break-all}.st-entries p{animation:slide-in .15s steps(2)}@media(min-width:1360px){.st-panel{position:fixed;left:14px;top:64px;bottom:14px;width:300px;display:flex;flex-direction:column}.st-entries{max-height:none;flex:1}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9;background:#070a1af7;border-top:2px solid rgba(248,240,216,.25);padding:6px 8px calc(6px + env(safe-area-inset-bottom));gap:6px}.bottom-nav button{flex:1;position:relative;font-family:inherit;font-size:13px;letter-spacing:1px;min-height:46px;background:transparent;border:2px solid transparent;border-radius:8px;color:#f8f0d88c;cursor:pointer}.bottom-nav button.on{color:var(--accent);border-color:#ffcb0580;background:#ffcb0514}.nav-badge{position:absolute;top:4px;right:14px;min-width:16px;height:16px;border-radius:8px;background:var(--danger);color:#fff;font-size:10px;line-height:16px;padding:0 3px}@media(max-width:999px){.bottom-nav{display:flex}.room-screen{padding-bottom:84px}.topbar{position:sticky;top:0;z-index:7;background:#070a1af2;margin:-10px -10px 0;padding:10px 12px 6px}.guide-bar{position:sticky;top:50px;z-index:7}.room-screen.view-town .sec-chat,.room-screen.view-town .sec-log,.room-screen.view-chat .sec-town,.room-screen.view-chat .sec-log,.room-screen.view-log .sec-town,.room-screen.view-log .sec-chat{display:none}.view-chat .chat-log{max-height:none;min-height:48vh}.view-log .log-entries,.view-log .st-entries{max-height:38vh}.view-log .night-log-entries{max-height:30vh}.room-screen{gap:8px}.role-card .role-ability{font-size:11px}.role-sprite{height:44px}}.toast{position:fixed;bottom:18px;left:50%;transform:translate(-50%);background:var(--frame);color:#2a2440;border:3px solid var(--frame-border);border-radius:6px;padding:10px 16px;font-size:13px;animation:slide-in .2s steps(3);z-index:10;max-width:88vw}
