:root{--color-charcoal: #202221;--color-maroon: #661E2A;--color-rust: #AB381B;--color-cream: #EAD4A3;--color-stone: #E3DED8;--bg-primary: var(--color-stone);--bg-secondary: var(--color-cream);--bg-tertiary: #ffffff;--bg-inverse: var(--color-charcoal);--text-primary: var(--color-charcoal);--text-secondary: #4a4a4a;--text-muted: #6b6b6b;--text-inverse: var(--color-stone);--accent: var(--color-maroon);--accent-hover: var(--color-rust);--accent-muted: rgba(102, 30, 42, .1);--accent-text: var(--color-maroon);--border: rgba(32, 34, 33, .15);--border-strong: rgba(32, 34, 33, .3);--shadow-sm: 0 1px 2px rgba(32, 34, 33, .05);--shadow-md: 0 4px 6px rgba(32, 34, 33, .07);--shadow-lg: 0 10px 15px rgba(32, 34, 33, .1);--color-success: #2d6a4f;--color-warning: var(--color-rust);--color-error: var(--color-maroon);--color-info: #1d3557}[data-theme=dark]{--bg-primary: var(--color-charcoal);--bg-secondary: #2a2c2b;--bg-tertiary: #353736;--bg-inverse: var(--color-stone);--text-primary: var(--color-stone);--text-secondary: var(--color-cream);--text-muted: #9a9a9a;--text-inverse: var(--color-charcoal);--accent: var(--color-rust);--accent-hover: var(--color-cream);--accent-muted: rgba(171, 56, 27, .15);--accent-text: var(--color-cream);--border: rgba(227, 222, 216, .1);--border-strong: rgba(227, 222, 216, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4);--color-success: #40916c;--color-warning: var(--color-cream);--color-error: #e63946;--color-info: #a8dadc}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg-primary: var(--color-charcoal);--bg-secondary: #2a2c2b;--bg-tertiary: #353736;--bg-inverse: var(--color-stone);--text-primary: var(--color-stone);--text-secondary: var(--color-cream);--text-muted: #9a9a9a;--text-inverse: var(--color-charcoal);--accent: var(--color-rust);--accent-hover: var(--color-cream);--accent-muted: rgba(171, 56, 27, .15);--accent-text: var(--color-cream);--border: rgba(227, 222, 216, .1);--border-strong: rgba(227, 222, 216, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4);--color-success: #40916c;--color-warning: var(--color-cream);--color-error: #e63946;--color-info: #a8dadc}}:root{--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem;--space-9: 6rem}:root{--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700}:root{--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px}:root{--duration-fast: .1s;--duration-normal: .15s;--duration-slow: .3s;--ease-default: ease-out;--ease-in-out: cubic-bezier(.4, 0, .2, 1)}:root{--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-tooltip: 600}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-none{flex:none}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.m-0{margin:var(--space-0)}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-5{margin:var(--space-5)}.m-6{margin:var(--space-6)}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-top:auto;margin-bottom:auto}.mt-0{margin-top:var(--space-0)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mb-0{margin-bottom:var(--space-0)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.ml-0{margin-left:var(--space-0)}.ml-1{margin-left:var(--space-1)}.ml-2{margin-left:var(--space-2)}.ml-3{margin-left:var(--space-3)}.ml-4{margin-left:var(--space-4)}.ml-auto{margin-left:auto}.mr-0{margin-right:var(--space-0)}.mr-1{margin-right:var(--space-1)}.mr-2{margin-right:var(--space-2)}.mr-3{margin-right:var(--space-3)}.mr-4{margin-right:var(--space-4)}.mr-auto{margin-right:auto}.p-0{padding:var(--space-0)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.px-1{padding-left:var(--space-1);padding-right:var(--space-1)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-5{padding-left:var(--space-5);padding-right:var(--space-5)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-5{padding-top:var(--space-5);padding-bottom:var(--space-5)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-full{max-width:100%}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-text)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.bg-accent{background-color:var(--accent)}.border{border:1px solid var(--border)}.border-strong{border:1px solid var(--border-strong)}.border-t{border-top:1px solid var(--border)}.border-b{border-bottom:1px solid var(--border)}.border-l{border-left:1px solid var(--border)}.border-r{border-right:1px solid var(--border)}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-none{box-shadow:none}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.transition{transition-property:color,background-color,border-color,box-shadow,opacity,transform;transition-duration:var(--duration-normal);transition-timing-function:var(--ease-default)}.transition-fast{transition-duration:var(--duration-fast)}.transition-slow{transition-duration:var(--duration-slow)}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{user-select:none}.select-text{user-select:text}.select-all{user-select:all}.filter-section{padding:0 0 var(--space-3) 0;border-bottom:1px solid var(--border);margin-bottom:var(--space-3)}.filter-group{margin-bottom:var(--space-3)}.filter-group:last-child{margin-bottom:0}.filter-label{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em}.filter-buttons{display:flex;flex-wrap:wrap;gap:var(--space-2)}.filter-btn{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);min-width:50px}.filter-btn:hover{border-color:var(--accent)}.filter-btn.active{border-color:var(--accent);background:var(--accent-muted)}.filter-btn .icon{font-size:var(--text-lg);margin-bottom:var(--space-1)}.filter-btn .label{font-size:var(--text-xs)}.filter-buttons.style-buttons .filter-btn{flex-direction:row;padding:var(--space-1) var(--space-2);min-width:auto}.filter-buttons.style-buttons .filter-btn .icon{margin-bottom:0;margin-right:var(--space-1)}.component-grid-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2);padding:0 var(--space-1)}.result-count{font-size:var(--text-xs);color:var(--text-muted)}.component-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-2)}.component-card{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:2px solid transparent;background:var(--bg-tertiary)}.component-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.component-thumbnail{aspect-ratio:16 / 9;background:#1a1a1a;position:relative}.component-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.placeholder-icon{font-size:var(--text-2xl);opacity:.5}.thumbnail-preview-canvas{position:absolute;top:0;left:0;width:100%;height:100%;display:block}.thumbnail-preview-viewport{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.thumbnail-preview-scene{width:1920px;height:1080px;transform-origin:top left;position:absolute;top:0;left:0;pointer-events:none}.asset-badge{position:absolute;top:var(--space-1);right:var(--space-1);font-size:9px;color:#fffc;background:#0009;padding:2px 4px;border-radius:var(--radius-sm);text-transform:uppercase}.component-info{padding:var(--space-1) var(--space-2);display:flex;justify-content:space-between;align-items:center}.component-name{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-primary);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.component-meta{font-size:10px;color:var(--text-muted)}@keyframes panel-highlight-pulse{0%{box-shadow:0 0 #6366f180}50%{box-shadow:0 0 0 4px #6366f14d}to{box-shadow:0 0 #6366f100}}.panel-highlight{animation:panel-highlight-pulse .8s ease-out 2}.asset-library-content{padding:var(--space-2);height:100%}.asset-drop-zone{border:2px dashed var(--border-strong);border-radius:var(--radius-md);padding:var(--space-2);min-height:80px;transition:all var(--duration-normal) var(--ease-default)}.asset-drop-zone.empty{display:flex;align-items:center;justify-content:center}.asset-drop-zone.drag-over{border-color:var(--accent);background:var(--accent-muted)}.drop-zone-message{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);color:var(--text-muted)}.drop-icon{font-size:var(--text-xl);font-weight:700;opacity:.5}.drop-text{font-size:var(--text-sm)}.drop-hint{font-size:var(--text-xs);opacity:.7}.asset-list{display:flex;flex-direction:column;gap:var(--space-1)}.asset-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1);border-radius:var(--radius-sm);background:var(--bg-tertiary);transition:background var(--duration-fast) var(--ease-default);cursor:pointer}.asset-item:hover{background:var(--bg-primary)}.asset-thumbnail{width:40px;height:28px;border-radius:var(--radius-sm);overflow:hidden;background:#1a1a1a;flex-shrink:0;display:flex;align-items:center;justify-content:center}.asset-thumbnail img{width:100%;height:100%;object-fit:cover}.asset-thumbnail.video-thumbnail{color:var(--text-muted);font-size:var(--text-xs)}.video-icon{opacity:.6}.asset-info{flex:1;min-width:0;display:flex;flex-direction:column}.asset-name{font-size:var(--text-xs);color:var(--text-primary);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.asset-meta{font-size:10px;color:var(--text-muted)}.asset-delete{padding:var(--space-1);color:var(--text-muted);font-size:var(--text-sm);opacity:0;transition:opacity var(--duration-fast) var(--ease-default)}.asset-item:hover .asset-delete{opacity:1}.asset-delete:hover{color:var(--color-error)}.asset-library-error{color:var(--color-error);font-size:var(--text-xs);margin-top:var(--space-2);text-align:center}.import-btn{font-size:var(--text-lg);font-weight:700;padding:var(--space-1) var(--space-2)}.asset-preview-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4)}.asset-preview-popup{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-width:90vw;max-height:90vh;overflow:hidden}.asset-preview-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);gap:var(--space-3)}.asset-preview-title{display:flex;flex-direction:column;min-width:0}.asset-preview-name{font-size:var(--text-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-preview-meta{font-size:var(--text-xs);color:var(--text-muted)}.asset-preview-close{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:18px;color:var(--text-muted);cursor:pointer;transition:color var(--duration-fast) var(--ease-default),background var(--duration-fast) var(--ease-default)}.asset-preview-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.asset-preview-body{display:flex;align-items:center;justify-content:center;overflow:hidden}.asset-preview-media{display:block;max-width:90vw;max-height:calc(90vh - 60px);object-fit:contain}.timeline-component{display:flex;flex-direction:column;gap:var(--space-2)}.timeline-blocks-area{display:flex;align-items:center;gap:var(--space-2);position:relative}.timeline-blocks{flex:1;position:relative;height:60px;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow-x:auto;overflow-y:hidden}.timeline-blocks::-webkit-scrollbar{height:4px}.timeline-blocks::-webkit-scrollbar-track{background:transparent}.timeline-blocks::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}.timeline-blocks-inner{position:relative;height:100%}.timeline-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--text-sm)}.timeline-block{position:absolute;display:flex;flex-direction:column;justify-content:center;padding:var(--space-1) var(--space-2);background:color-mix(in srgb,var(--block-color, var(--accent)) 25%,var(--bg-tertiary));border:1px solid color-mix(in srgb,var(--block-color, var(--accent)) 40%,transparent);border-radius:var(--radius-sm);cursor:grab;transition:background var(--duration-fast) var(--ease-default),border-color var(--duration-fast) var(--ease-default);min-width:40px;overflow:hidden;box-sizing:border-box}.timeline-block.layer-background{top:32px;height:24px}.timeline-block.layer-foreground{top:4px;height:24px}.timeline-block:hover,.timeline-block.selected{z-index:1;background:color-mix(in srgb,var(--block-color, var(--accent)) 50%,var(--bg-tertiary));border-color:var(--block-color, var(--accent))}.block-name{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--block-color, var(--text-primary));text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.block-duration{font-size:10px;color:var(--text-muted)}.block-delete{position:absolute;top:2px;right:2px;padding:2px 4px;font-size:10px;color:var(--text-muted);opacity:0;transition:opacity var(--duration-fast) var(--ease-default);border-radius:var(--radius-sm)}.timeline-block:hover .block-delete{opacity:1;color:var(--text-primary)}.block-delete:hover{background:#0003}body.timeline-dragging{cursor:grabbing!important;user-select:none}body.timeline-dragging *{cursor:grabbing!important}.timeline-block.dragging{opacity:.85;box-shadow:0 2px 8px #0000004d;z-index:10}.timeline-block.drag-invalid{opacity:.5;outline:2px dashed var(--color-error);outline-offset:-2px}@keyframes drag-reject-shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.timeline-block.drag-rejected{animation:drag-reject-shake .2s ease-in-out 2}.timeline-block.push-preview{opacity:.7;outline:1px dashed var(--accent);outline-offset:-1px}.timeline-insertion-caret{position:absolute;width:2px;background:var(--color-error);border-radius:1px;pointer-events:none;z-index:20;transition:left 30ms linear,top .1s ease-out}.timeline-insertion-caret:before{content:"";position:absolute;top:-3px;left:-3px;width:8px;height:8px;background:var(--color-error);border-radius:50%}.timeline-insertion-caret:after{content:"";position:absolute;bottom:-3px;left:-3px;width:8px;height:8px;background:var(--color-error);border-radius:50%}.timeline-marquee{position:absolute;border:1px dashed var(--accent);background:#6366f114;pointer-events:none;z-index:15;border-radius:2px}.timeline-block.marquee-hit{outline:2px solid var(--accent);outline-offset:-2px}body.timeline-selecting{cursor:crosshair!important;user-select:none}body.timeline-selecting *{cursor:crosshair!important}.timeline-add-btn{width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border);font-size:var(--text-xl);font-weight:700;color:var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--duration-fast) var(--ease-default)}.timeline-add-btn:hover{background:var(--accent-muted);border-color:var(--accent);color:var(--accent-text)}.timeline-zoom-controls{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.timeline-zoom-btn{width:24px;height:24px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border);font-size:var(--text-sm);font-weight:700;color:var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--duration-fast) var(--ease-default);cursor:pointer;line-height:1}.timeline-zoom-btn:hover:not(:disabled){background:var(--accent-muted);border-color:var(--accent);color:var(--accent-text)}.timeline-zoom-btn:disabled{opacity:.3;cursor:not-allowed}.timeline-controls{display:flex;align-items:center;gap:var(--space-3)}.timeline-controls .play-btn{width:32px;height:32px;flex-shrink:0}.timeline-controls .play-btn .icon-play,.timeline-controls .play-btn .icon-pause{pointer-events:none}.timeline-controls .timeline-scrubber{flex:1;padding:var(--space-3) 0;cursor:pointer}.timeline-controls .timeline-track{position:relative;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);cursor:pointer}.timeline-controls .timeline-progress{position:absolute;top:0;left:0;height:100%;width:0%;background:var(--accent);border-radius:var(--radius-full);pointer-events:none}.timeline-controls .timeline-handle{position:absolute;top:50%;left:0%;width:12px;height:12px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);cursor:grab;opacity:0;transition:opacity var(--duration-fast) var(--ease-default)}.timeline-controls .timeline-scrubber:hover .timeline-handle,.timeline-controls .timeline-handle:active{opacity:1}.timeline-controls .timeline-handle:active{cursor:grabbing}.timeline-controls .time-display{font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;min-width:80px;text-align:right}.timeline-controls .time-separator{margin:0 var(--space-1)}.component-info{margin-bottom:var(--space-4)}.component-title{font-size:var(--text-base);font-weight:var(--font-semibold);margin:0}.control-group{margin-bottom:var(--space-4)}.control-group-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-3) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.control-group-content{display:flex;flex-direction:column;gap:var(--space-3)}.asset-slot{display:flex;flex-direction:column;gap:var(--space-1)}.asset-slot-header{display:flex;align-items:center;gap:var(--space-2)}.required-badge{font-size:9px;text-transform:uppercase;color:var(--color-warning);background:#ab381b26;padding:2px 4px;border-radius:var(--radius-sm)}.asset-slot-hint{font-size:var(--text-xs);color:var(--text-muted);margin:var(--space-1) 0 0 0}.control{display:flex;flex-direction:column;gap:var(--space-1)}.control-header{display:flex;justify-content:space-between;align-items:center}.control-label{font-size:var(--text-sm);color:var(--text-primary)}.control-value{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.slider-input{width:100%;height:4px;appearance:none;background:var(--bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.slider-input::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:grab;transition:transform var(--duration-fast) var(--ease-default)}.slider-input::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider-input::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}.slider-input::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--accent);cursor:grab}.toggle-label{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.toggle-text{font-size:var(--text-sm)}.toggle-switch{position:relative;width:40px;height:22px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-tertiary);border-radius:var(--radius-full);transition:var(--duration-fast) var(--ease-default)}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:var(--text-muted);border-radius:50%;transition:var(--duration-fast) var(--ease-default)}.toggle-switch input:checked+.toggle-slider{background:var(--accent-muted)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px);background:var(--accent)}.text-input{width:100%;padding:var(--space-2);font-size:var(--text-sm);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary)}.text-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.textarea-input{width:100%;padding:var(--space-2);font-size:var(--text-sm);font-family:SF Mono,Fira Code,Menlo,Consolas,monospace;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);resize:vertical;line-height:1.5;tab-size:2}.textarea-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.color-input-wrapper{display:flex;align-items:center;gap:var(--space-2)}.color-input{width:40px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);cursor:pointer;background:none}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:1px solid var(--border);border-radius:var(--radius-sm)}.color-value{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-muted)}.select-input{width:100%;padding:var(--space-2);font-size:var(--text-sm);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer}.select-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.point2d-inputs{display:flex;gap:var(--space-2)}.point2d-input{flex:1;display:flex;align-items:center;gap:var(--space-1)}.point2d-label{font-size:var(--text-xs);color:var(--text-muted);min-width:16px}.point2d-input input{flex:1;width:100%;min-width:0;padding:var(--space-1) var(--space-2);font-size:var(--text-sm);font-family:var(--font-mono);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary)}.point2d-input input:focus{outline:none;border-color:var(--accent)}.control-thumbnail-select{gap:0;overflow:hidden;min-width:0;margin-left:calc(-1 * var(--space-3));margin-right:calc(-1 * var(--space-3))}.thumbnail-grid{display:grid;grid-template-columns:repeat(var(--thumb-columns, 1),1fr);gap:2px;min-width:0}.thumbnail-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-1) 0;border:2px solid transparent;border-radius:0;background:var(--bg-tertiary);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-default),background var(--duration-fast) var(--ease-default);font-family:inherit;color:inherit;min-width:0;overflow:hidden}.thumbnail-option:hover{border-color:var(--border-strong, var(--border));background:var(--bg-primary)}.thumbnail-option.selected{border-color:var(--accent);background:var(--accent-muted)}.thumbnail-canvas{width:100%;aspect-ratio:16 / 9;border-radius:0;background:#0a0a12;display:block}.thumbnail-label{font-size:var(--text-xs);color:var(--text-muted);text-align:center;line-height:var(--leading-tight, 1.25);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.thumbnail-option.selected .thumbnail-label{color:var(--accent-text, var(--accent));font-weight:var(--font-medium)}.control-group-hero{margin-bottom:var(--space-3)}.control-group-hero .control-group-content{gap:0}.layer-section{padding:var(--space-3);margin-bottom:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary)}.layer-section:last-child{margin-bottom:0}.layer-section.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-muted)}.layer-section-background{border-left:3px solid var(--color-background-layer, #6366f1)}.layer-section-foreground{border-left:3px solid var(--color-foreground-layer, #f59e0b)}.layer-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border);cursor:pointer}.layer-header:hover{opacity:.8}.layer-label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--bg-tertiary)}.layer-section-background .layer-label{color:var(--color-background-layer, #6366f1);background:#6366f11a}.layer-section-foreground .layer-label{color:var(--color-foreground-layer, #f59e0b);background:#f59e0b1a}.layer-header .component-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.project-menu{position:relative}.project-menu-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);max-width:200px}.project-menu-trigger:hover{border-color:var(--border-strong);background:var(--bg-primary)}.project-menu-trigger .project-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-menu-arrow{flex-shrink:0;font-size:var(--text-xs);color:var(--text-muted)}.project-menu-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:200px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden}.project-menu-list{max-height:200px;overflow-y:auto;padding:var(--space-1) 0}.project-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;text-align:left;transition:background var(--duration-fast) var(--ease-default)}.project-menu-item:hover{background:var(--bg-primary)}.project-menu-item.current{color:var(--accent-text);font-weight:var(--font-medium)}.project-menu-item .current-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-text);flex-shrink:0}.project-menu-item .project-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-menu-divider{height:1px;background:var(--border);margin:var(--space-1) 0}.project-menu-action{display:block;width:100%;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--text-muted);font-size:var(--text-sm);cursor:pointer;text-align:left;transition:all var(--duration-fast) var(--ease-default)}.project-menu-action:hover{background:var(--bg-primary);color:var(--text-primary)}.project-menu-action:disabled{opacity:.4;cursor:not-allowed}.project-menu-action:disabled:hover{background:none;color:var(--text-muted)}.tier-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border);text-decoration:none;cursor:pointer}.tier-badge.paid{background:var(--accent-muted);color:var(--accent-text);border-color:var(--accent)}.upgrade-prompt-content p{margin:0 0 var(--space-3);font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.upgrade-prompt-actions{display:flex;gap:var(--space-2)}.upgrade-prompt-actions .btn{flex:1}.upgrade-prompt-license-link{padding:0 var(--space-4) var(--space-4);margin:0;font-size:var(--text-xs);color:var(--text-muted);text-align:center}.upgrade-prompt-license-link a{color:var(--accent);text-decoration:none}.upgrade-prompt-license-link a:hover{text-decoration:underline}.license-input-modal .modal-header{display:flex;align-items:center;justify-content:space-between}.license-input-modal .modal-header h3{flex:1}.license-input-close{background:none;border:none;color:var(--text-muted);font-size:var(--text-xl);cursor:pointer;padding:0;line-height:1}.license-input-close:hover{color:var(--text-primary)}.license-status{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-3);background:var(--bg-tertiary);color:var(--text-secondary)}.license-status-paid{background:var(--accent-muted);color:var(--accent-text)}.license-input-label{display:block;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.license-input-field{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-mono);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);margin-bottom:var(--space-3);box-sizing:border-box}.license-input-field:focus{outline:none;border-color:var(--accent)}.license-input-error{font-size:var(--text-xs);color:var(--danger, #e74c3c);margin-bottom:var(--space-3)}.license-input-error.hidden{display:none}.license-active-message{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-3)}.license-input-content .btn{width:100%}.license-input-content .license-input-remove{margin-top:var(--space-2)}.export-plan-status{margin:0 0 var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.export-option{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) 0}.export-option+.export-option{border-top:1px solid var(--border)}.export-option label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.export-option select{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--space-1) var(--space-2);font-size:var(--text-sm);cursor:pointer}.export-option select:focus{outline:none;border-color:var(--accent)}.export-option select option:disabled{color:var(--text-muted)}.export-value{font-size:var(--text-sm);color:var(--text-primary)}.pro-badge{font-size:var(--text-xs);font-weight:700;color:var(--accent-text, #fff);background:var(--accent);padding:1px 6px;border-radius:var(--radius-sm);margin-left:var(--space-2);white-space:nowrap}.pro-badge.hidden{display:none}.export-done-text{font-size:var(--text-sm);color:var(--text-secondary);margin:0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%;display:flex;flex-direction:column}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-muted);color:var(--text-primary)}a{color:var(--accent-text);text-decoration:none;transition:color var(--duration-fast) var(--ease-default)}a:hover{color:var(--accent-hover)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}button:disabled{cursor:not-allowed;opacity:.5}input,textarea,select{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);transition:border-color var(--duration-fast) var(--ease-default),box-shadow var(--duration-fast) var(--ease-default)}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted);outline:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.logo{display:flex;align-items:center}.header-actions{display:flex;align-items:center;gap:var(--space-2)}.header-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.header-btn:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-primary)}.header-btn:disabled{opacity:.4;cursor:not-allowed}.app-main{display:grid;grid-template-columns:280px 1fr 300px;flex:1;min-height:0;overflow:hidden}.panel{display:flex;flex-direction:column;background:var(--bg-secondary);overflow:hidden}.panel-left{border-right:1px solid var(--border);display:flex;flex-direction:column}.panel-right{border-left:1px solid var(--border)}.panel-section{display:flex;flex-direction:column;overflow:hidden}.panel-section.component-library{flex:1;min-height:0}.panel-section.asset-library{flex:0 0 auto;max-height:220px;min-height:120px;border-top:1px solid var(--border)}.panel-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.panel-header h2{font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0}.panel-content{flex:1;overflow-y:auto;padding:var(--space-3)}.preview-area{display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:var(--space-4);overflow:hidden}.preview-canvas-wrapper{position:relative;width:100%;max-width:960px;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.preview-canvas-wrapper canvas{width:100%;height:100%;display:block}.preview-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.preview-empty-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--text-lg)}.preview-empty-state.hidden{display:none}.timeline-bar{padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0;min-height:100px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);text-align:center;height:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-default);cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--bg-primary)}.btn-icon-only{width:36px;height:36px;padding:0;border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon-only:hover:not(:disabled){background:var(--accent-muted);color:var(--accent-text)}.btn-icon{font-size:var(--text-base)}.btn-sm{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border)}.btn-sm:hover:not(:disabled){background:var(--accent-muted);border-color:var(--accent)}.modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop)}.modal-backdrop.hidden{display:none}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;margin:var(--space-4)}.modal-header{padding:var(--space-4);border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:var(--text-lg)}.modal-content{padding:var(--space-4)}.modal-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:var(--space-2)}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-3)}.progress-fill{height:100%;width:0%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--duration-normal) var(--ease-default)}.progress-text{font-size:var(--text-sm);color:var(--text-muted);text-align:center}
