.scenario-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f3f4f6;color:#111827}.card{width:min(720px,100%);background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 10px 30px #0f172a14;overflow:hidden;transition:box-shadow .2s}.card:hover{box-shadow:0 14px 34px #0f172a1f}.card__head{padding:28px 28px 20px;border-bottom:1px solid #e5e7eb}.card__head h1{margin:0;font-size:24px;font-weight:600;letter-spacing:-.3px;color:#111827}.sub{margin:8px 0 0;color:#6b7280;font-size:14px;line-height:1.5}.card__body{padding:28px}.form-grid{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr;gap:20px}@media (min-width: 640px){.form-row{grid-template-columns:1fr 1fr}}.field{display:flex;flex-direction:column}.field label{display:block;font-size:13px;font-weight:500;color:#6b7280;margin:0 0 8px}.input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;outline:none;background:#fff;color:#111827;font-size:15px;transition:border-color .15s,box-shadow .15s,background .15s}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb24;background:#fff}.input:read-only{opacity:.7;cursor:not-allowed}.input[type=number]{-moz-appearance:textfield}.input::-webkit-outer-spin-button,.input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hint{color:#6b7280;font-size:12px;margin-top:6px;line-height:1.4}.actions-field{display:flex;flex-direction:column;justify-content:flex-end}.actions{display:flex;gap:10px;margin-top:8px}.btn{border:0;cursor:pointer;-webkit-user-select:none;user-select:none;padding:12px 20px;border-radius:8px;font-weight:500;font-size:14px;transition:all .15s;flex:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#2563eb;color:#fff;box-shadow:0 2px 8px #2563eb40}.btn-primary:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #2563eb52}.btn-primary:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 4px #2563eb33}.btn-secondary{background:#f6f7fb;color:#111827;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#eef2f7;border-color:#cbd5e1}.btn-secondary:active:not(:disabled){transform:translateY(1px)}.error-message{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#b91c1c;font-size:14px;margin-top:8px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#11182759;z-index:50}.overlay__box{display:flex;flex-direction:column;align-items:center;gap:16px;background:#fff;border:1px solid #e5e7eb;color:#111827;padding:32px 40px;border-radius:12px;box-shadow:0 20px 60px #0f172a33}.loader{width:48px;height:48px;border-radius:50%;border:3px solid #d1d5db;border-top-color:#2563eb;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.overlay__text{font-size:14px;color:#6b7280;font-weight:500}.script-page{min-height:100vh;background:#f3f4f6;color:#111827;padding:16px}.script-toolbar{max-width:1200px;margin:0 auto 16px;background:#fff;border:1px solid #e6e8ee;border-radius:14px;padding:10px 12px;display:flex;justify-content:space-between;gap:10px;align-items:center;position:sticky;top:12px;z-index:20;box-shadow:0 6px 16px #0f172a0f}.script-toolbar__left{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.toolbar-btn{background:#f6f7fb;border:1px solid #d7dce7;border-radius:999px;color:#111827;padding:7px 13px;cursor:pointer;font-weight:500;font-size:14px}.toolbar-btn.primary{background:#2563eb;color:#fff;border-color:#2563eb}.toolbar-btn.danger{background:#fff;border-color:#fecaca;color:#b91c1c}.script-toolbar__meta{color:#6b7280;font-size:14px;white-space:nowrap}.toolbar-separator{width:1px;height:24px;background:#d8dde8;margin:0 2px}@media (max-width: 980px){.script-toolbar{position:static;box-shadow:none;align-items:stretch;flex-direction:column}.script-toolbar__meta{white-space:normal;padding-top:0}.toolbar-separator{display:none}}.script-layout{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 980px){.script-layout{grid-template-columns:1fr 1fr}}.script-panel,.json-panel{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px}.script-summary{display:flex;gap:14px;flex-wrap:wrap;color:#6b7280;margin:8px 0 14px}.script-summary strong{color:#111827;margin-left:6px}.meta-input{display:block;margin-top:6px;border:1px solid #d1d5db;border-radius:10px;padding:8px 10px;min-width:240px}.script-error{border:1px solid #5b2323;background:#2e1616;color:#ffb4b4;border-radius:10px;padding:10px;margin-bottom:12px}.scene-card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;margin-bottom:10px;background:#f9fafb}.scene-head{display:flex;align-items:center;justify-content:space-between}.shot-row{display:flex;justify-content:flex-start;gap:8px;border-top:1px dashed #d1d5db;padding-top:8px;margin-top:8px}.shot-box{margin-top:10px;border:1px dashed #d1d5db;border-radius:12px;padding:12px;background:#fff}.field-grid{display:grid;gap:10px}.field-grid.two{grid-template-columns:1fr}@media (min-width: 900px){.field-grid.two{grid-template-columns:1fr 1fr}}.field-label{display:block;font-size:13px;color:#6b7280;margin-bottom:4px}.field-input,.field-textarea{width:100%;border:1px solid #d1d5db;border-radius:10px;padding:10px;font-size:14px;background:#fff}.field-textarea{min-height:72px;resize:vertical}.characters-title{margin-top:10px;margin-bottom:8px}.char-box{border:1px solid #e5e7eb;border-radius:10px;padding:10px;margin-bottom:8px;background:#fff}.asset-preview-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px}.asset-preview-label{font-size:13px;color:#6b7280}.asset-thumb{width:76px;height:76px;border-radius:10px;object-fit:cover;border:1px solid #d1d5db;background:#f3f4f6}.asset-thumb-location{width:120px;height:68px}.asset-placeholder{font-size:12px;color:#9ca3af;border:1px dashed #d1d5db;border-radius:10px;padding:8px 10px}.json-input{width:100%;min-height:500px;background:#111;border:1px solid var(--border);border-radius:10px;color:#f5f5f5;padding:12px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.json-panel__hint{color:#6b7280;margin-top:8px;font-size:13px}.back-link{display:inline-block;margin-top:10px;color:#d8d8d8}.prompts-page{min-height:100vh;background:#f3f4f6;padding:16px;color:#111827;position:relative}.prompts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#11182773;z-index:60}.prompts-overlay__box{background:#fff;color:#111827;border:1px solid #e5e7eb;border-radius:12px;padding:18px 24px;display:flex;align-items:center;gap:12px;box-shadow:0 20px 50px #0f172a33}.prompts-loader{width:22px;height:22px;border-radius:50%;border:2px solid #d1d5db;border-top-color:#2563eb;animation:prompts-spin .8s linear infinite}.prompts-overlay__text{font-size:14px}@keyframes prompts-spin{to{transform:rotate(360deg)}}.prompts-toolbar{max-width:1200px;margin:0 auto 12px;display:flex;gap:8px;background:#fff;border:1px solid #e6e8ee;border-radius:14px;padding:10px 12px;box-shadow:0 6px 16px #0f172a0f}.toolbar-btn.primary{background:#2563eb;border-color:#2563eb;color:#fff}.prompts-layout{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:12px}@media (min-width: 980px){.prompts-layout{grid-template-columns:1fr 1fr}}.prompts-list,.prompts-json{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px}.prompts-empty{color:#6b7280;margin-top:8px}.json-input{width:100%;min-height:520px;border:1px solid #d1d5db;border-radius:10px;padding:10px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:#111;color:#f5f5f5}.prompt-card{border:1px solid #e5e7eb;border-radius:10px;padding:12px;margin-top:10px;background:#f9fafb}.prompt-meta{display:flex;gap:8px;align-items:center;color:#6b7280;font-size:13px;margin-bottom:8px}.prompt-text{color:#111827;white-space:pre-wrap}.refs-row{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.ref-item{display:flex;flex-direction:column;gap:4px;align-items:center}.ref-thumb{width:56px;height:56px;border-radius:8px;border:1px solid #d1d5db;object-fit:cover;background:#f3f4f6}.ref-label{font-size:11px;color:#6b7280;max-width:72px;text-align:center;line-height:1.2}.prompt-regenerate-btn{margin-left:auto;padding:4px 10px;font-size:12px}.generated-image{margin-top:10px;width:100%;border-radius:10px;border:1px solid #d1d5db;object-fit:cover}.scripts-page{min-height:100vh;padding:16px 24px 24px;background:#f3f4f6;color:#111827}.scripts-page .toolbar-btn{background:#f6f7fb;border:1px solid #d7dce7;border-radius:999px;color:#111827;padding:7px 13px;cursor:pointer;font-weight:500;font-size:14px}.scripts-page .toolbar-btn.primary{background:#2563eb;border-color:#2563eb;color:#fff}.scripts-header{max-width:1200px;margin:0 auto 16px;display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e6e8ee;border-radius:14px;padding:12px 14px;box-shadow:0 8px 20px #0f172a14;position:sticky;top:12px;z-index:20}.scripts-header h1{margin:0;font-size:34px;line-height:1.1;font-weight:700}.scripts-header__actions{display:flex;gap:8px;align-items:center}.scripts-list{max-width:1200px;margin:0 auto;display:grid;gap:12px;grid-template-columns:1fr}@media (min-width: 900px){.scripts-list{grid-template-columns:repeat(3,minmax(0,1fr))}}.script-item{background:#fff;border:1px solid #e5e7eb;color:#111827;border-radius:12px;padding:16px;min-height:132px;display:flex;flex-direction:column;justify-content:space-between;text-align:left;cursor:pointer;box-shadow:0 6px 14px #0f172a0f;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease}.script-item:hover{border-color:#cfd6e4;box-shadow:0 14px 28px #0f172a24;transform:translateY(-2px);background:#fcfdff}.script-item__title{font-weight:600;margin-bottom:10px;font-size:20px;line-height:1.2}.script-item__meta{color:#6b7280;font-size:15px;line-height:1.5}.scripts-empty{max-width:1200px;margin:12px auto 18px;color:#6b7280}.scripts-empty.error{color:#b91c1c}@media (max-width: 900px){.scripts-page{padding:12px}.scripts-header{position:static}.scripts-header h1{font-size:28px}.scripts-header__actions{flex-wrap:wrap;justify-content:flex-end}}.gallery-page{min-height:100vh;background:#f3f4f6;padding:16px 24px 24px;color:#111827}.gallery-header{max-width:1400px;margin:0 auto 16px;display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e6e8ee;border-radius:14px;padding:12px 14px;box-shadow:0 8px 20px #0f172a14}.gallery-header h1{margin:0;font-size:30px}.gallery-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media (min-width: 1100px){.gallery-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width: 1500px){.gallery-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.gallery-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 6px 14px #0f172a0f}.gallery-image-btn{border:0;padding:0;width:100%;background:transparent;cursor:zoom-in}.gallery-image{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block}.gallery-meta{padding:8px 10px;font-size:13px;color:#6b7280}.gallery-empty{max-width:1400px;margin:12px auto;color:#6b7280}.gallery-empty.error{color:#b91c1c}.gallery-sentinel{width:100%;height:8px}.toolbar-btn{background:#f6f7fb;border:1px solid #d7dce7;border-radius:999px;color:#111827;padding:7px 13px;cursor:pointer;font-size:14px;font-weight:500}.toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.gallery-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ac7;display:flex;align-items:center;justify-content:center;z-index:80;padding:20px}.gallery-lightbox__content{width:min(1200px,100%);background:#fff;border-radius:14px;border:1px solid #e5e7eb;padding:12px;position:relative}.gallery-lightbox__close{position:absolute;right:10px;top:8px;border:1px solid #d7dce7;background:#f6f7fb;width:34px;height:34px;border-radius:999px;font-size:22px;line-height:1;cursor:pointer}.gallery-lightbox__image{width:100%;max-height:78vh;object-fit:contain;border-radius:10px;background:#f3f4f6}.gallery-lightbox__meta{margin-top:8px;color:#6b7280;font-size:14px}.gallery-lightbox__actions{margin-top:10px;display:flex;justify-content:center;gap:10px;align-items:center}.gallery-lightbox__counter{color:#6b7280;min-width:80px;text-align:center}:root{--bg: #0f0f0f;--bg-secondary: #1a1a1a;--card: #2a2a2a;--card-hover: #333333;--text: #ffffff;--text-muted: #a0a0a0;--border: #404040;--primary: #ffffff;--primary-hover: #e0e0e0;--ring: rgba(255, 255, 255, .1);--radius: 12px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg);color:var(--text);line-height:1.5}#root{height:100%}
