: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:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh}.mode-switch-wrapper{display:flex;align-items:center;gap:1rem;margin-top:1.5rem}.mode-switch-label{position:relative;display:inline-flex;align-items:center;cursor:pointer}.cookie-switch{--cookie-size: 1.5em;--outer-border: .25em;--inner-border: .25em;--border-color: #d8a04d;--height: calc(var(--cookie-size) + (2 * (var(--outer-border) + var(--inner-border))));--width: calc(var(--height) * 2);position:relative;width:var(--width);height:var(--height)}.cookie-switch input{display:none}.cookie-switch label{cursor:pointer}.cookie-switch input:checked~.cookie{transform:translate(calc(var(--width) / 2)) rotate(360deg);color:#d8a04d;background-color:currentColor}.cookie-switch input:checked~.cookie span[class^=cookie-part-],.cookie-switch input:checked~.cookie span[class^=chocolate-chips-]{transform:translate(0)}.cookie-background{height:100%;border-radius:calc(var(--width) / 4);border:var(--outer-border) solid var(--border-color);background:linear-gradient(to right,#484848,#202020)}.cookie{--chip-size: calc(var(--cookie-size) / 8);--split-offset: calc(var(--cookie-size) / 24);position:absolute;top:calc(var(--outer-border) + var(--inner-border));left:calc(var(--outer-border) + var(--inner-border));width:var(--cookie-size);height:var(--cookie-size);border-radius:50%;transition:transform 1s linear}.cookie span[class^=cookie-part-]{position:absolute;width:100%;height:100%;border-radius:50%;color:#d8a04d;background-color:currentColor}.cookie-part-1{clip-path:polygon(0% 0%,55% 0%,52% 8%,55% 10%,55% 16%,52% 19%,52% 24%,47% 26%,45% 30%,50% 33%,47% 37%,47% 42%,51% 47%,47% 49%,40% 50%,34% 50%,30% 53%,25% 53%,20% 56%,16% 56%,14% 61%,0% 60%);transform:translate(calc(var(--split-offset) * -1),calc(var(--split-offset) * -1))}.cookie-part-2{clip-path:polygon(55% 0%,100% 0%,100% 72%,88% 68%,84% 61%,78% 60%,77% 56%,75% 53%,71% 55%,66% 50%,63% 47%,58% 49%,56% 44%,51% 47%,47% 42%,47% 37%,50% 33%,45% 30%,47% 26%,52% 24%,52% 19%,55% 16%,55% 10%,52% 8%);transform:translate(calc(var(--split-offset) * 1),calc(var(--split-offset) * -1))}.cookie-part-3{clip-path:polygon(0% 60%,14% 61%,16% 56%,20% 56%,25% 53%,30% 53%,34% 50%,40% 50%,47% 49%,51% 47%,55% 53%,60% 56%,56% 62%,53% 67%,57% 72%,57% 81%,57% 87%,63% 92%,60% 100%,0% 100%);transform:translate(calc(var(--split-offset) * -1),calc(var(--split-offset) * 1))}.cookie-part-4{clip-path:polygon(100% 100%,100% 72%,88% 68%,84% 61%,78% 60%,77% 56%,75% 53%,71% 55%,66% 50%,63% 47%,58% 49%,56% 44%,51% 47%,55% 53%,60% 56%,56% 62%,53% 67%,57% 72%,57% 81%,57% 87%,63% 92%,60% 100%);transform:translate(calc(var(--split-offset) * 1),calc(var(--split-offset) * 1))}.cookie span[class^=chocolate-chips-]{position:absolute;color:#754e27;background-color:#865729;height:var(--chip-size);width:var(--chip-size);border-radius:50%;box-shadow:inset -.175em 0}.cookie .chocolate-chips-1a{top:41%;left:5%}.cookie .chocolate-chips-1b{top:20%;left:18%}.cookie .chocolate-chips-1c{top:35%;left:33%}.cookie .chocolate-chips-1d{top:6%;left:39%}.cookie .chocolate-chips-2a{--chip-size: calc(var(--cookie-size) / 10);top:24%;right:35%}.cookie .chocolate-chips-2b{top:36%;right:23%}.cookie .chocolate-chips-2c{top:7%;right:29%}.cookie .chocolate-chips-2d{top:42%;right:7%}.cookie .chocolate-chips-2e{top:19%;right:12%}.cookie .chocolate-chips-3a{--chip-size: calc(var(--cookie-size) / 6);bottom:24%;left:18%}.cookie .chocolate-chips-3b{bottom:34%;left:42%}.cookie .chocolate-chips-3c{bottom:9%;left:39%}.cookie .chocolate-chips-4a{bottom:27%;right:29%}.cookie .chocolate-chips-4b{bottom:12%;right:23%}.cookie .chocolate-chips-4c{--chip-size: calc(var(--cookie-size) / 12);bottom:28%;right:17%}.cookie span[class^=chocolate-chips-1]{transform:translate(calc(var(--split-offset) * -1),calc(var(--split-offset) * -1))}.cookie span[class^=chocolate-chips-2]{transform:translate(calc(var(--split-offset) * 1),calc(var(--split-offset) * -1))}.cookie span[class^=chocolate-chips-3]{transform:translate(calc(var(--split-offset) * -1),calc(var(--split-offset) * 1))}.cookie span[class^=chocolate-chips-4]{transform:translate(calc(var(--split-offset) * 1),calc(var(--split-offset) * 1))}.mode-label-text{font-size:.875rem;color:#ffffffe6;font-weight:600;min-width:6rem;text-align:left}.app-logo{display:flex;align-items:center;gap:.5rem;height:55px;width:-moz-fit-content;width:fit-content}.logo-img{height:100%;width:auto;-o-object-fit:contain;object-fit:contain}.landing-footer{background:#050505;border-top:1px solid rgba(255,255,255,.1);padding:1.5rem 2rem;width:100%;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.github-link{color:#fff;transition:transform .2s ease;display:flex;align-items:center}.github-link:hover{transform:scale(1.1)}.github-icon-container{width:40px;height:40px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.github-link:hover .github-icon-container{background:#fff3;border-color:#fff6;box-shadow:0 0 15px #ffffff1a}.footer-logo{opacity:.8;transition:opacity .3s ease}.footer-logo:hover{opacity:1}@media(max-width:768px){.landing-footer{padding:1.5rem 1rem}}.landing-page{min-height:100vh;background:#000;--angle: 90deg}.hero-section{position:relative;width:100%;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden}.logo-container{position:absolute;top:2rem;left:2rem;z-index:10}.theatre-background{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:flex;align-items:center;justify-content:center}.theatre-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.6}.ray{clip-path:polygon(0% 40%,100% 0%,100% 100%,0% 60%);transition:4s;transform:translateY(-50%) translate(-50%) rotate(var(--angle)) translateY(50%) translate(50%) translateY(-50%);position:absolute;top:-50px;width:800px;height:150px;background:linear-gradient(.25turn,#ff0c,#ffff6400)}.light1,.light2{position:absolute;top:0;width:100%;height:100%;pointer-events:none}.light1{left:-15%;animation-duration:10s;animation-name:wave1;animation-iteration-count:infinite}.light1 .ray{left:35%}.light2{right:-15%;animation-duration:7s;animation-name:wave2;animation-iteration-count:infinite}.light2 .ray{left:65%}.hero-content{position:relative;z-index:1;text-align:center;max-width:900px;padding:2rem;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-title{margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.5rem}.title-main{font-size:clamp(3.5rem,10vw,7rem);font-weight:900;background:linear-gradient(135deg,#fff,#a855f7,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;line-height:1;text-shadow:0 0 80px rgba(168,85,247,.5)}.title-tagline{font-size:clamp(1.2rem,3vw,1.8rem);font-weight:300;color:#ffffffb3;letter-spacing:.05em}.hero-description{font-size:clamp(1rem,2vw,1.25rem);color:#fffc;max-width:700px;margin:0 auto 2.5rem;line-height:1.6}.hero-cta{background:linear-gradient(135deg,#a855f7,#3b82f6);color:#fff;border:none;padding:1rem 2.5rem;font-size:1.2rem;font-weight:600;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 40px #a855f766;display:inline-flex;align-items:center;gap:.75rem}.hero-cta:hover{transform:translateY(-2px);box-shadow:0 15px 50px #a855f799}.cta-arrow{font-size:1.5rem;animation:bounce 2s infinite;margin-block-end:5px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.input-section{position:relative;background:linear-gradient(180deg,#000,#0a0a0a);padding:5rem 2rem;min-height:100vh;display:flex;align-items:center;justify-content:center}.input-container{max-width:1000px;width:100%;margin:0 auto}.input-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:#fff;margin:0 0 1rem;text-align:center}.input-subtitle{font-size:1.25rem;color:#ffffffb3;text-align:center;margin:0 0 4rem;line-height:1.6;max-width:600px;margin-left:auto;margin-right:auto}.input-wrapper{background:#ffffff08;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:32px;padding:3rem;margin-bottom:4rem;box-shadow:0 30px 80px #0006}.story-input{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;font-size:1.25rem;color:#fff;font-family:inherit;resize:vertical;transition:all .3s ease;min-height:160px;line-height:1.6}.story-input::-moz-placeholder{color:#fff6}.story-input::placeholder{color:#fff6}.story-input:focus{outline:none;border-color:#a855f7;background:#ffffff1a;box-shadow:0 0 0 3px #a855f71a}.name-input{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem 1.5rem;font-size:1rem;color:#fff;font-family:inherit;transition:all .3s ease;margin-top:1rem}.name-input::-moz-placeholder{color:#fff6}.name-input::placeholder{color:#fff6}.name-input:focus{outline:none;border-color:#a855f7;background:#0006;box-shadow:0 0 0 2px #a855f71a}.name-input-wrapper{position:relative;margin-top:1rem;display:flex;align-items:center}.name-input-wrapper .name-input{flex:1;margin-top:0}.optional-label{position:absolute;right:1.5rem;color:#fff6;font-size:.875rem;pointer-events:none;font-style:italic}.submit-button{width:100%;background:linear-gradient(135deg,#a855f7,#3b82f6);color:#fff;border:none;padding:1rem 2rem;font-size:1.125rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s ease;margin-top:1rem;box-shadow:0 10px 30px #a855f74d}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 40px #a855f780}.submit-button:disabled{opacity:.5;cursor:not-allowed}.examples-section{text-align:center}.examples-label{color:#ffffff80;font-size:.875rem;text-transform:uppercase;letter-spacing:.1em;margin:0 0 1.5rem}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.example-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#ffffffe6;padding:1rem 1.5rem;border-radius:12px;font-size:.95rem;cursor:pointer;transition:all .3s ease;text-align:left;line-height:1.5}.example-button:hover{background:#a855f71a;border-color:#a855f7;transform:translateY(-2px);box-shadow:0 10px 30px #a855f733}@media(max-width:768px){.hero-section{height:100svh}.input-section{padding:3rem 1rem}.input-wrapper{padding:1.5rem}.examples-grid{grid-template-columns:1fr}.story-input{min-height:215px}}.chroma-grid{position:relative;width:100%;height:100%;display:grid;grid-template-columns:repeat(var(--cols, 3),280px);grid-auto-rows:auto;justify-content:center;gap:1.5rem;max-width:1600px;margin:0 auto;padding:2rem;box-sizing:border-box;--x: 50%;--y: 50%;--r: 220px}@media(max-width:1124px){.chroma-grid{grid-template-columns:repeat(auto-fit,minmax(320px,320px));gap:.5rem;padding:.5rem}}@media(max-width:480px){.chroma-grid{grid-template-columns:320px;gap:.75rem;padding:1rem}}.chroma-card{position:relative;display:flex;flex-direction:column;width:280px;height:auto;border-radius:20px;overflow:hidden;border:1px solid #333;transition:border-color .3s ease;background:var(--card-gradient);--mouse-x: 50%;--mouse-y: 50%;--spotlight-color: rgba(255, 255, 255, .3)}.chroma-card:hover{border-color:var(--card-border)}.chroma-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mouse-x) var(--mouse-y),var(--spotlight-color),transparent 70%);pointer-events:none;opacity:0;transition:opacity .5s ease;z-index:2}.chroma-card:hover:before,.chroma-card.speaking:before{opacity:1}.chroma-card.speaking{border-color:var(--card-border);box-shadow:0 0 40px var(--card-border),0 8px 32px #0006;z-index:10}.chroma-card.speaking:before{opacity:1;background:radial-gradient(circle at 50% 50%,var(--spotlight-color),transparent 70%)}.chroma-img-wrapper{position:relative;z-index:1;flex:1;padding:10px;box-sizing:border-box;background:transparent;transition:background .3s ease}.chroma-img-wrapper img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:10px;display:block}.chroma-info{position:relative;z-index:1;padding:.75rem 1rem;color:#fff;font-family:system-ui,sans-serif;display:grid;grid-template-columns:1fr auto;row-gap:.25rem;-moz-column-gap:.75rem;column-gap:.75rem}.chroma-info .role,.chroma-info .handle{color:#aaa}.chroma-overlay{position:absolute;inset:0;pointer-events:none;z-index:3;backdrop-filter:grayscale(1) brightness(.78);-webkit-backdrop-filter:grayscale(1) brightness(.78);background:#0000;mask-image:radial-gradient(circle var(--r) at var(--x) var(--y),transparent 0%,transparent 15%,rgba(0,0,0,.1) 30%,rgba(0,0,0,.22) 45%,rgba(0,0,0,.35) 60%,rgba(0,0,0,.5) 75%,rgba(0,0,0,.68) 88%,white 100%);-webkit-mask-image:radial-gradient(circle var(--r) at var(--x) var(--y),transparent 0%,transparent 15%,rgba(0,0,0,.1) 30%,rgba(0,0,0,.22) 45%,rgba(0,0,0,.35) 60%,rgba(0,0,0,.5) 75%,rgba(0,0,0,.68) 88%,white 100%)}.chroma-fade{position:absolute;inset:0;pointer-events:none;z-index:4;backdrop-filter:grayscale(1) brightness(.78);-webkit-backdrop-filter:grayscale(1) brightness(.78);background:#0000;mask-image:radial-gradient(circle var(--r) at var(--x) var(--y),white 0%,white 15%,rgba(255,255,255,.9) 30%,rgba(255,255,255,.78) 45%,rgba(255,255,255,.65) 60%,rgba(255,255,255,.5) 75%,rgba(255,255,255,.32) 88%,transparent 100%);-webkit-mask-image:radial-gradient(circle var(--r) at var(--x) var(--y),white 0%,white 15%,rgba(255,255,255,.9) 30%,rgba(255,255,255,.78) 45%,rgba(255,255,255,.65) 60%,rgba(255,255,255,.5) 75%,rgba(255,255,255,.32) 88%,transparent 100%);opacity:1;transition:opacity .25s ease}.chroma-gallery{position:relative;width:100%;height:450px;perspective:1000px;overflow:hidden;display:flex;justify-content:center;align-items:flex-start;margin-top:0}.chroma-gallery-track{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:flex-start}.chroma-gallery-card{position:absolute;width:245px;height:auto;background:var(--card-gradient);border-radius:20px;border:1px solid #333;transition:all .6s cubic-bezier(.23,1,.32,1);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 30px #00000080;left:50%;top:2rem;transform-origin:center center}.chroma-gallery-card.active{border-color:var(--card-border);box-shadow:0 0 40px var(--card-border),0 20px 50px #0009;z-index:100}.chroma-gallery-card .chroma-img-wrapper{flex:1;padding:10px;box-sizing:border-box}.chroma-gallery-card img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:10px;display:block;aspect-ratio:3/4}.chroma-gallery-card .chroma-info{padding:1rem;color:#fff}.chroma-gallery-card .name{font-size:1.25rem;font-weight:700;margin:0}.chroma-gallery-card .role{color:#aaa;font-size:.9rem;margin:.25rem 0 0}.chroma-gallery-card .handle{color:#666;font-size:.8rem;display:block;margin-top:.25rem}.volume-control-wrapper{position:fixed;bottom:2rem;right:2rem;z-index:10}.volume-slider{position:relative;cursor:pointer;display:inline-flex;flex-direction:row-reverse;align-items:center;border-radius:12px;padding:1rem}.volume-icon{display:inline-block;vertical-align:top;margin-right:15px;color:#ffffffb3;width:25px;height:auto;position:absolute;left:12px;pointer-events:none}.volume-level{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:50px;background:#525252;overflow:hidden;border-radius:9px;transition:height .1s;cursor:pointer;transform:rotate(270deg)}.volume-level::-webkit-slider-thumb{-webkit-appearance:none;width:0;height:0;box-shadow:-200px 0 0 200px #fff}.volume-level::-moz-range-thumb{width:0;height:0;border-radius:0;border:none;box-shadow:-200px 0 0 200px #fff}.script-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0009;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.script-overlay-content{background:linear-gradient(135deg,#d4af37,#f4e4c1);border-radius:20px;width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;opacity:.75}.script-overlay-header{padding:1.5rem;border-bottom:2px solid rgba(0,0,0,.1);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.script-overlay-header h2{margin:0;font-size:1.5rem;color:#2c2c2c;font-weight:700}.close-overlay-btn{background:transparent;border:none;font-size:2rem;color:#2c2c2c;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;line-height:1;padding:0}.close-overlay-btn:hover{background:#0000001a}.script-overlay-body{padding:1.5rem;overflow-y:auto;flex:1;color:#2c2c2c;scrollbar-width:none;-ms-overflow-style:none}.script-overlay-body::-webkit-scrollbar{display:none}.script-scenario{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid rgba(0,0,0,.1)}.scenario-label{margin:0 0 .5rem;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#0009}.scenario-value{margin:0;font-size:1.1rem;font-style:italic;line-height:1.6;color:#2c2c2c}.script-dialogue{display:flex;flex-direction:column;gap:1.5rem}.dialogue-line{display:flex;flex-direction:column;gap:.25rem}.character-name{font-weight:700;font-size:1rem;color:#1a1a1a;text-transform:uppercase;letter-spacing:.5px}.dialogue-text{font-size:.95rem;line-height:1.6;color:#1a1a1a;padding-left:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.theatre-page{position:fixed;top:0;left:0;width:100%;height:100dvh;max-height:100dvh;overflow:hidden;padding:3rem 2rem;animation:slideUp .7s cubic-bezier(.16,1,.3,1);--angle: 90deg;background:#0a0a0a;color:#e0e0e0;box-sizing:border-box}.back-arrow-btn{position:fixed;top:2rem;left:2rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#ffffffb3;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .3s ease;font-family:inherit;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-arrow-btn:hover{background:#ffffff14;border-color:#fff3;color:#fff;transform:translate(-4px)}.new-scenario-btn{position:fixed;top:2rem;right:2rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#ffffffb3;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .3s ease;font-family:inherit;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.new-scenario-btn:hover{background:#ffffff14;border-color:#fff3;color:#fff;transform:translate(4px)}.theatre-lights{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:2;animation:fadeIn .8s ease}.theatre-lights .ray{clip-path:polygon(0% 40%,100% 0%,100% 100%,0% 60%);transition:4s;transform:translateY(-50%) translate(-50%) rotate(var(--angle)) translateY(50%) translate(50%) translateY(-50%);position:absolute;top:-50px;width:800px;height:150px;background:linear-gradient(.25turn,#ffff0080,#ffff6400)}.theatre-lights .light1,.theatre-lights .light2{position:absolute;top:0;width:100%;height:100%;pointer-events:none;opacity:.3}.theatre-lights .light1{left:-15%;animation-duration:10s;animation-name:wave1;animation-iteration-count:infinite}.theatre-lights .light1 .ray{left:35%}.theatre-lights .light2{right:-15%;animation-duration:7s;animation-name:wave2;animation-iteration-count:infinite}.theatre-lights .light2 .ray{left:65%}@keyframes wave1{0%{--angle: 80deg}50%{--angle: 105deg}to{--angle: 55deg}}@keyframes wave2{0%{--angle: 100deg}50%{--angle: 125deg}to{--angle: 75deg}}.theatre-header{max-width:1000px;margin:4rem auto 1rem;text-align:center;position:relative;z-index:1}.scenario-text{font-size:1.35rem;color:#ccc;margin:0 1rem 1rem;line-height:1.5;font-style:italic}.status-line{margin-top:1.5rem;margin-bottom:1rem}.start-controls{display:flex;flex-direction:column;align-items:center;gap:1rem;transition:opacity 0s,max-height .4s ease,margin .4s ease,padding .4s ease;max-height:200px;opacity:1;overflow:hidden}.start-controls.hidden{opacity:0;max-height:0;margin:0;padding:0;pointer-events:none}.status{font-size:.95rem;color:#888;display:inline-flex;align-items:center;gap:.5rem}.status:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:#8b5cf6;animation:pulse 2s infinite}.status-ready{font-size:.95rem;color:#10b981;font-weight:500}.grid-wrapper{max-width:1600px;margin:0 auto;padding-bottom:3rem;position:relative;z-index:1}.play-story-btn{display:block;margin:0 auto;padding:1.2rem 3rem;font-size:1.15rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:14px;cursor:pointer;transition:all .3s ease;font-family:inherit;box-shadow:0 4px 16px #10b98140;position:relative;z-index:1}.play-story-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.play-story-btn:active{transform:translateY(0)}.mobile-drawer{display:none;position:fixed;top:0;left:0;right:0;z-index:100}.drawer-toggle{width:100%;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-bottom:1px solid rgba(255,255,255,.1);color:#ffffffe6;font-size:1rem;font-weight:600;cursor:pointer;font-family:inherit;text-align:left;padding:1rem 1rem 1rem 1.5rem}.drawer-content{max-height:0;overflow:hidden;background:#000000f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);transition:max-height .3s ease}.drawer-content.open{max-height:300px}.drawer-action-btn{width:100%;padding:1rem 1.5rem;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:#ffffffe6;font-size:1rem;font-weight:500;cursor:pointer;font-family:inherit;text-align:left;transition:all .2s ease}.drawer-action-btn:hover{background:#ffffff0d;color:#fff}.drawer-action-btn:last-child{border-bottom:none}.side-actions{position:fixed;right:2rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:1rem;z-index:10}.side-action-btn{width:60px;height:60px;border-radius:50%;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .3s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00000080;background:#ffffff14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff}.side-action-btn svg{width:24px;height:24px}.side-action-btn:hover{transform:scale(1.1);box-shadow:0 8px 24px #fff3;background:#ffffff26;border-color:#fff3}.drawer-icon-btn{display:flex;align-items:center;gap:.75rem}.drawer-icon-btn svg{width:20px;height:20px}.error-text{font-size:.9rem;color:#ef4444;margin-top:.75rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.mobile-top-actions{display:none;position:fixed;top:0;left:0;right:0;padding:1rem 2rem;z-index:100;justify-content:space-between;align-items:center;pointer-events:none}.mobile-top-actions .icon-btn{pointer-events:auto;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem}.mobile-top-actions .right-actions{display:flex;gap:.5rem}.mobile-bottom-controls{display:none;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:100;gap:1.5rem;align-items:center;background:#0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:.75rem 2rem;border-radius:2rem;border:1px solid rgba(255,255,255,.1)}.mobile-bottom-controls .control-btn{background:transparent;border:none;color:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.mobile-bottom-controls .control-btn svg{width:24px;height:24px}.mobile-bottom-controls .main-control{color:#fff;background:#ffffff1a;width:50px;height:50px;border-radius:50%}.mobile-bottom-controls .main-control svg{width:28px;height:28px;fill:currentColor}.mobile-new-scenario-btn{display:none;position:fixed;bottom:2rem;right:1.5rem;z-index:100;background:#0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:.75rem 1rem;color:#fffc;cursor:pointer;flex-direction:column;align-items:center;gap:2px;transition:all .2s}.mobile-new-scenario-btn .icon{font-size:1.2rem;font-weight:700;line-height:1}.mobile-new-scenario-btn .label{font-size:.65rem;font-weight:500;opacity:.7;white-space:nowrap;letter-spacing:.02em}@media(max-width:1024px){.desktop-only{display:none!important}.mobile-top-actions,.mobile-bottom-controls,.mobile-new-scenario-btn{display:flex}.theatre-header{margin-top:4rem;margin-bottom:0}.theatre-page{padding:1rem 0}.grid-wrapper{height:70vh;display:flex;align-items:center}}*{margin:0;padding:0;box-sizing:border-box}.app{width:100%;min-height:100vh;background:#0a0a0a;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;position:relative}
