:root{--brand-deep: #1F1B3D;--brand-violet: #5B4BD8;--brand-violet-soft: #ECEAFB;--surface: #FFFFFF;--surface-2: #F6F7FB;--canvas-top: #F7F8FB;--canvas-bottom: #E9ECF3;--ground: #FAFBFD;--grid-minor: #DEE2EC;--grid-major: #C5CAD6;--text: #0F1230;--text-muted: #5A6079;--success: #22A06B;--warning: #D9821A;--danger: #D24858;--axis-x: #E5484D;--axis-y: #30A46C;--axis-z: #3E63DD;--border: #DEE2EC;--shadow-elevation: 0 6px 24px rgba(15, 18, 48, .1);--radius-chip: 8px;--radius-button: 12px;--radius-panel: 16px;--motion-fast: .12s;--motion-base: .18s;--motion-slow: .24s;--ease-out: cubic-bezier(.2, .8, .2, 1);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--canvas-bottom);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}button,input{font:inherit}button{border:0}button:focus-visible,input:focus-visible{outline:2px solid var(--brand-violet);outline-offset:2px}kbd{display:inline-block;padding:0 8px;border:1px solid var(--grid-major);border-bottom-width:2px;border-radius:var(--radius-chip);background:var(--surface-2);color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1.5}.app-shell{display:grid;grid-template-rows:56px minmax(0,1fr);height:100dvh;overflow:hidden}.app-shell.is-playing{grid-template-rows:minmax(0,1fr);background:var(--canvas-bottom)}.topbar{position:relative;z-index:20;display:grid;grid-template-columns:minmax(280px,1fr) auto minmax(320px,1fr);align-items:center;height:56px;padding:0 16px;gap:16px;background:var(--brand-deep);color:#fff}.topbar-cluster{display:flex;align-items:center;min-width:0}.topbar-left{gap:16px}.topbar-center{justify-content:center;gap:8px}.topbar-right{justify-content:flex-end;gap:8px}.brand{display:inline-flex;align-items:center;gap:8px;min-width:0}.brand-mark{display:grid;place-items:center;width:32px;height:32px;border-radius:var(--radius-button);background:#fff;color:var(--brand-deep);font-family:Nunito,Inter,sans-serif;font-size:20px;font-weight:800}.brand-name{font-family:Nunito,Inter,sans-serif;font-size:16px;font-weight:800}.scene-title-button,.scene-title-input{min-width:0;max-width:280px;height:36px;border-radius:var(--radius-chip);color:#fff}.scene-title-button{display:inline-flex;align-items:center;gap:8px;padding:0 12px;background:#ffffff14;cursor:pointer}.scene-title-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-title-input{border:1px solid rgba(255,255,255,.28);padding:0 12px;background:#ffffff24}.topbar-button,.play-button{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;color:#fff;cursor:pointer;transition:background var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),opacity var(--motion-fast) var(--ease-out)}.topbar-button{flex-direction:column;gap:2px;padding:4px 8px;border-radius:var(--radius-button);background:transparent;color:#ffffffd1;font-size:12px;font-weight:600}.topbar-button:hover,.topbar-button.is-active{background:#ffffff1f;color:#fff}.topbar-button:disabled{cursor:not-allowed;opacity:.38}.play-button{gap:8px;min-width:132px;padding:0 16px;border-radius:var(--radius-button);background:var(--brand-violet);font-family:Nunito,Inter,sans-serif;font-size:16px;font-weight:800}.play-button:hover,.play-button.is-active{background:var(--brand-violet)}.grid-menu-wrap{position:relative}.grid-menu{position:absolute;top:calc(100% + 8px);left:50%;width:340px;transform:translate(-50%);border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);color:var(--text);box-shadow:var(--shadow-elevation)}.workspace{position:relative;display:grid;grid-template-columns:40px minmax(0,1fr);min-height:0;overflow:hidden}.app-shell.is-playing .workspace{grid-template-columns:minmax(0,1fr)}.left-dock{position:relative;z-index:12;grid-column:1;min-height:0;background:#ffffffeb;border-right:1px solid var(--border)}.dock-strip{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 4px}.dock-button,.icon-button{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:var(--radius-chip);background:transparent;color:var(--text-muted);cursor:pointer;transition:background var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out)}.dock-button:hover,.dock-button.is-active,.icon-button:hover,.icon-button.is-active{background:var(--brand-violet-soft);color:var(--brand-violet)}.dock-panel{position:absolute;top:12px;left:48px;width:240px;max-height:calc(100dvh - 96px);display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation);overflow:hidden}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:16px;background:var(--surface-2);border-bottom:1px solid var(--border)}.panel-head h2{margin:0;color:var(--text-muted);font-size:13px;font-weight:700;text-transform:uppercase}.mini-badge{min-width:24px;padding:2px 8px;border-radius:999px;background:var(--brand-violet-soft);color:var(--brand-violet);font-size:12px;font-weight:700;text-align:center}.scenes-panel,.outliner-section{display:flex;flex:1;min-height:0;flex-direction:column}.scene-card{display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;gap:12px;margin:12px;padding:8px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface);color:var(--text);text-align:left;cursor:pointer}.scene-card.is-active{border-color:var(--brand-violet);background:var(--brand-violet-soft)}.scene-thumb{display:grid;place-items:center;width:48px;height:40px;border-radius:var(--radius-chip);background:linear-gradient(180deg,var(--canvas-top),var(--canvas-bottom));color:var(--brand-violet)}.scene-card strong,.scene-card small{display:block}.scene-card strong{font-size:14px}.scene-card small{color:var(--text-muted);font-size:12px}.new-scene-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin:auto 12px 12px;min-height:40px;border-radius:var(--radius-button);background:var(--brand-violet);color:#fff;font-size:14px;font-weight:700;cursor:pointer}.outliner-list{display:flex;flex-direction:column;gap:8px;padding:12px;overflow:auto}.outliner-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:44px;padding:4px;border:1px solid transparent;border-radius:var(--radius-button);background:transparent;color:var(--text)}.outliner-item:hover,.outliner-item.is-selected{border-color:var(--brand-violet);background:var(--brand-violet-soft)}.outliner-item.is-hidden{color:var(--text-muted);opacity:.72}.outliner-select{display:grid;grid-template-columns:16px minmax(0,1fr);align-items:center;gap:8px;min-width:0;padding:4px;background:transparent;color:inherit;text-align:left;cursor:pointer}.outliner-select:disabled{cursor:not-allowed}.outliner-swatch{width:16px;height:16px;border:1px solid rgba(15,18,48,.16);border-radius:4px}.outliner-labels{display:flex;min-width:0;flex-direction:column}.outliner-name,.outliner-kind{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.outliner-name{font-size:13px;font-weight:700}.outliner-kind{color:var(--text-muted);font-size:12px}.outliner-controls{display:flex;gap:4px}.icon-button:disabled,.module-button:disabled,.action-chip:disabled,.axis-nudge:disabled,.axis-input:disabled,.scale-button:disabled,.color-chip:disabled,.color-picker:disabled,.secondary-panel-button:disabled{cursor:not-allowed;opacity:.44}.empty-panel-note{margin:0;padding:16px;color:var(--text-muted);font-size:13px;line-height:1.5}.scene-stage{position:relative;grid-column:2;min-width:0;min-height:0;overflow:hidden}.app-shell.is-playing .scene-stage{grid-column:1}.scene-stage:after{content:"";position:absolute;inset:12px;z-index:8;border:2px solid rgba(91,75,216,0);border-radius:20px;box-shadow:inset 0 0 0 9999px #5b4bd800;pointer-events:none;opacity:0;transition:opacity var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out)}.scene-stage.is-drop-target:after{border-color:#5b4bd88a;box-shadow:inset 0 0 0 9999px #5b4bd812,inset 0 0 36px #5b4bd833;opacity:1}.app-shell.is-playing .scene-stage:after{display:none}.scene-frame{position:absolute;inset:0;overflow:hidden;background:linear-gradient(180deg,var(--canvas-top) 0%,var(--canvas-bottom) 100%)}.scene-canvas{display:block;width:100%;height:100%;outline:none;touch-action:none}.scene-hud{position:absolute;left:16px;bottom:304px;display:flex;gap:8px;pointer-events:none}.scene-hud-chip,.scene-status{border:1px solid var(--border);border-radius:999px;background:#fffffff0;color:var(--text-muted);font-size:12px;font-weight:600;box-shadow:var(--shadow-elevation)}.scene-hud-chip{padding:8px 12px}.scene-status{position:absolute;right:24px;bottom:304px;z-index:6;display:flex;gap:12px;padding:8px 12px;pointer-events:none}.play-mode-hud{position:absolute;top:16px;right:16px;z-index:18;display:flex;align-items:center;gap:8px;pointer-events:none}.play-exit-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 14px;border:1px solid rgba(255,255,255,.72);border-radius:var(--radius-button);background:#1f1b3de0;color:#fff;font-family:Nunito,Inter,sans-serif;font-size:15px;font-weight:800;box-shadow:var(--shadow-elevation);cursor:pointer;pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.play-exit-button:hover{background:var(--brand-violet)}.app-shell.dock-collapsed .scene-hud,.app-shell.dock-collapsed .scene-status{bottom:112px}.selection-gizmo-cluster{position:absolute;top:88px;left:50%;z-index:10;display:flex;gap:4px;padding:6px;transform:translate(-50%);border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation)}.selection-gizmo-cluster button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:44px;height:36px;padding:0 10px;border-radius:var(--radius-button);background:transparent;color:var(--text-muted);font-size:13px;font-weight:700;cursor:pointer}.selection-gizmo-cluster button:hover,.selection-gizmo-cluster button.is-active{background:var(--brand-violet-soft);color:var(--brand-violet)}.selection-gizmo-cluster .more-button{width:36px;min-width:36px;padding:0}.selection-gizmo-cluster .more-button span{display:none}.object-action-panel,.transform-popover{position:absolute;z-index:11;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-elevation);overflow:hidden}.object-action-panel{top:0;right:0;width:min(360px,calc(100% - 48px));border-top:0;border-right:0;border-bottom:0;border-radius:0;box-shadow:-6px 0 24px #0f12301a;overflow-y:auto}.code-panel{position:absolute;z-index:11;top:0;right:0;bottom:0;width:720px;display:grid;grid-template-rows:auto auto minmax(0,1fr);border-left:1px solid var(--border);background:var(--surface);box-shadow:-10px 0 28px #0f12301f;overflow:hidden}.code-panel-resizer{position:absolute;top:0;bottom:0;left:-3px;width:8px;cursor:col-resize;z-index:12;display:flex;align-items:center;justify-content:center;background:transparent;outline:none}.code-panel-resizer:hover .code-panel-resizer-grip,.code-panel-resizer:focus-visible .code-panel-resizer-grip{background:var(--brand-violet);opacity:1}.code-panel-resizer-grip{display:block;width:3px;height:56px;border-radius:999px;background:var(--border);opacity:.6;transition:background .12s,opacity .12s}.code-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.code-panel-title{display:flex;align-items:center;gap:12px;min-width:0}.code-panel-title>div{display:grid;min-width:0;gap:2px}.code-panel-title span{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.code-panel-title strong{overflow:hidden;color:var(--text);font-size:15px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.code-panel-header-status{display:flex;align-items:center;gap:8px;flex-shrink:0}.code-save-status{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.01em}.code-save-status-pending{background:var(--surface-2);color:var(--text-muted);box-shadow:inset 0 0 0 1px var(--border)}.code-save-status-saved{background:#22a06b1f;color:#167854}.code-panel-header{gap:16px}.code-panel-tabs{display:flex;flex:1;align-items:center;gap:6px;min-width:0;overflow-x:auto;padding:2px 0}.code-panel-tabs::-webkit-scrollbar{height:0}.code-tab{display:inline-flex;align-items:center;gap:4px;height:30px;padding:0 8px 0 12px;border-radius:999px;background:transparent;border:1px solid transparent;color:var(--text-muted);flex-shrink:0;transition:background .12s,border-color .12s,color .12s}.code-tab:hover{background:var(--surface);color:var(--text)}.code-tab.is-active{background:var(--brand-violet-soft);color:var(--brand-violet);border-color:#5b4bd82e}.code-tab-button{border:0;background:transparent;color:inherit;font-size:13px;font-weight:700;cursor:pointer;padding:0;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-tab-close{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;background:transparent;color:inherit;opacity:.7;cursor:pointer}.code-tab-close:hover{background:#5b4bd829;opacity:1}.code-tab-rename-input{height:22px;width:120px;padding:0 8px;border:1px solid var(--brand-violet);border-radius:999px;background:var(--surface);color:var(--text);font-size:13px;font-weight:700;outline:none}.code-tab-add{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px dashed var(--border);border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s,border-color .12s}.code-tab-add:hover{background:var(--brand-violet-soft);color:var(--brand-violet);border-color:#5b4bd866;border-style:solid}.code-context-bar{display:flex;flex-wrap:wrap;gap:18px;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.code-context-summary{display:grid;gap:1px}.code-context-summary small{color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.code-context-summary span{color:var(--text);font-size:12px;font-weight:700}.code-main{display:grid;grid-template-columns:64px minmax(0,1fr);min-width:0;min-height:0;position:relative}.code-main.is-empty{grid-template-columns:minmax(0,1fr);background:#f8f9fc}.code-category-rail{display:flex;flex-direction:column;align-items:stretch;gap:4px;padding:10px 6px;border-right:1px solid var(--border);background:var(--surface-2);overflow-y:auto}.code-category-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:56px;padding:6px 4px;border:0;border-radius:10px;background:transparent;color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:background .12s,color .12s}.code-category-button span{display:block;text-align:center}.code-category-button:hover,.code-category-button:focus-visible{background:var(--surface);outline:none}.code-category-event:hover{color:#5b4bd8}.code-category-motion:hover{color:#167854}.code-category-look:hover{color:#13649f}.code-category-part:hover{color:#a85c10}.code-category-flow:hover{color:#8e2a8c}.code-blockly-area{position:relative;display:flex;flex-direction:column;min-width:0;min-height:0}.code-toolbox-chrome{position:absolute;top:8px;left:8px;right:8px;z-index:40;display:flex;align-items:center;gap:6px;pointer-events:none}.code-toolbox-search{display:flex;align-items:center;gap:6px;height:30px;width:168px;padding:0 10px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);pointer-events:auto;box-shadow:0 2px 8px #0f12300f}.code-toolbox-search svg{flex-shrink:0}.code-toolbox-search input{flex:1;min-width:0;height:24px;padding:0;border:0;background:transparent;color:var(--text);font-size:12px;font-weight:600;outline:none}.code-toolbox-collapse{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);cursor:pointer;pointer-events:auto;box-shadow:0 2px 8px #0f12300f}.code-toolbox-collapse:hover{color:var(--brand-violet);border-color:var(--brand-violet)}.code-blockly-area .code-workspace{flex:1;min-width:0;min-height:0;background:#f6f7fb;position:relative;padding-top:0}.code-blockly-area .blocklyFlyoutBackground{fill:#f4f6fb}.code-panel:not(.is-flyout-collapsed) .blocklyFlyout .blocklyDraggable{clip-path:inset(-2px calc(100% - 152px) -2px -2px round 14px);transition:clip-path .22s cubic-bezier(.2,.8,.2,1);cursor:grab}.code-panel:not(.is-flyout-collapsed) .blocklyFlyout .blocklyDraggable:hover{clip-path:inset(-2px -2px -2px -2px round 14px)}.code-blockly-area:before{content:"";position:absolute;top:0;bottom:0;left:156px;width:1px;background:var(--border);pointer-events:none;z-index:4;transition:opacity .16s ease}.code-panel.is-flyout-collapsed .code-blockly-area:before{opacity:0}.code-blockly-area:after{content:"";position:absolute;top:0;bottom:0;left:152px;width:28px;pointer-events:none;background:linear-gradient(to right,#f4f6fb00,#f4f6fbc7 60%,#f4f6fb00);opacity:1;transition:opacity .16s ease}.code-panel.is-flyout-collapsed .code-blockly-area:after{opacity:0}.code-workspace{min-width:0;min-height:0;background:#f6f7fb}.code-empty-state{display:grid;place-items:center;align-content:center;gap:10px;padding:24px;color:var(--text-muted);font-size:14px;font-weight:600;text-align:center}.code-main.is-empty .code-empty-state{justify-self:stretch;align-self:stretch;min-width:0;min-height:0}.code-empty-state strong{color:var(--text);font-size:16px;font-weight:700}.code-empty-state span{max-width:220px}.code-workspace .blocklyFlyout{filter:drop-shadow(0 1px 0 var(--border));overflow:visible}.code-workspace .blocklyFlyoutBackground{fill:#f4f6fb;fill-opacity:1}.code-workspace .blocklyFlyoutScrollbar .blocklyScrollbarBackground{pointer-events:all}.code-workspace .blocklyFlyoutLabel .blocklyFlyoutLabelText{font-family:Inter,system-ui,sans-serif;font-size:11px;font-weight:800;letter-spacing:.14em;paint-order:stroke;stroke:#f4f6fb;stroke-width:4px;fill:var(--text-muted)}.code-workspace .lud-flyout-label-event .blocklyFlyoutLabelText{fill:#5b4bd8}.code-workspace .lud-flyout-label-motion .blocklyFlyoutLabelText{fill:#167854}.code-workspace .lud-flyout-label-look .blocklyFlyoutLabelText{fill:#13649f}.code-workspace .lud-flyout-label-part .blocklyFlyoutLabelText{fill:#a85c10}.code-workspace .lud-flyout-label-flow .blocklyFlyoutLabelText{fill:#8e2a8c}.transform-popover{top:144px;left:64px;width:336px;border-radius:var(--radius-panel);max-height:calc(100% - 448px);overflow-y:auto}.object-panel-header,.popover-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid var(--border);background:var(--surface-2)}.popover-header h2{margin:0;color:var(--text-muted);font-size:13px;font-weight:700;text-transform:uppercase}.object-name-field{display:grid;min-width:0;flex:1;gap:4px}.object-name-field span{color:var(--text-muted);font-size:12px;font-weight:700;text-transform:uppercase}.object-name-field input{height:36px;width:100%;border:1px solid var(--border);border-radius:var(--radius-chip);padding:0 12px;background:var(--surface);color:var(--text);font-weight:700}.module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:12px}.module-button{position:relative;display:grid;min-height:64px;place-items:center;gap:4px;padding:8px;border-radius:var(--radius-button);background:var(--surface-2);color:var(--text-muted);font-size:12px;font-weight:700;cursor:pointer}.module-button:hover:not(:disabled){background:var(--brand-violet-soft);color:var(--brand-violet)}.module-button small{position:absolute;top:4px;right:4px;padding:1px 4px;border-radius:999px;background:var(--brand-violet);color:#fff;font-size:10px}.object-action-row{display:flex;flex-wrap:wrap;gap:8px;padding:0 12px 12px}.action-chip,.secondary-panel-button,.primary-panel-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 12px;border-radius:var(--radius-button);font-size:13px;font-weight:700;cursor:pointer}.action-chip,.secondary-panel-button{border:1px solid var(--border);background:var(--surface);color:var(--text)}.action-chip:hover,.secondary-panel-button:hover{border-color:var(--brand-violet);background:var(--brand-violet-soft);color:var(--brand-violet)}.action-chip.is-danger:hover{border-color:var(--danger);background:#d248581a;color:var(--danger)}.primary-panel-button{background:var(--brand-violet);color:#fff}.full-width{width:100%}.selection-editor{display:grid;gap:12px;padding:12px}.group{border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);overflow:hidden}.group.is-active{border-color:var(--brand-violet);box-shadow:0 0 0 3px #5b4bd829}.group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface)}.group-header h3{margin:0;color:var(--text-muted);font-size:12px;font-weight:700;text-transform:uppercase}.axis-grid{display:grid;gap:8px;padding:12px}.axis-row{display:grid;grid-template-columns:24px 32px minmax(0,1fr) auto 32px;align-items:center;gap:8px}.axis-label{display:grid;place-items:center;width:24px;height:24px;border-radius:var(--radius-chip);color:#fff;font-size:12px;font-weight:800}.axis-row.axis-x .axis-label{background:var(--axis-x)}.axis-row.axis-y .axis-label{background:var(--axis-y)}.axis-row.axis-z .axis-label{background:var(--axis-z)}.axis-nudge,.scale-button{border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface);color:var(--text);font-weight:800;cursor:pointer}.axis-nudge{width:32px;height:32px}.axis-input{width:100%;height:32px;border:1px solid var(--border);border-radius:var(--radius-chip);padding:0 8px;background:var(--surface);color:var(--text);text-align:right;font-variant-numeric:tabular-nums}.axis-unit{color:var(--text-muted);font-size:12px;font-weight:700}.axis-nudge:hover,.scale-button:hover{border-color:var(--brand-violet);background:var(--brand-violet-soft);color:var(--brand-violet)}.scale-row{display:grid;grid-template-columns:40px minmax(0,1fr) 40px;align-items:center;gap:8px;padding:12px}.scale-button{height:40px;font-size:18px}.scale-display{display:flex;min-width:0;flex-direction:column;align-items:center;gap:4px;font-variant-numeric:tabular-nums}.scale-display>span:first-child{color:var(--text);font-size:16px;font-weight:800}.scale-axes{max-width:100%;overflow:hidden;color:var(--text-muted);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.palette-row{display:flex;flex-wrap:wrap;gap:8px;padding:12px}.color-chip,.color-picker{width:28px;height:28px;border-radius:999px;cursor:pointer}.color-chip{border:2px solid transparent;box-shadow:inset 0 0 0 1px #0f12302e}.color-chip.is-active{border-color:var(--brand-violet);box-shadow:inset 0 0 0 1px #0f12302e,0 0 0 3px #5b4bd82e}.color-picker{padding:0;border:1px solid var(--border);background:transparent;overflow:hidden}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:0;border-radius:999px}.bottom-dock{position:absolute;left:40px;right:0;bottom:0;z-index:8;display:grid;grid-template-columns:136px minmax(0,1fr);border-top:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-elevation);transition:height var(--motion-base) var(--ease-out)}.bottom-dock.is-expanded{height:280px}.bottom-dock.is-collapsed{height:88px}.bottom-dock-tabs{display:flex;flex-direction:column;gap:8px;padding:12px;border-right:1px solid var(--border);background:var(--surface-2);overflow:hidden}.bottom-tab,.collapse-button,.category-button,.asset-tile{cursor:pointer;transition:background var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out)}.bottom-tab{display:flex;align-items:center;gap:8px;min-height:32px;padding:0 8px;border-radius:var(--radius-chip);background:transparent;color:var(--text-muted);font-size:13px;font-weight:700}.bottom-tab:hover,.bottom-tab.is-active{background:var(--brand-violet-soft);color:var(--brand-violet)}.collapse-button{display:grid;place-items:center;min-height:32px;margin-top:auto;border-radius:var(--radius-chip);background:var(--surface);color:var(--text-muted)}.library-content{display:grid;grid-template-columns:160px minmax(0,1fr);min-width:0;min-height:0}.category-column{display:flex;flex-direction:column;gap:8px;padding:12px;border-right:1px solid var(--border);overflow-y:auto}.category-button{display:flex;align-items:center;gap:8px;min-height:36px;padding:0 8px;border-radius:var(--radius-chip);background:transparent;color:var(--text-muted);text-align:left;font-size:13px;font-weight:700}.category-button:hover,.category-button.is-active{background:var(--brand-violet-soft);color:var(--brand-violet)}.asset-region{display:grid;grid-template-rows:auto minmax(0,1fr);min-width:0;min-height:0;padding:12px 16px 16px;gap:12px}.search-field{display:flex;align-items:center;gap:8px;width:min(360px,100%);height:40px;border:1px solid var(--border);border-radius:var(--radius-button);padding:0 12px;background:var(--surface-2);color:var(--text-muted)}.search-field input{min-width:0;width:100%;border:0;background:transparent;color:var(--text);outline:0}.asset-strip{display:flex;gap:12px;min-width:0;overflow-x:auto;padding-bottom:8px}.asset-tile{position:relative;flex:0 0 96px;width:96px;height:96px;display:grid;place-items:center;gap:6px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text-muted);font-size:13px;font-weight:700;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out),background var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out)}.asset-drag-grip{position:absolute;top:7px;right:7px;color:currentColor;opacity:.42;transition:opacity var(--motion-fast) var(--ease-out)}.asset-tile span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-tile:hover{transform:translateY(-4px);border-color:var(--brand-violet);background:var(--brand-violet-soft);color:var(--brand-violet);box-shadow:0 10px 24px #5b4bd829}.asset-tile:hover .asset-drag-grip{opacity:.88}.asset-tile:active{cursor:grabbing;transform:translateY(-2px) scale(.98)}.asset-drag-preview{position:fixed;top:-120px;left:-120px;z-index:10000;width:96px;height:96px;border-color:var(--brand-violet);background:var(--surface);color:var(--brand-violet);box-shadow:0 18px 42px #18123b47;pointer-events:none;transform:rotate(-2deg) scale(.98)}.dock-empty-content{display:flex;align-items:center;gap:12px;min-width:0;padding:16px;overflow-x:auto}.environment-chip,.help-chip{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 12px;border-radius:999px;background:var(--surface-2);color:var(--text-muted);font-size:13px;font-weight:700;white-space:nowrap}.bottom-dock.is-collapsed .library-content{grid-template-columns:minmax(0,1fr)}.bottom-dock.is-collapsed .asset-region{display:none}.bottom-dock.is-collapsed .category-column{flex-direction:row;border-right:0;overflow-x:auto}.bottom-dock.is-collapsed .category-button{flex:0 0 auto}.file-input{display:none}.snap-controls{display:grid;gap:12px;padding:12px}.snap-option{display:grid;grid-template-columns:20px minmax(0,1fr) auto;align-items:center;gap:12px;min-height:32px;color:var(--text-muted);font-size:13px;font-weight:700}.snap-option input{width:18px;height:18px;accent-color:var(--brand-violet)}.snap-option kbd{min-width:32px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface-2);color:var(--text-muted);font-family:Inter,sans-serif;font-size:12px;font-weight:700;text-align:center}.grid-resolution-control{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));overflow:hidden;border-radius:var(--radius-chip);background:var(--surface-2)}.grid-resolution-control button{height:40px;border-radius:0;border-right:1px solid var(--border);color:var(--text-muted);font-size:13px;font-weight:800;font-variant-numeric:tabular-nums}.grid-resolution-control button:last-child{border-right:0}.grid-resolution-control button:hover,.grid-resolution-control button.is-active{background:var(--brand-violet);color:#fff}.toast-stack{position:fixed;left:50%;bottom:304px;z-index:30;display:flex;flex-direction:column;align-items:center;gap:8px;transform:translate(-50%);pointer-events:none}.app-shell.dock-collapsed .toast-stack{bottom:112px}.app-shell.is-playing .toast-stack{bottom:24px}.toast{display:flex;align-items:center;gap:12px;max-width:min(440px,calc(100vw - 48px));min-height:44px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface);color:var(--text);font-size:14px;font-weight:700;box-shadow:var(--shadow-elevation);pointer-events:none}.toast-success{border-color:#22a06b52}.toast-danger{border-color:#d2485852}.toast-action{min-height:28px;padding:0 10px;border-radius:999px;background:var(--brand-violet-soft);color:var(--brand-violet);font-size:13px;font-weight:800;cursor:pointer;pointer-events:auto}.toast-close{display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;pointer-events:auto}.modal-backdrop{position:fixed;inset:0;z-index:25;display:grid;place-items:center;padding:24px;background:#0f12305c}.first-run-panel-wrap{position:fixed;top:72px;left:50%;z-index:24;width:min(680px,calc(100vw - 112px));transform:translate(-50%);pointer-events:none}.modal-panel{width:min(640px,100%);max-height:calc(100dvh - 48px);overflow:auto;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation)}.first-run-panel{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation);pointer-events:auto}.modal-header,.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border-bottom:1px solid var(--border)}.modal-footer{justify-content:flex-end;border-top:1px solid var(--border);border-bottom:0}.modal-header h2{margin:0;color:var(--text);font-size:20px;line-height:1.3}.walkthrough-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}.walkthrough-steps article{padding:16px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2)}.walkthrough-steps span{display:grid;place-items:center;width:32px;height:32px;border-radius:999px;background:var(--brand-violet);color:#fff;font-weight:800}.walkthrough-steps h3{margin:12px 0 8px;font-size:16px}.walkthrough-steps p,.shortcut-grid p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.45}.help-layout{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:16px;padding:16px}.shortcut-grid{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px 16px}.shortcut-grid>span{display:flex;align-items:center;justify-content:flex-end;gap:4px;white-space:nowrap}.help-actions{display:grid;align-content:start;gap:8px}@media(max-width:1100px){.topbar{grid-template-columns:minmax(180px,1fr) auto minmax(220px,1fr)}.scene-title-button,.scene-title-input{max-width:200px}.topbar-button{padding:4px 6px}}@media(max-width:900px){.topbar{grid-template-columns:minmax(0,1fr) auto}.topbar-center,.scene-title-button{display:none}.play-button{min-width:48px;padding:0 10px}.play-button span,.topbar-button span{display:none}.topbar-right{gap:4px}}@media(max-width:720px){.topbar-button span,.bottom-tab span,.selection-gizmo-cluster span{display:none}.topbar{padding:0 8px;gap:8px}.brand-name{display:none}.bottom-dock{grid-template-columns:64px minmax(0,1fr)}.bottom-dock-tabs{padding:8px}.bottom-tab{justify-content:center}.library-content{grid-template-columns:minmax(0,1fr)}.category-column{flex-direction:row;overflow-x:auto;border-right:0}.category-button span{display:none}.object-action-panel,.transform-popover{left:56px;right:8px;width:auto}.code-panel{left:8px;right:8px;width:auto!important;border:1px solid var(--border);border-radius:var(--radius-panel)}.code-panel-resizer{display:none}.object-action-panel{top:8px;border:1px solid var(--border);border-radius:var(--radius-panel)}.help-layout,.walkthrough-steps{grid-template-columns:1fr}.first-run-panel-wrap{top:64px;right:8px;left:48px;width:auto;transform:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:0ms!important;animation-duration:0ms!important;scroll-behavior:auto!important}}
