@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Sora:wght@300;400;500;600;700&display=swap";:root{color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-moz-text-size-adjust:100%;text-size-adjust:100%;--font-display:"Space Grotesk","Trebuchet MS",sans-serif;--bg:#0b0d12;--panel:#10131ce6;--panel-strong:#131721f2;--text:#f4f6fb;--text-muted:#9aa3b2;--accent:#f2a63b;--accent-2:#4bd0ff;--accent-3:#ff7a70;--accent-4:#fff;--border:#ffffff1a;--shadow:0 18px 44px #02060c73;--radius:18px;font-family:Sora,Segoe UI,sans-serif;font-weight:400;line-height:1.5}:root.light{--bg:#f5f7fa;--panel:#fffffff2;--panel-strong:#f5f7fafa;--text:#1a1d24;--text-muted:#5c6370;--accent:#d4890a;--accent-2:#0090c7;--accent-3:#d94e45;--accent-4:#fff;--border:#0000001a;--shadow:0 18px 44px #0000001f}*,:before,:after{box-sizing:border-box}body{background:radial-gradient(circle at top left,#4bd0ff1f,transparent 40%),radial-gradient(circle at 20% 80%,#f2a63b1f,transparent 45%),radial-gradient(circle at 90% 20%,#ff7a701f,transparent 40%),var(--bg);min-height:100vh;color:var(--text);margin:0;transition:background .3s,color .3s}.light body,:root.light body{background:radial-gradient(circle at top left,#4bd0ff14,transparent 40%),radial-gradient(circle at 20% 80%,#f2a63b14,transparent 45%),radial-gradient(circle at 90% 20%,#ff7a7014,transparent 40%),var(--bg)}img{max-width:100%;display:block}button,input,textarea,select{font:inherit}#root{min-height:100vh}*{scrollbar-width:thin;scrollbar-color:#fff3 transparent}.light *{scrollbar-color:#0003 transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.light ::-webkit-scrollbar-thumb{background:#0003}.light ::-webkit-scrollbar-thumb:hover{background:#0000004d}input[type=range]{appearance:none;background:0 0}input[type=range]::-moz-range-track{background:var(--border);border:none;border-radius:3px;height:6px}input[type=range]::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}input[type=range]::-moz-range-progress{background:var(--accent);border-radius:3px;height:6px}input[type=range]::-webkit-slider-runnable-track{background:var(--border);border-radius:3px;height:6px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px;margin-top:-5px}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa3b2' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}button{appearance:none}::placeholder{color:var(--text-muted);opacity:1}::-webkit-input-placeholder{color:var(--text-muted)}::-moz-placeholder{color:var(--text-muted);opacity:1}:-ms-placeholder-shown{color:var(--text-muted)}@supports (-webkit-touch-callout:none){.topbar{position:sticky}.btn+.btn{margin-left:8px}html{-webkit-overflow-scrolling:touch}input[type=text],input[type=number],select,textarea{font-size:16px}}@-moz-document url-prefix(){.left-panel,.right-panel{scrollbar-gutter:stable}html{scroll-behavior:smooth}button{text-align:center}}@supports not (gap:1px){.workspace>*+*{margin-left:20px}.panel>*+*{margin-top:18px}.topbar>*+*{margin-left:10px}.history-controls>*+*{margin-left:6px}.project-controls>*+*{margin-left:10px}}@media print{.topbar,.left-panel,.right-panel,.timeline{display:none!important}.workspace{display:block}.center-panel{width:100%}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px #4bd0ff33}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.layer-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;background:#4bd0ff1a}[role=button]:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{background:var(--accent);color:var(--bg);z-index:100;border-radius:0 0 8px;padding:8px 16px;font-weight:600;transition:top .2s;position:absolute;top:-40px;left:0}.skip-link:focus{top:0}.app{grid-template-rows:auto 1fr auto;gap:0;height:100vh;min-height:100vh;display:grid;overflow:hidden}.drop-overlay{z-index:50;text-align:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;background:#080a0fbf;border:2px dashed #4bd0ff99;place-items:center;display:grid;position:fixed;inset:0}.drop-overlay h3{font-family:var(--font-display);margin:0 0 6px}.drop-overlay p{color:var(--text-muted);margin:0;font-size:.9rem}.topbar{border-bottom:1px solid var(--border);z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(120deg,#12161eeb,#0a0c12fa);justify-content:space-between;align-items:center;padding:20px 28px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.brand-mark{background:conic-gradient(from 120deg,#f2a63b,#4bd0ff,#ff7a70,#f2a63b);border-radius:14px;width:44px;height:44px;box-shadow:0 12px 28px #00000073}.brand-title{font-family:var(--font-display);margin:0;font-size:1.05rem;font-weight:600}.brand-sub{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.75rem}.project{gap:6px;min-width:220px;display:grid}.project label{text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);font-size:.7rem}.project input{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:10px 12px}.topbar-actions{gap:10px;display:flex}.history-controls{gap:6px;display:flex}.btn-icon{background:var(--panel-strong);width:36px;height:36px;color:var(--text);border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.btn-icon:hover:not(:disabled){background:var(--panel);border-color:#fff3}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-icon svg{width:16px;height:16px}.project-controls{align-items:center;gap:10px;display:flex}.project-menu-wrapper{position:relative}.project-menu-wrapper .btn{align-items:center;gap:6px;display:flex}.project-menu{background:var(--panel-strong);border:1px solid var(--border);z-index:100;border-radius:12px;min-width:240px;margin-top:8px;padding:8px;position:absolute;top:100%;left:0;box-shadow:0 16px 48px #0006}.project-menu-actions{gap:4px;display:flex}.project-menu-actions .btn{flex:1;padding:8px 10px;font-size:.8rem}.project-menu-divider{background:var(--border);height:1px;margin:8px 0}.project-menu-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:4px 8px;font-size:.7rem}.project-menu-list{max-height:240px;overflow-y:auto}.project-menu-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;transition:background .15s;display:flex}.project-menu-item:hover{background:#ffffff0f}.project-menu-item.active{background:#4bd0ff1f;border:1px solid #4bd0ff4d}.project-menu-item-info{flex-direction:column;gap:2px;min-width:0;display:flex}.project-menu-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.project-menu-item-date{color:var(--text-muted);font-size:.7rem}.project-menu-item-delete{width:24px;height:24px;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:1.2rem;transition:all .15s;display:flex}.project-menu-item:hover .project-menu-item-delete{opacity:1}.project-menu-item-delete:hover{color:#ff6464;background:#ff646433}.save-status{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.workspace{grid-template-columns:290px minmax(0,1fr) 320px;gap:20px;min-height:0;padding:24px 28px 30px;display:grid;overflow:hidden}.panel{flex-direction:column;gap:18px;min-width:0;min-height:0;display:flex}.left-panel,.right-panel{scrollbar-gutter:stable;min-height:0;overflow-y:auto}.panel-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:16px;min-width:0;padding:18px;display:flex}.panel-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.panel-header h2{font-family:var(--font-display);margin:0 0 6px;font-size:1rem}.panel-header p{color:var(--text-muted);margin:0;font-size:.82rem}.panel-header.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--radius)var(--radius)0 0;margin:-18px -18px 0;padding:18px;transition:background .15s}.panel-card.collapsed .panel-header.collapsible{border-radius:var(--radius);margin-bottom:-18px}.panel-header.collapsible:hover{background:var(--panel-strong)}.panel-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.collapse-toggle{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:flex}.collapse-toggle:hover{background:var(--border);color:var(--text)}.collapse-icon{transition:transform .2s}.collapse-icon.collapsed{transform:rotate(-90deg)}.panel-card.collapsed{gap:0}.panel-content{flex-direction:column;gap:16px;display:flex}.tag{text-transform:uppercase;letter-spacing:.12em;color:#0b0d12;background:var(--accent);white-space:nowrap;border-radius:999px;padding:4px 8px;font-size:.7rem}.btn{letter-spacing:.02em;background:var(--panel-strong);color:var(--text);border:1px solid #0000;border-radius:12px;padding:10px 14px;font-weight:600;transition:transform .2s,box-shadow .2s,border .2s}.btn:hover{border-color:#ffffff2e;transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn.primary{color:#101219;background:linear-gradient(120deg,#f2a63b,#ff7a70);box-shadow:0 12px 24px #f2a63b47}.btn.danger{color:#111218;background:linear-gradient(120deg,#ff5f6d,#ff8c5a);box-shadow:0 12px 24px #ff6f6240}.btn.secondary{background:#11141ee6;border:1px solid #ffffff1f}.btn.ghost{background:0 0;border:1px solid #ffffff1f}.btn.ghost.active{border-color:var(--accent);color:var(--accent)}.panel-actions{align-items:center;gap:12px;display:flex}.helper{color:var(--text-muted);font-size:.75rem}textarea{border:1px solid var(--border);width:100%;min-height:96px;color:var(--text);resize:vertical;background:#0c0f16cc;border-radius:12px;padding:12px}.chip-row{flex-wrap:wrap;gap:8px;display:flex}.ai-mode-toggle{gap:8px;margin-bottom:12px;display:flex}.ai-mode-toggle .btn{flex:1;padding:8px 12px;font-size:.78rem}.variation-source{gap:10px;margin-bottom:12px;display:grid}.variation-preview{border:1px solid var(--border);background:#0c0f1699;border-radius:10px;width:100%;height:120px;overflow:hidden}.variation-preview img{object-fit:contain;width:100%;height:100%}.advanced-options{margin-bottom:12px}.advanced-toggle{color:var(--text-muted);align-items:center;gap:6px;padding:6px 0;font-size:.75rem;display:flex}.advanced-toggle svg{transition:transform .2s}.advanced-toggle svg.rotated{transform:rotate(180deg)}.advanced-content{border:1px solid var(--border);background:#0c0f1680;border-radius:10px;margin-top:8px;padding:12px}.advanced-content textarea{min-height:60px;font-size:.82rem}.model-info{flex-wrap:wrap;gap:6px;margin:8px 0;display:flex}.model-badge{color:#4bd0ff;background:#4bd0ff1f;border:1px solid #4bd0ff33;border-radius:6px;align-items:center;padding:3px 8px;font-size:.68rem;display:inline-flex}.generation-progress{align-items:center;gap:10px;margin:10px 0;display:flex}.generation-progress .progress-bar{background:#ffffff1a;border-radius:3px;flex:1;height:6px;overflow:hidden}.generation-progress .progress-bar span{background:linear-gradient(90deg,var(--accent-2),var(--accent));border-radius:3px;height:100%;transition:width .2s;display:block}.generation-progress .progress-text{color:var(--text-muted);text-align:right;min-width:36px;font-size:.72rem}:root.light .variation-preview{background:#f5f7facc}:root.light .advanced-content{background:#fff9}:root.light .model-badge{color:#0284c7;background:#4bd0ff14}.chip{color:var(--text-muted);background:#0c0f1680;border:1px solid #ffffff24;border-radius:999px;padding:6px 12px;font-size:.78rem}.chip.preset-chip{align-items:center;gap:8px;padding:6px 10px;display:inline-flex}.preset-item{align-items:center;gap:6px;display:inline-flex}.preset-item-actions{align-items:center;gap:4px;display:inline-flex}.preset-action{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);background:#0c0f1673;border:1px solid #ffffff24;border-radius:999px;padding:5px 8px;font-size:.65rem}.preset-action.danger{color:#ffb5a6;border-color:#ff8d7a99}.preset-swatch{background-image:linear-gradient(135deg,#ffe29f 0%,#ffa99f 45%,#a1c4fd 100%);border:1px solid #fff3;border-radius:8px;flex-shrink:0;width:28px;height:28px;position:relative;overflow:hidden}.preset-swatch:before{content:"";opacity:var(--swatch-grain,0);mix-blend-mode:soft-light;background-image:radial-gradient(circle at 20% 30%,#ffffff59,#0000 40%),radial-gradient(circle at 70% 60%,#00000059,#0000 45%);position:absolute;inset:0}.preset-swatch:after{content:"";background:radial-gradient(circle at center,#0000 calc(var(--swatch-vignette-size,.75)*100%),rgba(0,0,0,var(--swatch-vignette,0))100%);position:absolute;inset:0}.chip.preset-chip.active .preset-swatch{box-shadow:0 0 0 2px #4bd0ff99}.preset-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.chip.active{color:#dff6ff;background:#4bd0ff2e;border-color:#4bd0ff80}.error-text{color:#ff8d7a;margin:0;font-size:.75rem}.upload-row,.asset-list{flex-direction:column;gap:10px;display:flex}.asset-item{background:#0a0c12b3;border:1px solid #ffffff14;border-radius:14px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px;display:grid}.asset-thumb{background:#ffffff0a;border-radius:12px;place-items:center;width:52px;height:52px;display:grid;overflow:hidden}.asset-thumb.image img{object-fit:cover;width:100%;height:100%}.asset-thumb.video{background:#0003;position:relative}.asset-thumb.video video{object-fit:cover;width:100%;height:100%}.asset-thumb.video:after{content:"";pointer-events:none;background:#0000004d;place-items:center;display:grid;position:absolute;inset:0}.asset-thumb.video:before{content:"";z-index:1;pointer-events:none;border:8px solid #0000;border-left:12px solid #ffffffe6;border-right-width:0;width:0;height:0;position:absolute}.audio-bars{align-items:flex-end;gap:3px;height:32px;display:flex}.audio-bars span{background:linear-gradient(#4bd0ff,#1f6f8b);border-radius:999px;width:4px}.audio-bars span:first-child{height:40%}.audio-bars span:nth-child(2){height:70%}.audio-bars span:nth-child(3){height:55%}.audio-bars span:nth-child(4){height:85%}.audio-bars span:nth-child(5){height:60%}.asset-meta{gap:4px;display:grid}.asset-name{margin:0;font-size:.85rem;font-weight:600}.asset-sub{color:var(--text-muted);margin:0;font-size:.72rem}.asset-actions{align-items:center;display:flex}.shape-row{gap:10px;display:flex}.shape-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.shape-btn{flex-direction:column;align-items:center;gap:4px;padding:10px 8px!important;font-size:.7rem!important;display:flex!important}.shape-btn svg{width:20px;height:20px}.shape-btn span{opacity:.8;font-size:.68rem}.stage-panel{scrollbar-gutter:stable;flex-direction:column;gap:18px;min-height:0;display:flex;overflow:hidden auto}.stage-toolbar{justify-content:space-between;align-items:center;padding:4px 8px 0;display:flex}.stage-toolbar h2{font-family:var(--font-display);margin:0;font-size:1.1rem}.stage-toolbar p{color:var(--text-muted);margin:4px 0 0;font-size:.8rem}.canvas-dimensions{color:var(--text-muted);opacity:.7;margin-left:6px;font-size:.7rem;font-weight:400}.layer-count-badge{color:var(--text-muted);vertical-align:middle;background:#4bd0ff26;border-radius:10px;margin-left:8px;padding:2px 8px;font-size:.65rem;font-weight:500}.stage-info{align-items:center;gap:16px;display:flex}.selected-layer-badge{background:#4bd0ff1a;border:1px solid #4bd0ff40;border-radius:8px;align-items:center;gap:10px;padding:6px 12px;font-size:.72rem;display:flex}.layer-badge-name{color:var(--accent);text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-weight:500;overflow:hidden}.layer-badge-pos,.layer-badge-size{color:var(--text-muted);font-family:monospace;font-size:.68rem}.layer-badge-pos:before,.layer-badge-size:before{content:"";vertical-align:middle;background:#ffffff26;width:1px;height:12px;margin-right:10px;display:inline-block}.toolbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.zoom-control{background:#0c0f168c;border:1px solid #ffffff1f;border-radius:12px;align-items:center;gap:8px;padding:6px 10px;display:flex}.zoom-control span{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.7rem}.zoom-control span:last-of-type{color:var(--text)}.zoom-control input[type=range]{width:120px;accent-color:var(--accent)}.zoom-control .btn{padding:6px 10px;font-size:.7rem}.zoom-presets{background:#0c0f1666;border-radius:8px;gap:2px;padding:2px;display:flex}.zoom-presets .btn{border-radius:6px;min-width:32px;padding:4px 6px;font-size:.65rem}.zoom-presets .btn:hover{background:#4bd0ff26}.layer-order-buttons{gap:4px;display:flex}.layer-order-buttons .btn{padding:5px 8px;font-size:.68rem}.flip-buttons{gap:4px;display:flex}.flip-buttons .btn{padding:5px 8px;font-size:.68rem}.rotate-buttons{gap:4px;display:flex}.rotate-buttons .btn{padding:5px 10px;font-size:.85rem}.snap-size-select{color:var(--text);cursor:pointer;background:#0c0f1699;border:1px solid #ffffff1f;border-radius:8px;padding:6px 10px;font-size:.72rem}.snap-size-select:hover{border-color:#4bd0ff66}.stage-shell{background:#06080c99;border:1px solid #ffffff14;border-radius:24px;flex:auto;align-content:start;place-items:start center;min-height:520px;padding:24px;display:grid;overflow:auto}.stage{background:linear-gradient(135deg,#232936e6,#12161ef2);border:1px solid #ffffff1f;border-radius:18px;place-items:center;width:min(860px,100%);display:grid;position:relative;overflow:hidden;box-shadow:0 25px 60px #00000073}.stage:before{content:"";opacity:.25;pointer-events:none;z-index:0;background-image:linear-gradient(#ffffff0f 1px,#0000 1px),linear-gradient(90deg,#ffffff0f 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.stage>.konvajs-content{z-index:1;position:relative}.stage-empty{text-align:center;color:var(--text-muted);z-index:2;pointer-events:none;place-items:center;display:grid;position:absolute;inset:0}.stage-empty h3{font-family:var(--font-display);color:var(--text);margin:0 0 8px}.layer-list{flex-direction:column;gap:8px;display:flex}.layer-item{color:var(--text);text-align:left;cursor:pointer;background:#0c0f1699;border:1px solid #ffffff14;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;width:100%;min-width:0;padding:10px 12px;display:flex}.layer-main{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.layer-name{text-overflow:ellipsis;white-space:nowrap;cursor:text;min-width:0;overflow:hidden}.layer-name-input{border:1px solid var(--accent);background:var(--panel-strong);width:100%;color:var(--text);font-size:inherit;border-radius:4px;outline:none;padding:2px 4px;font-family:inherit}.layer-item.active{border-color:#f2a63bb3;box-shadow:0 0 0 2px #f2a63b33}.layer-item.selected{background:#4bd0ff1a;border-color:#4bd0ff80}.layer-type{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-size:.7rem}.layer-actions{flex-shrink:0;gap:6px;display:inline-flex}.layer-action{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);background:#0c0f1673;border:1px solid #ffffff24;border-radius:999px;padding:4px 8px;font-size:.65rem}.layer-action.is-on{color:#dff6ff;border-color:#4bd0ff99}.layer-action.is-off{color:#ffb5a6;border-color:#ff8d7a99}.control-stack{flex-direction:column;gap:12px;display:flex}.animation-card{background:#0a0d14b3;border:1px solid #ffffff14;border-radius:14px;gap:12px;padding:12px;display:grid}.animation-card-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.animation-card-header h4{margin:0;font-size:.85rem}.animation-card-header p{color:var(--text-muted);margin:0;font-size:.75rem}.animation-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.animation-subhead{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.72rem;display:flex}.animation-presets{background:#0c0f1699;border:1px solid #ffffff0f;border-radius:12px;flex-direction:column;gap:10px;padding:12px;display:flex}.animation-presets-header{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:4px;font-size:.72rem}.animation-presets-grid{flex-direction:column;gap:12px;display:flex}.animation-preset-group{flex-direction:column;gap:6px;display:flex}.animation-preset-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-size:.68rem;font-weight:500}.animation-preset-buttons{flex-wrap:wrap;gap:6px;display:flex}.animation-preset-btn{align-items:center;gap:6px;display:inline-flex;background:#ffffff0a!important;border:1px solid #ffffff14!important;border-radius:8px!important;padding:6px 10px!important;font-size:.72rem!important;transition:all .15s!important}.animation-preset-btn:hover{transform:translateY(-1px);background:#4bd0ff1f!important;border-color:#4bd0ff66!important}.animation-preset-btn .preset-icon{font-size:.9rem;line-height:1}.animation-preset-btn .preset-name{white-space:nowrap}.custom-preset-item{align-items:center;gap:2px;display:flex;position:relative}.custom-preset-delete{opacity:.5;padding:4px 6px!important;font-size:.9rem!important;line-height:1!important;transition:opacity .15s!important}.custom-preset-item:hover .custom-preset-delete{opacity:1}.custom-preset-delete:hover{color:#ff7a70!important}.style-copy-row{gap:8px;padding:8px 0;display:flex}.style-copy-row .btn{flex:1;font-size:.72rem}.divider{background:#ffffff14;height:1px;margin:4px 0}.control-divider{background:#ffffff14;width:100%;height:1px;margin:4px 0}.animation-actions-row{align-items:center;gap:8px;display:flex}.animation-actions-row .btn{flex:1}.animation-actions-row .btn.ghost{flex:none}.alignment-tools{background:#0c0f1680;border:1px solid #ffffff0f;border-radius:10px;gap:16px;padding:10px 12px;display:flex}.alignment-group{flex-direction:column;flex:1;gap:6px;display:flex}.alignment-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.68rem}.alignment-buttons{gap:4px;display:flex}.alignment-btn{justify-content:center;align-items:center;border-radius:8px!important;width:32px!important;height:32px!important;padding:0!important;display:flex!important}.alignment-btn svg{width:16px;height:16px}.alignment-btn:hover{background:#4bd0ff1f!important;border-color:#4bd0ff66!important}.text-effects-section{background:#0c0f1680;border:1px solid #ffffff0f;border-radius:10px;flex-direction:column;gap:8px;padding:10px 12px;display:flex}.text-effects-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-size:.72rem;font-weight:500}.control-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.control-grid label,.control-stack label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;gap:6px;min-width:0;font-size:.75rem;display:grid}.control-stack.ai-grid label{text-transform:none;letter-spacing:.02em}.prompt-history{flex-direction:column;gap:8px;display:flex}.prompt-history-toggle{color:var(--text-muted);align-items:center;gap:6px;width:fit-content;padding:4px 8px;font-size:.75rem;display:flex}.prompt-history-toggle svg.rotated{transform:rotate(180deg)}.prompt-history-list{background:#0c0f1680;border-radius:8px;flex-direction:column;gap:4px;max-height:200px;padding:8px;display:flex;overflow-y:auto}.prompt-history-item{align-items:center;gap:4px;display:flex}.prompt-history-content{border:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-radius:6px;flex-direction:column;flex:1;align-items:flex-start;gap:2px;padding:6px 8px;transition:background .15s,border-color .15s;display:flex}.prompt-history-content:hover{background:var(--panel-strong);border-color:var(--accent)}.prompt-history-content .prompt-text{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.78rem;overflow:hidden}.prompt-history-content .prompt-style{color:var(--text-muted);font-size:.68rem}.prompt-history-delete{color:var(--text-muted);flex-shrink:0;padding:4px}.prompt-history-delete:hover{color:var(--error)}.prompt-history-clear{color:var(--text-muted);margin-top:4px;padding:4px 8px;font-size:.72rem}input,select{border:1px solid var(--border);color:var(--text);background:#0c0f16b3;border-radius:10px;padding:8px 10px}.right-panel{min-width:0;max-width:100%;overflow-x:hidden}.right-panel .panel-card{flex:none;max-width:100%;overflow:hidden visible}.right-panel .panel-card input:not([type=range]):not([type=color]):not([type=checkbox]),.right-panel .panel-card select,.right-panel .panel-card textarea{width:100%;min-width:0;max-width:100%}input:disabled,select:disabled,textarea:disabled{opacity:.6;cursor:not-allowed}input[type=range]{width:100%}input[type=color]{height:44px;padding:4px}.range-row{color:var(--text);grid-template-columns:1fr auto;align-items:center;gap:10px;font-size:.8rem;display:grid}.toggle-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.toggle-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.toggle-row.compact{gap:8px;font-size:.78rem}.toggle-row.compact input[type=checkbox]{width:14px;height:14px}.flip-buttons{color:var(--text-muted);justify-content:space-between;align-items:center;gap:12px;font-size:.82rem;display:flex}.flip-buttons .btn-group{gap:6px;display:flex}.flip-buttons .btn{align-items:center;gap:4px;padding:6px 10px;font-size:.75rem;display:flex}.flip-buttons .btn.active{background:var(--accent);color:var(--bg)}.flip-buttons .btn svg{opacity:.8}.fit-buttons{gap:8px;display:flex}.fit-buttons .btn{flex:1;padding:6px 10px;font-size:.75rem}.quick-rotate{gap:6px;display:flex}.quick-rotate .btn{flex:1;justify-content:center;align-items:center;gap:4px;padding:5px 8px;font-size:.72rem;display:flex}.quick-rotate .btn svg{opacity:.7}.center-btn{grid-column:span 2;justify-content:center;align-items:center;gap:6px;font-size:.75rem;display:flex}.center-btn svg{opacity:.7}.size-actions{gap:8px;display:flex}.size-actions .btn{flex:1;padding:6px 10px;font-size:.75rem}.filename-options{flex-wrap:wrap;gap:16px;display:flex}.watermark-block{gap:10px;display:grid}.empty-state{color:var(--text-muted);text-align:center;background:#0c0f1680;border-radius:12px;padding:14px;font-size:.82rem}.timeline{border-top:1px solid var(--border);scrollbar-gutter:stable;background:#090b10f2;max-height:clamp(220px,32vh,320px);padding:20px 28px 26px;overflow-y:auto}.timeline-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.timeline-header h2{font-family:var(--font-display);margin:0 0 6px;font-size:1rem}.timeline-header p{color:var(--text-muted);margin:0;font-size:.78rem}.timeline-meta{color:var(--text-muted);gap:12px;font-size:.75rem;display:flex}.timeline-body{gap:10px;display:grid}.timeline-scrub{background:#0c0f16b3;border:1px solid #ffffff14;border-radius:14px;gap:10px;margin-bottom:16px;padding:12px 14px;display:grid}.timeline-scrub-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.timeline-scrub-header h4{margin:0 0 4px;font-size:.85rem}.timeline-scrub-header p{color:var(--text-muted);margin:0;font-size:.75rem}.audio-sync-badge{color:#4bd0ff;background:#4bd0ff26;border:1px solid #4bd0ff4d;border-radius:10px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:.7rem;font-weight:500;animation:1.5s ease-in-out infinite pulse;display:inline-flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.timeline-scrub-meta{color:var(--text);flex-wrap:wrap;align-items:center;gap:10px;font-size:.75rem;display:flex}.playback-speed-select{color:var(--text);cursor:pointer;background:#0c0f1699;border:1px solid #ffffff1f;border-radius:6px;min-width:55px;padding:5px 8px;font-size:.72rem}.playback-speed-select:hover{border-color:#4bd0ff66}.playback-speed-select:focus{border-color:var(--accent);outline:none}.timeline-slider{width:100%}.timeline-tracks{gap:10px;margin-top:12px;display:grid}.timeline-track-header{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);justify-content:space-between;font-size:.72rem;display:flex}.timeline-row{cursor:pointer;background:#0c0f16b3;border:1px solid #ffffff14;border-radius:14px;grid-template-columns:140px 1fr;align-items:center;gap:12px;padding:10px 12px;display:grid}.timeline-row.active{border-color:#4bd0ff99}.timeline-row:focus-visible{outline-offset:2px;outline:2px solid #4bd0ffcc}.timeline-row-label{color:var(--text);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.78rem;overflow:hidden}.timeline-row-track{background:#ffffff0f;border-radius:999px;height:24px;position:relative;overflow:hidden}.timeline-row-track:after{content:"";width:2px;top:-6px;bottom:-6px;left:var(--playhead,0%);background:var(--accent);opacity:.7;position:absolute}.timeline-clip{background:linear-gradient(90deg,#4bd0ffcc,#f2a63bcc);border-radius:999px;position:absolute;top:4px;bottom:4px;box-shadow:0 0 0 1px #0003}.timeline-empty{color:var(--text-muted);padding-left:10px;font-size:.72rem}.render-panel{background:#0c0f16bf;border:1px solid #ffffff14;border-radius:16px;gap:10px;margin-top:16px;padding:16px;display:grid}.render-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.render-header h3{font-family:var(--font-display);margin:0;font-size:1rem}.render-header p{color:var(--text-muted);margin:6px 0 0;font-size:.78rem}.render-actions{flex-wrap:wrap;gap:10px;display:flex}.render-options{flex-wrap:wrap;align-items:flex-end;gap:16px;display:flex}.render-options label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;gap:6px;min-width:160px;font-size:.75rem;display:grid}.render-options .helper{margin:0}.render-status{align-items:center;gap:12px;display:flex}.progress-bar{background:#ffffff14;border-radius:999px;flex:1;height:8px;overflow:hidden}.progress-bar span{background:linear-gradient(90deg,var(--accent),var(--accent-2));width:0%;height:100%;transition:width .2s;display:block}.status-text{color:var(--text-muted);text-align:right;min-width:140px;font-size:.75rem}.track{background:#0c0f16b3;border:1px solid #ffffff14;border-radius:14px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.track.active{border-color:#4bd0ff99}.track.audio.active{border-color:#f2a63b99}.track-label{text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);font-size:.7rem}.track-content{font-size:.85rem}.track-actions{gap:8px;display:flex}.reveal{animation:.6s both reveal}.delay-1{animation-delay:50ms}.delay-2{animation-delay:.12s}.delay-3{animation-delay:.18s}.delay-4{animation-delay:.24s}@keyframes reveal{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1200px){.app{height:auto;overflow:visible}.workspace{min-height:auto;overflow:visible}.left-panel,.right-panel{scrollbar-gutter:auto;overflow:visible}.stage-panel,.stage-shell{overflow:visible}.timeline{scrollbar-gutter:auto;max-height:none;overflow:visible}.workspace{grid-template-columns:250px minmax(0,1fr)}.right-panel{flex-flow:wrap;grid-column:1/-1}.right-panel .panel-card{flex:320px}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#080a0fd9;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-content{background:var(--panel-strong);border:1px solid var(--border);border-radius:20px;flex-direction:column;width:100%;max-width:640px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 24px 60px #00000080}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-family:var(--font-display);margin:0;font-size:1.2rem}.modal-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;place-items:center;font-size:1.5rem;transition:all .15s;display:grid}.modal-close:hover{color:var(--text);background:#ffffff14}.modal-body{padding:24px;overflow-y:auto}.shortcuts-modal{max-width:720px}.shortcuts-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.shortcut-group h3{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;font-size:.85rem;font-weight:600}.shortcut-list{flex-direction:column;gap:8px;display:flex}.shortcut-item{background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;display:flex}.shortcut-item:hover{background:#ffffff0f}.shortcut-keys{flex-shrink:0;align-items:center;gap:4px;display:flex}.shortcut-keys kbd{color:var(--text);background:#ffffff1a;border:1px solid #ffffff26;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:.75rem;font-weight:500;display:inline-block;box-shadow:0 2px #0003}.key-separator{color:var(--text-muted);margin:0 2px;font-size:.7rem}.shortcut-description{color:var(--text-muted);text-align:right;font-size:.8rem}.shortcuts-footer{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.shortcuts-footer p{color:var(--text-muted);margin:0;font-size:.8rem}.shortcuts-footer kbd{color:var(--text);background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;padding:2px 6px;font-family:inherit;font-size:.7rem;display:inline-block}.error-boundary{background:radial-gradient(circle at 0 0,#ff7a7026,#0000 40%),radial-gradient(circle at 80% 80%,#f2a63b1a,#0000 45%),#0b0d12;place-items:center;min-height:100vh;padding:24px;display:grid}.error-boundary-content{text-align:center;background:var(--panel);border:1px solid var(--border);border-radius:24px;max-width:480px;padding:48px 32px;box-shadow:0 24px 60px #0006}.error-icon{color:var(--accent-3);margin-bottom:24px}.error-icon svg{width:64px;height:64px}.error-boundary-content h2{font-family:var(--font-display);color:var(--text);margin:0 0 12px;font-size:1.5rem}.error-boundary-content>p{color:var(--text-muted);margin:0 0 28px;font-size:.95rem;line-height:1.6}.error-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.error-details{text-align:left;background:#0000004d;border-radius:12px;margin-top:28px;overflow:hidden}.error-details summary{cursor:pointer;color:var(--text-muted);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.8rem}.error-details summary:hover{background:#ffffff08}.error-message,.error-stack{color:var(--accent-3);white-space:pre-wrap;word-break:break-all;max-height:200px;margin:0;padding:12px 16px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.75rem;overflow:auto}.error-stack{color:var(--text-muted);border-top:1px solid var(--border)}.notification-container{z-index:200;pointer-events:none;flex-direction:column;gap:10px;width:100%;max-width:380px;display:flex;position:fixed;top:20px;right:20px}.notification{background:var(--panel-strong);border:1px solid var(--border);pointer-events:auto;border-radius:14px;align-items:flex-start;gap:12px;padding:14px 16px;animation:.25s slideIn;display:flex;box-shadow:0 12px 32px #00000059}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.notification-icon{flex-shrink:0;place-items:center;width:24px;height:24px;display:grid}.notification-success .notification-icon{color:#4ade80}.notification-error .notification-icon{color:var(--accent-3)}.notification-warning .notification-icon{color:var(--accent)}.notification-info .notification-icon{color:var(--accent-2)}.notification-content{flex:1;min-width:0}.notification-title{color:var(--text);margin-bottom:2px;font-size:.9rem;font-weight:600}.notification-message{color:var(--text-muted);font-size:.8rem;line-height:1.4}.notification-close{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;place-items:center;font-size:1.2rem;transition:all .15s;display:grid}.notification-close:hover{color:var(--text);background:#ffffff14}.notification-success{border-left:3px solid #4ade80}.notification-error{border-left:3px solid var(--accent-3)}.notification-warning{border-left:3px solid var(--accent)}.notification-info{border-left:3px solid var(--accent-2)}@media (max-width:900px){.topbar{flex-direction:column;align-items:flex-start;gap:16px}.workspace{grid-template-columns:1fr}.stage-shell{min-height:420px}.timeline-header{flex-direction:column;align-items:flex-start;gap:10px}.timeline-scrub-header{flex-direction:column;align-items:flex-start}.timeline-row{grid-template-columns:1fr}.render-header{flex-direction:column;align-items:flex-start}.render-status{flex-direction:column;align-items:stretch}.status-text{text-align:left}}:root.light .topbar{background:linear-gradient(120deg,#fffffff2,#f5f7fafa)}:root.light .drop-overlay{background:#ffffffd9}:root.light .panel-card{background:#ffffffe6}:root.light .stage{background:linear-gradient(45deg,#e5e8ed 25%,#0000 25%),linear-gradient(-45deg,#e5e8ed 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#e5e8ed 75%),linear-gradient(-45deg,#0000 75%,#e5e8ed 75%)}:root.light .timeline{background:linear-gradient(#fffffff2,#f5f7fafa)}:root.light .layer-item{background:#fffc;border-color:#00000014}:root.light .layer-item:hover{background:#fffffff2}:root.light .btn.ghost{color:var(--text)}:root.light .btn.ghost:hover{background:#0000000d}:root.light .btn.secondary{color:var(--text);background:#0000000f}:root.light .btn.secondary:hover{background:#0000001a}:root.light input,:root.light select,:root.light textarea{color:var(--text);background:#ffffffe6;border-color:#0000001a}:root.light .preset-chip{color:var(--text);background:#0000000d}:root.light .preset-chip:hover{background:#00000014}:root.light .asset-card{background:#fffc;border-color:#00000014}:root.light .stage-toolbar{background:#ffffffe6}:root.light .modal-content{background:#fffffffa}:root.light .notification{color:var(--text);background:#fffffffa}:root.light .project-menu{background:#fffffffa}:root.light .project-menu-item:hover{background:#0000000d}.content-with-emoji{flex-direction:column;gap:8px;display:flex}.content-with-emoji label{flex:1}.content-with-emoji .emoji-picker-wrapper{align-self:flex-start}.emoji-picker-wrapper{display:inline-block;position:relative}.emoji-trigger{padding:6px 10px;font-size:1.2rem}.emoji-picker{background:var(--panel-strong);border:1px solid var(--border);width:260px;box-shadow:var(--shadow);z-index:100;border-radius:12px;margin-bottom:8px;padding:8px;position:absolute;bottom:100%;left:0}.emoji-categories{border-bottom:1px solid var(--border);gap:4px;margin-bottom:8px;padding-bottom:8px;display:flex}.emoji-category-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:8px;padding:6px 8px;font-size:1rem;transition:opacity .15s,background .15s}.emoji-category-btn:hover{opacity:.9;background:#ffffff1a}.emoji-category-btn.active{opacity:1;background:#4bd0ff33}.emoji-grid{grid-template-columns:repeat(5,1fr);gap:4px;max-height:200px;display:grid;overflow-y:auto}.emoji-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px;font-size:1.3rem;transition:background .15s,transform .15s}.emoji-btn:hover{background:#ffffff1a;transform:scale(1.15)}:root.light .emoji-picker{background:#fffffffa}:root.light .emoji-category-btn:hover,:root.light .emoji-btn:hover{background:#0000000d}.mobile-warning-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#080a0ff2;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.mobile-warning-content{background:var(--panel-strong);border:1px solid var(--border);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow);border-radius:24px;margin:auto;padding:28px}.mobile-warning-icon{width:72px;height:72px;color:var(--accent-2);background:linear-gradient(135deg,#4bd0ff33,#f2a63b33);border-radius:18px;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.mobile-warning-content h2{font-family:var(--font-display);margin:0 0 12px;font-size:1.3rem}.mobile-warning-description{color:var(--text-muted);margin:0 0 16px;font-size:.9rem;line-height:1.5}.mobile-warning-description strong{color:var(--accent)}.mobile-warning-device-info{justify-content:center;align-items:center;gap:12px;margin-bottom:20px;display:flex}.device-badge{background:var(--accent-2);color:var(--bg);text-transform:uppercase;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:600}.screen-size{color:var(--text-muted);font-family:monospace;font-size:.8rem}.mobile-warning-actions{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.mobile-warning-actions .btn{justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 16px;display:flex}.mobile-warning-features{text-align:left;background:#0003;border-radius:12px;margin-bottom:16px;padding:14px}.mobile-warning-features h4{color:var(--text);margin:0 0 10px;font-size:.8rem;font-weight:600}.mobile-warning-features ul{margin:0;padding:0;font-size:.75rem;list-style:none}.mobile-warning-features li{color:var(--text-muted);padding:4px 0}.mobile-warning-features li:nth-child(-n+3){color:#4ade80}.mobile-warning-features li:nth-child(n+4){color:#f87171}.mobile-warning-hint{color:var(--text-muted);opacity:.7;margin:0;font-size:.75rem}:root.light .mobile-warning-overlay{background:#f5f7faf2}:root.light .mobile-warning-content{background:#fffffffa}:root.light .mobile-warning-features{background:#0000000d}body.mobile-limited-mode .topbar{flex-wrap:wrap;gap:8px;padding:10px 12px}body.mobile-limited-mode .brand-sub,body.mobile-limited-mode .save-status{display:none}body.mobile-limited-mode .workspace{grid-template-rows:auto 1fr auto;grid-template-columns:1fr;gap:8px;padding:8px}body.mobile-limited-mode .left-panel{flex-direction:row;gap:8px;max-height:none;padding-bottom:8px;display:flex;overflow:auto hidden}body.mobile-limited-mode .left-panel .panel-card{flex:0 0 280px;min-width:280px;max-height:200px}body.mobile-limited-mode .center-panel{min-height:40vh}body.mobile-limited-mode .right-panel{flex-direction:row;gap:8px;max-height:250px;padding-top:8px;display:flex;overflow:auto hidden}body.mobile-limited-mode .right-panel .panel-card{flex:0 0 280px;min-width:280px}body.mobile-limited-mode .panel-card{padding:12px}body.mobile-limited-mode .timeline{padding:10px}body.touch-device .btn,body.touch-device button{min-width:44px;min-height:44px}body.touch-device .layer-item{min-height:52px;padding:12px}body.touch-device input[type=range]::-webkit-slider-thumb{width:24px;height:24px;margin-top:-9px}body.touch-device input[type=range]::-moz-range-thumb{width:24px;height:24px}body.touch-device .layer-item,body.touch-device .panel-header,body.touch-device .btn{-webkit-user-select:none;user-select:none}@media (max-width:480px){.mobile-warning-content{border-radius:16px;padding:20px}.mobile-warning-icon{width:60px;height:60px}.mobile-warning-content h2{font-size:1.1rem}.mobile-warning-description{font-size:.85rem}body.mobile-limited-mode .topbar{padding:8px}body.mobile-limited-mode .brand-mark{width:28px;height:28px}body.mobile-limited-mode .brand-title{font-size:.85rem}body.mobile-limited-mode .project{min-width:100px}body.mobile-limited-mode .project input{padding:6px 8px;font-size:.8rem}body.mobile-limited-mode .left-panel .panel-card,body.mobile-limited-mode .right-panel .panel-card{flex:0 0 240px;min-width:240px}body.mobile-limited-mode .canvas-toolbar{flex-wrap:wrap;gap:4px;padding:6px}body.mobile-limited-mode .canvas-toolbar .btn-icon{width:36px;height:36px}}@media (max-width:767px) and (orientation:landscape){body.mobile-limited-mode .workspace{grid-template-rows:1fr;grid-template-columns:200px 1fr}body.mobile-limited-mode .left-panel{flex-direction:column;max-height:none;overflow:hidden auto}body.mobile-limited-mode .left-panel .panel-card{flex:none;width:100%;min-width:0}body.mobile-limited-mode .right-panel{background:var(--panel-strong);border-top:1px solid var(--border);z-index:15;max-height:35vh;padding:8px;position:fixed;bottom:0;left:0;right:0}body.mobile-limited-mode .timeline{z-index:14;position:fixed;bottom:0;left:0;right:0}}.audio-trim-ui{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;margin:8px 0;padding:16px}.audio-trim-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.audio-trim-title{color:var(--text);align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.audio-trim-title svg{color:var(--accent)}.audio-trim-info{color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:12px;font-size:.85rem;display:flex}.audio-trim-duration{font-variant-numeric:tabular-nums;color:var(--accent)}.audio-trim-track-wrapper{margin-bottom:16px}.audio-trim-track{background:var(--bg);cursor:pointer;border-radius:6px;height:80px;position:relative;overflow:hidden}.audio-trim-waveform{pointer-events:none;justify-content:space-around;align-items:center;padding:0 4px;display:flex;position:absolute;inset:0}.audio-trim-wave-bar{background:var(--accent);opacity:.3;border-radius:2px;width:3px;min-height:4px;transition:opacity .15s}.audio-trim-region{border-left:2px solid var(--accent);border-right:2px solid var(--accent);pointer-events:none;background:#4bd0ff26;position:absolute;top:0;bottom:0}.audio-trim-dimmed{pointer-events:none;background:#00000080;position:absolute;top:0;bottom:0}.audio-trim-handle{cursor:ew-resize;z-index:2;width:16px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.audio-trim-handle:hover .audio-trim-handle-line,.audio-trim-handle.active .audio-trim-handle-line{background:var(--accent-2);box-shadow:0 0 8px var(--accent-2)}.audio-trim-handle-line{background:var(--accent);border-radius:2px;width:4px;transition:background .15s,box-shadow .15s;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.audio-trim-handle-label{font-variant-numeric:tabular-nums;background:var(--bg-secondary);white-space:nowrap;color:var(--text);border:1px solid var(--border);opacity:0;border-radius:4px;padding:2px 6px;font-size:.7rem;transition:opacity .15s;position:absolute;top:-24px;left:50%;transform:translate(-50%)}.audio-trim-handle:hover .audio-trim-handle-label,.audio-trim-handle.active .audio-trim-handle-label{opacity:1}.audio-trim-markers{color:var(--text-muted);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:6px;font-size:.7rem;display:flex}.audio-trim-inputs{align-items:flex-end;gap:12px;display:flex}.audio-trim-inputs label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:.75rem;display:flex}.audio-trim-inputs input[type=number]{border:1px solid var(--border);background:var(--bg);width:80px;color:var(--text);font-variant-numeric:tabular-nums;border-radius:4px;padding:6px 8px;font-size:.85rem}.audio-trim-inputs input[type=number]:focus{border-color:var(--accent);outline:none}:root.light .audio-trim-dimmed{background:#fff9}:root.light .audio-trim-region{background:#4bd0ff33}.batch-export-modal{width:90%;max-width:500px}.batch-export-section{margin-bottom:20px}.batch-export-section h3{color:var(--text);margin:0 0 12px;font-size:.9rem;font-weight:600}.batch-export-section label{color:var(--text-muted);flex-direction:column;gap:8px;font-size:.85rem;display:flex}.batch-export-section input[type=text]{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;padding:8px 12px;font-size:.9rem}.batch-export-section input[type=text]:focus{border-color:var(--accent);outline:none}.batch-export-section input[type=range]{width:100%;margin-top:4px}.batch-export-formats{flex-direction:column;gap:8px;display:flex}.batch-export-format-option{border:1px solid var(--border);background:var(--bg);cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:12px;transition:all .15s;display:flex}.batch-export-format-option:hover:not(.disabled){border-color:var(--accent);background:#4bd0ff0d}.batch-export-format-option.selected{border-color:var(--accent);background:#4bd0ff1a}.batch-export-format-option.disabled{opacity:.5;cursor:not-allowed}.batch-export-format-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.format-info{flex-direction:column;gap:2px;display:flex}.format-label{color:var(--text);font-size:.9rem;font-weight:600}.format-description{color:var(--text-muted);font-size:.8rem}.batch-export-progress h3{color:var(--text);margin:0 0 16px;font-size:.9rem;font-weight:600}.batch-export-items{flex-direction:column;gap:12px;display:flex}.batch-export-item{border:1px solid var(--border);background:var(--bg);border-radius:8px;padding:12px}.batch-export-item.current{border-color:var(--accent)}.batch-export-item.done{border-color:var(--success)}.batch-export-item.error{border-color:var(--error)}.batch-export-item-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.batch-export-item-format{color:var(--text);font-size:.85rem;font-weight:600}.batch-export-item-status{color:var(--text-muted);font-size:.8rem}.batch-export-item.done .batch-export-item-status{color:var(--success)}.batch-export-item.error .batch-export-item-status{color:var(--error)}.batch-export-item-progress{background:var(--border);border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.batch-export-item-progress-bar{background:var(--accent);height:100%;transition:width .2s}.batch-export-item-error{color:var(--error);font-size:.8rem}.batch-export-item .btn.small{padding:4px 8px;font-size:.75rem}.batch-export-running-hint{color:var(--text-muted);margin:0;font-size:.85rem}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;margin-top:16px;padding-top:16px;display:flex}.export-history-modal{width:90%;max-width:550px}.export-history-empty{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.export-history-empty svg{opacity:.4;margin-bottom:16px}.export-history-empty p{color:var(--text);margin:0 0 4px;font-size:1rem;font-weight:600}.export-history-empty span{font-size:.85rem}.export-history-list{flex-direction:column;gap:8px;max-height:400px;display:flex;overflow-y:auto}.export-history-item{background:var(--bg);border:1px solid var(--border);border-radius:8px;align-items:center;gap:12px;padding:12px;transition:border-color .15s;display:flex}.export-history-item:hover{border-color:var(--accent)}.export-history-item-icon{width:40px;height:40px;color:var(--accent);background:#4bd0ff1a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.export-history-item-icon[data-type=video]{color:var(--accent-2);background:#f2a63b1a}.export-history-item-icon[data-type=gif]{color:#a855f7;background:#a855f71a}.export-history-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.export-history-item-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.export-history-item-meta{color:var(--text-muted);font-size:.75rem}.export-history-item-actions{flex-shrink:0;gap:8px;display:flex}.export-history-item-actions .btn.small{padding:6px 10px;font-size:.75rem}.export-history-item-actions .btn.ghost{padding:6px}.export-history-item-actions .btn.ghost svg{opacity:.6}.export-history-item-actions .btn.ghost:hover svg{opacity:1}.btn.has-badge{position:relative}.btn .badge{text-align:center;color:#fff;background:var(--accent);border-radius:9px;min-width:18px;height:18px;padding:0 5px;font-size:.65rem;font-weight:600;line-height:18px;position:absolute;top:-6px;right:-6px}.template-modal{flex-direction:column;width:90vw;max-width:1100px;max-height:85vh;display:flex}.template-filters{border-bottom:1px solid var(--border);flex-direction:column;gap:12px;padding:0 24px 16px;display:flex}.template-search{border:1px solid var(--border);background:var(--panel-strong);width:100%;color:var(--text);border-radius:8px;padding:10px 14px;font-size:.9rem}.template-search:focus{border-color:var(--accent);outline:none}.template-search::placeholder{color:var(--text-muted)}.template-categories{flex-wrap:wrap;gap:8px;display:flex}.template-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));align-content:start;gap:16px;padding:20px 24px;display:grid;overflow-y:auto}.template-card-wrapper{position:relative}.template-card{background:var(--panel-strong);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:12px;flex-direction:column;width:100%;padding:0;transition:all .2s;display:flex;overflow:hidden}.template-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.template-delete-btn{cursor:pointer;width:28px;height:28px;color:var(--text-muted);opacity:0;z-index:2;background:#000000b3;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:8px;right:8px}.template-card-wrapper:hover .template-delete-btn{opacity:1}.template-delete-btn:hover{background:var(--accent-3);color:#fff}.template-preview{aspect-ratio:4/3;background:var(--bg);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.template-preview img{object-fit:cover;width:100%;height:100%}.template-preview-placeholder{color:var(--text-muted);opacity:.4;justify-content:center;align-items:center;display:flex}.template-badge{text-transform:uppercase;letter-spacing:.05em;background:var(--accent);color:#fff;border-radius:4px;padding:4px 8px;font-size:.7rem;font-weight:600;position:absolute;top:8px;right:8px}.template-info{flex-direction:column;gap:6px;padding:14px;display:flex}.template-info h4{color:var(--text);margin:0;font-size:.95rem;font-weight:600}.template-info p{color:var(--text-muted);margin:0;font-size:.8rem;line-height:1.4}.template-meta{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:.7rem;font-weight:500;display:inline-block}.template-grid .empty-state{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:48px 24px;font-size:.95rem}.save-template-modal{width:90vw;max-width:500px}.save-template-modal .modal-body{flex-direction:column;gap:20px;padding:20px 24px;display:flex}.save-template-modal .form-group{flex-direction:column;gap:8px;display:flex}.save-template-modal .form-group label{color:var(--text);font-size:.85rem;font-weight:500}.save-template-modal .form-group input,.save-template-modal .form-group textarea{border:1px solid var(--border);background:var(--panel-strong);color:var(--text);resize:vertical;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:.9rem}.save-template-modal .form-group input:focus,.save-template-modal .form-group textarea:focus{border-color:var(--accent);outline:none}.save-template-modal .form-group input::placeholder,.save-template-modal .form-group textarea::placeholder{color:var(--text-muted)}.template-category-select{flex-wrap:wrap;gap:8px;display:flex}.template-preview-summary{background:var(--panel-strong);border:1px solid var(--border);border-radius:8px;padding:16px}.template-preview-summary h4{color:var(--text);margin:0 0 12px;font-size:.85rem;font-weight:600}.template-preview-summary ul{gap:16px;margin:0;padding:0;list-style:none;display:flex}.template-preview-summary li{color:var(--text-muted);font-size:.85rem}.template-preview-summary li:before{content:"";background:var(--accent);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-right:8px;display:inline-block}.gradient-editor{background:var(--panel-strong);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:12px;padding:12px;display:flex}.gradient-type-selector{flex-direction:column;gap:8px;display:flex}.gradient-type-label,.gradient-stops-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.gradient-stops{flex-direction:column;gap:8px;display:flex}.gradient-stop-row{align-items:center;gap:8px;display:flex}.gradient-stop-row input[type=color]{border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;width:32px;height:32px;padding:0}.gradient-stop-row input[type=range]{flex:1;min-width:60px}.gradient-stop-row span{color:var(--text-muted);text-align:right;min-width:36px;font-size:.8rem}.gradient-stop-row .btn.small{flex-shrink:0;padding:4px 8px;font-size:.8rem}.brandkit-panel{flex-direction:column;gap:16px;display:flex}.brandkit-selector label{color:var(--text-muted);flex-direction:column;gap:6px;font-size:.8rem;display:flex}.brandkit-selector select{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:8px 10px;font-size:.9rem}.brandkit-create{gap:8px;display:flex}.brandkit-create input{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:6px;flex:1;padding:8px 10px;font-size:.85rem}.brandkit-name-edit{border-bottom:1px solid var(--border);gap:8px;padding-bottom:12px;display:flex}.brandkit-name-edit input{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:6px;flex:1;padding:8px 10px;font-size:.9rem;font-weight:600}.brandkit-section{flex-direction:column;gap:10px;display:flex}.brandkit-section h4{color:var(--text);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.8rem;font-weight:600}.brandkit-colors,.brandkit-fonts{flex-direction:column;gap:8px;display:flex}.brandkit-color-item{align-items:center;gap:8px;display:flex}.brandkit-color-item input[type=color]{border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;width:32px;height:32px;padding:0}.brandkit-color-item .color-name-input{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:6px;flex:1;padding:6px 10px;font-size:.85rem}.brandkit-add-row{align-items:center;gap:8px;margin-top:4px;display:flex}.brandkit-add-row input[type=color]{border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;width:32px;height:32px;padding:0}.brandkit-add-row input[type=text]{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:6px;flex:1;padding:6px 10px;font-size:.85rem}.brandkit-font-item{background:var(--panel-strong);border-radius:6px;align-items:center;gap:8px;padding:8px;display:flex}.brandkit-font-item .font-preview{background:var(--bg);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.brandkit-font-item .font-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.brandkit-font-item .font-name-input{color:var(--text);background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 8px;font-size:.85rem;font-weight:500}.brandkit-font-item .font-name-input:hover,.brandkit-font-item .font-name-input:focus{background:var(--bg);border-color:var(--border)}.brandkit-font-item .font-meta{color:var(--text-muted);padding-left:8px;font-size:.7rem}.brandkit-add-font{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.brandkit-add-font input[type=text]{background:var(--panel-strong);border:1px solid var(--border);min-width:120px;color:var(--text);border-radius:6px;flex:1;padding:6px 10px;font-size:.85rem}.brandkit-add-font select{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:6px 10px;font-size:.85rem}.brandkit-logo select{background:var(--panel-strong);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;padding:8px 10px;font-size:.85rem}.brandkit-empty{text-align:center;color:var(--text-muted);padding:20px}.brandkit-empty p{margin:0 0 8px}.btn.danger{color:var(--accent-4)}.btn.danger:hover{background:#ff7a7026}.helper-text{color:var(--text-muted);margin-top:6px;font-size:.75rem}.layer-context-menu{background:var(--panel);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;min-width:180px;padding:6px 0;box-shadow:0 8px 32px #0006}.context-menu-item{width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:8px 14px;font-size:.85rem;transition:background .15s;display:flex}.context-menu-item:hover{background:var(--panel-strong)}.context-menu-item:disabled{opacity:.4;cursor:not-allowed}.context-menu-item:disabled:hover{background:0 0}.context-menu-item.danger{color:var(--accent-3)}.context-menu-item.danger:hover{background:#ff7a7026}.context-menu-item svg{opacity:.7;flex-shrink:0}.context-menu-item .shortcut{color:var(--text-muted);opacity:.6;margin-left:auto;font-size:.7rem}.context-menu-divider{background:var(--border);height:1px;margin:6px 0}.recent-colors{margin-top:8px}.recent-colors-label{color:var(--text-muted);margin-bottom:6px;font-size:.7rem;display:block}.recent-colors-grid{flex-wrap:wrap;gap:4px;display:flex}.recent-color-swatch{cursor:pointer;border:2px solid #0000;border-radius:4px;width:20px;height:20px;transition:border-color .15s,transform .15s}.recent-color-swatch:hover{border-color:var(--text-muted);transform:scale(1.15)}.recent-color-swatch.active{border-color:var(--accent)}.recent-color-swatch.transparent{background-color:#fff;background-image:linear-gradient(45deg,#ccc 25%,#0000 25%),linear-gradient(-45deg,#ccc 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#ccc 75%),linear-gradient(-45deg,#0000 75%,#ccc 75%);background-position:0 0,0 4px,4px -4px,-4px 0;background-size:8px 8px}.hex-input-row{margin-bottom:8px}.hex-input{background:var(--panel-strong);border:1px solid var(--border);width:100%;color:var(--text);border-radius:4px;padding:6px 10px;font-family:monospace;font-size:.85rem}.hex-input:focus{border-color:var(--accent);outline:none}.hex-input::placeholder{color:var(--text-muted);opacity:.5}.layer-bulk-actions{border-top:1px solid var(--border);gap:8px;margin-top:10px;padding:10px 0 0;display:flex}.layer-bulk-actions .btn{flex:1;font-size:.75rem}.canvas-bg-control{background:var(--panel-strong);border-radius:6px;align-items:center;gap:6px;padding:4px 8px;display:flex}.canvas-bg-control span{color:var(--text-muted);font-size:.75rem}.canvas-bg-control input[type=color]{border:2px solid var(--border);cursor:pointer;border-radius:4px;width:24px;height:24px;padding:0}.canvas-bg-control input[type=color]::-webkit-color-swatch-wrapper{padding:0}.canvas-bg-control input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}.bg-preset{border:2px solid var(--border);cursor:pointer;border-radius:4px;width:20px;height:20px;transition:transform .15s,border-color .15s}.bg-preset:hover{border-color:var(--accent);transform:scale(1.1)}.bg-preset.white{background:#fff}.bg-preset.black{background:#000}.bg-preset.gray{background:gray}.bg-preset.transparent{background-color:#fff;background-image:linear-gradient(45deg,#ccc 25%,#0000 25%),linear-gradient(-45deg,#ccc 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#ccc 75%),linear-gradient(-45deg,#0000 75%,#ccc 75%);background-position:0 0,0 4px,4px -4px,-4px 0;background-size:8px 8px}.stage.transparent-bg{background-color:#f5f5f5;background-image:linear-gradient(45deg,#e0e0e0 25%,#0000 25%),linear-gradient(-45deg,#e0e0e0 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#e0e0e0 75%),linear-gradient(-45deg,#0000 75%,#e0e0e0 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px}.range-number{text-align:center;background:var(--panel-strong);border:1px solid var(--border);width:50px;color:var(--text);border-radius:4px;padding:4px 6px;font-size:.8rem}.range-number:focus{border-color:var(--accent);outline:none}.range-row .range-number{margin-left:8px}.layer-search{margin-bottom:10px;position:relative}.layer-search input{background:var(--panel-strong);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;padding:8px 30px 8px 10px;font-size:.85rem}.layer-search input:focus{border-color:var(--accent);outline:none}.layer-search input::placeholder{color:var(--text-muted)}.search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.2rem;line-height:1;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-clear:hover{color:var(--text)}.layer-type-icon{width:20px;height:20px;color:var(--text-muted);opacity:.7;flex-shrink:0;justify-content:center;align-items:center;display:flex}.layer-type-icon svg{width:14px;height:14px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.sr-only-focusable:focus,.sr-only-focusable:active{width:auto;height:auto;padding:inherit;margin:inherit;clip:auto;white-space:normal;position:static;overflow:visible}.sr-live-region{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.reveal{opacity:1!important;transform:none!important}.btn,.layer-item,input,select{transition:none!important}}@media (prefers-contrast:more){:root{--bg:#000;--panel:#0a0a0a;--panel-strong:#111;--border:#fff;--text:#fff;--text-muted:#ccc;--accent:#0ff;--accent-2:#0f0;--accent-3:red;--accent-4:#fff}.btn{border:2px solid}.btn.primary{background:var(--accent);color:#000;border-color:var(--accent)}.btn.secondary{color:var(--text);border-color:var(--text);background:0 0}.btn.ghost{border:1px solid var(--text-muted)}.btn.ghost:hover{border-color:var(--text);background:#ffffff1a}.layer-item{border:1px solid var(--border)}.layer-item.active{border-color:var(--accent);background:#0ff3}input,select,textarea{border:2px solid var(--text-muted);background:#000}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:2px solid var(--accent)}.panel{border:1px solid var(--border)}.stage-shell{border:2px solid var(--border)}.collapsible-panel{border:1px solid var(--border)}.layer-count-badge,.selected-layer-badge{border:2px solid var(--accent);background:#00ffff4d}.canvas-dimensions,.layer-badge-pos,.layer-badge-size{color:var(--text)}}.keyframe-editor{background:var(--panel);border-radius:4px;flex-direction:column;gap:8px;margin-top:8px;padding:8px;display:flex}.keyframe-timeline{cursor:pointer;-webkit-user-select:none;user-select:none;height:40px;position:relative}.keyframe-track{background:var(--border);border-radius:2px;height:4px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.keyframe-range{background:var(--accent);opacity:.4;border-radius:4px;height:8px;position:absolute;top:50%;transform:translateY(-50%)}.keyframe-playhead{background:var(--accent-2);z-index:1;width:2px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.keyframe-playhead:before{content:"";background:var(--accent-2);border-radius:2px;width:8px;height:8px;position:absolute;top:0;left:50%;transform:translate(-50%)rotate(45deg)}.keyframe-handle{cursor:ew-resize;z-index:2;width:20px;height:20px;position:absolute;top:50%;transform:translate(-50%,-50%)}.keyframe-handle:hover .keyframe-diamond,.keyframe-handle.dragging .keyframe-diamond{background:var(--accent);transform:rotate(45deg)scale(1.2)}.keyframe-diamond{background:var(--text);width:12px;height:12px;margin:4px auto;transition:transform .15s,background .15s;transform:rotate(45deg)}.keyframe-start .keyframe-diamond{background:#4ade80}.keyframe-end .keyframe-diamond{background:#f87171}.keyframe-time-labels{color:var(--text-muted);justify-content:space-between;font-size:.65rem;display:flex;position:absolute;bottom:0;left:0;right:0}.easing-preview{background:var(--panel-strong);border-radius:4px;align-items:center;gap:8px;padding:4px 8px;display:flex;position:relative}.easing-label{color:var(--text-muted);text-transform:capitalize;font-size:.75rem}.easing-curve{width:60px;height:40px}.easing-tooltip{background:var(--panel-strong);border:1px solid var(--border);white-space:nowrap;z-index:10;border-radius:4px;margin-bottom:4px;padding:6px 10px;font-size:.7rem;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.easing-tooltip p{color:var(--text-muted);margin:2px 0}.keyframe-properties{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.properties-label{color:var(--text-muted);margin-right:4px;font-size:.7rem}.properties-list{flex-wrap:wrap;gap:4px;display:flex}.property-badge{color:var(--accent);background:#4bd0ff1a;border:1px solid #4bd0ff4d;border-radius:3px;padding:2px 6px;font-size:.65rem}.animation-card .keyframe-editor{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.keyframe-toggle{width:100%;margin-top:8px;padding:4px 8px;font-size:.75rem}.keyframe-toggle:hover{background:#4bd0ff1a}.cubic-bezier-editor{background:var(--panel);border:1px solid var(--border);border-radius:12px;width:280px;padding:16px;box-shadow:0 8px 32px #0006}.cubic-bezier-editor-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cubic-bezier-editor-header h4{margin:0;font-size:.9rem;font-weight:600}.cubic-bezier-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.2rem;line-height:1}.cubic-bezier-close:hover{color:var(--text)}.cubic-bezier-graph-container{justify-content:center;margin-bottom:12px;display:flex}.cubic-bezier-graph{background:#0003;border-radius:8px}.cubic-bezier-value{text-align:center;margin-bottom:12px}.cubic-bezier-value code{background:var(--panel-strong);color:var(--accent);border-radius:4px;padding:4px 8px;font-size:.75rem}.cubic-bezier-inputs{gap:12px;margin-bottom:12px;display:flex}.cubic-bezier-input-group{flex-direction:column;flex:1;gap:4px;display:flex}.cubic-bezier-input-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.cubic-bezier-input-group input{background:var(--panel-strong);border:1px solid var(--border);width:100%;color:var(--text);text-align:center;border-radius:4px;padding:6px 8px;font-size:.8rem}.cubic-bezier-input-group input:focus{border-color:var(--accent);outline:none}.cubic-bezier-presets{margin-bottom:12px}.cubic-bezier-presets>label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.7rem;display:block}.cubic-bezier-preset-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.cubic-bezier-preset-btn{background:var(--panel-strong);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:4px;transition:all .15s;display:flex}.cubic-bezier-preset-btn:hover{border-color:var(--accent);background:#f2a63b1a}.cubic-bezier-preset-btn span{color:var(--text-muted);text-transform:capitalize;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.55rem;overflow:hidden}.cubic-bezier-preview{border-top:1px solid var(--border);padding-top:12px}.cubic-bezier-preview>label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.7rem;display:block}.cubic-bezier-preview-track{background:var(--panel-strong);border-radius:12px;height:24px;position:relative;overflow:hidden}.cubic-bezier-preview-ball{background:var(--accent);border-radius:50%;width:16px;height:16px;animation:2s infinite bezier-preview;position:absolute;top:4px;left:4px}@keyframes bezier-preview{0%{left:4px}50%{left:calc(100% - 20px)}to{left:4px}}.easing-select-group{align-items:center;gap:4px;display:flex}.easing-select-group select{flex:1}.cubic-bezier-btn{background:var(--panel-strong);border:1px solid var(--border);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;transition:all .15s;display:flex}.cubic-bezier-btn:hover{border-color:var(--accent)}.cubic-bezier-btn.active{border-color:var(--accent);background:#f2a63b33}.cubic-bezier-popup{z-index:100;margin-top:4px;position:absolute;top:100%;left:0}.path-animation-editor{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.path-editor-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}.path-editor-header label{align-items:center;gap:6px;font-size:.75rem;display:flex}.path-editor-header select{padding:2px 6px;font-size:.75rem}.path-editor-header .toggle-row.compact{gap:6px;font-size:.75rem}.path-editor-header .toggle-row.compact input{width:14px;height:14px}.path-editor-canvas{background:var(--panel);border-radius:4px;justify-content:center;padding:4px;display:flex;overflow:hidden}.path-editor-canvas svg{cursor:crosshair;border-radius:2px}.path-editor-actions{align-items:center;gap:8px;margin-top:8px;display:flex}.path-editor-actions .btn.small{padding:2px 8px;font-size:.7rem}.path-point-count{color:var(--text-muted);margin-left:auto;font-size:.7rem}.animation-path-toggle{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:8px;padding:8px 0;display:flex}.animation-path-toggle span{color:var(--text-muted);font-size:.8rem}.tour-overlay{z-index:9998;cursor:pointer;background:#0009;position:fixed;inset:0}.tour-highlight{border-radius:8px;position:relative;z-index:9999!important;box-shadow:0 0 0 4px var(--accent),0 0 20px #4bd0ff66!important}.tour-tooltip{background:var(--panel-strong);border:1px solid var(--border);z-index:10000;border-radius:12px;width:320px;padding:16px;animation:.2s tooltipFadeIn;position:fixed;box-shadow:0 8px 32px #0006}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tour-tooltip-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.tour-tooltip-header h3{color:var(--text);flex:1;margin:0;font-size:1rem;font-weight:600}.tour-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.25rem;line-height:1;display:flex}.tour-close-btn:hover{background:var(--border);color:var(--text)}.tour-tooltip-description{color:var(--text-muted);margin:0 0 16px;font-size:.85rem;line-height:1.5}.tour-tooltip-footer{justify-content:space-between;align-items:center;display:flex}.tour-progress{gap:6px;display:flex}.tour-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:all .2s}.tour-dot.active{background:var(--accent);transform:scale(1.2)}.tour-dot.completed{background:var(--accent);opacity:.5}.tour-actions{gap:8px;display:flex}.tour-step-counter{color:var(--text-muted);font-size:.7rem;position:absolute;top:16px;right:48px}.first-use-tooltip-container{position:relative}.first-use-tooltip{background:var(--panel-strong);border:1px solid var(--accent);z-index:1000;border-radius:8px;width:260px;padding:12px;animation:.3s tooltipFadeIn;position:absolute;box-shadow:0 4px 16px #4bd0ff33}.first-use-tooltip-bottom{top:calc(100% + 12px);left:50%;transform:translate(-50%)}.first-use-tooltip-top{bottom:calc(100% + 12px);left:50%;transform:translate(-50%)}.first-use-tooltip-left{top:50%;right:calc(100% + 12px);transform:translateY(-50%)}.first-use-tooltip-right{top:50%;left:calc(100% + 12px);transform:translateY(-50%)}.first-use-tooltip-arrow{background:var(--panel-strong);border:1px solid var(--accent);width:12px;height:12px;position:absolute;transform:rotate(45deg)}.first-use-tooltip-bottom .first-use-tooltip-arrow{border-bottom:none;border-right:none;margin-left:-6px;top:-7px;left:50%}.first-use-tooltip-top .first-use-tooltip-arrow{border-top:none;border-left:none;margin-left:-6px;bottom:-7px;left:50%}.first-use-tooltip-left .first-use-tooltip-arrow{border-bottom:none;border-left:none;margin-top:-6px;top:50%;right:-7px}.first-use-tooltip-right .first-use-tooltip-arrow{border-top:none;border-right:none;margin-top:-6px;top:50%;left:-7px}.first-use-tooltip-content{position:relative}.first-use-tooltip-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.first-use-tooltip-icon{font-size:1rem}.first-use-tooltip-header h4{color:var(--accent);flex:1;margin:0;font-size:.85rem;font-weight:600}.first-use-tooltip-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:1rem;line-height:1}.first-use-tooltip-close:hover{color:var(--text)}.first-use-tooltip p{color:var(--text-muted);margin:0 0 10px;font-size:.75rem;line-height:1.4}.first-use-tooltip .btn.small{padding:4px 10px;font-size:.7rem}.start-tour-btn{align-items:center;gap:4px;font-size:.75rem;display:flex}.start-tour-btn:before{content:"?";background:var(--accent);width:16px;height:16px;color:var(--bg);border-radius:50%;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:inline-flex}@media (min-width:768px) and (max-width:1024px){.btn,.btn-icon,[role=button],button{min-width:44px;min-height:44px}.btn-icon{width:44px;height:44px}.btn.small{min-height:36px;padding:8px 12px}.topbar{flex-wrap:wrap;gap:8px;padding:12px 16px}.brand-mark{border-radius:10px;width:36px;height:36px}.brand-title{font-size:.95rem}.brand-sub{display:none}.project{min-width:160px}.project label{display:none}.project input{padding:8px 10px;font-size:.85rem}.project-controls{gap:6px}.project-controls .btn{padding:8px 10px;font-size:.8rem}.save-status{display:none}.workspace{grid-template-rows:1fr auto;grid-template-columns:240px minmax(0,1fr);gap:12px;padding:12px}.left-panel{grid-area:1/1/2/2}.center-panel{grid-area:1/2/2/3}.right-panel{flex-direction:row;grid-area:2/1/3/3;gap:12px;max-height:280px;display:flex;overflow-x:auto}.right-panel .panel-card{flex:0 0 280px;min-width:280px}.panel-card{gap:12px;padding:14px}.panel-header h2{font-size:.9rem}.panel-header p{font-size:.75rem}.layer-item{min-height:48px;padding:10px 12px}.layer-preview{width:36px;height:36px}.layer-text .label{font-size:.8rem}.canvas-toolbar{gap:6px;padding:8px}.canvas-toolbar .btn-icon{width:40px;height:40px}.zoom-controls{gap:4px}.zoom-value{min-width:50px;font-size:.75rem}.properties-content{gap:12px}.property-group,.property-row{gap:8px}.property-row label{min-width:70px;font-size:.7rem}.property-row input[type=number],.property-row input[type=text],.property-row select{min-height:40px;padding:8px;font-size:.8rem}.color-picker-wrapper{min-height:40px}.timeline{gap:10px;padding:12px}.timeline-controls{gap:6px}.timeline-track{height:36px}.time-marker{font-size:.65rem}.output-preview{max-height:180px}.format-options{gap:6px}.format-option{min-height:44px;padding:10px}.modal-content{max-width:90vw;max-height:85vh}.modal-header{padding:14px 16px}.modal-body{padding:16px}.tour-tooltip{width:280px;padding:14px}.tour-tooltip-header h3{font-size:.95rem}.tour-tooltip-description{font-size:.8rem}.first-use-tooltip{width:240px;padding:10px}}@media (min-width:768px) and (max-width:900px) and (orientation:portrait){.workspace{grid-template-rows:auto 1fr auto;grid-template-columns:1fr}.left-panel{flex-direction:row;grid-area:1/1/2/2;gap:12px;max-height:200px;display:flex;overflow-x:auto}.left-panel .panel-card{flex:0 0 260px;min-width:260px;max-height:180px;overflow-y:auto}.center-panel{grid-area:2/1/3/2}.right-panel{grid-area:3/1/4/2;max-height:240px}.canvas-wrapper{min-height:50vh}.topbar{padding:10px 12px}.brand{gap:8px}.brand-mark{width:32px;height:32px}.project{flex:1;order:2;min-width:120px}.history-controls{order:1}.project-controls{order:3}.start-tour-btn{display:none}}@media (pointer:coarse){.layer-item{min-height:52px;padding:12px 14px}.layer-actions button{width:36px;height:36px}input[type=range]{height:8px}input[type=range]::-webkit-slider-thumb{width:24px;height:24px}input[type=range]::-moz-range-thumb{width:24px;height:24px}.left-panel::-webkit-scrollbar{width:6px;height:6px}.right-panel::-webkit-scrollbar{width:6px;height:6px}.timeline-cursor{width:4px}.keyframe-handle{width:16px;height:16px}.konvajs-content{touch-action:none}.color-preview{width:40px;height:40px}select{padding:10px 12px;font-size:.85rem}.btn+.btn{margin-left:8px}.property-group+.property-group{margin-top:16px}}@media (max-width:767px) and (orientation:landscape){.workspace{grid-template-columns:200px minmax(0,1fr);gap:8px;padding:8px}.right-panel{background:var(--panel);border-top:1px solid var(--border);z-index:20;max-height:40vh;display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.right-panel.visible{display:block}.topbar{padding:8px 12px}.panel-card{padding:10px}}.audio-waveform-container{background:#0c0f1699;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;gap:8px;padding:12px;display:flex}.audio-waveform-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.audio-waveform-header h5{color:var(--text);margin:0;font-size:.78rem;font-weight:500}.audio-waveform-time{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.72rem}.audio-waveform{border-radius:8px;transition:opacity .2s;overflow:hidden}.audio-waveform:hover{opacity:.9}.audio-waveform-controls{align-items:center;gap:8px;margin-top:4px;display:flex}.audio-waveform-controls .btn{padding:4px 8px;font-size:.7rem}:root.light .audio-waveform-container{background:#fffc;border-color:#00000014}.layer-group{background:#4bd0ff0d;border:1px solid #4bd0ff33;border-radius:12px;margin:4px 0;overflow:hidden}.layer-group.expanded{border-color:#4bd0ff66}.layer-group-header{cursor:pointer;background:#4bd0ff1a;align-items:center;gap:8px;padding:8px 12px;transition:background .15s;display:flex}.layer-group-header:hover{background:#4bd0ff26}.layer-group-header.selected{background:#4bd0ff40}.layer-group-expand{width:20px;height:20px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:transform .2s,color .15s;display:flex}.layer-group-expand:hover{color:var(--text)}.layer-group.expanded .layer-group-expand{transform:rotate(90deg)}.layer-group-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.8rem;font-weight:500;overflow:hidden}.layer-group-count{color:var(--text-muted);background:#ffffff1a;border-radius:8px;padding:2px 6px;font-size:.7rem}.layer-group-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex}.layer-group-header:hover .layer-group-actions{opacity:1}.layer-group-actions .btn{padding:4px 6px;font-size:.68rem}.layer-group-children{border-top:1px solid #4bd0ff26;padding-left:16px;display:none}.layer-group.expanded .layer-group-children{display:block}.layer-group-children .layer-item{border-radius:8px;margin:4px 8px 4px 0}:root.light .layer-group{background:#4bd0ff08;border-color:#4bd0ff26}:root.light .layer-group-header{background:#4bd0ff14}:root.light .layer-group-header:hover{background:#4bd0ff1f}:root.light .layer-group-count{background:#0000000f}.browser-warning,.browser-info,.browser-error{border-radius:10px;align-items:flex-start;gap:10px;margin-top:10px;padding:10px 14px;font-size:.78rem;line-height:1.4;display:flex}.browser-warning{color:#fbbf24;background:#fbbf241f;border:1px solid #fbbf244d}.browser-warning svg{flex-shrink:0;margin-top:1px}.browser-info{color:#4bd0ff;background:#4bd0ff1a;border:1px solid #4bd0ff40}.browser-info svg{flex-shrink:0;margin-top:1px}.browser-error{color:#f87171;background:#f871711f;border:1px solid #f871714d}.browser-error svg{flex-shrink:0;margin-top:1px}:root.light .browser-warning{color:#b45309;background:#fbbf2414}:root.light .browser-info{color:#0284c7;background:#4bd0ff0f}:root.light .browser-error{color:#dc2626;background:#f8717114}.layer-item.is-child{border-left:2px solid #4bd0ff4d;margin-left:12px}.layer-item.is-group{background:#4bd0ff14;border-color:#4bd0ff33}.layer-item.is-group:hover{background:#4bd0ff1f}.layer-item.is-group.active{border-color:#4bd0ff99}.layer-group-expand{width:18px;height:18px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:flex}.layer-group-expand:hover{color:var(--text);background:#ffffff1a}.layer-group-count{color:var(--text-muted);background:#4bd0ff26;border-radius:6px;margin-left:auto;padding:1px 5px;font-size:.68rem}:root.light .layer-item.is-child{border-left-color:#4bd0ff66}:root.light .layer-item.is-group{background:#4bd0ff0d}:root.light .layer-group-expand:hover{background:#0000000d}.audio-assets-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.audio-assets-row .label{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.audio-assets-chips{flex-wrap:wrap;gap:6px;display:flex}.audio-assets-chips .chip{color:var(--accent);cursor:pointer;background:#4bd0ff1a;border:1px solid #4bd0ff40;border-radius:16px;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;transition:all .15s;display:inline-flex}.audio-assets-chips .chip:hover{background:#4bd0ff33;border-color:#4bd0ff66}.audio-tracks-list{flex-direction:column;gap:8px;display:flex}.audio-tracks-list .empty-state{text-align:center;color:var(--text-muted);background:#ffffff05;border:1px dashed #ffffff1a;border-radius:10px;padding:20px;font-size:.75rem}.audio-track-item{background:#0c0f1699;border:1px solid #ffffff14;border-radius:10px;flex-direction:column;gap:8px;padding:10px 12px;transition:all .15s;display:flex}.audio-track-item:hover{border-color:#ffffff26}.audio-track-item.muted{opacity:.5}.audio-track-item.solo{background:#fbbf240d;border-color:#fbbf2480}.track-header{align-items:center;gap:8px;display:flex}.track-number{width:20px;height:20px;color:var(--accent);background:#4bd0ff26;border-radius:50%;justify-content:center;align-items:center;font-size:.68rem;font-weight:600;display:flex}.track-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.78rem;font-weight:500;overflow:hidden}.track-duration{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.7rem}.track-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.track-volume{flex:1;align-items:center;gap:6px;min-width:120px;display:flex}.track-volume label{color:var(--text-muted);align-items:center;display:flex}.track-volume input[type=range]{flex:1;min-width:60px;height:4px}.track-volume .volume-value{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;min-width:32px;font-size:.68rem}.track-start,.track-fades{align-items:center;gap:4px;display:flex}.track-start label,.track-fades label{color:var(--text-muted);font-size:.68rem}.track-start input[type=number],.track-fades input[type=number]{width:50px;color:var(--text);font-variant-numeric:tabular-nums;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;padding:3px 6px;font-size:.7rem}.track-start input[type=number]:focus,.track-fades input[type=number]:focus{border-color:var(--accent);outline:none}.track-start span{color:var(--text-muted);font-size:.68rem}.track-actions{align-items:center;gap:4px;margin-left:auto;display:flex}.track-btn{border-radius:6px;justify-content:center;align-items:center;min-width:28px;height:28px;padding:0 6px;font-size:.72rem;font-weight:600;transition:all .15s;display:flex}.track-btn.active{color:#f87171;background:#f8717133;border-color:#f871714d}.track-btn.solo-active{color:#fbbf24;background:#fbbf2433;border-color:#fbbf244d}.track-btn.danger:hover{color:#f87171;background:#f8717126}.master-info{border-top:1px solid #ffffff14;margin-top:8px;padding-top:8px}.master-info .helper{color:var(--text-muted);font-size:.72rem}:root.light .audio-assets-chips .chip{background:#4bd0ff14}:root.light .audio-tracks-list .empty-state{background:#00000005;border-color:#0000001a}:root.light .audio-track-item{background:#fffc;border-color:#00000014}:root.light .audio-track-item:hover{border-color:#00000026}:root.light .audio-track-item.solo{background:#fbbf2414}:root.light .track-start input[type=number],:root.light .track-fades input[type=number]{background:#00000008;border-color:#0000001a}
