*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg,#f7f8fb);color:var(--text,#0f172a);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}:root,:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{scrollbar-width:thin;scrollbar-color:#0f172a38 #0f172a14}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#0f172a0f}::-webkit-scrollbar-thumb{background:#0f172a38;border:2px solid #ffffffb3;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#0f172a52}:root[data-theme=dark] *{scrollbar-color:#e8eef547 #e8eef51a}:root[data-theme=dark] ::-webkit-scrollbar-track{background:#e8eef514}:root[data-theme=dark] ::-webkit-scrollbar-thumb{background:#e8eef542;border:2px solid #0a0e16d9}:root[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#e8eef55c}button,input,select,textarea{font:inherit}button{cursor:pointer}:root{--z-canvas-overlay:20;--z-mobile-toolstrip:30;--z-panel-layer:40;--z-dropdown:60;--z-modal:80;--al-stage-top:72px;--al-stage-bottom:72px;--al-stage-height:calc(100dvh - var(--al-stage-top) - var(--al-stage-bottom));--al-left-stack-pane-h:calc(var(--al-stage-height) / 2)}:root,:root[data-theme=light]{--bg:#f7f8fb;--stage-bg:var(--field);--bg-elevated:#fff;--field:#fbfaf5;--panel:#ffffffe0;--panel-2:#fffffff5;--line:#0f172a1a;--line-strong:#2563eb52;--muted:#64748b;--text:#0f172a;--blue:#2563eb;--blue-dim:#2563eb1a;--green:#10b981;--gold:#eab308;--red:#ef4444;--vignette:#0f172a0f;--focus-ring:0 0 0 2px var(--bg), 0 0 0 4px #2563eb73}:root[data-theme=light] .topbar-metrics{background:#ffffffe0;border-color:#0f172a24}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:root[data-theme=dark]{--bg:#05080d;--stage-bg:var(--field);--bg-elevated:#0a1018;--field:#0a0f16;--panel:#0e1420e0;--panel-2:#121a28f0;--line:#ffffff1a;--line-strong:#60a5fa59;--muted:#a3b1c2;--text:#e8eef5;--blue:#60a5fa;--blue-dim:#60a5fa24;--green:#58b882;--gold:#dead46;--red:#e8665a;--vignette:#00000073;--focus-ring:0 0 0 2px var(--bg), 0 0 0 4px #60a5faa6}:root[data-theme=dark] .topbar-sims,:root[data-theme=dark] .topbar-group{background:#ffffff0a}:root[data-theme=dark] .topbar-metrics{background:#ffffff0d}:root[data-theme=dark] .button-grid button,:root[data-theme=dark] .preset-grid button,:root[data-theme=dark] .icon-button,:root[data-theme=dark] .transport-pill button,:root[data-theme=dark] .wide-button,:root[data-theme=dark] .modal-actions button{box-shadow:none;background:#ffffff0f;border-color:#ffffff1f}:root[data-theme=dark] .button-grid button:hover:not(.active),:root[data-theme=dark] .icon-button:hover,:root[data-theme=dark] .wide-button:hover,:root[data-theme=dark] .modal-actions button:hover{background:#60a5fa1a;border-color:#60a5fa59}:root[data-theme=dark] .button-grid button.active{background:#60a5fa24;border-color:#60a5fa8c;box-shadow:0 0 0 1px #60a5fa24}:root[data-theme=dark] .topbar-group,:root[data-theme=dark] .topbar-sims,:root[data-theme=dark] .topbar-metrics{border-color:#ffffff1f}:root[data-theme=dark] .tools-hint,:root[data-theme=dark] .floating-palette-card,:root[data-theme=dark] .floating-tool-button,:root[data-theme=dark] .floating-palette-hint,:root[data-theme=dark] .floating-palette-segmented,:root[data-theme=dark] .floating-palette-segmented button,:root[data-theme=dark] .sim-card,:root[data-theme=dark] .control-badge{color:var(--text);background:#ffffff0f;border-color:#ffffff1f}:root[data-theme=dark] .floating-palette-label,:root[data-theme=dark] .floating-palette-hint{color:#e8eef5c7}:root[data-theme=dark] .control-badge{color:#e8eef5b8}:root[data-theme=dark] .sim-card:hover:not(:disabled){background:#60a5fa1a;border-color:#60a5fa59}:root[data-theme=dark] .sim-card.is-active{background:#60a5fa24;border-color:#60a5fa8c}:root[data-theme=dark] .mobile-tool-strip__btn,:root[data-theme=dark] .mobile-tool-strip__btn--tools{background:#ffffff14;border-color:#ffffff1f}:root[data-theme=dark] .control-badge--warn{color:#e8665af2;background:#e8665a1f;border-color:#e8665a61}.app-shell{background:var(--bg);height:100dvh;min-height:100vh;box-shadow:none;flex-direction:column;padding:8px 14px 14px;display:flex;overflow:hidden}.app-header{margin-bottom:6px}.topbar{flex-direction:column;align-items:stretch;gap:6px;display:flex}.topbar.is-focus .topbar-row{gap:10px 12px}.topbar-row{flex-wrap:wrap;align-items:center;gap:12px 16px;min-width:0;display:flex}.topbar-mid{flex:200px;justify-content:center;min-width:0;display:flex}.topbar-group--state{flex-wrap:wrap;justify-content:center;max-width:100%}.topbar-metrics{border:1px solid var(--line);color:var(--muted);letter-spacing:.04em;background:#ffffff59;border-radius:999px;align-items:baseline;gap:4px 6px;padding:4px 10px 4px 8px;font-size:11px;font-weight:600;display:inline-flex}.topbar-metric-run.is-run{color:var(--green)}.topbar-metric-sep{opacity:.45;padding:0 1px}.topbar-metric-num{font-variant-numeric:tabular-nums;color:var(--text);font-size:12px;font-weight:800}.topbar-metric-num--quiet{letter-spacing:.02em;text-transform:none;opacity:.88;font-size:11px;font-weight:700}.topbar-metric-unit{letter-spacing:.14em;text-transform:uppercase;opacity:.65;font-size:9px;font-weight:800}.topbar-brand{flex-direction:column;flex:none;justify-content:center;gap:2px;min-width:0;display:flex}.topbar-brand-title-row{flex-wrap:wrap;align-items:center;gap:8px 12px;min-width:0;display:flex}.topbar-about-btn{border:1px solid var(--line);color:var(--muted);letter-spacing:.02em;cursor:pointer;background:#ffffff0f;border-radius:999px;align-items:center;gap:5px;margin:0;padding:4px 10px;font-size:12px;font-weight:600;line-height:1.2;display:inline-flex}.topbar-about-btn:hover{color:var(--text);border-color:var(--line-strong);background:#60a5fa1f}:root[data-theme=light] .topbar-about-btn{background:#ffffffa6}:root[data-theme=light] .topbar-about-btn:hover{background:#2563eb1a}.eyebrow{color:var(--blue);letter-spacing:.2em;text-transform:uppercase;font-size:11px;font-weight:600}h1{letter-spacing:-.03em;margin:0;font-size:22px;font-weight:700;line-height:1.15}.topbar-sims{border:1px solid var(--line);background:#ffffff6b;border-radius:999px;gap:5px;padding:3px;display:inline-flex}.topbar-sim{color:var(--muted);background:0 0;border:1px solid #0000;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.topbar-sim.is-on{color:var(--text);background:#60a5fa2e;border-color:#60a5faa6;box-shadow:0 10px 24px #0f172a1a}.telemetry-chip{z-index:22;pointer-events:none;border:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#e8eef5e0;background:#00000038;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:600;display:inline-flex;position:absolute;top:14px;right:14px}.telemetry-chip b{color:#e8eef5f5;font-weight:800}:root[data-theme=light] .telemetry-chip{border-color:var(--line);color:var(--text);background:#ffffffeb}:root[data-theme=light] .telemetry-chip b{color:var(--text)}.telemetry-chip .dot{opacity:.35}.telemetry-chip--focus{padding:6px 10px;font-size:11px;font-weight:600}.button-grid,.preset-grid{flex-wrap:wrap;gap:8px;display:flex}.button-grid button,.preset-grid button,.icon-button,.transport-pill button,.wide-button,.modal-actions button{border:1px solid var(--line);color:var(--text);background:#ffffffc7;border-radius:999px;padding:8px 14px;transition:border-color .14s,background .14s,box-shadow .14s,transform .14s}.button-grid button.active{background:#2563eb1f;border-color:#2563eb66;box-shadow:0 0 0 1px #2563eb2e,0 10px 26px #0f172a1a}.button-grid button:hover:not(.active){background:#ffffff12;border-color:#ffffff29}.preset-grid button{background:var(--panel-2);border-radius:14px;padding:9px 14px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #0003}.preset-grid button:hover{background:#60a5fa1f;border-color:#60a5fa73;transform:translateY(-1px);box-shadow:0 6px 16px #00000047}.preset-gallery-help,.preset-gallery-empty-imports{margin:0 0 10px;font-size:12px;line-height:1.45}.preset-gallery-groups{flex-direction:column;gap:12px;max-height:42vh;padding-right:4px;display:flex;overflow:auto}.preset-gallery-group,.preset-gallery-imports{border:1px solid var(--line);background:#0000001f;border-radius:12px;padding:8px 10px}.preset-gallery-sim{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:11px;font-weight:800}.preset-gallery-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.preset-gallery-row{align-items:flex-start;gap:8px;display:flex}.preset-gallery-meta{flex:1;min-width:0}.preset-gallery-name{color:var(--text);font-size:13px;font-weight:650}.preset-gallery-desc{margin-top:2px;font-size:11px;line-height:1.35}.preset-gallery-sim-pill{letter-spacing:.04em;text-transform:uppercase;margin-top:4px;font-size:10px;font-weight:700;display:inline-block}.preset-gallery-apply{border:1px solid var(--line);background:var(--panel-2);color:var(--text);cursor:pointer;border-radius:999px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:600}.preset-gallery-apply:hover{background:#60a5fa1f;border-color:#60a5fa73}.preset-gallery-imports{margin-top:12px}.icon-button,.transport-pill button{align-items:center;gap:8px;font-size:13px;font-weight:500;display:inline-flex}.icon-button.is-on{background:#60a5fa29;border-color:#60a5fa8c}.icon-button--primary{background:linear-gradient(#60a5fa38,#60a5fa1a);border-color:#60a5fa66}.icon-button--primary:hover{background:#60a5fa33;border-color:#60a5faa6}.icon-button--secondary{background:#ffffff0d}.icon-button--compact{gap:6px;padding:6px 11px;font-size:12px}.icon-button--ghost{color:var(--muted);background:0 0;border-color:#0000;padding:6px 9px}.icon-button--ghost:hover{color:var(--text);border-color:var(--line);background:#ffffff0f}.topbar-actions{background:0 0;border:none;border-radius:0;flex-wrap:wrap;flex:0 auto;justify-content:flex-end;align-items:center;gap:8px;margin-left:auto;padding:0;display:inline-flex}.topbar-group{border:1px solid var(--line);background:#ffffff61;border-radius:999px;gap:5px;padding:3px;display:inline-flex}.topbar-quick-actions{align-items:center;gap:6px;display:inline-flex}.topbar-group-label{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);align-self:center;padding:0 6px 0 8px;font-size:9px;font-weight:800}.topbar-dropdown{align-items:center;display:inline-flex;position:relative}.topbar-dropdown-menu{z-index:120;border:1px solid var(--line);background:var(--panel-2);border-radius:16px;gap:2px;min-width:240px;max-width:min(320px,92vw);padding:6px;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 18px 44px #0f172a2e}.topbar-dropdown-note{margin:0;padding:6px 10px 8px;font-size:11px;font-weight:500;line-height:1.4}.topbar-dropdown-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:600;display:flex}.topbar-dropdown-item:hover{background:#60a5fa1f}.topbar-dropdown-item--primary{color:var(--blue)}.topbar-dropdown-divider{background:var(--line);height:1px;margin:4px}.topbar-dropdown-item--quiet{color:var(--muted);font-size:12px;font-weight:500}.topbar-chip{color:var(--muted);letter-spacing:.02em;background:0 0;border:1px solid #0000;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.topbar-chip.is-on{color:var(--text);background:#60a5fa1a;border-color:#60a5fa73}.text-button{color:var(--muted);background:0 0;border:0;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none}.text-button:hover{color:var(--text);background:#ffffff0f}.topbar-error-slot{grid-column:1/-1;min-height:0}.topbar-error-slot.has-error{margin-top:2px}.topbar-error{color:var(--text);background:#e8665a1a;border:1px solid #e8665a66;border-radius:14px;padding:10px 14px;font-size:13px;line-height:1.45}.topbar-status{color:var(--text);background:#58b8821a;border:1px solid #58b88259;border-radius:14px;padding:10px 14px;font-size:13px;line-height:1.45}.topbar-warning{color:var(--text);background:#eab30814;border:1px solid #eab30873;border-radius:14px;margin-top:6px;padding:10px 14px;font-size:13px;line-height:1.45}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#00000094;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{border:1px solid var(--line);background:#0e1420f7;border-radius:20px;width:min(760px,92vw);padding:18px 20px 16px;box-shadow:0 24px 64px #0000008c,inset 0 0 0 1px #ffffff0a}:root[data-theme=light] .modal-backdrop{background:#0f172a6b}:root[data-theme=light] .modal{background:var(--bg-elevated);color:var(--text);box-shadow:0 24px 48px #0f172a2e,inset 0 0 0 1px #ffffffd9}.modal-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.modal-header strong{letter-spacing:-.02em;font-size:15px}.modal-textarea{resize:vertical;border:1px solid var(--line);width:100%;min-height:200px;color:var(--text);background:#ffffff0a;border-radius:14px;padding:12px 14px;line-height:1.45}.modal-textarea:focus{box-shadow:var(--focus-ring);border-color:#60a5fa8c;outline:none}.modal-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.modal-actions button[disabled]{opacity:.45;cursor:not-allowed}.modal--about{width:min(520px,92vw)}.about-modal-body{color:var(--text);font-size:14px;line-height:1.55}.about-modal-lead{margin:0 0 10px}.about-build-line{letter-spacing:.01em;margin:0 0 16px;font-size:12px}.about-modal-subhead{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:14px 0 8px;font-size:12px;font-weight:700}.about-modal-list{margin:0;padding-left:1.15rem}.about-modal-list--compact{font-size:13px;line-height:1.5}.about-modal-list li+li{margin-top:4px}.about-modal-license{margin:16px 0 0;font-size:12px}.about-modal-license code{border:1px solid var(--line);background:#ffffff0a;border-radius:6px;padding:1px 5px;font-size:11px}.workspace{flex:1;grid-template-columns:1fr;align-items:stretch;gap:16px;width:100%;min-height:0;display:grid;overflow:hidden}.workspace.is-focus{grid-template-columns:1fr}.stage-card{border:1px solid var(--line);background:var(--panel);border-radius:22px;overflow:hidden;box-shadow:0 18px 44px #0f172a1f,inset 0 0 0 1px #fff9}.al-panels-layer{pointer-events:none;z-index:40;position:fixed;inset:0}.al-panel{pointer-events:auto;border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:18px;width:min(420px,46vw);position:fixed;overflow:hidden;box-shadow:0 14px 36px #0f172a1a}.al-panel[data-panel-id=guide]{width:min(760px,82vw)}.al-panel[data-panel-id=guide] .al-panel-body{max-height:min(74vh,820px)}.al-panel--docked{left:14px;top:var(--al-stage-top)}.al-panel--docked[data-panel-id=controls]{left:auto;right:14px;top:var(--al-stage-top);flex-direction:column;display:flex;bottom:14px}.al-panel--docked[data-panel-id=controls] .al-panel-body{flex:1 1 0;min-height:0;max-height:none;overflow-y:auto}.al-panel--docked[data-panel-id=tools]{left:14px;right:auto;top:calc(var(--al-stage-top) + var(--al-left-stack-pane-h));height:var(--al-left-stack-pane-h);flex-direction:column;display:flex;bottom:auto}.al-panel--docked[data-panel-id=tools] .al-panel-body{flex:auto;min-height:0;max-height:none;overflow-y:auto}.al-panel--docked[data-panel-id=telemetry]{left:14px;right:auto;top:var(--al-stage-top);height:var(--al-left-stack-pane-h);flex-direction:column;display:flex;bottom:auto}.al-panel--docked[data-panel-id=telemetry] .al-panel-body{flex:auto;min-height:0;max-height:none;overflow-y:auto}.al-panel--floating[data-panel-id=telemetry],.al-panel--floating[data-panel-id=tools]{height:var(--al-left-stack-pane-h);flex-direction:column;display:flex}.al-panel--floating[data-panel-id=telemetry] .al-panel-body,.al-panel--floating[data-panel-id=tools] .al-panel-body{flex:auto;min-height:0;max-height:none;overflow-y:auto}.al-panel--docked[data-panel-id=guide]{top:auto;bottom:18px;left:14px}.al-panel-header{cursor:default;-webkit-user-select:none;user-select:none;background:linear-gradient(#ffffff0f,#0000);border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:9px 11px;display:flex}.al-panel--floating .al-panel-header{cursor:grab}.al-panel--floating .al-panel-header:active{cursor:grabbing}.al-panel-title-text{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:800}.al-panel-actions{opacity:.2;gap:5px;transition:opacity .16s;display:inline-flex}.al-panel:hover .al-panel-actions,.al-panel:focus-within .al-panel-actions{opacity:1}.al-panel-icon{width:28px;height:28px;color:var(--muted);background:0 0;border:1px solid #0000;border-radius:999px;place-items:center;padding:0;display:grid}.al-panel:hover .al-panel-icon,.al-panel:focus-within .al-panel-icon{border-color:var(--line);color:var(--text);background:#ffffff0f}.al-panel-body{max-height:min(72vh,720px);overflow:auto}.al-panel-collapsed{padding:10px 12px 12px}.stage-card{border-color:#2563eb2e;height:100%;min-height:0;display:block;position:relative;box-shadow:0 18px 44px #0f172a1f,inset 0 1px #ffffffa6}.stage-card:before{content:"";border-radius:inherit;pointer-events:none;z-index:0;background:0 0;position:absolute;inset:0}.stage-card>*{z-index:1;position:relative}.stage-card.stage-card--canvas-first{flex-direction:column;display:flex}.stage-card.stage-card--canvas-first>.canvas-host{flex:auto;height:auto;min-height:0}.canvas-host{background:var(--stage-bg);width:100%;height:100%;min-height:0;position:relative}:root[data-theme=dark] .canvas-host{background:var(--stage-bg)}.canvas-host.has-grid{background:linear-gradient(#0f172a09 1px, transparent 1px), linear-gradient(90deg, #0f172a09 1px, transparent 1px), var(--stage-bg);background-size:48px 48px,48px 48px,auto}:root[data-theme=dark] .canvas-host.has-grid{background:linear-gradient(#ffffff0a 1px, transparent 1px), linear-gradient(90deg, #ffffff0a 1px, transparent 1px), var(--stage-bg);background-size:48px 48px,48px 48px,auto}.ab-divider{pointer-events:none;background:#0f172a1a;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-1px)}:root[data-theme=dark] .ab-divider{background:#ffffff1f}.ab-label{letter-spacing:.04em;color:#0f172ae0;pointer-events:none;background:#ffffffc2;border:1px solid #0f172a1a;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:700;position:absolute;top:12px}:root[data-theme=dark] .ab-label{color:#e8eef5eb;background:#0a0e16c7;border:1px solid #ffffff1f}.ab-label--left{left:12px}.ab-label--right{right:12px}.simulation-canvas{touch-action:none;image-rendering:auto;width:100%;height:100%;display:block}.control-panel,.stats-panel,.simulation-guide{padding:4px 0 2px}.control-panel-sliders{flex-direction:column;gap:2px;padding:0 14px 8px;display:flex}.stats-panel .section,.simulation-guide .section{padding-left:14px;padding-right:14px}.section-body{flex-direction:column;gap:2px;padding:0 14px 12px;display:flex}.control-subdivider{background:#ffffff12;height:1px;margin:8px 0 10px}.advanced-controls{margin-top:10px}.advanced-toggle{text-align:left;width:100%;color:var(--muted);letter-spacing:.01em;background:#ffffff09;border:1px solid #ffffff14;border-radius:14px;padding:10px 12px;font-size:13px;font-weight:600}.advanced-toggle:hover{color:var(--text);background:#60a5fa14;border-color:#60a5fa59}.advanced-body{padding-top:8px}.guide-list{margin:8px 0 0;padding-left:18px}.guide-list li{margin-bottom:6px}.guide-list--tight li{margin-bottom:4px;font-size:12px;line-height:1.45}.guide-block{border-bottom:1px solid var(--line);padding:10px 14px 6px}.guide-block:last-child{border-bottom:0}.guide-block-title{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;font-size:10px;font-weight:800}.guide-block-list{margin:0;padding-left:18px}.guide-block-list li+li{margin-top:6px}.guide-block-note{margin:0;font-size:12px;line-height:1.45}.mode-info{padding:2px 0 6px}.mode-info__header{padding:0 14px 10px}.mode-info__title{letter-spacing:-.01em;color:var(--text);font-size:14px;font-weight:800;line-height:1.25}.mode-info__subtitle{margin-top:4px}.mode-info__principle{border:1px solid var(--line);background:#ffffff0a;border-radius:14px;flex-wrap:wrap;align-items:baseline;gap:6px 10px;margin:0 14px 10px;padding:10px 12px;display:flex}.mode-info__principle-label{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:800}.mode-info__principle-value{color:var(--text);font-size:13px;font-weight:650}.mode-info__description{margin:0;padding:0 14px 6px}.mode-info__section{padding:10px 0 0}.mode-info__section-title{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);padding:0 14px 8px;font-size:10px;font-weight:800}.mode-info__list{margin:0;padding:0 14px 0 30px}.mode-info__list li+li{margin-top:6px}.mode-info__hint{margin:0;padding:0 14px 2px}.mode-info__closing{margin:0;padding:12px 14px 2px;font-size:12px;line-height:1.45}.simulation-guide--compact .section-header{margin-bottom:6px;font-size:12px}.first-run-guide{border:1px solid var(--line);background:var(--panel-2);z-index:25;border-radius:16px;max-width:520px;margin:0;position:absolute;top:14px;left:14px;right:14px;box-shadow:0 10px 28px #0f172a14}:root[data-theme=dark] .first-run-guide{box-shadow:0 12px 32px #00000059}.first-run-guide__inner{padding:14px 16px 12px}.first-run-guide__head{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px;display:flex}.first-run-guide__title{letter-spacing:.02em;font-size:14px}.first-run-guide__tag{text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:650}.first-run-guide__list{color:var(--text);margin:0 0 10px;padding-left:18px;font-size:12px;line-height:1.5}.first-run-guide__list li{margin-bottom:6px}.first-run-guide__list strong{font-weight:700}.first-run-guide__hint{margin:0 0 10px;font-size:11px;line-height:1.45}.first-run-guide__actions{justify-content:flex-end;display:flex}.tool-coach-toast{z-index:40;border:1px solid var(--line);background:var(--panel-2);pointer-events:none;border-radius:14px;flex-wrap:wrap;align-items:baseline;gap:6px 10px;max-width:min(420px,100vw - 32px);padding:10px 14px;font-size:12px;line-height:1.4;animation:4.2s forwards tool-coach-fade;display:flex;position:fixed;bottom:108px;left:50%;transform:translate(-50%);box-shadow:0 12px 36px #0f172a24}:root[data-theme=dark] .tool-coach-toast{box-shadow:0 14px 40px #00000073}.tool-coach-toast__label{letter-spacing:.08em;text-transform:uppercase;color:var(--blue);font-size:11px;font-weight:750}.tool-coach-toast__text{color:var(--muted)}@keyframes tool-coach-fade{0%{opacity:0;transform:translate(-50%)translateY(6px)}8%{opacity:1;transform:translate(-50%)translateY(0)}72%{opacity:1}to{opacity:0;transform:translate(-50%)translateY(0)}}.shortcuts-help{flex-direction:column;gap:6px;margin:0;display:flex}.shortcuts-help__row{grid-template-columns:88px 1fr;align-items:start;gap:10px;margin:0;display:grid}.shortcuts-help__row dt{margin:0}.shortcuts-help__kbd{border:1px solid var(--line);background:#ffffff8c;border-radius:8px;padding:2px 7px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:11px;font-weight:650;display:inline-block}:root[data-theme=dark] .shortcuts-help__kbd{background:#ffffff0f}.shortcuts-help__row dd{margin:0;font-size:12px;line-height:1.4}.preset-suggestion-chips{flex-direction:column;gap:8px;display:flex}.preset-suggestion-chip{text-align:left;border:1px solid var(--line);width:100%;color:var(--text);cursor:pointer;background:#ffffff73;border-radius:14px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;transition:border-color .14s,background .14s;display:flex}.preset-suggestion-chip:hover{background:#60a5fa14;border-color:#60a5fa73}:root[data-theme=dark] .preset-suggestion-chip{background:#ffffff0a}.preset-suggestion-chip__mood{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:800}.preset-suggestion-chip__name{font-size:13px;font-weight:650}.guide-tool-hint{margin:0;font-size:12px;line-height:1.45}.brush-panel{padding:10px 12px 12px}.brush-panel-hint{margin:0;padding:8px 2px 4px;font-size:12px;line-height:1.45}.brush-palette{flex-direction:column;gap:8px;display:flex}.brush-palette-label{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-size:9px;font-weight:800}.brush-palette-pills{border:1px solid var(--line);background:#ffffff47;border-radius:14px;flex-wrap:wrap;gap:6px;padding:5px;display:flex}:root[data-theme=dark] .brush-palette-pills{background:#ffffff0a}.brush-pill-content{align-items:center;gap:6px;display:inline-flex}.brush-pill-glyph{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.brush-pill-glyph svg{display:block}.brush-pill-swatch{border-radius:999px;flex-shrink:0;width:10px;height:10px;box-shadow:inset 0 0 0 1px #0f172a1f,0 0 0 1px #ffffff59}:root[data-theme=dark] .brush-pill-swatch{box-shadow:inset 0 0 0 1px #00000059,0 0 0 1px #ffffff14}.brush-pill{border:1px solid var(--line);color:var(--text);letter-spacing:.02em;cursor:pointer;background:#ffffff8c;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:650;transition:transform .12s,border-color .12s,box-shadow .12s,background .12s}.brush-pill:hover{background:#60a5fa14;border-color:#60a5fa73;transform:translateY(-1px)}.brush-pill.is-active{background:#60a5fa24;border-color:#60a5fa8c;box-shadow:0 6px 14px #0f172a14}.tool-hint{margin-top:10px}.tool-button-inner{align-items:center;gap:6px;display:inline-flex}.section{border-bottom:1px solid var(--line);padding:14px 0}.section:last-child{border-bottom:0}.section-header{color:var(--text);letter-spacing:.02em;justify-content:space-between;align-items:center;margin-bottom:10px;padding:0 14px;font-size:13px;font-weight:700;display:flex}.section-number{color:var(--muted);letter-spacing:.14em;font-size:11px;font-weight:600}.muted{color:var(--muted);font-size:13px;line-height:1.55}.control-row{grid-template-columns:1fr auto;align-items:center;gap:6px 12px;padding:6px 0;display:grid}.control-label{color:var(--text);font-size:13px;font-weight:500}.control-meta{vertical-align:middle;gap:6px;margin-left:8px;display:inline-flex}.control-badge{color:#0f172aad;letter-spacing:.14em;text-transform:uppercase;background:#ffffff8c;border:1px solid #0f172a1a;border-radius:999px;align-items:center;padding:2px 7px;font-size:10px;font-weight:800;display:inline-flex}.control-badge--warn{color:#e8665af2;background:#e8665a1a;border-color:#e8665a61}.control-value{color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px;font-weight:500}.control-row input[type=range]{width:100%;accent-color:var(--blue);grid-column:1/-1;margin-top:2px}.control-select{border:1px solid var(--line);width:100%;color:var(--text);background:#ffffff0a;border-radius:12px;grid-column:1/-1;margin-top:4px;padding:8px 10px;font-size:13px}.control-select:focus{box-shadow:var(--focus-ring);border-color:#60a5fa80;outline:none}.switch-row{border:1px solid var(--line);width:100%;color:var(--text);background:#ffffff09;border-radius:14px;justify-content:space-between;align-items:center;margin:6px 0;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.switch-knob{background:#ffffff1f;border-radius:999px;flex-shrink:0;width:36px;height:19px;position:relative}.switch-knob:after{content:"";background:#fff;border-radius:999px;width:15px;height:15px;transition:transform .16s;position:absolute;top:2px;left:2px}.switch-row.is-on .switch-knob{background:#60a5fad9}.switch-row.is-on .switch-knob:after{transform:translate(17px)}.button-grid.two{grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;display:grid}.wide-button{background:#ffffff0f;border-radius:14px;width:100%;margin:12px 0 0;font-weight:600}.wide-button:hover{background:#60a5fa1f;border-color:#60a5fa73}.view-reset-note{margin-top:8px}.section-body>.button-grid{margin-top:4px}.section-body>.muted:first-child{margin-top:0}.transport-pill{z-index:20;pointer-events:none;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.transport-pill.is-header{pointer-events:auto;margin:10px auto 0;position:static;bottom:auto;left:auto;transform:none}.transport-pill-inner{pointer-events:auto;border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff9e;border-radius:999px;grid-template-columns:auto auto auto 1fr;align-items:center;gap:10px;padding:10px 12px;display:grid;box-shadow:0 18px 44px #0f172a2e}.topbar-transport{border:1px solid var(--line);background:#ffffff61;border-radius:999px;flex:none;align-items:center;gap:6px;padding:3px;display:inline-flex}.topbar-transport-btn{color:var(--text);background:0 0;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:6px 9px;display:inline-flex}.topbar-transport-btn:hover{background:#60a5fa1a;border-color:#60a5fa73}.topbar-transport-speed{color:var(--muted);align-items:center;gap:8px;padding:0 8px 0 6px;font-size:11px;font-weight:700;display:inline-flex}.topbar-transport-speed-value{font-variant-numeric:tabular-nums;text-align:right;min-width:38px}.topbar-transport-speed input[type=range]{width:160px}:root[data-theme=dark] .transport-pill-inner{background:#ffffff1a;border-color:#ffffff1f}:root[data-theme=dark] .topbar-transport{background:#ffffff14;border-color:#ffffff1f}:root[data-theme=dark] .topbar-transport-btn:hover{background:#60a5fa1f;border-color:#60a5fa59}.transport-pill-inner button{justify-content:center;min-width:40px;padding:8px 10px}.transport-pill-slider{min-width:220px}.transport-pill.is-concealed{opacity:0;pointer-events:none}.mobile-tool-strip{z-index:22;pointer-events:none;position:absolute;bottom:78px;left:12px}.mobile-tool-strip__inner{pointer-events:auto;border:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000038;border-radius:999px;align-items:center;gap:6px;padding:6px;display:inline-flex;box-shadow:0 10px 30px #0f172a33}.mobile-tool-strip__btn{border:1px solid var(--line);width:38px;height:38px;color:var(--text);background:#ffffffbd;border-radius:999px;place-items:center;padding:0;display:grid}.mobile-tool-strip__btn.is-on{background:#60a5fa2e;border-color:#60a5faa6}.mobile-tool-strip__btn--tools{background:#ffffffeb}.mobile-tool-strip.is-concealed{opacity:0;pointer-events:none}.floating-palette{z-index:18;pointer-events:none;position:absolute}.floating-palette--tools{top:14px;left:14px}.floating-palette--brush{top:14px;left:74px}.tools-rail{gap:8px;display:grid}.tools-rail-btn{width:100%;color:var(--text);background:#fff9;border:1px solid #0f172a1a;border-radius:14px;grid-template-columns:18px 1fr;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:650;display:grid}.tools-rail-btn.is-on{background:#60a5fa1a;border-color:#60a5fa73}:root[data-theme=dark] .tools-rail-btn{background:#ffffff0f;border-color:#ffffff1f}:root[data-theme=dark] .tools-rail-btn.is-on{background:#60a5fa1f;border-color:#60a5fa80}.tools-hint{background:#ffffff80;border:1px solid #0f172a14;border-radius:14px;margin-top:10px;padding:8px 10px;line-height:1.35}.section-title{align-items:center;gap:8px;display:inline-flex}.section-collapse{width:28px;height:28px;color:var(--text);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;place-items:center;padding:0;display:grid}.section-collapse svg{transition:transform .16s}.section-collapse.is-collapsed svg{transform:rotate(-90deg)}.section-collapsed{padding:0 14px 12px}.floating-palette-card{pointer-events:auto;border:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb8;border-radius:18px;min-width:52px;padding:10px 10px 8px;box-shadow:0 18px 44px #0f172a29}.floating-palette-label{letter-spacing:.18em;text-transform:uppercase;color:#0f172a99;padding:0 4px 8px;font-size:10px;font-weight:800}.floating-palette-buttons{grid-template-columns:1fr;align-items:center;gap:8px;display:grid}.floating-tool-button{border:1px solid var(--line);width:42px;height:42px;color:var(--text);background:#ffffffc7;border-radius:14px;place-items:center;transition:transform .14s,box-shadow .14s,background .14s,border-color .14s;display:grid}.floating-tool-button:hover{background:#60a5fa1a;border-color:#60a5fa8c;transform:translateY(-1px)}.floating-tool-button.is-active{background:#60a5fa29;border-color:#60a5faa6;box-shadow:0 10px 26px #0f172a1f}.floating-palette-hint{color:#0f172ac7;background:#ffffff8c;border:1px solid #0f172a14;border-radius:14px;max-width:220px;margin-top:10px;padding:8px 10px;font-size:12px;line-height:1.35}.floating-palette-segmented{background:#ffffffa6;border:1px solid #0f172a1a;border-radius:16px;flex-wrap:wrap;gap:6px;padding:4px;display:inline-flex}.floating-palette-segmented button{color:var(--text);background:#ffffffc7;border:1px solid #0f172a1a;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:600}.floating-palette-segmented button.is-active{background:#60a5fa29;border-color:#60a5faa6}.sim-picker{padding:14px}.sim-picker-label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-size:10px;font-weight:800}.sim-picker-grid{gap:10px;display:grid}.sim-card{text-align:left;border:1px solid var(--line);background:#ffffffb3;border-radius:18px;padding:12px;transition:transform .14s,box-shadow .14s,border-color .14s,background .14s;box-shadow:0 10px 26px #0f172a14}.sim-card:hover:not(:disabled){border-color:#60a5fa73;transform:translateY(-1px);box-shadow:0 18px 44px #0f172a1f}.sim-card.is-active{background:#60a5fa1a;border-color:#60a5faa6}.sim-card.is-disabled{opacity:.55;cursor:not-allowed}.sim-card-title{letter-spacing:.02em;color:var(--text);font-size:13px;font-weight:800}.sim-card-desc{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.35}.stat-card{border-bottom:1px solid #ffffff12;flex-direction:column;gap:2px;padding:12px 14px;display:flex}.stat-card--strong{background:#ffffff0a}.stat-subheader{letter-spacing:.18em;text-transform:uppercase;color:#ffffff8c;padding:10px 14px 6px;font-size:10px;font-weight:800}.stat-card:last-of-type{border-bottom:none}.stat-card-label{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:700}.stat-card-value{font-variant-numeric:tabular-nums;color:var(--text);font-size:22px;font-weight:700;line-height:1.2}.stat-debug-row{color:#ffffff8c;border-bottom:1px solid #ffffff12;flex-wrap:wrap;align-items:baseline;gap:10px;padding:10px 14px 2px;font-size:11px;display:flex}.stat-debug-label{letter-spacing:.16em;text-transform:uppercase;color:#ffffff73;margin-right:2px;font-size:10px;font-weight:700}.stat-debug-item{align-items:baseline;gap:6px;display:inline-flex}.stat-debug-item b{font-variant-numeric:tabular-nums;color:#ffffffd1;font-weight:700}.series-list{margin-top:8px}.series-list--compact .series-row{grid-template-columns:64px 1fr 40px;gap:6px;margin-bottom:6px;font-size:11px}.stats-description{margin:0 0 10px}.telemetry-instrument{border:1px solid var(--line);background:#fff6;border-radius:14px;grid-template-columns:repeat(auto-fit,minmax(88px,1fr));gap:8px 10px;margin:0 2px;padding:10px 12px 12px;display:grid}:root[data-theme=dark] .telemetry-instrument{background:#ffffff0a}.telemetry-metric{flex-direction:column;align-items:flex-start;gap:3px;min-width:0;display:flex}.telemetry-metric-value{font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--text);font-size:22px;font-weight:800;line-height:1.05}.telemetry-metric-label{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-size:9px;font-weight:800}.stats-description--instrument{font-size:12px;line-height:1.45;margin-top:8px!important}.series-row{color:var(--muted);grid-template-columns:72px 1fr 44px;align-items:center;gap:8px;margin-bottom:10px;font-size:12px;display:grid}.series-row span:first-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.series-list--compact .series-bar{height:5px}.series-bar{background:#ffffff0f;border-radius:999px;height:8px;overflow:hidden;box-shadow:inset 0 1px 2px #00000059}.series-bar i{border-radius:inherit;background:linear-gradient(90deg,#60a5fabf,#60a5fa);height:100%;display:block;box-shadow:0 0 8px #60a5fa59}.series-row b{font-variant-numeric:tabular-nums;color:var(--text);text-align:right;font-weight:700}.stats-description{margin:0;padding:0 14px 8px}.matrix-control{grid-template-columns:1fr;gap:8px;padding-top:10px;padding-bottom:10px}.matrix-control>.control-label{padding:0 2px}.matrix-grid{gap:6px;width:100%;display:grid}.matrix-cell{border:1px solid var(--line);width:100%;min-width:0;color:var(--text);font-variant-numeric:tabular-nums;text-align:center;background:#ffffff0d;border-radius:10px;padding:6px 4px;font-family:ui-monospace,Cascadia Code,Segoe UI Mono,monospace;font-size:11px}.matrix-cell:focus{box-shadow:var(--focus-ring);border-color:#60a5fa8c;outline:none}.matrix-cell.positive{background:#60a5fa1f;border-color:#60a5fa47}.matrix-cell.negative{background:#e8665a1a;border-color:#e8665a47}.matrix-cell.zero-ish{background:#ffffff0a}@media (width<=1366px){.canvas-host{min-height:480px}.al-panel{width:min(400px,90vw)}.al-panel[data-panel-id=guide]{width:min(760px,90vw)}}@media (width<=1024px){.canvas-host{min-height:420px}.app-shell{padding:12px 14px 18px}}@media (width<=860px){.topbar-row{flex-direction:column;align-items:stretch}.topbar-mid{justify-content:flex-start}.topbar-actions{justify-content:flex-start;margin-left:0}.workspace{grid-template-columns:1fr}.right-panel{flex-direction:column;grid-area:auto/1}.transport-pill-inner{grid-template-columns:auto auto auto;gap:8px;padding:10px 12px}.transport-pill-slider{display:none}}@media (width<=768px){.app-shell{padding:6px 8px calc(8px + env(safe-area-inset-bottom))}.app-header{margin-bottom:4px}.topbar{gap:4px}.topbar-row{align-items:flex-start;gap:8px}.topbar.is-mobile .topbar-brand{flex:none}.topbar.is-mobile .topbar-brand-title-row{gap:6px}.topbar.is-mobile h1{letter-spacing:-.02em;font-size:18px}.topbar.is-mobile .topbar-mid{flex:100%;order:3;justify-content:flex-start}.topbar.is-mobile .topbar-group--state{background:0 0;border:0;border-radius:14px;justify-content:flex-start;width:100%;padding:0}.topbar.is-mobile .topbar-group-label{display:none}.topbar.is-mobile .topbar-sims{white-space:nowrap;scrollbar-width:none;width:100%;overflow:auto hidden}.topbar.is-mobile .topbar-sims::-webkit-scrollbar{display:none}.topbar.is-mobile .topbar-sim{min-height:40px;padding:7px 12px}.topbar.is-mobile .topbar-metrics{padding:4px 9px}.topbar.is-mobile .topbar-actions{flex-wrap:nowrap;gap:6px;margin-left:auto}.topbar.is-mobile .icon-button--compact{min-height:40px;padding:7px 12px}.topbar-mobile-quick-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-top:2px;display:grid}.topbar-mobile-quick-btn{justify-content:center;gap:5px;min-height:36px;padding:6px 8px;font-size:12px}.workspace{gap:8px}.stage-card{border-radius:14px}.canvas-host{min-height:0}.first-run-guide{display:none}.al-panel,.al-panel--floating,.al-panel--docked{width:calc(100vw - 16px);max-width:none;right:8px;bottom:calc(76px + env(safe-area-inset-bottom));border-radius:16px;top:auto!important;left:8px!important}.al-panel[data-panel-id=controls]{width:calc(100vw - 40px);right:20px;left:20px!important}.al-panel--sheet{box-shadow:0 18px 38px #0f172a33}.al-panel-header{z-index:1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);position:sticky;top:0}.al-panel-actions{opacity:1}.al-panel-icon{width:36px;height:36px}.al-panel-body{max-height:min(72vh,620px);overflow:auto}.al-panel[data-panel-id=controls] .al-panel-body{max-height:min(50vh,420px)}.tools-rail-btn,.brush-pill,.switch-row,.button-grid button,.preset-grid button{min-height:40px}.transport-pill{bottom:max(12px, env(safe-area-inset-bottom))}.transport-pill.is-mobile .transport-pill-inner{grid-template-columns:auto auto auto;gap:6px;max-width:calc(100vw - 32px);padding:7px 10px}.transport-pill.is-mobile .transport-pill-inner button{min-width:36px;padding:7px 8px}.transport-pill.is-mobile .transport-pill-slider{display:none}.mobile-tool-strip{bottom:calc(max(12px, env(safe-area-inset-bottom)) + 52px)}.mobile-tool-strip__btn{width:40px;height:40px}.control-label{font-size:14px}.control-row input[type=range]{min-height:34px}}@media (height<=820px){.app-shell{padding:10px 12px 14px}.app-header{margin-bottom:10px}.workspace{gap:12px}.stage-card{min-height:0}.canvas-host{min-height:360px}}button:focus-visible,.text-button:focus-visible,.switch-row:focus-visible,.control-select:focus-visible,.matrix-cell:focus-visible,.modal-textarea:focus-visible,.al-panel-icon:focus-visible{box-shadow:var(--focus-ring);outline:none}.icon-button--close-modal{min-width:40px;padding:6px 12px;font-size:20px;font-weight:400;line-height:1}
