:root{--brand-deep: #1F1B3D;--brand-violet: #5B4BD8;--brand-violet-soft: #ECEAFB;--chrome-graphite: #17171D;--chrome-graphite-raised: #2A2934;--chrome-graphite-hover: #343240;--chrome-graphite-border: rgba(255, 255, 255, .16);--chrome-text-muted: rgba(255, 255, 255, .7);--surface: #FFFFFF;--surface-2: #F6F7FB;--surface-inset: #EEF1F7;--canvas-top: #F7F8FB;--canvas-bottom: #E9ECF3;--ground: #FAFBFD;--grid-minor: #DEE2EC;--grid-major: #C5CAD6;--text: #0F1230;--text-muted: #5A6079;--success: #22A06B;--success-text: #167854;--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;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);background:var(--chrome-graphite);overflow:hidden}.app-shell.is-playing{background:var(--canvas-bottom)}.mobile-fullscreen-control{display:none;position:fixed;top:calc(env(safe-area-inset-top) + 54px);right:calc(env(safe-area-inset-right) + 8px);z-index:30;flex-direction:column;align-items:flex-end;gap:6px}.mobile-fullscreen-button{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:#17171d9e;color:#fff;box-shadow:0 6px 18px #00000047;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;transition:background var(--motion-fast) var(--ease-out)}.mobile-fullscreen-button:hover{background:#17171dcc}.mobile-fullscreen-hint{max-width:240px;padding:10px 12px;border-radius:var(--radius-button);background:var(--chrome-graphite-raised);color:#fff;font-size:12px;line-height:1.45;box-shadow:0 12px 30px #00000052}.mobile-fullscreen-hint strong{font-weight:700}.mobile-fullscreen-hint button{margin-top:8px;padding:4px 12px;border-radius:999px;background:#ffffff29;color:#fff;font-size:12px;font-weight:700;cursor:pointer}.app-shell:fullscreen,.play-room-page:fullscreen{width:100vw;height:100dvh;overflow:hidden}.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(--chrome-graphite);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}.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(--chrome-graphite);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:var(--chrome-graphite-raised);border:1px solid rgba(255,255,255,.08);cursor:pointer}.scene-title-button:hover{background:var(--chrome-graphite-hover)}.scene-title-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-title-button:disabled{cursor:default;opacity:.85}.readonly-chip{display:inline-flex;align-items:center;min-height:24px;padding:2px 8px;border:1px solid rgba(255,255,255,.22);border-radius:999px;color:#ffffffe0;font-size:11px;font-weight:800;white-space:nowrap}.multiplayer-chip{display:inline-flex;align-items:center;gap:5px;min-height:24px;padding:2px 8px;border:1px solid rgba(45,212,191,.36);border-radius:999px;background:#14b8a624;color:#ccfbf1;font-size:11px;font-weight:800;white-space:nowrap}.physics-chip{display:inline-flex;align-items:center;gap:5px;min-height:24px;padding:2px 8px;border:1px solid rgba(99,102,241,.34);border-radius:999px;background:#6366f124;color:#e0e7ff;font-size:11px;font-weight:800;white-space:nowrap}.scene-title-input{border:1px solid var(--chrome-graphite-border);padding:0 12px;background:var(--chrome-graphite-raised)}.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:4px;padding:4px 8px;border-radius:var(--radius-button);background:transparent;color:var(--chrome-text-muted);font-size:12px;font-weight:600}.topbar-button:hover,.topbar-button.is-active{background:var(--chrome-graphite-hover);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)}.play-button.is-stop{min-width:96px;background:transparent;color:var(--danger);border:1.5px solid var(--danger)}.play-button.is-stop:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.play-status-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:600;pointer-events:none;-webkit-user-select:none;user-select:none}.play-status-chip.is-playing{background:#22a06b40;color:var(--success)}.play-status-chip.is-paused{background:#d9821a40;color:var(--warning)}.play-status-chip.is-playing:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--success);animation:play-pulse 1.4s ease-in-out infinite}.play-status-chip.is-paused:before{content:"⏸";font-size:10px}@keyframes play-pulse{0%,to{opacity:1}50%{opacity:.35}}@media(prefers-reduced-motion:reduce){.play-status-chip.is-playing:before{animation:none}.runtime-click-ripple{display:none}}.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)}.icon-button:disabled{opacity:.3;cursor:default}.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:10px 12px;background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0}.panel-head h2{margin:0;color:var(--text-muted);font-size:13px;font-weight:700;text-transform:uppercase}.mini-badge{min-width:24px;padding:4px 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-list{flex:1;min-height:0;overflow-y:auto;padding:4px 0}.scene-card{display:flex;align-items:center;gap:2px;padding:0 4px 0 12px;min-height:36px;border-left:2px solid transparent;color:var(--text);text-align:left}.scene-card.is-active{border-left-color:var(--brand-violet);background:var(--brand-violet-soft)}.scene-card-select{flex:1;min-width:0;display:flex;align-items:center;height:36px;padding:0;background:transparent;color:inherit;text-align:left;cursor:pointer}.scene-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-name-input{flex:1;min-width:0;font-size:13px;font-weight:500;padding:2px 6px;border:1px solid var(--brand-violet);border-radius:var(--radius-chip);background:var(--surface);color:var(--text);outline:none}.scene-card-actions{display:flex;align-items:center;flex-shrink:0}.scene-card .icon-button{width:28px;height:28px}.scene-mode-card{display:grid;gap:8px;margin:8px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface)}.scene-mode-card-head{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:11px;font-weight:800;text-transform:uppercase}.scene-mode-group{display:grid;gap:5px}.scene-mode-label{color:var(--text-muted);font-size:11px;font-weight:800}.scene-mode-switch{display:grid;grid-template-columns:1fr;gap:6px}.scene-mode-switch button{min-height:30px;padding:0 8px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text-muted);font-size:12px;font-weight:800;cursor:pointer}.scene-mode-switch button:hover,.scene-mode-switch button:focus-visible{border-color:#5b4bd85c;color:var(--brand-violet);outline:none}.scene-mode-switch button.is-active{border-color:#0f766e52;background:#d7f4ef;color:#0f766e}.environment-preset-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.environment-preset{display:grid;grid-template-columns:28px minmax(0,1fr);align-items:center;gap:6px;min-height:32px;padding:4px 7px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text-muted);font-size:11px;font-weight:800;text-align:left;cursor:pointer}.environment-preset:hover,.environment-preset:focus-visible{border-color:#5b4bd85c;color:var(--brand-violet);outline:none}.environment-preset.is-active{border-color:#0f766e52;background:#d7f4ef;color:#0f766e}.environment-swatch{display:block;width:28px;height:20px;border-radius:6px;border:1px solid rgba(15,23,42,.12)}.environment-swatch-studio{background:linear-gradient(#dceaf7,#e0e4e2)}.environment-swatch-sky{background:linear-gradient(#87c8ff,#e9f7ff)}.environment-swatch-dawn{background:linear-gradient(#f6c99c,#ffe7c2)}.environment-swatch-sunset{background:linear-gradient(#e87945,#ffd6a3)}.environment-swatch-night{background:linear-gradient(#0f172a,#334155)}.environment-swatch-starry{background:radial-gradient(circle at 72% 32%,#f8fafc 0 1.5px,transparent 2.5px),radial-gradient(circle at 34% 55%,#c7d2fe 0 1px,transparent 2px),#07111f}.environment-swatch-cloudy{background:radial-gradient(ellipse at 34% 68%,rgba(255,255,255,.88) 0 32%,transparent 33%),radial-gradient(ellipse at 68% 58%,rgba(241,245,249,.86) 0 28%,transparent 29%),linear-gradient(#b8c4d2,#dce3ec)}.environment-swatch-grass{background:linear-gradient(#91cf72,#4f8f46)}.environment-swatch-water{background:repeating-linear-gradient(165deg,rgba(255,255,255,.26) 0 2px,transparent 2px 7px),linear-gradient(#58c4dd,#2188aa)}.environment-swatch-checker{background:conic-gradient(#f8fafc 25%,#64748b 0 50%,#f8fafc 0 75%,#64748b 0);background-size:10px 10px}.environment-swatch-none{background:linear-gradient(135deg,transparent 44%,rgba(100,116,139,.5) 45% 55%,transparent 56%),#f8fafc}.environment-swatch-city{background:linear-gradient(90deg,transparent 0 12%,#334155 12% 28%,transparent 28% 34%,#64748b 34% 54%,transparent 54% 60%,#0f766e 60% 76%,transparent 76% 82%,#475569 82% 100%),linear-gradient(#b9d3e7 0 54%,#283746 54% 100%)}.environment-swatch-mountains{background:linear-gradient(135deg,transparent 0 48%,#2f4852 49% 70%,transparent 71%),linear-gradient(45deg,transparent 0 42%,#60727a 43% 68%,transparent 69%),linear-gradient(#b9d3e7 0 50%,#29483b 50% 100%)}.environment-swatch-countryside{background:linear-gradient(165deg,transparent 0 48%,#d2a449 49% 62%,transparent 63%),linear-gradient(15deg,transparent 0 43%,#5f8f3c 44% 67%,transparent 68%),linear-gradient(#b9d3e7 0 46%,#315f32 46% 100%)}.environment-swatch-forest{background:linear-gradient(72deg,transparent 0 41%,#183d24 42% 57%,transparent 58%),linear-gradient(108deg,transparent 0 38%,#2f6b35 39% 61%,transparent 62%),repeating-linear-gradient(90deg,#153623 0 5px,#244f2d 5px 10px),linear-gradient(#9fc2cb 0 42%,#163b24 42% 100%)}.environment-swatch-coast{background:linear-gradient(72deg,transparent 0 43%,#1d5d2a 44% 48%,transparent 49%),linear-gradient(108deg,transparent 0 41%,#267436 42% 47%,transparent 48%),linear-gradient(#9bd7eb 0 37%,#087c9d 38% 62%,#e3bd72 63% 100%)}.environment-swatch-desert{background:linear-gradient(165deg,transparent 0 41%,#914521 42% 64%,transparent 65%),linear-gradient(15deg,transparent 0 47%,#bc6a31 48% 68%,transparent 69%),linear-gradient(#e7b56f 0 43%,#c47a35 44% 100%)}.environment-swatch-sahara{background:radial-gradient(ellipse at 72% 70%,#f1cf78 0 18%,transparent 19%),radial-gradient(ellipse at 24% 78%,#d79538 0 24%,transparent 25%),linear-gradient(#edbd69 0 42%,#c77b2a 43% 100%)}.scene-mode-select{min-height:32px;width:100%;padding:0 8px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text);font-size:12px;font-weight:750}.scene-mode-field{display:grid;gap:5px}.scene-mode-number{min-height:32px;width:100%;padding:0 8px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text);font-size:12px;font-weight:750}.scene-mode-toggle{display:flex;align-items:center;gap:8px;min-height:30px;color:var(--text-muted);font-size:12px;font-weight:800}.scene-mode-toggle input{width:16px;height:16px;accent-color:var(--brand-violet)}.scene-mode-range{display:grid;gap:5px}.scene-mode-range input{width:100%;accent-color:var(--brand-violet)}.scene-mode-note{margin:0;color:var(--text-muted);font-size:11px;font-weight:650;line-height:1.35}.runtime-audio-toggle{position:absolute;right:18px;bottom:18px;z-index:12;min-height:34px;padding:0 12px;border:1px solid rgba(15,23,42,.16);border-radius:var(--radius-button);background:#ffffffe6;color:var(--text);font-size:12px;font-weight:850;box-shadow:var(--shadow-soft);cursor:pointer}.runtime-audio-toggle.is-muted{color:var(--text-muted);background:#f1f5f9eb}.new-scene-button{display:flex;align-items:center;justify-content:center;gap:6px;margin:8px;min-height:34px;flex-shrink:0;border-radius:var(--radius-button);background:var(--brand-violet);color:#fff;font-size:13px;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:var(--radius-chip)}.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,.primary-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:10px;z-index:8;border:2px solid rgba(91,75,216,0);border-radius:var(--radius-panel);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:#5b4bd8bd;box-shadow:inset 0 0 0 9999px #5b4bd81a,inset 0 0 0 1px #ffffffbf,inset 0 0 52px #5b4bd842,0 0 0 1px #5b4bd82e;opacity:1}.scene-stage.is-drop-ready:after{border-color:#5b4bd8eb;box-shadow:inset 0 0 0 9999px #5b4bd821,inset 0 0 0 1px #ffffffd6,inset 0 0 64px #5b4bd852,0 0 0 1px #5b4bd83d}.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:18px;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}.road-builder-menu{position:absolute;top:72px;left:50%;z-index:13;display:flex;align-items:center;justify-content:center;gap:6px;max-width:calc(100% - 32px);padding:6px;transform:translate(-50%);border:1px solid var(--border);border-radius:var(--radius-panel);background:#fffffff5;box-shadow:var(--shadow-elevation);pointer-events:auto}.road-builder-option{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-width:104px;height:38px;padding:6px 11px 6px 7px;border:1px solid rgba(91,75,216,.28);border-radius:999px;background:#fffffff7;color:#252a44;font:800 12px/1.1 Inter,system-ui,sans-serif;box-shadow:0 14px 32px #18123b2e,0 2px 8px #18123b14;transform:translateY(0);transition:background-color .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease,transform .12s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.road-builder-option:hover,.road-builder-option:focus-visible,.road-builder-option.is-active{border-color:#5b4bd8b8;background:#fff;color:#3e31b8;box-shadow:0 18px 38px #18123b3d,0 0 0 3px #5b4bd821;transform:translateY(-1px)}.road-builder-option:focus-visible{outline:none}.road-builder-option-icon{display:inline-grid;place-items:center;flex:0 0 auto;width:25px;height:25px;border-radius:999px;background:#5b4bd8;color:#fff;font-size:12px;font-weight:900;line-height:1}.road-builder-option-label{display:block}.scene-status{position:absolute;right:24px;bottom:18px;z-index:6;display:flex;gap:12px;padding:8px 12px;pointer-events:none}.app-shell.resource-open .scene-status{right:calc(var(--resource-panel-width, 460px) + 24px)}.runtime-code-hud{position:absolute;top:80px;left:50%;z-index:16;display:grid;justify-items:center;gap:8px;max-width:min(520px,calc(100% - 48px));transform:translate(-50%);pointer-events:none}.runtime-goal{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.runtime-goal-chip{border-radius:999px;padding:5px 12px;background:#fffffff0;border:1px solid rgba(255,255,255,.72);color:var(--text);font-size:14px;font-weight:800;box-shadow:var(--shadow-elevation)}.runtime-goal-lives{color:#d24858}.runtime-score,.runtime-text{border:1px solid rgba(255,255,255,.72);border-radius:var(--radius-button);background:#fffffff0;color:var(--text);box-shadow:var(--shadow-elevation)}.runtime-score{padding:8px 12px;color:var(--brand-violet);font-size:13px;font-weight:800}.runtime-score.is-pop{animation:runtime-score-pop .36s var(--ease-out)}.runtime-click-ripple{position:absolute;z-index:15;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid rgba(91,75,216,.76);border-radius:999px;background:#5b4bd81f;pointer-events:none;animation:runtime-click-ripple .46s var(--ease-out) forwards}@keyframes runtime-score-pop{0%{transform:translateY(0) scale(.92)}45%{transform:translateY(-4px) scale(1.08)}to{transform:translateY(0) scale(1)}}@keyframes runtime-click-ripple{0%{transform:scale(.2);opacity:.9}to{transform:scale(4.2);opacity:0}}.runtime-text{padding:12px 16px;font-size:16px;font-weight:700;line-height:1.3;text-align:center}.object-text-overlay{position:absolute;z-index:17;max-width:min(220px,calc(100% - 32px));padding:5px 9px;border:1px solid rgba(255,255,255,.72);border-radius:var(--radius-button);background:#fffffff0;color:var(--text);box-shadow:var(--shadow-elevation);font-size:12px;font-weight:800;line-height:1.25;text-align:center;overflow-wrap:anywhere;pointer-events:none;transform:translate(-50%,-100%)}.object-text-bubble{padding:8px 11px;border-color:#5b4bd838;border-radius:8px;background:#fffffffa;color:var(--brand-violet);font-size:13px}.object-text-bubble:after{content:"";position:absolute;left:50%;bottom:-7px;width:12px;height:12px;border-right:1px solid rgba(91,75,216,.22);border-bottom:1px solid rgba(91,75,216,.22);background:inherit;transform:translate(-50%) rotate(45deg)}.object-text-floating{border-color:#0f12302e;background:#0f1230c7;color:#fff}.object-text-overlay.is-runtime{animation:object-text-pop .18s var(--ease-out)}@keyframes object-text-pop{0%{opacity:0;transform:translate(-50%,calc(-100% + 4px)) scale(.96)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.play-mode-hud{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:18;display:flex;align-items:center;gap:8px;pointer-events:none}.play-camera-mode-group{display:inline-flex;align-items:center;gap:2px;padding:3px;border-radius:var(--radius-button);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-elevation);pointer-events:all}.play-camera-mode-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;height:26px;border-radius:calc(var(--radius-button) - 2px);font-size:12px;font-weight:600;color:var(--text-muted);background:transparent;cursor:pointer;white-space:nowrap;transition:background var(--motion-fast),color var(--motion-fast)}.play-camera-mode-btn:hover{background:var(--surface-inset);color:var(--text)}.play-camera-mode-btn.is-active{background:var(--brand-violet);color:var(--surface)}.touch-play-controls{display:none}.touch-look-pad,.touch-joystick{-webkit-tap-highlight-color:transparent}.selection-action-bar{position:absolute;top:12px;left:50%;z-index:12;display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:6px;max-width:calc(100% - 32px);padding:6px;transform:translate(-50%);border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation)}.app-shell.resource-open .selection-action-bar{left:calc((100% - var(--resource-panel-width, 460px)) / 2);max-width:calc(100% - var(--resource-panel-width, 460px) - 32px)}.selection-action-group{display:flex;align-items:center;gap:4px}.selection-action-trailing{gap:6px}.selection-action-divider{align-self:stretch;width:1px;margin:2px 0;background:var(--border)}.selection-action-summary{padding:0 6px;color:var(--text-muted);font-size:12px;font-weight:700;white-space:nowrap}.selection-action-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:40px;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-action-button:hover:not(:disabled),.selection-action-button.is-active{background:var(--brand-violet-soft);color:var(--brand-violet)}.selection-action-button.is-danger:hover:not(:disabled){background:#d248581f;color:var(--danger)}.selection-action-button.is-icon{min-width:36px;padding:0}.selection-action-button:disabled{cursor:not-allowed;opacity:.4}.editor-mode-toggle{display:inline-flex;padding:2px;border:1px solid var(--border);border-radius:999px;background:var(--surface-2)}.editor-mode-toggle button{padding:5px 12px;border-radius:999px;background:transparent;color:var(--text-muted);font-size:12px;font-weight:700;cursor:pointer}.editor-mode-toggle button.is-active{background:var(--brand-violet);color:#fff}.selection-more-wrap{position:relative}.selection-more-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:20;min-width:230px;display:grid;gap:2px;padding:6px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface);box-shadow:var(--shadow-elevation)}.selection-more-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:var(--radius-chip);background:transparent;color:var(--text);font-size:13px;font-weight:600;text-align:left;cursor:pointer}.selection-more-menu button:hover:not(:disabled){background:var(--brand-violet-soft);color:var(--brand-violet)}.selection-more-menu button:disabled{cursor:not-allowed;opacity:.4}.selection-more-divider{height:1px;margin:4px 2px;background:var(--border)}.selection-more-hint{padding:6px 10px;color:var(--text-muted);font-size:12px}.object-inspector{position:absolute;z-index:11;top:0;right:0;width:min(360px,calc(100% - 48px));display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface);box-shadow:-6px 0 24px #0f12301a;overflow:hidden}.inspector-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid var(--border);background:var(--surface-2)}.inspector-title{display:grid;gap:6px;min-width:0;flex:1}.inspector-type-chip{justify-self:start;max-width:100%;padding:2px 8px;border-radius:999px;background:var(--brand-violet-soft);color:var(--brand-violet);font-size:11px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inspector-body{flex:1;display:grid;align-content:start;gap:8px;padding:8px;overflow-y:auto}.inspector-section{border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);overflow:hidden}.inspector-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:var(--surface);color:var(--text);font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;cursor:pointer}.inspector-section-body{display:grid;gap:10px;padding:10px}.inspector-section-body .selection-editor,.inspector-section-body .module-grid{padding:0}.inspector-advanced-actions{display:grid;gap:8px}.inspector-debug{margin:0;color:var(--text-muted);font-size:11px;word-break:break-all}.xform-grid{display:grid;gap:8px}.xform-row{display:grid;grid-template-columns:68px minmax(0,1fr);align-items:center;gap:10px}.xform-label{color:var(--text-muted);font-size:12px;font-weight:700}.xform-fields{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.xform-field{display:flex;align-items:center;gap:2px;min-width:0;padding-left:6px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface)}.xform-field:focus-within{border-color:var(--brand-violet);box-shadow:0 0 0 2px #5b4bd829}.xform-axis{flex:none;width:12px;text-align:center;font-size:11px;font-weight:800}.xform-field.axis-x .xform-axis{color:var(--axis-x)}.xform-field.axis-y .xform-axis{color:var(--axis-y)}.xform-field.axis-z .xform-axis{color:var(--axis-z)}.xform-field .axis-input{height:30px;min-width:0;padding:0 6px 0 2px;border:0;border-radius:0;background:transparent}.xform-field .axis-input:focus{outline:none}.component-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.component-button{display:grid;place-items:center;gap:4px;min-height:60px;padding:8px;border:1px solid transparent;border-radius:var(--radius-button);background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:700;cursor:pointer}.component-button:hover:not(:disabled){background:var(--brand-violet-soft);color:var(--brand-violet)}.component-button.is-active{border-color:var(--brand-violet);background:var(--brand-violet-soft);color:var(--brand-violet)}.component-button:disabled{cursor:not-allowed;opacity:.4}.component-disabled-note{margin:8px 0 0;color:var(--text-muted);font-size:12px;font-weight:650;line-height:1.35}.component-panel{display:grid;gap:8px;margin-top:10px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface)}.component-panel-title{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.physics-component-panel{gap:10px}.physics-field{display:grid;gap:6px}.physics-field select{min-height:34px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text);font-weight:700}.physics-segmented{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.physics-segmented button{min-height:30px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text-muted);font-size:12px;font-weight:800;cursor:pointer}.physics-segmented button.is-active{border-color:#5b4bd85c;background:var(--brand-violet-soft);color:var(--brand-violet)}.physics-toggle{display:flex;align-items:center;gap:8px;color:var(--text);font-size:12px;font-weight:750}.physics-toggle input{width:16px;height:16px;accent-color:var(--brand-violet)}.physics-sliders{display:grid;gap:8px}.physics-sliders label{display:grid;gap:4px;color:var(--text-muted);font-size:12px;font-weight:750}.material-component-panel,.text-component-panel{gap:10px}.behaviors-component-panel{gap:6px}.component-panel-hint{margin:0 0 2px;color:var(--text-muted);font-size:11.5px;line-height:1.35}.behavior-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--radius-button)}.behavior-row.is-active{background:#5b4bd814}.behavior-toggle{display:flex;align-items:center;gap:7px;color:var(--text);font-size:12px;font-weight:750;cursor:pointer}.behavior-amount{width:96px;accent-color:var(--brand-violet)}.material-sliders{display:grid;gap:8px}.material-sliders label,.material-pattern-field,.text-component-field{display:grid;gap:5px;color:var(--text-muted);font-size:12px;font-weight:750}.material-sliders input[type=range]{width:100%;accent-color:var(--brand-violet)}.text-component-field textarea{width:100%;min-height:72px;resize:vertical;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text);font:inherit;line-height:1.35}.code-panel,.animator-panel{position:absolute;z-index:19;top:0;right:0;bottom:0;width:720px;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface);box-shadow:-10px 0 28px #0f12301f;overflow:hidden;container-type:inline-size}.resource-panel{position:absolute;z-index:19;top:0;right:0;bottom:0;width:460px;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface);box-shadow:-10px 0 28px #0f12301f;overflow:hidden;container-type:inline-size}.code-panel-resizer{position:absolute;top:0;bottom:0;left:-3px;width:8px;cursor:col-resize;z-index:20;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 var(--motion-fast) var(--ease-out),opacity var(--motion-fast) var(--ease-out)}.code-panel-header{display:flex;align-items:center;justify-content:flex-start;gap:10px;min-height:48px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface-2)}.animator-panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:48px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface-2)}.resource-panel-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-height:58px;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--surface)}.animator-panel-title{display:inline-flex;align-items:center;gap:8px;min-width:0;color:var(--text);font-size:13px;font-weight:850}.animator-panel-title svg{color:var(--text-muted)}.resource-panel-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:4px;min-width:0;padding:4px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface-inset)}.resource-tab{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-width:0;min-height:34px;padding:0 12px;border-radius:6px;background:transparent;color:var(--text-muted);font-size:12px;font-weight:800;cursor:pointer;transition:background var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out)}.resource-tab:hover{background:#ffffffa3;color:var(--text)}.resource-tab.is-active{background:var(--surface);color:var(--brand-violet);box-shadow:0 1px 3px #1419381f}.resource-panel-body{min-height:0;flex:1;overflow:hidden}.code-panel-title{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex:0 0 auto;border-radius:999px;color:var(--text-muted);background:var(--surface);box-shadow:inset 0 0 0 1px var(--border)}.code-panel-header-status{display:flex;align-items:center;gap:8px;flex-shrink:0}.code-panel-check{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border:0;border-radius:999px;background:#1f9d57;color:#fff;font-size:13px;font-weight:800;cursor:pointer;box-shadow:0 2px 8px #1f9d5747;transition:background var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.code-panel-check:hover{background:#1b8b4d}.code-panel-check:active{transform:translateY(1px)}.code-panel-check:focus-visible{outline:2px solid #1f9d57;outline-offset:2px}.code-save-status{padding:4px 8px;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:var(--success-text)}.code-panel-tabs-region{display:grid;flex:1 1 auto;grid-template-rows:34px;gap:2px;align-items:center;min-width:120px;min-height:34px}.code-panel-tabs-region.has-slider{grid-template-rows:34px 8px;min-height:44px}.code-panel-tabs{display:inline-flex;flex:1 1 auto;align-items:center;gap:4px;min-width:0;max-width:100%;overflow-x:auto;padding:0;scrollbar-width:none}.code-panel-tabs::-webkit-scrollbar{height:0}.code-tabs-slider{width:100%;height:8px;margin:0;padding:0;border:0;background:transparent;cursor:pointer;appearance:none;accent-color:var(--brand-violet)}.code-tabs-slider::-webkit-slider-runnable-track{height:3px;border-radius:999px;background:#5b4bd82e}.code-tabs-slider::-webkit-slider-thumb{width:14px;height:14px;margin-top:-5.5px;border:2px solid var(--surface-2);border-radius:999px;background:var(--brand-violet);box-shadow:0 1px 4px #0f123038;appearance:none}.code-tabs-slider::-moz-range-track{height:3px;border-radius:999px;background:#5b4bd82e}.code-tabs-slider::-moz-range-thumb{width:10px;height:10px;border:2px solid var(--surface-2);border-radius:999px;background:var(--brand-violet);box-shadow:0 1px 4px #0f123038}.code-tabs-slider:focus-visible{outline:2px solid var(--brand-violet);outline-offset:2px}.code-tab{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 6px 0 12px;border-radius:var(--radius-chip);background:#ffffff8a;border:1px solid rgba(113,120,150,.22);color:var(--text-muted);flex-shrink:0;box-shadow:0 1px 2px #0f12300a;transition:background var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out)}.code-tab:hover{background:var(--surface);border-color:#5b4bd838;color:var(--text)}.code-tab.is-active{background:var(--brand-violet-soft);color:var(--brand-violet);border-color:#5b4bd857;box-shadow:0 2px 8px #5b4bd81a}.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-actions{display:inline-flex;align-items:center;gap:3px;flex:0 0 auto;padding-left:2px}.code-tab-action{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border:1px solid rgba(113,120,150,.28);border-radius:7px;background:#ffffffc7;cursor:pointer;opacity:1;transition:background var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.code-tab-action:hover,.code-tab-action:focus-visible{outline:none;transform:translateY(-1px)}.code-tab-rename{color:var(--brand-violet)}.code-tab-rename:hover,.code-tab-rename:focus-visible{border-color:#5b4bd86b;background:#fff;color:var(--brand-violet)}.code-tab-close{color:#b4232f}.code-tab-close:hover,.code-tab-close:focus-visible{border-color:#b4232f6b;background:#fff5f5;color:#9f1f2b}.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 var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out)}.code-tab-add:hover{background:var(--brand-violet-soft);color:var(--brand-violet);border-color:#5b4bd866;border-style:solid}.code-context-bar{display:inline-flex;flex:0 0 auto;align-items:center;min-width:0}.code-block-mode{display:flex;align-items:center;flex:0 0 auto;min-width:0}.code-block-mode-switch{display:inline-flex;align-items:center;gap:0;padding:3px;border:1px solid var(--border);border-radius:999px;background:var(--surface-inset)}.code-block-mode-switch button{min-width:58px;min-height:24px;padding:0 8px;border:0;border-radius:999px;background:transparent;color:var(--text-muted);font-size:12px;font-weight:800;cursor:pointer}.code-block-mode-switch button:hover,.code-block-mode-switch button:focus-visible{color:var(--brand-violet);outline:none}.code-block-mode-switch button.is-active{background:var(--surface);color:var(--brand-violet);box-shadow:0 1px 4px #0f12301f}@container (max-width: 460px){.code-panel-header{gap:6px;padding-inline:8px}.code-panel-check{width:30px;padding:0;justify-content:center}.code-panel-check span{display:none}.code-block-mode-switch button{min-width:48px;padding:0 6px}}.code-check-ok{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;background:#ecfdf3;color:#137a45;font-size:12px;font-weight:800;white-space:nowrap}.code-issue-overlay{position:absolute;inset:0;z-index:35;pointer-events:none;overflow:hidden}.code-block-delete-overlay{position:absolute;inset:0;z-index:36;pointer-events:none;overflow:hidden;clip-path:inset(0 0 0 0)}.code-block-delete-transform{position:absolute;top:0;left:0;transform-origin:0 0;pointer-events:none}.code-block-delete-button{position:absolute;display:inline-grid;place-items:center;width:24px;height:24px;padding:0;border:1px solid rgba(0,0,0,.18);border-radius:999px;background:color-mix(in srgb,var(--block-delete-fill, #4f5bd5) 74%,#000 26%);color:#fff;box-shadow:inset 0 1px #ffffff38;cursor:pointer;pointer-events:auto;touch-action:none;user-select:none;-webkit-user-select:none;transform:translate(-50%,-50%);transition:filter var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.code-block-delete-button:hover,.code-block-delete-button:focus-visible{filter:brightness(1.12)}.code-block-delete-button.is-holding{filter:brightness(1.06);transform:translate(-50%,-50%) scale(1.06)}.code-block-delete-button svg:not(.code-block-delete-ring){position:relative;z-index:1}.code-block-delete-ring{position:absolute;inset:-1px;width:24px;height:24px;overflow:visible;transform:rotate(-90deg)}.code-block-delete-ring-track,.code-block-delete-ring-progress{fill:none;stroke-width:2.5}.code-block-delete-ring-track{stroke:#ffffff38}.code-block-delete-ring-progress{stroke:#fff;stroke-linecap:round}.code-block-delete-button.is-holding .code-block-delete-ring-progress{stroke:#ffd5da;animation:code-block-delete-ring-fill 1s linear forwards}@keyframes code-block-delete-ring-fill{0%{stroke-dashoffset:62.8319}to{stroke-dashoffset:0}}.lud-issue-outline{position:absolute;box-sizing:border-box;border:3px solid #e11d48;border-radius:8px;box-shadow:0 0 0 2px #ffffffc7,0 0 14px #e11d4857;pointer-events:none;animation:lud-issue-pulse .7s ease-in-out 0s 6}.lud-issue-outline-field{border-width:2px;border-radius:7px;background:#e11d4812}@keyframes lud-issue-pulse{0%,to{opacity:.4}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.code-block-delete-button{transition:none}.code-block-delete-button.is-holding{transform:translate(-50%,-50%)}.lud-issue-outline{animation:none;opacity:1}}.code-main{flex:1 1 auto;display:grid;grid-template-columns:148px minmax(0,1fr);min-width:0;min-height:0;position:relative}.code-main.is-empty{grid-template-columns:minmax(0,1fr);background:var(--surface-2)}.code-category-rail{display:flex;flex-direction:column;align-items:stretch;gap:5px;padding:10px 8px;border-right:1px solid var(--border);background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(113,120,150,.42) transparent}.code-category-rail::-webkit-scrollbar{width:5px;height:0}.code-category-rail::-webkit-scrollbar-thumb{border-radius:999px;background:#71789657}.code-category-button{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:8px;min-height:42px;min-width:0;padding:7px 9px;border:1px solid transparent;border-radius:10px;background:#ffffff85;color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:0;cursor:pointer;box-shadow:0 1px 2px #0f123008;transition:background var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.code-category-button svg{flex:0 0 auto}.code-category-button span{display:block;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.code-category-button:hover,.code-category-button:focus-visible{background:var(--surface);border-color:#71789638;box-shadow:0 2px 8px #0f123014;outline:none;transform:translate(1px)}.code-category-event:hover{color:#5b4bd8}.code-category-control:hover{color:#8e2a8c}.code-category-logic:hover{color:#2949a8}.code-category-operator:hover{color:#114d3c}.code-category-data:hover{color:#6540b8}.code-category-multiplayer:hover{color:#0f766e}.code-category-physics:hover{color:#8a3b14}.code-category-motion:hover{color:#167854}.code-category-look:hover{color:#13649f}.code-category-part:hover{color:#a85c10}.code-category-screen:hover{color:#9f2e3b}.code-category-sound:hover{color:#0e7490}.code-category-button.is-active{background:var(--surface);border-color:#71789633;box-shadow:inset 3px 0 0 currentColor,0 2px 8px #0f123014}.code-category-event.is-active{color:#5b4bd8}.code-category-control.is-active{color:#8e2a8c}.code-category-logic.is-active{color:#2949a8}.code-category-operator.is-active{color:#114d3c}.code-category-data.is-active{color:#6540b8}.code-category-multiplayer.is-active{color:#0f766e}.code-category-physics.is-active{color:#8a3b14}.code-category-motion.is-active{color:#167854}.code-category-look.is-active{color:#13649f}.code-category-part.is-active{color:#a85c10}.code-category-screen.is-active{color:#9f2e3b}.code-category-sound.is-active{color:#0e7490}.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:8px;pointer-events:none}.code-toolbox-search{display:flex;align-items:center;gap:8px;height:30px;width:200px;padding:0 8px;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-blockly-area .code-workspace{flex:1;min-width:0;min-height:0;background:var(--surface-2);position:relative;padding-top:0}.code-blockly-area .blocklyFlyoutBackground{fill:var(--surface-2)}.code-panel:not(.is-flyout-collapsed) .blocklyFlyout .blocklyDraggable{clip-path:inset(-2px calc(100% - 184px) -2px -2px round 14px);transition:clip-path var(--motion-slow) var(--ease-out);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:48px;bottom:0;left:188px;width:1px;background:var(--border);pointer-events:none;z-index:4;transition:opacity var(--motion-base) var(--ease-out)}.code-panel.is-flyout-collapsed .code-blockly-area:before{opacity:0}.code-blockly-area:after{content:"";position:absolute;top:48px;bottom:0;left:184px;width:28px;pointer-events:none;background:linear-gradient(to right,#f4f6fb00,#f4f6fbc7 60%,#f4f6fb00);opacity:1;transition:opacity var(--motion-base) var(--ease-out)}.code-panel.is-flyout-collapsed .code-blockly-area:after{opacity:0}.code-workspace{min-width:0;min-height:0;background:var(--surface-2)}.code-empty-state{display:grid;place-items:center;align-content:center;gap:8px;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));clip-path:inset(0 -100vw 0 0);overflow:visible}.code-workspace .blocklyFlyoutBackground{fill:var(--surface-2);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:var(--surface-2);stroke-width:4px;fill:var(--text-muted)}.code-workspace .blocklySelected>.blocklyPath,.code-workspace .luduum-blockly-multi-selected>.blocklyPath{stroke:#facc15!important;stroke-width:3px;filter:drop-shadow(0 0 6px rgba(250,204,21,.55))}.code-workspace .lud-flyout-label-event .blocklyFlyoutLabelText{fill:#5b4bd8}.code-workspace .lud-flyout-label-control .blocklyFlyoutLabelText{fill:#8e2a8c}.code-workspace .lud-flyout-label-logic .blocklyFlyoutLabelText{fill:#2949a8}.code-workspace .lud-flyout-label-operator .blocklyFlyoutLabelText{fill:#114d3c}.code-workspace .lud-flyout-label-data .blocklyFlyoutLabelText{fill:#6540b8}.code-workspace .lud-flyout-label-multiplayer .blocklyFlyoutLabelText{fill:#0f766e}.code-workspace .lud-flyout-label-physics .blocklyFlyoutLabelText{fill:#8a3b14}.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-screen .blocklyFlyoutLabelText{fill:#9f2e3b}.code-workspace .lud-flyout-label-sound .blocklyFlyoutLabelText{fill:#0e7490}.code-workspace .luduum-top-event-drop-slot{pointer-events:none;opacity:.96}.code-workspace .luduum-top-event-drop-slot-frame{fill:#ffffff94;stroke:var(--brand-violet);stroke-width:3px;stroke-dasharray:11 7;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 8px rgba(91,75,216,.48)) drop-shadow(0 8px 16px rgba(91,75,216,.2));transform-box:fill-box;transform-origin:center;animation:lud-landing-slot-pulse .7s ease-in-out infinite}.code-workspace .luduum-top-event-drop-cue{filter:drop-shadow(0 0 7px rgba(91,75,216,.55))}.code-workspace .luduum-top-event-drop-cue-halo{fill:var(--brand-violet);fill-opacity:.2;stroke:var(--brand-violet);stroke-opacity:.68;stroke-width:1.5px;transform-box:fill-box;transform-origin:center;animation:lud-landing-cue-pulse .7s ease-in-out infinite}.code-workspace .luduum-top-event-drop-cue-caret{fill:none;stroke:#fff;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.code-workspace .luduum-top-event-drop-shifted,.code-workspace .luduum-stack-drop-shifted{transition:transform .14s ease-out;will-change:transform}.code-workspace .luduum-landing-slot.blocklyInsertionMarker{pointer-events:none}.code-workspace .luduum-landing-slot.blocklyInsertionMarker>.blocklyPath,.code-workspace .blocklyReplaceable>.blocklyPath{fill:#ffffff94!important;fill-opacity:.92!important;stroke:var(--brand-violet)!important;stroke-width:3px;stroke-dasharray:10 7;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 8px rgba(91,75,216,.45)) drop-shadow(0 6px 14px rgba(91,75,216,.18));transform-box:fill-box;transform-origin:center;animation:lud-landing-slot-pulse .7s ease-in-out infinite}.code-workspace .luduum-landing-slot.blocklyInsertionMarker>.blocklyPathLight,.code-workspace .luduum-landing-slot.blocklyInsertionMarker>.blocklyPathDark{display:none}.code-workspace .luduum-landing-slot.blocklyInsertionMarker>text,.code-workspace .luduum-landing-slot.blocklyInsertionMarker>image,.code-workspace .luduum-landing-slot.blocklyInsertionMarker>.blocklyField,.code-workspace .luduum-landing-slot.blocklyInsertionMarker>.blocklyEditableText{opacity:0}.code-workspace .blocklyHighlightedConnectionPath{stroke:var(--brand-violet)!important;stroke-width:5px;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px rgba(91,75,216,.5))}.code-workspace .luduum-landing-cue{pointer-events:none;opacity:.96;filter:drop-shadow(0 0 8px rgba(91,75,216,.55))}.code-workspace .luduum-landing-cue-halo{fill:var(--brand-violet);fill-opacity:.18;stroke:var(--brand-violet);stroke-opacity:.62;stroke-width:1.5px;transform-box:fill-box;transform-origin:center;animation:lud-landing-cue-pulse .7s ease-in-out infinite}.code-workspace .luduum-landing-cue-caret{fill:none;stroke:#fff;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}@keyframes lud-landing-slot-pulse{0%,to{opacity:.82;transform:scale(1)}50%{opacity:1;transform:scale(1.025)}}@keyframes lud-landing-cue-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}@media(prefers-reduced-motion:reduce){.code-workspace .luduum-top-event-drop-slot-frame,.code-workspace .luduum-top-event-drop-cue-halo,.code-workspace .luduum-top-event-drop-shifted,.code-workspace .luduum-stack-drop-shifted,.code-workspace .luduum-landing-slot.blocklyInsertionMarker>.blocklyPath,.code-workspace .blocklyReplaceable>.blocklyPath,.code-workspace .luduum-landing-cue-halo{animation:none;transition:none}}.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:0 4px;border-radius:999px;background:var(--brand-violet);color:#fff;font-size:10px}.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}.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)}.library-content{display:flex;flex-direction:column;min-width:0;min-height:0;flex:1}.library-toolbar{display:flex;align-items:center;gap:12px;min-width:0;padding:10px 16px}.library-browser{display:flex;flex:1;flex-direction:column;min-width:0;min-height:0}.category-column{display:flex;flex-direction:row;align-items:center;gap:6px;min-width:0;flex:1;padding-bottom:2px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scroll-snap-type:x proximity}.category-column::-webkit-scrollbar{height:6px}.category-column::-webkit-scrollbar-thumb{border-radius:999px;background:var(--border)}.category-button{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto;min-height:32px;padding:0 12px;border:1px solid transparent;border-radius:999px;background:var(--surface-2);color:var(--text-muted);text-align:left;font-size:13px;font-weight:700;white-space:nowrap;scroll-snap-align:start}.category-button:hover{border-color:var(--brand-violet);color:var(--brand-violet)}.category-button.is-active{background:var(--brand-violet);border-color:var(--brand-violet);color:#fff}.search-field{display:flex;align-items:center;gap:8px;flex:0 0 auto;width:min(240px,38%);height:36px;border:1px solid var(--border);border-radius:var(--radius-button);padding:0 12px;background:var(--surface-2);color:var(--text-muted)}.search-field:focus-within{border-color:var(--brand-violet);color:var(--brand-violet)}.search-field input{min-width:0;width:100%;border:0;background:transparent;color:var(--text);outline:0}.asset-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));grid-auto-rows:122px;align-content:start;gap:10px;min-width:0;min-height:0;flex:1;padding:0 16px 16px;overflow-y:auto}.asset-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;flex:1;padding:12px 16px 20px;color:var(--text-muted);text-align:center}.asset-empty p{margin:0;font-size:13px;font-weight:600;max-width:38ch}.asset-tile{position:relative;display:grid;grid-template-rows:82px minmax(24px,auto);justify-items:center;align-content:center;row-gap:6px;min-width:0;padding:0;color:var(--text-muted);font-size:12px;font-weight:700;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform var(--motion-fast) var(--ease-out),color var(--motion-fast) var(--ease-out)}.asset-card{position:relative;display:grid;place-items:center;width:100%;height:82px;box-sizing:border-box;padding:11px 12px;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);transition:box-shadow var(--motion-fast) var(--ease-out),background var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out)}.asset-drag-grip{position:absolute;top:6px;right:6px;color:currentColor;opacity:.42;transition:opacity var(--motion-fast) var(--ease-out)}.asset-tile .asset-label{align-self:start;width:100%;max-width:100%;min-width:0;min-height:2.3em;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;text-align:center;line-height:1.15;overflow-wrap:anywhere;-webkit-hyphens:auto;hyphens:auto}.asset-tile:hover{transform:translateY(-4px);color:var(--brand-violet)}.asset-tile:hover .asset-card{border-color:var(--brand-violet);background:var(--brand-violet-soft);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-tile.is-dragging-source{color:var(--brand-violet);cursor:grabbing;transform:translateY(-2px) scale(.96)}.asset-tile.is-dragging-source .asset-card{border-color:#5b4bd894;background:var(--brand-violet-soft);box-shadow:inset 0 0 0 1px #5b4bd82e,0 10px 22px #5b4bd824;opacity:.76}.app-shell.library-drag-active .resource-panel .asset-tile:not(.is-dragging-source):not(.is-audio){opacity:.72}.library-drag-preview{position:fixed;z-index:58;left:var(--library-drag-left);top:var(--library-drag-top);width:72px;height:72px;display:grid;place-items:center;box-sizing:border-box;padding:0;border:0;background:transparent;color:var(--brand-violet);filter:drop-shadow(0 12px 18px rgba(15,18,48,.2));pointer-events:none;transform:translate3d(-50%,-50%,0) scale(1.06);transition:opacity var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out);will-change:left,top,transform,opacity}.library-drag-preview.is-over-scene{opacity:0;transform:translate3d(-50%,-50%,0) scale(.82)}.library-drag-preview .asset-thumbnail-frame{width:64px;height:64px}.asset-thumbnail-frame{display:grid;place-items:center;width:58px;height:58px;overflow:hidden;line-height:0;pointer-events:none}.asset-thumbnail-frame.is-fallback{color:currentColor}.asset-thumbnail,.asset-icon-fallback{display:block;max-width:100%;max-height:100%}.asset-thumbnail{width:100%;height:100%;object-fit:contain;image-rendering:auto}.app-shell.library-drag-active .resource-panel{box-shadow:-10px 0 28px #0f12301a,inset 1px 0 #5b4bd81f}.asset-tile.is-audio{cursor:default}.asset-tile.is-audio .asset-card{border-style:dashed}.asset-meta{color:var(--text-muted);font-size:10px;font-weight:750}.resource-panel .library-content{display:grid;grid-template-rows:auto minmax(0,1fr);height:100%}.resource-panel .library-toolbar{align-items:stretch;padding:12px;border-bottom:1px solid var(--border)}.resource-panel .search-field{width:100%}.resource-panel .library-browser{display:grid;grid-template-columns:144px minmax(0,1fr);min-width:0;min-height:0}.resource-panel .category-column{flex-direction:column;align-items:stretch;gap:6px;flex:initial;padding:10px 8px;border-right:1px solid var(--border);overflow-x:hidden;overflow-y:auto;scroll-snap-type:none}.resource-panel .category-column::-webkit-scrollbar{width:6px;height:6px}.resource-panel .category-button{justify-content:flex-start;width:100%;min-height:34px;padding:0 9px;border-radius:var(--radius-chip);font-size:12px;line-height:1.15;white-space:normal;scroll-snap-align:none}.resource-panel .category-button span{min-width:0;overflow-wrap:anywhere}.resource-panel .asset-strip{grid-template-columns:repeat(auto-fill,minmax(94px,1fr));grid-auto-rows:118px;gap:10px;min-height:0;padding:12px}.resource-panel .asset-empty{min-height:0;padding:16px}.resource-panel .dock-environment{height:100%;flex-direction:column;align-items:stretch;gap:18px;padding:14px;overflow-x:hidden;overflow-y:auto}.resource-panel .dock-environment-controls{flex-direction:column;gap:14px;width:100%}.resource-panel .dock-environment-controls .environment-preset-grid{grid-template-columns:repeat(2,minmax(0,1fr));min-width:0}.resource-panel .dock-environment-row{flex-direction:column;align-items:stretch;gap:12px}.resource-panel .dock-environment-row .scene-mode-group{min-width:0}.dock-empty-content{display:flex;align-items:center;gap:12px;min-width:0;padding:16px;overflow-x:auto}.dock-section-title{display:block;margin-bottom:8px;color:var(--text-muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.dock-template-grid{display:flex;gap:10px}.dock-template-card{display:flex;flex-direction:column;gap:3px;width:150px;padding:10px;text-align:left;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);cursor:pointer}.dock-template-card:hover,.dock-template-card:focus-visible{border-color:#5b4bd866;outline:none}.dock-template-icon{font-size:22px}.dock-template-label{color:var(--text);font-size:13px;font-weight:800}.dock-template-desc{color:var(--text-muted);font-size:11px;line-height:1.3}.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}.dock-environment{display:flex;align-items:flex-start;gap:20px;min-width:0;padding:16px;overflow-x:auto}.dock-environment-controls{display:flex;align-items:flex-start;gap:18px;min-width:0}.dock-environment-controls .environment-preset-grid{grid-template-columns:repeat(4,minmax(108px,1fr));min-width:460px}.dock-environment-controls .environment-decoration-grid{grid-template-columns:repeat(2,minmax(108px,1fr));min-width:230px}.dock-environment-row{display:flex;align-items:flex-end;gap:14px}.dock-environment-row .scene-mode-group{min-width:150px}.dock-environment-empty{margin:0;align-self:center;color:var(--text-muted);font-size:13px;font-weight:600}.animator-dock{display:flex;flex-direction:column;gap:10px;min-width:0;min-height:0;flex:1;padding:12px 16px 14px;overflow:hidden}.animator-dock.is-empty,.animator-dock-empty{align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;font-weight:700}.animator-header{display:flex;align-items:center;gap:8px;min-width:0}.animator-header{flex:0 0 auto;flex-wrap:wrap;row-gap:6px}.animator-object{display:inline-flex;align-items:center;gap:8px;min-width:120px;max-width:220px;color:var(--text);font-size:13px;font-weight:800}.animator-object span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.animator-clip-select{flex:1 1 220px;min-width:150px}.animator-loop-select{flex:0 0 116px}.animator-view-select{flex:0 0 92px}.animator-zoom-controls{display:inline-flex;align-items:center;flex:0 0 auto;gap:4px;min-width:0}.animator-icon-button{display:grid;place-items:center;flex:0 0 auto;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface-2);color:var(--text)}.animator-zoom-button{width:30px;height:34px}.animator-icon-button:hover:not(:disabled),.animator-icon-button:focus-visible{border-color:#5b4bd880;color:var(--brand-violet);outline:none}.animator-time-readout,.animator-clip-end{flex:0 0 auto;color:var(--text-muted);font-size:12px;font-weight:800;white-space:nowrap}.animator-time-readout{min-width:50px;color:var(--text)}.animator-header-button{flex:0 0 auto}.animator-keyframe-button{margin-left:auto}.animator-window{--animator-track-gap: 5px;--animator-ruler-row-height: 52px;--animator-track-heading-height: 17px;--animator-transform-row-height: 28px;--animator-part-row-height: 30px;display:grid;grid-template-columns:216px minmax(0,1fr);gap:10px;min-width:0;min-height:0;flex:1;align-items:stretch}.animator-property-tree{display:grid;align-content:start;gap:var(--animator-track-gap);min-width:0;overflow-x:hidden;overflow-y:auto;border-right:1px solid var(--border);padding-right:10px;scrollbar-width:thin}.animator-name-field{display:grid;align-content:start;gap:4px;height:var(--animator-ruler-row-height);color:var(--text-muted);font-size:11px;font-weight:750}.animator-property-group-title{display:flex;align-items:center;height:var(--animator-track-heading-height);color:var(--text);font-size:12px;font-weight:900}.animator-property-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;height:var(--animator-transform-row-height);min-height:var(--animator-transform-row-height);padding:0 8px;border-radius:var(--radius-chip);background:transparent;color:var(--text-muted);text-align:left;font-size:12px;font-weight:800}.animator-property-row:hover:not(:disabled),.animator-property-row:focus-visible{background:var(--surface-2);color:var(--brand-violet);outline:none}.animator-property-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.animator-property-row small{color:var(--text-muted);font-size:10px;font-weight:750}.animator-part-row{display:grid;grid-template-columns:minmax(0,1fr) auto 84px;grid-template-areas:"name state actions";align-items:center;gap:6px;height:var(--animator-part-row-height);min-height:var(--animator-part-row-height);padding:3px 6px;border-radius:var(--radius-chip);background:var(--surface-2);color:var(--text-muted);font-size:12px;font-weight:800}.animator-part-row>span{grid-area:name;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.animator-part-row>small{grid-area:state;color:var(--text-muted);font-size:10px;font-weight:800}.animator-part-actions{grid-area:actions;display:grid;grid-template-columns:1fr 1fr;gap:3px}.animator-part-actions button{min-height:20px;padding:0 4px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface);color:var(--text-muted);font-size:10px;font-weight:850}.animator-part-actions button:hover:not(:disabled),.animator-part-actions button:focus-visible{border-color:#5b4bd870;color:var(--brand-violet);outline:none}.animator-dopesheet{display:flex;flex-direction:column;min-width:0;overflow-x:hidden;overflow-y:auto;scrollbar-width:thin}.animator-timeline-canvas{width:100%;min-width:100%}.animator-ruler{position:relative;height:var(--animator-ruler-row-height);padding-top:4px}.animator-ruler input{position:absolute;left:0;right:0;top:3px;width:100%;z-index:2}.animator-ruler-labels{position:absolute;left:0;right:0;bottom:0;height:16px}.animator-ruler-labels span{position:absolute;top:0;transform:translate(-50%);color:var(--text-muted);font-size:10px;font-weight:800;white-space:nowrap}.animator-playhead{position:absolute;top:0;bottom:-180px;width:2px;z-index:1;background:var(--brand-violet);box-shadow:0 0 0 1px #5b4bd82e;pointer-events:none;transform:translate(-1px)}.animator-lanes{display:grid;gap:var(--animator-track-gap);margin-top:var(--animator-track-gap);min-width:0}.animator-lane-spacer{height:var(--animator-track-heading-height)}.animator-lane{display:block}.animator-lane-track{position:relative;height:var(--animator-transform-row-height);border:1px solid var(--border);border-radius:4px;background:linear-gradient(90deg,rgba(91,75,216,.12) 0 1px,transparent 1px) 0 0 / 20% 100%,var(--surface-2)}.animator-lane.is-part .animator-lane-track{height:var(--animator-part-row-height)}.animator-key-dot{position:absolute;top:50%;z-index:2;width:24px;height:24px;padding:0;border:0;background:transparent;cursor:grab;touch-action:none;transform:translate(-50%,-50%)}.animator-key-dot:before{content:"";position:absolute;top:50%;left:50%;width:10px;height:10px;border:2px solid #fff;border-radius:2px;background:var(--brand-violet);box-shadow:0 2px 6px #241e4733;transform:translate(-50%,-50%) rotate(45deg)}.animator-key-dot:hover,.animator-key-dot:focus-visible{outline:none}.animator-key-dot:hover:before,.animator-key-dot:focus-visible:before{background:var(--brand-teal)}.animator-key-dot.is-selected{z-index:4}.animator-key-dot.is-selected:before{background:var(--brand-violet);box-shadow:0 0 0 4px #5b4bd82e,0 5px 14px #241e4738}.animator-part-key.is-open:before{background:var(--brand-teal)}.animator-part-key.is-closed:before{background:var(--text-muted)}.animator-keyframe-popover{position:absolute;bottom:calc(100% + 8px);z-index:8;display:inline-flex;align-items:center;gap:5px;min-height:30px;padding:4px 5px 4px 7px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface);color:var(--text-muted);box-shadow:0 8px 22px #0f123029;font-size:11px;font-weight:800;transform:translate(-50%)}.animator-keyframe-popover input{width:58px;height:22px;min-height:22px;padding:0 4px;border:1px solid var(--border);border-radius:6px;background:var(--surface-2);color:var(--text);font-size:11px;font-weight:800}.animator-keyframe-popover input:focus{border-color:var(--brand-violet);outline:none;box-shadow:0 0 0 2px #5b4bd824}.animator-keyframe-delete{display:grid;place-items:center;width:24px;height:22px;border:1px solid var(--border);border-radius:6px;background:var(--surface-2);color:var(--text-muted)}.animator-keyframe-delete:hover:not(:disabled),.animator-keyframe-delete:focus-visible{border-color:#d2485873;color:var(--danger);outline:none}.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:24px;z-index:30;display:flex;flex-direction:column;align-items:center;gap:8px;transform:translate(-50%);pointer-events:none}.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 12px;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)}.confirm-dialog{width:min(380px,calc(100vw - 48px));border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation);overflow:hidden}.confirm-dialog-header{padding:16px;border-bottom:1px solid var(--border)}.confirm-dialog-header h2{margin:0;font-size:16px;font-weight:700;color:var(--text);line-height:1.3}.confirm-dialog-body{margin:0;padding:14px 16px;font-size:13px;color:var(--text-muted);line-height:1.5}.confirm-dialog-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.confirm-cancel-button{padding:0 14px;min-height:34px;border:1px solid var(--border);border-radius:var(--radius-button);background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--motion-fast) var(--ease-out)}.confirm-cancel-button:hover{background:var(--surface-2)}.confirm-delete-button{padding:0 14px;min-height:34px;border:1px solid transparent;border-radius:var(--radius-button);background:var(--danger);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:opacity var(--motion-fast) var(--ease-out)}.confirm-delete-button:hover{opacity:.88}.confirm-delete-button:focus-visible{outline:2px solid var(--danger);outline-offset:2px}.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}.duplicate-dialog{width:min(440px,calc(100vw - 32px))}.duplicate-dialog-heading{display:grid;gap:2px;min-width:0}.duplicate-dialog-heading h2{margin:0;font-size:18px}.duplicate-dialog-heading p{margin:0;color:var(--text-muted);font-size:12px}.duplicate-dialog-body{display:grid;gap:12px;padding:16px}.dialog-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.dialog-field{display:grid;gap:4px;min-width:0}.dialog-field>span{color:var(--text-muted);font-size:12px;font-weight:700}.dialog-field small{font-weight:600;text-transform:none}.dialog-field input{width:100%;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface);color:var(--text);font-weight:700}.dialog-toggle{display:flex;align-items:center;gap:8px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer}.dialog-hint{margin:0;color:var(--text-muted);font-size:12px}.dialog-error{margin:0;color:var(--danger);font-size:12px;font-weight:700}.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:1536px){.topbar{grid-template-columns:auto minmax(0,1fr) auto;gap:12px}.topbar-center{min-width:0}.scene-title-button,.scene-title-input{max-width:200px}}@media(max-width:1536px){.topbar{gap:8px}.scene-title-button,.scene-title-input{max-width:168px}.topbar-right .topbar-button span{display:none}.topbar-right .topbar-button{min-width:44px;padding:4px}}@media(max-width:1040px){.topbar{padding:0 12px}.topbar-left{gap:8px}.brand-name,.topbar-center .topbar-button span{display:none}.topbar-center .topbar-button{min-width:44px;padding:4px}.play-button{min-width:112px;padding:0 12px}.scene-title-button,.scene-title-input{max-width:132px}}@media(min-width:901px)and (max-width:1500px){.topbar-center{display:none}}@media(max-width:980px){.scene-title-button,.scene-title-input{display:none}}@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 8px}.play-button span,.topbar-button span{display:none}.topbar-right{gap:4px}}@media(max-width:720px){.topbar-button span,.bottom-tab span,.selection-action-button span{display:none}.resource-tab svg{display:none}.topbar{padding:0 8px;gap:8px}.brand-name{display:none}.library-toolbar{padding:8px 10px;gap:8px}.search-field{width:min(160px,40%)}.code-panel,.animator-panel{left:8px;right:8px;width:auto!important;border:1px solid var(--border);border-radius:var(--radius-panel)}.resource-panel{width:min(420px,calc(100vw - 48px))!important}.code-panel-resizer{display:none}.object-inspector{top:auto;left:0;right:0;width:100%;border-left:0;border-top:1px solid var(--border);border-radius:var(--radius-panel) var(--radius-panel) 0 0;box-shadow:0 -6px 24px #0f12301f}.selection-action-bar{gap:4px;padding:5px}.selection-action-button{min-width:36px;padding:0 8px}.help-layout,.walkthrough-steps{grid-template-columns:1fr}.first-run-panel-wrap{top:64px;right:8px;left:48px;width:auto;transform:none}}@media(max-width:760px)and (orientation:portrait){.app-shell:before{content:"";position:fixed;inset:0;z-index:9998;background:radial-gradient(circle at 50% 35%,rgba(91,75,216,.22),transparent 32%),var(--chrome-graphite);pointer-events:all}.app-shell:after{content:"Ruota il telefono";position:fixed;top:50%;left:50%;z-index:9999;width:min(280px,calc(100vw - 48px));padding:18px 20px;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-panel);background:var(--chrome-graphite-raised);color:#fff;box-shadow:0 18px 42px #00000047;font-size:18px;font-weight:800;text-align:center;pointer-events:all}.app-shell.ar-active:before,.app-shell.ar-active:after{content:none;display:none}}@media(orientation:landscape)and (((max-width:940px)and (max-height:520px))or ((any-pointer:coarse)and (max-height:700px))){.app-shell{grid-template-rows:48px minmax(0,1fr)}.topbar{grid-template-columns:auto minmax(0,1fr) auto;height:48px;padding:0 8px;gap:6px}.topbar-left{gap:8px}.topbar-center,.brand-name,.scene-title-button,.scene-title-input,.user-chip-name,.topbar-divider{display:none}.multiplayer-chip,.physics-chip{max-width:118px;min-height:26px;padding:2px 8px;overflow:hidden;text-overflow:ellipsis}.topbar-right{gap:6px}.topbar-button{min-width:36px;min-height:40px;padding:0 4px}.topbar-button span,.play-button span{display:none}.play-button{width:48px;min-width:48px;min-height:44px;padding:0}.play-button svg{width:26px;height:26px}.play-button.is-stop{width:48px;min-width:48px;min-height:44px;padding:0;background:var(--danger);color:#fff;border:0;border-radius:var(--radius-button)}.play-button.is-stop:hover,.play-button.is-stop:active{background:#bf3e4c;color:#fff;border:0}.play-button.is-stop svg{width:20px;height:20px}.user-chip{height:36px;padding:0 6px;gap:2px}.user-chip .icon-button{width:28px;height:28px}.workspace{grid-template-columns:36px minmax(0,1fr)}.left-dock{width:36px}.dock-strip{gap:6px;padding:8px 2px}.dock-button{width:32px;height:32px}.dock-panel{top:6px;left:40px;width:min(220px,calc(100vw - 56px));max-height:calc(100dvh - 112px)}.library-content{position:relative;display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:34px minmax(0,1fr)}.library-toolbar,.library-browser{display:contents}.category-column{flex-direction:row;flex-wrap:nowrap;flex:initial;gap:6px;padding:5px 24px 4px 8px;min-width:0;max-width:100%;border-right:0;border-bottom:1px solid var(--border);overflow-x:auto;overflow-y:hidden;touch-action:pan-x;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:none}.category-column::-webkit-scrollbar{display:none}.library-content:after{content:"";position:absolute;top:0;right:0;width:24px;height:34px;pointer-events:none;z-index:1;background:linear-gradient(to right,rgba(255,255,255,0),var(--surface))}.category-button{flex:0 0 auto;min-height:26px;padding:0 9px;gap:5px;font-size:12px;white-space:nowrap}.category-button span{display:inline}.search-field{display:none}.dock-environment{gap:10px;padding:6px 10px;overflow-x:auto;overflow-y:hidden}.dock-environment-controls{gap:12px}.dock-environment-controls .environment-preset-grid{grid-template-columns:repeat(4,minmax(80px,1fr));min-width:360px}.dock-environment-row{gap:10px}.dock-environment-row .scene-mode-group{min-width:112px}.asset-strip{display:flex;flex-direction:row;grid-auto-rows:initial;align-content:initial;height:56px;gap:8px;padding:4px 8px 0;overflow-x:auto;overflow-y:hidden;touch-action:pan-x;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.asset-tile{flex:0 0 64px;width:64px;height:56px;grid-template-rows:38px 12px;row-gap:2px;padding:0;font-size:11px;touch-action:pan-x}.asset-card{height:38px;padding:5px;border-radius:var(--radius-chip)}.asset-thumbnail-frame{width:26px;height:26px}.asset-icon-fallback{width:18px;height:18px}.asset-tile .asset-label{min-height:0;line-height:1.05;-webkit-line-clamp:1;line-clamp:1}.asset-empty{flex-direction:row;gap:8px;padding:6px 10px}.asset-empty svg{width:18px;height:18px;flex:0 0 auto}.asset-empty p{font-size:12px}.asset-drag-grip{display:none}.dock-empty-content{gap:8px;padding:8px}.scene-hud,.scene-status{bottom:16px}.scene-status{right:12px;gap:8px;padding:6px 9px;font-size:11px}.play-mode-hud{top:8px;max-width:calc(100vw - 176px);gap:6px}.play-status-chip{min-height:28px;padding:6px 10px;font-size:11px}.play-camera-mode-group{max-width:min(360px,calc(100vw - 312px));overflow-x:auto;scrollbar-width:none}.play-camera-mode-group::-webkit-scrollbar{display:none}.play-camera-mode-btn{flex:0 0 auto;height:26px;padding:3px 8px;font-size:11px}.touch-play-controls{position:absolute;inset:0;z-index:17;display:block;pointer-events:none}.touch-look-pad{position:absolute;top:0;right:0;bottom:0;z-index:1;width:62%;cursor:grab;pointer-events:auto;touch-action:none}.touch-look-pad:active{cursor:grabbing}.touch-joystick{position:absolute;left:14px;bottom:16px;z-index:2;width:92px;height:92px;border:1px solid rgba(255,255,255,.44);border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.2),transparent 54%),#1118273d;box-shadow:0 14px 34px #080d1c47,inset 0 0 0 1px #0f172a1f;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);pointer-events:auto;touch-action:none}.touch-joystick-ring{position:absolute;inset:19px;border:1px dashed rgba(255,255,255,.46);border-radius:inherit}.touch-joystick-thumb{position:absolute;top:50%;left:50%;width:38px;height:38px;border:1px solid rgba(255,255,255,.86);border-radius:50%;background:linear-gradient(145deg,#ffffffeb,#d2e2ffc7);box-shadow:0 8px 18px #0f172a3d,inset 0 1px #ffffffd1;transform:translate(calc(-50% + var(--touch-stick-x, 0px)),calc(-50% + var(--touch-stick-y, 0px)));transition:box-shadow var(--motion-fast),background var(--motion-fast)}.touch-joystick.is-active{background:radial-gradient(circle at 50% 50%,rgba(92,80,218,.22),transparent 58%),#1118274d}.touch-joystick.is-active .touch-joystick-thumb{background:linear-gradient(145deg,#fff,#8574ffdb);box-shadow:0 10px 22px #4737cd47,inset 0 1px #ffffffdb}.touch-play-controls.is-disabled .touch-look-pad,.touch-play-controls.is-disabled .touch-joystick{pointer-events:none}.touch-play-controls.is-disabled .touch-joystick{opacity:.48}.touch-zoom-controls{position:absolute;right:14px;bottom:16px;z-index:3;display:flex;flex-direction:column;gap:8px;pointer-events:none}.touch-zoom-button,.touch-jump-button{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid rgba(255,255,255,.44);border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.2),transparent 54%),#1118273d;color:#fff;box-shadow:0 14px 34px #080d1c47,inset 0 0 0 1px #0f172a1f;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);pointer-events:auto;touch-action:manipulation;cursor:pointer}.touch-jump-button{background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.24),transparent 54%),#5a46d257}.touch-zoom-button:active,.touch-jump-button:active{background:radial-gradient(circle at 50% 50%,rgba(92,80,218,.22),transparent 58%),#1118274d}.touch-jump-button:disabled{opacity:.46;cursor:default}.touch-play-controls.is-disabled .touch-zoom-controls{pointer-events:none;opacity:.48}.toast-stack{bottom:16px}.selection-action-bar{max-width:calc(100vw - 56px);gap:2px;padding:4px;border-radius:var(--radius-button)}.selection-action-button span{display:none}.selection-action-button{min-width:36px;height:34px;padding:0 6px}.object-inspector{max-height:calc(100dvh - 156px);overflow-y:auto}.code-panel,.animator-panel{left:0;right:0;top:0!important;bottom:0!important;width:auto!important;max-height:none!important;border-left:0;border-radius:0}.code-panel-resizer,.app-shell.workspace-panel-open .mobile-fullscreen-control{display:none}.code-panel-header,.animator-panel-header,.resource-panel-header{padding:6px 10px;gap:8px}.resource-panel-header{padding-right:56px}.code-context-bar{padding:0}.code-main{grid-template-columns:46px minmax(0,1fr)}.code-category-rail{gap:2px;padding:4px}.code-category-button{justify-content:center;gap:0;min-height:38px;padding:4px 2px}.code-category-button span{display:none}.resource-panel .library-content{display:grid;grid-template-rows:auto minmax(0,1fr)}.resource-panel .library-toolbar{display:flex;gap:8px;padding:8px 10px}.resource-panel .library-browser{display:grid;grid-template-columns:112px minmax(0,1fr);min-height:0}.resource-panel .category-column{flex-direction:column;flex-wrap:nowrap;max-height:none;padding:8px 6px;border-right:1px solid var(--border);border-bottom:0;overflow-x:hidden;overflow-y:auto;touch-action:pan-y}.resource-panel .category-button{min-height:30px;padding:0 7px;font-size:11px}.resource-panel .library-content:after{display:none}.resource-panel .search-field{display:flex;width:100%;height:32px}.resource-panel .asset-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));grid-auto-rows:74px;height:auto;padding:8px 10px;overflow-x:hidden;overflow-y:auto;touch-action:pan-y}.resource-panel .asset-tile{width:auto;height:auto;grid-template-rows:48px 14px}.resource-panel .asset-card{height:48px}.resource-panel .dock-environment{gap:10px;padding:10px;overflow-x:hidden;overflow-y:auto}.resource-panel .dock-environment-controls,.resource-panel .dock-environment-row{flex-direction:column;align-items:stretch}.resource-panel .dock-environment-controls .environment-preset-grid{grid-template-columns:repeat(2,minmax(0,1fr));min-width:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:0ms!important;animation-duration:0ms!important;scroll-behavior:auto!important}}.topbar-divider{width:1px;height:20px;margin:0 4px;background:var(--chrome-graphite-border);flex-shrink:0}.user-chip{display:flex;align-items:center;gap:4px;min-width:0;height:36px;padding:0 6px 0 12px;border-radius:999px;background:var(--chrome-graphite-raised);border:1px solid rgba(255,255,255,.34);box-shadow:inset 0 0 0 1px #ffffff0a;color:var(--chrome-text-muted)}.user-chip .icon-button{width:28px;height:28px;color:#ffffffb8}.user-chip .icon-button:hover,.user-chip .icon-button.is-active{background:#ffffff24;color:#fff}.user-chip-name{min-width:0;font-size:12px;font-weight:800;color:#fff;white-space:nowrap;max-width:128px;overflow:hidden;text-overflow:ellipsis;margin-right:4px}@media(max-width:1535px){.user-chip-name{max-width:104px}}@media(max-width:1280px){.user-chip-name{max-width:64px}}@media(max-width:1152px){.user-chip-name{display:none}}.auth-modal{width:min(400px,100%);border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:var(--shadow-elevation);overflow:hidden}.auth-tabs{display:flex;border-bottom:1px solid var(--border)}.auth-tab-btn{flex:1;padding:10px 8px;font-size:13px;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.auth-tab-btn:hover{color:var(--text)}.auth-tab-btn.is-active{color:var(--brand-violet, #7c5cbf);border-bottom-color:var(--brand-violet, #7c5cbf)}.auth-body{padding:20px}.auth-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:500;color:var(--text-muted)}.form-input{height:36px;padding:0 10px;font-size:13px;color:var(--text);background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-control);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--brand-violet, #7c5cbf)}.auth-code-input{text-transform:uppercase;letter-spacing:.1em;font-weight:600}.form-error{margin:0;font-size:12px;color:var(--color-danger, #d24858)}.form-submit{margin-top:4px;height:38px;padding:0 16px;font-size:13px;font-weight:600;color:#fff;background:var(--brand-violet, #7c5cbf);border:none;border-radius:var(--radius-control);cursor:pointer;transition:opacity .15s}.form-submit:disabled{opacity:.5;cursor:not-allowed}.form-submit:not(:disabled):hover{opacity:.88}.auth-oauth-section{display:flex;flex-direction:column;gap:10px;margin-top:6px}.auth-oauth-divider{display:flex;align-items:center;gap:10px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.auth-oauth-divider:before,.auth-oauth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-oauth-buttons{display:flex;flex-direction:column;gap:8px}.auth-oauth-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;height:38px;padding:0 14px;font-size:13px;font-weight:500;color:var(--text);background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-control);cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.auth-oauth-button:not(:disabled):hover{background:var(--surface);border-color:var(--brand-violet, #7c5cbf)}.auth-oauth-button:focus-visible{outline:2px solid var(--brand-violet, #7c5cbf);outline-offset:2px}.auth-oauth-button:disabled{opacity:.55;cursor:not-allowed}.auth-oauth-button svg{flex-shrink:0}.auth-oauth-dev-hint{margin:10px 0 0;padding:10px 12px;font-size:11px;line-height:1.5;color:var(--text-muted);background:var(--surface-raised);border:1px dashed var(--border);border-radius:var(--radius-control)}.auth-oauth-dev-hint code{padding:1px 5px;font-size:11px;font-family:var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);background:var(--surface);border:1px solid var(--border);border-radius:3px}.dashboard-modal{width:min(680px,100%);max-height:calc(100dvh - 48px);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}.dashboard-header-info{display:flex;align-items:center;gap:8px;margin-left:auto;margin-right:8px;font-size:12px;color:var(--text-muted)}.role-badge{padding:2px 7px;border-radius:999px;font-size:11px;font-weight:600;background:var(--surface-raised);border:1px solid var(--border);color:var(--text-muted)}.dashboard-body{flex:1;overflow:auto;display:grid;grid-template-columns:1fr 1fr;gap:0}.dashboard-body.student-view{display:block;padding:20px}.text-muted{color:var(--text-muted);font-size:13px;line-height:1.5}.dash-section{padding:16px;border-right:1px solid var(--border);min-height:0;overflow:auto;display:flex;flex-direction:column;gap:8px}.dash-section:last-child{border-right:none}.dash-section-head{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);padding-bottom:6px;border-bottom:1px solid var(--border)}.dash-loading{font-size:12px;color:var(--text-muted);padding:8px 0}.dash-empty{font-size:12px;color:var(--text-muted);line-height:1.5}.dash-empty-state{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:12px;border:1px dashed var(--grid-major);border-radius:var(--radius-chip);background:var(--surface-raised)}.dash-empty-state p{margin:0;font-size:13px;color:var(--text-muted)}.dash-empty-action{display:inline-flex;align-items:center;gap:6px;min-height:34px;font-size:12px}.project-list,.class-list,.roster-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.project-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-control);background:var(--surface-raised)}.project-row-info{flex:1;min-width:0}.project-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-date{font-size:11px;color:var(--text-muted);margin-top:1px}.class-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 8px;border-radius:var(--radius-control);background:var(--surface-raised)}.class-name{font-size:13px;font-weight:500;color:var(--text)}.class-code{display:inline-block;margin-left:6px;padding:1px 6px;font-size:11px;font-weight:600;letter-spacing:.08em;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text-muted)}.roster-section{margin-top:2px}.class-invite-card{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 8px 10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface)}.class-invite-label{font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.class-invite-code{margin-top:3px;font-size:18px;font-weight:800;letter-spacing:.12em;color:var(--brand-violet)}.class-invite-card p{margin:4px 0 0;max-width:460px;font-size:12px;color:var(--text-muted);line-height:1.35}.class-copy-button{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;min-height:32px;font-size:12px}.roster-row{padding:4px 12px;font-size:12px;color:var(--text-muted)}.roster-table-wrap,.assignment-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface)}.roster-table,.assignment-table{width:100%;border-collapse:collapse;min-width:520px}.roster-table th,.roster-table td,.assignment-table th,.assignment-table td{padding:9px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;font-size:12px}.roster-table th,.assignment-table th{background:var(--surface-2);color:var(--text-muted);font-size:10px;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.roster-table tr:last-child td,.assignment-table tr:last-child td{border-bottom:0}.roster-name-cell{font-weight:700;color:var(--text)}.roster-status{display:inline-flex;align-items:center;min-height:22px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;white-space:nowrap}.roster-status--active,.roster-status--success{background:#22a06b1f;color:var(--success-text, #0f7b50)}.roster-status--reset{background:#d9821a21;color:var(--warning)}.roster-actions,.assignment-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}.assignment-room-share{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:8px;padding:8px 10px;border:1px solid rgba(91,75,216,.18);border-radius:var(--radius-chip);background:#5b4bd80f;color:var(--text);font-size:12px}.assignment-room-share div{display:inline-flex;align-items:center;gap:8px;min-width:0}.assignment-room-share code{padding:2px 7px;border-radius:999px;background:var(--surface);color:var(--brand-violet);font-weight:900;letter-spacing:.04em}.roster-action-btn{min-height:28px;font-size:11px}.student-projects-row td{background:var(--surface-2)}.student-projects-loading{padding:8px 10px}.student-project-list{display:grid;gap:6px;margin:0;padding:4px 0;list-style:none}.student-project-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface)}.student-project-title{font-size:12px;font-weight:800;color:var(--text)}.danger-action{color:var(--danger);border-color:#d248583d;background:#d248580f}.danger-action:hover:not(:disabled){border-color:#d2485873;background:#d248581a}.dash-create-form{display:flex;gap:8px;margin-top:4px}.dash-create-form .form-input{flex:1;min-width:0}.assignment-section{margin-top:8px;padding:8px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.assignment-section-head{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px}.assignment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.assignment-row{padding:6px 8px;border-radius:var(--radius-control);background:var(--surface-raised)}.assignment-row-title{font-size:13px;font-weight:500;color:var(--text)}.assignment-row-due{font-size:11px;color:var(--text-muted);margin-top:2px}.assignment-row-instructions{font-size:12px;color:var(--text-muted);margin-top:2px;line-height:1.4}.assignment-student-row{padding:8px 10px;border-radius:var(--radius-control);background:var(--surface-raised);display:flex;flex-direction:column;gap:4px}.assignment-student-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}.assignment-publish-btn{align-self:flex-start;display:flex;align-items:center;gap:6px}.assignment-success{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--success, #22a06b);font-weight:500}.assignment-form{display:flex;flex-direction:column;gap:6px;margin-top:4px}.assignment-form-textarea{resize:vertical;min-height:48px;font-family:inherit}.assignment-form-label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text-muted)}.assignment-form-actions{display:flex;gap:8px;justify-content:flex-end}.assignment-form-warning{font-size:11px;color:var(--danger, #e5484d);line-height:1.4}.home-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;min-height:100dvh;padding:40px 24px;background:linear-gradient(160deg,var(--surface-2) 0%,var(--brand-violet-soft) 100%);overflow-y:auto}.home-hero{display:flex;flex-direction:column;align-items:center;gap:8px}.home-brand{display:flex;align-items:center;gap:10px}.home-brand-mark{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:var(--brand-violet);color:#fff;font-size:26px;font-weight:800;letter-spacing:-1px}.home-brand-name{font-size:28px;font-weight:800;color:var(--brand-deep);letter-spacing:-.5px}.home-auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-panel);box-shadow:var(--shadow-elevation);overflow:hidden}.home-demo-btn{background:none;border:0;color:var(--text-muted);font-size:13px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:4px 8px;border-radius:6px}.home-demo-btn:hover{color:var(--text)}.projects-page{display:grid;grid-template-rows:auto 1fr;height:100dvh;overflow:hidden;background:var(--surface-2)}.projects-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;min-height:56px;padding:8px 20px;background:var(--surface);border-bottom:1px solid var(--border);gap:12px 16px;position:sticky;top:0;z-index:5}.projects-topbar .brand-mark{background:var(--brand-violet);color:#fff;box-shadow:0 2px 8px #5b4bd847}.projects-topbar-right{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:8px}.projects-create-button{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 14px;border-radius:var(--radius-button);background:var(--brand-violet);color:#fff;font-size:13px;font-weight:800;cursor:pointer;box-shadow:var(--shadow-elevation)}.projects-create-button:hover{background:#4739bf}.projects-content{display:flex;flex-direction:column;overflow-y:auto;padding:0}.projects-templates{width:100%;max-width:1280px;margin:0 auto;padding:clamp(16px,3vw,24px) clamp(16px,4vw,28px) 4px}.projects-template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.projects-template-grid .dock-template-card{width:auto;transition:border-color var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.projects-template-grid .dock-template-card:hover:not(:disabled){border-color:#5b4bd866;box-shadow:0 4px 14px #5b4bd81f;transform:translateY(-1px)}.projects-template-grid .dock-template-card:disabled{cursor:default;opacity:.7}.dashboard-page-content{width:100%;max-width:1280px;margin:0 auto;height:auto;overflow:visible}.dashboard-page-content .modal-header{position:sticky;top:0;z-index:4;background:var(--surface);border-bottom:1px solid var(--border)}.landing-page{display:flex;flex-direction:column;min-height:100dvh;overflow-y:auto;background:var(--surface)}.landing-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;min-height:60px;padding:0 28px;background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.landing-nav-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px}.landing-nav-link{padding:8px 14px;border:0;border-radius:var(--radius-button);background:transparent;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:color var(--motion-fast) var(--ease-out)}.landing-nav-link:hover{color:var(--text)}.landing-nav-cta{padding:8px 16px;border:0;border-radius:var(--radius-button);background:var(--brand-violet);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:opacity var(--motion-fast) var(--ease-out)}.landing-nav-cta:hover{opacity:.88}@media(max-width:720px){.landing-nav{align-items:flex-start;height:auto;padding:10px 16px;gap:8px;flex-direction:column}.landing-nav-actions{justify-content:flex-start}}.landing-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:80px 24px 72px;gap:22px;background:linear-gradient(160deg,var(--brand-violet-soft) 0%,var(--surface) 65%)}.landing-headline{margin:0;font-family:Nunito,Inter,sans-serif;font-size:clamp(30px,5vw,52px);font-weight:800;color:var(--brand-deep);line-height:1.15;letter-spacing:-.5px}.landing-sub{margin:0;max-width:560px;font-size:17px;color:var(--text-muted);line-height:1.65}.landing-hero-ctas{display:flex;align-items:center;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px}.landing-cta-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border:0;border-radius:var(--radius-button);background:var(--brand-violet);color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #5b4bd84d;transition:opacity var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.landing-cta-primary:hover{opacity:.88;transform:translateY(-1px)}.landing-cta-student{padding:14px 18px;border:0;border-radius:var(--radius-button);background:transparent;color:var(--text-muted);font-size:15px;font-weight:600;cursor:pointer;transition:color var(--motion-fast) var(--ease-out)}.landing-cta-student:hover{color:var(--brand-violet)}.landing-section{width:100%;max-width:1040px;margin:0 auto;padding:64px 24px}.landing-section--alt{max-width:none;background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.landing-section--alt>*{max-width:680px;margin-left:auto;margin-right:auto}.landing-section-title{margin:0 0 36px;font-family:Nunito,Inter,sans-serif;font-size:26px;font-weight:800;color:var(--brand-deep);text-align:center}.landing-for-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.landing-for-card{display:flex;flex-direction:column;gap:14px;padding:28px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);transition:box-shadow var(--motion-base) var(--ease-out)}.landing-for-card:hover{box-shadow:var(--shadow-elevation)}.landing-for-card h2{margin:0;font-size:18px;font-weight:700;color:var(--text)}.landing-for-card p{margin:0;font-size:14px;color:var(--text-muted);line-height:1.65}.landing-for-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:var(--radius-button);background:var(--brand-violet-soft);color:var(--brand-violet)}.landing-for-icon--student{background:#22a06b1a;color:var(--success)}.landing-for-icon--family{background:#e5484d1a;color:#d14343}.landing-for-icon--personal{background:#1389b01a;color:#1389b0}.landing-for-link{border:0;padding:0;background:transparent;color:var(--brand-violet);font-size:14px;font-weight:600;cursor:pointer;text-align:left;margin-top:auto;transition:opacity var(--motion-fast) var(--ease-out)}.landing-for-link:hover{opacity:.72}.landing-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.landing-step{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--border)}.landing-step:last-child{border-bottom:none}.landing-step-num{flex-shrink:0;width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background:var(--brand-violet);color:#fff;font-size:14px;font-weight:800;font-family:Nunito,Inter,sans-serif}.landing-step-body{display:flex;flex-direction:column;gap:4px;padding-top:5px}.landing-step-body strong{font-size:15px;font-weight:700;color:var(--text)}.landing-step-body span{font-size:14px;color:var(--text-muted);line-height:1.5}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.landing-feature{display:flex;flex-direction:column;gap:10px;padding:20px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);transition:box-shadow var(--motion-base) var(--ease-out)}.landing-feature:hover{box-shadow:0 2px 12px #0f123012}.landing-feature strong{font-size:14px;font-weight:700;color:var(--text)}.landing-feature span{font-size:13px;color:var(--text-muted);line-height:1.5}.landing-feature-icon{display:grid;place-items:center;width:36px;height:36px;border-radius:var(--radius-chip);background:var(--brand-violet-soft);color:var(--brand-violet)}.landing-footer{margin-top:auto;border-top:1px solid var(--border);padding:20px 28px}.landing-footer-inner{max-width:1040px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.landing-demo-link{border:0;padding:6px 12px;border-radius:var(--radius-chip);background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;transition:color var(--motion-fast) var(--ease-out),background var(--motion-fast) var(--ease-out)}.landing-demo-link:hover{color:var(--text);background:var(--surface-2)}.landing-footer-copy{font-size:13px;color:var(--text-muted)}.auth-page{display:flex;flex-direction:column;min-height:100dvh;overflow-y:auto;background:var(--surface-2)}.auth-page-nav{display:flex;align-items:center;padding:16px 24px}.auth-page-back{display:inline-flex;align-items:center;gap:8px;border:0;padding:8px 12px;border-radius:var(--radius-chip);background:transparent;color:var(--text-muted);font-size:14px;font-weight:700;cursor:pointer;transition:color var(--motion-fast) var(--ease-out),background var(--motion-fast) var(--ease-out)}.auth-page-back:hover{color:var(--text);background:var(--surface)}.auth-page-card{width:min(400px,calc(100% - 48px));margin:16px auto 48px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-panel);box-shadow:var(--shadow-elevation);overflow:hidden}.auth-screen-heading{padding:18px 20px 12px;border-bottom:1px solid var(--border);background:var(--surface)}.auth-screen-heading p{margin:0 0 4px;font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.auth-screen-heading h1{margin:0;font-size:18px;line-height:1.25;color:var(--text)}.auth-screen-note{display:block;margin-top:8px;font-size:12px;line-height:1.45;color:var(--text-muted)}.auth-form-intro{margin:0;font-size:12px;line-height:1.45;color:var(--text-muted)}.auth-choice-switch{display:grid;grid-template-columns:1fr;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.auth-choice-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;min-height:62px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-control);background:var(--surface);color:var(--text);text-align:left;cursor:pointer}.auth-choice-card span{font-size:13px;font-weight:800}.auth-choice-card small{font-size:12px;line-height:1.35;color:var(--text-muted)}.auth-choice-card.is-active{border-color:#5b4bd880;background:var(--brand-violet-soft);box-shadow:0 0 0 2px #5b4bd814}.auth-role-picker{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px 64px;text-align:center}.auth-role-subtitle{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-violet, #7c5cbf);margin:0 0 8px}.auth-role-title{font-size:28px;font-weight:800;color:var(--text);margin:0 0 40px;line-height:1.2}.auth-role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;width:min(760px,100%)}@media(max-width:480px){.auth-role-grid{grid-template-columns:1fr}}.auth-role-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-panel);box-shadow:var(--shadow-elevation);cursor:pointer;transition:border-color var(--motion-fast) var(--ease-out),box-shadow var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out);text-align:center}.auth-role-card:hover{border-color:var(--brand-violet, #7c5cbf);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-violet, #7c5cbf) 12%,transparent),var(--shadow-elevation);transform:translateY(-2px)}.auth-role-icon{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center}.auth-role-icon--teacher{background:color-mix(in srgb,var(--brand-violet, #7c5cbf) 12%,transparent);color:var(--brand-violet, #7c5cbf)}.auth-role-icon--student{background:color-mix(in srgb,#22a06b 12%,transparent);color:#22a06b}.auth-role-icon--family{background:color-mix(in srgb,#d14343 12%,transparent);color:#d14343}.auth-role-icon--child{background:color-mix(in srgb,#1389b0 12%,transparent);color:#1389b0}.auth-role-icon--personal{background:color-mix(in srgb,#b7791f 14%,transparent);color:#b7791f}.auth-role-name{font-size:15px;font-weight:700;color:var(--text)}.auth-role-desc{font-size:13px;color:var(--text-muted);line-height:1.5}.dash-page-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:4}.dash-page-welcome{display:flex;flex-direction:column;align-items:flex-start;gap:3px;flex:1;min-width:0}.dash-page-welcome-line{display:flex;align-items:center;gap:8px;min-width:0;max-width:100%}.dash-page-subtitle{font-size:12.5px;color:var(--text-muted);line-height:1.4}.dash-page-greeting{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-page-actions{display:flex;align-items:center;gap:8px}.dash-action-btn{min-height:34px;font-size:13px}.dash-close-btn{flex-shrink:0;margin-left:auto}.project-card{display:flex;flex-direction:column;gap:0;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface);transition:box-shadow var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out),transform var(--motion-fast) var(--ease-out)}.project-card:hover{border-color:var(--brand-violet);box-shadow:0 4px 14px #5b4bd81f;transform:translateY(-1px)}.project-card-row{display:flex;align-items:center;gap:10px}.project-card-error{margin:6px 0 0;padding:0;font-size:12px}.project-card-icon{display:grid;place-items:center;width:32px;height:32px;border-radius:var(--radius-chip);background:var(--brand-violet-soft);color:var(--brand-violet);flex-shrink:0}.project-card-info{flex:1;min-width:0}.project-card-open{flex-shrink:0;min-height:32px;font-size:12px}.project-card-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.project-rename-input{width:100%;min-width:0;font-size:13px;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--brand-violet);border-radius:var(--radius-chip);padding:2px 8px;outline:none;line-height:1.4}.project-rename-input:focus{box-shadow:0 0 0 2px var(--brand-violet-soft)}.class-card{border:1px solid var(--border);border-radius:var(--radius-button);background:var(--surface);overflow:hidden;transition:box-shadow var(--motion-fast) var(--ease-out),border-color var(--motion-fast) var(--ease-out)}.class-card:hover{border-color:#5b4bd866;box-shadow:0 4px 14px #5b4bd81a}.class-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px}.class-card-identity{display:flex;align-items:center;gap:8px;min-width:0}.class-code-chip{display:inline-block;padding:2px 7px;font-size:11px;font-weight:700;letter-spacing:.1em;background:var(--brand-violet-soft);border:1px solid rgba(91,75,216,.2);border-radius:6px;color:var(--brand-violet);flex-shrink:0}.class-card-btn{flex-shrink:0;min-height:30px;font-size:12px}.class-card-body{border-top:1px solid var(--border);background:var(--surface-2);padding:12px;display:flex;flex-direction:column;gap:10px}.roster-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0;margin-right:6px;vertical-align:middle}.roster-dot--offline{background:var(--text-muted);opacity:.45}.dash-empty-hint{font-size:12px;color:var(--text-muted);line-height:1.5}.student-assignments-section{border-right:none!important;max-width:680px}.student-assignment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.student-assignment-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);transition:box-shadow var(--motion-fast) var(--ease-out)}.student-assignment-card:hover{box-shadow:0 2px 10px #0f123012}.student-assignment-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.status-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700;flex-shrink:0}.status-badge--submitted{background:#5b4bd81a;color:var(--brand-violet)}.status-badge--reviewed{background:#22a06b1f;color:var(--success-text)}.status-badge--needs-changes{background:#d9821a1f;color:var(--warning)}.submission-review-feedback{display:flex;align-items:flex-start;gap:6px;margin-top:2px;padding:7px 9px;border-radius:var(--radius-chip);background:var(--surface-2);font-size:12px;color:var(--text-muted);line-height:1.5}.submission-review-feedback svg{flex-shrink:0;margin-top:1px}.assignment-row-due{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);margin-top:2px}.landing-room-join{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:6px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:0 8px 24px #0f123014}.landing-room-join input,.projects-room-join input{width:132px;min-width:0;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font:inherit;font-weight:700;letter-spacing:0;text-transform:uppercase}.landing-room-join input{height:36px;padding:0 10px}.landing-room-button{height:36px;border:none;border-radius:6px;background:var(--brand-violet);color:#fff;padding:0 14px;font-weight:800;cursor:pointer}.projects-room-join{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 6px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface);color:var(--text-muted)}.projects-room-join input{height:24px;width:150px;padding:0 8px;text-transform:none}.projects-room-join input::placeholder{font-weight:600;letter-spacing:0;text-transform:none}.projects-room-join button{height:24px;border:none;border-radius:5px;background:var(--surface-2);color:var(--brand-violet);font-weight:800;padding:0 8px;cursor:pointer}.project-share-panel{position:fixed;z-index:31;top:64px;right:16px;display:grid;gap:12px;width:min(380px,calc(100vw - 32px));padding:14px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:0 18px 48px #0f123033}.project-share-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.project-share-header h2{margin:0;color:var(--text);font-size:18px;line-height:1.15}.project-share-eyebrow{display:block;margin-bottom:2px;color:var(--text-muted);font-size:10px;font-weight:850;letter-spacing:0;text-transform:uppercase}.project-share-state{min-height:148px;display:grid;place-items:center;color:var(--text-muted);font-size:13px;font-weight:750}.project-share-ready{display:grid;justify-items:center;gap:10px}.project-share-qr{display:grid;place-items:center;width:166px;height:166px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.project-share-copy-row{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:8px;width:100%}.project-share-copy-row input{min-width:0;min-height:34px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface-2);color:var(--text);font-size:12px;font-weight:650}.project-share-meta{color:var(--text-muted);font-size:11px;font-weight:700}.project-share-room-code{display:grid;justify-items:center;gap:2px}.project-share-room-code span{color:var(--text-muted);font-size:10px;font-weight:850;letter-spacing:0;text-transform:uppercase}.project-share-room-code strong{color:var(--brand-violet);font-size:26px;line-height:1;letter-spacing:0}.project-share-room-ready .play-room-classroom-controls{width:100%;max-width:none}.project-share-empty{min-height:148px;display:grid;place-items:center;align-content:center;gap:8px;padding:12px;border:1px dashed var(--border);border-radius:8px;background:var(--surface-2);text-align:center}.project-share-empty svg{color:var(--brand-violet)}.project-share-empty strong{color:var(--text);font-size:14px}.project-share-empty span{max-width:260px;color:var(--text-muted);font-size:12px;font-weight:650;line-height:1.35}.project-share-error{margin:0;color:var(--danger);font-size:12px;font-weight:750}.project-share-actions{display:flex;flex-wrap:wrap;gap:8px}.project-share-actions .primary-panel-button,.project-share-actions .secondary-panel-button{min-height:34px;padding:0 12px;font-size:12px}.project-share-actions .danger{color:var(--danger)}.play-room-classroom-controls{display:grid;gap:8px;min-width:230px;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.play-room-classroom-controls.is-compact{min-width:220px;max-width:260px;padding:8px}.play-room-classroom-head{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--text-muted);font-size:12px;font-weight:800}.play-room-classroom-head span{display:inline-flex;align-items:center;gap:5px}.play-room-freeze-button{justify-content:center;width:100%;min-height:30px;font-size:12px}.play-room-participant-list{display:grid;gap:6px;max-height:170px;margin:0;padding:0;overflow:auto;list-style:none}.play-room-participant-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px;border:1px solid var(--border);border-radius:7px;background:var(--surface-2)}.play-room-participant-name{display:block;max-width:150px;overflow:hidden;color:var(--text);font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.play-room-participant-meta,.play-room-participant-empty,.play-room-classroom-error{font-size:11px;color:var(--text-muted)}.play-room-classroom-error{margin:0;color:var(--danger)}.play-room-page{min-height:100dvh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);background:var(--surface-2);color:var(--text)}.play-room-page--state{display:flex;flex-direction:column}.play-room-topbar{height:58px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 18px;border-bottom:1px solid var(--border);background:var(--surface)}.play-room-meta{display:inline-flex;align-items:center;gap:10px;min-width:0;color:var(--text-muted);font-size:13px}.play-room-conn{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.play-room-conn--ok{color:#15803d;background:#22a06b1f}.play-room-conn--warn{color:#b45309;background:#d9821a24}.play-room-stage{position:relative;height:calc(100dvh - 58px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}.play-room-stage .scene-stage,.play-room-stage .scene-canvas{height:100%}.play-room-interaction-hint{position:absolute;left:50%;bottom:22px;transform:translate(-50%);z-index:4;padding:8px 12px;border:1px solid rgba(91,75,216,.22);border-radius:999px;background:#fffffff0;box-shadow:0 10px 28px #0f12301f;color:var(--text);font-size:13px;font-weight:700}.play-room-freeze-banner,.play-room-waiting-banner{position:absolute;top:18px;left:50%;z-index:5;transform:translate(-50%);padding:8px 14px;border:1px solid rgba(91,75,216,.2);border-radius:999px;background:#fffffff2;box-shadow:0 10px 28px #0f12301f;color:var(--text);font-size:13px;font-weight:800}.play-room-classroom-overlay{position:absolute;z-index:5;top:16px;right:16px;width:min(280px,calc(100vw - 32px))}.play-room-state,.play-room-card{margin:auto}.play-room-card{width:min(420px,calc(100vw - 32px));padding:22px;border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface);box-shadow:0 16px 40px #0f123017}.play-room-card h1{margin:0 0 8px;font-size:22px}.play-room-card p{margin:0 0 16px;color:var(--text-muted)}@media(max-width:760px){.landing-room-join,.projects-room-join,.project-share-panel{align-items:stretch;flex-direction:column}.landing-room-join,.projects-room-join,.landing-room-join input,.landing-room-button,.projects-room-join input,.projects-room-join button{width:100%}.project-share-panel{left:12px;right:12px;width:auto}.play-room-classroom-overlay{top:12px;right:12px;left:12px;width:auto;z-index:20}}@media(orientation:landscape)and (((max-width:940px)and (max-height:520px))or ((any-pointer:coarse)and (max-height:700px))){.mobile-fullscreen-control{display:flex}}.ar-entry{display:none;align-items:center;gap:5px;height:32px;padding:0 12px;border-radius:var(--radius-button);background:var(--brand-violet);color:var(--surface);border:1px solid transparent;box-shadow:var(--shadow-elevation);font-size:12px;font-weight:700;white-space:nowrap;cursor:pointer;pointer-events:all;transition:background var(--motion-fast),color var(--motion-fast)}.ar-entry.is-unavailable{background:var(--surface);color:var(--text-muted);border-color:var(--border)}.ar-viewer{position:fixed;inset:0;z-index:9990;display:flex;flex-direction:column;background:var(--surface);color:var(--text)}.ar-viewer[data-ar-session-active=true]{background:transparent;pointer-events:none}.ar-viewer-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border)}.ar-viewer[data-ar-session-active=true] .ar-viewer-header{pointer-events:auto;border-bottom:0;background:linear-gradient(180deg,#17171db8,#17171d00)}.ar-viewer-title{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700}.ar-viewer-exit{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-button);background:var(--surface-inset);color:var(--text);border:1px solid var(--border);cursor:pointer}.ar-viewer-body{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}.ar-viewer[data-ar-session-active=true] .ar-viewer-body{align-items:flex-end;justify-content:center;padding:0 16px max(18px,env(safe-area-inset-bottom));overflow:hidden;pointer-events:none}.ar-viewer-state{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:460px;text-align:center}.ar-viewer[data-ar-session-active=true] .ar-viewer-state{width:100%;max-width:none;min-height:100%;justify-content:flex-end;pointer-events:none}.ar-viewer-stage{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:var(--surface-inset);color:var(--brand-violet);border:1px solid var(--border)}.ar-viewer-stage.is-muted{color:var(--text-muted)}.ar-viewer-stage.is-error{color:var(--danger, #d24858)}.ar-viewer[data-ar-session-active=true] .ar-viewer-stage{display:none}.ar-viewer-heading{margin:0;font-size:18px;font-weight:700}.ar-viewer-copy{margin:0;color:var(--text-muted);font-size:14px;line-height:1.5}.ar-viewer-tips{margin:0;padding-left:18px;text-align:left;color:var(--text-muted);font-size:13px;line-height:1.6}.ar-viewer-notices{display:flex;flex-direction:column;gap:8px;width:100%;text-align:left}.ar-viewer-notice{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:var(--radius-button);background:var(--surface-inset);border:1px solid var(--border);color:var(--text);font-size:13px;line-height:1.45}.ar-viewer-notice.is-warning,.ar-viewer-notice.is-budget.is-warn{border-color:var(--warning, #d8a200)}.ar-viewer-notice.is-budget.is-block{border-color:var(--danger, #d24858)}.ar-viewer-notice svg{flex:0 0 auto;margin-top:1px}.ar-viewer-launcher{display:flex;flex-direction:column;gap:10px;width:100%;align-items:center}.ar-viewer-actions,.ar-viewer-session-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.ar-viewer[data-ar-session-active=true] .ar-viewer-session-controls{pointer-events:auto;padding:10px;border-radius:8px;background:#17171db8;border:1px solid rgba(255,255,255,.18)}.ar-viewer-primary{height:40px;padding:0 18px;border-radius:var(--radius-button);background:var(--brand-violet);color:var(--surface);border:1px solid transparent;font-weight:700;cursor:pointer}.ar-viewer-secondary{height:40px;padding:0 18px;border-radius:var(--radius-button);background:var(--surface);color:var(--text);border:1px solid var(--border);font-weight:600;cursor:pointer}@media(orientation:landscape)and (((max-width:940px)and (max-height:520px))or ((any-pointer:coarse)and (max-height:700px))){.ar-entry{display:inline-flex}}@media(prefers-reduced-motion:reduce){.ar-entry,.ar-viewer-exit,.ar-viewer-primary,.ar-viewer-secondary{transition:none}}.blocklyDropDownContent:has(.luduum-object-picker){max-height:min(72vh,540px);overflow:hidden}.luduum-object-picker{--lud-picker-rows: 7;--lud-picker-row-h: 1.85em;--lud-picker-row-gap: 2px;display:flex;flex-direction:column;gap:7px;width:218px;max-width:78vw;padding:8px;box-sizing:border-box}.luduum-object-picker-scene{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:7px 10px;border:none;border-radius:var(--radius-chip);background:var(--brand-violet);color:#fff;font:inherit;font-weight:600;cursor:pointer;box-shadow:0 2px 6px #5b4bd847;transition:filter .15s ease,box-shadow .15s ease,transform .05s ease}.luduum-object-picker-scene:hover{filter:brightness(1.06);box-shadow:0 3px 10px #5b4bd857}.luduum-object-picker-scene:active{transform:translateY(1px);box-shadow:0 1px 4px #5b4bd847}.luduum-object-picker-search{width:100%;padding:6px 9px;border:1px solid var(--border);border-radius:var(--radius-chip);background:var(--surface-2);color:var(--text);font:inherit;box-sizing:border-box;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.luduum-object-picker-search::placeholder{color:var(--text-muted)}.luduum-object-picker-search:focus{outline:none;background:var(--surface);border-color:var(--brand-violet);box-shadow:0 0 0 3px #5b4bd82e}.luduum-object-picker-list{display:flex;flex-direction:column;gap:var(--lud-picker-row-gap);box-sizing:border-box;max-height:calc(var(--lud-picker-rows) * var(--lud-picker-row-h) + (var(--lud-picker-rows) - 1) * var(--lud-picker-row-gap));overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:#a6abc2 transparent}.luduum-object-picker-list::-webkit-scrollbar{width:10px}.luduum-object-picker-list::-webkit-scrollbar-track{background:transparent}.luduum-object-picker-list::-webkit-scrollbar-thumb{background:#a6abc2;border-radius:999px;border:2px solid transparent;background-clip:padding-box;min-height:28px}.luduum-object-picker-list::-webkit-scrollbar-thumb:hover{background:var(--brand-violet);background-clip:padding-box}.luduum-object-picker-item{flex:0 0 var(--lud-picker-row-h);display:block;width:100%;height:var(--lud-picker-row-h);line-height:var(--lud-picker-row-h);text-align:left;padding:0 10px;border:none;border-radius:var(--radius-chip);background:transparent;color:var(--text);font:inherit;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .12s ease,color .12s ease}.luduum-object-picker-item:hover{background:var(--surface-2)}.luduum-object-picker-item.is-selected{background:var(--brand-violet);color:#fff;font-weight:600}.luduum-object-picker-item.is-selected:hover{background:var(--brand-violet);filter:brightness(1.04)}.luduum-object-picker-empty{padding:14px 9px;color:var(--text-muted);font:inherit;text-align:center}@media(orientation:landscape)and (((max-width:940px)and (max-height:520px))or ((any-pointer:coarse)and (max-height:700px))){.luduum-object-picker{--lud-picker-rows: 5;--lud-picker-row-h: 1.75em;width:202px;padding:7px}}.code-panel.is-picking{transform:translate(calc(100% - 14px));opacity:.35;pointer-events:none;transition:transform var(--motion-base) cubic-bezier(.2,.8,.2,1),opacity var(--motion-base) cubic-bezier(.2,.8,.2,1)}.object-pick-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:40;display:flex;align-items:center;gap:12px;padding:8px 8px 8px 16px;border-radius:999px;background:var(--brand-deep);color:#fff;box-shadow:0 6px 24px #0f12302e}.object-pick-banner-text{font-weight:600}.object-pick-banner-cancel{border:none;border-radius:999px;padding:6px 14px;background:#ffffff29;color:#fff;font:inherit;font-weight:600;cursor:pointer}.object-pick-banner-cancel:hover{background:#ffffff47}@media(prefers-reduced-motion:reduce){.code-panel.is-picking{transition:none}}@media(max-width:940px)and (max-height:520px)and (orientation:landscape){.code-panel.is-picking{transform:translate(100%);opacity:0}}@media(max-width:920px){.dashboard-body{grid-template-columns:1fr}.dash-section{border-right:none;border-bottom:1px solid var(--border)}.dash-section:last-child{border-bottom:none}}@media(max-width:920px){.roster-table-wrap,.assignment-table-wrap{overflow-x:auto}}@media(max-width:760px){.projects-room-join{flex-direction:row;width:100%}.projects-room-join input{flex:1;width:auto;min-width:0}.projects-room-join button{width:auto;flex-shrink:0}}@media(max-width:560px){.projects-topbar{padding:8px 14px}.projects-topbar-right{width:100%;justify-content:flex-end}.projects-create-button{flex:1;justify-content:center}.projects-templates{padding-left:clamp(14px,4vw,20px);padding-right:clamp(14px,4vw,20px)}.dash-page-header{padding:14px 16px}.dash-section{padding:14px}}
