:root{--cyan: #00ffff;--cyan-dim: rgba(0, 255, 255, .5);--cyan-subtle: rgba(0, 255, 255, .15);--cyan-ghost: rgba(0, 255, 255, .08);--bg-deep: #080a10;--bg-panel: rgba(12, 12, 20, .95);--bg-card: rgba(255, 255, 255, .05);--bg-card-hover: rgba(255, 255, 255, .09);--text: #eeeef4;--text-dim: rgba(255, 255, 255, .65);--text-ghost: rgba(255, 255, 255, .35);--red: #ff3344;--orange: #ff8844;--green: #44ff88;--border: rgba(0, 255, 255, .18);--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", "SF Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg-deep);color:var(--text);font-family:var(--font);overflow:hidden;height:100vh;width:100vw}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--cyan-subtle);border-radius:2px}#top-bar{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#000000f2;border-bottom:1px solid var(--border);position:fixed;top:0;left:0;right:0;z-index:100}.top-left{display:flex;align-items:center;gap:16px}.logo{font-size:20px;font-weight:700;letter-spacing:6px;color:var(--cyan);text-shadow:0 0 20px rgba(0,255,255,.3)}.mode-label{font-size:10px;font-weight:600;letter-spacing:3px;color:var(--cyan-dim);padding:3px 10px;border:1px solid var(--cyan-subtle);border-radius:3px}.top-center{position:absolute;left:50%;transform:translate(-50%)}.mode-tabs{display:flex;gap:2px;background:#ffffff08;border-radius:6px;padding:3px}.mode-tab{padding:6px 20px;background:transparent;border:none;color:var(--text-dim);font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:2px;cursor:pointer;border-radius:4px;transition:all .2s}.mode-tab:hover{color:var(--text);background:#ffffff0d}.mode-tab.active{color:var(--cyan);background:#00ffff14}.top-right{display:flex;align-items:center}.rec-indicator{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;color:var(--red);letter-spacing:1px}.rec-dot{width:8px;height:8px;background:var(--red);border-radius:50%;animation:rec-pulse 1s ease-in-out infinite}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.3}}.mode-screen{display:none;position:fixed;top:52px;left:0;right:0;bottom:0}.mode-screen.active{display:flex;flex-direction:column}#mode-direct.active,#mode-review.active{flex-direction:row}#quick-scene-bar{padding:20px 24px 0;flex-shrink:0}.quick-scene-inner{background:linear-gradient(135deg,#00ffff0d,#6400ff0a);border:1px solid var(--border);border-radius:10px;padding:18px 20px}.quick-scene-label{font-size:10px;font-weight:700;letter-spacing:4px;color:var(--cyan);margin-bottom:12px;text-shadow:0 0 10px rgba(0,255,255,.2)}.quick-scene-input-row{display:flex;gap:12px;align-items:flex-start}.quick-scene-textarea{flex:1;padding:12px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;resize:none;height:52px;transition:border-color .2s}.quick-scene-textarea:focus{border-color:var(--cyan-subtle)}.quick-scene-textarea::placeholder{color:var(--text-ghost)}.quick-scene-btn{padding:14px 28px;background:linear-gradient(135deg,#00ffff26,#00ffff14);border:1px solid var(--cyan);border-radius:8px;color:var(--cyan);font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:3px;cursor:pointer;transition:all .3s;text-shadow:0 0 8px rgba(0,255,255,.2);white-space:nowrap;flex-shrink:0}.quick-scene-btn:hover{background:linear-gradient(135deg,#00ffff40,#00ffff26);box-shadow:0 0 40px #00ffff26}.quick-scene-btn:disabled{opacity:.4;cursor:wait}.quick-scene-status{margin-top:10px;font-size:11px;font-weight:500;letter-spacing:1px;min-height:16px;color:var(--cyan-dim)}.quick-scene-status.success{color:var(--green)}.quick-scene-status.error{color:var(--red)}.build-layout{display:flex;width:100%;flex:1;min-height:0}.build-left,.build-right{flex:1;padding:24px;overflow-y:auto}.build-left{border-right:1px solid var(--border)}.section-header{font-size:11px;font-weight:700;letter-spacing:4px;color:var(--cyan);margin-bottom:20px;text-shadow:0 0 10px rgba(0,255,255,.2)}.sub-header{font-size:9px;font-weight:600;letter-spacing:3px;color:var(--cyan-dim);margin-bottom:12px;margin-top:20px}.world-preview-container{position:relative;width:100%;aspect-ratio:16/9;border-radius:8px;overflow:hidden;border:1px solid var(--border);margin-bottom:20px;background:#000}.world-preview-container canvas{width:100%!important;height:100%!important}.world-preview-label{position:absolute;bottom:12px;left:12px;font-size:10px;font-weight:600;letter-spacing:3px;color:var(--cyan);background:#000000b3;padding:4px 10px;border-radius:3px}.env-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.env-card[data-env=ai-custom]{grid-column:1 / -1;background:linear-gradient(135deg,#00ffff0a,#6400ff0a);border-style:dashed}.env-card[data-env=ai-custom].selected{border-style:solid;box-shadow:0 0 25px #00ffff1f,0 0 25px #6400ff14}.env-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px;cursor:pointer;transition:all .25s;text-align:center}.env-card:hover{background:var(--bg-card-hover);border-color:#00ffff40}.env-card.selected{border-color:var(--cyan);box-shadow:0 0 20px #00ffff26,inset 0 0 20px #00ffff0d}.env-icon{font-size:28px;margin-bottom:8px}.env-name{font-size:9px;font-weight:600;letter-spacing:2px;color:var(--text-dim)}.env-card.selected .env-name{color:var(--cyan)}.ai-world-panel{margin-top:16px;margin-bottom:8px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;animation:portrait-fade-in .3s ease-out}.ai-world-textarea{width:100%;padding:10px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;resize:none;height:72px;margin-bottom:10px;transition:border-color .2s}.ai-world-textarea:focus{border-color:var(--cyan-subtle)}.ai-world-textarea::placeholder{color:var(--text-ghost)}.ai-world-source-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.ai-world-source-label{font-size:9px;font-weight:600;letter-spacing:2px;color:var(--text-dim)}.ai-world-source-toggle{display:flex;gap:2px;background:#ffffff08;border-radius:5px;padding:2px}.source-option{padding:5px 12px;background:transparent;border:none;color:var(--text-dim);font-family:var(--font);font-size:9px;font-weight:600;letter-spacing:1px;cursor:pointer;border-radius:4px;transition:all .2s}.source-option:hover{color:var(--text);background:#ffffff0d}.source-option.active{color:var(--cyan);background:#00ffff1a}.ai-world-gen-btn{width:100%;padding:12px;background:linear-gradient(135deg,#00ffff1f,#00ffff0f);border:1px solid var(--cyan);border-radius:6px;color:var(--cyan);font-family:var(--font);font-size:11px;font-weight:700;letter-spacing:3px;cursor:pointer;transition:all .3s;text-shadow:0 0 8px rgba(0,255,255,.2)}.ai-world-gen-btn:hover{background:linear-gradient(135deg,#00ffff38,#00ffff1f);box-shadow:0 0 30px #00ffff26}.ai-world-gen-btn:disabled{opacity:.4;cursor:not-allowed}.ai-world-status{margin-top:10px;font-size:11px;font-weight:500;letter-spacing:1px;min-height:16px}.ai-world-status.loading{color:var(--cyan-dim);animation:rec-pulse 1.5s ease-in-out infinite}.ai-world-status.success{color:var(--green)}.ai-world-status.error{color:var(--red)}.slider-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.slider-row label{font-size:9px;font-weight:600;letter-spacing:2px;color:var(--text-dim);width:80px;flex-shrink:0}.mood-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:#ffffff14;border-radius:2px;outline:none}.mood-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--cyan);cursor:pointer;box-shadow:0 0 8px #0ff6}.slider-val{font-family:var(--mono);font-size:11px;color:var(--cyan-dim);width:28px;text-align:right}.weather-toggles{display:flex;gap:8px}.weather-btn{flex:1;padding:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-family:var(--font);font-size:9px;font-weight:600;letter-spacing:2px;cursor:pointer;transition:all .2s}.weather-btn:hover{background:var(--bg-card-hover)}.weather-btn.selected{border-color:var(--cyan);color:var(--cyan);background:#00ffff0f}.char-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:12px;overflow:hidden;transition:border-color .2s}.char-card:hover{border-color:#00ffff40}.char-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.char-card-header .char-number{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--cyan)}.char-card-header .char-preview-name{font-size:12px;color:var(--text-dim);flex:1;margin-left:12px}.char-delete{background:none;border:none;color:var(--text-dim);font-size:16px;cursor:pointer;padding:4px;line-height:1;transition:color .2s}.char-delete:hover{color:var(--red)}.char-card-body{padding:0 16px 16px;display:none}.char-card.expanded .char-card-body{display:block}.char-field{margin-bottom:12px}.char-field label{display:block;font-size:9px;font-weight:600;letter-spacing:2px;color:var(--text-dim);margin-bottom:6px}.char-field input,.char-field textarea,.char-field select{width:100%;padding:8px 12px;background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-radius:6px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s}.char-field input:focus,.char-field textarea:focus,.char-field select:focus{border-color:var(--cyan-subtle)}.char-field textarea{resize:none;height:56px}.char-field select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2300ffff' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.char-field select option{background:#111;color:var(--text)}.char-field input::placeholder,.char-field textarea::placeholder{color:var(--text-ghost)}.render-mode-toggle{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.render-mode-label{font-size:9px;font-weight:600;letter-spacing:3px;color:var(--text-dim)}.toggle-switch-container{display:flex;gap:2px;background:#ffffff08;border-radius:6px;padding:3px}.toggle-option{padding:6px 16px;background:transparent;border:none;color:var(--text-dim);font-family:var(--font);font-size:10px;font-weight:700;letter-spacing:2px;cursor:pointer;border-radius:4px;transition:all .25s}.toggle-option:hover{color:var(--text);background:#ffffff0d}.toggle-option.active{color:var(--cyan);background:#00ffff1a;box-shadow:0 0 10px #00ffff1a}.char-3d-section{margin-top:10px;display:flex;align-items:center;gap:10px}.generate-3d-btn{flex:1;padding:10px;background:linear-gradient(135deg,#6400ff1f,#00ffff14);border:1px solid rgba(100,0,255,.4);border-radius:6px;color:#b482ffe6;font-family:var(--font);font-size:10px;font-weight:700;letter-spacing:2px;cursor:pointer;transition:all .3s}.generate-3d-btn:hover{background:linear-gradient(135deg,#6400ff38,#00ffff26);border-color:#6400ff99;box-shadow:0 0 20px #6400ff26}.generate-3d-btn.ready{border-color:var(--green);color:var(--green);background:#44ff8814;cursor:default}.generate-3d-btn.generating{border-color:var(--cyan-dim);color:var(--cyan-dim);background:#00ffff0f;animation:rec-pulse 1.5s ease-in-out infinite;cursor:wait}.generate-3d-btn.error{border-color:var(--orange);color:var(--orange)}.model-error-msg{font-size:8px;color:var(--orange);margin-top:4px;display:block;line-height:1.3}.modal-field{margin-bottom:16px}.modal-field-label{display:block;font-size:10px;font-weight:700;letter-spacing:2px;color:var(--cyan-dim);margin-bottom:6px}.modal-field-hint{font-weight:400;letter-spacing:0;color:var(--text-dim);font-size:10px}.model-ready-badge{font-size:8px;font-weight:700;letter-spacing:2px;color:var(--green);padding:4px 8px;border:1px solid rgba(68,255,136,.3);border-radius:4px;background:#44ff880f;white-space:nowrap;animation:portrait-fade-in .5s ease-out}.char-portrait-container{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;margin-bottom:16px;position:relative;background:#0000004d}.char-portrait-img{width:100%;height:100%;object-fit:cover;animation:portrait-fade-in .5s ease-out}@keyframes portrait-fade-in{0%{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.char-portrait-shimmer{width:100%;height:100%;background:linear-gradient(110deg,#ffffff08 30%,#00ffff14,#ffffff08 70%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.char-portrait-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px}.char-portrait-initial{font-size:48px;font-weight:700;color:var(--text-dim);letter-spacing:2px}.regen-portrait-btn{width:100%;padding:10px;margin-top:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:2px;cursor:pointer;transition:all .2s}.regen-portrait-btn:hover{border-color:var(--cyan-subtle);color:var(--cyan);background:var(--cyan-ghost)}.live-char-avatar{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;margin-bottom:8px}.live-char-avatar-fallback{width:100%;aspect-ratio:1;border-radius:6px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--text-dim)}.add-char-btn{width:100%;padding:14px;background:transparent;border:1px dashed var(--cyan-subtle);border-radius:8px;color:var(--cyan-dim);font-family:var(--font);font-size:12px;font-weight:600;letter-spacing:2px;cursor:pointer;transition:all .2s;margin-bottom:24px}.add-char-btn:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-ghost)}.add-char-btn:disabled{opacity:.3;cursor:not-allowed}.scene-setup{margin-bottom:24px}.scene-input{width:100%;padding:10px 14px;background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-radius:6px;color:var(--text);font-family:var(--font);font-size:14px;font-weight:500;outline:none;margin-bottom:10px;transition:border-color .2s}.scene-input:focus{border-color:var(--cyan-subtle)}.scene-input::placeholder{color:var(--text-ghost)}.scene-textarea{width:100%;padding:10px 14px;background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-radius:6px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;resize:none;height:80px;transition:border-color .2s}.scene-textarea:focus{border-color:var(--cyan-subtle)}.scene-textarea::placeholder{color:var(--text-ghost)}.begin-btn{width:100%;padding:16px;background:linear-gradient(135deg,#00ffff26,#00ffff14);border:1px solid var(--cyan);border-radius:8px;color:var(--cyan);font-family:var(--font);font-size:14px;font-weight:700;letter-spacing:4px;cursor:pointer;transition:all .3s;text-shadow:0 0 10px rgba(0,255,255,.3);box-shadow:0 0 30px #00ffff1a}.begin-btn:hover{background:linear-gradient(135deg,#00ffff40,#00ffff26);box-shadow:0 0 50px #0ff3;transform:translateY(-1px)}#direct-canvas-container{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}#direct-canvas-container canvas{width:100%!important;height:100%!important}#scene-title-overlay{position:absolute;top:20px;left:50%;transform:translate(-50%);font-size:14px;font-weight:600;letter-spacing:4px;color:var(--text-dim);z-index:10;pointer-events:none}.direct-sidebar{position:absolute;top:0;left:0;bottom:80px;width:260px;background:linear-gradient(to right,#000000d9,#0000);padding:20px 16px;z-index:10;overflow-y:auto;transition:transform .3s}.direct-sidebar.collapsed{transform:translate(-220px)}.sidebar-toggle{position:absolute;top:12px;right:8px;background:none;border:none;color:var(--text-dim);font-size:14px;cursor:pointer;z-index:11;transition:color .2s}.sidebar-toggle:hover{color:var(--cyan)}.live-char-card{background:#0009;border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .3s}.live-char-card:hover{border-color:#00ffff4d}.live-char-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.live-char-name{font-size:12px;font-weight:700;letter-spacing:2px;color:var(--cyan)}.live-char-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:rec-pulse 2s ease-in-out infinite}.pov-btn{background:none;border:1px solid var(--border);color:var(--text-dim);font-size:14px;padding:2px 6px;border-radius:4px;cursor:pointer;transition:all .2s}.pov-btn:hover{color:var(--cyan);border-color:var(--cyan-subtle)}.live-char-role{font-size:10px;color:var(--text-dim);margin-bottom:6px}.live-char-emotion{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--text-dim);margin-bottom:4px}.emotion-bar{flex:1;height:3px;background:#ffffff0f;border-radius:2px;overflow:hidden}.emotion-fill{height:100%;background:var(--cyan);border-radius:2px;transition:width .5s}.live-char-last{font-size:11px;color:var(--text-dim);font-style:italic;margin-top:6px;line-height:1.4}#director-controls{position:absolute;bottom:0;left:0;right:0;z-index:10;background:linear-gradient(to top,#000000e6,#0000);padding:40px 24px 20px}#action-log{max-height:120px;overflow-y:auto;margin-bottom:12px;padding:0 60px}.log-entry{font-size:12px;margin-bottom:4px;line-height:1.5;opacity:0;animation:fade-in .3s forwards}@keyframes fade-in{to{opacity:1}}.log-entry .log-sender{font-weight:700;letter-spacing:1px;font-size:10px}.log-entry .log-sender.director{color:var(--cyan)}.log-entry .log-sender.character{color:var(--orange)}.log-entry .log-sender.system{color:var(--text-dim)}.log-entry .log-text{color:var(--text);margin-left:4px}.director-input-row{display:flex;align-items:center;gap:16px;justify-content:center}.mic-btn{width:72px;height:72px;border-radius:50%;background:transparent;border:2px solid var(--cyan-subtle);color:var(--cyan);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .3s;flex-shrink:0}.mic-btn:hover{border-color:var(--cyan);box-shadow:0 0 30px #00ffff26}.mic-btn.active{background:#00ffff1f;border-color:var(--cyan);box-shadow:0 0 40px #00ffff4d;animation:pulse-glow 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #00ffff26}50%{box-shadow:0 0 50px #0ff6}}.mic-label{font-size:6px;letter-spacing:1px;font-weight:600}.text-input-wrapper{flex:1;max-width:500px;display:flex;gap:8px}.text-input-wrapper input{flex:1;padding:12px 16px;background:#ffffff14;border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s}.text-input-wrapper input:focus{border-color:var(--cyan-subtle)}.text-input-wrapper input::placeholder{color:var(--text-ghost)}.send-btn{width:44px;height:44px;border-radius:8px;background:#00ffff14;border:1px solid var(--cyan-subtle);color:var(--cyan);font-size:18px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.send-btn:hover{background:#00ffff26;border-color:var(--cyan)}#transcript-display{text-align:center;font-size:13px;color:var(--cyan);margin-top:8px;font-style:italic}.review-layout{display:flex;width:100%;height:100%}.review-preview{flex:1;display:flex;flex-direction:column;background:#000}.review-preview canvas{flex:1;width:100%!important}.review-controls{display:flex;align-items:center;gap:16px;padding:12px 20px;background:#000000f2;border-top:1px solid var(--border)}.review-ctrl-btn{padding:8px 16px;background:#00ffff14;border:1px solid var(--cyan-subtle);border-radius:6px;color:var(--cyan);font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:2px;cursor:pointer;transition:all .2s}.review-ctrl-btn:hover{background:#00ffff26}.review-timeline{flex:1}.timeline-bar{height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;cursor:pointer}.timeline-progress{height:100%;background:var(--cyan);border-radius:2px;width:0%;transition:width .1s linear}.review-time{font-family:var(--mono);font-size:11px;color:var(--text-dim);white-space:nowrap}.review-sidebar{width:340px;flex-shrink:0;background:var(--bg-panel);border-left:1px solid var(--border);display:flex;flex-direction:column;padding:20px}.review-log{flex:1;overflow-y:auto;margin-bottom:20px}.review-log-entry{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px;line-height:1.5}.review-log-entry .rlog-time{font-family:var(--mono);font-size:10px;color:var(--text-dim);margin-right:8px}.review-log-entry .rlog-sender{font-weight:700;font-size:10px;letter-spacing:1px}.review-actions{border-top:1px solid var(--border);padding-top:16px}.export-btn{width:100%;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:2px;cursor:pointer;transition:all .2s;margin-bottom:8px}.export-btn:hover{border-color:var(--cyan-subtle);color:var(--cyan)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:200;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#0c0c14;border:1px solid var(--border);border-radius:12px;padding:32px;width:400px;max-width:90vw}.modal-title{font-size:14px;font-weight:700;letter-spacing:3px;color:var(--cyan);margin-bottom:12px}.modal-desc{font-size:13px;color:var(--text-dim);margin-bottom:20px;line-height:1.5}.modal-input{width:100%;padding:12px 14px;background:#ffffff0a;border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:13px;outline:none;margin-bottom:20px;transition:border-color .2s}.modal-input:focus{border-color:var(--cyan-subtle)}.modal-buttons{display:flex;gap:10px}.modal-btn{flex:1;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-family:var(--font);font-size:12px;font-weight:600;letter-spacing:1px;cursor:pointer;transition:all .2s}.modal-btn:hover{border-color:#fff3;color:var(--text)}.modal-btn.primary{background:#00ffff1a;border-color:var(--cyan);color:var(--cyan)}.modal-btn.primary:hover{background:#0ff3}.hidden{display:none!important}.char-color-0{--char-accent: #00ffff}.char-color-1{--char-accent: #ff8844}.char-color-2{--char-accent: #44ff88}.char-color-3{--char-accent: #ff44aa}.script-toggle-btn{background:#00ffff1a;border:1px solid var(--cyan-dim);color:var(--cyan);padding:8px 14px;border-radius:6px;font-family:var(--mono);font-size:11px;font-weight:600;cursor:pointer;letter-spacing:1px;transition:all .2s;white-space:nowrap}.script-toggle-btn:hover{background:#0ff3}.pause-scene-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:var(--text);padding:8px 14px;border-radius:6px;font-family:var(--mono);font-size:11px;font-weight:600;cursor:pointer;letter-spacing:1px;transition:all .2s;white-space:nowrap}.pause-scene-btn:hover{background:#ffffff26}.pause-scene-btn.paused{background:#44ff8826;border-color:#4f86;color:var(--green)}.cinema-cam-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);color:var(--text-dim);padding:8px 14px;border-radius:6px;font-family:var(--mono);font-size:11px;font-weight:600;cursor:pointer;letter-spacing:1px;transition:all .2s;white-space:nowrap}.cinema-cam-btn:hover{background:#ffffff1a}.cinema-cam-btn.active{background:#ff884426;border-color:var(--orange);color:var(--orange)}.record-video-btn{background:#ff33441a;border:1px solid rgba(255,51,68,.4);color:var(--red);padding:8px 14px;border-radius:6px;font-family:var(--mono);font-size:11px;font-weight:600;cursor:pointer;letter-spacing:1px;transition:all .2s;white-space:nowrap}.record-video-btn:hover{background:#f343}.record-video-btn.recording{background:#ff33444d;border-color:var(--red);animation:rec-pulse 1s ease-in-out infinite}@keyframes rec-pulse{0%,to{box-shadow:0 0 #f346}50%{box-shadow:0 0 12px 4px #ff33444d}}#vr-button{position:absolute!important;bottom:140px!important;left:50%!important;transform:translate(-50%)!important;font-family:var(--font-main)!important;font-size:13px!important;font-weight:600!important;letter-spacing:1px!important;background:#6366f14d!important;border:1px solid var(--indigo)!important;color:var(--indigo)!important;padding:12px 32px!important;border-radius:8px!important;cursor:pointer!important;z-index:100!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important}#vr-button:hover{background:#6366f180!important}.script-panel{position:absolute;right:16px;bottom:140px;width:440px;max-height:60vh;background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;z-index:100;display:flex;flex-direction:column;box-shadow:0 8px 32px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.script-panel-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.script-panel-title{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--cyan);letter-spacing:2px}.script-mode-toggle{display:flex;gap:4px;margin-left:auto}.script-mode-btn{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-dim);padding:4px 10px;border-radius:4px;font-family:var(--mono);font-size:10px;cursor:pointer;transition:all .2s}.script-mode-btn.active{background:var(--cyan-subtle);border-color:var(--cyan-dim);color:var(--cyan)}.script-panel-close{background:none;border:none;color:var(--text-ghost);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.script-panel-close:hover{color:var(--red)}.script-editor{width:100%;min-height:200px;max-height:40vh;background:#0000004d;border:none;color:var(--text);font-family:var(--mono);font-size:13px;line-height:1.7;padding:16px;resize:vertical;outline:none}.script-editor::placeholder{color:var(--text-ghost)}.script-ai-prompt{width:100%;min-height:80px;background:#0000004d;border:none;color:var(--text);font-family:var(--font);font-size:13px;line-height:1.5;padding:16px;resize:vertical;outline:none}.script-ai-prompt::placeholder{color:var(--text-ghost)}.script-ai-gen-btn{width:100%;padding:10px;background:linear-gradient(135deg,#00ffff26,#00ffff0d);border:1px solid var(--cyan-dim);color:var(--cyan);font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:1px;cursor:pointer;transition:all .2s}.script-ai-gen-btn:hover{background:#0ff3}.script-ai-gen-btn:disabled{opacity:.5;cursor:not-allowed}.script-ai-status{padding:8px 16px;font-size:11px;color:var(--text-dim);font-family:var(--mono)}.script-controls{display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--border)}.script-perform-btn{flex:1;padding:10px 20px;background:linear-gradient(135deg,#4f83,#44ff880d);border:1px solid rgba(68,255,136,.4);color:var(--green);font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:1px;cursor:pointer;border-radius:6px;transition:all .2s}.script-perform-btn:hover{background:#44ff8840}.script-perform-btn:disabled{opacity:.5;cursor:not-allowed}.script-perform-btn.performing{background:linear-gradient(135deg,#f843,#ff88440d);border-color:var(--orange);color:var(--orange)}.script-stop-btn{padding:10px 20px;background:#ff334426;border:1px solid rgba(255,51,68,.4);color:var(--red);font-family:var(--mono);font-size:12px;font-weight:600;cursor:pointer;border-radius:6px}.script-progress{font-family:var(--mono);font-size:11px;color:var(--text-dim)}
