:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;width:100%;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);overflow:hidden;display:flex;flex-direction:column}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{background-color:#1a1a1a;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);display:flex;flex-direction:column;overflow:hidden;margin:0;padding:0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (min-width: 768px){.app{max-width:600px;margin:0 auto;box-shadow:0 0 20px #0000004d}}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;background:#1c1c1c;color:#fff}.loading:after{content:"";width:30px;height:30px;border:3px solid #666;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{color:#ff6b6b;padding:20px;text-align:center;background-color:#ff6b6b1a;border-radius:5px;margin:20px}:focus{outline:2px solid #666;outline-offset:2px}:focus:not(:focus-visible){outline:none}@media (hover: none){button:hover{opacity:1}}button{background:#f44;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:4px;cursor:pointer;font-family:Courier New,Courier,monospace;transition:background-color .3s ease}button:hover{background:#f66}input,textarea{background:#1c1c1c;color:#fff;border:1px solid #333;padding:.8rem;border-radius:4px;font-family:Courier New,Courier,monospace}input:focus,textarea:focus{outline:none;border-color:#f44}h1,h2,h3{color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}h1,h2,h3,h4{font-family:Playfair Display,serif;color:#fafafa;text-shadow:1px 1px 2px #000}.controls{margin-bottom:10px;color:#d4af37}select{margin-left:10px;background-color:#111;color:#fafafa;border:1px solid #444;padding:.4rem;border-radius:4px}.scene-image{width:100%;border-radius:6px;margin:1rem 0;filter:grayscale(100%) contrast(110%)}.suspect-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1rem}.suspect-button{background:#222;color:#d4af37;border:1px solid #555;border-radius:6px;display:flex;align-items:center;padding:.4rem .8rem;font-size:.9rem}.suspect-button.active{background:#444;border-color:#d4af37;font-weight:700}.suspect-avatar{width:32px;height:32px;margin-right:.5rem;border-radius:50%;object-fit:cover}.chat{background-color:#1c1c1c;padding:1rem;border-radius:5px;border:1px solid #444;max-height:200px;overflow-y:auto;margin-top:1rem;margin-bottom:1rem}.message{display:flex;align-items:flex-start;margin-bottom:1rem}.avatar{width:32px;height:32px;border-radius:50%;margin-right:.5rem;border:1px solid #555}.bubble{background:#333;color:#fafafa;padding:.7rem;border-radius:10px;max-width:75%;box-shadow:inset 0 0 5px #000}.user .bubble{margin-left:auto;background-color:#444}.input-row{display:flex;gap:.5rem;margin:1rem 0}.input-row input{flex:1;background:#222;color:#fafafa;border:1px solid #555;border-radius:5px;padding:.5rem;font-size:16px}.cta-button{background-color:#d4af37;color:#000;font-size:1.1rem;font-weight:700;padding:1rem;border-radius:8px;margin-top:2rem;width:100%;box-shadow:0 4px 10px #00000080;transition:background-color .3s ease}.cta-button:hover{background-color:#e8c94e}.explicit-button{margin:2rem 0;text-align:center}.final-submission textarea{background-color:#111;color:#fafafa;border:1px solid #444;padding:.5rem;border-radius:5px;width:100%;margin-bottom:1rem;font-size:16px}.evaluation,.solution{background-color:#1a1a1a;border:1px solid #333;border-radius:6px;padding:1rem;margin-top:1rem;color:#fafafa}.eval-buttons{display:flex;gap:1rem;margin-top:1rem}.stage-avatar{font-style:italic;margin:.5rem 0}.fade-in{animation:fadeIn .5s ease-in}@media (max-width: 600px){.input-row{flex-direction:column}.suspect-buttons{flex-direction:column;align-items:stretch}button,.cta-button{width:100%}.bubble{max-width:100%}.chat{max-height:150px}}.restart-link{color:#d4af37;cursor:pointer;margin-left:1rem;text-decoration:underline}.restart-link:hover{color:#fff8dc}.mystery-selection{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);background:#1c1c1c;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;box-sizing:border-box}.game-logo{position:absolute;top:1rem;left:50%;transform:translate(-50%);width:50%;max-width:300px;height:auto;z-index:10}.hamburger-menu{position:absolute;top:1rem;left:1rem;width:48px;height:48px;background:#000000b3;border:none;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;z-index:20;backdrop-filter:blur(4px);transition:background .3s ease}.hamburger-menu:hover{background:#000000e6}.hamburger-line{width:24px;height:3px;background:#bc8d0d;border-radius:2px;transition:all .3s ease}.hamburger-menu:hover .hamburger-line{background:#e8c94e}.mystery-carousel{position:relative;width:100%;max-width:1200px;height:80vh;overflow-x:auto;scroll-snap-type:x mandatory;border-radius:12px;scrollbar-width:none;-ms-overflow-style:none;touch-action:pan-y;background:#1c1c1c}.mystery-carousel::-webkit-scrollbar{display:none}.mystery-slides{display:flex;height:100%;transition:transform .3s ease-out;align-items:center;justify-content:flex-start;gap:2rem;padding-left:calc(50% - 140px)}.mystery-slide{flex:0 0 auto;width:280px;height:392px;display:flex;align-items:center;justify-content:center;padding:0;box-sizing:border-box;scroll-snap-align:center;scroll-snap-stop:always;margin:0;background:#000;border-radius:12px}.mystery-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0006}.mystery-content img{width:100%;height:100%;object-fit:contain;border-radius:12px;background:transparent;box-sizing:border-box}.mystery-info{position:absolute;bottom:0;left:0;right:0;background:#000c;padding:1rem;text-align:center;border-radius:0 0 12px 12px;backdrop-filter:blur(4px)}.mystery-date{color:#ccc;margin:0;font-size:.9rem}.mystery-date-top{position:absolute;top:0;left:0;right:0;background:#000c;color:#bbb;padding:.75rem;text-align:center;font-size:1.1rem;font-family:inherit;line-height:1.2;border-radius:12px 12px 0 0;backdrop-filter:blur(4px);z-index:2}.carousel-controls{position:absolute;left:50%;bottom:.25rem;transform:translate(-50%);display:flex;align-items:center;justify-content:center;gap:1.5rem;z-index:30;pointer-events:auto;will-change:transform}.nav-button{position:relative;top:unset;left:unset;right:unset;transform:none;margin:0 .5rem;background:#000000b3!important;color:#fff;border:none;width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:1.2rem;transition:background .3s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);pointer-events:auto;z-index:31}.nav-button:hover,.nav-button:active,.nav-button:focus{background:#000000e6!important;color:#bc8d0d;outline:none}.nav-button:disabled{opacity:.3;cursor:not-allowed;background:#000000b3!important;color:#fff}.carousel-dots{position:static;transform:none;background:#0000004d;border-radius:20px;padding:.5rem 1rem;display:flex;gap:.75rem;align-items:center;z-index:31;pointer-events:auto}.dot{width:6px;height:6px;border-radius:50%;background:#fff6;cursor:pointer;transition:all .3s ease;border:none;padding:0}.dot:hover{background:#fff9;transform:scale(1.2)}.dot.active{background:#bc8d0d;transform:scale(1.3)}.dot:focus-visible{outline:2px solid #BC8D0D;outline-offset:2px}.mystery-slide:active{opacity:.8}.mystery-carousel{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.mystery-content:after{content:"";position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);pointer-events:none}.mystery-selection .mystery-carousel .mystery-slide .mystery-content .mystery-info h2{color:#fff!important;margin:0 0 .25rem;font-size:1.1rem;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.8)}body,html{height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);overflow:hidden;margin:0;padding:0;display:flex;flex-direction:column;overscroll-behavior:none;-webkit-overflow-scrolling:touch}#root{margin:0;padding:0;width:100%;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);display:flex;flex-direction:column;flex:1;overflow:hidden;position:relative}#root>div{margin:0;padding:0;width:100%;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);display:flex;flex-direction:column;flex:1;overflow:hidden}.mystery-gameplay{display:flex;flex-direction:column;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);min-height:100vh;min-height:100dvh;min-height:calc(var(--vh, 1vh) * 100);background:#232323;color:#bc8d0d;font-family:Montserrat,Roboto Slab,Arial,sans-serif;overflow:hidden;position:relative;-webkit-overflow-scrolling:touch;box-sizing:border-box}.mystery-header{display:flex;justify-content:space-between;align-items:center;background:#232323;color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:800;font-size:1.25rem;height:36px;letter-spacing:.5px;box-shadow:0 2px 8px #0007;z-index:10}.region-stack{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.region{background:#2a2a2a;transition:height .3s ease,padding-top .3s ease,padding-bottom .3s ease;position:relative;overflow:hidden}.region.collapsed{flex:0 0 auto}.region.intro-region.collapsed{height:44px}.region.suspects-region.collapsed{height:auto;padding:16px}.region.conclusion-region.collapsed{height:44px}.region.expanded{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}.region:after{content:"";position:absolute;bottom:0;left:11px;right:11px;height:1px;background:#bc8d0d}.region.conclusion-region:after{display:none}.region.collapsed:hover{background:#2a2a2a}.region.suspects-region.collapsed .character-buttons{padding:0}.mystery-header .case-title{font-family:Roboto Slab,serif;font-size:1.18rem;text-shadow:1px 1px 2px rgba(0,0,0,.7);padding:0 11px;letter-spacing:.5px;white-space:nowrap;text-align:left}.mystery-header .close-btn{background:none;border:none;color:#bc8d0d;font-size:1.5rem;font-weight:700;cursor:pointer;transition:color .2s;padding:0;line-height:1;z-index:1;width:36px;min-width:36px;display:flex;align-items:center;justify-content:center}.mystery-header .close-btn:hover{color:#fff}.collapsed-bar{display:flex;align-items:center;justify-content:space-between;height:50px;background:#232323;border-bottom:2.5px solid #BC8D0D;cursor:pointer;position:relative;z-index:3;box-shadow:0 2px 8px #0007;padding:0;margin:0}.bar-label,.bar-title{display:flex;align-items:center;font-family:Roboto Slab,serif;font-weight:700;font-size:1.08rem;letter-spacing:.5px;padding-left:6px;padding-right:6px;height:100%;line-height:1;margin:0}.bar-arrow,.bar-arrow-expanded{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#232323;color:#bc8d0d;font-size:1.7rem;font-weight:700;box-shadow:0 2px 8px #0007;transition:background .2s,color .2s;margin-right:12px;user-select:none}.bar-arrow-expanded{background:#232323;color:#bc8d0d;transform:rotate(180deg);border-top:6px solid #BC8D0D}.collapsed-bar:hover .bar-arrow{background:#bc8d0d;color:#232323;border-top-color:#fff}.intro-preview{padding:11px;color:#bbb;cursor:pointer;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#232323}.intro-preview:hover{background:#2a2a2a}.intro-content{padding:16px 11px 11px;display:flex;flex-direction:column;align-items:center;overflow-y:auto;height:100%;min-height:0}.intro-text{color:#bbb;font-size:1rem;width:100%;margin-bottom:11px}.intro-text p{margin:0;color:#bbb}.restart-btn{background:#bc8d0d;color:#000;padding:12px 24px;border-radius:4px;font-size:.9rem;cursor:pointer;box-shadow:none;border:none;width:fit-content;align-self:center}.restart-btn:hover{background:#e8c94e}.suspects-content{display:flex;flex-direction:column;height:100%;background:#232323;min-height:0;flex:1}.character-carousel{display:flex;align-items:center;justify-content:space-between;padding:11px;background:#232323;border-bottom:2.5px solid #BC8D0D}.nav-button{background:none;border:none;color:#bc8d0d;font-size:2rem;padding:0 10px;cursor:pointer;transition:color .2s}.nav-button:hover{color:#fff}.character-header{display:flex;flex-direction:column;align-items:center;gap:8px}.character-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.character-name{color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;white-space:nowrap;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;font-size:clamp(.7rem,2.5vw,.9rem);line-height:1.2;flex:1;min-width:0;min-height:1.2em;display:block}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:11px;min-height:0}.chat-messages{background-color:#1c1c1c;padding:1rem;border-radius:5px;border:1px solid #444;overflow-y:scroll;margin-bottom:1rem;flex:1 0 0;display:flex;flex-direction:column;gap:8px;min-height:0}.message{margin-bottom:10px;padding:10px 14px;border-radius:14px;max-width:80%;font-size:1.05rem;color:#fff;background:#353535;box-shadow:0 1px 4px #0003}.message.user{background:#8b0000;color:#fff;margin-left:auto;font-weight:700}.message.assistant{background:#353535;color:#fff;margin-right:auto}.typing-message{background:#353535!important;padding:10px 14px!important}.typing-animation{display:flex;gap:4px;align-items:center}.typing-animation span{width:8px;height:8px;border-radius:50%;background:#bc8d0d;animation:typing 1.4s infinite ease-in-out}.typing-animation span:nth-child(1){animation-delay:-.32s}.typing-animation span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.question-form{display:flex;gap:11px;padding:11px;background:#232323;position:relative;z-index:10;min-height:60px;align-items:center}.question-form input{flex:1;background:#222;color:#fafafa;border:1px solid #555;border-radius:5px;padding:.5rem;font-size:16px;min-height:44px;box-sizing:border-box}.question-form input:focus{outline:none;border-color:#bc8d0d;box-shadow:0 0 5px #bc8d0d}.question-form button{background:#444;color:#bbb;padding:8px 16px;border-radius:4px;font-size:.9rem;cursor:pointer;box-shadow:none;border:none;width:fit-content;white-space:nowrap;min-height:44px;display:flex;align-items:center;justify-content:center}.question-form button:hover{background:#555}.solve-preview{width:100%;padding:11px;background:#232323;border:none;color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;font-size:1.1rem;cursor:pointer;text-align:center}.solve-preview:hover{background:#2a2a2a}.conclusion-content{padding:16px 11px 11px;display:flex;flex-direction:column;height:100%;overflow-y:auto;min-height:0}.conclusion-content textarea{width:100%;min-height:200px;background:#222;color:#fafafa;border:1px solid #555;border-radius:5px;padding:1rem;font-size:16px;font-family:inherit;resize:vertical;margin-bottom:11px;box-sizing:border-box}.conclusion-content textarea:focus{outline:none;border-color:#bc8d0d}.solve-btn{background:#bc8d0d;color:#000;padding:12px 24px;border-radius:4px;font-size:.9rem;cursor:pointer;box-shadow:none;border:none;width:fit-content;align-self:center}.solve-btn:hover{background:#555}.evaluation{background:#1c1c1c;border:1px solid #444;border-radius:5px;padding:1rem;margin-top:11px;color:#fafafa}.evaluation h4{color:#bc8d0d;margin:0 0 8px;font-family:Roboto Slab,serif}.evaluation p{margin:4px 0;color:#bbb}.reveal-btn{background:#bc8d0d;color:#000;padding:8px 16px;border-radius:4px;font-size:.9rem;cursor:pointer;box-shadow:none;border:none;width:fit-content;margin-top:11px;font-weight:700}.reveal-btn:hover{background:#e8c94e}.solution{background:#1c1c1c;border:1px solid #444;border-radius:5px;padding:1rem;margin-top:11px;color:#fafafa}.solution h4{color:#bc8d0d;margin:0 0 8px;font-family:Roboto Slab,serif}.solution p{margin:4px 0;color:#bbb}.solution strong{color:#bc8d0d}.character-buttons{display:flex;gap:11px;padding:16px;background:#232323}.character-button{background:#222;color:#bc8d0d;border:1px solid #555;border-radius:6px;display:flex;align-items:center;padding:.3rem .6rem .3rem .3rem;font-size:.9rem;gap:5px;flex:1;transition:all .2s;min-width:0}.character-button:hover{background:#333}.character-button.active{background:#444;border-color:#bc8d0d;font-weight:700}.character-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}@media (max-width: 768px){.character-carousel{padding:8px}.character-avatar{width:40px;height:40px}.character-name{font-size:.85rem;white-space:nowrap;min-height:1.2em;display:block}.nav-button{font-size:1.8rem;padding:0 8px}.chat-messages{padding:11px}.question-form{padding:8px 0}.message{font-size:1rem;padding:8px 12px}.character-button{padding:.3rem .6rem .3rem .3rem;gap:5px}.character-avatar{width:28px;height:28px}}@supports (-webkit-touch-callout: none){.mystery-gameplay{height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);overflow:hidden}.chat-container{padding-bottom:20px;display:flex;flex-direction:column;height:100%;position:relative}.chat-messages{flex:1;overflow-y:auto;padding-bottom:100px}.question-form{position:absolute;bottom:0;left:0;right:0;background:#232323;border-top:1px solid #444;z-index:100;padding:11px;margin:0}.question-form input{font-size:16px!important;line-height:1.2}body,html{position:static;overflow:auto}}.evaluating-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.evaluating-container p{color:#bbb;margin-top:1rem;font-size:1.1rem}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;height:100dvh;background:#1c1c1c;color:#bc8d0d;font-family:Roboto Slab,serif;font-size:1.2rem;gap:2rem}.loading p{margin:0;color:#bc8d0d}.loading .loading-spinner{margin-top:0}.avatar-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}.avatar-popup-content{background:#2a2a2a;border:2px solid #BC8D0D;border-radius:12px;padding:2rem;display:flex;flex-direction:column;align-items:center;position:relative;max-width:90vw;max-height:90vh;box-shadow:0 8px 32px #0009}.avatar-popup-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:#bc8d0d;font-size:2rem;font-weight:700;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.avatar-popup-close:hover{background:#bc8d0d33}.avatar-popup-image{width:200px;height:200px;border-radius:50%;object-fit:cover;border:3px solid #BC8D0D;margin-bottom:1rem;box-shadow:0 4px 16px #0006}.avatar-popup-name{color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;font-size:1.5rem;margin:0;text-align:center;text-shadow:1px 1px 2px rgba(0,0,0,.8)}@media (max-width: 768px){.avatar-popup-content{padding:1.5rem;margin:1rem}.avatar-popup-image{width:150px;height:150px}.avatar-popup-name{font-size:1.2rem}}.inactivity-warning-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.inactivity-warning-modal{background:#2a2a2a;border:2px solid #BC8D0D;border-radius:8px;padding:24px;max-width:400px;width:90%;text-align:center;box-shadow:0 4px 20px #00000080;animation:slideIn .3s ease}.inactivity-warning-content h3{color:#bc8d0d;font-family:Roboto Slab,serif;font-size:1.3rem;margin:0 0 16px;font-weight:700}.inactivity-warning-content p{color:#fff;font-family:Montserrat,sans-serif;font-size:.95rem;line-height:1.5;margin:0 0 12px}.inactivity-warning-dismiss{background:#bc8d0d;color:#232323;border:none;border-radius:4px;padding:12px 24px;font-family:Montserrat,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;margin-top:16px}.inactivity-warning-dismiss:hover{background:#d4a017;transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.debug-panel{position:fixed;top:20px;right:20px;background:#000000e6;color:#bc8d0d;padding:15px;border-radius:8px;border:2px solid #BC8D0D;z-index:10000;font-family:Courier New,monospace;font-size:12px;min-width:200px;backdrop-filter:blur(4px)}.debug-panel h4{margin:0 0 10px;color:#bc8d0d;font-size:14px;text-align:center}.debug-stats{margin-bottom:10px}.debug-stats div{margin:2px 0;padding:2px 0}.debug-panel button{background:#bc8d0d;color:#1c1c1c;border:none;padding:5px 10px;border-radius:4px;cursor:pointer;font-size:11px;width:100%}.debug-panel button:hover{background:#d4a017}.scene-image.cached,.character-avatar.cached,.avatar-popup-image.cached{border:2px solid #4CAF50}.scene-image.fresh,.character-avatar.fresh,.avatar-popup-image.fresh{border:2px solid #FF9800}.scene-image.error,.character-avatar.error,.avatar-popup-image.error{border:2px solid #f44336}.mobile-debug-btn{position:fixed;top:10px;right:10px;width:44px;height:44px;border-radius:50%;background:#bc8d0de6;border:2px solid #BC8D0D;color:#232323;font-size:20px;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #0000004d;-webkit-tap-highlight-color:transparent}.mobile-debug-btn:hover,.mobile-debug-btn:active{background:#bc8d0d;transform:scale(1.1);box-shadow:0 4px 12px #0006}.mobile-debug-btn:focus{outline:none;box-shadow:0 0 0 3px #bc8d0d80}@media (max-width: 768px){.mobile-debug-btn{top:15px;right:15px}.game-header{padding-right:60px}}.login-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}.login-modal{background:#2a2a2a;border:2px solid #BC8D0D;border-radius:12px;padding:2rem;width:90%;max-width:400px;position:relative;box-shadow:0 8px 32px #0009}.login-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:#bc8d0d;font-size:2rem;font-weight:700;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.login-close:hover{background:#bc8d0d33}.login-header{text-align:center;margin-bottom:1.5rem}.login-header h2{color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;margin:0 0 .5rem;font-size:1.5rem}.login-header p{color:#bbb;margin:0;font-size:.9rem}.login-error{background:#ff6b6b1a;border:1px solid #ff6b6b;color:#ff6b6b;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.login-form{margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;color:#bc8d0d;font-weight:600;margin-bottom:.5rem;font-size:.9rem}.form-group input{width:100%;padding:.75rem;background:#222;border:1px solid #555;border-radius:6px;color:#fafafa;font-size:1rem;box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#bc8d0d;box-shadow:0 0 5px #bc8d0d4d}.login-submit{width:100%;background:#bc8d0d;color:#000;border:none;padding:.75rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-submit:hover:not(:disabled){background:#e8c94e}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-divider{text-align:center;margin:1.5rem 0;position:relative}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#555}.login-divider span{background:#2a2a2a;padding:0 1rem;color:#bbb;font-size:.9rem}.google-signin{width:100%;background:#fff;color:#333;border:1px solid #ddd;padding:.75rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.google-signin:hover:not(:disabled){background:#f5f5f5}.google-signin:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px}.login-footer{text-align:center;margin-top:1.5rem}.login-footer p{color:#bbb;margin:0;font-size:.9rem}.login-toggle{background:none;border:none;color:#bc8d0d;cursor:pointer;text-decoration:underline;font-size:.9rem;margin-left:.5rem}.login-toggle:hover{color:#e8c94e}@media (max-width: 768px){.login-modal{padding:1.5rem;margin:1rem}.login-header h2{font-size:1.3rem}}.video-unlock-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;backdrop-filter:blur(8px);opacity:1;visibility:visible;transition:opacity .2s ease,visibility .2s ease}.video-unlock-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.video-unlock-modal{background:#2a2a2a;border:2px solid #BC8D0D;border-radius:12px;padding:2rem;width:90%;max-width:500px;position:relative;box-shadow:0 8px 32px #000c}.video-unlock-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:#bc8d0d;font-size:2rem;font-weight:700;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.video-unlock-close:hover{background:#bc8d0d33}.video-unlock-header{text-align:center;margin-bottom:1.5rem}.video-unlock-header h2{color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;margin:0 0 .5rem;font-size:1.5rem}.video-unlock-header p{margin:.5rem 0;color:#ccc;font-size:.9rem}.video-container{margin-bottom:1.5rem}.video-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;background:#1c1c1c;border-radius:8px;border:1px solid #444}.video-loading p{color:#bbb;margin-top:1rem;font-size:1rem}.video-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;background:#ff6b6b1a;border:1px solid #ff6b6b;border-radius:8px;color:#ff6b6b}.video-error button{background:#ff6b6b;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;margin-top:1rem;cursor:pointer}.video-watching{background:#1c1c1c;border-radius:8px;overflow:hidden;border:1px solid #444}.ad-progress{text-align:center;color:#bbb;padding:2rem 1rem}.progress-bar{width:100%;height:8px;background:#333;border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:#bc8d0d;border-radius:4px;transition:width .3s ease}.ad-progress p{margin:0;font-size:1rem;font-weight:500}.video-placeholder{background:#1c1c1c;border-radius:8px;overflow:hidden;border:1px solid #444}.video-player{position:relative;width:100%;height:200px;background:linear-gradient(45deg,#1a1a1a,#2a2a2a);display:flex;align-items:center;justify-content:center}.video-content{text-align:center;color:#bbb}.play-button{font-size:3rem;color:#bc8d0d;margin-bottom:.5rem;cursor:pointer;transition:transform .2s}.play-button:hover{transform:scale(1.1)}.video-duration{font-size:.9rem;color:#888;margin-top:.5rem}.video-controls{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.watch-video-btn{background:#bc8d0d;color:#000;border:none;padding:.75rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.watch-video-btn:hover{background:#e8c94e}.watch-video-btn.primary{background:#bc8d0d;color:#000;font-weight:600;font-size:1.1rem;padding:1rem 2rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px #bc8d0d4d}.watch-video-btn.primary:hover{background:#d4a017;transform:translateY(-2px);box-shadow:0 6px 12px #bc8d0d66}.watch-video-btn.primary:disabled{background:#666;cursor:not-allowed;transform:none;box-shadow:none}.skip-video-btn{background:transparent;color:#bc8d0d;border:1px solid #BC8D0D;padding:.75rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.skip-video-btn:hover{background:#bc8d0d;color:#000}.video-unlock-footer{text-align:center;color:#bbb;font-size:.9rem;line-height:1.4}.video-unlock-footer p{margin:.25rem 0}.subscription-prompt{max-width:600px}.subscription-content{text-align:center}.subscription-content h2{color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;margin:0 0 .5rem;font-size:1.8rem}.subscription-content>p{color:#bbb;margin:0 0 2rem;font-size:1.1rem}.subscription-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.plan{background:#1c1c1c;border:1px solid #444;border-radius:8px;padding:1.5rem 1rem;text-align:center;transition:all .2s}.plan.featured{border-color:#bc8d0d;background:#bc8d0d1a;transform:scale(1.05)}.plan h3{color:#bc8d0d;margin:0 0 1rem;font-size:1.2rem}.plan .price{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.5rem}.plan .price span{font-size:.9rem;color:#bbb;font-weight:400}.plan .savings{background:#bc8d0d;color:#000;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600;margin-bottom:1rem;display:inline-block}.plan ul{list-style:none;padding:0;margin:1rem 0 0;text-align:left}.plan li{color:#bbb;margin:.5rem 0;font-size:.9rem;position:relative;padding-left:1.5rem}.plan li:before{content:"✓";color:#bc8d0d;position:absolute;left:0;font-weight:700}.subscribe-btn{background:#bc8d0d;color:#000;border:none;padding:1rem 2rem;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .2s;margin-bottom:1rem;width:100%;max-width:200px}.subscribe-btn:hover{background:#e8c94e}.back-to-video{background:transparent;color:#bc8d0d;border:none;font-size:.9rem;cursor:pointer;text-decoration:underline}.back-to-video:hover{color:#e8c94e}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.video-unlock-modal{padding:1.5rem;margin:1rem}.subscription-plans{grid-template-columns:1fr}.plan.featured{transform:none}.video-player{height:150px}.play-button{font-size:2.5rem}}.anonymous-notice{background:#ff6b35;color:#fff;padding:.5rem;border-radius:4px;font-size:.8rem;font-weight:600;margin:.5rem 0}.login-subscribe-note{background:#bc8d0d1a;border:1px solid rgba(188,141,13,.3);border-radius:8px;padding:1rem;margin-top:1rem}.login-subscribe-note p{margin:0;color:#bc8d0d;font-size:.9rem;text-align:center}.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;backdrop-filter:blur(8px)}.menu-modal{background:#2a2a2a;border:2px solid #BC8D0D;border-radius:12px;padding:2rem;width:90%;max-width:400px;position:relative;box-shadow:0 8px 32px #000c}.menu-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:#bc8d0d;font-size:2rem;font-weight:700;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.menu-close:hover{background:#bc8d0d33}.menu-content h2{color:#bc8d0d;font-family:Roboto Slab,serif;font-weight:700;margin:0 0 1.5rem;font-size:1.8rem;text-align:center}.user-info{display:flex;align-items:center;gap:1rem;background:#bc8d0d1a;border:1px solid rgba(188,141,13,.3);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.user-avatar{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#bc8d0d33;border-radius:50%;flex-shrink:0}.user-details h3{color:#bc8d0d;margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.user-status{color:#bbb;margin:0;font-size:.9rem}.menu-options{display:flex;flex-direction:column;gap:1rem}.menu-option{background:#1c1c1c;border:1px solid #444;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:1rem;text-align:left;width:100%}.menu-option:hover{border-color:#bc8d0d;background:#bc8d0d1a;transform:translateY(-2px);box-shadow:0 4px 12px #bc8d0d33}.logout-option:hover{border-color:#ff6b6b;background:#ff6b6b1a;box-shadow:0 4px 12px #ff6b6b33}.logout-option .menu-icon{background:#ff6b6b33}.logout-option:hover .menu-icon{background:#ff6b6b4d}.logout-option .menu-text h3{color:#ff6b6b}.premium-option:hover{border-color:gold;background:#ffd7001a;box-shadow:0 4px 12px #ffd70033}.premium-option .menu-icon{background:#ffd70033}.premium-option:hover .menu-icon{background:#ffd7004d}.premium-option .menu-text h3{color:gold}.menu-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#bc8d0d33;border-radius:8px;flex-shrink:0}.menu-text h3{color:#bc8d0d;margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.menu-text p{color:#bbb;margin:0;font-size:.9rem;line-height:1.3}@media (max-width: 768px){.menu-modal{padding:1.5rem;margin:1rem}.menu-option{padding:.75rem}.menu-icon{width:36px;height:36px;font-size:1.3rem}}.subscription-overlay{position:fixed;inset:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;backdrop-filter:blur(5px)}.subscription-modal{background:#1a1a1a;border-radius:16px;padding:2rem;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;position:relative;border:1px solid #333;box-shadow:0 20px 40px #00000080}.subscription-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:1px solid #333;color:#fff;font-size:1.5rem;font-weight:700;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;z-index:10}.subscription-close:hover{background:#fff3;border-color:#666;transform:scale(1.1)}.subscription-header{text-align:center;margin-bottom:2rem}.subscription-header h2{color:#fff;font-size:2rem;margin-bottom:.5rem;font-weight:600}.subscription-header p{color:#ccc;font-size:1.1rem;margin:0}.subscription-error{background:#f44;color:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.subscription-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.subscription-plan{background:#2a2a2a;border:2px solid #333;border-radius:12px;padding:1.5rem;position:relative;transition:all .3s ease;cursor:pointer}.subscription-plan:hover{border-color:#666;transform:translateY(-2px);box-shadow:0 10px 20px #0000004d}.subscription-plan.popular{border-color:gold;background:linear-gradient(135deg,#2a2a2a,#333)}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:gold;color:#000;padding:.25rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.plan-header{text-align:center;margin-bottom:1.5rem}.plan-header h3{color:#fff;font-size:1.5rem;margin-bottom:1rem;font-weight:600}.plan-price{margin-bottom:.5rem}.plan-price .price{color:gold;font-size:2.5rem;font-weight:700;display:block}.plan-price .period{color:#888;font-size:1rem;display:block}.plan-description{color:#ccc;font-size:.9rem;margin:0;line-height:1.4}.plan-features{list-style:none;padding:0;margin:0 0 1.5rem}.plan-features li{color:#ccc;padding:.5rem 0;display:flex;align-items:center;font-size:.95rem}.feature-icon{color:#4caf50;font-weight:700;margin-right:.75rem;font-size:1.1rem}.subscribe-button{width:100%;background:#4caf50;color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.subscribe-button:hover:not(:disabled){background:#45a049;transform:translateY(-1px)}.subscribe-button:disabled{background:#666;cursor:not-allowed;transform:none}.subscribe-button.popular{background:gold;color:#000}.subscribe-button.popular:hover:not(:disabled){background:#ffed4e}.subscription-footer{text-align:center;border-top:1px solid #333;padding-top:1.5rem}.subscription-footer p{color:#888;font-size:.9rem;margin:.25rem 0}.success-modal{max-width:500px;text-align:center}.success-content{padding:1rem}.success-icon{font-size:4rem;margin-bottom:1rem}.success-content h2{color:#4caf50;margin-bottom:1rem}.success-content p{color:#ccc;font-size:1.1rem;margin-bottom:2rem}.success-features{text-align:left;margin-bottom:2rem}.success-features h3{color:#fff;margin-bottom:1rem;text-align:center}.success-features ul{list-style:none;padding:0}.success-features li{color:#ccc;padding:.5rem 0;font-size:1rem}.success-actions{display:flex;flex-direction:column;gap:1rem}.primary-button{background:#4caf50;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.primary-button:hover{background:#45a049;transform:translateY(-1px)}.secondary-button{background:transparent;color:#888;border:1px solid #333;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.secondary-button:hover{background:#333;color:#fff}@media (max-width: 768px){.subscription-modal{padding:1.5rem;margin:1rem}.subscription-plans{grid-template-columns:1fr;gap:1rem}.subscription-header h2{font-size:1.5rem}.plan-price .price{font-size:2rem}}@media (max-width: 480px){.subscription-modal,.subscription-plan{padding:1rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.subscribe-button:disabled{opacity:.7;cursor:not-allowed;pointer-events:none}.subscribe-button:disabled:hover{transform:none;box-shadow:none}
