:root{--brand: #19c37d;--brand-strong: #0ea76a;--brand-soft: rgba(25, 195, 125, .12);--brand-glow: rgba(25, 195, 125, .35);--danger: #ef5350;--warning: #f5b942;--info: #4da3ff;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--font-ui: "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;--topbar-h: 52px;--scenesbar-h: 96px;--sidebar-rail-w: 56px;--sidebar-panel-w: 288px;--rightpanel-w: 292px;--shadow-1: 0 2px 10px rgba(0, 0, 0, .18);--shadow-2: 0 10px 36px rgba(0, 0, 0, .28);--ease: cubic-bezier(.22, 1, .36, 1)}[data-theme=dark]{--bg-app: #0e1116;--bg-panel: #161b22;--bg-panel-2: #1c232d;--bg-elevated: #212a36;--bg-canvas: #0a0d12;--bg-input: #0f141b;--border: #2a3441;--border-soft: #222b36;--text-1: #e8edf4;--text-2: #9aa7b8;--text-3: #677687;--hover: rgba(255, 255, 255, .06);--active: rgba(25, 195, 125, .14);--grid-dot: rgba(255, 255, 255, .05);--scrollbar: #2c3644;--backdrop: rgba(4, 6, 10, .66)}[data-theme=light]{--bg-app: #eef1f5;--bg-panel: #ffffff;--bg-panel-2: #f5f7fa;--bg-elevated: #ffffff;--bg-canvas: #e2e6ec;--bg-input: #f2f4f8;--border: #d7dde6;--border-soft: #e4e9f0;--text-1: #16202c;--text-2: #5a6878;--text-3: #8b97a6;--hover: rgba(10, 30, 50, .05);--active: rgba(25, 195, 125, .14);--grid-dot: rgba(10, 30, 60, .08);--scrollbar: #c3ccd8;--backdrop: rgba(20, 28, 40, .45);--shadow-1: 0 2px 10px rgba(30, 45, 70, .1);--shadow-2: 0 12px 36px rgba(30, 45, 70, .16)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-ui);background:var(--bg-app);color:var(--text-1);font-size:14px;overflow:hidden;-webkit-font-smoothing:antialiased}button{font-family:inherit;border:none;background:none;color:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:13px;color:var(--text-1);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 9px;outline:none;transition:border-color .15s;min-width:0}input:focus,select:focus,textarea:focus{border-color:var(--brand)}input[type=color]{padding:2px;height:30px;width:38px;cursor:pointer}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--border);border:none;padding:0;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--bg-panel);box-shadow:0 1px 4px #0000004d}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:5px;border:2px solid transparent;background-clip:content-box}::selection{background:var(--brand-glow)}h1,h2,h3,h4{font-weight:600}[data-tip]{position:relative}[data-tip]:after{content:attr(data-tip);position:absolute;left:50%;top:calc(100% + 7px);transform:translate(-50%) translateY(-2px);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-1);font-size:11px;font-weight:500;white-space:nowrap;padding:5px 9px;border-radius:6px;box-shadow:var(--shadow-1);opacity:0;pointer-events:none;transition:opacity .12s ease .3s,transform .12s ease .3s;z-index:500}[data-tip]:hover:after{opacity:1;transform:translate(-50%) translateY(0)}[data-tip][data-tip-pos=bottom-left]:after{left:auto;right:0;transform:translateY(-2px)}[data-tip][data-tip-pos=bottom-left]:hover:after{transform:translateY(0)}[data-tip][data-tip-pos=top]:after{top:auto;bottom:calc(100% + 7px)}.muted{color:var(--text-2)}.tiny{font-size:11px}.studio{display:flex;flex-direction:column;height:100%;overflow:hidden}.studio-body{flex:1;display:flex;min-height:0;position:relative}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--bg-panel);border-bottom:1px solid var(--border-soft);z-index:60;flex-shrink:0}.topbar-logo{display:flex;align-items:center;gap:9px;padding-right:12px;border-right:1px solid var(--border-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.topbar-logo svg{width:28px;height:28px}.brand-word{font-size:13px;font-weight:700;letter-spacing:.14em;white-space:nowrap}.brand-word b{color:var(--brand)}.brand-sub{display:block;font-size:9px;font-weight:600;letter-spacing:.22em;color:var(--text-3);text-transform:uppercase}.topbar-group{display:flex;align-items:center;gap:4px;padding:0 6px}.topbar-group+.topbar-group{border-left:1px solid var(--border-soft)}.topbar-spacer{flex:1}.project-name-input{background:transparent;border:1px solid transparent;font-weight:600;font-size:14px;width:190px;padding:6px 8px}.project-name-input:hover{border-color:var(--border)}.project-name-input:focus{background:var(--bg-input);border-color:var(--brand)}.save-pill{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:5px;padding:4px 8px;white-space:nowrap}.save-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--text-3)}.save-pill.saved .dot{background:var(--brand)}.save-pill.dirty .dot{background:var(--warning)}.zoom-label{font-size:12px;color:var(--text-2);min-width:46px;text-align:center;font-variant-numeric:tabular-nums;cursor:pointer}.side-rail{width:var(--sidebar-rail-w);background:var(--bg-panel);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:4px;z-index:50;flex-shrink:0}.rail-btn{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-2);transition:background .15s,color .15s;position:relative}.rail-btn:hover{background:var(--hover);color:var(--text-1)}.rail-btn.active{background:var(--active);color:var(--brand)}.rail-btn.active:before{content:"";position:absolute;left:-7px;top:9px;bottom:9px;width:3px;border-radius:2px;background:var(--brand)}.rail-btn svg{width:20px;height:20px}.rail-flex{flex:1}.side-panel{width:var(--sidebar-panel-w);background:var(--bg-panel);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;min-height:0;z-index:45;flex-shrink:0}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:13px 14px 9px;flex-shrink:0}.panel-head h3{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2)}.panel-scroll{flex:1;overflow-y:auto;padding:0 14px 18px;min-height:0}.canvas-wrap{flex:1;position:relative;background:var(--bg-canvas);min-width:0;overflow:hidden;background-image:radial-gradient(var(--grid-dot) 1px,transparent 1px);background-size:22px 22px}.canvas-wrap.tool-pan{cursor:grab}.canvas-wrap.tool-pan:active{cursor:grabbing}.canvas-hud{position:absolute;bottom:12px;left:12px;display:flex;gap:6px;z-index:20}.hud-chip{background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:20px;padding:5px 11px;font-size:11px;color:var(--text-2);box-shadow:var(--shadow-1);white-space:nowrap}.right-panel{width:var(--rightpanel-w);background:var(--bg-panel);border-left:1px solid var(--border-soft);display:flex;flex-direction:column;min-height:0;z-index:45;flex-shrink:0}.right-tabs{display:flex;padding:8px 10px 0;gap:4px;flex-shrink:0}.right-tab{flex:1;padding:8px 4px;font-size:12px;font-weight:600;color:var(--text-2);border-radius:8px 8px 0 0;border-bottom:2px solid transparent;text-align:center}.right-tab:hover{color:var(--text-1)}.right-tab.active{color:var(--brand);border-bottom-color:var(--brand)}.scenes-bar{height:var(--scenesbar-h);background:var(--bg-panel);border-top:1px solid var(--border-soft);display:flex;align-items:center;padding:0 12px;gap:10px;flex-shrink:0;z-index:40}.scenes-list{display:flex;gap:8px;overflow-x:auto;padding:6px 2px;flex:1}.scene-card{width:116px;height:72px;border-radius:var(--radius-md);background:var(--bg-panel-2);border:2px solid var(--border-soft);flex-shrink:0;cursor:pointer;position:relative;overflow:hidden;transition:border-color .15s,transform .15s;-webkit-user-select:none;user-select:none}.scene-card:hover{border-color:var(--border)}.scene-card.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.scene-card.drag-over{border-color:var(--info)}.scene-thumb{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.scene-thumb-empty{background:var(--bg-panel-2)}.scene-shade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000006b,#0000 38%,#0000 55%,#0000008c);pointer-events:none}.scene-num{position:absolute;top:3px;left:6px;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7)}.scene-name{position:absolute;left:6px;bottom:4px;max-width:64px;font-size:10.5px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-name-input{position:absolute;left:4px;bottom:3px;width:70px;font-size:10.5px;padding:2px 4px}.scene-duration{position:absolute;right:4px;bottom:4px;font-size:9.5px;font-weight:700;color:#fff;background:#00000073;border-radius:9px;padding:2px 6px;line-height:1.2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.scene-duration:hover{background:var(--brand);color:#06281a}.scene-dur-input{position:absolute;right:3px;bottom:3px;width:46px;font-size:10px;padding:2px 4px}.scenes-bar-label{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.scene-actions{position:absolute;top:3px;right:4px;display:none;gap:2px}.scene-card:hover .scene-actions{display:flex}.scene-actions button{width:18px;height:18px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-2);background:var(--bg-elevated)}.scene-actions button:hover{color:var(--text-1);background:var(--hover)}.scene-actions svg{width:11px;height:11px}.scene-add{width:56px;height:68px;border-radius:var(--radius-md);border:2px dashed var(--border);color:var(--text-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s}.scene-add:hover{border-color:var(--brand);color:var(--brand)}@media (max-width: 1100px){:root{--sidebar-panel-w: 248px;--rightpanel-w: 248px}}@media (max-width: 900px){.side-panel{position:absolute;left:var(--sidebar-rail-w);top:0;bottom:0;box-shadow:var(--shadow-2)}.right-panel{position:absolute;right:0;top:0;bottom:0;box-shadow:var(--shadow-2)}.brand-word{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:600;border:1px solid var(--border);background:var(--bg-panel-2);color:var(--text-1);transition:.15s var(--ease);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--hover);border-color:var(--text-3)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn svg{width:15px;height:15px}.btn-primary{background:var(--brand);border-color:var(--brand);color:#06281a}.btn-primary:hover{background:var(--brand-strong);border-color:var(--brand-strong)}.btn-danger{color:var(--danger);border-color:#ef535066}.btn-danger:hover{background:#ef53501f;border-color:var(--danger)}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--hover);border-color:transparent}.btn-sm{padding:5px 10px;font-size:12px;border-radius:var(--radius-sm)}.btn-block{width:100%}.icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--text-2);transition:.13s;flex-shrink:0}.icon-btn:hover{background:var(--hover);color:var(--text-1)}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.icon-btn:disabled:hover{background:none;color:var(--text-2)}.icon-btn.active{background:var(--active);color:var(--brand)}.icon-btn svg{width:17px;height:17px}.section{padding:12px 0;border-bottom:1px solid var(--border-soft)}.section:last-child{border-bottom:none}.section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-3);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}.field{margin-bottom:10px}.field label{display:block;font-size:11px;font-weight:600;color:var(--text-2);margin-bottom:5px}.field-row{display:flex;gap:8px;align-items:center;margin-bottom:10px}.field-row>*{min-width:0}.field-row .grow{flex:1}.field-inline{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px}.field-inline label{font-size:12px;color:var(--text-2);font-weight:500;flex-shrink:0}.field-inline input[type=range]{flex:1}.field-val{font-size:11px;color:var(--text-3);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.num-input{width:64px}.chip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.chip-grid.cols-2{grid-template-columns:repeat(2,1fr)}.preset-chip{background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:9px 4px 7px;display:flex;flex-direction:column;align-items:center;gap:5px;transition:.14s;color:var(--text-2)}.preset-chip:hover{border-color:var(--brand);color:var(--text-1);transform:translateY(-1px)}.preset-chip.selected{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}.preset-chip .emoji{font-size:19px;line-height:1}.preset-chip .lbl{font-size:10px;font-weight:600;text-align:center;line-height:1.15}.preset-chip svg{width:30px;height:30px}.search-box{position:relative;margin-bottom:10px}.search-box input{width:100%;padding-left:30px}.search-box svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-3);pointer-events:none}.cat-tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}.cat-tab{font-size:11px;font-weight:600;padding:5px 10px;border-radius:20px;background:var(--bg-panel-2);border:1px solid var(--border-soft);color:var(--text-2);transition:.13s}.cat-tab:hover{color:var(--text-1)}.cat-tab.active{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.asset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.asset-card{background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:.14s;position:relative;padding:6px 3px;-webkit-user-select:none;user-select:none}.asset-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow-1)}.asset-card svg{width:34px;height:34px;flex-shrink:0}.asset-card .asset-name{font-size:9.5px;font-weight:600;color:var(--text-2);text-align:center;line-height:1.15;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.asset-fav{position:absolute;top:3px;right:3px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--text-3);opacity:0;transition:.13s}.asset-card:hover .asset-fav{opacity:1}.asset-fav.faved{opacity:1;color:var(--warning)}.asset-fav svg{width:13px;height:13px}.draw-tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.draw-tool{background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:10px 4px 8px;display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--text-2);transition:.13s}.draw-tool:hover{border-color:var(--brand);color:var(--text-1);transform:translateY(-1px)}.draw-tool.active{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}.draw-tool svg{width:19px;height:19px}.draw-tool span{font-size:10px;font-weight:600}.brush-preview{display:flex;align-items:center;justify-content:center;height:70px;background:var(--bg-panel-2);border-radius:var(--radius-md);margin-top:4px}.brush-preview span{display:block;border-radius:50%}.char-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.char-card{background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;cursor:pointer;transition:.14s;position:relative;padding:8px 3px 6px;-webkit-user-select:none;user-select:none;min-height:96px}.char-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow-1)}.char-preview{height:52px;display:flex;align-items:center;justify-content:center}.char-card-actions{display:none;position:absolute;bottom:3px;right:3px;gap:2px}.char-card:hover .char-card-actions{display:flex}.char-card-actions button{width:19px;height:19px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-2);background:var(--bg-elevated)}.char-card-actions button:hover{color:var(--text-1)}.char-card-actions svg{width:11px;height:11px}.empty-note{text-align:center;color:var(--text-3);font-size:12px;padding:26px 8px;line-height:1.5}.layer-row{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s}.layer-row:hover{background:var(--hover)}.layer-row.selected{background:var(--active);border-color:var(--brand)}.layer-row.drag-over{border-top:2px solid var(--info)}.layer-thumb{width:26px;height:26px;border-radius:6px;background:var(--bg-panel-2);border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;color:var(--text-2);flex-shrink:0}.layer-thumb svg{width:14px;height:14px}.layer-name{flex:1;font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-name input{width:100%;padding:2px 5px;font-size:12px}.layer-row .icon-btn{width:24px;height:24px;opacity:0}.layer-row:hover .icon-btn,.layer-row .icon-btn.on{opacity:1}.layer-row .icon-btn svg{width:13px;height:13px}.layer-row.is-hidden .layer-name,.layer-row.is-hidden .layer-thumb{opacity:.4}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .16s var(--ease);padding:20px}.modal{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);width:480px;max-width:100%;max-height:86vh;display:flex;flex-direction:column;box-shadow:var(--shadow-2);animation:popIn .18s var(--ease)}.modal.wide{width:660px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border-soft);flex-shrink:0}.modal-head h2{font-size:16px}.modal-body{padding:16px 18px;overflow-y:auto;min-height:0}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px 16px;border-top:1px solid var(--border-soft);flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}.context-menu{position:fixed;z-index:300;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-2);min-width:198px;padding:5px;animation:popIn .12s var(--ease)}.context-menu .cm-item{display:flex;align-items:center;gap:9px;width:100%;padding:7px 10px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--text-1);text-align:left}.context-menu .cm-item:hover{background:var(--hover)}.context-menu .cm-item.danger{color:var(--danger)}.context-menu .cm-item:disabled{opacity:.4;cursor:default}.context-menu .cm-item:disabled:hover{background:none}.context-menu .cm-item svg{width:14px;height:14px;flex-shrink:0}.context-menu .cm-item .kbd{margin-left:auto}.context-menu .cm-sep{height:1px;background:var(--border-soft);margin:5px 4px}.kbd{font-size:10px;color:var(--text-3);background:var(--bg-input);border:1px solid var(--border-soft);border-radius:4px;padding:1px 5px;font-family:inherit}.toast-stack{position:fixed;bottom:calc(var(--scenesbar-h) + 14px);right:14px;display:flex;flex-direction:column;gap:8px;z-index:400}.toast{display:flex;align-items:center;gap:9px;background:var(--bg-elevated);border:1px solid var(--border);border-left:3px solid var(--brand);border-radius:var(--radius-md);padding:10px 14px;font-size:12.5px;font-weight:500;box-shadow:var(--shadow-2);animation:toastIn .22s var(--ease);max-width:320px}.toast.error{border-left-color:var(--danger)}.toast.info{border-left-color:var(--info)}@keyframes toastIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}.project-card{background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:13px;cursor:pointer;transition:.15s;position:relative}.project-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow-1)}.project-card.current{border-color:var(--brand);background:var(--brand-soft)}.project-card h4{font-size:13px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:20px}.project-card .meta{font-size:11px;color:var(--text-3);line-height:1.5}.project-card .pc-actions{display:flex;gap:4px;margin-top:9px}.project-card .pc-actions .icon-btn{width:26px;height:26px}.project-card .pc-actions svg{width:13px;height:13px}.switch{position:relative;width:36px;height:20px;border-radius:12px;background:var(--border);transition:.18s;flex-shrink:0}.switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:.18s var(--ease);box-shadow:0 1px 3px #0000004d}.switch.on{background:var(--brand)}.switch.on:after{left:18px}.segmented{display:flex;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;gap:2px}.segmented button{flex:1;padding:6px 8px;font-size:12px;font-weight:600;color:var(--text-2);border-radius:5px}.segmented button.active{background:var(--bg-elevated);color:var(--text-1);box-shadow:var(--shadow-1)}.shortcut-table{width:100%;border-collapse:collapse}.shortcut-table td{padding:7px 4px;font-size:12.5px;border-bottom:1px solid var(--border-soft)}.shortcut-table td:last-child{text-align:right}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:500}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--brand-soft);border-top-color:var(--brand);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-style-chip{width:100%;background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:11px 10px;margin-bottom:8px;text-align:center;transition:.13s}.text-style-chip:hover{border-color:var(--brand)}.color-swatches{display:flex;gap:6px;flex-wrap:wrap}.swatch{width:24px;height:24px;border-radius:6px;border:2px solid var(--border);cursor:pointer;transition:.12s}.swatch:hover{transform:scale(1.12)}.swatch.selected{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-soft)}.export-scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:8px;margin:4px 0 6px;max-height:196px;overflow-y:auto;padding:2px}.export-scene{position:relative;border:2px solid var(--border-soft);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;aspect-ratio:16/10;background:var(--bg-panel-2);transition:.13s;-webkit-user-select:none;user-select:none}.export-scene:hover{border-color:var(--border)}.export-scene.on{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-soft)}.export-scene.fixed{cursor:default}.export-scene img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.export-scene-ph{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-panel-2)}.export-scene-name{position:absolute;left:0;right:0;bottom:0;padding:10px 6px 4px;font-size:10px;font-weight:600;color:#fff;background:linear-gradient(transparent,#000000b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.export-scene-check{position:absolute;top:4px;right:4px;width:17px;height:17px;border-radius:50%;background:#0006;color:transparent;font-size:11px;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(255,255,255,.55)}.export-scene-check.on{background:var(--brand);color:#06281a;border-color:var(--brand)}.export-files{margin-top:14px;padding-top:12px;border-top:1px solid var(--border-soft)}.export-file-list{display:flex;flex-wrap:wrap;gap:5px}.export-file-chip{font-size:11px;font-weight:600;background:var(--bg-input);border:1px solid var(--border-soft);border-radius:6px;padding:3px 8px;font-family:Courier New,monospace}.export-progress{margin-top:14px}.export-progress-row{display:flex;justify-content:space-between;margin-bottom:6px}.progress-track{height:8px;background:var(--bg-input);border:1px solid var(--border-soft);border-radius:5px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-strong));border-radius:5px;transition:width .25s var(--ease)}.progress-fill.done{background:var(--brand)}.banner-pro{background:linear-gradient(120deg,var(--brand-soft),rgba(77,163,255,.1));border:1px solid var(--brand);border-radius:var(--radius-md);padding:12px;font-size:12px;line-height:1.55;margin-top:12px}.banner-pro b{color:var(--brand)}.timeline-panel{height:230px;background:var(--bg-panel);border-top:1px solid var(--border-soft);display:flex;flex-direction:column;flex-shrink:0;z-index:42}.tl-toolbar{display:flex;align-items:center;gap:10px;padding:6px 10px;border-bottom:1px solid var(--border-soft);flex-shrink:0;flex-wrap:wrap}.tl-controls{display:flex;align-items:center;gap:2px}.tl-time{font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-2);margin-left:6px;min-width:86px;font-weight:600}.tl-actions{display:flex;align-items:center;gap:6px;flex:1}.tl-zoom{display:flex;align-items:center;gap:2px}.tl-presets-wrap{position:relative}.tl-presets-pop{position:absolute;bottom:calc(100% + 8px);left:0;z-index:120;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-2);padding:10px;width:330px;animation:popIn .14s var(--ease)}.tl-presets-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.tl-preset{position:relative;background:var(--bg-panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-sm);padding:8px 2px 6px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--text-2);transition:.12s}.tl-preset:hover{border-color:var(--brand);color:var(--text-1)}.tl-preset .emoji{font-size:16px}.tl-preset-del{position:absolute;top:0;right:3px;font-size:12px;color:var(--text-3)}.tl-preset-del:hover{color:var(--danger)}.tl-presets-sep{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin:10px 0 6px}.tl-body{flex:1;min-height:0;position:relative}.tl-scroll{height:100%;overflow:auto;position:relative}.tl-row{display:flex;border-bottom:1px solid var(--border-soft);position:relative}.tl-label{width:148px;flex-shrink:0;padding:5px 10px;font-size:11.5px;display:flex;align-items:center;gap:6px;border-right:1px solid var(--border-soft);background:var(--bg-panel);position:sticky;left:0;z-index:5;overflow:hidden}.tl-label-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}.tl-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--brand);background:var(--bg-panel-2)}.tl-group-row .tl-lane{background:var(--bg-panel-2);height:22px}.tl-el-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.tl-el-meta{font-size:9.5px;color:var(--text-3);margin-left:auto;flex-shrink:0;font-variant-numeric:tabular-nums}.tl-el-row{cursor:pointer}.tl-el-row:hover .tl-label{color:var(--text-1)}.tl-el-row.selected .tl-label{background:var(--active);color:var(--brand)}.tl-lane{position:relative;height:30px;flex-shrink:0}.tl-ruler-row{position:sticky;top:0;z-index:6;background:var(--bg-panel)}.tl-ruler{position:relative;height:26px;cursor:ew-resize;-webkit-user-select:none;user-select:none}.tl-tick{position:absolute;top:4px;font-size:9px;color:var(--text-3);border-left:1px solid var(--border);padding-left:3px;height:18px;pointer-events:none}.tl-span{position:absolute;top:50%;height:6px;transform:translateY(-50%);background:var(--brand-soft);border:1px solid var(--brand);border-radius:3px;pointer-events:none}.tl-kf{position:absolute;top:50%;width:11px;height:11px;margin-left:-5.5px;transform:translateY(-50%) rotate(45deg);background:var(--brand);border:2px solid var(--bg-panel);border-radius:2px;cursor:ew-resize;z-index:3;transition:transform .1s}.tl-kf:hover{transform:translateY(-50%) rotate(45deg) scale(1.25);background:var(--warning)}.tl-playhead{position:absolute;top:0;bottom:0;width:1.5px;background:var(--danger);z-index:8;pointer-events:none}.tl-playhead-cap{position:absolute;top:0;left:-5px;width:11px;height:12px;background:var(--danger);clip-path:polygon(0 0,100% 0,100% 55%,50% 100%,0 55%)}.tl-empty{padding:22px;text-align:center;font-size:12px;color:var(--text-3);line-height:1.6}.tl-soon{opacity:.55}.tl-soon-chip{font-size:8.5px;background:var(--bg-input);border:1px solid var(--border-soft);border-radius:8px;padding:1px 6px;color:var(--text-3);text-transform:none;letter-spacing:0}.tl-toggle-badge{position:absolute;top:4px;right:4px;width:7px;height:7px;border-radius:50%;background:var(--brand)}
