:root{--font-family: "Segoe UI", sans-serif;--bg-gradient-end: #000000;--bg-gradient-start: #000000;--canvas-bg: #000000;--text-color: #d5e3ff;--text-bright: #e8f1ff;--text-muted: #a0b4d0;--text-secondary: var(--text-muted);--text-dim: var(--text-muted);--accent-primary: #40e0d0;--accent-secondary: #f0a830;--accent-success: #4de88a;--accent-danger: #ff5c5c;--panel-bg: rgba(5, 9, 16, .95);--panel-bg-hover: rgba(12, 18, 28, .82);--panel-border: rgba(255, 255, 255, .08);--border-color: var(--panel-border);--accent: var(--accent-primary);--section-bg: rgba(255, 255, 255, .03);--section-border: rgba(255, 255, 255, .05);--section-params-bg: rgba(0, 0, 0, .15);--input-bg: #0a1420;--input-border: rgba(255, 255, 255, .15);--btn-bg: rgba(255, 255, 255, .08);--btn-border: rgba(255, 255, 255, .15);--btn-hover-bg: rgba(255, 255, 255, .12);--btn-primary-bg: rgba(64, 224, 208, .18);--btn-primary-hover: rgba(64, 224, 208, .28);--modal-bg: rgba(10, 20, 35, .98);--rocket-scale: 1;--border-radius: 6px;--border-radius-lg: 10px;--slider-rocket: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><g transform='rotate(90 32 32)'><path d='M32 4C32 4 18 18 18 38C18 42 19.5 45.5 21 48L24 52H40L43 48C44.5 45.5 46 42 46 38C46 18 32 4 32 4Z' fill='%23d5e3ff' opacity='0.45' stroke='%23d5e3ff' stroke-width='1.5'/><path d='M26 52V58C26 58 28 60 32 60C36 60 38 58 38 58V52' fill='%2340e0d0' opacity='0.7' stroke='%2340e0d0' stroke-width='1'/><ellipse cx='32' cy='28' rx='5' ry='6' fill='white' opacity='0.35'/><path d='M18 36L7 47L19 44Z' fill='%23d5e3ff' opacity='0.25'/><path d='M46 36L57 47L45 44Z' fill='%23d5e3ff' opacity='0.25'/></g></svg>");--scrollbar-thumb: rgba(255, 255, 255, .12);--scrollbar-thumb-hover: rgba(255, 255, 255, .25);--overlay-bg: rgba(0, 0, 0, .4);--overlay-medium: rgba(0, 0, 0, .6);--overlay-heavy: rgba(0, 0, 0, .7);--fill-ghost: rgba(255, 255, 255, .02);--fill-faint: rgba(255, 255, 255, .03);--fill-subtle: rgba(255, 255, 255, .05);--fill-muted: rgba(255, 255, 255, .06);--fill-soft: rgba(255, 255, 255, .08);--fill-visible: rgba(255, 255, 255, .1);--border-faint: rgba(255, 255, 255, .06);--border-subtle: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .15);--border-strong: rgba(255, 255, 255, .25);--text-ghost: rgba(255, 255, 255, .35);--text-subtle: rgba(255, 255, 255, .5);--text-semi: rgba(255, 255, 255, .7);--text-strong: rgba(255, 255, 255, .8);--text-white: #fff;--shadow-color: rgba(0, 0, 0, .5);--shadow-heavy: rgba(0, 0, 0, .7);--shadow-light: rgba(0, 0, 0, .4);--shadow-sm: 0 4px 16px var(--shadow-light);--shadow-md: 0 8px 32px var(--shadow-color);--shadow-lg: 0 20px 60px var(--shadow-heavy), 0 0 30px var(--glow-accent-soft);--shadow-glow: 0 0 6px var(--glow-accent);--danger-bg: rgba(255, 107, 107, .15);--danger-bg-hover: rgba(255, 107, 107, .25);--danger-text: rgba(255, 100, 100, .4);--danger-text-hover: rgba(255, 100, 100, .8);--danger-border: rgba(255, 100, 100, .15);--danger-border-hover: rgba(255, 100, 100, .3);--glow-accent: rgba(64, 224, 208, .5);--glow-accent-soft: rgba(64, 224, 208, .15);--glow-accent-border: rgba(64, 224, 208, .3);--glow-accent-intense: rgba(64, 224, 208, .6);--glow-playback: rgba(127, 196, 255, .3);--slide-tab-bg: rgba(20, 20, 30, .85);--slide-tab-hover-bg: rgba(30, 30, 50, .95);--slide-panel-bg: rgba(20, 20, 30, .92);--gravity-tab-color: rgba(255, 120, 120, .7);--gravity-tab-hover: #ff8888;--gravity-tab-border: rgba(255, 100, 100, .25);--gravity-on-color: #00ff88;--gravity-on-border: rgba(0, 255, 136, .3);--gravity-on-hover: #33ffaa;--perf-tab-color: rgba(100, 180, 255, .7);--perf-tab-hover: #88ccff;--perf-tab-border: rgba(100, 180, 255, .25);--zone-ok: rgba(76, 175, 80, .9);--zone-warn: rgba(255, 152, 0, .9);--zone-crit: rgba(244, 67, 54, .9);--zone-ok-fill: rgba(76, 175, 80, .7);--zone-warn-fill: rgba(255, 152, 0, .7);--zone-crit-fill: rgba(244, 67, 54, .7);--orbit-p2: #aa66ff;--orbit-p3: #88ff44;--orbit-p4: #ffd166;--panel-m-color: rgb(190, 190, 195)}body.light-mode{--bg-gradient-start: #c0c6d0;--bg-gradient-end: #cdd3db;--canvas-bg: #bec4ce;--text-color: #2d3748;--text-bright: #1a202c;--text-muted: #4a5568;--accent-primary: #2070cc;--accent-secondary: #18a060;--accent-success: #28955a;--accent-danger: #d03030;--panel-bg: rgba(220, 225, 232, .95);--panel-bg-hover: rgba(210, 215, 222, .9);--panel-border: rgba(0, 0, 0, .12);--border-color: var(--panel-border);--accent: var(--accent-primary);--section-bg: rgba(0, 0, 0, .03);--section-border: rgba(0, 0, 0, .08);--section-params-bg: rgba(0, 0, 0, .04);--input-bg: #d8dde5;--input-border: rgba(0, 0, 0, .2);--btn-bg: rgba(0, 0, 0, .05);--btn-border: rgba(0, 0, 0, .15);--btn-hover-bg: rgba(0, 0, 0, .08);--btn-primary-bg: rgba(32, 112, 204, .14);--btn-primary-hover: rgba(32, 112, 204, .22);--modal-bg: rgba(220, 225, 232, .98);--slider-rocket: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><g transform='rotate(90 32 32)'><path d='M32 4C32 4 18 18 18 38C18 42 19.5 45.5 21 48L24 52H40L43 48C44.5 45.5 46 42 46 38C46 18 32 4 32 4Z' fill='%232d3748' opacity='0.45' stroke='%232d3748' stroke-width='1.5'/><path d='M26 52V58C26 58 28 60 32 60C36 60 38 58 38 58V52' fill='%232070cc' opacity='0.7' stroke='%232070cc' stroke-width='1'/><ellipse cx='32' cy='28' rx='5' ry='6' fill='white' opacity='0.35'/><path d='M18 36L7 47L19 44Z' fill='%232d3748' opacity='0.25'/><path d='M46 36L57 47L45 44Z' fill='%232d3748' opacity='0.25'/></g></svg>");--scrollbar-thumb: rgba(0, 0, 0, .15);--scrollbar-thumb-hover: rgba(0, 0, 0, .3);--fill-ghost: rgba(0, 0, 0, .02);--fill-faint: rgba(0, 0, 0, .03);--fill-subtle: rgba(0, 0, 0, .05);--fill-muted: rgba(0, 0, 0, .06);--fill-soft: rgba(0, 0, 0, .08);--fill-visible: rgba(0, 0, 0, .1);--border-faint: rgba(0, 0, 0, .06);--border-subtle: rgba(0, 0, 0, .1);--border-medium: rgba(0, 0, 0, .15);--border-strong: rgba(0, 0, 0, .25);--text-ghost: rgba(0, 0, 0, .45);--text-subtle: rgba(0, 0, 0, .6);--text-semi: rgba(0, 0, 0, .75);--text-strong: rgba(0, 0, 0, .8);--text-white: #1a202c;--glow-accent: rgba(32, 112, 204, .5);--glow-accent-soft: rgba(32, 112, 204, .15);--glow-accent-border: rgba(32, 112, 204, .3);--glow-accent-intense: rgba(32, 112, 204, .6);--glow-playback: rgba(32, 112, 204, .3);--slide-tab-bg: rgba(255, 255, 255, .85);--slide-tab-hover-bg: rgba(255, 255, 255, .95);--slide-panel-bg: rgba(255, 255, 255, .92);--danger-bg: rgba(208, 48, 48, .12);--danger-bg-hover: rgba(208, 48, 48, .2);--danger-text: rgba(208, 48, 48, .5);--danger-text-hover: rgba(208, 48, 48, .8);--danger-border: rgba(208, 48, 48, .15);--danger-border-hover: rgba(208, 48, 48, .3);--panel-m-color: #4a5568}:root{--app-viewport-width: 100vw;--app-viewport-height: 100dvh;--app-safe-top: env(safe-area-inset-top, 0px);--app-safe-right: env(safe-area-inset-right, 0px);--app-safe-bottom: env(safe-area-inset-bottom, 0px);--app-safe-left: env(safe-area-inset-left, 0px)}*{box-sizing:border-box}button:focus,button:focus-visible,[role=button]:focus,[role=button]:focus-visible,[tabindex]:focus,[tabindex]:focus-visible,input:focus,select:focus,textarea:focus,a:focus,a:focus-visible{outline:none}html{width:100%;height:100%;height:-webkit-fill-available;touch-action:manipulation}body,html{margin:0;padding:0;overflow:hidden;overscroll-behavior:none;background-color:var(--canvas-bg);background-image:radial-gradient(circle at 20% 20%,var(--bg-gradient-start),var(--bg-gradient-end) 55%);background-repeat:no-repeat;background-size:cover;font-family:var(--font-family);color:var(--text-color);-webkit-user-select:none;user-select:none}body{width:100%;min-height:100%;min-height:-webkit-fill-available;min-height:100dvh;touch-action:manipulation}#canvas{position:fixed;inset:0;width:100%;height:100%;background:var(--canvas-bg);touch-action:none}button,[role=button],input,select,textarea,a,label,#welcomeOverlay{touch-action:manipulation}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}a{color:var(--accent-primary);text-decoration:none}body.light-mode .welcome-divider{opacity:.7;color:var(--text-color)}body.light-mode .welcome-launch-btn,body.light-mode .welcome-launch-btn .launch-text{color:var(--text-color)}body.light-mode .rocket-icon [fill=currentColor]{opacity:.35}html.skip-welcome #welcomeOverlay{display:none!important}#welcomeOverlay{position:fixed;inset:0;width:100%;min-height:100%;min-height:100dvh;z-index:200;display:grid;place-items:center;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable both-edges;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--overlay-bg);overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}#welcomeOverlay.launching{pointer-events:none;overflow-x:hidden}#welcomeOverlay.fade-out{transition:backdrop-filter .8s ease,-webkit-backdrop-filter .8s ease,background .8s ease,opacity .4s ease .4s;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);background:transparent;opacity:0}#welcomeOverlay.returning{transition:backdrop-filter .6s ease,-webkit-backdrop-filter .6s ease,background .6s ease,opacity .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--overlay-bg);opacity:1}.welcome-center{position:relative;width:min(100%,760px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(14px,2.2vh,24px);min-height:min(100dvh,980px);padding:clamp(20px,4vh,48px) 16px;box-sizing:border-box;flex-shrink:0;margin:0 auto}.welcome-content{display:flex;flex-direction:column;align-items:center;gap:clamp(8px,1.5vw,16px);width:100%}.welcome-logo-slot{display:flex;align-items:center;justify-content:center;width:100%;min-height:clamp(133px,min(26.4vw,32vh),317px)}.welcome-logo{width:clamp(133px,min(26.4vw,32vh),317px);height:clamp(133px,min(26.4vw,32vh),317px);overflow:visible;flex-shrink:0;perspective:600px}.orbit-ring{transform-origin:300px 300px;transition:transform .8s ease-out}.orbit-ring-1,.orbit-ring-2{stroke:var(--text-color);stroke-opacity:.28;stroke-width:1.5}.orbit-ring-3,.orbit-ring-4{stroke:var(--text-color);stroke-opacity:.22;stroke-width:1}.orbit-inset{pointer-events:none}.welcome-logo:hover .orbit-ring-1{animation:ring-spin-ccw 2.5s ease-in-out}.welcome-logo:hover .orbit-ring-2{animation:ring-spin-cw 2s ease-in-out}.welcome-logo:hover .orbit-ring-3{animation:ring-spin-ccw 1.5s ease-in-out}.welcome-logo:hover .orbit-ring-4{animation:ring-spin-cw 1.2s ease-in-out}@keyframes ring-spin-ccw{0%,to{transform:rotateY(0)}50%{transform:rotateY(-180deg)}}@keyframes ring-spin-cw{0%,to{transform:rotateY(0)}50%{transform:rotateY(180deg)}}.welcome-divider{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:clamp(7px,.9vw,11px);font-weight:300;letter-spacing:clamp(1.5px,.25vw,3px);text-transform:uppercase;color:var(--text-muted);opacity:.45;flex-shrink:0;display:flex;align-items:center;justify-content:center}.orbit-planet{transform-origin:300.232px 300.232px}.orbit-p1{animation:orbit-spin 25s linear infinite}.orbit-p2{animation:orbit-spin 18s linear infinite}.orbit-p3{animation:orbit-spin 12s linear infinite reverse}.orbit-p4{animation:orbit-spin 8s linear infinite}@keyframes orbit-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.orbit-p1>ellipse{fill:var(--accent-primary);stroke:currentColor;stroke-opacity:.15;stroke-width:1}.orbit-p2>ellipse{fill:var(--orbit-p2);stroke:currentColor;stroke-opacity:.15;stroke-width:1}.orbit-p3>ellipse{fill:var(--orbit-p3);stroke:currentColor;stroke-opacity:.15;stroke-width:1}.orbit-p4>ellipse{fill:var(--orbit-p4);stroke:currentColor;stroke-opacity:.15;stroke-width:1}.orbit-moon ellipse,.orbit-submoon ellipse{opacity:.7;stroke:currentColor;stroke-opacity:.1;stroke-width:.5}.moon-of-p1>ellipse{fill:var(--text-white)}.moon-of-p1{transform-origin:75.078px 101.742px;animation:orbit-spin 7s linear infinite reverse}.submoon-of-p1>ellipse{fill:var(--text-white);opacity:.5}.submoon-of-p1{transform-origin:116px 101.742px;animation:orbit-spin 2s linear infinite}.moon-orbit-path,.submoon-orbit-path{fill:none;stroke:var(--text-white);stroke-width:1;stroke-opacity:.15}.orbit-trail-1{opacity:.6}.orbit-trail-2{opacity:.5}.orbit-trail-3{opacity:.4}.orbit-trail-4{opacity:.32}.orbit-trail-5{opacity:.24}.orbit-trail-6{opacity:.18}.orbit-trail-7{opacity:.13}.orbit-trail-8{opacity:.09}.orbit-trail-9{opacity:.05}.orbit-trail-10{opacity:.02}.welcome-text{display:flex;flex-direction:column;align-items:flex-end;gap:clamp(4px,.8vw,12px)}.welcome-text .om-brand{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:clamp(32px,min(6vw,9vh),80px);font-weight:800;letter-spacing:.18em;text-transform:uppercase;transform:scaleY(.75);transform-origin:center;color:#d2d7e180;line-height:.9;margin-right:-.18em;text-shadow:0 0 1px rgba(140,150,170,.6),0 0 6px rgba(150,160,180,.3),0 0 16px rgba(130,140,160,.15)}.welcome-text .om-accent{color:transparent;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;width:1.15em;height:1.15em;padding-top:0;background:transparent;border:.08em solid var(--accent-primary);border-radius:50%;box-shadow:0 0 16px var(--glow-accent-soft)}.welcome-text .om-tagline{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:clamp(8px,min(1vw,1.5vh),12px);font-weight:400;color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:-2px;margin-right:-.15em}.welcome-launch-btn{padding:clamp(6px,.8vw,10px) clamp(10px,1.3vw,16px) clamp(6px,.8vw,10px) clamp(16px,2.2vw,28px);color:var(--text-muted);background:transparent;border:none;border-radius:32px;cursor:pointer;display:none;align-items:center;gap:clamp(6px,1vw,12px);transition:color .3s,transform .3s;position:relative;z-index:2;min-height:48px;visibility:hidden;opacity:0;pointer-events:none}body.authenticated .welcome-launch-btn,body.dev-mode .welcome-launch-btn{display:flex;visibility:visible;opacity:1;pointer-events:auto}.welcome-launch-btn .rocket-icon{width:clamp(36px,min(5.5vw,10vh),70px);height:clamp(36px,min(5.5vw,10vh),70px);transform:rotate(90deg);flex-shrink:0;transition:transform .3s,filter .3s}.welcome-launch-btn .launch-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:clamp(12px,min(2.1vw,3.8vh),26px);font-weight:300;letter-spacing:clamp(3px,.65vw,8px);text-transform:uppercase;color:var(--text-muted);transition:color .3s}@media(max-height:520px){#welcomeOverlay{place-items:start center}.welcome-center{min-height:auto;justify-content:flex-start;gap:10px;padding-top:16px;padding-bottom:12px}.welcome-content{gap:6px}.welcome-logo-slot{min-height:clamp(84px,26vh,160px)}.welcome-logo{width:clamp(84px,26vh,160px);height:clamp(84px,26vh,160px)}.welcome-auth{margin-top:10px;min-height:32px}.welcome-launch-btn{min-height:40px;padding:4px 12px 4px 18px}}.welcome-launch-btn:hover,.welcome-launch-btn:focus{color:var(--accent-primary);transform:scale(1.05);outline:none}.welcome-launch-btn:hover .rocket-icon{filter:drop-shadow(0 0 8px var(--glow-accent-intense));transform:rotate(90deg) scale(1.1)}.welcome-launch-btn:hover .launch-text{color:var(--accent-primary)}.install-btn{position:fixed;top:16px;right:16px;z-index:201;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:20px;color:var(--text-muted);padding:6px 16px;font-family:inherit;font-size:.75rem;font-weight:600;cursor:pointer;transition:color .2s,border-color .2s}.install-btn:hover{color:var(--text-color);border-color:#ffffff4d}.welcome-stats{position:fixed;bottom:12px;right:16px;z-index:201;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.6875rem;font-weight:600;color:var(--accent-primary);letter-spacing:.5px;opacity:.5;display:flex;align-items:center;gap:6px}.clear-cache-btn{background:transparent;border:1px solid currentColor;border-radius:3px;color:inherit;font-size:.8125rem;padding:0 4px;cursor:pointer;pointer-events:auto;opacity:.7;transition:opacity .2s}.clear-cache-btn:hover{opacity:1}.rocket-steam-puff{position:fixed;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.35),rgba(200,200,200,.1),transparent);pointer-events:none;z-index:201;animation:steam-puff 1.2s ease-out forwards;transform:translate(-50%,-50%)}@keyframes steam-puff{0%{opacity:.7;transform:translate(-50%,-50%) scale(.3)}50%{opacity:.4}to{opacity:0;transform:translate(calc(-50% + var(--x-drift)),calc(-50% + var(--y-drift))) scale(var(--end-scale))}}body.boot-pending #panel,body.boot-pending #historyBar,body.boot-pending #bottomHud,body.boot-pending #hud,body.boot-pending .top-right-controls,body.boot-pending #floatingCameraPanel,body.boot-pending #floatingColorSchemePanel,body.boot-pending #floatingMaterialPanel,body.boot-pending #floatingBackgroundPanel,body.boot-pending #floatingPresetsPanel,body.boot-pending #floatingPathPanel,body.welcome-active #panel,body.welcome-active #historyBar,body.welcome-active #bottomHud,body.welcome-active #hud,body.welcome-active .top-right-controls,body.welcome-active #floatingCameraPanel,body.welcome-active #floatingColorSchemePanel,body.welcome-active #floatingMaterialPanel,body.welcome-active #floatingBackgroundPanel,body.welcome-active #floatingPresetsPanel,body.welcome-active #floatingPathPanel{opacity:0;pointer-events:none}body.boot-pending:not(.welcome-shell-ready) #welcomeOverlay{pointer-events:none}body.welcome-active #panel{transform:translate(-60px)}body.welcome-active .top-right-controls{transform:translate(60px)}body.welcome-active #historyBar,body.welcome-active #bottomHud{transform:translate(-50%) translateY(60px)}body.welcome-active #hud{transform:translateY(60px)}body:not(.welcome-active) #panel{opacity:1;transform:translate(0);transition:opacity .5s ease .1s,transform .5s cubic-bezier(.4,0,.2,1) .1s}body:not(.welcome-active) .top-right-controls{opacity:1;transform:translate(0);transition:opacity .5s ease .2s,transform .5s cubic-bezier(.4,0,.2,1) .2s}body:not(.welcome-active) #historyBar{opacity:1;transform:translate(-50%) translateY(0);transition:opacity .5s ease .25s,transform .5s cubic-bezier(.4,0,.2,1) .25s}body:not(.welcome-active) #bottomHud{opacity:1;transform:translate(-50%) translateY(0);transition:opacity .5s ease .25s,transform .5s cubic-bezier(.4,0,.2,1) .25s}body:not(.welcome-active) #hud{opacity:1;transform:translateY(0);transition:opacity .5s ease .35s,transform .5s cubic-bezier(.4,0,.2,1) .35s}.welcome-auth{position:static;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:clamp(20px,3vw,40px);width:100%;min-height:48px}.welcome-auth-loading{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);opacity:.62}.welcome-auth-fallback-title,.welcome-auth-fallback-note{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;text-align:center}.welcome-auth-fallback-title{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);opacity:.78}.welcome-auth-fallback-note{max-width:28rem;font-size:.75rem;line-height:1.45;color:var(--text-muted);opacity:.56}.welcome-reload-btn{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:8px 18px;background:transparent;border:1px solid var(--btn-border);border-radius:999px;color:var(--text-muted);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.8125rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.welcome-reload-btn:hover,.welcome-reload-btn:focus{color:var(--text-bright);border-color:var(--accent-primary);background:var(--btn-hover-bg);outline:none}body.dev-mode .welcome-auth,html.dev-mode .welcome-auth,body.authenticated .welcome-auth .google-signin-btn{display:none}.google-signin-btn{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--btn-bg);border:1px solid var(--btn-border);border-radius:20px;color:var(--text-muted);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}.google-signin-btn:hover{background:var(--btn-hover-bg);color:var(--text-bright);border-color:var(--accent-primary)}.google-signin-btn svg{flex-shrink:0}.auth-viewer-link{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.6875rem;color:var(--text-muted);opacity:.5;text-decoration:none;transition:opacity .2s}.auth-viewer-link:hover{opacity:.8}.auth-user-info{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.8125rem}.auth-avatar{width:24px;height:24px;border-radius:50%;border:1px solid var(--btn-border)}.auth-name{opacity:.7}.user-avatar{display:none;width:32px;height:32px;min-width:32px;min-height:32px;border-radius:50%;overflow:hidden;cursor:pointer;opacity:.7;transition:opacity .2s;align-items:center;justify-content:center;color:var(--text-bright);background:var(--btn-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.75rem;font-weight:600;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover;display:block}.user-avatar:hover{opacity:1}body.signed-in:not(.welcome-active) .user-avatar{display:flex}.user-avatar.has-image{color:transparent}#webgpu-error{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--panel-bg);border:1px solid var(--accent-danger);border-radius:var(--border-radius-lg);padding:24px 32px;text-align:center;z-index:100}#webgpu-error h2{color:var(--accent-danger);margin-bottom:16px}#webgpu-error ul{text-align:left;color:var(--accent-primary)}.webgpu-error-actions{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:18px}.webgpu-error-note{max-width:24rem;font-size:.75rem;line-height:1.45;color:var(--text-muted);opacity:.72}#appUpdatePrompt{position:fixed;left:50%;top:50%;bottom:auto;transform:translate(-50%,-50%);display:none;flex-direction:column;align-items:stretch;gap:16px;width:min(560px,calc(100vw - 32px));max-width:calc(100vw - 32px);padding:22px 22px 20px;border:1px solid var(--btn-border);border-radius:18px;background:color-mix(in srgb,var(--panel-bg) 92%,black 8%);box-shadow:0 24px 72px #00000073;backdrop-filter:blur(16px);z-index:120}.app-update-prompt__body{min-width:0;display:flex;flex-direction:column;gap:6px;text-align:center}.app-update-prompt__title{color:var(--text-bright);font-size:.95rem;font-weight:700;letter-spacing:.02em}.app-update-prompt__text{color:var(--text-muted);font-size:.825rem;line-height:1.45}.app-update-prompt__actions{display:flex;align-items:center;gap:10px;justify-content:center}.app-update-prompt__btn{appearance:none;border:1px solid var(--btn-border);border-radius:12px;padding:10px 14px;min-height:40px;font:inherit;font-size:.8125rem;font-weight:600;letter-spacing:.01em;color:var(--text-bright);background:var(--btn-bg);cursor:pointer;transition:background .18s ease,border-color .18s ease,opacity .18s ease}.app-update-prompt__btn:hover,.app-update-prompt__btn:focus-visible{background:var(--btn-hover);outline:none}.app-update-prompt__btn--primary{background:var(--btn-primary-bg)}.app-update-prompt__btn--primary:hover,.app-update-prompt__btn--primary:focus-visible{background:var(--btn-primary-hover)}#appUpdatePrompt.is-updating .app-update-prompt__btn{cursor:default}#appUpdatePrompt .app-update-prompt__btn:disabled{opacity:.55}@media(max-width:640px){#appUpdatePrompt{left:16px;right:16px;top:50%;transform:translateY(-50%);max-width:none;width:auto;padding:20px 18px 18px}.app-update-prompt__actions{width:100%;justify-content:center;flex-wrap:wrap}}@media(display-mode:standalone){html,body{position:fixed;inset:0;width:100%;height:-webkit-fill-available;min-height:-webkit-fill-available;overflow:hidden;overscroll-behavior:none}#canvas,#welcomeOverlay{inset:0;width:100%;height:100%;min-height:100%}#welcomeOverlay{overflow-y:hidden;overscroll-behavior:none}.top-right-controls{top:calc(16px + var(--app-safe-top));right:calc(16px + var(--app-safe-right))}#panel{left:calc(16px + var(--app-safe-left));top:calc(16px + var(--app-safe-top))}#hud{right:calc(16px + var(--app-safe-right));bottom:calc(12px + var(--app-safe-bottom))}#bottomHud{padding-bottom:0}#appUpdatePrompt{bottom:calc(16px + var(--app-safe-bottom))}}:root{--right-slide-panel-base-width: 280px;--right-rail-tab-width: 28px;--right-rail-total-width: calc(var(--right-rail-tab-width) + var(--right-slide-panel-base-width));--right-rail-viewport-height: calc(var(--app-viewport-height, 100dvh) / var(--ui-zoom, 1));--right-slide-panel-duration: .3s;--right-slide-panel-ease: ease;--right-tab-stack-gap: 8px}body{--right-rail-translate-x: var(--right-slide-panel-base-width)}body.panel-open{--right-rail-translate-x: 0px}#panel,#bottomHud,#hud,.top-right-controls,.object-modal-overlay,.axis-gizmo,#rightRail{zoom:var(--ui-zoom, 1);-webkit-user-select:none;user-select:none}.right-rail{position:fixed;top:0;right:0;width:var(--right-rail-total-width);height:var(--right-rail-viewport-height);display:flex;align-items:stretch;justify-content:flex-start;overflow:hidden;pointer-events:none;z-index:25;transform:translate(var(--right-rail-translate-x));transition:transform var(--right-slide-panel-duration) var(--right-slide-panel-ease)}.right-panels-viewport{position:relative;width:var(--right-slide-panel-base-width);flex:0 0 var(--right-slide-panel-base-width);height:100%;pointer-events:none;overflow:hidden}.tab-stack{position:relative;width:var(--right-rail-tab-width);flex:0 0 var(--right-rail-tab-width);height:100%;display:flex;flex-direction:column;justify-content:center;gap:var(--right-tab-stack-gap);z-index:30;pointer-events:none}.tab-stack>*{pointer-events:auto}.panel-switching .tab-stack,.panel-switching .filter-panel,.panel-switching .pulse-panel,.panel-switching .path-panel,.panel-switching .gravity-panel,.panel-switching .perf-panel,.panel-switching .settings-panel,.panel-switching .links-panel,.panel-switching .scene-panel{transition:none!important}.top-right-controls{position:fixed;top:16px;right:16px;z-index:20;display:flex;align-items:center;gap:4px;pointer-events:auto;transition:opacity .5s ease .2s,transform .5s cubic-bezier(.4,0,.2,1) .2s}.fullscreen-btn{width:32px;height:32px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s ease}.fullscreen-btn.hovered{transform:scale(1.2)}.fullscreen-btn svg{width:20px;height:20px}.orbit-style-bar{display:none;align-items:center;justify-content:center;gap:4px;padding:4px 8px;border-bottom:1px solid var(--section-border)}.orbit-style-bar-hidden{display:none!important}.orbit-style-toggle{width:24px;height:24px;border-radius:50%;border:2px solid transparent;background:var(--btn-primary-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.4;transition:opacity .2s,border-color .2s,color .2s}.orbit-style-toggle svg{width:13px;height:13px}.orbit-style-toggle.active{opacity:1;color:var(--text-bright);border-color:var(--accent-primary)}.orbit-style-toggle:hover{opacity:.8}.orbit-geometry-btn,.orbit-line-style-btn{width:24px;height:24px;border-radius:50%;border:2px solid transparent;background:var(--btn-primary-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;opacity:.7;transition:opacity .2s,border-color .2s,color .2s}.orbit-geometry-btn:hover,.orbit-geometry-btn:focus,.orbit-line-style-btn:hover,.orbit-line-style-btn:focus{opacity:1;color:var(--text-bright);outline:none}.orbit-geometry-btn svg,.orbit-line-style-btn svg{width:13px;height:13px}.orbit-line-freq-btn,.orbit-line-ampy-btn{width:24px;height:24px;border-radius:50%;border:2px solid transparent;background:var(--btn-primary-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.7;transition:opacity .2s,border-color .2s,color .2s;font-size:.6875rem;font-weight:700;font-family:inherit}.orbit-line-freq-btn:hover,.orbit-line-freq-btn:focus,.orbit-line-ampy-btn:hover,.orbit-line-ampy-btn:focus{opacity:1;color:var(--text-bright);outline:none}.orbit-line-ampy-btn .icon-arrow-up{width:13px;height:13px}.orbit-line-ampy-btn .ampy-value:not(:empty)~.icon-arrow-up{display:none}.orbit-line-ampy-btn .ampy-value:empty{display:none}.orbit-line-ampy-btn:has(.ampy-value:not(:empty)){color:var(--text-bright)}.orbit-style-divider{width:1px;height:14px;background:var(--section-border);margin:0 2px}.orbit-style-reset-btn{width:22px;height:22px;background:transparent;border:none;color:#ff9aa3;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:color .2s}.orbit-style-reset-btn:hover,.orbit-style-reset-btn:focus{color:#ffc2c8;outline:none}.orbit-style-reset-btn svg{width:14px;height:14px;display:block}.theme-toggle-btn{width:32px;height:32px;flex-shrink:0;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s ease}.theme-toggle-btn.hovered{transform:scale(1.2)}.theme-toggle-btn svg{width:16px;height:16px}#recordBtn:hover,#recordBtn:focus{color:var(--accent-danger);border-color:var(--accent-danger)}#recordBtn.recording{color:var(--accent-danger);border-color:var(--accent-danger);animation:pulse-record 1s ease-in-out infinite}@keyframes pulse-record{0%,to{opacity:1}50%{opacity:.5}}#floatingCameraPanel{width:220px}.floating-panel-header{font-size:.75rem;font-weight:700;color:var(--text-bright);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:space-between}.floating-panel-header .gamepad-btn{width:28px;height:28px;padding:5px}.icon-buttons-row{display:flex;gap:8px;padding:6px 0;justify-content:flex-start}.icon-btn{width:36px;height:36px;background:var(--btn-bg);border:1px solid var(--btn-border);border-radius:var(--border-radius);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:color .2s,border-color .2s,background .2s}.icon-btn:hover,.icon-btn:focus{color:var(--text-bright);border-color:var(--accent-primary);background:var(--btn-hover-bg);outline:none}.icon-btn.active{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--btn-primary-bg)}.icon-btn svg{width:20px;height:20px}.floating-inline-panel{position:fixed;width:200px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:25;padding:12px;display:none}.floating-inline-panel.visible{display:block}.floating-inline-panel .control{margin-bottom:0}.core-position-panel{width:200px}.core-pos-title{font-size:.6875rem;font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.core-pos-fields{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.core-pos-fields label{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted);font-weight:600}.core-pos-fields input{flex:1;width:0;padding:4px 6px;border:1px solid var(--btn-border);border-radius:var(--border-radius);background:var(--input-bg);color:var(--text-bright);font-size:.75rem;font-family:inherit}.core-pos-fields input:focus{outline:none;border-color:var(--accent-primary)}.core-pos-actions{display:flex;gap:6px}.core-pos-actions button{flex:1;padding:5px 0;border:1px solid var(--btn-border);border-radius:var(--border-radius);background:var(--btn-bg);color:var(--text-bright);font-size:.6875rem;font-weight:600;cursor:pointer}.core-pos-actions button:hover{background:var(--btn-hover)}.core-pos-apply{background:var(--accent-primary)!important;border-color:var(--accent-primary)!important;color:#fff!important}.core-pos-apply:hover{opacity:.85}.orbit-style-picker-panel{width:220px}.orbit-style-picker-title{font-size:.6875rem;font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.orbit-style-picker-grid{display:grid;gap:6px}.orbit-style-group-label{grid-column:1 / -1;font-size:.625rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:2px 2px 0}.orbit-style-picker-grid.icons{grid-template-columns:repeat(4,minmax(0,1fr))}.orbit-style-picker-grid.values{grid-template-columns:repeat(5,minmax(0,1fr))}.orbit-style-option{width:100%;min-height:32px;border:1px solid var(--btn-border);border-radius:var(--border-radius);background:var(--btn-bg);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;font-weight:700;padding:4px;transition:color .2s,border-color .2s,background .2s}.orbit-style-option:hover,.orbit-style-option:focus{color:var(--text-bright);border-color:var(--accent-primary);background:var(--btn-hover-bg);outline:none}.orbit-style-option.selected{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--btn-primary-bg)}.orbit-style-option-icon,.orbit-style-option svg{width:18px;height:18px}.option-list{display:flex;flex-direction:column;gap:2px}.floating-inline-panel:not(#floatingColorSchemePanel):not(#floatingMaterialPanel) .option-list{max-height:300px;overflow-y:auto}#floatingMaterialPanel{top:16px;width:320px;max-height:calc(100vh - 32px);overflow-y:auto}#floatingMaterialPanel .color-scheme-cat-list{display:grid;grid-template-columns:1fr 1fr;gap:2px}#floatingMaterialPanel .color-scheme-cat-list .option-item{width:auto;padding:5px 8px;font-size:.6875rem}.option-item{padding:8px 12px;border-radius:var(--border-radius);cursor:pointer;font-size:.75rem;color:var(--text-color);transition:background .15s,color .15s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:8px}.option-swatches{display:flex;gap:3px;flex-shrink:0}.option-swatch{width:8px;height:8px;border-radius:50%;box-shadow:0 0 0 1px #ffffff26}.option-item:hover{background:var(--btn-hover-bg);color:var(--text-bright)}.option-item.selected,.option-item:focus{background:var(--btn-primary-bg);color:var(--accent-primary);font-weight:600;outline:none}#floatingColorSchemePanel{top:16px;width:280px;max-height:calc(100vh - 32px);overflow-y:auto}.color-scheme-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);margin-bottom:6px;flex-shrink:0}.color-scheme-tab{flex:1;padding:5px 0;font-size:.6875rem;font-weight:600;font-family:inherit;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.color-scheme-tab:hover{color:var(--text-bright)}.color-scheme-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.color-scheme-cat-list{display:flex;flex-wrap:wrap;gap:2px;align-content:flex-start}.color-scheme-cat-list .option-item{width:calc(50% - 1px);padding:4px 6px;font-size:.625rem}.color-scheme-empty{padding:12px;text-align:center;color:var(--text-muted);font-size:.6875rem;width:100%}.color-scheme-del{margin-left:auto;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.875rem;padding:0 4px}.color-scheme-del:hover{color:var(--accent-danger)}.color-scheme-add{width:100%;padding:8px;margin-top:4px;font-size:.6875rem;font-family:inherit;background:transparent;border:1px dashed var(--border-color);border-radius:var(--border-radius);color:var(--text-muted);cursor:pointer}.color-scheme-add:hover{border-color:var(--accent-primary);color:var(--accent-primary)}#floatingBackgroundPanel{width:260px}#floatingPresetsPanel,#floatingPathPanel{width:280px}#panel select{width:100%;padding:6px 8px;border-radius:var(--border-radius);border:1px solid transparent;background:transparent;color:var(--text-bright);font-family:var(--font-family)}#panel select:hover,#panel select:focus{border-color:var(--input-border);background:var(--input-bg);outline:none}#panel select option{background:var(--canvas-bg);color:var(--text-bright)}.bg-color-swatches{display:grid;grid-template-columns:repeat(10,1fr);gap:2px;padding:4px 0}.bg-swatch{width:100%;aspect-ratio:1;border-radius:3px;cursor:pointer;border:1px solid rgba(255,255,255,.12);transition:border-color .15s}.bg-swatch:hover{border-color:#fff6}.bg-swatch.selected{border-color:var(--accent-primary)}.bg-color-row{display:flex;align-items:center;gap:8px;padding:6px 0 2px}.bg-color-row input[type=color]{width:32px;height:24px;padding:0;border:none;cursor:pointer;background:transparent;border-radius:4px}.bg-color-row .btn-sm{font-size:11px;padding:2px 8px;border-radius:4px;cursor:pointer;background:#ffffff14;color:var(--text-secondary);border:1px solid rgba(255,255,255,.12)}.bg-color-row .btn-sm:hover{background:#ffffff26}.floating-inline-panel .text-path-sliders{margin-top:8px}.share-popup{width:auto;padding:6px;display:none;flex-direction:row;gap:2px}.share-popup.visible{display:flex}.share-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 14px;border:none;border-radius:var(--border-radius);background:transparent;color:var(--text-muted);font-size:.625rem;cursor:pointer;transition:all .15s ease}.share-option:hover{background:var(--btn-hover-bg);color:var(--accent-primary)}.share-option svg{width:20px;height:20px}.qr-overlay{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:var(--overlay-heavy);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:qr-fade-in .2s ease}.qr-overlay.visible{display:flex}@keyframes qr-fade-in{0%{opacity:0}to{opacity:1}}.qr-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;padding:28px 32px 24px;background:var(--panel-bg);border:1px solid var(--border-subtle);border-radius:16px;box-shadow:0 8px 32px var(--shadow-light);min-width:260px}.qr-close{position:absolute;top:8px;right:12px;background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;line-height:1;padding:4px;transition:color .15s}.qr-close:hover{color:var(--text-bright)}.qr-canvas{border-radius:8px;image-rendering:pixelated}.qr-brand{display:flex;align-items:center;gap:10px}.qr-logo-svg{width:28px;height:28px}.qr-brand-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;font-weight:200;letter-spacing:3px;color:var(--text-bright)}.qr-accent{color:transparent;font-weight:700;display:inline-flex;align-items:center;justify-content:center;width:1.15em;height:1.15em;background:transparent;border:.08em solid var(--accent-primary);border-radius:50%;box-shadow:0 0 10px var(--glow-accent-soft)}.qr-actions{display:flex;gap:8px;width:100%}.qr-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:#ffffff0f;border:1px solid var(--border-subtle);border-radius:var(--border-radius);color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .15s ease}.qr-btn:hover{background:var(--btn-hover-bg);color:var(--accent-primary)}.qr-btn svg{width:16px;height:16px;flex-shrink:0}.qr-btn-flash{color:var(--accent-primary)!important;border-color:var(--accent-primary)}body.fullscreen-mode #panel{transform:translate(calc(-100% - 32px))}body.fullscreen-mode #historyBar,body.fullscreen-mode #bottomHud{transform:translate(-50%) translateY(calc(100% + 40px))}body.fullscreen-mode #hud{transform:translateY(calc(100% + 32px))}body.fullscreen-mode .axis-gizmo{transform:translate(calc(100% + 32px),calc(100% + 32px))}body.fullscreen-mode .right-rail{transform:translate(calc(100% + 32px))}body.fullscreen-mode .top-right-controls{gap:0}body.fullscreen-mode .top-right-controls .user-avatar,body.fullscreen-mode .top-right-controls .theme-toggle-btn{opacity:0;pointer-events:none;transform:scale(.92);width:0;min-width:0;height:0;min-height:0;padding:0;margin:0;overflow:hidden}#hud{position:fixed;right:16px;left:auto;bottom:12px;transition:transform .35s ease;pointer-events:none;z-index:5;display:flex;align-items:center;gap:6px}#panel{position:fixed;left:16px;top:16px;padding:12px 14px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-size:.8125rem;color:var(--text-color);width:280px;display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 32px);overflow:hidden;z-index:10;transition:transform .35s ease}#panel button:focus:not(:focus-visible),#bottomHud button:focus:not(:focus-visible){outline:none;box-shadow:none}.sys-vis-btn:focus,.sys-vis-btn:focus-visible,.sys-style-btn:focus,.sys-style-btn:focus-visible,.orbit-style-toggle:focus,.orbit-style-toggle:focus-visible,.orbit-geometry-btn:focus,.orbit-geometry-btn:focus-visible,.orbit-line-style-btn:focus,.orbit-line-style-btn:focus-visible{outline:none;box-shadow:none}.system-tabs{flex-shrink:0;display:flex;align-items:center;gap:2px;padding:2px 10px;overflow-x:auto}.system-tabs::-webkit-scrollbar{display:none}.system-tabs:empty{display:none}.system-tab{flex-shrink:0;padding:4px 6px;border-radius:4px;font-size:13px;font-weight:400;font-family:inherit;color:var(--text-ghost);background:transparent;border:1px solid transparent;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background .15s,color .15s}.system-tab+.system-tab:before{content:"";position:absolute;left:0;top:25%;height:50%;width:1px;background:var(--border-color)}.system-tab+.system-tab{position:relative}.system-tab:hover{background:var(--fill-muted);color:var(--text-bright)}.system-tab.active{background:transparent;color:var(--text-bright);font-weight:700;border-color:transparent;border-radius:4px}.system-tab-delete,.system-tab-add,.system-tab-pause,.system-tab-vis,.system-tab-list{flex-shrink:0;width:16px;height:16px;border-radius:4px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.7;transition:opacity .15s,color .15s}.system-tab-delete svg,.system-tab-add svg,.system-tab-pause svg,.system-tab-vis svg,.system-tab-list svg{width:18px;height:14px}.system-tab-add{margin-left:4px}.system-tab-pause.active{color:var(--accent-secondary)}.system-tab-vis:not(.active){color:var(--text-dim)}.system-tab-delete:hover:not(:disabled),.system-tab-add:hover:not(:disabled),.system-tab-pause:hover:not(:disabled),.system-tab-vis:hover:not(:disabled),.system-tab-list:hover:not(:disabled){opacity:1;color:var(--text-bright)}.system-tab-delete:hover:not(:disabled){color:var(--accent-danger)}.system-tab-delete:disabled,.system-tab-add:disabled{opacity:.15;cursor:default;pointer-events:none}.system-tab-ellipsis{flex-shrink:0;padding:2px 6px;font-size:.625rem;color:var(--text-muted);font-family:inherit;display:flex;align-items:center}.system-context-menu{position:fixed;z-index:10000;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:4px 0;min-width:120px;font-size:.75rem;color:var(--text-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-md)}.context-menu-header{padding:6px 14px;font-size:.625rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;cursor:default;border-bottom:1px solid var(--border-color);margin-bottom:2px}.context-menu-item{padding:6px 14px;cursor:pointer}.context-menu-item:hover{background:var(--btn-hover-bg)}.system-list-menu{min-width:180px;max-height:320px;overflow-y:auto}.sys-list-row{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;cursor:pointer}.sys-list-row:hover{background:var(--btn-hover-bg)}.sys-list-row.active .sys-list-name{color:var(--accent-primary)}.sys-list-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sys-list-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.sys-list-action{width:18px;height:18px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;border-radius:3px}.sys-list-action svg{width:12px;height:12px}.sys-list-action:hover{color:var(--text-bright);background:var(--btn-hover-bg)}.sys-list-action.on{color:var(--accent-secondary)}.sys-list-rename{flex:1;min-width:0;font:inherit;font-size:.75rem;padding:1px 4px;border-radius:3px;border:1px solid var(--accent-primary);background:var(--input-bg);color:var(--text-bright);outline:none}.sys-list-add{gap:4px;color:var(--text-muted);border-top:1px solid var(--border-color);margin-top:2px;padding-top:6px}.sys-list-add svg{width:14px;height:14px}.system-tabs-wrapper{display:flex;align-items:center;gap:0;padding:0 10px;margin-top:-4px}.system-tabs-wrapper>.system-tabs{flex:1;min-width:0;border-bottom:none;padding-left:0;padding-right:0}.system-tab-scroll{flex-shrink:0;width:14px;min-width:14px;height:22px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:color .15s,opacity .15s}.system-tab-scroll svg{width:14px;height:14px}.system-tab-scroll:hover:not(:disabled){opacity:1;color:var(--text-bright)}.system-tab-scroll:disabled{opacity:.4;cursor:default;pointer-events:none}.system-visibility-bar{display:flex;align-items:center;padding:2px 0 2px 10px}.global-scope-toggle{width:22px;height:22px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;margin:0 4px 0 0;transition:border-color .15s,color .15s}.global-scope-toggle svg{width:12px;height:12px}.global-scope-toggle:focus,.global-scope-toggle:focus-visible{outline:none;box-shadow:none}.global-scope-toggle:disabled{opacity:.25;cursor:default;pointer-events:none}.global-scope-toggle.active{border-color:#ff8c00;color:#ff8c00}.system-vis-buttons{flex:1;display:flex;align-items:center;justify-content:space-evenly}.system-style-tools,.system-vis-tools,.system-orbit-style-tools{display:contents}.system-visibility-divider{width:1px;height:14px;background:var(--section-border);opacity:.85;align-self:center;flex-shrink:0}.sys-style-btn{width:22px;height:22px;border-radius:50%;border:1px solid transparent;background:var(--btn-primary-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.72;transition:opacity .2s,border-color .2s,color .2s,background .2s}.sys-style-btn svg{width:12px;height:12px}.sys-style-btn .mode-3d-icon{display:inline-block;font-size:.56rem;font-weight:800;line-height:1;letter-spacing:.03em}.sys-grid-toggle{position:relative}.sys-grid-toggle input{position:absolute;opacity:0;pointer-events:none}.sys-style-btn:hover{opacity:.92;color:var(--text-bright)}.sys-style-btn.active{opacity:1;color:var(--text-bright);border-color:var(--accent-primary);background:var(--btn-primary-bg)}.global-edit-btn{width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:color .2s}.global-edit-btn:hover{color:var(--text-bright)}.global-edit-btn.active{transform:scale(1.3)}.sys-vis-btn{width:22px;height:22px;border-radius:50%;border:1px solid transparent;background:var(--btn-primary-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.72;transition:opacity .2s,border-color .2s,color .2s,background .2s}.sys-vis-btn svg{width:12px;height:12px}.sys-vis-btn.active{opacity:1;color:var(--text-bright);border-color:var(--accent-primary);background:var(--btn-primary-bg)}.sys-vis-btn:hover{opacity:.92;color:var(--text-bright)}.panel-space-control{flex-shrink:0;padding:0 18px 0 10px;margin:-10px 0}.space-slider-row{display:flex;align-items:center;gap:8px}.space-slider-row .global-scope-toggle{margin:0 2px 0 0}.space-slider-row input[type=range]{flex:1;min-width:0}.space-value{font-size:.75rem;font-weight:700;color:var(--text-muted);min-width:20px;text-align:right}.space-value.infinity{color:var(--accent-primary)}.panel-scroll-content{flex:1;overflow-y:auto;overflow-x:hidden;display:grid;gap:4px;padding:4px 10px;background:transparent}#panelHeader{display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:2px 0 2px 8px;border-bottom:1px solid var(--section-border);cursor:pointer;border-radius:var(--border-radius)}#panelHeader:hover .panel-logo-text span{color:var(--accent-primary);transition:color .3s ease}.panel-logo{width:48px;height:48px;flex-shrink:0;overflow:visible;border-radius:50%;transition:box-shadow .4s ease,transform .3s ease}#panelHeader:hover .panel-logo{box-shadow:0 0 6px var(--accent-primary),inset 0 0 4px var(--fill-subtle);transform:scale(1.08)}.panel-m{height:12.5px;width:auto;flex-shrink:0;color:var(--panel-m-color);margin-left:-10px;align-self:flex-end;transition:transform .3s ease,color .3s ease}#panelHeader:hover .panel-m{color:var(--accent-primary);transform:scale(.93)}.panel-divider{width:1px;height:36px;background:var(--section-border);flex-shrink:0}.panel-logo-text{display:flex;flex-direction:column;line-height:1.15;flex:1}.panel-logo-text span{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:800;font-size:1.3rem;color:var(--text-bright);text-transform:uppercase;transform:scaleY(.75);transform-origin:center;letter-spacing:.18em}.section-item{background:transparent;border:none;border-radius:var(--border-radius);overflow:hidden;margin-bottom:8px}.section-header{display:flex;align-items:center;padding:8px 10px;cursor:pointer;-webkit-user-select:none;user-select:none;gap:8px}.section-header:hover,.section-header:focus{background:transparent;outline:none}.section-arrow{font-size:.625rem;transition:transform .2s;color:var(--accent-primary)}.section-item.expanded .section-arrow{transform:rotate(90deg)}.section-name{font-weight:600;color:var(--text-bright);font-size:.75rem;flex:1;text-transform:uppercase;letter-spacing:.5px}.subsection-header{font-weight:600;color:var(--text-bright);font-size:.6875rem;text-transform:uppercase;letter-spacing:.5px;padding:8px 0 4px;margin-top:4px;border-top:1px solid var(--section-border)}.section-params{display:none;padding:8px 10px;border-top:1px solid var(--section-border);background:transparent}.section-item.expanded .section-params{display:grid;gap:6px}.path-tab,.filter-tab,.gravity-tab,.perf-tab,.settings-tab,.links-tab,.scene-tab{transition:opacity var(--right-slide-panel-duration) var(--right-slide-panel-ease),color .2s,background .2s,border-color .2s}.path-tab.active,.filter-tab.active,.gravity-tab.active,.perf-tab.active,.settings-tab.active,.links-tab.active,.scene-tab.active{color:var(--accent-primary)}.path-panel,.filter-panel,.gravity-panel,.perf-panel,.settings-panel,.links-panel,.scene-panel{width:var(--right-slide-panel-base-width);transform:translate3d(var(--right-slide-panel-width),0,0);transition:transform var(--right-slide-panel-duration) var(--right-slide-panel-ease);will-change:transform}.path-panel.open,.filter-panel.open,.gravity-panel.open,.perf-panel.open,.settings-panel.open,.links-panel.open,.scene-panel.open{transform:translateZ(0)}.path-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);cursor:pointer;z-index:30;transition:right .3s ease,color .2s,background .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.path-tab svg{width:16px;height:16px}.path-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.path-tab.active{right:280px;color:var(--accent-primary)}.path-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.path-panel.open{transform:translate(0)}.path-panel-header,.filter-panel-header,.gravity-panel-header,.perf-panel-header,.settings-panel-header,.links-panel-header,.scene-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-color);font-size:.9375rem;font-weight:600;color:var(--text-color);text-transform:uppercase;letter-spacing:.06em}.path-panel-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:12px 14px}.pulse-panel .pulse-panel-body{flex:1;overflow-y:auto;padding:10px 12px}.pulse-section{margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.pulse-section:last-child{border-bottom:none}.pulse-section-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--accent-primary);margin-bottom:8px}.pulse-buttons{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:8px}.pulse-preset-btn{background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-muted);font-size:.6875rem;font-weight:600;padding:5px 6px;cursor:pointer;font-family:inherit;transition:color .15s,border-color .15s,background .15s}.pulse-preset-btn:hover{color:var(--text-bright);border-color:var(--text-muted)}.pulse-preset-btn.active{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--btn-primary-bg)}.pulse-slider-row{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:.625rem}.pulse-slider-row label{min-width:46px;color:var(--text-muted)}.pulse-slider-row input[type=range]{flex:1;height:4px}.pulse-slider-value{min-width:34px;text-align:right;color:var(--text-bright);font-variant-numeric:tabular-nums}.filter-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);font-size:.75rem;font-weight:700;font-family:inherit;cursor:pointer;z-index:30;transition:right .3s ease,color .2s,background .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.filter-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.filter-tab.active{right:280px;color:var(--accent-primary)}.filter-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.filter-panel.open{transform:translate(0)}.filter-panel-close{background:none;border:none;color:var(--text-muted);font-size:1.125rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}.filter-panel-close:hover{color:var(--text-bright)}.filter-list{flex:1 1 auto;overflow-y:auto;padding:6px 0}.filter-inline-params{padding:8px 14px 12px;background:var(--fill-faint);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.filter-item{padding:6px 14px;font-size:.75rem;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s;-webkit-user-select:none;user-select:none}.filter-item:hover{background:var(--fill-subtle);color:var(--text-color)}.filter-item.selected{background:var(--fill-soft);color:var(--accent-primary);font-weight:600}.filter-params{display:none}.filter-param-row{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}.filter-param-label{display:flex;justify-content:space-between;font-size:.6875rem;color:var(--text-muted)}.filter-param-value{color:var(--text-color);font-weight:600;min-width:30px;text-align:right}.filter-param-row input[type=range]{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;outline:none;cursor:pointer}.filter-param-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent-primary);cursor:pointer}.filter-param-row input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent-primary);border:none;cursor:pointer}.gravity-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);cursor:pointer;z-index:30;transition:right .3s ease,opacity .3s ease,color .2s,background .2s,border-color .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.gravity-tab svg{width:16px;height:16px}.gravity-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.gravity-tab.active{right:280px;color:var(--accent-primary)}.gravity-tab.gravity-on{color:var(--gravity-on-color);border-color:var(--gravity-on-border)}.gravity-tab.gravity-on:hover{color:var(--gravity-on-hover)}.gravity-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.gravity-panel.open{transform:translate(0)}.gravity-panel-content{flex:1;overflow-y:auto;padding:10px 14px;display:grid;gap:8px;align-content:start}.perf-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);cursor:pointer;z-index:30;transition:right .3s ease,opacity .3s ease,color .2s,background .2s,border-color .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.perf-tab svg{width:16px;height:16px}.perf-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.perf-tab.active{right:280px;color:var(--accent-primary)}.perf-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.perf-panel.open{transform:translate(0)}.perf-panel-content{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:12px}.perf-sections{display:flex;flex:1;min-height:0;flex-direction:column;gap:12px}.perf-metrics{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.6875rem;padding:8px;background:var(--fill-faint);border-radius:4px;border:1px solid var(--border-faint)}.perf-metric{display:flex;justify-content:space-between;align-items:center;padding:1px 0}.perf-metric-label{color:var(--text-muted);font-size:.625rem}.perf-metric-value{font-weight:600;color:var(--text-color);font-size:.6875rem}.zone-ok{color:var(--zone-ok)!important}.zone-warn{color:var(--zone-warn)!important}.zone-crit{color:var(--zone-crit)!important}.perf-bar{height:6px;background:var(--fill-soft);border-radius:3px;overflow:hidden;margin-top:4px}.perf-bar-fill{height:100%;border-radius:3px;transition:width .3s ease,background-color .3s ease}.perf-bar-fill.zone-ok{background-color:var(--zone-ok-fill)}.perf-bar-fill.zone-warn{background-color:var(--zone-warn-fill)}.perf-bar-fill.zone-crit{background-color:var(--zone-crit-fill)}.perf-section{border-top:1px solid var(--border-faint);padding-top:8px}.perf-section-header{display:flex;align-items:center;justify-content:space-between;gap:6px;cursor:default;-webkit-user-select:none;user-select:none;margin-bottom:6px}.perf-section.always-expanded .perf-section-header{cursor:default}.perf-section.always-expanded .perf-section-header:hover .perf-section-label{color:var(--accent-primary)}.perf-section-label{font-size:.6875rem;font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px;transition:color .2s}.perf-section-header:hover .perf-section-label{color:var(--accent-primary)}.perf-section-arrow{font-size:.5625rem;color:var(--accent-primary);transition:transform .2s}.perf-section.expanded .perf-section-arrow{transform:rotate(90deg)}.perf-section-body{display:none;padding-left:4px}.perf-section.expanded .perf-section-body{display:block}.perf-toggle-section .perf-section-header{margin-bottom:8px}.perf-toggle-section .perf-section-body{display:none}.perf-toggle-section.active .perf-section-body{display:block}.perf-section-switch{display:inline-flex;align-items:center;justify-content:center;width:30px;height:18px;padding:0;border:none;background:transparent;cursor:pointer;flex:0 0 auto}.perf-section-switch-track{position:relative;width:30px;height:18px;border-radius:999px;border:1px solid var(--border-color);background:var(--fill-soft);transition:border-color .2s,background .2s}.perf-section-switch-thumb{position:absolute;top:1px;left:1px;width:14px;height:14px;border-radius:50%;background:var(--text-muted);transition:transform .2s,background .2s,box-shadow .2s}.perf-toggle-section.active .perf-section-switch-track{border-color:color-mix(in srgb,var(--accent-primary) 60%,var(--border-color));background:color-mix(in srgb,var(--accent-primary) 18%,var(--fill-soft))}.perf-toggle-section.active .perf-section-switch-thumb{transform:translate(12px);background:var(--accent-primary);box-shadow:var(--shadow-glow)}.perf-section-switch:hover .perf-section-switch-track{border-color:var(--text-bright)}.perf-section-switch:focus-visible{outline:1px solid var(--accent-primary);outline-offset:2px;border-radius:999px}.perf-logs-section,.perf-section.perf-logs-section.expanded .perf-section-body{display:flex;flex:1;min-height:0;flex-direction:column}.perf-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:3px 0}.perf-toggle-label{color:var(--text-muted);flex:0 0 74px;min-width:74px;max-width:74px;font-size:.625rem;line-height:1.25}.perf-toggle{width:14px;height:14px;border-radius:50%;border:2px solid var(--text-muted);background:transparent;padding:0;cursor:pointer;transition:all .2s;flex-shrink:0}.perf-toggle:hover{border-color:var(--text-bright)}.perf-toggle.active{background:var(--accent-primary);border-color:var(--accent-primary)}.perf-slider-row{display:flex;align-items:center;gap:8px;padding:3px 0}.perf-slider-label{color:var(--text-muted);flex:0 0 74px;min-width:74px;max-width:74px;font-size:.625rem;line-height:1.25}.perf-slider-value{color:var(--text-color);font-weight:600;min-width:0;text-align:right}.perf-slider-row input[type=range]{flex:1 1 auto;min-width:0}.perf-slider-row .perf-slider-value-wrap{flex:0 0 auto;min-width:78px;justify-content:space-between}.perf-slider-row .slider-value-arrow{padding:2px 7px}.perf-slider-row .slider-value-input{width:auto;min-width:4ch;padding:2px 3px;font-size:.625rem;font-weight:600}.perf-slider-row .slider-value-wrap:focus-within{border-color:var(--accent-primary)}.perf-mode-params{margin:2px 0 4px 8px;padding-left:8px;border-left:1px solid var(--border-faint)}.perf-group-title{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-weight:600;margin:6px 0 2px}.perf-group-divider{height:1px;background:var(--border-faint);margin:8px 0 6px}.perf-readout{font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.625rem;color:var(--text-muted);padding:2px 0}.perf-breakdown{font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.625rem;line-height:1.6}.perf-breakdown-row{display:flex;justify-content:space-between;padding:1px 0;color:var(--text-muted)}.perf-breakdown-row.parent{color:var(--text-color);font-weight:600}.perf-breakdown-row.child{padding-left:12px}.perf-mem-row{display:flex;justify-content:space-between;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.625rem;color:var(--text-muted);padding:1px 0}.perf-mem-row.total{color:var(--text-color);font-weight:600;border-top:1px solid var(--border-faint);margin-top:2px;padding-top:3px}.perf-logs-toolbar{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;margin-bottom:6px}.perf-log-filter-tab{min-width:0;width:100%;padding:4px 6px;border:1px solid var(--border-faint);border-radius:999px;background:transparent;color:var(--text-muted);font:inherit;font-size:.625rem;font-weight:700;letter-spacing:.2px;white-space:nowrap;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.perf-log-filter-tab:hover{color:var(--text-bright);border-color:var(--text-muted)}.perf-log-filter-tab.active{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--btn-primary-bg)}.perf-logs-box{flex:1;min-height:220px;overflow-y:auto;border:1px solid var(--border-faint);border-radius:4px;background:var(--fill-faint);padding:6px;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.625rem;line-height:1.4}.perf-log-row{display:grid;grid-template-columns:62px 42px minmax(0,1fr);gap:6px;align-items:start;color:var(--text-muted);white-space:pre-wrap;word-break:break-word;margin-bottom:2px}.perf-log-row .perf-log-time{color:var(--text-muted);white-space:nowrap}.perf-log-row .perf-log-cat{color:var(--accent-primary);text-transform:lowercase;white-space:nowrap}.perf-log-row .perf-log-msg{min-width:0;color:var(--text-color)}.perf-log-row.level-warn .perf-log-msg{color:var(--zone-warn)}.perf-log-row.level-error .perf-log-msg{color:var(--zone-crit)}.settings-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);cursor:pointer;z-index:30;transition:right .3s ease,opacity .3s ease,color .2s,background .2s,border-color .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.settings-tab svg{width:16px;height:16px}.settings-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.settings-tab.active{right:280px;color:var(--accent-primary)}.settings-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.settings-panel.open{transform:translate(0)}.settings-panel-content{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:12px}.app-version-line{margin-top:16px;padding-top:10px;border-top:1px solid var(--border-faint);text-align:center;font-size:.625rem;color:var(--text-muted);font-variant-numeric:tabular-nums;letter-spacing:.3px;-webkit-user-select:text;user-select:text}.axis-gizmo{position:fixed;bottom:12px;right:12px;width:64px;height:64px;z-index:4;pointer-events:none;opacity:.7;transition:opacity .3s}.axis-gizmo:hover{opacity:1}.links-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);cursor:pointer;z-index:30;transition:right .3s ease,color .2s,background .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.links-tab svg{width:16px;height:16px}.links-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.links-tab.active{right:280px;color:var(--accent-primary)}.links-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.links-panel.open{transform:translate(0)}.links-panel-content{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:8px}.link-row{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--fill-faint);border:1px solid var(--border-faint);border-radius:4px;font-size:.6875rem;color:var(--text-muted)}.link-row-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-row-remove{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.75rem;padding:0 4px;margin-left:6px}.link-row-remove:hover{color:#ff6b6b}.links-add-btn{width:100%;padding:8px;background:var(--fill-faint);border:1px dashed var(--border-faint);border-radius:4px;color:var(--text-muted);font-size:.6875rem;cursor:pointer;transition:color .2s,border-color .2s}.links-add-btn:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.links-add-form{display:flex;flex-direction:column;gap:6px;padding:8px;background:var(--fill-faint);border:1px solid var(--border-faint);border-radius:4px}.links-add-form select{width:100%;padding:4px 6px;background:var(--panel-bg);border:1px solid var(--border-faint);border-radius:3px;color:var(--text-color);font-size:.6875rem}.links-add-form label{font-size:.625rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.links-add-form .links-form-actions{display:flex;gap:6px}.links-add-form button{flex:1;padding:4px 8px;border:1px solid var(--border-faint);border-radius:3px;background:var(--fill-faint);color:var(--text-muted);font-size:.625rem;cursor:pointer}.links-add-form button.links-confirm{color:var(--accent-primary);border-color:var(--accent-primary)}.scene-tab{width:28px;height:28px;padding:4px;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border:1px solid var(--panel-border);border-right:none;border-radius:8px 0 0 8px;color:var(--text-muted);cursor:pointer;z-index:30;transition:right .3s ease,opacity .3s ease,color .2s,background .2s,border-color .2s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.scene-tab svg{width:16px;height:16px}.scene-tab:hover{color:var(--text-bright);background:var(--panel-bg-hover)}.scene-tab.active{right:280px;color:var(--accent-primary)}.scene-panel{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur, 4px));backdrop-filter:blur(var(--frosted-blur, 4px));border-left:1px solid var(--border-color);transform:translate(280px);transition:transform .3s ease;z-index:25;display:flex;flex-direction:column;overflow:hidden}.scene-panel.open{transform:translate(0)}.scene-panel-content{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:12px}.scene-btn-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.scene-mode-btn{flex:1;padding:3px 6px;background:var(--fill-faint);border:1px solid var(--border-faint);border-radius:3px;color:var(--text-muted);font-size:.625rem;font-family:inherit;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.scene-mode-btn:hover{color:var(--text-color);border-color:var(--border-color)}.scene-mode-btn.active{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--fill-soft)}.scene-color-input{width:32px;height:22px;border:none;border-radius:3px;cursor:pointer;padding:0;vertical-align:middle;background:none}.panel-section-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px 2px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.panel-section-actions{display:flex;gap:2px}.preset-picker-row{display:flex;gap:2px;align-items:center;padding:0 10px;width:100%;box-sizing:border-box}.preset-picker-row .btn-icon-sm,.panel-section-actions .btn-icon-sm{flex-shrink:0;width:18px;height:18px;padding:0;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.5;transition:color .2s,opacity .2s}.preset-picker-row .btn-icon-sm:hover,.panel-section-actions .btn-icon-sm:hover{color:var(--text-bright);opacity:1}.preset-picker-row .btn-icon-sm svg,.panel-section-actions .btn-icon-sm svg{width:15px;height:15px}#panelSaveBtn{margin-left:4px}.preset-picker-btn{flex:1 1 0;min-width:0;background:none;border:1px solid var(--panel-border);border-radius:var(--border-radius);color:var(--text-muted);padding:6px 10px;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s,border-color .2s}.preset-picker-btn:hover{color:var(--text-bright);border-color:var(--border-medium)}.active-preset-name{color:var(--text-bright);margin-left:4px;font-weight:600;letter-spacing:.5px}.preset-picker-overlay{position:fixed;inset:0;z-index:1000;background:transparent}.preset-picker-panel{position:fixed;background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur));backdrop-filter:blur(var(--frosted-blur));border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);padding:16px;width:280px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.preset-picker-header{display:flex;justify-content:space-between;align-items:center;padding:0 0 8px;flex-shrink:0}.preset-picker-tabs{display:flex;gap:0;flex-shrink:0;border-bottom:1px solid var(--panel-border)}.preset-picker-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.75rem;font-family:inherit;font-weight:500;padding:6px 0;cursor:pointer;transition:color .15s,border-color .15s}.preset-picker-tab:hover{color:var(--text-bright)}.preset-picker-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);font-weight:700}.preset-picker-empty{color:var(--text-muted);font-size:.75rem;text-align:center;padding:20px 0}.preset-picker-title{font-size:.875rem;font-weight:700;color:var(--text-bright)}.preset-picker-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:4px}.preset-picker-close:hover{color:var(--text-bright)}.preset-picker-group-title{font-size:.625rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:8px 0 4px}.preset-picker-list{display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1;min-height:0;padding-top:8px}.preset-picker-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--border-radius);cursor:pointer;transition:background .15s}.preset-picker-item:hover{background:#ffffff0d}.preset-picker-item-name{flex:1;font-size:.75rem;color:var(--text-bright)}.preset-picker-item-meta{font-size:.625rem;color:var(--text-muted)}.preset-picker-swatches{display:flex;gap:2px}.preset-picker-swatch{width:8px;height:8px;border-radius:50%}.preset-picker-delete{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:2px 4px}.preset-picker-delete:hover{color:var(--accent-danger)}#rightRail .path-tab,#rightRail .filter-tab,#rightRail .gravity-tab,#rightRail .perf-tab,#rightRail .settings-tab,#rightRail .links-tab,#rightRail .scene-tab{transition:opacity var(--right-slide-panel-duration) var(--right-slide-panel-ease),color .2s,background .2s,border-color .2s}#rightRail .path-tab.active,#rightRail .filter-tab.active,#rightRail .gravity-tab.active,#rightRail .perf-tab.active,#rightRail .settings-tab.active,#rightRail .links-tab.active,#rightRail .scene-tab.active{right:auto;color:var(--accent-primary)}#rightPanelsViewport>.path-panel,#rightPanelsViewport>.filter-panel,#rightPanelsViewport>.pulse-panel,#rightPanelsViewport>.gravity-panel,#rightPanelsViewport>.perf-panel,#rightPanelsViewport>.settings-panel,#rightPanelsViewport>.links-panel,#rightPanelsViewport>.scene-panel{position:absolute;inset:0;width:var(--right-slide-panel-base-width);height:100%;transform:none;opacity:0;visibility:hidden;pointer-events:none;transition:none}#rightPanelsViewport>.path-panel.open,#rightPanelsViewport>.filter-panel.open,#rightPanelsViewport>.pulse-panel.open,#rightPanelsViewport>.gravity-panel.open,#rightPanelsViewport>.perf-panel.open,#rightPanelsViewport>.settings-panel.open,#rightPanelsViewport>.links-panel.open,#rightPanelsViewport>.scene-panel.open{opacity:1;visibility:visible;pointer-events:auto}#rightPanelsViewport>.closing{pointer-events:none}#objectList{display:grid;gap:0;margin:0 -10px}.object-item{background:transparent;border:none;border-radius:var(--border-radius)}.object-item+.object-item{border-top:1px solid var(--section-border);margin-top:2px}.object-header{position:relative;display:flex;align-items:center;padding:2px 0 2px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;gap:2px;background:var(--fill-ghost)}.object-header:hover{background:var(--btn-primary-bg)}.object-header.selected,.object-header:focus{background:var(--btn-primary-bg);color:var(--accent-primary);font-weight:600;outline:none}.object-arrow{font-size:.475rem;transition:transform .2s;color:var(--accent-primary);position:absolute;left:var(--arrow-indent, 5px);top:50%;transform:translateY(-50%)}.instance-item>.object-arrow{left:var(--arrow-indent-nested, -8px)}.object-item.expanded>.object-header>.object-arrow,.instance-with-children.expanded>.instance-item>.object-arrow{transform:translateY(-50%) rotate(90deg)}.instance-with-children>.instance-children{display:none}.instance-with-children.expanded>.instance-children{display:block}.object-name{font-weight:500;color:var(--text-color);font-size:.75rem}.object-count{color:var(--text-muted, #888);font-size:.5625rem;margin-left:2px;flex:1}.instance-name-wrap{flex:1;min-width:0;display:flex;align-items:center}.instance-name-wrap .instance-count{flex:none;margin-left:3px;font-weight:400}.object-color-preview{width:12px;height:12px;border-radius:50%;border:1px solid var(--input-border);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.object-color-preview:hover{transform:scale(1.2);box-shadow:0 0 6px var(--border-strong)}.object-toggle{width:16px;height:16px;cursor:pointer;accent-color:var(--accent-primary)}.object-toggle.orbit-toggle{accent-color:var(--accent-secondary);margin-left:4px}.object-params{display:none;padding:8px 10px;border-top:1px solid var(--section-border);background:var(--section-params-bg)}.object-item.expanded .object-params{display:grid;gap:6px}.btn-add-object{background:transparent;border:none;color:var(--text-dim);font-size:1.25rem;font-weight:700;width:22px;height:22px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s ease;margin-left:-2px}.btn-add-object:hover,.btn-add-object:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-delete-object{background:transparent;border:none;color:var(--text-dim);width:22px;height:22px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;margin-left:-2px;transition:all .15s ease}.btn-delete-object svg{width:14px;height:14px}.btn-delete-object:hover,.btn-delete-object:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-edit-object{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--text-bright);font-size:.6875rem;padding:2px 6px;border-radius:var(--border-radius);cursor:pointer;margin-left:4px;font-family:var(--font-family)}.btn-edit-object:hover,.btn-edit-object:focus{background:var(--btn-hover-bg);outline:none}.object-item>.instances-container{padding:2px 0 2px 16px!important;margin-left:0;border-left:none}.instances-container{padding:1px 0 1px 3px!important;margin-left:0;border-left:1px solid var(--section-border)}.instance-item{position:relative;display:flex;align-items:center;gap:2px;padding:2px 0 2px 2px;background:transparent;border:none;border-radius:var(--border-radius);margin-bottom:1px;min-width:0}.instance-item:last-child{margin-bottom:0}.instance-item:hover{background:var(--btn-primary-bg)}.instance-item.selected,.instance-item:focus{background:var(--btn-primary-bg);color:var(--accent-primary);font-weight:600;outline:none}.instance-name{flex:1;min-width:0;font-size:.625rem;color:var(--text-color);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-delete-instance{background:transparent;border:none;color:var(--text-dim);font-size:.875rem;font-weight:700;width:16px;height:16px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:all .15s ease}.btn-delete-instance:hover,.btn-delete-instance:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-add-child{background:transparent;border:none;color:var(--text-muted);font-size:.9375rem;font-weight:700;width:16px;height:16px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:all .15s ease;margin-left:-2px}.btn-add-child:hover,.btn-add-child:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-delete-child{background:transparent;border:none;color:var(--text-dim);width:16px;height:16px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;margin-left:-2px;transition:all .15s ease}.btn-delete-child svg{width:12px;height:12px}.btn-delete-child:hover,.btn-delete-child:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-settings{background:transparent;border:none;color:var(--text-muted);font-size:.9375rem;width:16px;height:16px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;margin-left:-2px;transition:opacity .15s ease}.btn-settings:hover,.btn-settings:focus{background:transparent;color:var(--text-bright);opacity:1;transform:scale(1.2);outline:none}.object-header .btn-settings{width:20px;height:20px;font-size:1.1875rem}.object-header .object-color-preview{width:14px;height:14px}.instance-with-children{margin-bottom:1px}.instance-with-children:last-child{margin-bottom:0}.instance-children{margin-left:6px;margin-top:1px;padding-left:0;border-left:1px solid var(--section-border);overflow:visible}.instance-children .instance-item{padding:2px 0 2px 4px}.instance-actions-group{margin-left:auto;display:flex;align-items:center;gap:2px;flex-shrink:0}.btn-action-inline{background:transparent;border:none;color:var(--text-muted);width:16px;height:16px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:color .15s ease,transform .15s ease}.btn-action-inline svg{width:12px;height:12px}.btn-action-inline:hover,.btn-action-inline:focus{color:var(--text-bright);transform:scale(1.2);outline:none}.btn-action-inline:disabled{opacity:.15;pointer-events:none;cursor:default}.object-header .btn-action-inline{width:16px;height:16px}.object-header .btn-action-inline svg{width:13px;height:13px}.btn-add-instance:hover,.btn-add-child:hover{color:var(--accent-secondary)}.btn-freeze.playing{opacity:.5;color:var(--accent-secondary)}.btn-freeze.playing:hover{opacity:1}.btn-freeze:not(.playing){color:var(--text-dim)}.btn-freeze:not(.playing):hover{color:var(--accent-primary)}.btn-delete-orbit:hover,.btn-action-inline.btn-delete-instance:hover{color:var(--accent-danger)}.instance-with-children.dragging>.instance-item,.object-item.dragging>.object-header{opacity:.4;outline:1px dashed var(--accent-primary)}.instance-with-children.drag-over>.instance-item,.object-item.drag-over>.object-header{background:var(--accent-primary);opacity:.8;border-radius:var(--border-radius)}.drag-ghost{opacity:.7;box-shadow:var(--shadow-sm);background:var(--section-params-bg);border:1px solid var(--accent-primary);border-radius:var(--border-radius)}.object-context-menu{position:fixed;z-index:10000;background:var(--modal-bg);border:1px solid var(--panel-border);border-radius:6px;padding:4px 0;min-width:120px;font-size:.75rem;color:var(--text-bright);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}.object-context-menu-item{padding:6px 14px;cursor:pointer;transition:background .1s;display:flex;align-items:center;gap:8px}.object-context-menu-item:hover{background:var(--btn-primary-bg)}.object-context-menu-item.danger{color:var(--accent-danger)}.object-context-menu-item.disabled{opacity:.3;pointer-events:none}.context-menu-input{width:36px;padding:1px 4px;font-size:.65rem;border-radius:3px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-bright);text-align:center;margin-left:auto;-moz-appearance:textfield;appearance:textfield}.context-menu-input::-webkit-inner-spin-button,.context-menu-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.context-menu-add-btn{font-size:.6rem;padding:2px 8px;border-radius:3px;border:1px solid var(--accent-primary);background:var(--btn-primary-bg);color:var(--accent-primary);cursor:pointer;white-space:nowrap}.context-menu-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7}.context-menu-icon svg{width:14px;height:14px}.context-menu-text{flex:1}.object-context-menu-separator{height:1px;background:var(--section-border);margin:4px 8px}.btn-kebab{background:transparent;border:none;color:var(--text-muted);font-size:1rem;width:18px;height:18px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:opacity .15s ease,color .15s ease,transform .15s ease;line-height:1}.btn-kebab:hover,.btn-kebab:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.object-header .btn-kebab{width:18px;height:18px;font-size:1rem}.control label{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-weight:400;color:var(--text-bright);font-size:.6875rem}.control.control-inline{display:flex;align-items:center;gap:8px}.control.control-inline .control-label{flex:0 0 auto;min-width:80px;max-width:90px;margin-bottom:0;display:block}.control.control-inline input[type=range]{flex:1 1 auto;min-width:0;margin:0}.control.control-inline .slider-value-wrap{flex:0 0 auto}.slider-value-wrap{display:inline-flex;align-items:center;gap:0;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--fill-soft);overflow:hidden}.slider-value-arrow{background:none;border:none;color:var(--text-muted);font-size:.6rem;padding:2px 5px;cursor:pointer;line-height:1}.slider-value-arrow:hover{color:var(--text-bright)}.slider-value-input{width:44px;padding:2px;background:none;border:none;color:var(--text-bright);font-size:.6875rem;font-family:inherit;font-weight:400;text-align:center;outline:none}.slider-value-wrap:focus-within{border-color:var(--accent-primary)}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:20px;background:transparent;cursor:pointer}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{height:1px;background:var(--input-border);border-radius:0}input[type=range]::-moz-range-track{height:1px;background:var(--input-border);border-radius:0;border:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent-primary);border:none;margin-top:-5.5px;transition:box-shadow .2s}input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent-primary);border:none;transition:box-shadow .2s}input[type=range]:hover::-webkit-slider-thumb{box-shadow:var(--shadow-glow)}input[type=range]:hover::-moz-range-thumb{box-shadow:var(--shadow-glow)}.panel-space-control .control label{font-size:.8125rem;margin-bottom:6px}#orbitsValue{font-size:.875rem;font-weight:300;min-width:2ch;text-align:right}#orbitsValue.infinity{display:inline-block;transform:scale(2.5);margin-right:6px}#orbitsSlider{height:36px}#orbitsSlider::-webkit-slider-runnable-track{height:1px}#orbitsSlider::-moz-range-track{height:1px}#orbitsSlider::-webkit-slider-thumb{-webkit-appearance:none;width:36px;height:36px;margin-top:-17px;border-radius:0;border:none;background:transparent;background-image:var(--slider-rocket);background-size:contain;background-repeat:no-repeat;background-position:center;cursor:pointer;transition:filter .2s}#orbitsSlider::-moz-range-thumb{width:36px;height:36px;border-radius:0;border:none;background:transparent;background-image:var(--slider-rocket);background-size:contain;background-repeat:no-repeat;background-position:center;cursor:pointer;transition:filter .2s}#orbitsSlider:hover::-webkit-slider-thumb{filter:drop-shadow(0 0 6px var(--accent-primary));box-shadow:none}#orbitsSlider:hover::-moz-range-thumb{filter:drop-shadow(0 0 6px var(--accent-primary));box-shadow:none}.rocket-steam-puff.slider-puff{z-index:10;animation-duration:.8s}.control input[type=color]{width:36px;height:24px;padding:0;border:1px solid var(--input-border);border-radius:var(--border-radius);background:transparent;cursor:pointer}.control input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.control input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}.control select,.floating-inline-panel select{width:100%;padding:6px 8px;border-radius:var(--border-radius);border:1px solid transparent;background:transparent;color:var(--text-bright);font-size:.75rem;font-family:var(--font-family)}.control select:hover,.floating-inline-panel select:hover,.control select:focus,.floating-inline-panel select:focus{border-color:var(--input-border);background:var(--input-bg);outline:none}.control select option,.floating-inline-panel select option{background:var(--canvas-bg);color:var(--text-bright)}.color-row{display:flex;align-items:center;justify-content:space-between}.color-row label{font-weight:600;color:var(--text-bright);font-size:.6875rem}.camera-row{display:flex;gap:6px;align-items:center}.camera-row select{flex:1}.gamepad-btn{width:32px;height:32px;padding:6px;border-radius:var(--border-radius);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.gamepad-btn:hover,.gamepad-btn:focus{background:var(--btn-hover-bg);color:var(--text-bright);outline:none}.gamepad-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--canvas-bg)}.gamepad-btn svg{width:18px;height:18px}.btn-visibility{width:16px;height:16px;padding:2px;border-radius:var(--border-radius);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-left:-2px}.btn-visibility:hover,.btn-visibility:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-visibility.visible{opacity:.8;color:var(--text-muted)}.btn-visibility.visible:hover,.btn-visibility.visible:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-visibility svg{width:12px;height:12px}.object-header .btn-visibility{width:22px;height:22px}.object-header .btn-visibility svg{width:16px;height:16px}.btn-freeze{width:16px;height:16px;padding:2px;border-radius:var(--border-radius);border:none;background:transparent;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:.5;margin-left:-4px;flex-shrink:0}.btn-freeze:hover,.btn-freeze:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-freeze.playing{opacity:.6;color:var(--text-muted)}.btn-freeze.playing:hover,.btn-freeze.playing:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-freeze svg{width:12px;height:12px}.object-header .btn-freeze{width:22px;height:22px}.object-header .btn-freeze svg{width:16px;height:16px}.preset-row{display:flex;gap:8px;align-items:center}.preset-row select{flex:1}.preset-actions{display:flex;gap:2px}.text-path-row{display:flex;gap:8px;align-items:center}.text-path-row input[type=text]{flex:1;padding:6px 8px;border-radius:var(--border-radius);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-bright);font-family:var(--font-family);font-size:.75rem}.text-path-row input[type=text]:focus{outline:none;border-color:var(--accent-primary)}.text-path-row .btn-icon{padding:5px;border:1px solid var(--input-border);border-radius:var(--border-radius);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center}.text-path-row .btn-icon svg{width:16px;height:16px}.text-path-row .btn-icon.active{color:var(--accent-primary);border-color:var(--accent-primary)}.btn-primary-sm{display:inline-flex;align-items:center;justify-content:center;padding:5px 12px;font-size:.6875rem;font-family:inherit;border-radius:var(--border-radius);border:1px solid var(--accent-primary);background:transparent;color:var(--accent-primary);cursor:pointer;white-space:nowrap;transition:opacity .15s;appearance:none;-webkit-appearance:none}.btn-primary-sm:hover{opacity:.85}.path-image-row{display:flex;flex-direction:column;gap:10px}.path-upload-btn{width:100%;justify-content:center;padding:8px 12px;font-size:.75rem}.path-upload-btn.active{background:var(--btn-primary-bg)}.path-preview-meta{display:flex;align-items:center;gap:10px;min-height:42px;padding:8px 10px;border:1px solid var(--input-border);border-radius:var(--border-radius);background:var(--input-bg)}.image-file-name{min-width:0;flex:1;max-width:none;font-size:.6875rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.path-launch-row{justify-content:center;gap:12px;padding-top:2px}.path-preview-thumb{width:40px;height:40px;border-radius:var(--border-radius);object-fit:cover;flex-shrink:0}.path-preview-thumb:not([src]),.path-preview-thumb[src=""]{display:none}.path-history-list:empty+.path-history-clear{display:none}.path-history-section{margin-top:0;border-top:1px solid var(--section-border);padding-top:8px}.path-history-header{font-size:.625rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.path-mode-row{padding:0}.path-mode-tabs{display:flex;width:100%;gap:0;border-bottom:1px solid var(--border-color)}.path-mode-tab{flex:1;padding:6px 0;font-size:.75rem;font-weight:600;font-family:inherit;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.path-mode-tab:hover{color:var(--text-bright)}.path-mode-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.path-history-item.active{background:var(--btn-primary-bg);color:var(--accent-primary)}.path-history-list{display:flex;flex-direction:column;gap:2px;max-height:240px;overflow-y:auto}.path-history-item{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:var(--border-radius);cursor:pointer;font-size:.6875rem;color:var(--text-color)}.path-history-item:hover{background:var(--btn-hover-bg)}.path-history-item .path-history-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.path-history-item .path-history-thumb{width:20px;height:20px;border-radius:3px;object-fit:cover;flex-shrink:0}.path-history-item .path-history-del{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem;padding:0 2px;flex-shrink:0}.path-history-item .path-history-del:hover{color:var(--accent-danger)}.path-history-clear{width:100%;margin-top:6px;padding:4px;font-size:.625rem;font-family:inherit;background:transparent;border:1px dashed var(--border-color);border-radius:var(--border-radius);color:var(--text-muted);cursor:pointer}.path-history-clear:hover{border-color:var(--accent-danger);color:var(--accent-danger)}.button-row{display:flex;gap:8px;flex-wrap:wrap}.btn-default{flex:1;padding:10px 12px;border-radius:var(--border-radius);border:1px solid transparent;background:transparent;color:var(--text-muted);font-weight:700;cursor:pointer;font-family:var(--font-family)}.btn-default:hover,.btn-default:focus{border-color:var(--btn-border);background:var(--btn-hover-bg);color:var(--text-bright);outline:none}.btn-primary{padding:6px 12px;border-radius:var(--border-radius);border:1px solid transparent;background:transparent;color:var(--text-muted);font-weight:600;cursor:pointer;font-family:var(--font-family)}.btn-primary:hover,.btn-primary:focus{border-color:var(--btn-border);background:var(--btn-primary-hover);color:var(--text-bright);outline:none}.btn-primary.full-width{flex:1;padding:10px 12px;border-radius:var(--border-radius);font-weight:700}.btn-danger{padding:6px 12px;border-radius:var(--border-radius);border:1px solid transparent;background:transparent;color:var(--accent-danger);font-weight:600;cursor:pointer;font-family:var(--font-family);opacity:.7}.btn-danger:hover,.btn-danger:focus{border-color:var(--accent-danger);background:var(--danger-bg-hover);opacity:1;outline:none}.btn-icon-default{background:transparent;border:none;color:var(--text-muted);width:20px;height:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.5;transition:all .15s ease}.btn-icon-default svg{width:18px;height:18px}.btn-icon-default:hover,.btn-icon-default:focus{opacity:1;color:var(--text-bright);transform:scale(1.2);outline:none}.btn-icon-default.btn-success-flash{color:var(--accent-success);opacity:1}.btn-icon-danger{background:transparent;border:none;color:var(--accent-danger);width:20px;height:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.5;transition:all .15s ease}.btn-icon-danger svg{width:18px;height:18px}.btn-icon-danger:hover,.btn-icon-danger:focus{opacity:1;color:var(--accent-danger);transform:scale(1.2);outline:none}#bottomHud{position:fixed;bottom:14px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;z-index:20;transition:transform .35s ease}#playbackControls{display:flex;align-items:center;gap:6px;padding:8px 16px 12px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:50px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.playback-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--btn-border);border-radius:50%;background:var(--btn-bg);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.playback-btn svg{width:20px;height:20px}.playback-btn:hover,.playback-btn:focus{background:var(--btn-hover-bg);border-color:var(--accent-primary);color:var(--accent-primary);transform:scale(1.05);outline:none}.playback-btn:active{transform:scale(.95)}.playback-btn:disabled{opacity:.5;cursor:default;pointer-events:none}.playback-btn-ghost{background:transparent;border-color:transparent}.playback-btn-ghost:hover,.playback-btn-ghost:focus{background:transparent;color:var(--text-bright);border-color:var(--btn-border)}.playback-btn-ghost.active:hover,.playback-btn-ghost.active:focus{border-color:var(--accent-primary)}.pb-grid{display:flex;justify-content:center;gap:2px}.pb-grid .playback-btn{width:24px;height:24px;border-radius:50%}.pb-grid .playback-btn svg{width:13px;height:13px}.playback-btn-ghost.active{color:var(--text-bright);border-color:var(--accent-primary);border-radius:50%}#presetsBtn{display:none}.playback-btn-main{width:56px;height:56px;margin-bottom:-6px;background:var(--btn-primary-bg);border-color:var(--accent-primary);color:var(--accent-primary)}.playback-btn-main svg{width:26px;height:26px}.playback-btn-main:hover,.playback-btn-main:focus{background:var(--btn-primary-hover);box-shadow:0 0 20px var(--glow-playback);outline:none}.speed-control,.core-speed-control{display:flex;align-items:center;gap:2px}.speed-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease;opacity:.6}.speed-btn svg{width:18px;height:18px}.speed-btn:hover,.speed-btn:focus{opacity:1;color:var(--accent-primary);transform:scale(1.2);outline:none}.speed-btn:active{transform:scale(.9)}.speed-value{font-size:.9375rem;font-weight:600;color:var(--text-bright);min-width:40px;text-align:center;-webkit-user-select:none;user-select:none;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .15s ease,transform .15s ease}.speed-column{position:relative;display:flex;flex-direction:column;align-items:center;min-width:90px}.speed-column .pb-grid{position:absolute;bottom:-20px;left:50%;transform:translate(-50%)}.speed-value-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.speed-sublabel{position:absolute;top:-12px;left:50%;transform:translate(-50%);font-size:.4625rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);line-height:1;white-space:nowrap}.speed-value:hover{background:var(--fill-visible);transform:scale(1.1)}.speed-value.core{min-width:32px;color:var(--text-bright)}.toggle-switch{position:relative;display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:.6875rem;font-weight:600;color:var(--text-bright)}.toggle-switch input{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:36px;height:20px;background:var(--section-bg);border:1px solid var(--input-border);border-radius:10px;transition:all .2s ease}.toggle-slider:before{content:"";position:absolute;width:14px;height:14px;left:2px;top:2px;background:var(--text-muted);border-radius:50%;transition:all .2s ease}.toggle-switch input:checked+.toggle-slider{background:var(--btn-primary-bg);border-color:var(--accent-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(16px);background:var(--accent-primary)}.toggle-switch.bodies input:checked+.toggle-slider{border-color:var(--accent-success)}.toggle-switch.bodies input:checked+.toggle-slider:before{background:var(--accent-success)}.toggle-switch.orbits input:checked+.toggle-slider{border-color:var(--accent-secondary)}.toggle-switch.orbits input:checked+.toggle-slider:before{background:var(--accent-secondary)}.toggle-switch.trails input:checked+.toggle-slider{border-color:var(--accent-primary)}.toggle-switch.trails input:checked+.toggle-slider:before{background:var(--accent-primary)}.toggle-switch.trails-long input:checked+.toggle-slider:before{background:var(--accent-primary)}.toggle-switch.trails-short input:checked+.toggle-slider:before{background:var(--accent-secondary)}.forces-section{margin-top:8px;padding-top:8px;border-top:1px solid var(--input-border)}.forces-row{display:flex;gap:12px}.force-block{flex:1;min-width:0}.force-header{display:flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none}.force-label{font-size:.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:color .2s}.force-label:hover,.force-block.expanded .force-label{color:var(--text-bright)}.force-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--text-muted);background:transparent;padding:0;cursor:pointer;transition:all .2s;flex-shrink:0}.force-dot:hover{border-color:var(--text-bright)}.force-dot.active{background:var(--accent-danger);border-color:var(--accent-danger)}#blackHoleDot.active{background:var(--accent-secondary);border-color:var(--accent-secondary)}.force-params{display:none;margin-top:6px}.force-params .control label{font-weight:400;font-size:.5rem}.force-block.expanded .force-params{display:block}.toggle-switch.grid input:checked+.toggle-slider{border-color:var(--text-muted)}.toggle-switch.grid input:checked+.toggle-slider:before{background:var(--text-muted)}.toggle-row{display:flex;gap:10px;padding:4px 0}.toggle-row-labeled{display:flex;justify-content:space-between;gap:8px;padding:6px 0}.toggle-item{display:flex;flex-direction:column;align-items:center;gap:4px}.toggle-label{font-size:.625rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.pb-stat-group{display:flex;flex-direction:column;align-items:center;gap:4px}.pb-stat-btns{display:flex;gap:6px;margin-bottom:-6px}.stats-cell{display:flex;align-items:baseline;gap:4px;justify-content:center;pointer-events:none}.stats-value{font-size:.75rem;font-weight:800;color:var(--text-bright);font-variant-numeric:tabular-nums}.stats-label{font-size:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}@media(max-width:402px){#bottomHud{width:min(402px,calc(100vw - 24px))}#playbackControls{width:100%;justify-content:space-between;gap:4px;padding:6px 10px 10px;border-radius:42px}.speed-column{min-width:72px}.speed-column .pb-grid{bottom:-18px}.pb-stat-group{gap:3px}.pb-stat-btns{gap:4px;margin-bottom:-5px}.playback-btn{width:30px;height:30px}.playback-btn svg{width:18px;height:18px}.pb-grid .playback-btn{width:22px;height:22px}.pb-grid .playback-btn svg{width:12px;height:12px}.playback-btn-main{width:50px;height:50px;margin-bottom:-4px}.playback-btn-main svg{width:24px;height:24px}.speed-btn{width:24px;height:24px}.speed-btn svg{width:16px;height:16px}.speed-value{min-width:34px;font-size:.875rem;padding:1px 3px}.speed-value.core{min-width:28px}.speed-sublabel{top:-10px;font-size:.42rem}.stats-value{font-size:.6875rem}.stats-label{font-size:.46rem;letter-spacing:.8px}}.history-list-dialog{min-width:320px;max-width:420px}.history-list-dialog .option-list{max-height:400px}.history-list-dialog .option-item{display:flex;justify-content:space-between;align-items:center}.history-list-dialog .option-item .history-item-time{font-size:.625rem;color:var(--text-muted);margin-left:12px;flex-shrink:0;opacity:.6}.history-list-dialog .option-item.current{border-left:3px solid var(--accent-primary)}.history-icon-buttons{display:flex;align-items:center;gap:2px;justify-self:start}.history-icon-buttons .icon-btn{width:28px;height:28px;border-radius:50%;border:1px solid transparent;background:transparent;color:var(--text-muted);opacity:.5}.history-icon-buttons .icon-btn:hover,.history-icon-buttons .icon-btn:focus{opacity:1;color:var(--text-bright);background:var(--btn-hover-bg);border-color:var(--btn-border)}.history-icon-buttons .icon-btn.active{opacity:1;color:var(--accent-primary);background:var(--btn-primary-bg);border-color:var(--accent-primary)}.history-icon-buttons .icon-btn svg{width:14px;height:14px}.history-toggles{display:flex;align-items:center;gap:2px;justify-self:end}.history-toggle{display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none}.history-toggle input{position:absolute;opacity:0;width:0;height:0}.history-toggle-label{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:.6875rem;font-weight:700;color:var(--text-muted);background:transparent;border:1px solid transparent;transition:all .15s ease;opacity:.4}.history-toggle input:checked+.history-toggle-label{opacity:1;color:var(--text-bright);background:var(--btn-primary-bg);border-color:var(--accent-primary)}.history-toggle:hover .history-toggle-label{opacity:.8;background:var(--btn-hover-bg)}.history-toggle-label svg{width:14px;height:14px}.y-axis-overlay{position:fixed;width:1px;background:var(--accent-primary);opacity:.6;z-index:50;pointer-events:none;display:none}.y-axis-grid-dot{position:fixed;width:10px;height:10px;border-radius:50%;background:var(--accent-primary);z-index:51;pointer-events:none;display:none}.y-axis-label{position:fixed;top:50%;padding:2px 8px;background:var(--panel-bg);border:1px solid var(--accent-primary);border-radius:var(--border-radius);color:#fff;font-size:.6875rem;font-weight:700;white-space:nowrap;z-index:51;pointer-events:none;display:none}.docs-overlay{display:none;position:fixed;inset:0;z-index:3000;background:var(--overlay-medium);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center}.docs-overlay.visible{display:flex}.docs-panel{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:min(640px,90vw);max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.docs-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 0;border-bottom:1px solid var(--border-color)}.docs-tabs{display:flex;gap:0}.docs-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.8rem;font-family:inherit;padding:8px 16px;cursor:pointer;transition:color .15s,border-color .15s}.docs-tab:hover{color:var(--text-bright)}.docs-tab.active{color:var(--text-bright);font-weight:600;border-bottom-color:var(--accent-primary)}.docs-close{background:none;border:none;color:var(--text-secondary);font-size:1.4rem;cursor:pointer;padding:4px 8px;line-height:1}.docs-close:hover{color:var(--text-bright)}.docs-body{padding:16px 20px;overflow-y:auto;font-size:.8rem;line-height:1.6;color:var(--text-color)}.docs-content{display:none}.docs-content.active{display:block}.docs-content h3{color:var(--text-bright);font-size:.85rem;margin:16px 0 6px;font-weight:600}.docs-content h3:first-child{margin-top:0}.docs-content p{margin:0 0 8px}.docs-content pre{background:var(--section-params-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:10px 12px;font-size:.75rem;line-height:1.5;overflow-x:auto;margin:6px 0 12px;color:var(--text-bright)}.docs-shortcuts-table{width:100%;border-collapse:collapse;margin:6px 0 16px;font-size:.8rem}.docs-shortcuts-table th{text-align:left;color:var(--text-bright);font-weight:600;padding:6px 12px 6px 0;border-bottom:1px solid var(--border-color)}.docs-shortcuts-table td{padding:5px 12px 5px 0;border-bottom:1px solid rgba(255,255,255,.05)}.docs-shortcuts-table td:first-child{color:var(--text-bright);white-space:nowrap;font-family:var(--font-mono, monospace);font-size:.75rem}.docs-killer-stat{text-align:center;font-size:3rem;font-weight:800;color:var(--accent-primary);letter-spacing:-.02em;line-height:1;margin:20px 0 4px}.docs-killer-unit{font-size:.4em;font-weight:400;color:var(--text-muted);margin-left:4px;vertical-align:super}.docs-killer-sub{text-align:center;font-size:.8rem;color:var(--text-color);margin:0 0 16px;opacity:.7}.code-overlay{display:none;position:fixed;inset:0;z-index:3000;background:var(--overlay-medium);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center}.code-overlay.visible{display:flex}.code-panel{position:relative;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:min(700px,92vw);height:75vh;display:flex;flex-direction:column}.code-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 0;border-bottom:1px solid var(--border-color)}.code-tabs{display:flex;gap:0}.code-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted, #666);font-size:.8rem;font-family:inherit;padding:8px 16px;cursor:pointer;transition:color .15s,border-color .15s}.code-tab:hover{color:var(--text-color, #333)}.code-tab.active{color:var(--text-color, #333);border-bottom-color:var(--accent-primary)}.code-body{overflow-y:auto;padding:0;flex:1;min-height:0}.code-content{display:none;padding:12px 16px}.code-content.active{display:block}body:not(.light-mode) .json-key{--json-key: #c4b5fd}body:not(.light-mode) .json-string{--json-string: #86efac}body:not(.light-mode) .json-number{--json-number: #93c5fd}body:not(.light-mode) .json-bool{--json-bool: #fbbf24}.json-tree{font-family:var(--font-mono, "SF Mono", "Menlo", monospace);font-size:.75rem;line-height:1.6;color:var(--text-secondary)}.json-key{color:var(--json-key, #7c3aed)}.json-string{color:var(--json-string, #16a34a)}.json-number{color:var(--json-number, #2563eb)}.json-bool{color:var(--json-bool, #d97706)}.json-null{color:var(--json-null, #6b7280);font-style:italic}.json-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-block;width:14px;text-align:center;color:var(--text-secondary);opacity:.5;font-size:.65rem}.json-toggle:hover{opacity:1;color:var(--accent-primary)}.json-bracket{color:var(--text-secondary);opacity:.5}.json-collapsed-hint{color:var(--text-secondary);opacity:.35;font-style:italic;font-size:.7rem}.json-children{padding-left:18px}.json-line{white-space:nowrap}.code-encoded-pre{font-family:var(--font-mono, "SF Mono", "Menlo", monospace);font-size:.75rem;line-height:1.6;color:var(--text-bright);background:var(--section-params-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:12px;margin:0;word-break:break-all;white-space:pre-wrap;-webkit-user-select:all;user-select:all}.code-copy-btn{position:absolute;bottom:12px;right:12px;z-index:1;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);font-size:.75rem;font-family:inherit;padding:5px 14px;cursor:pointer;transition:color .15s,border-color .15s}.code-copy-btn:hover{color:var(--text-bright);border-color:var(--text-secondary)}.code-copy-btn.copied{color:var(--accent-primary);border-color:var(--accent-primary)}.code-decode-url-input{display:flex;gap:8px;margin-bottom:10px}.code-decode-url-input input{flex:1;padding:8px 10px;background:var(--section-params-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-bright);font-size:.8rem;font-family:inherit;outline:none}.code-decode-url-input input:focus{border-color:var(--accent-primary)}.code-decode-url-input button{padding:7px 16px;background:var(--accent-primary);border:none;border-radius:var(--border-radius);color:#fff;font-size:.8rem;font-family:inherit;font-weight:500;cursor:pointer}.code-decode-url-input button:hover{opacity:.85}.import-overlay{display:none;position:fixed;inset:0;z-index:3000;background:var(--overlay-medium);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center}.import-overlay.visible{display:flex}.import-panel{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:min(340px,90vw)}.import-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color)}.import-title{font-size:.85rem;font-weight:600;color:var(--text-bright)}.import-body{padding:12px;display:flex;flex-direction:column;gap:6px}.import-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:#ffffff0a;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);font-size:.8rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.import-option:hover{background:#ffffff14;color:var(--text-bright)}.import-option svg{flex-shrink:0;width:18px;height:18px}#importUrlField{display:block;width:calc(100% - 20px);box-sizing:border-box;padding:8px 10px;margin:10px 10px 0;background:var(--section-params-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-bright);font-size:.8rem;font-family:inherit}#importUrlField,#importUrlField:focus,#importUrlField:focus-visible{outline:2px solid transparent;box-shadow:none}#importUrlField:focus{border-color:var(--accent-primary)}#importUrlSubmit{display:block;margin:10px;padding:7px 16px;background:var(--accent-primary);border:none;border-radius:var(--border-radius);color:#fff;font-size:.8rem;font-family:inherit;font-weight:500;cursor:pointer}#importUrlSubmit:hover{opacity:.85}#importUrlError{color:#f87171;font-size:.75rem;margin:0 10px}.color-picker-popup{display:none;position:fixed;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);z-index:2000;min-width:200px;padding:12px}.color-picker-popup.visible{display:block}.color-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.75rem;color:var(--text-bright)}.color-picker-close{background:transparent;border:none;color:var(--text-muted);font-size:1.125rem;cursor:pointer;padding:0;line-height:1}.color-picker-close:hover,.color-picker-close:focus{color:var(--text-bright);outline:none}.color-picker-palette{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;margin-bottom:10px}.color-picker-swatch{width:20px;height:20px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform .1s ease,border-color .1s ease}.color-picker-swatch:hover{transform:scale(1.15)}.color-picker-swatch.selected{border-color:var(--text-bright)}.color-picker-custom{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-top:8px;border-top:1px solid var(--border-color)}.color-picker-custom input[type=color]{width:32px;height:24px;border:none;border-radius:4px;cursor:pointer;padding:0}.color-picker-custom label{font-size:.6875rem;color:var(--text-muted)}.object-modal-overlay{position:fixed;inset:0;background:var(--overlay-heavy);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;justify-content:center;align-items:center;z-index:1000}.object-modal-overlay.visible{display:flex}.object-modal-overlay.context-menu{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;pointer-events:none}.object-modal-overlay.context-menu .object-modal{pointer-events:auto;animation:contextMenuIn .15s ease-out}@keyframes contextMenuIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.object-modal{background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--frosted-blur));backdrop-filter:blur(var(--frosted-blur));border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);padding:16px;width:280px;max-height:85vh;overflow-y:auto}.object-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--panel-border)}.object-modal-title{font-size:1rem;font-weight:700;color:var(--text-bright);display:flex;align-items:center;gap:10px}.modal-scope-toggle{width:20px;height:20px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:border-color .15s,color .15s}.modal-scope-toggle svg{width:12px;height:12px}.modal-scope-toggle:focus,.modal-scope-toggle:focus-visible{outline:none}.modal-scope-toggle.active{border-color:#ff8c00;color:#ff8c00}.object-modal-title .color-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--input-border)}.object-modal-close{background:transparent;border:none;color:var(--accent-primary);font-size:1.25rem;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius)}.object-modal-close:hover,.object-modal-close:focus{background:var(--btn-bg);outline:none}.object-modal-body{display:grid;gap:8px}.object-modal-section{padding:10px 0 0}.object-modal-section:first-child{padding-top:0;border-top:none}.modal-orbit-style-bar{display:flex!important;justify-content:flex-start;gap:10px;border-bottom:none;padding:8px 0 14px}.object-modal-section-title{font-size:.75rem;font-weight:400;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.object-modal-section-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.section-arrow{font-size:.7rem;color:var(--accent-primary);opacity:.6;transition:opacity .15s}.object-modal-section-toggle:hover .section-arrow{opacity:1}.modal-orbit-style-bar .icon-btn{width:22px;height:22px;border-radius:50%}.modal-orbit-style-bar .icon-btn svg{width:13px;height:13px;flex-shrink:0}.modal-orbit-style-bar .orbit-style-toggle{width:22px;height:22px;border:1px solid var(--input-border);border-radius:50%;background:var(--btn-bg);color:var(--text-muted);opacity:1}.modal-orbit-style-bar .orbit-style-toggle.active{color:var(--text-bright);border-color:var(--accent-primary)}.modal-orbit-style-bar .orbit-style-toggle:hover{background:var(--btn-hover-bg)}.modal-orbit-style-bar .orbit-style-divider{margin-left:2px;margin-right:2px}#modalOrbitStylePickerPanel{z-index:1201}.object-modal-footer{display:flex;gap:10px;margin-top:16px;padding-top:12px;border-top:1px solid var(--section-border)}.object-modal-footer .btn-primary{flex:1;padding:10px;font-weight:700}.object-modal-footer .btn-danger{padding:10px 16px;flex:1}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--overlay-medium);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:1000}.dialog-overlay.visible{display:flex}.dialog-box{background:var(--modal-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);padding:24px;min-width:320px;max-width:400px;animation:dialogIn .2s ease-out}@keyframes dialogIn{0%{opacity:0;transform:scale(.92) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.dialog-title{font-size:1rem;font-weight:700;color:var(--text-bright);margin-bottom:16px}.dialog-body{margin-bottom:20px;color:var(--text-color);font-size:.8125rem}.dialog-body input[type=text]{width:100%;padding:10px 12px;border-radius:var(--border-radius);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-bright);font-size:.875rem;font-family:var(--font-family);outline:none;box-sizing:border-box;transition:border-color .2s}.dialog-body input[type=text]:focus{border-color:var(--accent-primary)}.dialog-body .dialog-message{line-height:1.5}.dialog-notice{border:1px solid var(--panel-border);border-radius:var(--border-radius);padding:10px 12px;background:var(--btn-bg)}.dialog-notice-warning{border-color:color-mix(in srgb,var(--accent-primary) 55%,var(--panel-border));background:color-mix(in srgb,var(--btn-primary-bg) 45%,transparent)}.dialog-notice-title{font-size:.8125rem;font-weight:700;color:var(--text-bright);margin-bottom:6px}.dialog-notice-text{font-size:.75rem;line-height:1.45;color:var(--text-muted)}.dialog-body .dialog-error{color:var(--accent-danger);margin-top:8px;font-size:.75rem}.dialog-footer{display:flex;gap:10px;justify-content:flex-end}.dialog-btn{padding:8px 20px;border-radius:var(--border-radius);font-size:.8125rem;font-weight:600;cursor:pointer;font-family:var(--font-family);transition:background .15s,border-color .15s}.dialog-footer .btn-default{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--text-muted)}.dialog-footer .btn-default:hover,.dialog-footer .btn-default:focus{background:var(--btn-hover-bg);color:var(--text-bright);outline:none}.dialog-footer .btn-primary{background:var(--btn-primary-bg);border:1px solid var(--accent-primary);color:var(--text-bright)}.dialog-footer .btn-primary:hover,.dialog-footer .btn-primary:focus{background:var(--btn-primary-hover);outline:none}.dialog-footer .btn-danger{background:var(--danger-bg);border:1px solid var(--accent-danger);color:var(--accent-danger)}.dialog-footer .btn-danger:hover,.dialog-footer .btn-danger:focus{background:var(--danger-bg-hover);outline:none}.modal-visibility-row{display:flex;gap:12px;align-items:center}.vis-color-picker{width:36px;height:24px;padding:0;border:1px solid var(--input-border);border-radius:var(--border-radius);background:transparent;cursor:pointer;flex-shrink:0}.vis-color-picker::-webkit-color-swatch-wrapper{padding:2px}.vis-color-picker::-webkit-color-swatch{border:none;border-radius:2px}.modal-visibility-item{display:flex;align-items:center;gap:6px;font-size:.75rem}.modal-visibility-item input{width:16px;height:16px;accent-color:var(--accent-primary)}.modal-visibility-item.orbit input{accent-color:var(--accent-secondary)}.modal-add-objects-row{display:flex;gap:12px;align-items:flex-end}.modal-slider-wrap{flex:1}.modal-slider-wrap label{display:flex;justify-content:space-between;font-size:.6875rem;font-weight:400;color:var(--text-muted);margin-bottom:4px}.modal-slider-wrap .slider-value{color:var(--accent-primary);font-weight:600}.modal-slider-wrap input[type=range]{width:100%}.btn-add-objects{padding:6px 16px;font-size:.75rem;white-space:nowrap}.modal-max-reached{font-size:.6875rem;color:var(--text-muted);text-align:center;padding:8px}.signout-profile{display:flex;align-items:center;gap:12px;padding:8px 0}.signout-avatar{width:48px;height:48px;border-radius:50%;border:2px solid var(--border-color);flex-shrink:0}.signout-name{font-size:.875rem;font-weight:600;color:var(--text-bright)}.signout-email{font-size:.75rem;color:var(--text-muted);margin-top:2px}.terms-overlay{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:var(--overlay-heavy);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:opacity .3s ease}.terms-overlay.fade-out{opacity:0}.terms-box{background:var(--modal-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:min(520px,90vw);max-height:85vh;display:flex;flex-direction:column;animation:dialogIn .2s ease-out}.terms-header{padding:20px 24px 16px;font-size:1rem;font-weight:700;color:var(--text-bright);border-bottom:1px solid var(--section-border);flex-shrink:0}.terms-body{padding:16px 24px;overflow-y:auto;flex:1;color:var(--text-color);font-size:.8125rem;line-height:1.6}.terms-body h2{font-size:.9375rem;font-weight:700;color:var(--accent-primary);margin:24px 0 12px}.terms-body h2:first-child{margin-top:4px}.terms-body h3{font-size:.8125rem;font-weight:600;color:var(--text-bright);margin:16px 0 6px}.terms-body p{margin:0 0 8px}.terms-body ul{margin:0 0 8px;padding-left:20px}.terms-body li{margin-bottom:4px}.terms-body a{color:var(--accent-primary);text-decoration:none}.terms-body a:hover{text-decoration:underline}.terms-footer{padding:16px 24px;border-top:1px solid var(--section-border);display:flex;justify-content:flex-end;flex-shrink:0}.terms-footer .dialog-btn{min-width:120px}.terms-footer .dialog-btn:disabled{opacity:.4;cursor:not-allowed}
