:root{--color-bg:#0d0d14;--color-surface:#16161f;--color-surface-2:#1e1e2a;--color-surface-3:#252535;--color-border:#2a2a3e;--color-border-strong:#3a3a55;--color-text:#e2e2ea;--color-text-muted:#7a7a9a;--color-text-dim:#3a3a55;--color-primary:#6c5ce7;--color-primary-hover:#7d6ff0;--color-accent:#e94560;--color-success:#00b894;--color-warning:#fdcb6e;--color-error:#ff6b6b;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--radius-sm:4px;--radius-md:8px;--radius-lg:16px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 24px #0006;--shadow-lg:0 8px 48px #00000080;--toolbar-height:48px;--formula-bar-height:36px;--activity-bar-width:48px;--left-panel-width:260px;--right-panel-width:300px;--statusbar-height:32px;--page-strip-height:120px;--mobile-nav-height:52px}[data-theme=light]{--color-bg:#f0efee;--color-surface:#fff;--color-surface-2:#f3f2f1;--color-surface-3:#edebe9;--color-border:#d2d0ce;--color-border-strong:#b3b0ad;--color-text:#323130;--color-text-muted:#605e5c;--color-text-dim:#a19f9d;--color-primary:#0078d4;--color-primary-hover:#106ebe;--color-accent:#d83b01;--color-success:#107c10;--color-warning:#797673;--color-error:#a4262c}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--color-bg);height:100%;color:var(--color-text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5;overflow:hidden}#app{grid-template-columns:var(--activity-bar-width) min(var(--left-panel-width), calc(100vw - 2 * var(--activity-bar-width) - 200px - var(--right-panel-width))) 1fr min(var(--right-panel-width), calc(50vw - var(--activity-bar-width))) var(--activity-bar-width);grid-template-rows:var(--toolbar-height) var(--formula-bar-height) 1fr var(--statusbar-height);grid-template-areas:"toolbar toolbar toolbar toolbar toolbar""formula formula formula formula formula""actbar lpanel canvas rpanel ractbar""statusbar statusbar statusbar statusbar statusbar";height:100%;transition:grid-template-columns .18s;display:grid}#app.panel-collapsed{grid-template-columns:var(--activity-bar-width) 0px 1fr var(--right-panel-width) var(--activity-bar-width)}#app.rpanel-collapsed{grid-template-columns:var(--activity-bar-width) min(var(--left-panel-width), calc(100vw - 2 * var(--activity-bar-width) - 200px)) 1fr 0px var(--activity-bar-width)}#app.panel-collapsed.rpanel-collapsed{grid-template-columns:var(--activity-bar-width) 0px 1fr 0px var(--activity-bar-width)}.toolbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;height:var(--toolbar-height);white-space:nowrap;grid-area:toolbar;align-items:center;gap:8px;padding:0 12px;display:flex;overflow:clip visible}.toolbar>*{flex-shrink:0}.toolbar .toolbar-left{min-width:0}.toolbar .toolbar-project-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.toolbar button{flex-shrink:0}.formula-bar{background:var(--color-surface-2);border-bottom:1px solid var(--color-border);height:var(--formula-bar-height);z-index:99;grid-area:formula;align-items:center;gap:0;padding:0 8px;display:flex;position:relative;overflow:visible}.formula-bar>.panel-resize-handle--y{z-index:110;height:8px;margin:0;position:absolute;bottom:-4px;left:0;right:0}.fb-layer-id{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);border-right:1px solid var(--color-border);white-space:nowrap;text-overflow:ellipsis;min-width:120px;padding:0 8px;overflow:hidden}.fb-prefix{color:var(--color-primary);font-size:12px;font-weight:600;font-family:var(--font-mono);flex-shrink:0;padding:0 8px}.fb-input{height:100%;color:var(--color-text);font-size:12px;font-family:var(--font-mono);background:0 0;border:none;outline:none;flex:1;padding:0 4px}.fb-input:focus{background:#6c5ce70f}[data-theme=light] .fb-input:focus{background:#0078d40d}.fb-input::placeholder{color:var(--color-text-dim)}.activity-bar{background:var(--color-surface);border-right:1px solid var(--color-border);z-index:130;flex-direction:column;grid-area:actbar;align-items:center;gap:2px;padding:6px 0;display:flex;overflow:hidden}.r-activity-bar{background:var(--color-surface);border-left:1px solid var(--color-border);z-index:130;flex-direction:column;grid-area:ractbar;align-items:center;gap:2px;padding:6px 0;display:flex;overflow:hidden}.r-activity-bar .act-btn.active:before{border-radius:2px 0 0 2px;left:auto;right:0}.act-btn{width:36px;height:36px;color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin:1px 0;font-size:18px;line-height:1;transition:background .1s,color .1s;display:flex;position:relative}.act-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.act-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.act-btn.active{color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 12%, transparent)}.act-btn.active:before{content:"";background:var(--color-primary);border-radius:0 2px 2px 0;width:2px;position:absolute;top:6px;bottom:6px;left:0}.act-spacer{flex:1}.left-panel{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;grid-area:lpanel;min-width:0;display:flex;position:relative;overflow:hidden}.panel-resize-handle--x{cursor:col-resize}.panel-resize-handle--y{cursor:row-resize}.panel-resize-handle--x,.panel-resize-handle--y{touch-action:none;background:0 0}.panel-resize-handle--x:before,.panel-resize-handle--y:before{content:"";background:0 0;transition:background .12s;position:absolute}.panel-resize-handle--x:before{width:1px;top:0;bottom:0;left:50%;transform:translate(-50%)}.panel-resize-handle--y:before{height:1px;top:50%;left:0;right:0;transform:translateY(-50%)}.panel-resize-handle--x:hover:before,.panel-resize-handle--y:hover:before,.panel-resize-handle--x:focus-visible:before,.panel-resize-handle--y:focus-visible:before{background:var(--color-primary)}.left-panel>.panel-resize-handle--x{z-index:60;width:8px;position:absolute;top:0;bottom:0;right:0}.left-panel-view{flex-direction:column;flex:1;display:none;overflow:hidden}.left-panel-view.active{display:flex}.tool-btn{border-radius:var(--radius-sm);width:34px;height:34px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;transition:background .1s,color .1s,border-color .1s;display:flex}.tool-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.tool-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.layer-panel{flex:1;min-height:0;padding:4px 0;overflow:hidden auto}.file-tree{flex:1;padding:8px;overflow-y:auto}.asset-panel{border-top:1px solid var(--color-border);flex-direction:column;flex-shrink:0;max-height:240px;display:flex}.asset-panel-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:4px 8px;display:flex}.asset-panel-title{text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.06em;font-size:11px;font-weight:600}.asset-open-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-2);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;padding:2px 6px;font-size:10px;transition:color .1s,border-color .1s}.asset-open-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.asset-grid{flex-wrap:wrap;flex:1;align-content:flex-start;gap:4px;padding:4px 8px 8px;display:flex;overflow-y:auto}.asset-tile{border-radius:var(--radius-sm);border:1px solid var(--color-border);background-position:50%;background-repeat:no-repeat;background-size:contain;background-color:var(--color-surface-2);cursor:pointer;flex-shrink:0;width:52px;height:52px;transition:border-color .1s,transform .1s}.asset-tile:hover{border-color:var(--color-primary);transform:scale(1.05)}.asset-empty{color:var(--color-text-muted);padding:8px;font-size:11px}.layer-list{flex:1;padding:4px 0;overflow:hidden auto}.layer-empty{color:var(--color-text-muted);padding:16px 12px;font-size:12px}.layer-row{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;align-items:center;gap:4px;min-height:30px;padding:0 8px 0 0;font-size:12px;transition:background 80ms;display:flex;position:relative}.layer-row:hover{background:var(--color-surface-2)}.layer-row.selected{background:var(--color-primary);color:#fff}.layer-row.layer-hidden{opacity:.45}.layer-row.dragging{opacity:.5}.layer-row.drop-target:before{content:"";background:var(--color-primary);border-radius:1px;height:2px;position:absolute;top:-1px;left:0;right:0}.layer-row-indent{flex-shrink:0}.layer-collapse-btn{width:16px;height:16px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:9px;display:flex}.layer-collapse-btn:hover{background:var(--color-border)}.layer-collapse-btn.invisible{visibility:hidden}.layer-row.selected .layer-collapse-btn{color:#ffffffb3}.layer-icon{text-align:center;flex-shrink:0;width:16px;font-size:12px}.layer-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.layer-z{color:var(--color-text-muted);text-align:right;min-width:20px;font-size:10px;font-family:var(--font-mono);flex-shrink:0}.layer-row.selected .layer-z{color:#fff9}.layer-vis-btn,.layer-lock-btn{width:20px;height:20px;color:var(--color-text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:11px;transition:opacity .1s;display:flex}.layer-row:hover .layer-vis-btn,.layer-row:hover .layer-lock-btn,.layer-lock-btn.active{opacity:1}.layer-row.selected .layer-vis-btn,.layer-row.selected .layer-lock-btn{color:#fffc;opacity:1}.layer-rename-input{background:var(--color-surface-2);border:1px solid var(--color-primary);color:var(--color-text);border-radius:3px;outline:none;flex:1;min-width:0;padding:1px 4px;font-size:12px}.canvas-section{background:var(--color-bg);flex-direction:column;grid-area:canvas;display:flex;position:relative;overflow:hidden}.canvas-area.tool-draw{cursor:crosshair}.canvas-svg-container svg [data-layer-id]{cursor:pointer;touch-action:none}.selection-box{touch-action:none}.canvas-hover-box{border:1.5px dashed color-mix(in srgb, var(--color-primary) 80%, transparent);pointer-events:none;z-index:85;border-radius:1px;transition:opacity 80ms;position:absolute}.tab-bar-container{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;overflow:hidden}.viewport-area{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.page-strip-section{height:var(--page-strip-height);background:var(--color-surface);border-top:1px solid var(--color-border);flex-shrink:0;position:relative;overflow:hidden}.page-strip-section>.panel-resize-handle--y{z-index:30;height:8px;margin:0;position:absolute;top:0;left:0;right:0}.page-strip-section .page-strip-content{padding-top:8px}.page-strip-content{align-items:center;gap:8px;height:100%;padding:0 8px;display:flex;overflow:auto hidden}.tab-bar{background:var(--color-surface);align-items:stretch;gap:0;height:34px;display:flex;overflow:auto hidden}.tab-bar::-webkit-scrollbar{height:3px}.tab-item{border-right:1px solid var(--color-border);cursor:pointer;background:var(--color-surface-2);min-width:100px;max-width:180px;color:var(--color-text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:4px;padding:0 10px;font-size:12px;transition:background .1s,color .1s;display:flex}.tab-item:hover{background:var(--color-border);color:var(--color-text)}.tab-item.active{background:var(--color-bg);color:var(--color-text);border-bottom:2px solid var(--color-primary)}.tab-label{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.tab-close{width:16px;height:16px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:12px;line-height:1;display:flex}.tab-close:hover{background:var(--color-border);color:var(--color-text)}.tab-new-btn{width:34px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:color .1s;display:flex}.tab-new-btn:hover{color:var(--color-primary)}.viewport-layout{flex:1;width:100%;height:100%;min-height:0;display:grid}.viewport-layout--single{grid-template-rows:1fr;grid-template-columns:1fr}.viewport-layout--split-h{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.viewport-layout--split-v{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.viewport-layout--grid22{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.viewport-layout--cols3{grid-template-rows:1fr;grid-template-columns:1fr 1fr 1fr}.viewport-pane{border:1px solid var(--color-border);position:relative;overflow:hidden}.viewport-pane.active{border-color:var(--color-primary)}.viewport-pane>.canvas-area{background:var(--color-bg);grid-area:unset;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.canvas-viewport{box-shadow:var(--shadow-lg);background:#fff;position:relative}:root[data-theme=dark] .canvas-viewport{background:#1f1f2e}.monaco-container{z-index:10;position:absolute;inset:0}.sb-ruler-unit{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-2);min-width:28px;height:24px;color:var(--color-text-muted);font-size:10px;font-family:var(--font-mono);cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;padding:0 6px;font-weight:700;transition:color .1s,border-color .1s;display:flex}.sb-ruler-unit:hover{color:var(--color-primary);border-color:var(--color-primary)}.properties-panel{background:var(--color-surface);border-left:1px solid var(--color-border);flex-direction:column;grid-area:rpanel;display:flex;position:relative;overflow:hidden}.properties-panel>.panel-resize-handle--x{z-index:60;width:8px;position:absolute;top:0;bottom:0;left:0}.rpanel-body{flex:auto;min-height:0;position:relative;overflow:hidden}.rpanel-body>.tab-pane:not(.tab-pane--full):not(.tab-pane--flex):not(.tab-pane--scroll){height:100%;padding:0;overflow-y:auto}.rpanel-body>.tab-pane.active.tab-pane--full,.rpanel-body>.tab-pane.active.tab-pane--flex,.rpanel-body>.tab-pane.active.tab-pane--scroll{height:100%}.rpanel-body>.tab-pane[data-tab=properties],.rpanel-body>.tab-pane[data-tab=problems]{padding:0}.rpanel-body>.tab-pane{height:100%;display:none}.rpanel-body>.tab-pane.active{display:block}.rpanel-body>.tab-pane--flex.active{flex-direction:column;display:flex;overflow:hidden}.rpanel-body>.tab-pane--scroll.active{display:block;overflow-y:auto}.rpanel-body>.tab-pane--full.active{display:block}.status-bar{background:var(--color-surface);border-top:1px solid var(--color-border);height:var(--statusbar-height);z-index:50;color:var(--color-text-muted);grid-area:statusbar;align-items:center;gap:0;padding:0 4px;font-size:11px;display:flex;overflow:hidden}.status-pages{flex-shrink:0;align-items:center;gap:4px;max-width:320px;padding:0 6px;display:flex;overflow-x:auto}.status-pages .page-strip{min-height:unset!important;gap:4px!important;padding:0!important}.status-sep{background:var(--color-border);flex-shrink:0;width:1px;height:16px;margin:0 4px}.status-spacer{flex:1}.sb-btn{min-width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0 6px;font-size:11px;transition:background .1s,color .1s;display:flex}.sb-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.sb-btn.active{color:var(--color-primary)}.sb-zoom-val{font-size:11px;font-family:var(--font-mono);color:var(--color-text);text-align:center;flex-shrink:0;min-width:36px}.sb-info{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0;padding:0 8px;font-size:11px;overflow:hidden}.status-bar{gap:0;min-width:0}.status-spacer{flex:auto;min-width:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-strong);background-clip:padding-box;border:2px solid #0000;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted);background-clip:padding-box}::-webkit-scrollbar-corner{background:0 0}*{scrollbar-width:thin;scrollbar-color:var(--color-border-strong) transparent}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}button:focus:not(:focus-visible){outline:none}.panel-header{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;padding:10px 12px 6px;font-size:10px;font-weight:700}.btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-2);min-height:28px;color:var(--color-text);font-size:12px;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:6px 12px;transition:background .15s,border-color .15s;display:inline-flex}.btn:hover{background:var(--color-border)}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-sm{min-height:26px;padding:5px 10px;font-size:11px}.btn-icon{border-radius:var(--radius-sm);width:28px;height:28px;padding:0}.mode-toggle{border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;overflow:hidden}.mode-toggle button{min-height:26px;color:var(--color-text-muted);font-size:11px;font-family:var(--font-sans);cursor:pointer;background:0 0;border:none;padding:6px 14px;transition:background .1s,color .1s}.mode-toggle button.active{background:var(--color-primary);color:#fff}.selection-handle{border:2px solid var(--color-primary);z-index:90;cursor:pointer;outline-offset:-6px;touch-action:none;background:#fff;border-radius:2px;outline:6px solid #0000;width:10px;height:10px;transition:transform 80ms,background 80ms,border-color 80ms;position:absolute;box-shadow:0 1px 3px #0006}.selection-handle:hover{background:var(--color-primary);border-color:#fff;transform:scale(1.25)}.selection-handle:active{background:var(--color-primary-strong,var(--color-primary));transform:scale(1.1)}.handle-n,.handle-s{border-radius:3px;width:18px;margin-left:-4px}.handle-e,.handle-w{border-radius:3px;height:18px;margin-top:-4px}.handle-rotate{background:var(--color-primary)!important;border-color:#fff!important;border-radius:50%!important;width:14px!important;height:14px!important}.handle-rotate:hover{transform:scale(1.2)}.selection-box{border:1.5px solid var(--color-primary);pointer-events:none;z-index:89;position:absolute;box-shadow:inset 0 0 0 1px #ffffff2e}@media (pointer:coarse){.selection-handle{outline-offset:-8px;outline-width:8px;width:14px;height:14px}.handle-n,.handle-s{width:24px}.handle-e,.handle-w{height:24px}.handle-rotate{width:18px!important;height:18px!important}}.anim-panel{flex-direction:column;gap:12px;padding:8px;display:flex}.anim-section{flex-direction:column;gap:6px;display:flex}.anim-section-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;font-size:11px;font-weight:600;display:flex}.anim-select,.anim-num{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);width:100%;padding:3px 5px;font-size:11px}.anim-label{color:var(--color-text-muted);margin-bottom:2px;font-size:10px}.anim-kf-row{border-bottom:1px solid var(--color-border);align-items:center;gap:6px;padding:4px 0;font-size:11px;display:flex}.anim-kf-t{font-family:var(--font-mono);color:var(--color-primary);min-width:48px}.anim-kf-props{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.anim-kf-del{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px}.anim-kf-del:hover{color:var(--color-danger,#e94560)}.comp-panel{flex-direction:column;height:100%;display:flex}.comp-toolbar{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:6px 8px;display:flex}.comp-toolbar-title{color:var(--color-text-muted);font-size:12px;font-weight:600}.comp-save-btn{padding:2px 6px;font-size:11px}.comp-empty{color:var(--color-text-muted);text-align:center;padding:16px 8px;font-size:11px;line-height:1.6}.comp-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:8px;display:grid}.comp-card{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:default;background:var(--color-surface-2);overflow:hidden}.comp-card:hover{border-color:var(--color-primary)}.comp-thumb{aspect-ratio:1;background:var(--color-surface);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.comp-thumb svg{max-width:100%;max-height:100%}.comp-thumb-empty{color:var(--color-text-muted);font-size:28px}.comp-card-name{white-space:nowrap;text-overflow:ellipsis;color:var(--color-text);padding:3px 5px;font-size:10px;overflow:hidden}.comp-card-actions{justify-content:space-between;gap:2px;padding:2px 4px 4px;display:flex}.comp-insert{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;flex:1;padding:2px 4px;font-size:10px}.comp-delete{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 5px;font-size:12px}.comp-delete:hover{background:var(--color-danger,#e94560);color:#fff}.inline-text-editor{box-sizing:border-box;word-break:break-word;z-index:200;line-height:1.2;position:absolute;overflow:hidden}.guide-preview{pointer-events:none}.align-toolbar{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);z-index:95;gap:2px;padding:4px;display:flex;position:absolute;top:8px;left:50%;transform:translate(-50%)}.align-btn{width:28px;height:28px;color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:13px;transition:background .1s,color .1s;display:flex}.align-btn:hover{background:var(--color-border);color:var(--color-text)}.align-btn.inactive{opacity:.3;pointer-events:none;cursor:not-allowed}.align-toolbar{transition:opacity .15s,transform .15s}.align-toolbar.align-toolbar--hidden{opacity:0;pointer-events:none;visibility:hidden;transform:translate(-50%)translateY(-4px)}.toast{bottom:calc(var(--statusbar-height) + 8px);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:300;padding:10px 18px;font-size:12px;animation:.25s slideUp;position:fixed;right:16px}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.export-item{width:100%;color:var(--color-text);text-align:left;cursor:pointer;border:none;border-bottom:1px solid var(--color-border);background:0 0;padding:7px 12px;font-size:12px;display:block}.export-item:last-child{border-bottom:none}.export-item:hover{background:var(--color-border)}.dialog-overlay{z-index:400;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog-box{background:var(--color-surface-2);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);flex-direction:column;width:340px;max-width:90vw;display:flex}.dialog-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 16px 8px;display:flex}.dialog-title{color:var(--color-text);font-size:14px;font-weight:600}.dialog-close{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 6px;font-size:14px}.dialog-close:hover{background:var(--color-border)}.dialog-body{flex-direction:column;gap:8px;padding:12px 16px;display:flex}.tmpl-dialog{width:min(880px,92vw);max-height:80vh}.tmpl-dialog .dialog-body{max-height:calc(80vh - 64px);overflow-y:auto}.tmpl-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-auto-rows:1fr;gap:12px;display:grid}.tmpl-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;height:100%;color:inherit;text-align:left;content-visibility:auto;contain-intrinsic-size:260px;flex-direction:column;padding:0;font-family:inherit;transition:border-color .12s,transform .12s;display:flex;overflow:hidden}.tmpl-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.tmpl-thumb{aspect-ratio:4/3;background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-surface) 100%);border-bottom:1px solid var(--color-border);justify-content:center;align-items:center;display:flex;position:relative}.tmpl-thumb-dim{font-family:var(--font-mono);color:var(--color-text-muted);letter-spacing:.05em;font-size:11px}.tmpl-meta{flex-direction:column;gap:4px;padding:10px 12px 12px;display:flex}.tmpl-name{color:var(--color-text);font-size:14px;font-weight:600}.tmpl-sub{color:var(--color-text-muted);font-size:11px}.tmpl-tags{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.tmpl-tag{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:10px;padding:2px 6px;font-size:10px}.tmpl-empty{color:var(--color-text-muted);text-align:center;padding:24px;font-size:13px}.catalog-overlay{padding:32px}.catalog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:min(1280px,95vw);height:min(820px,90vh);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.catalog-header{border-bottom:1px solid var(--color-border);align-items:center;gap:16px;padding:14px 18px;display:flex}.catalog-title{color:var(--color-text);margin:0;font-size:16px;font-weight:700}.catalog-tabs{flex:1;gap:6px;margin-left:16px;display:flex}.catalog-tab{color:var(--color-text-muted);font:inherit;border-radius:var(--radius-md);cursor:pointer;background:0 0;border:1px solid #0000;padding:6px 12px;transition:background-color .12s,color .12s,border-color .12s}.catalog-tab:hover{color:var(--color-text);background:var(--color-surface-2)}.catalog-tab.active{color:var(--color-text);background:var(--color-bg);border-color:var(--color-border)}.catalog-filter{border-bottom:1px solid var(--color-border);background:var(--color-bg);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 18px;display:flex}.catalog-filter:empty{display:none}.catalog-filter{flex-shrink:0;max-height:84px;overflow-y:auto}.tag-chip-more{color:var(--color-text-muted);border:1px dashed var(--color-border);cursor:default;-webkit-user-select:none;user-select:none;background:0 0;border-radius:12px;padding:3px 9px;font-size:11px}.catalog-search{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font:inherit;flex:none;min-width:240px;padding:6px 10px}.catalog-search:focus{outline:1px solid var(--color-primary)}.catalog-chips{flex-wrap:wrap;flex:1;gap:6px;display:flex}.tag-chip{background:var(--color-surface-2);color:var(--color-text-muted);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;padding:3px 9px;font-family:inherit;font-size:11px}.tag-chip:hover{color:var(--color-text)}.tag-chip.selected{background:var(--color-primary);color:var(--color-bg);border-color:var(--color-primary)}.tag-chip.clear{color:var(--color-text-muted);background:0 0;border-style:dashed}.catalog-count{color:var(--color-text-muted);margin-left:auto;font-size:11px}.catalog-body{flex:1;grid-template-columns:1fr 360px;min-height:0;display:grid}.catalog-list{padding:16px 18px;overflow-y:auto}.catalog-rail{border-left:1px solid var(--color-border);background:var(--color-bg);flex-direction:column;gap:12px;padding:16px;display:flex;overflow-y:auto}.catalog-rail-head{flex-direction:column;gap:6px;display:flex}.rail-label-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.rail-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-size:11px}.btn-shuffle{font:inherit;border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;padding:4px 10px;font-size:11px;font-weight:600;transition:background-color .12s,border-color .12s}.btn-shuffle:hover{background:var(--color-surface-3);border-color:var(--color-primary)}.rail-chip--removable{align-items:center;gap:4px;padding-right:2px;display:inline-flex}.rail-chip-x{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:0 4px;font-size:14px;line-height:1}.rail-chip-x:hover{color:var(--color-error);background:color-mix(in srgb, var(--color-error) 12%, transparent)}.rail-page-nav{background:var(--color-surface-2);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;padding:4px 8px;font-size:11px;display:flex}.rail-page-nav button{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:4px;padding:2px 10px;font-size:16px;line-height:1}.rail-page-nav button:disabled{opacity:.35;cursor:not-allowed}.rail-page-nav button:hover:not(:disabled){background:var(--color-surface-3)}.rail-page-counter{text-align:center;font-family:var(--font-mono);color:var(--color-text-muted);flex:1;font-size:11px}.rail-hint:empty{display:none}.rail-hint{background:color-mix(in srgb, var(--color-warning) 12%, transparent);border-left:2px solid var(--color-warning);border-radius:2px;margin-top:4px;padding:6px 8px;font-size:11px;line-height:1.4}.rail-hint code{font-family:var(--font-mono);background:var(--color-surface-2);border-radius:3px;padding:1px 4px;font-size:10px}.rail-hint em{color:var(--color-text);font-style:normal;font-weight:600}.rail-hint-text{color:var(--color-text-muted)}.rail-pick{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.rail-chip{background:var(--color-surface-2);color:var(--color-text);border-radius:10px;padding:3px 8px;font-size:12px;font-weight:600}.rail-x{color:var(--color-text-muted);font-size:12px}.rail-preview{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:180px;max-height:440px;padding:8px;display:flex;overflow:hidden}.rail-preview>.rail-page-nav{align-self:stretch}.rail-preview svg{max-width:100%;max-height:100%}.rail-empty{color:var(--color-text-muted);text-align:center;padding:24px;font-size:12px}.catalog-rail-actions{flex-direction:column;gap:6px;margin-top:auto;display:flex}.catalog-rail-actions .btn{justify-content:center;width:100%;padding:8px 10px}.btn-link{color:var(--color-text-muted);cursor:pointer;text-align:center;background:0 0;border:none;padding:4px;font-size:11px}.btn-link:hover{color:var(--color-primary)}.tmpl-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary) inset}.theme-grid .tmpl-card{aspect-ratio:auto}.theme-preview{aspect-ratio:auto;border-bottom:1px solid var(--color-border);flex-direction:column;justify-content:space-between;min-height:110px;max-height:130px;padding:10px 12px;display:flex}.theme-preview-row{align-items:center;gap:6px;display:flex}.theme-preview-h{letter-spacing:-.02em;font-size:26px;font-weight:800;line-height:1}.theme-preview-dot{border-radius:50%;width:14px;height:14px;display:inline-block}.theme-swatches{gap:4px;display:flex}.theme-swatch{border:1px solid #ffffff0f;border-radius:4px;width:18px;height:18px;display:inline-block}.theme-swatch.sm{border-radius:3px;width:14px;height:14px}.combo-thumb{aspect-ratio:4/3;background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-surface) 100%);border-bottom:1px solid var(--color-border);flex-direction:column;justify-content:space-between;padding:12px;display:flex}.combo-thumb-title{color:var(--color-text);font-size:16px;font-weight:700}.dialog-row{align-items:center;gap:8px;display:flex}.dialog-label{color:var(--color-text-muted);flex-shrink:0;min-width:52px;font-size:12px}.dialog-input,.dialog-select{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:12px;font-family:var(--font-sans);outline:none;flex:1;min-width:0;padding:4px 8px}.dialog-input:focus,.dialog-select:focus{border-color:var(--color-primary)}.dialog-unit-label{color:var(--color-text-muted);text-align:left;min-width:24px;font-size:11px;font-family:var(--font-mono);flex-shrink:0}.dialog-info{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono);text-align:center;border-top:1px solid var(--color-border);margin-top:4px;padding:4px 0}.dialog-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;padding:10px 16px 12px;display:flex}.command-palette-overlay{z-index:200;background:#00000080;justify-content:center;align-items:flex-start;padding-top:80px;display:flex;position:fixed;inset:0}.command-palette{background:var(--color-surface-2);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);width:560px;box-shadow:var(--shadow-lg);overflow:hidden}.command-palette input{border:none;border-bottom:1px solid var(--color-border);width:100%;color:var(--color-text);font-size:14px;font-family:var(--font-sans);background:0 0;outline:none;padding:12px 16px}.command-result{cursor:pointer;align-items:center;gap:10px;padding:8px 16px;font-size:13px;display:flex}.command-result:hover,.command-result.focused{background:var(--color-border)}.command-result-key{background:var(--color-surface-3);color:var(--color-text-muted);font-size:10px;font-family:var(--font-mono);border-radius:3px;margin-left:auto;padding:2px 6px}.color-picker-popover{background:var(--color-surface-2);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);width:240px;box-shadow:var(--shadow-lg);z-index:250;flex-direction:column;gap:10px;padding:12px;display:flex;position:fixed}.color-swatch-grid{grid-template-columns:repeat(8,1fr);gap:4px;display:grid}.color-swatch{cursor:pointer;border:1px solid #ffffff1f;border-radius:3px;width:22px;height:22px;transition:transform .1s}.color-swatch:hover{transform:scale(1.15)}.palette-panel{height:100%;padding:8px;overflow-y:auto}.palette-group{margin-bottom:12px}.palette-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:5px;font-size:10px;font-weight:700}.palette-swatch-grid{flex-wrap:wrap;gap:4px;display:flex}.palette-swatch{cursor:pointer;border:1px solid #00000026;border-radius:4px;flex-shrink:0;width:22px;height:22px;padding:0;transition:transform .1s,box-shadow .1s}.palette-swatch:hover{z-index:1;position:relative;transform:scale(1.2);box-shadow:0 2px 6px #0000004d}.prop-empty{padding:0}.prop-empty-hero{text-align:center;border-bottom:1px solid var(--color-border);padding:28px 16px 20px}.prop-empty-icon{color:var(--color-text-dim);opacity:.7;margin-bottom:6px;font-size:28px}.prop-empty-title{color:var(--color-text);margin-bottom:4px;font-size:12px;font-weight:600}.prop-empty-hint{color:var(--color-text-muted);max-width:240px;margin:0 auto;font-size:11px;line-height:1.5}.prop-info-row{color:var(--color-text-muted);justify-content:space-between;align-items:baseline;gap:8px;padding:3px 2px;font-size:11px;display:flex}.prop-info-row>span:last-child{color:var(--color-text);font-family:var(--font-mono,monospace);text-align:right;text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-size:11px;overflow:hidden}.prop-empty kbd{background:var(--color-surface-2);border:1px solid var(--color-border);font-family:var(--font-mono,monospace);color:var(--color-text);border-radius:3px;margin:0 1px;padding:1px 5px;font-size:10px;display:inline-block}.prop-section{border-bottom:1px solid var(--color-border);padding:8px 10px}.prop-section-header{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:4px 0;font-size:10px;font-weight:700;display:flex}.prop-section-header:after{content:"▾";font-size:10px;transition:transform .15s}.prop-section.collapsed .prop-section-header:after{transform:rotate(-90deg)}.prop-section.collapsed .prop-section-body{display:none}.prop-section-body{padding-top:6px}.prop-row{align-items:center;gap:6px;margin-bottom:5px;display:flex}.prop-label{color:var(--color-text-muted);flex-shrink:0;min-width:52px;font-size:11px}.prop-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:11px;font-family:var(--font-sans);outline:none;flex:1;min-width:0;padding:3px 6px}.prop-input:focus{border-color:var(--color-primary)}.prop-input-sm{max-width:60px}.color-well{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;width:28px;height:22px}.panel-resize-handle{z-index:60;flex-shrink:0;transition:background .1s;position:relative}.panel-resize-handle--x{cursor:col-resize;background:0 0;width:4px;margin:0 -2px}.panel-resize-handle--y{cursor:row-resize;background:0 0;height:4px;margin:-2px 0}.panel-resize-handle:hover,.panel-resize-handle:focus-visible{background:var(--color-primary);outline:none}.panel-resize-handle:after{content:"";background:var(--color-border-strong);opacity:0;border-radius:2px;transition:opacity .15s;position:absolute}.panel-resize-handle--x:after{width:2px;height:32px;top:50%;left:50%;transform:translate(-50%,-50%)}.panel-resize-handle--y:after{width:32px;height:2px;top:50%;left:50%;transform:translate(-50%,-50%)}.panel-resize-handle:hover:after{opacity:1}.panel-resize-handle:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px;background:color-mix(in srgb, var(--color-primary) 20%, transparent)}@media (pointer:coarse){.panel-resize-handle--x{width:12px;margin:0 -6px}.panel-resize-handle--y{height:12px;margin:-6px 0}}.tools-panel{border-bottom:1px solid var(--color-border);scrollbar-gutter:stable;flex-shrink:0;grid-template-columns:repeat(auto-fill,34px);place-content:start center;gap:4px;max-height:220px;padding:6px;display:grid;overflow:hidden auto}.tool-section-sep{background:var(--color-border);grid-column:1/-1;height:1px;margin:2px 0}.ruler-unit-btn{width:var(--ruler-size,24px);height:var(--ruler-size,24px);background:var(--color-surface-2);border:none;border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:8px;font-family:var(--font-mono);cursor:pointer;z-index:10;justify-content:center;align-items:center;padding:0;font-weight:700;transition:color .1s;display:flex;position:absolute;top:0;left:0}.ruler-unit-btn:hover{color:var(--color-primary)}.mobile-nav{display:none}.mob-nav-btn{height:44px;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex:1;justify-content:center;align-items:center;font-size:20px;transition:color .1s,background .1s;display:flex}.mob-nav-btn.active{color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 12%, transparent)}.mob-backdrop{z-index:190;background:#00000073;display:none;position:fixed;inset:0}.mob-backdrop.active{display:block}.mob-sheet-grip{cursor:grab;flex-shrink:0;justify-content:center;padding:8px 0 4px;display:none}.mob-sheet-grip:before{content:"";background:var(--color-border-strong);border-radius:2px;width:36px;height:4px}@media (min-width:768px) and (max-width:1023px){#app{grid-template-columns:var(--activity-bar-width) 0px 1fr 0px var(--activity-bar-width);grid-template-areas:"toolbar toolbar toolbar toolbar toolbar""formula formula formula formula formula""actbar lpanel canvas canvas ractbar""statusbar statusbar statusbar statusbar statusbar"}.left-panel{left:var(--activity-bar-width);top:calc(var(--toolbar-height) + var(--formula-bar-height));bottom:var(--statusbar-height);z-index:120;width:clamp(220px,30vw,320px);box-shadow:var(--shadow-lg);border-right:1px solid var(--color-border-strong);transition:transform .25s;position:absolute;transform:translate(-105%)}#app:not(.panel-collapsed) .left-panel{transform:translate(0)}.properties-panel{right:0;top:calc(var(--toolbar-height) + var(--formula-bar-height));bottom:var(--statusbar-height);z-index:120;width:clamp(240px,32vw,340px);box-shadow:var(--shadow-lg);border-left:1px solid var(--color-border-strong);transition:transform .25s;position:absolute;transform:translate(105%);display:flex!important}.properties-panel.mob-open{transform:translate(0)}.properties-panel .minimap-container{display:none}}@media (max-width:767px){#app{grid-template-columns:1fr;grid-template-rows:var(--toolbar-height) 1fr var(--statusbar-height);grid-template-areas:"toolbar""canvas""statusbar"}.activity-bar,.formula-bar,.r-activity-bar{display:none}.toolbar{gap:6px;padding:0 8px}.toolbar .toolbar-project-name,.toolbar .toolbar-left>span:nth-child(2),.toolbar .toolbar-theme-select{display:none}.toolbar .mode-toggle button{padding:6px 10px}.status-bar{gap:0;padding:0 4px}.status-pages,.sb-info{display:none}.mobile-nav{bottom:var(--statusbar-height);height:var(--mobile-nav-height);background:var(--color-surface);border-top:1px solid var(--color-border);z-index:200;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:center;gap:4px;display:flex;position:fixed;left:0;right:0}.status-bar{z-index:210}.left-panel{bottom:calc(var(--mobile-nav-height) + var(--statusbar-height));z-index:195;border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:65vh;box-shadow:var(--shadow-lg);border-right:none;border-top:1px solid var(--color-border-strong);transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;left:0;right:0;transform:translateY(110%);width:auto!important;display:flex!important}.left-panel.mob-open{transform:translateY(0)}.left-panel>.panel-resize-handle--x{display:none}.left-panel .mob-sheet-grip{display:flex}.properties-panel{bottom:calc(var(--mobile-nav-height) + var(--statusbar-height));z-index:195;border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:65vh;box-shadow:var(--shadow-lg);border-left:none;border-top:1px solid var(--color-border-strong);transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;left:0;right:0;transform:translateY(110%);display:flex!important}.properties-panel.mob-open{transform:translateY(0)}.properties-panel .mob-sheet-grip{display:flex}.right-panel-resize-handle,.properties-panel .minimap-container{display:none}.tool-btn{width:44px;height:44px;font-size:18px}.layer-row{min-height:44px}.layer-vis-btn,.layer-lock-btn{width:36px;height:36px}}.timeline-panel{flex-direction:column;height:100%;font-size:11px;display:flex;overflow:hidden}.timeline-toolbar{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;align-items:center;gap:6px;padding:6px 8px;display:flex}.timeline-body{flex:1;overflow:hidden auto}.scheme-panel{padding:8px}.scheme-row{margin-bottom:8px}.scheme-swatch{cursor:pointer;border:none;border-radius:4px;flex-shrink:0;width:28px;height:28px;transition:transform .1s,box-shadow .1s}.scheme-swatch:hover{transform:scale(1.15);box-shadow:0 2px 8px #0006}
