html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;background:#1a1a1a;color:#ddd;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;position:relative}.timeline-panel{position:fixed;bottom:0;left:0;right:0;height:300px;background:#1a1a1a;border-top:2px solid #333;z-index:1000;box-shadow:0 -4px 12px #00000080}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:260px;min-width:260px;background:#252525;border-right:1px solid #444;display:flex;flex-direction:column;overflow:hidden}.sidebar-tabs{flex-shrink:0;border-bottom:1px solid #333}.tab-bar{display:flex;background:#1e1e1e}.tab-button{flex:1;background:transparent;border:none;color:#888;padding:12px 16px;cursor:pointer;font-size:13px;font-weight:500;border-bottom:2px solid transparent;transition:all .2s}.tab-button:hover{color:#aaa;background:#252525}.tab-button.active{color:#4a9eff;border-bottom-color:#4a9eff}.sidebar-content{flex:1;overflow-y:auto;padding:8px}.sidebar-content::-webkit-scrollbar{width:8px}.sidebar-content::-webkit-scrollbar-track{background:#1a1a1a}.sidebar-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#555}.canvas-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.canvas-container{flex:1;position:relative;background:#000;overflow:hidden;min-height:0}.fractal-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.error-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center}.error-message{background:#2a2a2a;border:1px solid #f44;border-radius:8px;padding:20px 30px;max-width:400px;text-align:center}.error-message h3{color:#f66;margin:0 0 10px}.error-message p{color:#aaa;margin:0}.loading-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;color:#888;font-size:14px}@media(max-width:800px){.sidebar{width:220px;min-width:220px}}@media(max-width:600px){.main-content{flex-direction:column}.sidebar{width:100%;min-width:100%;height:40%;border-right:none;border-bottom:1px solid #444}}.toolbar{display:flex;align-items:center;background:#333;border-bottom:1px solid #444;padding:4px 8px;gap:4px}.toolbar-group{display:flex;gap:2px}.toolbar-separator{width:1px;height:24px;background:#555;margin:0 6px}.toolbar button{width:32px;height:28px;background:#444;border:1px solid #555;color:#ccc;font-size:14px;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center}.toolbar button:hover{background:#555;color:#fff}.toolbar button:active{background:#333}.toolbar button.active{background:#556;border-color:#668;color:#fff}.toolbar button:disabled{opacity:.4;cursor:not-allowed}.panel{background:#2a2a2a;border:1px solid #444;border-radius:4px;margin-bottom:8px}.panel-header{background:#3a3a3a;padding:8px 12px;font-weight:700;font-size:12px;color:#ddd;border-bottom:1px solid #444;-webkit-user-select:none;user-select:none}.panel-content{padding:8px 12px}.control-row{display:flex;align-items:center;margin-bottom:8px;gap:8px}.control-row:last-child{margin-bottom:0}.control-row label{flex:0 0 80px;font-size:11px;color:#aaa}.control-row input[type=range]{flex:1;height:4px;-webkit-appearance:none;background:#555;border-radius:2px;outline:none}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#888;border-radius:50%;cursor:pointer}.control-row input[type=range]::-webkit-slider-thumb:hover{background:#aaa}.control-row .value{flex:0 0 40px;font-size:11px;color:#888;text-align:right;font-family:monospace}.control-row input[type=number]{width:60px;background:#333;border:1px solid #555;color:#ddd;padding:4px 6px;font-size:11px;border-radius:3px}.control-row input[type=number]:focus{border-color:#777;outline:none}.color-picker{width:60px;height:24px;padding:0;border:1px solid #555;border-radius:3px;cursor:pointer}.panel-buttons{display:flex;gap:4px;margin-top:8px}.panel-buttons button{flex:1;padding:6px 8px;background:#444;border:1px solid #555;color:#ddd;font-size:11px;border-radius:3px;cursor:pointer}.panel-buttons button:hover{background:#555}.panel-buttons button:active{background:#333}.panel-buttons button:disabled{opacity:.5;cursor:not-allowed}.control-row select{flex:1;background:#333;border:1px solid #555;color:#ddd;padding:4px 6px;font-size:11px;border-radius:3px}.control-row select:focus{border-color:#777;outline:none}.branch-list{max-height:150px;overflow-y:auto;background:#222;border:1px solid #444;border-radius:3px;margin-bottom:8px}.branch-item{padding:6px 10px;cursor:pointer;font-size:11px;display:flex;align-items:center;gap:8px;border-bottom:1px solid #333}.branch-item:last-child{border-bottom:none}.branch-item:hover{background:#333}.branch-item.selected{background:#445}.branch-color{width:12px;height:12px;border-radius:2px;border:1px solid #666}.branch-name{flex:1}.branch-weight{color:#888;font-family:monospace}.variation-list{display:flex;flex-direction:column;gap:6px}.variation-row{display:flex;align-items:center;gap:6px}.variation-row select{flex:1;min-width:0}.variation-row input[type=number]{width:50px}.variation-row button{padding:4px 8px;background:#444;border:1px solid #555;color:#999;font-size:11px;border-radius:3px;cursor:pointer}.variation-row button:hover{background:#555;color:#ddd}.chroma-picker{width:100%;aspect-ratio:1;background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);border:1px solid #555;border-radius:3px;position:relative;cursor:crosshair;margin-bottom:8px}.chroma-picker:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.5) 0%,transparent 50%,rgba(0,0,0,.5) 100%)}.chroma-marker{position:absolute;width:10px;height:10px;border:2px solid white;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1px #000;pointer-events:none;z-index:1}.affine-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:8px}.affine-grid .control-cell{display:flex;flex-direction:column;gap:2px}.affine-grid .control-cell label{font-size:10px;color:#666}.affine-grid .control-cell input{width:100%;background:#333;border:1px solid #555;color:#ddd;padding:4px;font-size:11px;border-radius:3px;font-family:monospace}.library-list{max-height:200px;overflow-y:auto;background:#222;border:1px solid #444;border-radius:3px}.library-item{padding:8px 10px;cursor:pointer;font-size:11px;border-bottom:1px solid #333}.library-item:last-child{border-bottom:none}.library-item:hover{background:#333}.library-item.selected{background:#445}.tab-bar{display:flex;background:#2a2a2a;border-bottom:1px solid #444}.tab-button{flex:1;padding:8px 12px;background:transparent;border:none;color:#888;font-size:11px;cursor:pointer;border-bottom:2px solid transparent}.tab-button:hover{color:#aaa;background:#333}.tab-button.active{color:#ddd;border-bottom-color:#668}.transform-tabs{display:flex;gap:2px;margin-bottom:8px}.transform-tab{padding:4px 12px;background:#333;border:1px solid #444;color:#888;font-size:11px;cursor:pointer;border-radius:3px 3px 0 0}.transform-tab:hover{background:#444;color:#aaa}.transform-tab.active{background:#445;color:#ddd;border-bottom-color:#445}.subsection{margin-top:12px;padding-top:8px;border-top:1px solid #444}.subsection-title{font-size:11px;color:#888;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.transform-overlay{position:absolute;top:0;left:0;pointer-events:all;cursor:crosshair;touch-action:none;user-select:none;-webkit-user-select:none}.transform-overlay.dragging{cursor:grabbing}.status-bar{display:flex;justify-content:space-between;align-items:center;background:#2a2a2a;border-top:1px solid #444;padding:4px 12px;font-size:11px;color:#888}.status-text{flex:1}.status-info{color:#666;font-family:monospace}.timeline-container{display:flex;flex-direction:column;background:#1a1a1a;height:100%;overflow:hidden;position:relative}.timeline-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#222;border-bottom:1px solid #333}.timeline-controls{display:flex;align-items:center;gap:12px}.timeline-controls button{background:#333;border:1px solid #444;color:#fff;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:14px}.timeline-controls button:hover{background:#444}.time-display{font-family:monospace;font-size:14px;color:#fff}.duration-display{font-family:monospace;font-size:12px;color:#888}.timeline-settings{display:flex;gap:16px;align-items:center}.timeline-settings label{display:flex;align-items:center;gap:6px;font-size:12px;color:#aaa}.timeline-settings input[type=number]{width:60px;background:#333;border:1px solid #444;color:#fff;padding:4px 6px;border-radius:3px}.timeline-settings input[type=range]{width:100px}.timeline-tracks{flex:1;overflow-y:auto;overflow-x:auto;position:relative;min-height:0}.timeline-track{display:flex;border-bottom:1px solid #2a2a2a;height:40px}.track-header{display:flex;align-items:center;justify-content:space-between;width:200px;min-width:200px;padding:0 12px;background:#1e1e1e;border-right:1px solid #333}.track-name{font-size:11px;color:#aaa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.add-key-btn{background:#333;border:1px solid #444;color:#fff;width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;padding:0}.add-key-btn:hover{background:#444}.track-timeline{position:relative;flex:1;background:repeating-linear-gradient(90deg,#1a1a1a 0px 99px,#2a2a2a 99px 100px)}.keyframe{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;color:#4a9eff;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:16px;line-height:12px;text-align:center}.keyframe:hover{color:#6ab4ff;transform:translate(-50%,-50%) scale(1.2)}.keyframe.selected{color:#ff9500}.playhead{position:fixed;top:auto;bottom:0;height:300px;width:2px;background:#ff3b30;pointer-events:none;z-index:1001;transform:translate(200px)}.playhead:before{content:"";position:absolute;top:0;left:-4px;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:8px solid #ff3b30}.keyframe-editor{position:absolute;bottom:0;right:0;width:300px;background:#222;border-left:1px solid #333;border-top:1px solid #333;padding:12px;max-height:200px;overflow-y:auto}.keyframe-editor h4{margin:0 0 12px;font-size:14px;color:#fff}.keyframe-editor p{margin:4px 0;font-size:12px;color:#aaa}.keyframe-editor label{display:block;margin:8px 0;font-size:12px;color:#aaa}.keyframe-editor input{width:100%;background:#333;border:1px solid #444;color:#fff;padding:6px;border-radius:3px;margin-top:4px;font-family:monospace;font-size:11px}.keyframe-editor button{background:#d32f2f;border:none;color:#fff;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;margin-top:8px}.keyframe-editor button:hover{background:#f44336}.video-export{background:#1e1e1e;border:1px solid #333;border-radius:8px;padding:20px;max-width:600px}.video-export h3{margin:0 0 20px;font-size:18px;color:#fff}.export-settings{display:flex;flex-direction:column;gap:16px}.setting-group{display:flex;flex-direction:column;gap:6px}.setting-group label{font-size:13px;font-weight:500;color:#aaa}.setting-group select,.setting-group input[type=number]{background:#2a2a2a;border:1px solid #444;color:#fff;padding:8px 12px;border-radius:4px;font-size:14px}.setting-group select:disabled,.setting-group input:disabled{opacity:.5;cursor:not-allowed}.setting-group small{font-size:11px;color:#666}.resolution-inputs{display:flex;align-items:center;gap:8px}.resolution-inputs input{flex:1}.resolution-inputs span{color:#666;font-size:14px}.export-info{background:#252525;border:1px solid #333;border-radius:4px;padding:12px}.export-info p{margin:4px 0;font-size:13px;color:#aaa}.export-info strong{color:#fff}.export-button{background:#4a9eff;border:none;color:#fff;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.export-button:hover:not(:disabled){background:#6ab4ff}.export-button:disabled{background:#333;cursor:not-allowed}.export-progress{margin-top:8px}.progress-bar{width:100%;height:8px;background:#2a2a2a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4a9eff,#6ab4ff);transition:width .3s ease}.export-help{margin-top:24px;padding-top:20px;border-top:1px solid #333}.export-help h4{margin:0 0 12px;font-size:14px;color:#fff}.export-help p{margin:0 0 8px;font-size:12px;color:#aaa}.export-help code{display:block;background:#252525;border:1px solid #333;border-radius:4px;padding:12px;font-family:Courier New,monospace;font-size:11px;color:#4a9eff;overflow-x:auto;white-space:pre-wrap;word-break:break-all}
