@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Noto+Sans+TC:wght@300;400;500;600;700;900&display=swap";:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-tertiary: #1a2236;--bg-card: rgba(17, 24, 39, .8);--bg-card-hover: rgba(26, 34, 54, .9);--bg-glass: rgba(255, 255, 255, .04);--bg-glass-hover: rgba(255, 255, 255, .08);--accent-primary: #2563eb;--accent-primary-light: #3b82f6;--accent-primary-dark: #1d4ed8;--accent-secondary: #f97316;--accent-tertiary: #ea580c;--accent-success: #10b981;--accent-warning: #f59e0b;--accent-danger: #ef4444;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--border-primary: rgba(37, 99, 235, .3);--border-default: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--gradient-primary: #2563eb;--gradient-secondary: #1d4ed8;--gradient-card: rgba(37, 99, 235, .04);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--shadow-glow: 0 0 24px rgba(37, 99, 235, .15);--shadow-glow-strong: 0 0 48px rgba(37, 99, 235, .25);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--font-sans: "Inter", "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes checkmark{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes progress-fill{0%{width:0%}}.animate-fade-in{animation:fadeIn .4s ease forwards}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-container{max-width:1200px;margin:0 auto;padding:1.5rem 1.5rem 6rem;position:relative}.app-container.wide{max-width:1600px;padding:1.5rem 2.5rem 6rem}.app-container:before,.app-container:after{content:"";position:fixed;border-radius:50%;pointer-events:none;z-index:0}.app-container:before{top:-40%;left:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(37,99,235,.06) 0%,transparent 70%)}.app-container:after{bottom:-30%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(249,115,22,.04) 0%,transparent 70%)}.app-header{text-align:center;padding:2.5rem 0 1.5rem;animation:fadeIn .5s ease;position:relative;z-index:1}.app-header.compact{padding:1rem 0 .5rem}.app-header.compact h1{font-size:1.8rem;margin-bottom:.25rem}.app-header.compact p{font-size:.9rem}.app-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.app-logo{display:inline-flex;align-items:center;gap:.5rem}.app-logo-icon{width:40px;height:40px;object-fit:contain}.app-logo-text{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.app-header h1{font-size:2.2rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:.5rem;color:#f1f5f9}.app-header p{font-size:1rem;color:var(--text-secondary);max-width:550px;margin:0 auto}.step-indicator{display:flex;align-items:center;justify-content:center;margin:1rem auto 1.5rem;max-width:600px;position:relative;z-index:1}.step-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:var(--radius-full);transition:all var(--transition-base)}.step-item:hover{background:var(--bg-glass-hover)}.step-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;border:2px solid var(--border-default);background:var(--bg-secondary);color:var(--text-tertiary);transition:all var(--transition-base);flex-shrink:0}.step-item.active .step-number{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:var(--shadow-glow)}.step-item.completed .step-number{background:var(--accent-success);border-color:var(--accent-success);color:#fff}.step-label{font-size:.78rem;font-weight:500;color:var(--text-tertiary)}.step-item.active .step-label{color:var(--text-primary)}.step-item.completed .step-label{color:var(--accent-success)}.step-connector{width:36px;height:2px;background:var(--border-default);flex-shrink:0;transition:background var(--transition-base)}.step-connector.completed{background:var(--accent-success)}.template-selector{position:relative;z-index:1;animation:slideUp .4s ease}.template-card{display:grid;grid-template-columns:1fr 380px;gap:2rem;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:1.5rem 2rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-slow);position:relative;overflow:hidden}.template-card.selected{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.template-info{position:relative;z-index:1}.template-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .75rem;background:#2563eb26;border:1px solid rgba(37,99,235,.3);border-radius:var(--radius-full);font-size:.72rem;font-weight:600;color:var(--accent-primary-light);letter-spacing:.05em;margin-bottom:.75rem}.template-info h2{font-size:1.3rem;font-weight:700;margin-bottom:.25rem}.template-info .description{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem}.template-meta{display:flex;flex-wrap:wrap;gap:.75rem}.meta-item{display:flex;align-items:center;gap:.25rem;padding:.2rem .75rem;background:var(--bg-glass);border-radius:var(--radius-full);font-size:.78rem;color:var(--text-secondary)}.template-video{position:relative;z-index:1;border-radius:var(--radius-lg);overflow:hidden;background:#000;aspect-ratio:16/9}.template-video video{width:100%;height:100%;object-fit:cover}.template-video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity var(--transition-base)}.template-video:hover .template-video-overlay{opacity:1}.play-button{width:56px;height:56px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.4);font-size:1.3rem}.scene-timeline{position:relative;z-index:1;margin-top:2rem}.scene-timeline-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.scene-timeline-header h2{font-size:1.2rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.scenes-progress{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-secondary)}.scenes-progress-bar{width:100px;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.scenes-progress-fill{height:100%;background:var(--accent-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.scene-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;margin-bottom:1rem;transition:all var(--transition-slow);animation:slideUp .4s ease forwards;opacity:0}.scene-card:nth-child(1){animation-delay:.03s}.scene-card:nth-child(2){animation-delay:.06s}.scene-card:nth-child(3){animation-delay:.09s}.scene-card:nth-child(4){animation-delay:.12s}.scene-card:nth-child(5){animation-delay:.15s}.scene-card:nth-child(6){animation-delay:.18s}.scene-card.completed{border-color:#10b9814d}.scene-card-header{padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:background var(--transition-base)}.scene-card-header:hover{background:var(--bg-glass-hover)}.scene-number-badge{width:42px;height:42px;border-radius:var(--radius-md);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:800;color:var(--text-tertiary);flex-shrink:0;transition:all var(--transition-base);border:1px solid var(--border-default)}.scene-card.active .scene-number-badge{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.scene-card.completed .scene-number-badge{background:var(--accent-success);color:#fff;border-color:var(--accent-success)}.scene-card-title{flex:1}.scene-card-title h3{font-size:1rem;font-weight:700;margin-bottom:1px;display:flex;align-items:center;gap:.5rem}.scene-card-title h3 .en-title{font-weight:400;color:var(--text-tertiary);font-size:.85rem}.scene-card-title .scene-meta{font-size:.78rem;color:var(--text-tertiary);display:flex;gap:.75rem}.scene-selected-variant{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:var(--accent-success)}.scene-expand-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);color:var(--text-tertiary);transition:all var(--transition-base);font-size:1.1rem}.scene-card.active .scene-expand-icon{transform:rotate(180deg);color:var(--accent-primary-light)}.scene-card-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.4,0,.2,1)}.scene-card.active .scene-card-body{max-height:1200px}.scene-card-content{padding:0 1.5rem 1.5rem}.scene-goal{padding:.5rem 0;margin-bottom:1rem;font-size:.85rem;color:var(--text-secondary)}.scene-goal strong{color:var(--text-primary)}.scene-main-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.variant-picker-inline{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.variant-chip{position:relative;background:var(--bg-tertiary);border:2px solid var(--border-default);border-radius:var(--radius-lg);padding:.9rem 1rem;cursor:pointer;transition:all var(--transition-base)}.variant-chip:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.variant-chip.selected{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);background:#2563eb14}.variant-chip.selected:after{content:"✓";position:absolute;top:.4rem;right:.5rem;width:22px;height:22px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;animation:checkmark .25s ease}.variant-chip-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem}.variant-letter-sm{width:22px;height:22px;border-radius:4px;background:var(--bg-glass);display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:var(--text-tertiary);flex-shrink:0}.variant-chip.selected .variant-letter-sm{background:#2563eb33;color:var(--accent-primary-light)}.variant-chip-name{font-size:.88rem;font-weight:600;color:var(--text-primary)}.variant-chip-desc{font-size:.78rem;color:var(--text-tertiary);line-height:1.4}.variant-chip-note{margin-top:.3rem;font-size:.72rem;color:var(--text-muted);font-style:italic}.scene-video-preview{border-radius:var(--radius-lg);overflow:hidden;background:#000;aspect-ratio:16/9;position:relative}.scene-video-preview video{width:100%;height:100%;object-fit:cover}.scene-video-label{position:absolute;bottom:0;left:0;right:0;padding:.3rem .6rem;background:#0009;font-size:.72rem;color:var(--text-secondary);text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.scene-materials-compact{grid-column:1 / -1;margin-top:.75rem}.materials-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .8rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-sans);font-size:.82rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-base)}.materials-toggle:hover{background:var(--bg-glass-hover)}.toggle-arrow{transition:transform var(--transition-base);font-size:.9rem}.toggle-arrow.open{transform:rotate(180deg)}.materials-bullet-list{list-style:none;padding:.5rem 0 0}.materials-bullet-list li{display:flex;align-items:center;gap:.4rem;padding:.25rem .8rem;font-size:.82rem;color:var(--text-secondary)}.materials-bullet-list li .material-type-icon{font-size:.85rem;flex-shrink:0}.materials-bullet-list li strong{color:var(--text-primary);font-weight:600;white-space:nowrap}.material-desc-inline{color:var(--text-muted);font-size:.78rem}.optional-header{margin-top:.3rem}.fill-container{position:relative;z-index:1;max-width:900px;margin:0 auto}.fill-scene-nav{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.fill-scene-dot{display:flex;align-items:center;gap:.35rem;padding:.35rem .8rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;font-family:var(--font-sans);font-size:.78rem;color:var(--text-tertiary);transition:all var(--transition-base)}.fill-scene-dot:hover{background:var(--bg-glass-hover);border-color:var(--border-hover)}.fill-scene-dot.active{background:#2563eb26;border-color:var(--accent-primary);color:var(--accent-primary-light)}.fill-scene-dot.complete{border-color:#10b98166;color:var(--accent-success)}.fill-dot-number{font-weight:700}.fill-dot-label{font-weight:500}.fill-card{position:relative;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:2rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeInScale .35s ease}.fill-topbar{margin-bottom:.75rem}.fill-bottom-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-default)}.fill-bottom-left,.fill-bottom-right{display:flex;gap:.5rem;align-items:center}.fill-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-default)}.fill-card-scene-badge{padding:.3rem .8rem;background:var(--accent-primary);border-radius:var(--radius-full);font-size:.78rem;font-weight:700;color:#fff;white-space:nowrap}.fill-card-title{font-size:1.15rem;font-weight:700}.fill-card-variant{font-size:.85rem;color:var(--accent-primary-light);margin-top:2px}.fill-card-duration{margin-left:auto;padding:.2rem .6rem;background:var(--bg-glass);border-radius:var(--radius-full);font-size:.78rem;color:var(--text-secondary);white-space:nowrap}.fill-video-preview{border-radius:var(--radius-lg);overflow:hidden;background:#000;aspect-ratio:16/9;margin-bottom:1.5rem}.fill-video-preview video{width:100%;height:100%;object-fit:cover}.fill-fields{display:flex;flex-direction:column;gap:.6rem}.compact-field{display:grid;grid-template-columns:1fr 300px;gap:.75rem;align-items:center;padding:.5rem .75rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:border-color var(--transition-base)}.compact-field:focus-within{border-color:var(--accent-primary)}.compact-field-label{display:flex;align-items:center;gap:.35rem;overflow:hidden;min-width:0}.compact-field-icon{font-size:.85rem;flex-shrink:0}.compact-field-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.required-dot{color:var(--accent-danger);font-weight:700;font-size:.9rem;flex-shrink:0}.compact-field-desc{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-field-input{display:flex;align-items:center;gap:.5rem}.compact-field-input input[type=text]{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:.4rem .6rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.85rem;transition:border-color var(--transition-base);outline:none;width:100%}.compact-field-input input:focus{border-color:var(--accent-primary)}.compact-field-input input::placeholder{color:var(--text-muted)}.compact-char-count{font-size:.7rem;color:var(--text-muted);white-space:nowrap}.compact-char-count.over{color:var(--accent-danger)}.compact-file-btn{padding:.35rem .8rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);font-size:.82rem;transition:all var(--transition-base);white-space:nowrap}.compact-file-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary-light)}.compact-file-list{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.4rem}.compact-file-uploaded{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--accent-success)}.compact-file-link{color:var(--accent-primary-light);text-decoration:none;word-break:break-all}.compact-file-link:hover{text-decoration:underline}.compact-file-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:0 .2rem;flex-shrink:0}.compact-file-remove:hover{color:var(--accent-danger)}.fill-page-indicator{text-align:center;margin-top:1.25rem;font-size:.78rem;color:var(--text-muted)}.review-container{position:relative;z-index:1}.review-header{text-align:center;margin-bottom:1.5rem;animation:fadeIn .4s ease}.review-header h2{font-size:1.6rem;font-weight:800;margin-bottom:.25rem;color:#f1f5f9}.review-header p{color:var(--text-secondary);font-size:.9rem}.review-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-default);margin-bottom:1.5rem}.review-tab{padding:.6rem 1.2rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-tertiary);font-family:var(--font-sans);font-size:.88rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.review-tab:hover{color:var(--text-secondary)}.review-tab.active{color:var(--accent-primary-light);border-bottom-color:var(--accent-primary)}.review-overview{display:flex;flex-direction:column;gap:1rem}.review-scene-card{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:1.5rem;animation:slideUp .4s ease forwards;opacity:0}.review-scene-card:nth-child(1){animation-delay:.05s}.review-scene-card:nth-child(2){animation-delay:.1s}.review-scene-card:nth-child(3){animation-delay:.15s}.review-scene-card:nth-child(4){animation-delay:.2s}.review-scene-card:nth-child(5){animation-delay:.25s}.review-scene-card:nth-child(6){animation-delay:.3s}.review-scene-badge{display:inline-block;padding:.2rem .6rem;background:var(--accent-primary);border-radius:var(--radius-full);font-size:.72rem;font-weight:700;color:#fff;margin-bottom:.5rem}.review-scene-left h3{font-size:1rem;font-weight:700;margin-bottom:.2rem}.review-scene-variant{font-size:.82rem;color:var(--accent-primary-light);margin-bottom:.3rem}.review-scene-duration{font-size:.78rem;color:var(--text-muted);margin-bottom:.5rem}.review-scene-visual{font-size:.82rem;color:var(--text-tertiary);padding:.4rem .6rem;background:var(--bg-glass);border-radius:var(--radius-sm);border-left:2px solid var(--accent-primary)}.review-scene-visual strong{color:var(--text-secondary)}.review-scene-right{display:flex;flex-direction:column;gap:.75rem}.review-scene-materials{display:flex;flex-direction:column;gap:.3rem}.review-material-row{display:flex;align-items:center;gap:.4rem;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.82rem}.review-material-row.filled{background:#10b9810d}.review-material-row.empty{background:#f59e0b0d}.review-material-icon{font-size:.82rem;flex-shrink:0}.review-material-label{font-weight:500;color:var(--text-secondary);white-space:nowrap;margin-right:.25rem}.review-material-value{color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.review-material-row.empty .review-material-value{color:var(--accent-warning);font-weight:400}.review-file-list{display:inline-flex;flex-wrap:wrap;gap:.3rem .6rem}.review-file-link{color:var(--accent-primary-light);text-decoration:none;font-weight:500}.review-file-link:hover{text-decoration:underline}.review-file-link:before{content:"📎 "}.review-markdown{animation:fadeIn .3s ease}.review-markdown-toolbar{margin-bottom:.75rem;text-align:right}.review-markdown-content{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;font-family:var(--font-sans);font-size:.85rem;color:var(--text-secondary);line-height:1.7;white-space:pre-wrap;word-wrap:break-word;max-height:70vh;overflow-y:auto;-webkit-user-select:text;user-select:text}.review-assets{display:flex;flex-direction:column;gap:1.5rem}.review-assets-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.9rem}.review-asset-group{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1rem 1.25rem}.review-asset-group-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.88rem;font-weight:500;color:var(--text-primary)}.review-asset-scene-badge{background:var(--accent-primary);color:#fff;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:var(--radius-sm);white-space:nowrap}.review-asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.review-asset-item{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.5rem;border:1px solid var(--border-default);border-radius:var(--radius-md);text-decoration:none;color:var(--text-secondary);transition:border-color var(--transition-base);cursor:pointer}.review-asset-item:hover{border-color:var(--accent-primary)}.review-asset-thumb{width:100%;max-height:100px;object-fit:contain;border-radius:var(--radius-sm);background:var(--bg-tertiary)}.review-asset-file-icon{font-size:2.5rem;padding:.5rem 0}.review-asset-name{font-size:.72rem;text-align:center;word-break:break-all;line-height:1.3;color:var(--text-secondary)}.home-page{position:relative;z-index:1;min-height:80vh}.home-header{text-align:center;padding:3rem 0 1.5rem;animation:fadeIn .5s ease}.home-header h1{font-size:2.5rem;font-weight:800;margin:1rem 0 .5rem;color:#f1f5f9}.home-header p{color:var(--text-secondary);font-size:1rem}.home-actions{display:flex;justify-content:center;margin-bottom:2rem}.create-new-btn{font-size:1rem;padding:.75rem 2rem}.home-empty{text-align:center;padding:4rem 2rem;animation:fadeIn .5s ease}.home-empty-icon{font-size:3rem;margin-bottom:1rem}.home-empty h3{font-size:1.3rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.home-empty p{color:var(--text-muted)}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.project-card{position:relative;display:flex;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1rem 1.25rem;cursor:pointer;transition:all var(--transition-base);animation:fadeIn .4s ease forwards;opacity:0}.project-card:nth-child(1){animation-delay:.05s}.project-card:nth-child(2){animation-delay:.1s}.project-card:nth-child(3){animation-delay:.15s}.project-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.project-card-thumb{width:48px;height:48px;border-radius:var(--radius-md);background:var(--accent-primary);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.project-card-info{flex:1;min-width:0}.project-card-info h3{font-size:.92rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card-meta{display:flex;gap:.75rem;font-size:.75rem;color:var(--text-muted);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.2rem;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.88rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg),var(--shadow-glow-strong)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-hover);color:var(--text-primary)}.btn-ghost{background:none;color:var(--text-tertiary);border:none;padding:.4rem .6rem;font-size:.82rem}.btn-ghost:hover{color:var(--text-primary)}.btn-sm{padding:.3rem .7rem;font-size:.78rem}.btn-lg{padding:.75rem 1.5rem;font-size:.92rem}.action-bar{position:sticky;bottom:0;left:0;right:0;padding:1rem 1.5rem;background:#0a0e17eb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border-default);display:flex;align-items:center;justify-content:space-between;z-index:100;margin:0 -2.5rem -6rem}.action-bar-info{font-size:.85rem;color:var(--text-secondary)}.action-bar-info strong{color:var(--text-primary)}.action-bar-buttons{display:flex;align-items:center;gap:.75rem}@media(max-width:1100px){.scene-main-layout{grid-template-columns:1fr}.scene-video-preview{max-width:400px}.fill-nav-arrow.left{left:.5rem}.fill-nav-arrow.right{right:.5rem}}@media(max-width:768px){.app-container.wide{padding:1rem 1rem 5rem}.template-card,.variant-picker-inline,.compact-field,.review-scene-card{grid-template-columns:1fr}.action-bar{margin:0 -1rem -5rem}.fill-bottom-nav{flex-direction:column;gap:.75rem}.fill-bottom-left,.fill-bottom-right{width:100%;justify-content:center}}.app-topbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 0 .5rem;position:relative;z-index:50}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-primary)}.login-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);animation:loginOrbFloat 12s ease-in-out infinite}.login-orb-1{width:500px;height:500px;background:#2563eb1f;top:-10%;left:-5%;animation-delay:0s}.login-orb-2{width:400px;height:400px;background:#f9731614;bottom:-15%;right:-5%;animation-delay:-4s}.login-orb-3{width:300px;height:300px;background:#2563eb0f;top:50%;left:60%;animation-delay:-8s}@keyframes loginOrbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}.login-card{position:relative;z-index:1;width:100%;max-width:440px;padding:2.5rem;background:#111827b3;border:1px solid var(--border-default);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:var(--shadow-xl),0 0 80px #2563eb14;animation:fadeInScale .5s ease}.login-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem}.login-title{text-align:center;font-size:1.8rem;font-weight:800;margin-bottom:.3rem;color:#f1f5f9}.login-subtitle{text-align:center;color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-label{display:flex;align-items:center;gap:.3rem;font-size:.82rem;font-weight:600;color:var(--text-secondary)}.login-label-icon{font-size:.85rem}.login-input{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:.7rem .9rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.92rem;transition:all var(--transition-base);outline:none}.login-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb26}.login-input::placeholder{color:var(--text-muted)}.login-error{display:flex;align-items:center;gap:.4rem;padding:.6rem .8rem;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);font-size:.82rem;color:#fca5a5;animation:fadeIn .2s ease}.login-submit{margin-top:.5rem;width:100%;justify-content:center;font-size:1rem;padding:.8rem;position:relative}.login-submit.loading{pointer-events:none}.login-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{margin-top:1.5rem;padding-top:1.2rem;border-top:1px solid var(--border-default)}.login-demo-accounts{text-align:center}.login-demo-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}.login-demo-list{display:flex;flex-direction:column;gap:.4rem}.login-demo-item{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.5rem 1rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);font-family:var(--font-sans);font-size:.82rem;color:var(--text-secondary)}.login-demo-item:hover{background:var(--bg-glass-hover);border-color:var(--border-hover);color:var(--text-primary)}.login-demo-role{display:inline-block;padding:.1rem .5rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;letter-spacing:.04em}.login-demo-role.admin{background:#f9731633;color:#fb923c}.login-demo-role.user{background:#06b6d433;color:#67e8f9}.login-demo-email{font-family:monospace;font-size:.82rem}.profile-menu{position:relative;z-index:200}.profile-trigger{display:flex;align-items:center;gap:.35rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-full);padding:.3rem .6rem .3rem .3rem;cursor:pointer;transition:all var(--transition-base);font-family:var(--font-sans)}.profile-trigger:hover{background:var(--bg-glass-hover);border-color:var(--border-hover)}.profile-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-primary);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;color:#fff;box-shadow:var(--shadow-glow)}.profile-chevron{font-size:.7rem;color:var(--text-tertiary)}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:#111827f2;border:1px solid var(--border-default);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:var(--shadow-xl);animation:fadeIn .15s ease;overflow:hidden}.profile-dropdown-header{display:flex;align-items:center;gap:.75rem;padding:1rem}.profile-dropdown-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent-primary);display:flex;align-items:center;justify-content:center;font-size:.92rem;font-weight:700;color:#fff;flex-shrink:0}.profile-dropdown-info{display:flex;flex-direction:column;min-width:0}.profile-dropdown-email{font-size:.85rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown-role{display:inline-flex;align-items:center;width:fit-content;padding:.1rem .5rem;border-radius:var(--radius-full);font-size:.68rem;font-weight:700;letter-spacing:.04em;margin-top:.2rem}.profile-dropdown-role.admin{background:#f9731633;color:#fb923c}.profile-dropdown-role.user{background:#06b6d433;color:#67e8f9}.profile-dropdown-divider{height:1px;background:var(--border-default);margin:0}.profile-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.7rem 1rem;background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);text-align:left}.profile-dropdown-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.profile-dropdown-item.danger:hover{background:#ef44441a;color:#fca5a5}.profile-dropdown-item-icon{font-size:.92rem;flex-shrink:0}.admin-panel{position:relative;z-index:1;min-height:60vh;animation:fadeIn .4s ease}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.admin-header-left{display:flex;flex-direction:column;gap:.2rem}.admin-title{display:flex;align-items:center;gap:.5rem;font-size:1.6rem;font-weight:800;color:#f1f5f9}.admin-subtitle{color:var(--text-secondary);font-size:.88rem}.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.admin-stat-card{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.admin-stat-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.admin-stat-value{font-size:1.8rem;font-weight:800;color:var(--accent-primary-light)}.admin-stat-label{font-size:.78rem;color:var(--text-tertiary);font-weight:500}.admin-table-container{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background:#ffffff05}.admin-table th{padding:.8rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);border-bottom:1px solid var(--border-default)}.admin-table td{padding:.8rem 1rem;border-bottom:1px solid var(--border-default);font-size:.85rem}.admin-table tbody tr{transition:background var(--transition-base)}.admin-table tbody tr:hover{background:var(--bg-glass)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr.inactive-row{opacity:.6}.admin-user-cell{display:flex;align-items:center;gap:.75rem}.admin-user-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-primary-dark);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#fff;flex-shrink:0}.admin-user-info{display:flex;align-items:center;gap:.5rem;min-width:0}.admin-user-email{font-weight:500;color:var(--text-primary)}.admin-you-badge{padding:.05rem .4rem;background:#2563eb26;border:1px solid rgba(37,99,235,.3);border-radius:var(--radius-full);font-size:.65rem;font-weight:700;color:var(--accent-primary-light);white-space:nowrap}.admin-role-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.admin-role-badge.admin{background:#f9731626;color:#fb923c}.admin-role-badge.user{background:#06b6d426;color:#67e8f9}.admin-status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.admin-status-badge.active{background:#10b9811f;color:#6ee7b7}.admin-status-badge.inactive{background:#f59e0b1f;color:#fbbf24}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}.status-dot.active{color:var(--accent-success)}.status-dot.inactive{color:var(--accent-warning)}.admin-date-cell{color:var(--text-tertiary);font-size:.82rem}.admin-actions{display:flex;align-items:center;gap:.5rem}.admin-delete-confirm{display:flex;gap:.35rem;animation:fadeIn .15s ease}.btn-danger{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef44444d;color:#fecaca}.btn-danger-ghost{color:var(--text-muted)}.btn-danger-ghost:hover{color:#fca5a5!important}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .15s ease}.modal-card{width:100%;max-width:460px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);animation:fadeInScale .25s ease;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid var(--border-default)}.modal-header h2{font-size:1.15rem;font-weight:700}.modal-close{width:28px;height:28px;border-radius:50%;background:var(--bg-glass);border:1px solid var(--border-default);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all var(--transition-base)}.modal-close:hover{background:#ef44441a;border-color:#ef44444d;color:#fca5a5}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-field{display:flex;flex-direction:column;gap:.35rem}.modal-field label{font-size:.82rem;font-weight:600;color:var(--text-secondary)}.modal-field-hint{font-weight:400;color:var(--text-muted);font-size:.75rem}.modal-input{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:.6rem .8rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.88rem;transition:all var(--transition-base);outline:none}.modal-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb26}.modal-input::placeholder{color:var(--text-muted)}.modal-role-select{display:flex;gap:.5rem}.role-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem;background:var(--bg-tertiary);border:2px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.role-option:hover{border-color:var(--border-hover);color:var(--text-primary)}.role-option.active{border-color:var(--accent-primary);background:#2563eb14;color:var(--accent-primary-light);box-shadow:var(--shadow-glow)}.role-option.status-option.active{border-color:var(--accent-success);background:#10b98114;color:#6ee7b7;box-shadow:0 0 16px #10b98126}.modal-error{padding:.6rem .8rem;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);font-size:.82rem;color:#fca5a5;animation:fadeIn .2s ease}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-default);background:#ffffff03}@media(max-width:900px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-table-container{overflow-x:auto}.admin-table{min-width:700px}.admin-header{flex-direction:column}}@media(max-width:480px){.login-card{margin:1rem;padding:1.5rem}.admin-stats{grid-template-columns:1fr 1fr}}.picker-modal{width:100%;max-width:820px;max-height:90vh;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);animation:fadeInScale .3s ease;overflow:hidden;display:flex;flex-direction:column}.picker-modal-header{flex-shrink:0;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border-default);background:var(--bg-secondary);z-index:10}.modal-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.picker-modal-body{flex:1;overflow-y:auto;padding-top:1.5rem}.picker-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.picker-filter-btn{background:var(--bg-glass);border:1px solid var(--border-default);color:var(--text-secondary);padding:.4rem .8rem;border-radius:var(--radius-full);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.picker-filter-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.picker-filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:var(--shadow-glow)}.picker-subtitle{color:var(--text-secondary);font-size:.88rem;margin-bottom:0}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;padding:0 1.5rem 1.5rem}.picker-card{background:var(--bg-card);border:2px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;transition:all var(--transition-slow);display:flex;flex-direction:column}.picker-card:hover,.picker-card.hovered{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.picker-card-video{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden}.picker-card-video video{width:100%;height:100%;object-fit:cover}.picker-card-video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:opacity var(--transition-base)}.picker-card:hover .picker-card-video-overlay{opacity:0}.picker-play-icon{width:44px;height:44px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.4);font-size:1rem;color:#fff}.picker-card-body{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.picker-card-name{font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.3}.picker-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.picker-card-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto}.picker-meta-tag{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .55rem;background:var(--bg-glass);border-radius:var(--radius-full);font-size:.72rem;color:var(--text-tertiary);white-space:nowrap}.picker-card-btn{margin-top:.75rem;width:100%;justify-content:center}@media(max-width:768px){.picker-modal{margin:1rem;max-height:85vh}.picker-grid{grid-template-columns:1fr}}.home-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}.project-card-v2{position:relative;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:visible;cursor:pointer;transition:all var(--transition-slow);animation:fadeIn .4s ease forwards;opacity:0}.project-card-v2:nth-child(1){animation-delay:.05s}.project-card-v2:nth-child(2){animation-delay:.1s}.project-card-v2:nth-child(3){animation-delay:.15s}.project-card-v2:nth-child(4){animation-delay:.2s}.project-card-v2:hover{border-color:var(--border-hover);transform:translateY(-3px);box-shadow:var(--shadow-lg)}.project-card-v2.generating{cursor:default}.project-card-v2.generating:hover{transform:none;box-shadow:none}.project-card-v2.completed:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.project-card-v2-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg-tertiary);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.project-card-v2-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow),filter var(--transition-slow)}.project-card-v2:hover .project-card-v2-thumb img{transform:scale(1.03)}.project-card-v2.generating .project-card-v2-thumb img{filter:brightness(.4)}.project-card-v2-generating-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.generating-spinner-ring{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent-primary-light);border-radius:50%;animation:spin .8s linear infinite}.generating-label{font-size:.82rem;font-weight:600;color:#ffffffd9;letter-spacing:.03em}.project-card-v2-completed-badge{position:absolute;bottom:.6rem;right:.6rem;padding:.3rem .8rem;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:.78rem;font-weight:600;color:#fff;opacity:0;transform:translateY(4px);transition:all var(--transition-base)}.project-card-v2.completed:hover .project-card-v2-completed-badge{opacity:1;transform:translateY(0)}.project-card-v2-body{padding:1rem 1.25rem 1.25rem;background:var(--bg-card);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.project-card-v2-name{font-size:1rem;font-weight:700;margin-bottom:.35rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card-v2-meta{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.78rem;color:var(--text-muted);margin-bottom:.5rem}.project-card-v2-progress{display:flex;align-items:center;gap:.6rem;margin-top:.25rem}.project-progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.project-progress-fill{height:100%;background:var(--accent-primary);border-radius:var(--radius-full);transition:width .6s ease;position:relative}.project-progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.25) 50%,transparent 100%);animation:progress-shimmer 1.5s ease-in-out infinite}@keyframes progress-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.project-progress-label{font-size:.75rem;font-weight:700;color:var(--accent-primary-light);white-space:nowrap;min-width:36px;text-align:right}.project-card-v2-status.completed{font-size:.78rem;font-weight:600;color:var(--accent-success);margin-top:.25rem}.project-card-menu-wrapper{position:absolute;top:.5rem;right:.5rem;z-index:10}.project-menu-btn{width:28px;height:28px;border-radius:50%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;color:#fff9;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);opacity:0;line-height:1;letter-spacing:1px}.project-card-v2:hover .project-menu-btn{opacity:1}.project-menu-btn:hover{color:#fff;background:#000000b3}.project-card-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);padding:.35rem 0;animation:fadeInScale .15s ease both;z-index:20}.project-card-dropdown-item{display:block;width:100%;padding:.5rem 1rem;background:none;border:none;color:var(--text-primary);font-size:.85rem;text-align:left;cursor:pointer;transition:background var(--transition-base)}.project-card-dropdown-item:hover{background:var(--bg-glass-hover)}.project-card-dropdown-item.danger{color:var(--accent-danger)}.project-card-dropdown-item.danger:hover{background:#ef44441a}.project-card-dropdown-divider{height:1px;background:var(--border-default);margin:.25rem 0}.preview-page{position:relative;z-index:1;animation:fadeIn .4s ease}.preview-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.preview-title{font-size:1.3rem;font-weight:800;color:var(--text-primary)}.preview-topbar-actions{display:flex;gap:.5rem}.preview-layout{display:grid;grid-template-columns:1fr 360px;gap:1.5rem;align-items:start}.preview-player-section{display:flex;flex-direction:column;gap:1.25rem}.preview-player{border-radius:var(--radius-xl);overflow:hidden;background:#000;aspect-ratio:16/9;box-shadow:var(--shadow-xl)}.preview-player video{width:100%;height:100%;object-fit:contain;background:#000}.preview-actions{display:flex;gap:.75rem}.preview-download-btn{flex:1}.preview-download-btn.loading{pointer-events:none;opacity:.8}.preview-info-section{display:flex;flex-direction:column;gap:1rem}.preview-info-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:1.25rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.preview-info-title{font-size:.92rem;font-weight:700;margin-bottom:.75rem;display:flex;align-items:center;gap:.35rem}.preview-info-rows{display:flex;flex-direction:column;gap:.5rem}.preview-info-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem 0;border-bottom:1px solid var(--border-default)}.preview-info-row:last-child{border-bottom:none}.preview-info-label{font-size:.82rem;color:var(--text-tertiary);font-weight:500}.preview-info-value{font-size:.82rem;color:var(--text-primary);font-weight:600;text-align:right;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.preview-status-badge.completed{background:#10b9811f;color:#6ee7b7}.preview-status-badge.generating{background:#2563eb1f;color:var(--accent-primary-light)}.preview-scene-list{display:flex;flex-direction:column;gap:.35rem}.preview-scene-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;background:var(--bg-glass);border-radius:var(--radius-md);transition:background var(--transition-base)}.preview-scene-item:hover{background:var(--bg-glass-hover)}.preview-scene-num{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:var(--text-tertiary);flex-shrink:0;border:1px solid var(--border-default)}.preview-scene-details{flex:1;min-width:0}.preview-scene-name{font-size:.82rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-scene-variant{font-size:.72rem;color:var(--accent-primary-light)}.preview-scene-dur{font-size:.72rem;color:var(--text-muted);white-space:nowrap}@media(max-width:900px){.preview-layout{grid-template-columns:1fr}.preview-info-section{order:-1}}@media(max-width:768px){.home-grid-v2{grid-template-columns:1fr}.preview-actions{flex-direction:column}}.create-method-modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:2.5rem;max-width:700px;width:90%;box-shadow:var(--shadow-xl);animation:fadeInScale var(--transition-slow) both}.create-method-subtitle{color:var(--text-secondary);margin-top:.25rem;margin-bottom:2rem}.create-method-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.create-method-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;cursor:pointer;transition:all var(--transition-base)}.create-method-card:hover{background:var(--bg-glass-hover);border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.create-method-card-icon{font-size:2.5rem;margin-bottom:1rem}.create-method-card h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.create-method-card p{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.create-method-card-btn{width:100%}@media(max-width:600px){.create-method-cards{grid-template-columns:1fr}}.translation-modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:2rem 2.5rem 2.5rem;max-width:520px;width:90%;box-shadow:var(--shadow-xl);animation:fadeInScale var(--transition-slow) both}.modal-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.modal-header-top h2{font-size:1.35rem;font-weight:700;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-md);transition:all var(--transition-base)}.modal-close:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.translation-modal-subtitle{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin-bottom:1.5rem}.translation-lang-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}.translation-lang-btn{padding:.6rem .75rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-base);text-align:center}.translation-lang-btn:hover{background:var(--bg-glass-hover);border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.translation-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0}.translation-loading p{color:var(--text-secondary);font-size:.9rem}@media(max-width:480px){.translation-lang-grid{grid-template-columns:repeat(2,1fr)}}.ai-flow-container{max-width:1100px;margin:0 auto;padding:0 1rem 4rem}.ai-flow-container.ai-flow-wide{max-width:90vw}.ai-flow-topbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;margin-bottom:1rem;border-bottom:1px solid var(--border-default)}.ai-flow-title{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.ai-flow-progress{font-size:.875rem;color:var(--text-secondary);background:var(--bg-glass);padding:.25rem .75rem;border-radius:var(--radius-full)}.ai-stepper{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:2.5rem;padding:1rem 0}.ai-stepper-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-full);transition:all var(--transition-base)}.ai-stepper-item:hover{background:var(--bg-glass)}.ai-stepper-number{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;background:var(--bg-glass);border:2px solid var(--border-default);color:var(--text-secondary);flex-shrink:0;transition:all var(--transition-base)}.ai-stepper-item.active .ai-stepper-number{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 0 16px #2563eb66}.ai-stepper-item.completed .ai-stepper-number{background:var(--accent-success);border-color:var(--accent-success);color:#fff}.ai-stepper-label{font-size:.875rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.ai-stepper-item.active .ai-stepper-label{color:var(--text-primary);font-weight:600}.ai-stepper-item.completed .ai-stepper-label{color:var(--accent-success)}.ai-step-actions{display:flex;align-items:center;justify-content:space-between;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border-default)}.ai-prompt-step{animation:fadeIn var(--transition-slow) both}.ai-prompt-header{text-align:center;margin-bottom:2rem}.ai-prompt-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.ai-prompt-header p{color:var(--text-secondary)}.ai-prompt-input-area{position:relative;margin-bottom:2rem}.ai-prompt-textarea{width:100%;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-sans);font-size:1rem;line-height:1.7;padding:1.25rem;resize:vertical;transition:border-color var(--transition-base),box-shadow var(--transition-base);box-sizing:border-box}.ai-prompt-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb26}.ai-prompt-textarea::placeholder{color:var(--text-muted)}.ai-prompt-char-count{position:absolute;bottom:.75rem;right:1rem;font-size:.75rem;color:var(--text-tertiary)}.ai-prompt-tags-section{margin-top:1.5rem}.ai-prompt-tags-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.ai-prompt-category-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.ai-prompt-category-tab{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:.4rem 1rem;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans)}.ai-prompt-category-tab:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.ai-prompt-category-tab.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.ai-prompt-examples{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.ai-prompt-example-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:1rem;cursor:pointer;transition:all var(--transition-base)}.ai-prompt-example-card:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.ai-prompt-example-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.ai-prompt-example-text{font-size:.8rem;color:var(--text-secondary);line-height:1.5}.ai-plan-step{animation:fadeIn var(--transition-slow) both}.ai-plan-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-default);margin-bottom:1.5rem}.ai-plan-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;padding:.75rem 1.25rem;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans)}.ai-plan-tab:hover{color:var(--text-primary);background:var(--bg-glass)}.ai-plan-tab.active{color:var(--accent-primary-light);border-bottom-color:var(--accent-primary);font-weight:600}.ai-plan-content{min-height:300px}.ai-plan-section{animation:fadeIn var(--transition-base) both}.ai-plan-section h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.ai-plan-section-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.ai-plan-hint{font-size:.825rem;color:var(--text-tertiary);margin-bottom:1rem}.ai-plan-textarea{width:100%;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:.9rem;line-height:1.6;padding:.75rem 1rem;resize:vertical;transition:border-color var(--transition-base);box-sizing:border-box}.ai-plan-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a}.ai-plan-char-count{text-align:right;font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem}.ai-style-selector{display:flex;flex-wrap:wrap;gap:.5rem}.ai-style-option{padding:.4rem .9rem;border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-glass);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.ai-style-option:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-glass-hover)}.ai-style-option.active{border-color:var(--accent-primary);background:#2563eb26;color:var(--accent-primary-light);font-weight:600}.ai-voice-desc{display:block;font-size:.65rem;font-weight:400;opacity:.7;margin-top:2px}.ai-prompt-lang-settings{margin-top:1.5rem;padding:1rem 1.25rem;background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-default)}.ai-prompt-lang-settings h3{margin:0 0 .75rem;font-size:.95rem}.ai-lang-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0}.ai-lang-row label{font-size:.82rem;color:var(--text-secondary)}.ai-lang-toggle{display:flex;gap:0;border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--border-default)}.ai-lang-toggle button{padding:.3rem .75rem;font-size:.78rem;font-weight:500;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.ai-lang-toggle button:not(:last-child){border-right:1px solid var(--border-default)}.ai-lang-toggle button.active{background:#2563eb33;color:var(--accent-primary-light);font-weight:600}.ai-lang-toggle button:hover:not(.active){background:var(--bg-hover);color:var(--text-primary)}.ai-plan-empty{text-align:center;padding:2rem;color:var(--text-muted);background:var(--bg-glass);border-radius:var(--radius-md);border:1px dashed var(--border-default)}.ai-inline-input{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;padding:.5rem .75rem;width:100%;transition:border-color var(--transition-fast);box-sizing:border-box}.ai-inline-input:focus{outline:none;border-color:var(--accent-primary)}.ai-inline-input::placeholder{color:var(--text-muted)}.ai-inline-input-name{font-weight:600;font-size:.95rem}.ai-inline-textarea{width:100%;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:.85rem;line-height:1.5;padding:.5rem .75rem;resize:vertical;transition:border-color var(--transition-fast);box-sizing:border-box}.ai-inline-textarea:focus{outline:none;border-color:var(--accent-primary)}.ai-inline-textarea::placeholder{color:var(--text-muted)}.ai-delete-btn{color:var(--text-muted)!important;font-size:1rem;flex-shrink:0}.ai-delete-btn:hover{color:var(--accent-danger)!important}.ai-character-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:1rem;margin-bottom:.75rem;transition:border-color var(--transition-base)}.ai-character-card:hover{border-color:var(--border-hover)}.ai-character-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.ai-asset-group{margin-bottom:2rem}.ai-asset-fields{display:grid;gap:.75rem}.ai-asset-field label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.ai-custom-asset-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.ai-custom-asset-row .ai-inline-input{flex:1}.ai-scene-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1rem;transition:border-color var(--transition-base)}.ai-scene-card:hover{border-color:var(--border-hover)}.ai-scene-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.ai-scene-badge{background:var(--accent-primary);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .6rem;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.ai-scene-card{position:relative}.ai-scene-card-actions{position:absolute;top:.5rem;right:.5rem;z-index:2;display:flex;align-items:center;gap:.15rem}.ai-scene-move-btn{font-size:.6rem!important;padding:.1rem .3rem!important;opacity:.5;line-height:1!important}.ai-scene-move-btn:hover:not(:disabled){opacity:1}.ai-scene-move-btn:disabled{opacity:.15;cursor:default}.ai-scene-tags{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:.75rem 0}.ai-scene-tags-label{font-size:.8rem;color:var(--text-tertiary);flex-shrink:0}.ai-appearance-tag{display:inline-flex;align-items:center;gap:.3rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;padding:.15rem .5rem;font-family:var(--font-sans)}.ai-appearance-tag-char{background:#2563eb26;border:1px solid var(--accent-primary);color:var(--accent-primary-light)}.ai-appearance-tag-asset{background:#f9731626;border:1px solid #f97316;color:#fb923c}.ai-appearance-tag-company{background:#a855f726;border:1px solid #a855f7;color:#c084fc}.ai-tag-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:.65rem;opacity:.6;padding:0;line-height:1}.ai-tag-remove:hover{opacity:1}.ai-tag-add-wrapper{position:relative;display:inline-block}.ai-tag-add-btn{width:24px;height:24px;border-radius:var(--radius-sm);border:1px dashed var(--border-hover);background:none;color:var(--text-tertiary);cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.ai-tag-add-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary-light)}.ai-tag-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:var(--bg-secondary);border:1px solid var(--border-hover);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:10;max-height:200px;overflow-y:auto}.ai-tag-dropdown-item{padding:.4rem .75rem;font-size:.8rem;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.ai-tag-dropdown-item:hover{background:var(--bg-glass)}.ai-tag-dropdown-type{font-size:.65rem;color:var(--text-muted);margin-right:.3rem}.ai-scene-inline-fields{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-default)}.ai-scene-inline-field{display:flex;align-items:center;gap:.5rem}.ai-scene-inline-field label{font-size:.75rem;font-weight:600;color:var(--text-tertiary);white-space:nowrap;min-width:32px}.ai-image-upload-area{margin-top:.5rem}.ai-image-thumbnails{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.ai-image-thumb{position:relative;width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-default)}.ai-image-thumb img{width:100%;height:100%;object-fit:cover}.ai-image-remove{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:#000000b3;border:none;color:#fff;font-size:.55rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.ai-logo-upload{display:flex;align-items:center;gap:.75rem}.ai-logo-preview{position:relative;width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-default)}.ai-logo-preview img{width:100%;height:100%;object-fit:contain;background:#fff}.ai-prompt-highlight-wrapper{position:relative}.ai-prompt-highlight-backdrop{position:absolute;inset:0;padding:.5rem .75rem;font-family:var(--font-sans);font-size:.85rem;line-height:1.5;color:transparent;white-space:pre-wrap;word-wrap:break-word;overflow:hidden;pointer-events:none}.ai-prompt-textarea-overlay{background:transparent!important;position:relative;z-index:1;caret-color:var(--text-primary)}.ai-mention{border-radius:3px;padding:0 2px}.ai-mention.char{background:#2563eb40;color:var(--accent-primary-light)}.ai-mention.asset{background:#f9731640;color:#fb923c}.ai-mention-tag{display:inline;border-radius:3px;padding:1px 4px;font-size:.8rem;font-weight:500;white-space:nowrap}.ai-mention-tag.char{background:#2563eb33;color:var(--accent-primary-light);border:1px solid rgba(37,99,235,.4)}.ai-mention-tag.asset{background:#f9731633;color:#fb923c;border:1px solid rgba(249,115,22,.4)}.ai-mention-dropdown{position:absolute;z-index:20;min-width:180px;max-height:180px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-hover);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg)}.ai-custom-asset-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:.75rem;margin-bottom:.5rem}.ai-storyboard-step{animation:fadeIn var(--transition-slow) both}.ai-storyboard-layout{display:grid;grid-template-columns:180px 1fr;gap:1.5rem;min-height:500px}.ai-storyboard-left h3{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.ai-storyboard-scene-list{display:flex;flex-direction:column;gap:.5rem}.ai-storyboard-scene-thumb{cursor:pointer;border-radius:var(--radius-sm);border:2px solid transparent;overflow:hidden;transition:all var(--transition-fast)}.ai-storyboard-scene-thumb:hover{border-color:var(--border-hover)}.ai-storyboard-scene-thumb.active{border-color:var(--accent-primary);box-shadow:0 0 12px #2563eb4d}.ai-storyboard-scene-thumb-img{aspect-ratio:16 / 9;background:var(--bg-tertiary);overflow:hidden}.ai-storyboard-scene-thumb-img img{width:100%;height:100%;object-fit:cover}.ai-storyboard-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);color:var(--text-muted);font-size:1.25rem;font-weight:700}.ai-storyboard-scene-thumb-label{font-size:.7rem;font-weight:500;color:var(--text-tertiary);text-align:center;padding:.25rem 0}.ai-storyboard-scene-thumb.active .ai-storyboard-scene-thumb-label{color:var(--accent-primary-light)}.ai-storyboard-scene-thumb-img{position:relative}.ai-keyframe-actions{position:absolute;top:4px;right:4px;z-index:2;opacity:0;transition:opacity var(--transition-fast)}.ai-storyboard-scene-thumb:hover .ai-keyframe-actions,.ai-storyboard-scene-thumb.active .ai-keyframe-actions{opacity:1}.ai-keyframe-gen-btn{width:22px;height:22px;border-radius:50%;border:none;background:var(--accent-primary);color:#fff;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background var(--transition-fast)}.ai-keyframe-gen-btn:hover{background:var(--accent-primary-dark, #1d4ed8)}.ai-keyframe-gen-btn:disabled{opacity:.5;cursor:not-allowed}.ai-keyframe-nav{display:flex;align-items:center;justify-content:center;gap:2px;padding:2px 0;background:#0000008c}.ai-keyframe-nav-btn{background:none;border:none;color:#fff;font-size:.65rem;cursor:pointer;padding:0 4px;opacity:.7;transition:opacity var(--transition-fast)}.ai-keyframe-nav-btn:hover{opacity:1}.ai-keyframe-counter{font-size:.6rem;color:#fffc;min-width:20px;text-align:center}.ai-keyframe-generating{position:relative}.ai-generating-spinner-sm{width:18px;height:18px;border:2px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;animation:ai-spin .8s linear infinite}.ai-lightbox-overlay{position:fixed;inset:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:fadeIn .15s ease}.ai-lightbox-img{max-width:90vw;max-height:90vh;border-radius:var(--radius-lg);box-shadow:0 8px 40px #00000080;object-fit:contain}.ai-storyboard-scene-header{display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-default)}.ai-storyboard-scene-title{font-size:1rem;font-weight:600;color:var(--text-primary);flex:1}.ai-storyboard-right{display:flex;flex-direction:column;height:calc(100vh - 220px);min-height:500px;gap:.75rem}.ai-keyframe-preview-area{flex-shrink:0}.ai-keyframe-preview-img{height:240px;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;justify-content:center}.ai-keyframe-preview-img img{width:100%;height:100%;object-fit:contain;border-radius:var(--radius-md)}.ai-keyframe-preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);width:100%;height:100%}.ai-keyframe-preview-empty span{font-size:1.5rem;font-weight:800;opacity:.3}.ai-keyframe-preview-empty p{font-size:.75rem;opacity:.5}.ai-keyframe-preview-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;gap:.75rem}.ai-keyframe-preview-info{display:flex;align-items:center;gap:.5rem;min-width:0;overflow:hidden}.ai-scene-badge{font-size:.7rem;font-weight:600;background:var(--accent-primary);color:#fff;padding:.15rem .5rem;border-radius:var(--radius-full);white-space:nowrap}.ai-keyframe-preview-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.ai-keyframe-nav-btn-lg{background:var(--bg-glass);border:1px solid var(--border-default);color:var(--text-secondary);font-size:.85rem;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.ai-keyframe-nav-btn-lg:hover{background:var(--bg-glass-hover);border-color:var(--border-hover);color:var(--text-primary)}.ai-keyframe-counter-lg{font-size:.75rem;color:var(--text-secondary);min-width:32px;text-align:center}.ai-keyframe-gen-btn-lg{background:var(--accent-primary);color:#fff;border:none;font-size:.75rem;font-weight:600;padding:.35rem .75rem;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.ai-keyframe-gen-btn-lg:hover{background:var(--accent-primary-dark)}.ai-keyframe-gen-btn-lg:disabled{opacity:.5;cursor:not-allowed}.ai-ref-images-grid{display:flex;flex-direction:column;gap:.75rem}.ai-ref-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:.5rem .75rem}.ai-ref-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.ai-ref-card-type{font-size:.6rem;font-weight:600;text-transform:uppercase;background:var(--accent-primary);color:#fff;padding:.1rem .35rem;border-radius:var(--radius-sm)}.ai-ref-card-name{font-size:.8rem;font-weight:500;color:var(--text-primary)}.ai-ref-card-images{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.ai-ref-thumb{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;cursor:zoom-in;border:1px solid var(--border-default)}.ai-ref-thumb img{width:100%;height:100%;object-fit:cover}.ai-ref-upload-btn{width:48px;height:48px;border-radius:var(--radius-sm);border:1px dashed var(--border-hover);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:all var(--transition-fast)}.ai-ref-upload-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#2563eb0d}.ai-storyboard-editor{flex:1;overflow-y:auto;padding-right:.5rem;min-height:0}.ai-storyboard-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-default)}.ai-storyboard-section:last-child{border-bottom:none}.ai-storyboard-section h4{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.ai-storyboard-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.ai-storyboard-section-header h4{margin-bottom:0}.ai-storyboard-field{margin-bottom:.75rem}.ai-storyboard-field label{display:block;font-size:.75rem;font-weight:500;color:var(--text-tertiary);margin-bottom:.25rem}.ai-storyboard-field-inline{display:flex;align-items:center;gap:.5rem}.ai-storyboard-field-inline label{margin-bottom:0;white-space:nowrap}.ai-subtitle-compact{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:.5rem .75rem}.ai-voiceover-compact{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.ai-range-slider{-webkit-appearance:none;appearance:none;height:4px;background:var(--border-default);border-radius:2px;outline:none;flex:1;min-width:80px}.ai-range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer}.ai-range-value,.ai-range-label{font-size:.7rem;color:var(--text-muted);min-width:32px;text-align:center}.ai-dual-range{display:flex;align-items:center;gap:.5rem;min-width:160px}.ai-dual-range-track{position:relative;flex:1;height:4px;background:var(--border-default);border-radius:2px}.ai-dual-range-track input[type=range]{position:absolute;width:100%;top:-5px;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none}.ai-dual-range-track input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer;pointer-events:auto}.ai-create-step{animation:fadeIn var(--transition-slow) both}.ai-create-step.ai-create-production{max-width:none;margin:0}.ai-create-header{text-align:center;margin-bottom:1.5rem}.ai-create-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.ai-create-header p{color:var(--text-secondary);margin-bottom:.5rem}.ai-create-progress-summary{display:flex;justify-content:center;gap:1.5rem;font-size:.8rem;color:var(--text-tertiary)}.ai-create-layout{display:grid;grid-template-columns:180px 1fr;gap:1.5rem;min-height:480px}.ai-create-scene-panel h3{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.ai-create-scene-list-v2{display:flex;flex-direction:column;gap:.5rem}.ai-create-scene-thumb{cursor:pointer;border-radius:var(--radius-sm);border:2px solid transparent;overflow:hidden;transition:all var(--transition-fast);background:var(--bg-glass)}.ai-create-scene-thumb:hover{border-color:var(--border-hover)}.ai-create-scene-thumb.active{border-color:var(--accent-primary);box-shadow:0 0 12px #2563eb4d}.ai-create-scene-thumb-img{aspect-ratio:16 / 9;background:var(--bg-tertiary);overflow:hidden}.ai-create-scene-thumb-img img{width:100%;height:100%;object-fit:cover}.ai-create-scene-thumb-info{display:flex;align-items:center;justify-content:space-between;padding:.25rem .4rem}.ai-create-scene-thumb-label{font-size:.7rem;font-weight:500;color:var(--text-tertiary)}.ai-create-scene-status-icons{display:flex;gap:.3rem}.ai-status-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:.55rem;font-weight:600}.ai-status-icon.done{background:#22c55e33;color:var(--accent-success)}.ai-status-icon.generating{background:#2563eb33;color:var(--accent-primary);animation:ai-spin 1s linear infinite}.ai-status-icon.error{background:#ef444433;color:var(--accent-danger)}.ai-create-work-panel{display:flex;flex-direction:column;gap:1rem}.ai-create-preview-area{flex-shrink:0}.ai-create-preview-container{position:relative;aspect-ratio:16 / 9;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden}.ai-create-preview-keyframe{position:relative;width:100%;height:100%}.ai-create-preview-keyframe img{width:100%;height:100%;object-fit:cover}.ai-create-preview-video{width:100%;height:100%;object-fit:contain;background:#000}.ai-create-subtitle-overlay{position:absolute;bottom:10%;left:50%;transform:translate(-50%);max-width:80%;padding:.4rem 1rem;background:#000000bf;color:#fff;font-size:1rem;font-weight:600;text-align:center;border-radius:var(--radius-sm);pointer-events:none;text-shadow:0 1px 3px rgba(0,0,0,.5)}.ai-create-preview-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000a6;color:#fff;gap:.5rem;z-index:2}.ai-create-preview-loading p{font-size:.85rem}.ai-create-preview-bar{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;font-size:.85rem;color:var(--text-secondary)}.ai-create-scene-bar-title{font-weight:500}.ai-create-duration{margin-left:auto;color:var(--text-tertiary);font-size:.8rem}.ai-create-section{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:1rem}.ai-create-render-section{border-color:var(--accent-primary);border-style:dashed}.ai-create-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.ai-create-section-header h4{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0}.ai-create-voiceover-text{font-size:.85rem;color:var(--text-primary);line-height:1.5;margin-bottom:.75rem;padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.ai-create-audio-player{width:100%;height:36px;border-radius:var(--radius-sm)}.ai-create-video-player{width:100%;border-radius:var(--radius-sm);max-height:300px}.ai-create-status-msg{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-tertiary);padding:.5rem 0}.ai-create-error{font-size:.8rem;color:var(--accent-danger);padding:.35rem 0}.ai-create-hint{font-size:.8rem;color:var(--text-tertiary);padding:.25rem 0}.ai-create-final-video{display:flex;flex-direction:column;align-items:flex-start}@media(max-width:900px){.ai-storyboard-layout{grid-template-columns:1fr}.ai-storyboard-left{order:-1}.ai-storyboard-scene-list{flex-direction:row;overflow-x:auto}.ai-storyboard-scene-thumb{min-width:100px}.ai-storyboard-right{height:auto;min-height:0}.ai-keyframe-preview-bar{flex-wrap:wrap}}@media(max-width:900px){.ai-create-layout{grid-template-columns:1fr}.ai-create-scene-panel{order:-1}.ai-create-scene-list-v2{flex-direction:row;overflow-x:auto}.ai-create-scene-thumb{min-width:120px}}@media(max-width:600px){.ai-stepper-label{display:none}}.ai-generating-overlay{position:fixed;inset:0;z-index:1000;background:#0a0e17d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:fadeIn var(--transition-base) both}.ai-generating-card{text-align:center;padding:3rem}.ai-generating-spinner{width:48px;height:48px;border:3px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;animation:ai-spin .8s linear infinite;margin:0 auto 1.5rem}@keyframes ai-spin{to{transform:rotate(360deg)}}.ai-generating-card h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.ai-generating-card p{color:var(--text-secondary);font-size:.9rem}.ai-prompt-error{background:#ef44441a;border:1px solid var(--accent-danger);border-radius:var(--radius-md);color:var(--accent-danger);padding:.75rem 1rem;font-size:.875rem;margin-top:1rem}.ai-create-tab-switcher{display:flex;gap:0;margin-top:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px;width:fit-content}.ai-create-tab{padding:.4rem 1.25rem;font-size:.8rem;font-weight:500;color:var(--text-tertiary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.ai-create-tab:hover{color:var(--text-secondary)}.ai-create-tab.active{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm)}.tl-container{display:flex;flex-direction:column;gap:0;padding:1rem 0;overflow-x:auto;min-width:0}.tl-ruler{display:flex;align-items:flex-end;height:28px;margin-bottom:2px}.tl-ruler-bar{flex:1;position:relative;height:100%;border-bottom:1px solid var(--border-default)}.tl-ruler-mark{position:absolute;bottom:0;transform:translate(-50%)}.tl-ruler-mark span{font-size:.65rem;color:var(--text-tertiary);white-space:nowrap}.tl-track{display:flex;align-items:stretch;min-height:48px;border-bottom:1px solid var(--border-default)}.tl-track-label{width:60px;min-width:60px;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.tl-track-bar{flex:1;position:relative;min-height:48px;background:var(--bg-glass)}.tl-scene-block{position:absolute;top:2px;bottom:2px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-default);overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:default;transition:border-color var(--transition-fast)}.tl-scene-block.hovered{border-color:var(--accent-primary-light)}.tl-scene-block.has-video{border-color:var(--accent-success)}.tl-scene-thumb{width:100%;height:100%;object-fit:cover;opacity:.7}.tl-scene-placeholder{font-size:1.1rem;font-weight:700;color:var(--text-tertiary)}.tl-scene-label{position:absolute;bottom:2px;left:4px;display:flex;gap:4px;align-items:center}.tl-scene-num{font-size:.6rem;font-weight:700;color:var(--text-primary);background:#00000080;padding:1px 4px;border-radius:3px}.tl-scene-dur{font-size:.6rem;color:var(--text-secondary);background:#0006;padding:1px 3px;border-radius:3px}.tl-scene-done-badge{position:absolute;top:2px;right:4px;font-size:.55rem;font-weight:600;color:var(--accent-success);background:#10b98126;padding:1px 5px;border-radius:3px;text-transform:uppercase}.tl-scene-generating{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006}.tl-transition-btn{position:absolute;top:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-secondary);color:var(--text-tertiary);font-size:.55rem;font-weight:700;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.tl-transition-btn:hover{border-color:var(--accent-primary-light);color:var(--accent-primary-light)}.tl-transition-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.tl-text-block{position:absolute;top:6px;bottom:6px;border-radius:4px;background:#f9731626;border:1px solid rgba(249,115,22,.3);padding:0 6px;display:flex;align-items:center;overflow:hidden}.tl-text-content{font-size:.65rem;color:var(--accent-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-voice-block{position:absolute;top:6px;bottom:6px;border-radius:4px;background:#2563eb1f;border:1px solid rgba(37,99,235,.25);padding:0 6px;display:flex;align-items:center;gap:4px;overflow:hidden}.tl-voice-block.done{border-color:var(--accent-success);background:#10b9811a}.tl-voice-content{font-size:.65rem;color:var(--accent-primary-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.tl-voice-done{font-size:.5rem;font-weight:600;color:var(--accent-success);text-transform:uppercase;flex-shrink:0}.tl-track-music .tl-track-bar{min-height:40px}.tl-music-bar{position:absolute;top:4px;bottom:4px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#8b5cf633,#8b5cf61a);border:1px solid rgba(139,92,246,.35);display:flex;align-items:center;padding:0 8px;gap:6px;overflow:hidden}.tl-music-name{font-size:.65rem;font-weight:600;color:#a78bfa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.tl-music-fade{font-size:.5rem;font-weight:700;padding:1px 4px;border-radius:3px;text-transform:uppercase;flex-shrink:0}.tl-fade-in,.tl-fade-out{background:#8b5cf633;color:#a78bfa}.tl-music-controls{display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem 0 .25rem 60px;align-items:center}.tl-music-row{display:flex;align-items:center;gap:.5rem}.tl-music-label{font-size:.75rem;font-weight:600;color:var(--text-tertiary);min-width:40px}.tl-music-select{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.75rem;padding:.3rem .5rem;outline:none}.tl-music-select:focus{border-color:var(--accent-primary)}.tl-music-range{width:100px}.tl-music-range-sep{color:var(--text-tertiary);font-size:.8rem}.tl-fade-btn{padding:.3rem .75rem;font-size:.7rem;font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-tertiary);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.tl-fade-btn:hover{border-color:var(--border-hover);color:var(--text-secondary)}.tl-fade-btn.active{background:#8b5cf626;border-color:#8b5cf666;color:#a78bfa}@media(max-width:600px){.tl-track-label{width:40px;min-width:40px;font-size:.6rem}.tl-music-controls{padding-left:40px;flex-direction:column;align-items:flex-start}}.paste-zone{position:relative;outline:2px dashed transparent;outline-offset:2px;border-radius:var(--radius-sm);transition:outline-color var(--transition-fast)}.paste-zone:focus{outline:none}.paste-zone-active{outline-color:var(--accent-primary)}.paste-zone-hint{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;font-size:.7rem;color:var(--accent-primary-light);background:#2563eb1a;border:1px solid rgba(37,99,235,.25);border-radius:var(--radius-full);white-space:nowrap;animation:paste-hint-fadein .2s ease}@keyframes paste-hint-fadein{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.paste-chooser-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:paste-overlay-in .15s ease}@keyframes paste-overlay-in{0%{opacity:0}to{opacity:1}}.paste-chooser-dialog{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;min-width:300px;max-width:420px;max-height:70vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.paste-chooser-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.paste-chooser-list{display:flex;flex-direction:column;gap:.5rem}.paste-chooser-card{display:block;width:100%;padding:.75rem 1rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;text-align:left;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.paste-chooser-card:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary)}.paste-chooser-cancel{margin-top:1rem;width:100%;text-align:center;color:var(--text-secondary)}.ai-prompt-title-area{margin-bottom:1.5rem}.ai-prompt-title-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.ai-prompt-title-input{width:100%;padding:.75rem 1rem;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-family:Noto Sans TC,Inter,sans-serif;outline:none;transition:border-color var(--transition-fast)}.ai-prompt-title-input:focus{border-color:var(--accent-primary)}.ai-prompt-title-input::placeholder{color:var(--text-muted)}.project-card-v2-name{cursor:pointer;transition:color var(--transition-fast)}.project-card-v2-name:hover{color:var(--accent-primary-light)}.project-card-v2-name-input{width:100%;padding:.25rem .5rem;background:var(--bg-glass);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:inherit;font-weight:600;font-family:inherit;outline:none}.ai-render-step{padding:1rem 0}.ai-render-header{margin-bottom:1.5rem}.ai-render-header h2{margin:0 0 .25rem;font-size:1.5rem;color:var(--text-primary)}.ai-render-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.ai-render-timeline-preview{margin-bottom:2rem}.ai-render-compose-section{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.ai-render-compose-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.ai-render-compose-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.ai-render-compose-status{font-size:.85rem;color:var(--text-secondary)}.ai-render-compose-actions{margin-bottom:1rem}.ai-render-preview-section{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;text-align:center}.ai-render-preview-section h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary)}.ai-render-video-wrapper{position:relative;width:100%;max-width:800px;margin:0 auto 1rem;border-radius:var(--radius-md);overflow:hidden;background:#000}.ai-render-final-video{width:100%;display:block;border-radius:var(--radius-md)}.ai-render-download-btn{margin-top:1rem;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.tl-playback-controls{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.5rem 0}.tl-play-btn{width:36px;height:36px;border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-glass);color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),border-color var(--transition-fast)}.tl-play-btn:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary)}.tl-play-btn.playing{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.tl-time-display{font-size:.85rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.tl-tracks-container{position:relative}.tl-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--accent-danger);z-index:10;pointer-events:none;transition:left .05s linear}.tl-playhead:before{content:"";position:absolute;top:-4px;left:-4px;width:10px;height:10px;background:var(--accent-danger);border-radius:var(--radius-full)}.tl-ruler-bar{cursor:pointer}
