@import "https://fonts.googleapis.com/css2?family=Vollkorn:ital,wght@0,400;0,600;0,700;1,400&family=Nunito:wght@300;400;500;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap";:root{--bg:#1a1613;--bg-elevated:#231f1a;--surface:#2d2720;--surface-hover:#363029;--accent:#cd7f32;--accent-dim:#cd7f3215;--accent-glow:#cd7f3244;--accent-muted:#b8860b;--text:#d4c5a9;--text-bright:#e8dcc6;--text-muted:#8c7b6b;--text-dim:#5a4f43;--success:#6b8e4e;--success-dim:#6b8e4e15;--danger:#b33a3a;--danger-dim:#b33a3a15;--danger-glow:#b33a3a44;--warn:#c9974c;--warn-dim:#c9974c15;--info:#7b9ebc;--info-dim:#7b9ebc15;--char-1:#cd7f32;--char-2:#6b8e4e;--char-3:#b33a3a;--char-4:#7b9ebc;--char-5:#9b7cb8;--char-6:#c9974c;--char-7:#5d8a6b;--char-8:#b07d62;--state-normal:#8c7b6b;--state-suspicious:#c9974c;--state-defensive:#cd7f32;--state-tense:#b33a3a;--state-breaking:#d44a4a;--state-cooperative:#6b8e4e;--state-scared:#9b7cb8;--border:#3d3429;--border-light:#4a3f33;--border-accent:#cd7f3266;--msg-narrator:#252019;--msg-player:#2d2518;--msg-event:#2a1a1a;--msg-discovery:#1f2a1f;--font-heading:"Vollkorn", "Crimson Pro", Georgia, serif;--font-body:"Nunito", "DM Sans", system-ui, sans-serif;--font-accent:"Crimson Pro", Georgia, serif;--font-mono:"JetBrains Mono", monospace;--text-xs:.7rem;--text-sm:.8rem;--text-base:1rem;--text-lg:1.1rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--leading-tight:1.3;--leading-normal:1.6;--leading-loose:1.8;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-glow:0 0 12px var(--accent-glow);--transition-fast:.15s ease;--transition-normal:.3s ease;--transition-slow:.5s ease;--z-base:1;--z-above:10;--z-panel:50;--z-backdrop:60;--z-modal:70;--z-overlay:100}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 20%,#cd7f3208 0%,#0000 50%),radial-gradient(at 80% 20%,#b8860b05 0%,#0000 40%)}#root{flex-direction:column;display:flex}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--text-bright);line-height:var(--leading-tight)}h1{font-size:var(--text-3xl);letter-spacing:.08em;font-weight:400}h2{font-size:var(--text-2xl);font-weight:600}h3{font-size:var(--text-xl);font-weight:600}h4{font-size:var(--text-lg);font-weight:600}.prose{font-family:var(--font-accent);font-size:var(--text-lg);line-height:var(--leading-loose);color:var(--text)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}::selection{background:var(--accent-dim);color:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.text-accent{color:var(--accent)}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-warn{color:var(--warn)}.bg-surface{background:var(--surface)}.bg-elevated{background:var(--bg-elevated)}.font-heading{font-family:var(--font-heading)}.font-body{font-family:var(--font-body)}.font-accent{font-family:var(--font-accent)}@media (width<=380px){:root{--text-base:.9rem;--text-lg:1rem;--text-xl:1.15rem}}@supports (padding:env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}}.setup-screen{min-height:100vh;padding:var(--space-5);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.setup-bg{z-index:0;position:fixed;inset:0}.setup-bg__image{object-fit:cover;object-position:center;width:100%;height:100%;animation:2s ease-out bgFadeIn;position:absolute;inset:0}@keyframes bgFadeIn{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.setup-bg__darken{background:linear-gradient(90deg,#0a0805d9 0%,#0a080566 15%,#0a080540 40% 60%,#0a080566 85%,#0a0805d9 100%),radial-gradient(#0a08054d 0%,#0a080580 60%,#0a0805b3 100%);position:absolute;inset:0}.setup-bg__fog{background:radial-gradient(at 30% 70%,#503c2814 0%,#0000 50%),radial-gradient(at 70% 30%,#3c32230f 0%,#0000 40%);animation:20s ease-in-out infinite alternate fogDrift;position:absolute;inset:0}.setup-bg__fog--2{background:radial-gradient(at 60% 80%,#64461e0d 0%,#0000 45%),radial-gradient(at 20% 40%,#4632190a 0%,#0000 50%);animation:25s ease-in-out infinite alternate fogDrift2}.setup-bg__vignette{background:radial-gradient(#0000 30%,#0a080580 70%,#050302d9 100%);position:absolute;inset:0}@keyframes fogDrift{0%{opacity:.6;transform:translate(-20px)scale(1)}to{opacity:1;transform:translate(20px)scale(1.05)}}@keyframes fogDrift2{0%{opacity:.5;transform:translate(15px)translateY(-10px)}to{opacity:.9;transform:translate(-15px)translateY(10px)}}.setup-bg__glow{pointer-events:none;background:radial-gradient(ellipse at center, var(--glow-color) 0%, transparent 70%);opacity:calc(.06 + var(--flicker,.3) * .04);mix-blend-mode:screen;z-index:1;border-radius:50%;position:absolute;transform:translate(-50%,-50%)}.setup-container{z-index:10;width:100%;max-width:420px;animation:1s fadeUp;position:relative}.setup-logo{text-align:center;margin-bottom:var(--space-8)}.setup-logo__icon{margin-bottom:var(--space-3);animation:4s ease-in-out infinite logoGlow}.setup-logo h1{font-family:var(--font-heading);letter-spacing:.2em;color:var(--text-bright);text-shadow:0 0 30px #cd7f324d,0 0 60px #cd7f321a,0 2px 4px #00000080;font-size:3.2rem;font-weight:400;animation:6s ease-in-out infinite titlePulse}.setup-logo p{font-family:var(--font-accent);font-style:italic;font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1);letter-spacing:.08em}.setup-logo__line{width:80px;height:1px;margin:var(--space-4) auto 0;background:linear-gradient(90deg, transparent, var(--accent) 30%, var(--accent) 70%, transparent);opacity:.5}@keyframes logoGlow{0%,to{filter:drop-shadow(0 0 8px #cd7f3233)}50%{filter:drop-shadow(0 0 16px #cd7f3266)}}@keyframes titlePulse{0%,to{text-shadow:0 0 30px #cd7f324d,0 0 60px #cd7f321a,0 2px 4px #00000080}50%{text-shadow:0 0 40px #cd7f3280,0 0 80px #cd7f3233,0 2px 4px #00000080}}.setup-step{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);padding:var(--space-6);background:#14110dbf;border:1px solid #cd7f321f;animation:.4s fadeUp;box-shadow:0 8px 32px #00000080,inset 0 1px #cd7f320f}.setup-label{font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-2);font-weight:600;display:block}.setup-input{border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-body);font-size:var(--text-sm);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#1e1912cc;outline:none;padding:12px 14px}.setup-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #cd7f321a}.setup-input::placeholder{color:var(--text-dim)}.setup-hint{color:var(--text-dim);margin-top:var(--space-1);font-size:.65rem}.setup-textarea{border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-accent);font-size:var(--text-base);border-radius:var(--radius-md);resize:vertical;min-height:80px;max-height:140px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#1e1912cc;outline:none;padding:12px 14px;line-height:1.5}.setup-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #cd7f321a}.setup-textarea::placeholder{color:var(--text-dim)}.chip-row{gap:var(--space-1);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.chip{border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.7rem;font-family:var(--font-body);background:#1e191299;padding:5px 12px}.chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.count-row{gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.count-btn{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:48px;height:48px;color:var(--text-muted);transition:all var(--transition-fast);font-size:1.1rem;font-weight:600;font-family:var(--font-body);background:#1e191299;justify-content:center;align-items:center;display:flex}.count-btn:hover{border-color:var(--accent);color:var(--text)}.count-btn.active{border-color:var(--accent);color:var(--accent);background:#cd7f321f;box-shadow:0 0 12px #cd7f3226}.difficulty-row{gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.diff-btn{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition-fast);font-family:var(--font-body);background:#1e191299;flex:1;padding:12px 8px}.diff-btn:hover{border-color:var(--accent)}.diff-btn.active{border-color:var(--accent);background:#cd7f321f;box-shadow:0 0 12px #cd7f321a}.diff-label{font-size:var(--text-sm);color:var(--text);font-weight:600;display:block}.diff-desc{color:var(--text-muted);margin-top:2px;font-size:.6rem;display:block}.diff-btn.active .diff-label{color:var(--accent)}.setup-nav{gap:var(--space-2);margin-top:var(--space-4);display:flex}.setup-btn{border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:.04em;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-normal);background:0 0;flex:1;padding:12px}.setup-btn:hover{border-color:var(--text-muted);color:var(--text)}.setup-btn.primary{border-color:var(--accent);color:var(--accent);text-shadow:0 0 12px #cd7f324d;font-weight:600}.setup-btn.primary:hover{background:var(--accent);color:var(--bg);text-shadow:none;box-shadow:0 0 20px #cd7f324d}.setup-btn:disabled{opacity:.4;cursor:not-allowed}.setup-error{margin-top:var(--space-3);padding:var(--space-3);background:var(--danger-dim);border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);font-size:var(--text-sm);text-align:center}.setup-footer{bottom:var(--space-4);text-align:center;z-index:10;letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;font-size:.6rem;position:fixed;left:0;right:0}@media (width<=480px){.setup-logo h1{letter-spacing:.15em;font-size:2.4rem}.setup-step{padding:var(--space-4)}.difficulty-row{flex-direction:column}}.build-screen{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;animation:.5s fadeIn;display:flex}.build-spinner{border:2px solid var(--border);border-top-color:var(--accent);width:36px;height:36px;margin-bottom:var(--space-4);border-radius:50%;animation:1.2s linear infinite spin}.build-title{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--accent);letter-spacing:.1em}.build-status{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-2);text-align:center;max-width:280px}.top-bar{padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;min-height:40px;display:flex}.top-left{align-items:center;gap:var(--space-2);display:flex}.day-label{font-family:var(--font-heading);font-size:var(--text-sm);color:var(--text-bright);font-weight:600}.time-label{font-size:.9rem}.action-count{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.day-cycle{max-width:180px;margin:0 var(--space-3);flex:1}.day-track{background:linear-gradient(90deg, var(--accent) 0%, var(--warn) 40%, var(--danger) 75%, #1a1a3e 100%);border-radius:3px;height:6px;position:relative;overflow:visible}.day-fill{background:#00000073;border-radius:3px;transition:width .6s;position:absolute;top:0;bottom:0;left:0}.day-orb{filter:drop-shadow(0 0 4px var(--accent-glow));z-index:2;font-size:.75rem;transition:left .6s;position:absolute;top:50%;transform:translate(-50%,-50%)}.top-right{align-items:center;gap:var(--space-1);display:flex}.tension-indicator{font-size:.7rem}.char-strip{justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0;display:flex;overflow-x:auto}.char-icon{cursor:pointer;transition:transform var(--transition-fast);background:0 0;border:none;flex-direction:column;align-items:center;min-width:48px;padding:0;display:flex}.char-icon:hover{transform:translateY(-2px)}.char-icon.dead{opacity:.5}.char-avatar{border:2px solid var(--border);background:var(--surface);width:40px;height:40px;transition:border-color var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex}.char-initial{font-family:var(--font-heading);font-size:1.1rem;font-weight:700}.char-name{color:var(--text-muted);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:50px;margin-top:2px;font-size:.6rem;overflow:hidden}.char-name.dead{color:var(--danger);text-decoration:line-through}@media (width<=380px){.char-avatar{width:34px;height:34px}.char-strip{gap:var(--space-1)}}.msg-area{padding:var(--space-3);gap:var(--space-2);-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;display:flex;overflow-y:auto}.msg{max-width:88%;font-family:var(--font-accent);font-size:var(--text-lg);line-height:var(--leading-loose);word-wrap:break-word;border-radius:var(--radius-lg);padding:14px 16px;animation:.3s fadeUp}.msg.narrator{background:var(--msg-narrator);border:1px solid var(--border);border-radius:2px var(--radius-lg) var(--radius-lg) var(--radius-lg);color:var(--text);align-self:flex-start}.msg.user{background:var(--msg-player);border-radius:var(--radius-lg) 2px var(--radius-lg) var(--radius-lg);color:var(--text-bright);align-self:flex-end}.msg.system{text-align:center;color:var(--text-dim);font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:.06em;text-transform:uppercase;padding:var(--space-2) 0;background:0 0;align-self:center;max-width:100%}.msg.event{text-align:center;background:var(--msg-event);border:1px dashed var(--danger);color:var(--danger);font-size:var(--text-base);padding:var(--space-3) var(--space-4);align-self:center;max-width:90%}.msg.death{text-align:center;background:var(--danger-dim);border:1px solid var(--danger);color:var(--danger);font-size:var(--text-lg);padding:var(--space-4);align-self:center;max-width:90%}.msg.discovery{text-align:center;background:var(--success-dim);border:1px solid var(--success);color:var(--success);font-size:var(--text-sm);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);align-self:center;max-width:90%}.msg.typing{background:var(--msg-narrator);border:1px solid var(--border);border-radius:2px var(--radius-lg) var(--radius-lg) var(--radius-lg);align-self:flex-start;align-items:center;gap:4px;padding:12px 16px;display:flex}.typing-dot{background:var(--text-muted);border-radius:50%;width:5px;height:5px;animation:1.4s ease-in-out infinite bounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.choice-area{padding:var(--space-2) var(--space-3);gap:var(--space-1);border-top:1px solid var(--border);background:var(--bg-elevated);flex-direction:column;flex-shrink:0;animation:.3s fadeUp;display:flex}.choice-btn{background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-accent);font-size:var(--text-base);text-align:left;cursor:pointer;transition:all var(--transition-normal);border-radius:var(--radius-md);padding:13px 16px;line-height:1.4}.choice-btn:hover{border-color:var(--accent);background:var(--accent-dim);transform:translate(3px)}.choice-btn:active{transform:translate(1px)}.choice-label{font-family:var(--font-body);font-size:var(--text-xs);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:2px;font-weight:700;display:block}.choice-text{color:var(--text)}.free-bar{gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border-top:1px solid var(--border);flex-shrink:0;display:flex}.free-input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--font-accent);font-size:var(--text-base);border-radius:var(--radius-md);transition:border-color var(--transition-fast);outline:none;flex:1;padding:11px 14px}.free-input:focus{border-color:var(--accent)}.free-input::placeholder{color:var(--text-dim);font-size:var(--text-sm)}.free-input:disabled{opacity:.4}.free-send{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);padding:11px 18px;font-weight:600}.free-send:hover:not(:disabled){background:var(--accent);color:var(--bg)}.free-send:disabled{opacity:.3;cursor:not-allowed}.panel-backdrop{z-index:var(--z-backdrop);background:#00000080;animation:.2s fadeIn;position:fixed;inset:0}.char-panel{z-index:var(--z-modal);background:var(--bg-elevated);border-bottom:2px solid var(--accent);max-height:70vh;padding:var(--space-4);animation:.3s slideDown;position:fixed;top:0;left:0;right:0;overflow-y:auto}.panel-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.panel-avatar{border:2px solid var(--accent);background:var(--surface);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.panel-initial{font-family:var(--font-heading);color:var(--accent);font-size:1.5rem;font-weight:700}.panel-info{flex:1}.panel-name{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--text-bright);font-weight:600}.panel-role{font-size:var(--text-sm);color:var(--text-muted)}.panel-close{cursor:pointer;color:var(--text-muted);padding:var(--space-2);transition:color var(--transition-fast);background:0 0;border:none;font-size:1.2rem}.panel-close:hover{color:var(--text)}.panel-section{margin-bottom:var(--space-3)}.section-title{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-1);font-weight:600}.section-content{font-family:var(--font-accent);font-size:var(--text-base);color:var(--text-muted);line-height:1.5}.state-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);border:1px solid;font-weight:500;display:inline-block}.discovery-item{padding:var(--space-2) 0;border-bottom:1px solid var(--border);font-size:var(--text-sm);color:var(--text-muted);gap:var(--space-2);display:flex}.discovery-turn{color:var(--text-dim);font-size:var(--text-xs);min-width:28px;font-family:var(--font-mono)}.accuse-btn{background:var(--danger-dim);border:1px solid var(--danger);width:100%;color:var(--danger);font-family:var(--font-body);font-size:var(--text-base);letter-spacing:.08em;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-normal);padding:14px;font-weight:600}.accuse-btn:hover{background:var(--danger);color:#fff}.accuse-form{animation:.3s fadeUp}.accuse-input{background:var(--bg);border:1px solid var(--danger);width:100%;color:var(--text);font-family:var(--font-accent);font-size:var(--text-sm);border-radius:var(--radius-md);resize:vertical;outline:none;min-height:60px;padding:12px}.accuse-actions{gap:var(--space-2);margin-top:var(--space-2);display:flex}.accuse-cancel,.accuse-submit{border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid;flex:1;padding:10px}.accuse-cancel{border-color:var(--border);color:var(--text-muted);background:0 0}.accuse-submit{background:var(--danger-dim);border-color:var(--danger);color:var(--danger);font-weight:600}.accuse-submit:hover:not(:disabled){background:var(--danger);color:#fff}.accuse-submit:disabled{opacity:.3;cursor:not-allowed}.room-lighting{background:#000;width:100%;height:100%;position:relative;overflow:hidden}.room-lighting__img{object-fit:cover;object-position:center;width:100%;height:100%;position:absolute}.room-lighting__glow{pointer-events:none;background:radial-gradient(ellipse at center, var(--glow-color) 0%, transparent 70%);opacity:calc(.06 + var(--flicker,.3) * .04);mix-blend-mode:screen;border-radius:50%;position:absolute;transform:translate(-50%,-50%)}.room-lighting__vignette{pointer-events:none;z-index:3;background:radial-gradient(#0000 40%,#0006 80%,#000000b3 100%);position:absolute;inset:0}.room-lighting__label{text-align:center;font-family:var(--font-heading,Georgia, serif);color:#e0d6c8;text-shadow:0 2px 8px #000c;z-index:10;letter-spacing:.08em;font-size:1.2rem;position:absolute;bottom:24px;left:0;right:0}.room-atmosphere{z-index:0;pointer-events:none;transition:opacity 1.2s ease-in-out;position:fixed;inset:0}.room-atmosphere__bg{position:absolute;inset:0}.room-atmosphere__fog{animation:18s ease-in-out infinite alternate roomFogDrift;position:absolute;inset:0}.room-atmosphere__fog--2{animation:22s ease-in-out infinite alternate roomFogDrift2}.room-atmosphere__canvas{width:100%;height:100%;position:absolute;inset:0}.room-atmosphere__vignette,.room-atmosphere__ambient{position:absolute;inset:0}@keyframes roomFogDrift{0%{opacity:.7;transform:translate(-15px)scale(1)}to{opacity:1;transform:translate(15px)scale(1.03)}}@keyframes roomFogDrift2{0%{opacity:.6;transform:translate(10px)translateY(-8px)}to{opacity:1;transform:translate(-10px)translateY(8px)}}.game-screen{isolation:isolate;background:#000;flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.game-screen__room-bg{z-index:0;pointer-events:none;position:absolute;inset:0}.game-screen>:not(.game-screen__room-bg){z-index:1;position:relative}.game-screen .top-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0e0b08d9}.game-screen .char-strip{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0e0b08bf}.game-screen .msg-area{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0e0b0899}.game-screen .msg.narrator{background:#14110deb;border-color:#cd7f3226}.game-screen .msg.user{background:#281e12eb}.game-screen .msg.system{text-shadow:0 1px 4px #000c}.game-screen .choice-area{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0e0b08eb;border-top-color:#cd7f3226}.game-screen .choice-btn{background:#191510f2;border-color:#cd7f3233}.game-screen .choice-btn:hover{background:#cd7f321f;border-color:#cd7f3280}.game-screen .free-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0e0b08eb}.game-screen .free-input{background:#191510e6}.game-screen .free-send{background:#cd7f3226}.game-screen .char-avatar{background:#1e1912e6}@media (width<=480px){.game-screen .choice-btn{padding:10px 12px}.game-screen .msg{max-width:95%}}.room-scene{z-index:3;pointer-events:none;animation:1.5s roomSceneFadeIn;position:fixed;inset:0}.room-svg{width:100%;height:100%;display:block}@keyframes roomSceneFadeIn{0%{opacity:0}to{opacity:1}}.light-demo{background:#000;width:100vw;height:100vh;position:relative;overflow:hidden}.light-demo__controls{z-index:20;opacity:.3;flex-direction:column;align-items:center;gap:8px;padding:12px;transition:opacity .3s;display:flex;position:absolute;top:0;left:0;right:0}.light-demo__controls:hover{opacity:1}.light-demo__tabs{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.light-demo__tab{color:#a09080;cursor:pointer;font-family:var(--font-heading,Georgia, serif);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:1px solid #ffffff26;border-radius:4px;padding:6px 12px;font-size:.8rem;transition:all .2s}.light-demo__tab:hover{color:#e0d6c8;background:#000c}.light-demo__tab--active{color:#ffe0a0;background:#aa8e604d;border-color:#aa8e60}.light-demo__variants{gap:6px;display:flex}.light-demo__variant{color:#a09080;cursor:pointer;font-family:var(--font-heading,Georgia, serif);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:1px solid #ffffff26;border-radius:4px;padding:6px 14px;font-size:.85rem;transition:all .2s}.light-demo__variant:hover{color:#e0d6c8}.light-demo__variant--active{color:#ffe0a0;background:#aa8e604d;border-color:#aa8e60}.light-editor{color:#e0d6c8;width:100vw;height:100vh;font-family:var(--font-heading,Georgia, serif);background:#0a0a0a;display:flex;overflow:hidden}.light-editor__sidebar{background:#111;border-right:1px solid #ffffff14;flex-direction:column;gap:8px;width:240px;min-width:240px;padding:12px;display:flex;overflow-y:auto}.light-editor__section-title{text-transform:uppercase;letter-spacing:.1em;color:#807060;border-bottom:1px solid #ffffff0f;margin-top:8px;padding-bottom:4px;font-size:.75rem}.light-editor__room-select{flex-wrap:wrap;gap:4px;display:flex}.le-room-btn{color:#908070;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:3px;padding:4px 8px;font-family:inherit;font-size:.7rem;transition:all .15s}.le-room-btn:hover{color:#e0d6c8;background:#ffffff14}.le-room-btn--active{color:#ffe0a0;background:#aa8e6040;border-color:#aa8e60}.light-editor__variant-row{gap:4px;display:flex}.le-var-btn{color:#908070;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:3px;flex:1;padding:4px;font-family:inherit;font-size:.75rem;transition:all .15s}.le-var-btn:hover{color:#e0d6c8}.le-var-btn--active{color:#ffe0a0;background:#aa8e6040;border-color:#aa8e60}.le-var-btn--saved{color:#c8e0b8;box-shadow:inset 0 0 0 1px #78c87859}.le-var-btn--saved.le-var-btn--active{box-shadow:inset 0 0 0 1px #c8e68c8c}.light-editor__presets{flex-direction:column;gap:2px;max-height:420px;display:flex;overflow-y:auto}.le-preset{color:#a09080;cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #0000;border-radius:4px;align-items:center;gap:6px;padding:6px 8px;font-family:inherit;font-size:.75rem;transition:all .15s;display:flex}.le-preset:hover{color:#e0d6c8;background:#ffffff0f}.le-preset--active{color:#ffe0a0;background:#aa8e6033;border-color:#aa8e60}.le-preset__icon{text-align:center;width:20px;font-size:1rem}.le-preset__label{flex:1}.le-preset__swatch{border-radius:50%;flex-shrink:0;width:10px;height:10px}.light-editor__actions{flex-direction:column;gap:4px;margin-top:auto;padding-top:8px;display:flex}.le-action-btn{color:#a09080;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:4px;padding:8px;font-family:inherit;font-size:.75rem;transition:all .15s}.le-action-btn:hover{color:#e0d6c8;background:#ffffff1a}.le-action-btn:disabled{opacity:.3;cursor:not-allowed}.le-action-btn--preview{color:#80e0a0;background:#3c8c6433;border-color:#40a060}.le-action-btn--save{color:#80b0ff;background:#3c64c833;border-color:#4080d0;font-weight:700}.le-action-btn--export{color:#ffe0a0;background:#aa8e6033;border-color:#aa8e60}.light-editor__status{background:#ffffff08;border:1px solid #78c87833;border-radius:4px;flex-direction:column;gap:3px;margin-top:8px;padding:8px;display:flex}.light-editor__status-row{letter-spacing:.02em;justify-content:space-between;font-size:.65rem;display:flex}.light-editor__status-label{color:#708060}.light-editor__status-value{color:#c8e0b8;font-weight:600}.light-editor__main{flex-direction:column;flex:1;display:flex;overflow:hidden}.light-editor__canvas{background:#000;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.light-editor__canvas--placing{cursor:crosshair}.light-editor__img-wrap{flex-shrink:0;position:relative}.light-editor__img{object-fit:fill;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0}.light-editor__glow{pointer-events:none;background:radial-gradient(ellipse at center, var(--glow-color) 0%, transparent 70%);opacity:calc(.1 + var(--flicker,.3) * .08);mix-blend-mode:screen;border-radius:50%;transition:outline .2s;position:absolute;transform:translate(-50%,-50%)}.light-editor__glow--highlight{outline-offset:4px;outline:2px dashed #ffe0a080}.light-editor__marker{color:#ffe0a0;cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;border:1.5px solid #ffe0a080;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.6rem;transition:all .15s;display:flex;position:absolute;transform:translate(-50%,-50%)}.light-editor__marker:hover,.light-editor__marker--highlight{color:#fff;background:#aa3232b3;border-color:#f66;transform:translate(-50%,-50%)scale(1.3)}.light-editor__vignette{pointer-events:none;z-index:5;background:radial-gradient(#0000 40%,#0006 80%,#000000b3 100%);position:absolute;inset:0}.light-editor__hint{color:#ffe0a0;z-index:20;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap;background:#000000b3;border-radius:6px;padding:8px 16px;font-size:.85rem;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.light-editor__list{background:#0d0d0d;border-top:1px solid #ffffff0f;flex-wrap:wrap;align-content:flex-start;gap:4px;height:120px;min-height:120px;padding:6px 12px;display:flex;overflow-y:auto}.le-list-item{color:#a09080;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:4px;align-items:center;gap:4px;padding:3px 6px;font-size:.7rem;transition:all .15s;display:flex}.le-list-item--highlight{color:#ffe0a0;border-color:#aa8e60}.le-list-item__num{background:#ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;font-size:.6rem;display:flex}.le-list-item__swatch{border-radius:50%;flex-shrink:0;width:8px;height:8px}.le-list-item__name{white-space:nowrap}.le-list-item__delete{color:#805050;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:.7rem;transition:color .15s}.le-list-item__delete:hover{color:#f66}.light-editor__glow--ignite{animation:.6s ease-out forwards lightIgnite!important}@keyframes lightIgnite{0%{opacity:0;transform:translate(-50%,-50%)scale(.3)}30%{opacity:.35;transform:translate(-50%,-50%)scale(1.4)}to{opacity:.12;transform:translate(-50%,-50%)scale(1)}}.light-editor__marker--ignite{animation:.4s ease-out markerPop}@keyframes markerPop{0%{opacity:0;transform:translate(-50%,-50%)scale(0)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.5)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.light-editor__preview{z-index:100;cursor:pointer;position:fixed;inset:0}.light-editor__preview-hint{font-family:var(--font-heading,Georgia, serif);color:#ffe0a099;z-index:101;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:6px;padding:8px 20px;font-size:.85rem;animation:3s ease-out forwards previewHintFade;position:absolute;bottom:60px;left:50%;transform:translate(-50%)}@keyframes previewHintFade{0%,60%{opacity:1}to{opacity:0}}
