.editor-app-container{flex-direction:column;background:var(--bg-primary)}.editor-app-container,.main-workspace{display:flex;height:100%;width:100%;overflow:hidden}.main-workspace{flex:1}.material-library{width:240px;min-width:200px;max-width:320px;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.library-header{padding:10px 12px;border-bottom:1px solid var(--border-subtle);justify-content:space-between}.library-header,.library-title{display:flex;align-items:center}.library-title{font-size:14px;font-weight:600;color:var(--text-primary);gap:8px;letter-spacing:-.01em}.library-title svg{color:var(--accent-primary);flex-shrink:0;filter:drop-shadow(0 0 4px rgba(168,85,247,.5));animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:rotate(0deg) scale(1)}50%{opacity:.8;transform:rotate(5deg) scale(1.05)}}.library-search{padding:8px 10px;border-bottom:1px solid var(--border-subtle);position:relative}.search-icon-library{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;z-index:1}.library-search input{width:100%;padding:6px 10px 6px 34px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:11px;transition:all var(--transition-fast)}.library-search input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.library-search input:focus~.search-icon-library{color:var(--accent-primary)}.library-filters{display:flex;gap:4px;padding:8px 10px;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary)}.filter-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 10px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-tab:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.filter-tab.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 2px 8px rgba(168,85,247,.3)}.filter-tab svg{flex-shrink:0}.filter-count{display:inline-block;min-width:18px;padding:2px 5px;background:rgba(0,0,0,.2);border-radius:10px;font-size:10px;text-align:center}.filter-tab.active .filter-count{background:hsla(0,0%,100%,.25)}.library-content{flex:1;overflow-y:auto;padding:8px}.material-category{margin-bottom:8px}.category-header{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);margin-bottom:6px}.category-header:hover{background:var(--bg-hover)}.category-title{font-size:11px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.category-title i{font-size:14px}.category-toggle{font-size:10px;color:var(--text-muted);transition:transform var(--transition-fast)}.category-toggle.collapsed{transform:rotate(-90deg)}.material-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 4px}.material-item{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:6px;cursor:grab;transition:all var(--transition-fast);position:relative;overflow:hidden}.material-item:before{content:"";position:absolute;inset:0;background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-fast)}.material-item:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px var(--accent-glow)}.material-item:hover:before{opacity:.05}.material-item:active{cursor:grabbing;transform:scale(.98)}.material-item.selected{border-color:var(--accent-primary);outline:2px solid var(--accent-primary);outline-offset:2px}.material-thumb{width:100%;aspect-ratio:16/10;background:var(--bg-hover);border-radius:var(--radius-sm);margin-bottom:5px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.material-thumb:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,transparent 30%,rgba(0,0,0,.3) 100%)}.material-thumb-text{font-size:10px;color:var(--text-muted);z-index:1}.material-color-preview{position:absolute;inset:0;opacity:.8;background-size:cover;background-position:50%;background-repeat:no-repeat;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.7}50%{opacity:.9}}.material-favorite-badge{position:absolute;top:4px;right:4px;width:20px;height:20px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 6px rgba(251,191,36,.4);z-index:2;animation:favoritePulse 2s ease-in-out infinite}@keyframes favoritePulse{0%,to{transform:scale(1);box-shadow:0 2px 6px rgba(251,191,36,.4)}50%{transform:scale(1.05);box-shadow:0 2px 10px rgba(251,191,36,.6)}}.material-name{font-size:10px;font-weight:600;color:var(--text-primary);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-props{font-size:9px;color:var(--text-muted);line-height:1.4}.material-duration{display:inline-flex;align-items:center;gap:4px;padding:3px 6px;background:var(--bg-active);border-radius:var(--radius-sm);font-size:10px;color:var(--text-secondary);margin-top:4px}.material-duration svg{flex-shrink:0;opacity:.7}.btn-with-icon{display:inline-flex!important;align-items:center;gap:6px}.btn-with-icon svg{flex-shrink:0}.btn-preparing,.btn:disabled{opacity:.6;cursor:not-allowed!important;pointer-events:auto}.btn-preparing:hover,.btn:disabled:hover{transform:none!important;box-shadow:none!important}.spin{animation:spin 1s linear infinite}.preview-header button{transition:all var(--transition-fast)}.preview-header button svg{transition:transform var(--transition-fast)}.preview-header button:hover:not(:disabled) svg{transform:scale(1.1)}.preview-play-btn{display:inline-flex;padding:8px!important}.preview-play-btn svg{flex-shrink:0}.material-extra{display:flex;flex-wrap:wrap;gap:4px;font-size:8px;color:var(--text-secondary);margin-top:4px}.material-remark{margin-top:4px;font-size:8px;color:var(--text-muted);line-height:1.4;max-height:24px;overflow:hidden;text-overflow:ellipsis}.editor-workspace{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden;min-width:0}.preview-properties-container{display:flex;flex-direction:row;min-height:150px;flex-shrink:0;border-bottom:1px solid var(--border-subtle)}.preview-area{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}.preview-header{padding:8px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.preview-title{font-size:12px;font-weight:600;color:var(--text-primary)}.preview-controls{display:flex;gap:6px}.preview-controls .btn{padding:4px 8px;font-size:10px}.preview-content{background:var(--bg-primary)}.preview-content,.vertical-video{flex:1;display:flex;overflow:hidden}.vertical-video{background:linear-gradient(180deg,#0a0a12,#12121a);position:relative;align-items:center;justify-content:center}#preview-area,.vertical-video{width:100%;height:100%}.vertical-video:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0,rgba(168,85,247,.1) 0,transparent 50%),radial-gradient(ellipse at 50% 100%,rgba(236,72,153,.1) 0,transparent 50%);pointer-events:none}.video-placeholder{color:var(--text-muted);text-align:center;z-index:1;width:100%;height:100%;overflow:hidden;position:relative;background:#000;justify-content:center}.compositing-indicator,.video-placeholder{font-size:14px;display:flex;align-items:center}.compositing-indicator{flex-direction:column;gap:12px;color:var(--text-secondary)}.compositing-spinner{width:40px;height:40px;border:3px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.preview-empty-hint{flex-direction:column;gap:16px;color:var(--text-muted);padding:40px 20px;text-align:center;max-width:400px;width:100%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2}.empty-icon-container,.preview-empty-hint{display:flex;align-items:center;justify-content:center}.empty-icon-container{position:relative;width:80px;height:80px;background:var(--bg-tertiary);border-radius:50%;border:2px solid var(--border-subtle)}.empty-sparkle-icon{color:var(--accent-primary);animation:sparkleFloat 3s ease-in-out infinite}@keyframes sparkleFloat{0%,to{transform:translateY(0) rotate(0deg);opacity:.6}50%{transform:translateY(-8px) rotate(5deg);opacity:1}}.empty-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.empty-description{margin:0;font-size:14px;color:var(--text-muted)}.empty-guide{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px;margin-top:12px}.guide-step{padding:12px 16px;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-fast);min-height:48px}.guide-step:hover{border-color:var(--accent-primary);transform:translateX(4px);box-shadow:0 2px 8px rgba(168,85,247,.2)}.step-number{width:18px;height:18px;min-width:18px;background:var(--accent-gradient);font-size:12px;box-shadow:0 2px 8px rgba(168,85,247,.4)}.guide-step span:last-child{color:var(--text-secondary);font-size:12px;font-weight:500;flex:1;text-align:left;line-height:1.4}.preview-playback-controls{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(transparent,rgba(0,0,0,.8));z-index:10}.preview-play-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);border:none;border-radius:50%;color:#fff;font-size:14px;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.preview-play-btn:hover{transform:scale(1.1);box-shadow:0 0 20px var(--accent-glow)}.preview-time{font-size:12px;color:#fff;font-variant-numeric:tabular-nums;min-width:100px;flex-shrink:0}.preview-progress-bar{flex:1;height:6px;background:hsla(0,0%,100%,.2);border-radius:3px;cursor:pointer;position:relative;transition:height .1s ease}.preview-progress-bar:hover{height:8px}.preview-progress-fill{height:100%;background:var(--accent-gradient);border-radius:3px}.preview-progress-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.3);opacity:1;transition:transform .1s ease}.preview-progress-bar:hover .preview-progress-handle{transform:translate(-50%,-50%) scale(1.2)}.preview-mute-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.15);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.preview-mute-btn:hover{background:hsla(0,0%,100%,.25);transform:scale(1.05)}.properties-area{width:240px;min-width:200px;max-width:300px;display:flex;flex-direction:column;background:var(--bg-secondary);flex-shrink:0;overflow:hidden}.properties-header{padding:0;border-bottom:1px solid var(--border-subtle)}.tab-navigation{display:flex;background:var(--bg-tertiary)}.tab{flex:1;padding:8px 10px;font-size:11px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border-bottom:2px solid transparent;text-align:center}.tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.tab.active{color:var(--text-primary);background:var(--bg-secondary);border-bottom-color:var(--accent-primary)}.properties-content{flex:1;padding:10px;overflow-y:auto}.properties-grid{display:flex;flex-direction:column;gap:10px}.property-source-badge{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,var(--accent-glow) 0,rgba(59,130,246,.08) 100%);border:1px solid var(--border-accent);border-radius:var(--radius-md);color:var(--accent-primary);font-size:13px;font-weight:500}.property-group{display:flex;flex-direction:column;gap:4px}.property-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.property-label{font-size:10px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.property-value{padding:5px 8px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:11px;color:var(--text-primary)}.property-value.shots-value{display:inline-flex;align-items:baseline;gap:6px;font-size:16px;font-weight:600;color:var(--accent-primary)}.shots-count{font-size:20px;font-weight:700;letter-spacing:.5px}.shots-unit{font-size:11px;color:var(--text-secondary)}.shots-hint{font-size:10px;color:var(--text-muted);margin-top:4px}.property-input{width:100%;padding:5px 8px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:11px;color:var(--text-primary);transition:all var(--transition-fast)}.property-input:hover{border-color:var(--border-strong)}.property-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.property-actions{display:flex;gap:6px;margin-top:6px}.property-actions .btn{padding:4px 8px;font-size:10px}.timeline-area{min-height:150px;display:flex;flex-direction:column;background:var(--bg-secondary);overflow:hidden}.timeline-header{padding:8px 12px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.timeline-title{font-size:12px;font-weight:600;color:var(--text-primary)}.timeline-actions{display:flex;align-items:center;gap:12px}.timeline-actions .btn{padding:4px 8px;font-size:10px}.undo-redo-group{display:flex;align-items:center;gap:4px;background:var(--bg-secondary);padding:3px;border-radius:var(--radius-sm)}.undo-redo-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.undo-redo-btn:hover:not(.disabled){background:var(--bg-tertiary);color:var(--text-primary)}.undo-redo-btn:active:not(.disabled){transform:scale(.95)}.undo-redo-btn.disabled{opacity:.3;cursor:not-allowed}.undo-redo-btn svg{width:16px;height:16px}.timeline-separator{width:1px;height:20px;background:var(--border-subtle)}.play-controls{gap:3px;background:var(--bg-secondary);padding:3px;border-radius:var(--radius-sm)}.play-btn,.play-controls{display:flex;align-items:center}.play-btn{width:26px;height:26px;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:12px}.play-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.play-btn.primary{background:var(--accent-gradient);color:#fff;width:28px;height:28px;border-radius:50%}.play-btn.primary:hover{box-shadow:var(--shadow-glow);transform:scale(1.05)}.timeline-controls{padding:6px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--text-secondary)}.zoom-controls{gap:6px;background:var(--bg-tertiary);padding:3px 6px;border-radius:var(--radius-sm)}.zoom-btn,.zoom-controls{display:flex;align-items:center}.zoom-btn{width:20px;height:20px;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:12px;font-weight:600}.zoom-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.zoom-btn:disabled{opacity:.35;cursor:not-allowed}.zoom-slider{width:80px;height:4px;-webkit-appearance:none;appearance:none;background:var(--bg-hover);border-radius:2px;outline:none;cursor:pointer}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer;transition:transform var(--transition-fast)}.zoom-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.zoom-slider::-moz-range-thumb{width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none}.granularity-controls{display:flex;align-items:center;gap:6px;background:var(--bg-tertiary);padding:3px 6px;border-radius:var(--radius-sm)}.granularity-text{color:var(--text-muted);font-size:10px}.granularity-label{min-width:48px;text-align:center;font-size:10px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.zoom-level{min-width:36px;text-align:center;font-size:10px;color:var(--text-muted)}.timeline-info{display:flex;align-items:center;gap:8px}.timeline-info-item{display:flex;align-items:center;gap:3px;padding:3px 6px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:10px}.timeline-info-label{color:var(--text-muted)}.timeline-info-value{color:var(--text-primary);font-weight:500}.track-controls{padding:6px 12px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:6px}.track-btn{padding:4px 8px;font-size:10px;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.track-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary)}.track-btn:disabled{opacity:.4;cursor:not-allowed}.track-btn:disabled:hover{background:var(--bg-secondary);border-color:var(--border-default);color:var(--text-secondary)}.track-btn.danger{color:var(--error);border-color:rgba(239,68,68,.3)}.track-btn.danger:hover{background:rgba(239,68,68,.1);border-color:var(--error)}.track-count{margin-left:auto;font-size:10px;color:var(--text-muted)}.timeline-container{flex:1;overflow-x:auto;overflow-y:auto;position:relative;background:var(--bg-primary)}.timeline-content{min-width:100%;padding:0;display:inline-block}.timeline-ruler{display:flex;height:28px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:20;padding-left:100px;white-space:nowrap}.ruler-mark{display:flex;align-items:flex-end;justify-content:flex-start;font-size:10px;color:var(--text-muted);border-left:1px solid var(--border-default);padding:0 0 4px 6px;position:relative;flex:0 0 auto}.ruler-mark.fine-mark{font-size:9px;color:var(--text-secondary);border-left-color:rgba(148,163,184,.3)}.ruler-mark.major-mark{color:var(--text-primary);border-left-color:var(--border-strong);font-weight:600}.ruler-mark.no-label{color:transparent;padding:0}.ruler-mark.no-label:before{height:4px;background:var(--border-default)}.ruler-mark.no-label.major-mark:before{height:6px;background:var(--border-strong)}.ruler-mark:before{content:"";position:absolute;left:0;bottom:0;width:1px;height:8px;background:var(--border-strong)}.timeline-rows{position:relative}.ruler-playhead{position:absolute;top:0;bottom:0;width:14px;transform:translateX(-7px);cursor:ew-resize;z-index:25;display:flex;flex-direction:column;align-items:center}.ruler-playhead-head{width:14px;height:14px;background:var(--accent-primary);clip-path:polygon(0 0,100% 0,100% 60%,50% 100%,0 60%);box-shadow:0 2px 8px rgba(168,85,247,.5);transition:transform .1s ease,box-shadow .1s ease}.ruler-playhead.dragging .ruler-playhead-head,.ruler-playhead:hover .ruler-playhead-head{transform:scale(1.15);box-shadow:0 2px 12px rgba(168,85,247,.7)}.ruler-playhead.dragging .ruler-playhead-head{background:linear-gradient(135deg,#a855f7,#ec4899)}.playhead{position:absolute;top:0;bottom:0;width:14px;transform:translateX(-7px);cursor:ew-resize;z-index:20;display:flex;justify-content:center}.playhead-line{width:2px;height:100%;background:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary),0 0 16px rgba(168,85,247,.3);transition:width .1s ease,box-shadow .1s ease}.playhead.dragging .playhead-line,.playhead:hover .playhead-line{width:3px;box-shadow:0 0 12px var(--accent-primary),0 0 24px rgba(168,85,247,.5)}.playhead.dragging .playhead-line{background:linear-gradient(180deg,#a855f7,#ec4899)}.timeline-row{display:flex;height:56px;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);white-space:nowrap}.timeline-row:hover{background:rgba(168,85,247,.02)}.row-label{width:100px;min-width:100px;gap:6px;font-size:11px;font-weight:600;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);position:sticky;left:0;z-index:999}.clear-track-btn,.row-label{display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.clear-track-btn{width:18px;height:18px;background:var(--bg-hover);border:1px solid var(--border-default);border-radius:50%;font-size:14px;line-height:1;cursor:pointer;transition:all var(--transition-fast);padding:0}.clear-track-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff;transform:scale(1.1)}.row-content{position:relative;min-height:100%;flex-shrink:0}.firework-drag-preview{position:absolute;top:4px;height:48px;border-radius:var(--radius-md);background:repeating-linear-gradient(45deg,rgba(168,85,247,.2),rgba(168,85,247,.2) 10px,rgba(168,85,247,.3) 0,rgba(168,85,247,.3) 20px);border:2px dashed var(--accent-primary);pointer-events:none;z-index:5;animation:dragPreviewPulse 1.5s ease-in-out infinite}@keyframes dragPreviewPulse{0%,to{opacity:.6}50%{opacity:.9}}.firework-drag-preview.shifted{background:repeating-linear-gradient(45deg,rgba(251,191,36,.2),rgba(251,191,36,.2) 10px,rgba(251,191,36,.3) 0,rgba(251,191,36,.3) 20px);border-color:#fbbf24}.drag-preview-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;color:#fbbf24;font-weight:600;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.8)}.drag-ghost-preview{display:flex;align-items:center;gap:8px;padding:8px 12px;background:linear-gradient(135deg,rgba(168,85,247,.95),rgba(139,92,246,.95));border-radius:8px;color:#fff;font-size:12px;font-weight:500;box-shadow:0 4px 12px rgba(0,0,0,.3);pointer-events:none;white-space:nowrap;backdrop-filter:blur(4px)}.drag-ghost-icon{font-size:16px;line-height:1}.drag-ghost-info{display:flex;flex-direction:column;gap:2px}.drag-ghost-name{font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis}.drag-ghost-duration{font-size:10px;opacity:.85}.firework-item{position:absolute;top:4px;height:48px;border-radius:var(--radius-md);cursor:move;transition:transform var(--transition-fast),box-shadow var(--transition-fast);overflow:hidden;user-select:none}.firework-item.video-clip{display:flex;flex-direction:column;background:var(--bg-tertiary);border:1px solid var(--border-default)}.video-clip-header{height:18px;padding:0 8px;display:flex;align-items:center;justify-content:space-between;font-size:10px;font-weight:600;flex-shrink:0}.video-clip-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff}.video-clip-time{font-size:9px;opacity:.8;margin-left:4px;color:hsla(0,0%,100%,.8)}.video-clip-thumbnails{flex:1;display:flex;background:rgba(0,0,0,.3);overflow:hidden}.video-thumbnail{flex:1;min-width:12px;border-right:1px solid rgba(0,0,0,.2);position:relative;background-size:cover;background-position:50%;background-repeat:no-repeat}.video-thumbnail:last-child{border-right:none}.firework-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);z-index:5}.firework-item.selected{border:2px solid var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow),var(--shadow-md);z-index:10}.firework-item.dragging{opacity:.9;transform:scale(1.02);box-shadow:var(--shadow-lg);z-index:100;cursor:grabbing}.clip-handle{position:absolute;top:0;bottom:0;width:6px;cursor:ew-resize;background:transparent;transition:background var(--transition-fast)}.clip-handle:hover{background:var(--accent-primary)}.clip-handle.left{left:0;border-radius:var(--radius-md) 0 0 var(--radius-md)}.clip-handle.right{right:0;border-radius:0 var(--radius-md) var(--radius-md) 0}.ai-panel{width:300px;min-width:260px;max-width:600px;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;position:relative;transition:none}.ai-panel.resizing{user-select:none}.ai-panel-resizer{position:absolute;left:0;top:0;bottom:0;width:4px;cursor:col-resize;background:transparent;z-index:10;transition:background .2s}.ai-panel-resizer:hover,.ai-panel.resizing .ai-panel-resizer{background:var(--accent-primary)}.ai-header{padding:10px 12px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);gap:8px}.ai-header,.ai-icon{display:flex;align-items:center}.ai-icon{width:26px;height:26px;justify-content:center;background:var(--accent-gradient);border-radius:var(--radius-sm);font-size:13px}.ai-title{font-size:12px;font-weight:600;color:var(--text-primary)}.ai-badge{padding:2px 6px;background:var(--accent-glow);color:var(--accent-primary);font-size:9px;font-weight:600;border-radius:var(--radius-sm);margin-left:auto}.ai-content{overflow:hidden}.ai-chat-messages,.ai-content{flex:1;display:flex;flex-direction:column}.ai-chat-messages{padding:12px;overflow-y:auto;gap:8px}.chat-message{max-width:95%;padding:10px 12px;border-radius:var(--radius-md);font-size:12px;line-height:1.5;animation:slideUp .2s ease}.chat-message strong{display:block;margin-bottom:3px;font-size:10px;font-weight:600}.user-message{align-self:flex-end;background:var(--accent-gradient);color:#fff;border-bottom-right-radius:var(--radius-sm)}.user-message strong{color:hsla(0,0%,100%,.8)}.ai-message{align-self:flex-start;background:var(--bg-tertiary);border:1px solid var(--border-subtle);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm)}.ai-message strong{color:var(--accent-primary)}.message-content{font-size:12px;line-height:1.5;word-wrap:break-word}.message-content>p{margin:0 0 6px}.message-content>p:last-child{margin-bottom:0}.md-paragraph{margin:0 0 6px;word-wrap:break-word}.md-paragraph:last-child{margin-bottom:0}.md-bold{font-weight:600;color:var(--text-primary)}.md-italic{font-style:italic}.md-heading{margin:10px 0 4px;font-weight:600;color:var(--accent-primary);line-height:1.3}.md-heading:first-child{margin-top:0}.md-h1{font-size:14px}.md-h2{font-size:13px}.md-h3{font-size:12px}.md-h4{font-size:11px;color:var(--text-secondary)}.md-list{margin:4px 0;padding-left:16px}.md-list-ordered{list-style-type:decimal}.md-list-item{margin:2px 0;line-height:1.5}.md-list .md-list{margin:2px 0}.md-code-inline{color:var(--accent-secondary);padding:1px 4px;border-radius:3px;font-family:Monaco,Menlo,Consolas,monospace;font-size:11px}.md-code-inline,.md-pre{background:var(--bg-primary)}.md-pre{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:8px;margin:6px 0;overflow-x:auto}.md-code-block{font-family:Monaco,Menlo,Consolas,monospace;font-size:11px;line-height:1.4;color:var(--text-secondary)}.md-blockquote{border-left:2px solid var(--accent-primary);margin:6px 0;padding:4px 0 4px 10px;color:var(--text-secondary);font-style:italic}.md-hr{border:none;border-top:1px solid var(--border-subtle);margin:10px 0}.md-br{display:block;height:4px}.streaming-text{white-space:pre-wrap;word-wrap:break-word;line-height:1.6}.streaming-cursor{display:inline-block;animation:blink .8s ease-in-out infinite;color:var(--accent-primary);margin-left:2px}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.ai-input-area{padding:8px 10px;background:var(--bg-tertiary);border-top:1px solid var(--border-subtle);display:flex;gap:6px}.ai-input{flex:1;padding:6px 10px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:11px;color:var(--text-primary);transition:all var(--transition-fast)}.ai-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.ai-input::placeholder{color:var(--text-muted)}.ai-send-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);font-size:13px}.ai-send-btn:hover{box-shadow:var(--shadow-glow);transform:scale(1.05)}.ai-controls{padding:8px 12px;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);display:flex;gap:6px}.ai-controls .btn{flex:1;padding:5px 8px;font-size:10px}.resizer{background:var(--border-subtle);position:relative;z-index:50;user-select:none;flex-shrink:0}.resizer:after{content:"";position:absolute;background:var(--accent-primary);opacity:0;transition:opacity var(--transition-fast)}.resizer.active:after,.resizer:hover:after{opacity:1}.resizer.vertical{width:1px;cursor:col-resize}.resizer.vertical:after{left:-2px;right:-2px;top:0;bottom:0}.resizer.horizontal{height:6px;cursor:row-resize;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.resizer.horizontal:hover{background:var(--bg-hover)}.resizer.horizontal:before{content:"";width:40px;height:4px;background:var(--border-strong);border-radius:2px;transition:background var(--transition-fast)}.resizer.horizontal:hover:before{background:var(--accent-primary)}.resizer.horizontal:after{top:-3px;bottom:-3px;left:0;right:0}@media (max-width:1400px){.material-library{width:180px}.ai-panel{width:220px}.properties-area{width:200px}}.generate-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.generate-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:450px;border:1px solid var(--border-default);box-shadow:var(--shadow-lg),0 0 40px var(--accent-glow);animation:scaleIn .2s ease}.generate-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.generate-modal-header h3{margin:0;font-size:15px;color:var(--text-primary)}.modal-close-btn{background:none;border:none;font-size:22px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;transition:color var(--transition-fast)}.modal-close-btn:hover{color:var(--text-primary)}.generate-modal-body{padding:18px}.generate-form-group{margin-bottom:14px}.generate-form-group label{display:block;margin-bottom:6px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.generate-input{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:12px;color:var(--text-primary);transition:all var(--transition-fast)}.generate-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.generate-textarea{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:12px;color:var(--text-primary);resize:vertical;min-height:60px}.generate-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.generate-info{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:12px;margin-bottom:14px}.info-row{display:flex;justify-content:space-between;padding:4px 0;font-size:11px}.info-row span{color:var(--text-muted)}.info-row strong{color:var(--text-primary)}.generate-notice{background:var(--accent-glow);border-left:3px solid var(--accent-primary);padding:10px 12px;border-radius:var(--radius-md)}.generate-notice p{margin:0;font-size:11px;color:var(--text-secondary);line-height:1.5}.generate-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid var(--border-subtle)}.generating-progress{text-align:center;padding:20px 0}.progress-icon{font-size:48px;margin-bottom:12px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.generating-progress h4{margin:0 0 16px;font-size:14px;color:var(--text-primary)}.progress-bar-container{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:10px}.progress-bar-fill{height:100%;background:var(--accent-gradient);border-radius:var(--radius-lg);transition:width .3s ease}.progress-text{margin:0;font-size:18px;font-weight:700;color:var(--accent-primary)}.progress-hint{margin:8px 0 0;font-size:11px;color:var(--text-muted)}@media (max-width:1200px){.material-grid{grid-template-columns:1fr}}.preview-toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.renderer-toggle{display:flex;align-items:center;gap:6px}.renderer-label{font-size:10px;color:var(--text-muted);margin-right:4px}.renderer-btn{padding:4px 10px;font-size:10px;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.renderer-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary)}.renderer-btn.active{background:var(--accent-gradient);border-color:var(--accent-primary);color:#fff}.stats-toggle{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:14px}.stats-toggle:hover{background:var(--bg-hover);border-color:var(--border-strong)}.stats-toggle.active{background:var(--accent-glow);border-color:var(--accent-primary)}.preview-stats{font-size:10px;font-weight:400;color:var(--text-muted);margin-left:12px;padding:3px 8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums}.preview-time-display{font-size:12px;margin-top:8px;color:var(--text-muted);text-align:center}.export-progress-bar{width:200px;background:hsla(0,0%,100%,.1);overflow:hidden;margin-top:12px}.export-progress-fill{background:var(--accent-gradient)}.blend-mode-selector{display:flex;align-items:center;gap:6px;margin-left:12px}.blend-mode-label{font-size:10px;color:var(--text-muted)}.blend-mode-select{padding:4px 8px;font-size:10px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.blend-mode-select:hover{border-color:var(--border-strong)}.blend-mode-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.quality-indicator{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:10px;color:var(--text-muted)}.quality-indicator.good{color:#22c55e}.quality-indicator.warning{color:#eab308}.quality-indicator.poor{color:#ef4444}.quality-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.compositor-info{position:absolute;top:8px;left:8px;padding:4px 8px;background:rgba(0,0,0,.7);border-radius:var(--radius-sm);font-size:10px;color:var(--text-secondary);z-index:10;display:flex;align-items:center;gap:6px}.compositor-info-icon{font-size:12px}.webgl-notice{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--accent-glow);border-radius:var(--radius-md);font-size:11px;color:var(--text-secondary);margin-bottom:8px}.webgl-notice-icon{font-size:14px}#preview-canvas{display:block;max-width:100%;max-height:100%;object-fit:contain;background:#000;border-radius:var(--radius-sm)}.preview-guide{padding:20px;background:linear-gradient(135deg,rgba(168,85,247,.1),rgba(236,72,153,.1));border:1px solid rgba(168,85,247,.3);border-radius:8px;margin:15px}.guide-step{display:flex;align-items:center;gap:12px;padding:10px 0;color:var(--text-primary)}.guide-step:not(:last-child){border-bottom:1px solid hsla(0,0%,100%,.1)}.step-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-radius:50%;font-weight:700;font-size:14px;flex-shrink:0}.step-text{font-size:13px;line-height:1.5}.preview-ready-hint{display:flex;align-items:center;gap:10px;padding:12px 20px;background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.3);border-radius:6px;margin:15px}.hint-icon{font-size:20px;flex-shrink:0}.hint-text{font-size:13px;color:#6ee7b7;font-weight:500}.preview-advanced-settings{padding:15px 20px;background:hsla(0,0%,100%,.03);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);margin:0 15px;border-radius:6px}.settings-section{margin-bottom:15px}.settings-section:last-child{margin-bottom:0}.settings-label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.settings-label input[type=checkbox]{margin-right:8px;cursor:pointer}.settings-hint{color:var(--text-muted);font-size:11px;font-weight:400;margin-left:5px}.preview-advanced-settings .renderer-toggle{display:flex;gap:8px;flex-wrap:wrap}.preview-advanced-settings .renderer-btn{padding:6px 12px;font-size:12px;background:hsla(0,0%,100%,.05);border:1px solid var(--border-default);color:var(--text-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.preview-advanced-settings .renderer-btn:hover{background:hsla(0,0%,100%,.1);border-color:var(--border-strong);color:var(--text-primary)}.preview-advanced-settings .renderer-btn.active{background:linear-gradient(135deg,#a855f7,#ec4899);border-color:#a855f7;color:#fff;font-weight:600}.btn-large{padding:12px 24px!important;font-size:15px!important;min-width:140px}.btn-outline{background:transparent;border:1px solid var(--border-default);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--border-strong);color:var(--text-primary)}.btn-icon,.btn-outline:hover{background:hsla(0,0%,100%,.05)}.btn-icon{padding:8px 12px;font-size:16px;border:1px solid var(--border-default);color:var(--text-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.btn-icon:hover{background:hsla(0,0%,100%,.1);color:var(--text-primary)}.btn-icon.active{background:rgba(168,85,247,.2);border-color:#a855f7;color:#a855f7}.global-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease}.global-loading-content{text-align:center;padding:40px 60px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-lg),0 0 60px var(--accent-glow);min-width:320px;max-width:480px}.loading-spinner-large{width:64px;height:64px;margin:0 auto 24px;border-top:4px solid var(--border-subtle);border:4px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.global-loading-content h3{margin:0 0 12px;font-size:18px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.global-loading-content p{margin:0;font-size:14px;color:var(--text-muted);line-height:1.6}@media (max-width:1200px){.preview-guide{padding:15px;margin:10px}.guide-step{padding:8px 0}.step-text{font-size:12px}.preview-ready-hint{padding:10px 15px;margin:10px}}.export-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:modalFadeIn .3s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.export-modal-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 64px;background:linear-gradient(135deg,rgba(30,30,40,.95),rgba(20,20,30,.98));border-radius:20px;border:1px solid rgba(139,92,246,.2);box-shadow:0 0 60px rgba(139,92,246,.15),0 20px 40px rgba(0,0,0,.4);min-width:320px}.export-loader{position:relative;width:100px;height:100px;margin-bottom:24px}.export-loader-svg{width:100%;height:100%;transform:rotate(-90deg)}.export-loader-bg{stroke:rgba(139,92,246,.15)}.export-loader-progress{stroke:url(#progressGradient);stroke:#8b5cf6;transition:stroke-dashoffset .3s ease;filter:drop-shadow(0 0 6px rgba(139,92,246,.5))}.export-loader-dot{transform-origin:50px 50px;animation:dotRotate 2s linear infinite}@keyframes dotRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.export-loader-percent{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.export-modal-title{font-size:20px;font-weight:600;color:#fff;margin:0 0 12px;letter-spacing:.5px}.export-stage{display:flex;align-items:center;gap:4px;font-size:14px;color:hsla(0,0%,100%,.6);margin-bottom:20px}.export-stage-text{color:hsla(0,0%,100%,.7)}.export-stage-dots{display:inline-flex;gap:3px;margin-left:2px}.export-stage-dots .dot{width:4px;height:4px;border-radius:50%;background:rgba(139,92,246,.8);animation:stageDotBounce 1.4s ease-in-out infinite}.export-stage-dots .dot:first-child{animation-delay:0s}.export-stage-dots .dot:nth-child(2){animation-delay:.2s}.export-stage-dots .dot:nth-child(3){animation-delay:.4s}@keyframes stageDotBounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-5px);opacity:1}}.export-progress-container{width:100%;margin-bottom:24px}.export-progress-bar{position:relative;height:6px;background:rgba(139,92,246,.15);border-radius:3px;overflow:visible}.export-progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa 50%,#c4b5fd);border-radius:3px;transition:width .3s ease;position:relative}.export-progress-glow{position:absolute;top:50%;width:12px;height:12px;background:#a78bfa;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px 4px rgba(139,92,246,.6);animation:glowPulse 1.5s ease-in-out infinite}@keyframes glowPulse{0%,to{box-shadow:0 0 8px 2px rgba(139,92,246,.4);transform:translate(-50%,-50%) scale(.9)}50%{box-shadow:0 0 16px 6px rgba(139,92,246,.7);transform:translate(-50%,-50%) scale(1.1)}}.export-modal-hint{font-size:13px;color:hsla(0,0%,100%,.4);margin:0;max-width:280px;line-height:1.5}.exporting-modal-overlay{display:none}.cache-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;border-radius:inherit}.cache-loading-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-primary)}.cache-loading-content svg{color:var(--accent-primary);animation:spin 1s linear infinite}.cache-loading-text{font-size:14px;color:var(--text-secondary)}.cache-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease}.cache-modal-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 64px;background:linear-gradient(135deg,rgba(30,30,40,.95),rgba(20,20,30,.98));border-radius:20px;border:1px solid rgba(139,92,246,.2);box-shadow:0 0 60px rgba(139,92,246,.15),0 20px 40px rgba(0,0,0,.4)}.cache-loader{position:relative;width:80px;height:80px;margin-bottom:28px}.cache-loader-ring{position:absolute;inset:0;border-radius:50%;border:2px solid transparent;animation:ring-spin 2s linear infinite}.cache-loader-ring:first-child{border-top-color:#8b5cf6;animation-delay:0s}.cache-loader-ring:nth-child(2){inset:8px;border-right-color:#a78bfa;animation-delay:.15s;animation-direction:reverse}.cache-loader-ring:nth-child(3){inset:16px;border-bottom-color:#c4b5fd;animation-delay:.3s}.cache-loader-core{position:absolute;inset:24px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#6d28d9);animation:core-pulse 1.5s ease-in-out infinite;box-shadow:0 0 20px rgba(139,92,246,.5)}@keyframes ring-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes core-pulse{0%,to{transform:scale(.8);opacity:.7}50%{transform:scale(1);opacity:1}}.cache-modal-title{font-size:20px;font-weight:600;color:#fff;margin:0 0 12px;letter-spacing:.5px}.cache-loading-dots{display:flex;align-items:center;gap:4px;font-size:14px;color:hsla(0,0%,100%,.6);margin-bottom:24px}.cache-loading-dots .dots{display:inline-flex;gap:2px;margin-left:2px}.cache-loading-dots .dot{width:4px;height:4px;border-radius:50%;background:rgba(139,92,246,.8);animation:dot-bounce 1.4s ease-in-out infinite}.cache-loading-dots .dot:first-child{animation-delay:0s}.cache-loading-dots .dot:nth-child(2){animation-delay:.2s}.cache-loading-dots .dot:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}.cache-modal-hint{font-size:13px;color:hsla(0,0%,100%,.4);margin:0;max-width:280px;line-height:1.5}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:confirmModalFadeIn .2s ease}@keyframes confirmModalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes confirmModalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-modal-content{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 40px;background:linear-gradient(135deg,rgba(35,35,45,.98),rgba(25,25,35,.99));border-radius:16px;border:1px solid hsla(0,0%,100%,.08);box-shadow:0 0 40px rgba(0,0,0,.4),0 16px 32px rgba(0,0,0,.3);min-width:320px;max-width:420px;animation:confirmModalSlideIn .25s ease}.confirm-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:hsla(0,0%,100%,.4);cursor:pointer;transition:all .15s ease}.confirm-modal-close:hover{background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.8)}.confirm-modal-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:rgba(251,191,36,.1);border-radius:50%;margin-bottom:16px;color:#fbbf24}.confirm-modal-icon.danger{background:rgba(239,68,68,.1);color:#ef4444}.confirm-modal-title{font-size:18px;font-weight:600;color:#fff;margin:0 0 8px;letter-spacing:.3px}.confirm-modal-message{font-size:14px;color:hsla(0,0%,100%,.6);margin:0 0 24px;line-height:1.6;max-width:300px}.confirm-modal-actions{display:flex;gap:12px;width:100%}.confirm-modal-btn{flex:1;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;border:none}.confirm-modal-btn.cancel{background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.8);border:1px solid hsla(0,0%,100%,.1)}.confirm-modal-btn.cancel:hover{background:hsla(0,0%,100%,.12);color:#fff}.confirm-modal-btn.confirm{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:1px solid rgba(139,92,246,.3);box-shadow:0 2px 8px rgba(139,92,246,.3)}.confirm-modal-btn.confirm:hover{background:linear-gradient(135deg,#9f75ff,#8b5cf6);box-shadow:0 4px 12px rgba(139,92,246,.4)}.confirm-modal-btn.confirm.danger{background:linear-gradient(135deg,#ef4444,#dc2626);border:1px solid rgba(239,68,68,.3);box-shadow:0 2px 8px rgba(239,68,68,.3)}.confirm-modal-btn.confirm.danger:hover{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 4px 12px rgba(239,68,68,.4)}