:root{--bg: #080b14;--panel: #0c1121;--panel2: #0e1529;--surface-raised: rgba(255, 255, 255, .035);--surface-hover: rgba(255, 255, 255, .06);--stroke: rgba(255, 255, 255, .08);--stroke-focus: rgba(74, 158, 255, .45);--text: rgba(255, 255, 255, .9);--muted: rgba(255, 255, 255, .52);--dim: rgba(255, 255, 255, .28);--accent: #4a9eff;--accent-muted: rgba(74, 158, 255, .15);--accent-hover: #5eadff;--accent-soft: var(--accent-muted);--good: #5ee8b0;--good-bg: rgba(94, 232, 176, .08);--warn: #f0c060;--warn-bg: rgba(240, 192, 96, .1);--bad: #f07080;--bad-bg: rgba(240, 112, 128, .08);--danger: var(--bad);--error: var(--bad);--radius: 8px;--radius-sm: 6px;--radius-lg: 12px;--radius-pill: 999px;--speed: .15s;--topbar-bg: linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .015));--pane-shadow: 0 2px 8px rgba(0, 0, 0, .2);--subtle-bg: rgba(255, 255, 255, .02);--elevated-border: rgba(255, 255, 255, .1);--chat-shell-bg: linear-gradient(180deg, rgba(255, 255, 255, .02), rgba(255, 255, 255, 0));--chat-history-bg: linear-gradient(180deg, rgba(255, 255, 255, .016), rgba(255, 255, 255, .006));--chat-bubble-ai-bg: rgba(255, 255, 255, .05);--chat-bubble-ai-border: rgba(255, 255, 255, .08);--chat-bubble-user-bg: rgba(74, 158, 255, .2);--chat-bubble-user-border: rgba(74, 158, 255, .36);--chat-input-bg: linear-gradient(180deg, rgba(255, 255, 255, .035), rgba(255, 255, 255, .015));--chat-textarea-bg: rgba(0, 0, 0, .2);--modal-bg: rgba(12, 17, 33, .97);--modal-title-bg: rgba(255, 255, 255, .03);--modal-shadow: 0 24px 64px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .04);--context-bg: rgba(14, 18, 34, .96);--context-shadow: 0 8px 24px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .04);--inline-highlight-bg: rgba(74, 158, 255, .18);--inline-highlight-border: rgba(74, 158, 255, .55);--node-icon-color: rgba(255, 255, 255, .85);--scroll-thumb: rgba(255, 255, 255, .12);--scroll-thumb-hover: rgba(255, 255, 255, .22);--selection-bg: rgba(74, 158, 255, .3);--viewcube-face-bg: rgba(14, 21, 41, .88);--viewcube-face-text: rgba(255, 255, 255, .75);--viewcube-face-border: rgba(255, 255, 255, .12);--viewcube-face-hover-bg: rgba(74, 158, 255, .25);--viewcube-face-hover-text: #ffffff;--viewcube-face-hover-border: rgba(74, 158, 255, .5);--viewport-toolbar-bg: rgba(10, 14, 28, .88);--viewport-toolbar-border: rgba(255, 255, 255, .08);--viewport-toolbar-shadow: 0 4px 16px rgba(0, 0, 0, .3);--viewport-toolbar-sep: rgba(255, 255, 255, .1);--viewport-toolbar-btn: rgba(255, 255, 255, .65);--viewport-toolbar-btn-hover-bg: rgba(255, 255, 255, .06);--viewport-toolbar-btn-hover-text: rgba(255, 255, 255, .9);--axis-x: #f05050;--axis-y: #50d060;--axis-z: #5080f0;--fg: var(--text);--surface: var(--surface-raised);--border: var(--stroke);--bg-2: var(--panel2);--mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--font-mono: var(--mono);color-scheme:dark;color:var(--text);background:var(--bg);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=light]{--bg: #f3f6fb;--panel: #ffffff;--panel2: #edf2f8;--surface-raised: rgba(15, 23, 42, .04);--surface-hover: rgba(15, 23, 42, .08);--stroke: rgba(15, 23, 42, .17);--stroke-focus: rgba(47, 109, 224, .42);--text: rgba(15, 23, 42, .94);--muted: rgba(15, 23, 42, .62);--dim: rgba(15, 23, 42, .4);--accent: #2f6de0;--accent-muted: rgba(47, 109, 224, .14);--accent-hover: #245ac0;--good-bg: rgba(24, 152, 101, .14);--warn-bg: rgba(185, 128, 33, .16);--bad-bg: rgba(191, 56, 86, .14);--topbar-bg: linear-gradient(180deg, rgba(255, 255, 255, .95), rgba(245, 248, 252, .92));--pane-shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 8px 24px rgba(15, 23, 42, .06);--subtle-bg: rgba(15, 23, 42, .03);--elevated-border: rgba(15, 23, 42, .16);--chat-shell-bg: linear-gradient(180deg, rgba(15, 23, 42, .02), rgba(15, 23, 42, 0));--chat-history-bg: linear-gradient(180deg, rgba(15, 23, 42, .02), rgba(15, 23, 42, .005));--chat-bubble-ai-bg: rgba(255, 255, 255, .92);--chat-bubble-ai-border: rgba(15, 23, 42, .18);--chat-bubble-user-bg: rgba(47, 109, 224, .16);--chat-bubble-user-border: rgba(47, 109, 224, .33);--chat-input-bg: linear-gradient(180deg, rgba(255, 255, 255, .95), rgba(242, 246, 252, .95));--chat-textarea-bg: rgba(255, 255, 255, .98);--modal-bg: rgba(255, 255, 255, .98);--modal-title-bg: rgba(15, 23, 42, .04);--modal-shadow: 0 20px 48px rgba(15, 23, 42, .22), 0 0 0 1px rgba(15, 23, 42, .08);--context-bg: rgba(255, 255, 255, .98);--context-shadow: 0 8px 22px rgba(15, 23, 42, .18), 0 0 0 1px rgba(15, 23, 42, .08);--inline-highlight-bg: rgba(47, 109, 224, .18);--inline-highlight-border: rgba(47, 109, 224, .55);--node-icon-color: rgba(15, 23, 42, .78);--scroll-thumb: rgba(15, 23, 42, .22);--scroll-thumb-hover: rgba(15, 23, 42, .32);--selection-bg: rgba(47, 109, 224, .24);--viewcube-face-bg: rgba(255, 255, 255, .92);--viewcube-face-text: rgba(15, 23, 42, .82);--viewcube-face-border: rgba(15, 23, 42, .18);--viewcube-face-hover-bg: rgba(47, 109, 224, .2);--viewcube-face-hover-text: rgba(15, 23, 42, .95);--viewcube-face-hover-border: rgba(47, 109, 224, .46);--viewport-toolbar-bg: rgba(255, 255, 255, .9);--viewport-toolbar-border: rgba(15, 23, 42, .16);--viewport-toolbar-shadow: 0 4px 14px rgba(15, 23, 42, .18);--viewport-toolbar-sep: rgba(15, 23, 42, .18);--viewport-toolbar-btn: rgba(15, 23, 42, .7);--viewport-toolbar-btn-hover-bg: rgba(15, 23, 42, .08);--viewport-toolbar-btn-hover-text: rgba(15, 23, 42, .95);color-scheme:light}html,body,#app{height:100%;margin:0;overflow:hidden}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.app{height:100%;display:flex;flex-direction:row;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;overflow:hidden}.topbar.topbar-mobile{position:fixed;inset:0 0 auto 0;height:calc(40px + env(safe-area-inset-top));padding:calc(4px + env(safe-area-inset-top)) 8px 4px;display:flex;align-items:center;gap:0;background:var(--topbar-bg);border-bottom:1px solid var(--stroke);flex-shrink:0;z-index:40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar.topbar-mobile+.layout.layout-mobile{padding-top:calc(40px + env(safe-area-inset-top))}.activity-bar{display:flex;flex-direction:column;width:74px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--stroke);z-index:30;height:100%}.activity-bar-top{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 0;flex:1}.activity-bar-bottom{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 0 12px;border-top:1px solid var(--stroke)}.activity-bar-brand{font-weight:700;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);text-align:center;padding:4px 0 8px;-webkit-user-select:none;user-select:none;line-height:1.2}.activity-bar-btn{position:relative;width:62px;min-height:46px;display:flex;flex-direction:column;gap:2px;align-items:center;justify-content:center;border-radius:var(--radius);border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all var(--speed);padding:0}.activity-bar-btn:hover{color:var(--text);background:var(--surface-hover)}.activity-bar-btn[data-active=true]{color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,var(--surface-hover));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent)}.activity-bar-btn[data-active=true]:before{content:"";position:absolute;left:-1px;top:7px;bottom:7px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.activity-bar-btn-label{font-size:10px;line-height:1;letter-spacing:.02em}.activity-bar-badge{position:absolute;top:5px;right:9px;min-width:14px;height:14px;padding:0 3px;border-radius:7px;background:var(--error, #f44);color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center}.tooltip-anchor[data-tooltip]{position:relative}@media(hover:hover){.tooltip-anchor[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%) translate(-4px);background:color-mix(in srgb,var(--panel) 92%,#000);color:var(--text);border:1px solid var(--stroke);border-radius:8px;padding:6px 8px;font-size:11px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .12s ease,transform .12s ease;z-index:999}.tooltip-anchor[data-tooltip]:hover:after,.tooltip-anchor[data-tooltip]:focus-visible:after{opacity:1;transform:translateY(-50%) translate(0)}.toolbar-btn[title]{position:relative}.toolbar-btn[title]:after{content:attr(title);position:absolute;left:50%;top:calc(100% + 6px);transform:translate(-50%) translateY(-4px);background:color-mix(in srgb,var(--panel) 92%,#000);color:var(--text);border:1px solid var(--stroke);border-radius:8px;padding:5px 7px;font-size:10px;white-space:nowrap;pointer-events:none;opacity:0;z-index:999;transition:opacity .1s ease,transform .1s ease}.toolbar-btn[title]:hover:after,.toolbar-btn[title]:focus-visible:after{opacity:1;transform:translate(-50%) translateY(0)}}.activity-bar-status{width:62px;min-height:30px;display:flex;flex-direction:column;gap:4px;align-items:center;justify-content:center;cursor:default}.activity-bar-status-copy{font-size:9px;letter-spacing:.02em;color:var(--muted);line-height:1;max-width:60px;text-align:center}.activity-bar-status-dot{width:8px;height:8px;border-radius:50%;transition:background var(--speed),box-shadow var(--speed)}.activity-bar-status-dot[data-status=idle]{background:var(--good);box-shadow:0 0 6px #5ee8b066}.activity-bar-status-dot[data-status=compiling],.activity-bar-status-dot[data-status=queued]{background:var(--warn);box-shadow:0 0 6px #f0c06066;animation:status-pulse 1.2s ease-in-out infinite}.activity-bar-status-dot[data-status=error]{background:var(--bad);box-shadow:0 0 6px #f0708066}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.4}}.activity-popover{position:fixed;left:52px;z-index:50;min-width:200px;max-width:280px;padding:8px 0;background:var(--panel);border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--context-shadow, var(--pane-shadow))}.activity-popover-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:12px;color:var(--text);cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background var(--speed);text-decoration:none}.activity-popover-item:hover{background:var(--surface-hover)}.activity-popover-divider{height:1px;margin:4px 0;background:var(--stroke)}.activity-popover-label{padding:4px 14px;font-size:11px;color:var(--muted);-webkit-user-select:none;user-select:none}.activity-popover-text{padding:4px 14px;font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis}.code-panel-project-bar{display:flex;align-items:center;gap:6px;padding:6px 10px;border-bottom:1px solid var(--stroke);flex-wrap:wrap}.code-panel-project-bar .select{flex:1;min-width:0}.code-panel-project-bar .code-panel-project-search{flex:0 0 180px;min-width:140px;font-family:inherit;padding:6px 8px;border-radius:8px}.code-panel-project-bar .code-panel-example-select{flex:0 0 220px}.inline-link-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;color:var(--accent);padding:0;margin:0;font:inherit;text-decoration:underline;cursor:pointer}.inline-link-button:hover{color:color-mix(in srgb,var(--accent) 82%,#fff)}.topbar-save{font-size:11px;white-space:nowrap}.topbar-save[data-state=error]{color:var(--bad)}.code-panel-recent-row{display:flex;align-items:center;gap:6px;padding:4px 10px 6px;border-bottom:1px solid var(--stroke);flex-wrap:wrap}.code-panel-quick-hint{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 10px 6px;border-bottom:1px dashed var(--stroke)}.code-panel-recent-chip{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.props-var-impact-list{margin:0;padding-left:14px;display:grid;gap:2px}.props-var-impact-item{font-size:11px;line-height:1.35}.props-var-hint{font-size:10px;color:var(--accent);font-weight:400;font-family:var(--font-mono);white-space:nowrap}.status{font-size:11px;padding:4px 10px;border:1px solid var(--stroke);border-radius:var(--radius-pill);color:var(--muted);justify-self:start;transition:color var(--speed),background var(--speed),border-color var(--speed)}.status[data-status=idle]{color:var(--good);background:var(--good-bg);border-color:#5ee8b033}.status[data-status=queued],.status[data-status=compiling]{color:var(--warn);background:var(--warn-bg);border-color:#f0c06033}.status[data-status=error]{color:var(--bad);background:var(--bad-bg);border-color:#f0708033}.layout{flex:1;display:flex;position:relative;padding:8px;gap:8px;min-height:0;overflow:hidden}.pane-left-column{width:min(480px,36vw);flex:0 0 min(480px,36vw)}.pane-resizer{flex:0 0 8px;width:8px;margin-inline:-4px;cursor:col-resize;border-radius:4px;background:transparent;position:relative;z-index:2}.pane-resizer:before{content:"";position:absolute;left:50%;top:8px;bottom:8px;width:2px;transform:translate(-50%);border-radius:2px;background:color-mix(in srgb,var(--stroke) 60%,transparent);opacity:.55;transition:opacity var(--speed),background var(--speed)}.pane-resizer:hover:before{opacity:.95;background:color-mix(in srgb,var(--accent) 60%,var(--stroke))}.pane-center-column{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;gap:8px;background:transparent;border:none;box-shadow:none;padding:0}.sidebar-panel-body{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;background:color-mix(in srgb,var(--panel2) 16%,var(--panel))}.sidebar-panel-body .chat{min-height:0}.desktop-left-code{min-height:0;display:flex;flex-direction:column;overflow:hidden;flex:1}.activity-bar-sep{width:42px;height:1px;background:var(--stroke);margin:4px 0}.pane{background:linear-gradient(180deg,color-mix(in srgb,var(--panel2) 52%,var(--panel)),color-mix(in srgb,var(--panel) 96%,transparent));border:1px solid color-mix(in srgb,var(--stroke) 88%,transparent);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;min-height:0;box-shadow:0 10px 28px #0000003d,inset 0 1px color-mix(in srgb,var(--text) 8%,transparent)}.pane-title{padding:10px 14px;font-size:11px;color:var(--muted);border-bottom:1px solid var(--stroke);background:linear-gradient(180deg,color-mix(in srgb,var(--surface-raised) 92%,transparent),color-mix(in srgb,var(--surface-raised) 40%,transparent));text-transform:uppercase;letter-spacing:.05em;font-weight:500}.pane-title-flex{display:flex;align-items:center;justify-content:space-between;gap:10px}.tabs{display:inline-flex;gap:6px;align-items:center}.tab{border-radius:var(--radius-pill);border:1px solid var(--stroke);background:transparent;color:var(--muted);padding:4px 10px;cursor:pointer;font-size:11px;transition:all var(--speed);letter-spacing:.02em}.tab:hover{color:var(--text);background:var(--surface-hover)}.tab[data-active=true]{background:var(--accent-muted);color:var(--accent);border-color:#4a9eff40}.tab[data-has-errors=true]{color:var(--error, #f44)}.tab[data-has-errors=true][data-active=true]{color:var(--error, #f44);background:#ff44441a;border-color:#ff444440}.editor-host{flex:1;min-height:0}.pane-viewport{flex:1;min-width:0;position:relative;border:none;border-radius:0;box-shadow:none;background:var(--panel2)}.desktop-viewport-pane .viewport{padding-bottom:72px}.viewport-command-bar{position:absolute;left:50%;transform:translate(-50%);bottom:10px;width:calc(100% - 24px);max-width:600px;z-index:22;display:grid;gap:6px}.viewport-command-title{justify-self:start;display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 36%,var(--stroke));background:color-mix(in srgb,var(--accent-muted) 70%,transparent);color:color-mix(in srgb,var(--accent) 86%,var(--text));font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.viewport-command-context{display:flex;flex-wrap:wrap;gap:6px}.viewport-command-chip{border:1px solid color-mix(in srgb,var(--accent) 35%,var(--stroke));border-radius:999px;background:color-mix(in srgb,var(--accent-soft) 78%,transparent);color:var(--text);font-size:11px;padding:4px 9px;cursor:pointer}.viewport-command-chip:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--stroke))}.viewport-command-chip-passive{cursor:default;opacity:.95}.viewport-command-busy{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:7px;width:fit-content;border:1px solid color-mix(in srgb,var(--warn) 34%,transparent);border-radius:999px;padding:4px 10px;font-size:11px;color:var(--warn);background:linear-gradient(100deg,color-mix(in srgb,var(--warn-bg) 78%,transparent),color-mix(in srgb,var(--warn-bg) 62%,transparent));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--warn) 10%,transparent);animation:processing-badge-glow 1.3s ease-in-out infinite}.viewport-command-busy:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-120%);background:linear-gradient(120deg,transparent 25%,color-mix(in srgb,var(--warn) 20%,transparent) 50%,transparent 75%);animation:processing-shimmer 1.9s linear infinite;pointer-events:none}.viewport-command-busy>span:last-child{position:relative;z-index:1}.viewport-command-busy-dot{position:relative;z-index:1;width:7px;height:7px;border-radius:999px;background:currentColor;box-shadow:0 0 color-mix(in srgb,currentColor 40%,transparent);animation:ai-busy-dot .8s ease-in-out infinite}.viewport-command-last{font-size:11px;color:var(--good);background:color-mix(in srgb,var(--good-bg) 72%,transparent);border:1px solid color-mix(in srgb,var(--good) 30%,transparent);border-radius:999px;padding:4px 10px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viewport-command-row{display:flex;align-items:center;gap:8px;border:1px solid var(--stroke);border-radius:12px;padding:7px 8px;background:color-mix(in srgb,var(--panel) 95%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.viewport-command-input{flex:1;min-width:0;border:1px solid transparent;background:transparent;color:var(--text);font-size:13px;padding:6px 8px;border-radius:8px;outline:none}.viewport-command-input:focus{border-color:var(--stroke-focus);background:var(--surface-raised)}@keyframes ai-busy-dot{0%{opacity:.35;transform:scale(.82);box-shadow:0 0 color-mix(in srgb,currentColor 45%,transparent)}55%{opacity:1;transform:scale(1);box-shadow:0 0 0 4px color-mix(in srgb,currentColor 0%,transparent)}to{opacity:.35;transform:scale(.82);box-shadow:0 0 color-mix(in srgb,currentColor 0%,transparent)}}@keyframes processing-badge-glow{0%,to{filter:saturate(.95)}50%{filter:saturate(1.08)}}@keyframes processing-shimmer{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes processing-ellipsis{0%,65%,to{opacity:.15;transform:translateY(0)}35%{opacity:1;transform:translateY(-.1em)}}@keyframes chat-msg-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes edit-status-sweep{0%{transform:translate(-120%)}to{transform:translate(120%)}}.floating-panel{position:absolute;z-index:10;background:var(--panel);border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--pane-shadow);overflow:hidden;display:flex;flex-direction:column;min-height:0}.floating-panel-code{left:8px;top:8px;bottom:8px;width:380px}.floating-panel-properties{right:8px;bottom:8px;width:340px;max-height:min(60vh,calc(100% - 16px))}.floating-panel-body{flex:1;overflow:auto;min-height:0;display:flex;flex-direction:column}.floating-panel-body>.editor-host{flex:1;min-height:0}.layout.layout-mobile{gap:0;padding:0}.layout.layout-mobile .pane-viewport{border-radius:0;border-left:none;border-right:none;border-bottom:none}.layout.layout-mobile .floating-panel{display:none}.btn{border-radius:var(--radius);border:1px solid var(--stroke);background:var(--surface-raised);color:var(--text);padding:7px 14px;cursor:pointer;font-size:12px;transition:all var(--speed);font-weight:500}.btn:hover{background:var(--surface-hover);border-color:#ffffff24}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-sm{padding:5px 10px;font-size:11px}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--surface-hover);border-color:var(--stroke)}.btn-danger{color:var(--bad)}.btn-danger:hover{background:var(--bad-bg);border-color:var(--bad)}.mobile-main-menu-item-danger{color:var(--bad)}.btn-google-entry{display:inline-flex;align-items:center;gap:6px;border-color:color-mix(in srgb,var(--accent) 36%,var(--stroke));background:color-mix(in srgb,var(--accent) 8%,var(--surface-raised))}.btn-google-entry-mark{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.btn-google-entry-mark svg{display:block}.btn-google-entry-text{white-space:nowrap}.btn-google-entry-text-short{display:none}.btn-google-entry:hover{border-color:color-mix(in srgb,var(--accent) 52%,var(--stroke));background:color-mix(in srgb,var(--accent) 14%,var(--surface-hover))}.btn-google-entry:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 70%,transparent);outline-offset:1px}.muted{color:var(--muted)}.select{height:30px;border-radius:var(--radius);border:1px solid var(--stroke);background:var(--surface-raised);color:var(--text);padding:0 10px;font-size:12px;transition:border-color var(--speed)}.select:focus{outline:none;border-color:var(--stroke-focus)}.select-compact{height:28px;min-width:88px;padding:0 8px;font-size:11px}.chat{display:flex;flex-direction:column;min-height:0;flex:1;overflow:hidden;height:100%;background:var(--chat-shell-bg)}.chat-docked{height:auto;border:1px solid var(--stroke);border-radius:12px;background:color-mix(in srgb,var(--panel) 94%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--pane-shadow);transition:box-shadow .2s ease}.chat-dock-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-bottom:1px solid var(--stroke);background:color-mix(in srgb,var(--surface-raised) 86%,transparent)}.chat-dock-title-wrap{display:inline-flex;align-items:center;gap:8px}.chat-dock-title{font-size:12px;color:color-mix(in srgb,var(--accent) 68%,var(--text));text-transform:uppercase;letter-spacing:.06em;font-weight:700}.chat-dock-badge{display:inline-flex;align-items:center;height:18px;padding:0 7px;border-radius:999px;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 85%,var(--text));background:color-mix(in srgb,var(--accent-muted) 72%,transparent);border:1px solid color-mix(in srgb,var(--accent) 38%,transparent)}.chat-pane-title{display:inline-flex;align-items:center;gap:8px}.chat-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:12px 12px 10px;overscroll-behavior:contain;scrollbar-gutter:stable}.chat-history{background:var(--chat-history-bg)}.chat-history-inner{min-height:100%;display:flex;flex-direction:column;gap:12px}.chat-banner{border:1px dashed var(--stroke);border-radius:12px;padding:10px 12px;background:var(--subtle-bg)}.chat-banner-row{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-top:6px}.chat-banner-actions{display:inline-flex;gap:8px;align-items:center}.chat-empty{font-size:12px}.chat-welcome{padding:16px;display:flex;flex-direction:column;gap:14px}.chat-welcome h2{margin:0;font-size:16px;font-weight:700;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chat-welcome p{margin:0;font-size:12px;color:var(--muted);line-height:1.5}.chat-welcome-features{display:flex;flex-direction:column;gap:8px}.chat-welcome-feat{border:1px solid var(--stroke);border-radius:var(--radius);padding:10px 12px;background:var(--surface-raised);transition:border-color var(--speed),background var(--speed)}.chat-welcome-feat:hover{border-color:#4a9eff33;background:var(--surface-hover)}.chat-welcome-feat-title{font-size:12px;font-weight:600;margin-bottom:3px}.chat-welcome-feat-desc{font-size:11px;color:var(--muted);line-height:1.4}.chat-prompt-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.chat-prompt-chip{padding:4px 10px;border-radius:20px;border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent);font-size:11px;cursor:pointer;white-space:nowrap;transition:background .1s,border-color .1s;touch-action:manipulation}.chat-prompt-chip:hover,.chat-prompt-chip:active{background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:color-mix(in srgb,var(--accent) 70%,transparent)}.chat-welcome-compact{padding:12px 16px}.chat-welcome-compact p{margin:0;font-size:12px;color:var(--muted);line-height:1.5}.chat-msg{display:flex;flex-direction:column;gap:4px;align-self:stretch;max-width:100%;padding:8px 10px;border:1px solid color-mix(in srgb,var(--chat-bubble-ai-border) 88%,transparent);border-radius:10px;background:color-mix(in srgb,var(--chat-bubble-ai-bg) 72%,transparent);box-shadow:inset 0 1px #ffffff08;animation:chat-msg-in .15s ease-out}.chat-msg[data-role=user]{margin-left:18px;background:color-mix(in srgb,var(--chat-bubble-user-bg) 65%,transparent);border-color:color-mix(in srgb,var(--chat-bubble-user-border) 82%,transparent)}.chat-msg-meta{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.chat-msg[data-role=assistant] .chat-msg-meta{color:color-mix(in srgb,var(--accent) 56%,var(--muted))}.chat-msg[data-role=user] .chat-msg-meta{color:color-mix(in srgb,var(--accent) 72%,var(--text))}.chat-role{display:none}.chat-text{margin:0;white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.55}.chat-ctx-card{margin-top:6px;border:1px solid var(--stroke);border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--panel2) 60%,transparent);max-width:240px}.chat-ctx-card[data-clickable=true]{cursor:pointer;transition:border-color .12s ease,background .12s ease}.chat-ctx-card[data-clickable=true]:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--panel2))}.chat-ctx-thumb{display:block;width:100%;height:auto;border-bottom:1px solid var(--stroke)}.chat-ctx-meta{display:flex;align-items:center;gap:6px;padding:5px 8px;font-size:11px;color:var(--muted)}.chat-ctx-label{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.chat-ctx-range{flex-shrink:0;opacity:.65;font-size:10px;font-family:var(--font-mono, monospace)}.chat-tool-status{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:7px;width:fit-content;max-width:100%;min-height:24px;border:1px solid var(--stroke);border-radius:999px;padding:3px 10px;font-size:11px;color:var(--muted);background:color-mix(in srgb,var(--surface-raised) 78%,transparent)}.chat-tool-status-dot{width:7px;height:7px;border-radius:999px;background:color-mix(in srgb,var(--accent) 62%,transparent);flex:none}.chat-tool-status-label{font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 60%,var(--muted))}.chat-tool-status-text{min-width:0;max-width:min(360px,72vw);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-tool-status[data-live=true]{color:color-mix(in srgb,var(--text) 78%,var(--muted))}.chat-tool-status[data-phase=editing]{border-color:color-mix(in srgb,var(--accent) 34%,var(--stroke));background:color-mix(in srgb,var(--accent-muted) 58%,transparent)}.chat-tool-status[data-phase=editing] .chat-tool-status-dot{background:color-mix(in srgb,var(--accent) 78%,var(--text))}.chat-tool-status[data-phase=editing][data-live=true]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-120%);background:linear-gradient(120deg,transparent 25%,color-mix(in srgb,var(--accent) 18%,transparent) 50%,transparent 75%);animation:edit-status-sweep 1.4s linear infinite;pointer-events:none}.chat-tool-status[data-phase=editing][data-live=true] .chat-tool-status-dot{animation:ai-busy-dot .8s ease-in-out infinite}.chat-error{border:1px solid rgba(240,112,128,.3);background:var(--bad-bg);border-radius:var(--radius-lg);padding:10px 12px;font-size:12px;color:var(--bad)}.chat-input{border-top:1px solid var(--stroke);padding:12px;background:var(--chat-input-bg);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;flex-shrink:0}.chat-processing{position:relative;overflow:hidden;grid-column:1 / -1;display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--warn);width:fit-content;border-radius:999px;border:1px solid color-mix(in srgb,var(--warn) 28%,transparent);background:linear-gradient(100deg,color-mix(in srgb,var(--warn-bg) 78%,transparent),color-mix(in srgb,var(--warn-bg) 62%,transparent));padding:4px 10px;animation:processing-badge-glow 1.3s ease-in-out infinite}.chat-processing:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-120%);background:linear-gradient(120deg,transparent 25%,color-mix(in srgb,var(--warn) 20%,transparent) 50%,transparent 75%);animation:processing-shimmer 1.9s linear infinite;pointer-events:none}.chat-processing>span:last-child{position:relative;z-index:1}.chat-processing-dot{position:relative;z-index:1;width:7px;height:7px;border-radius:999px;background:currentColor;box-shadow:0 0 color-mix(in srgb,currentColor 40%,transparent);animation:ai-busy-dot .8s ease-in-out infinite}.processing-ellipsis{display:inline-flex;width:1.5em;justify-content:space-between;margin-left:2px}.processing-ellipsis>span{display:inline-block;opacity:.12;animation:processing-ellipsis 1s ease-in-out infinite}.processing-ellipsis>span:nth-child(2){animation-delay:.18s}.processing-ellipsis>span:nth-child(3){animation-delay:.36s}.chat-input textarea{resize:none;height:64px;border-radius:10px;border:1px solid var(--stroke);background:var(--chat-textarea-bg);color:var(--text);padding:11px 12px;font-size:13px;line-height:1.5;outline:none;transition:border-color var(--speed);font-family:inherit}.chat-input textarea:focus{border-color:var(--stroke-focus)}.chat-blocked{border-top:1px solid var(--stroke);padding:14px 12px;background:var(--subtle-bg);display:flex;flex-direction:column;gap:10px;align-items:center;text-align:center;flex-shrink:0}.chat-blocked-text{font-size:12px;color:var(--muted);line-height:1.4}.chat-blocked-actions{display:flex;gap:8px;align-items:center}.chat-dock-blocked{border-top:1px solid var(--stroke);padding:10px;display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-dock-blocked-text{font-size:12px;color:var(--muted)}.chat-dock-blocked-actions{display:inline-flex;gap:8px;align-items:center}.chat-dock-blocked-minimal{padding:8px 10px}.chat-login-flow{width:min(420px,100%);border:1px solid var(--stroke);border-radius:12px;background:var(--surface-raised);padding:10px 12px;display:grid;gap:8px;justify-items:center}.chat-login-flow-title{font-size:12px;font-weight:600;color:var(--text)}.chat-login-flow-track{width:100%;height:6px;border-radius:999px;background:var(--subtle-bg);overflow:hidden}.chat-login-flow-bar{width:45%;height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,#34d399,#f59e0b);animation:chat-login-flow-slide 1.1s ease-in-out infinite}.chat-login-flow.is-launching .chat-login-flow-bar{width:100%;animation:chat-login-flow-fill .25s ease-out forwards}.chat-login-flow-desc{font-size:11px;color:var(--muted)}@keyframes chat-login-flow-slide{0%{transform:translate(-80%)}50%{transform:translate(60%)}to{transform:translate(220%)}}@keyframes chat-login-flow-fill{0%{opacity:.8}to{opacity:1}}.chat-send{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:6px}.chat-send .btn{min-width:64px}@media(prefers-reduced-motion:reduce){.chat-msg,.chat-tool-status[data-phase=editing][data-live=true]:after,.chat-tool-status[data-phase=editing][data-live=true] .chat-tool-status-dot,.chat-processing,.chat-processing-dot,.chat-processing:after,.viewport-command-busy,.viewport-command-busy-dot,.viewport-command-busy:after,.processing-ellipsis>span{animation:none!important}}.chat-mode-select{font-size:11px;padding:2px 4px;border-radius:var(--radius-sm, 4px);background:var(--bg-2, #1e1e1e);color:var(--fg, #ccc);border:1px solid var(--border, #333);cursor:pointer}.chat-hint{font-size:10px}.chat-input-docked{padding:8px 10px 10px;grid-template-columns:1fr auto}.chat-input-docked textarea{height:48px;padding:10px 11px}.chat[data-expanded=false].chat-docked .chat-body{display:none}.chat-docked[data-expanded=true] .chat-body{max-height:min(50vh,480px)}.chat-docked[data-expanded=true]{box-shadow:0 8px 32px #0000004d,0 0 0 1px #ffffff0a}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:100}.modal{width:min(520px,calc(100vw - 24px));border:1px solid var(--elevated-border);border-radius:16px;background:var(--modal-bg);box-shadow:var(--modal-shadow);overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;max-height:min(calc(100vh - 24px),920px)}@supports (height: 100dvh){.modal{max-height:min(calc(100dvh - 24px),920px)}}.modal-title{padding:12px 14px;border-bottom:1px solid var(--stroke);font-size:12px;color:var(--muted);background:var(--modal-title-bg);flex-shrink:0}.modal-body{padding:12px 14px;font-size:12px;min-height:0;overflow:auto}.onboarding-modal{width:min(560px,calc(100vw - 24px))}.onboarding-body h3{margin:0 0 8px;font-size:15px}.onboarding-progress{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--stroke);border-radius:var(--radius-pill);padding:2px 8px;font-size:11px;color:var(--muted);margin-bottom:10px}.onboarding-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.project-manager-modal{width:min(860px,calc(100vw - 24px))}.project-manager-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.project-manager-col{border:1px solid var(--stroke);border-radius:10px;padding:10px;display:grid;gap:8px;min-height:0}.project-manager-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.project-manager-inline-actions{display:flex;gap:6px;flex-wrap:wrap}.project-manager-list{margin:0;padding:0;list-style:none;display:grid;gap:6px;max-height:38vh;overflow:auto}.project-manager-item{border:1px solid var(--stroke);border-radius:8px;padding:7px 8px;display:flex;align-items:center;justify-content:space-between;gap:8px}.project-manager-item.is-active{border-color:color-mix(in srgb,var(--accent) 45%,var(--stroke));background:color-mix(in srgb,var(--accent) 12%,transparent)}.project-manager-item-main{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px}.project-manager-badge{font-size:10px;color:var(--muted);border:1px solid var(--stroke);border-radius:var(--radius-pill);padding:1px 6px}.modal-actions{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.param-input{width:100%;padding:4px 8px;font-size:12px;font-family:var(--mono);border:1px solid var(--stroke);border-radius:4px;background:var(--bg);color:var(--fg);outline:none}.param-input:focus{border-color:var(--accent)}.modal-footer{padding:12px 14px;border-top:1px solid var(--stroke);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.legal-sheet-backdrop{z-index:120}.legal-sheet-modal{width:min(760px,calc(100vw - 20px))}.legal-sheet-head{border-bottom:1px solid var(--stroke);padding:12px 14px 10px;background:var(--modal-title-bg)}.legal-sheet-head-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.legal-sheet-title{font-size:13px;font-weight:700;letter-spacing:.01em}.legal-sheet-meta{margin-top:4px;font-size:11px}.legal-sheet-tabs{margin-top:10px;display:inline-flex;gap:6px;flex-wrap:wrap}.legal-sheet-tab{border-radius:999px;border:1px solid var(--stroke);background:transparent;color:var(--muted);padding:5px 10px;font-size:11px;cursor:pointer}.legal-sheet-tab[data-active=true]{background:var(--accent-muted);border-color:color-mix(in srgb,var(--accent) 35%,var(--stroke));color:var(--accent)}.legal-sheet-body{padding:14px;min-height:0;overflow:auto;font-size:13px;line-height:1.65}.legal-sheet-body h2{margin:0 0 12px;font-size:17px}.legal-sheet-body p{margin:0 0 12px}.auth-modal{width:min(460px,calc(100vw - 24px))}.auth-modal-body{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding-block:18px}.auth-modal-copy{max-width:320px;line-height:1.45}.auth-modal-btn-wrap{width:100%;display:flex;justify-content:center}.auth-modal-legal{max-width:360px;font-size:11px;line-height:1.4}.auth-modal-legal a{color:var(--accent);text-decoration:none}.auth-modal-legal a:hover{text-decoration:underline}.auth-modal-error{max-width:360px;color:var(--bad);background:var(--bad-bg);border:1px solid color-mix(in srgb,var(--bad) 30%,transparent);border-radius:var(--radius);font-size:11px;line-height:1.4;padding:8px 10px}.gsi-btn-wrap{display:grid;place-items:center}.gsi-btn-wrap[data-ready=false] .gsi-btn,.gsi-btn-wrap[data-ready=true] .gsi-btn-placeholder{display:none}.gsi-btn-placeholder{min-width:220px}.modal-wide{width:min(860px,calc(100vw - 24px));position:relative}.checkout-redirect-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#080b14d9;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.checkout-redirect-spinner{width:32px;height:32px;border:3px solid var(--stroke);border-top-color:var(--accent);border-radius:50%;animation:checkout-spin .8s linear infinite}@keyframes checkout-spin{to{transform:rotate(360deg)}}.checkout-redirect-text{font-size:14px;color:var(--text)}.group-order-body{display:flex;flex-direction:column;gap:10px}.group-order-list{display:flex;flex-direction:column;gap:8px}.group-order-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid var(--stroke);border-radius:var(--radius);background:var(--surface-raised)}.group-order-item[data-dragging=true]{opacity:.55}.group-order-item[data-drop-target=true]{border-color:var(--accent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%,transparent)}.group-order-item[data-drop-target=true][data-drop-side=before]{box-shadow:inset 0 2px 0 var(--accent),inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%,transparent)}.group-order-item[data-drop-target=true][data-drop-side=after]{box-shadow:inset 0 -2px 0 var(--accent),inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%,transparent)}.group-order-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-order-actions{display:flex;gap:6px;flex-shrink:0}.group-order-drag-hint{font-size:11px;-webkit-user-select:none;user-select:none}.group-order-preview{padding:8px 10px;border:1px dashed var(--stroke);border-radius:var(--radius);color:var(--muted);white-space:nowrap;overflow:auto}.group-scope-breadcrumb{display:inline-flex;align-items:center;flex-wrap:wrap;gap:2px;max-width:100%}.group-scope-part{display:inline-flex;align-items:center;gap:4px;min-width:0}.group-scope-sep{color:var(--muted)}.group-scope-link{border:none;background:none;color:var(--text);font:inherit;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.3;padding:0 2px;border-radius:4px;cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:transparent}.group-scope-link:hover{color:var(--accent);text-decoration-color:currentColor;background:var(--surface-hover)}.group-scope-link[data-active=true]{color:var(--accent);font-weight:600;text-decoration:none}.viewport-empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:none;color:var(--muted);z-index:1}.viewport-empty-icon{opacity:.4}.viewport-empty-text{font-size:13px;text-align:center;max-width:260px;line-height:1.5}.viewport-empty-text strong{color:var(--fg);opacity:.7}.group-edit-bar{display:flex;flex-direction:column;gap:6px;margin:4px 0;padding:8px 10px;border:1px solid var(--accent-muted, color-mix(in srgb, var(--accent) 30%, transparent));border-radius:8px;background:color-mix(in srgb,var(--accent) 5%,var(--panel))}.group-edit-bar-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.group-edit-bar-title{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.group-edit-exit-btn{color:var(--muted);flex-shrink:0}.group-edit-exit-btn:hover{color:var(--danger, #e55)}.group-edit-bar-nav{display:flex;align-items:center;gap:6px;min-width:0}.group-edit-bar-nav .group-scope-breadcrumb{flex:1;min-width:0}.group-edit-bar-nav-btns{display:flex;align-items:center;gap:2px;flex-shrink:0}.btn-icon{min-width:26px;padding:2px 4px;text-align:center;line-height:1}.group-edit-bar-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.group-edit-bar-toggle{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);cursor:pointer;flex-shrink:0}.group-edit-bar-toggle input[type=checkbox]{accent-color:var(--accent)}.group-edit-bar-sep{width:1px;height:12px;background:var(--stroke);flex-shrink:0}.group-edit-bar .bool-op-legend{min-width:0;row-gap:4px}.group-edit-enter-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:1px dashed var(--stroke);border-radius:var(--radius-sm);background:transparent;color:var(--text);cursor:pointer;font:inherit;font-size:12px;transition:all var(--speed)}.group-edit-enter-btn:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.group-edit-enter-btn svg{flex-shrink:0;opacity:.6}.group-edit-enter-btn .muted{margin-left:auto;font-size:11px}.pricing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:stretch}.pricing-card{border:1px solid var(--stroke);border-radius:var(--radius-lg);padding:18px 16px;display:flex;flex-direction:column;gap:12px;background:var(--surface-raised);transition:border-color var(--speed)}.pricing-card-highlight{border-color:var(--accent);background:var(--accent-muted)}.pricing-card-packs{grid-column:1 / -1}.pricing-plan{font-size:13px;font-weight:600;letter-spacing:.02em}.pricing-price{font-size:28px;font-weight:700;letter-spacing:-.02em}.pricing-period{font-size:12px;font-weight:400;color:var(--muted)}.pricing-features{list-style:none;margin:0;padding:0;font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:6px}.pricing-features li:before{content:"✓ ";color:var(--good)}.pricing-cta{margin-top:auto}.pricing-cta .btn{width:100%;text-align:center}.pricing-pack-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:stretch}.pricing-pack-item{border:1px solid var(--stroke);border-radius:10px;padding:12px;background:var(--surface);display:flex;flex-direction:column;gap:8px;min-height:180px}.pricing-pack-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.pricing-pack-name{font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}.pricing-pack-price{font-size:16px;font-weight:700}.pricing-pack-credits{font-size:24px;font-weight:800;letter-spacing:-.02em}.pricing-pack-meta{font-size:11px;color:var(--muted);line-height:1.3;min-height:2.8em}.pricing-pack-item .btn{margin-top:auto;width:100%}@media(max-width:900px){.pricing-pack-list{grid-template-columns:repeat(2,minmax(0,1fr))}}.pricing-note{margin-top:12px;text-align:center;font-size:11px}@media(max-width:600px){.pricing-grid,.pricing-pack-list{grid-template-columns:1fr}.modal-wide{width:calc(100vw - 16px)}.project-manager-body{grid-template-columns:1fr}}@media(max-width:1100px){.floating-panel-code{width:320px}.floating-panel-properties{width:300px}}@media(max-width:960px){.app{flex-direction:column}.activity-bar{display:none}.topbar.topbar-mobile{padding:4px 8px;gap:0}.status{font-size:10px;padding:3px 8px;display:none}.status.status-compact{display:inline-flex;font-size:9px;padding:2px 7px;min-width:0;min-height:0!important;flex-shrink:0}.mobile-quick-actions{width:100%;justify-content:stretch;gap:4px;flex-wrap:nowrap;overflow:visible}.mobile-header-controls{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;column-gap:6px}.mobile-quick-actions .btn{width:100%;min-width:0;min-height:32px;padding:5px 4px;font-size:11px;flex:0 0 auto}.mobile-view-pill{min-height:32px;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;border:1px solid var(--stroke);border-radius:9px;color:var(--muted);font-size:11px;white-space:nowrap;background:color-mix(in srgb,var(--panel) 86%,transparent)}.mobile-quick-actions .export-dropdown{margin-left:0;width:100%}.mobile-header-controls .export-dropdown>.btn{width:100%}.mobile-main-menu{width:min(320px,calc(100vw - 16px))}.legal-sheet-backdrop{place-items:stretch}.legal-sheet-modal{width:100vw;max-width:none;height:100vh;max-height:100vh;border-radius:0;border-left:0;border-right:0}@supports (height: 100dvh){.legal-sheet-modal{height:100dvh;max-height:100dvh}}.legal-sheet-head{padding:10px 12px 8px}.legal-sheet-body{padding:12px;font-size:12px}.mobile-chat-dock-wrap{left:8px;right:8px;bottom:8px}.chat-docked{border-radius:10px}.chat-dock-head{padding:7px 8px}.chat-dock-title{font-size:10px;letter-spacing:.04em}.chat-dock-blocked-minimal .chat-dock-blocked-text{font-size:11px}.chat-input-docked{padding:6px 8px 8px}.chat-input-docked textarea{height:40px;padding:8px 10px}}.viewport{flex:1;min-height:0;position:relative;background:var(--panel2)}.compile-progress{position:absolute;top:0;left:0;right:0;height:2px;z-index:20;background:linear-gradient(90deg,transparent 0%,var(--accent) 50%,transparent 100%);background-size:200% 100%;animation:compile-slide 1.2s ease-in-out infinite}@keyframes compile-slide{0%{background-position:100% 0}to{background-position:-100% 0}}.pane-viewport-mobile{position:relative}.layout.layout-mobile{padding-bottom:calc(62px + env(safe-area-inset-bottom,0px))}.mobile-sheet{position:absolute;left:8px;right:8px;bottom:calc(86px + env(safe-area-inset-bottom,0px));z-index:20;display:flex;flex-direction:column;gap:6px;pointer-events:none;transition:transform .18s ease}.mobile-sheet.is-open{pointer-events:auto}.mobile-sheet.is-dragging{transition:none}.mobile-sheet-top{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid var(--stroke);border-radius:10px;background:color-mix(in srgb,var(--panel) 95%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.mobile-sheet-top-compact{padding-block:7px;flex-wrap:wrap}.mobile-sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--muted);opacity:.35;margin:0 auto 4px;flex-basis:100%;touch-action:none;cursor:grab}.mobile-sheet.is-dragging .mobile-sheet-handle{cursor:grabbing}.mobile-sheet-title{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.mobile-sheet-close{flex-shrink:0}.mobile-sheet-body{max-height:min(50vh,460px);overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--stroke);border-radius:10px;background:color-mix(in srgb,var(--panel) 96%,transparent);box-shadow:var(--pane-shadow)}.mobile-chat-dock-wrap{position:fixed;left:10px;right:10px;bottom:calc(70px + env(safe-area-inset-bottom,0px));z-index:26}.mobile-bottom-nav{position:fixed;left:8px;right:8px;bottom:calc(4px + env(safe-area-inset-bottom,0px));display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;padding:6px;border:1px solid var(--stroke);border-radius:12px;background:color-mix(in srgb,var(--panel) 95%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--pane-shadow);z-index:30}.mobile-bottom-nav-btn{border:1px solid transparent;border-radius:9px;background:transparent;color:var(--muted);font-size:12px;line-height:1;min-height:44px;padding:0 6px;cursor:pointer}.mobile-bottom-nav-btn[data-active=true]{color:var(--accent);background:var(--accent-muted);border-color:color-mix(in srgb,var(--accent) 36%,transparent);font-weight:600}.constraints-panel{display:flex;flex-direction:column;min-height:0;border-top:1px solid var(--stroke);margin-top:4px}.constraints-header{display:flex;align-items:center;padding:6px 10px 4px;flex-shrink:0}.constraints-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.constraint-row{padding:5px 8px 4px;display:flex;flex-direction:column;gap:3px;border-bottom:1px solid var(--stroke);font-size:12px}.constraint-row:last-child{border-bottom:none}.constraint-row--live{background:var(--good-bg)}.constraint-row--violated{background:var(--warn-bg)}.constraint-row--broken{background:var(--bad-bg)}.constraint-row-main{display:flex;align-items:center;gap:4px;min-width:0}.constraint-status-icon{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.cst-icon-live{background:var(--good)}.cst-icon-violated{background:var(--warn)}.cst-icon-broken{background:var(--bad);opacity:.7}.constraint-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--mono, monospace);font-size:11px;color:var(--text)}.constraint-label[style*=pointer]{text-decoration:underline dotted;text-underline-offset:2px}.constraint-type-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--surface-raised);border-radius:3px;padding:1px 4px;flex-shrink:0}.constraint-type-icon{display:inline-block;margin-right:3px;font-size:10px;line-height:1;vertical-align:baseline}.constraint-type-badge--asbuilt{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.constraint-delta{font-size:11px;color:var(--warn);font-family:var(--mono, monospace);flex-shrink:0}.constraint-fix-btn,.constraint-note-btn,.constraint-delete-btn{background:transparent;border:none;cursor:pointer;padding:1px 4px;font-size:11px;line-height:1;border-radius:3px;flex-shrink:0;color:var(--muted);transition:color var(--speed),background var(--speed)}.constraint-fix-btn:hover{color:var(--accent);background:var(--accent-muted)}.constraint-note-btn:hover,.constraint-note-btn[data-has-note=true]{color:var(--warn);background:var(--warn-bg)}.constraint-delete-btn:hover{color:var(--bad);background:var(--bad-bg)}.constraint-note-edit{padding:2px 0}.constraint-note-input{width:100%;background:var(--panel2);border:1px solid var(--stroke-focus);border-radius:4px;color:var(--text);font-size:11px;padding:3px 6px;outline:none;box-sizing:border-box}.constraint-note-display{font-size:11px;color:var(--muted);font-style:italic;padding:0 2px;cursor:pointer;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.constraint-note-display:hover{color:var(--text)}.cst-gutter-live{background:radial-gradient(circle at 50% 50%,var(--good) 30%,transparent 70%);width:8px!important;height:8px!important;border-radius:50%;margin:auto}.cst-gutter-violated{background:radial-gradient(circle at 50% 50%,var(--warn) 30%,transparent 70%);width:8px!important;height:8px!important;border-radius:50%;margin:auto}.cst-gutter-broken{background:radial-gradient(circle at 50% 50%,var(--bad) 30%,transparent 70%);opacity:.6;width:8px!important;height:8px!important;border-radius:50%;margin:auto}.dof-section{padding:6px 8px;border-top:1px solid var(--stroke)}.dof-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:4px}.dof-row{display:flex;align-items:center;justify-content:space-between;padding:2px 0;font-size:11px}.dof-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.dof-dots{display:flex;gap:3px;margin-left:8px;flex-shrink:0}.dof-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block}.dof-dot--locked{background:transparent;border:1.5px solid var(--muted)}.constraint-type-picker{position:fixed;z-index:1000;background:var(--panel);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--modal-shadow);padding:8px;display:flex;flex-direction:column;gap:4px;min-width:140px;transform:translate(-50%,-100%);margin-top:-8px}.constraint-type-picker-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 4px 4px;border-bottom:1px solid var(--stroke);margin-bottom:2px}.constraint-type-picker-btn{display:flex;align-items:center;gap:6px;background:var(--surface-raised);border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:5px 10px;cursor:pointer;text-align:left;transition:background var(--speed),border-color var(--speed)}.constraint-type-picker-icon{width:14px;text-align:center;font-size:13px;line-height:1;opacity:.9}.constraint-type-picker-btn:hover{background:var(--accent-muted);border-color:color-mix(in srgb,var(--accent) 36%,transparent);color:var(--accent)}.constraint-type-picker-btn--recommended{background:var(--accent-muted);border-color:var(--accent);color:var(--accent);font-weight:600}.constraint-type-picker-cancel{background:transparent;border:none;color:var(--muted);font-size:11px;padding:3px 10px;cursor:pointer;text-align:center;margin-top:2px;border-radius:var(--radius-sm);transition:color var(--speed)}.constraint-type-picker-cancel:hover{color:var(--text)}.constraint-type-picker-distance-row{display:flex;gap:4px;align-items:center}.constraint-type-picker-distance-input{width:56px;background:var(--panel2);border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:4px 6px;outline:none;flex-shrink:0}.constraint-type-picker-distance-input:focus{border-color:var(--stroke-focus)}.constraint-type-picker-distance-row .constraint-type-picker-btn{flex:1}.constraint-type-picker-flip{background:transparent;border:1px solid var(--stroke);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;padding:3px 8px;cursor:pointer;text-align:center;width:100%}.constraint-type-picker-flip:hover{background:var(--surface-hover);color:var(--accent);border-color:var(--accent)}.constraint-type-picker-asbuilt{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);padding:3px 4px;cursor:pointer}.anchor-pick-indicator{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:color-mix(in srgb,var(--panel) 90%,transparent);border:1px solid var(--accent);border-radius:var(--radius-pill);color:var(--accent);font-size:12px;padding:6px 16px;pointer-events:none;white-space:nowrap;z-index:28;box-shadow:0 2px 12px #4a9eff33;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.anchor-pick-indicator--second{border-color:var(--good);color:var(--good);box-shadow:0 2px 12px #5ee8b033}.constrain-mode-bar{position:absolute;top:52px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:8px;padding:6px 16px;border-radius:var(--radius-pill);border:1px solid var(--accent);background:color-mix(in srgb,var(--panel) 92%,var(--accent) 8%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 12px #4a9eff2e;font-size:12px;color:var(--text);pointer-events:none;white-space:nowrap}.constrain-mode-bar-icon{font-size:14px;line-height:1}.constrain-mode-bar-title{font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}.constrain-mode-bar-status{color:var(--text-secondary)}.constrain-mode-bar-hint{color:var(--text-muted);font-size:11px}.constrain-mode-bar-sep{width:1px;height:14px;background:var(--stroke)}.constrain-mode-bar-count{color:var(--good);font-weight:600;font-size:11px;display:inline-block;animation:count-bounce .3s ease}@keyframes count-bounce{0%{transform:scale(1)}50%{transform:scale(1.35)}to{transform:scale(1)}}.viewport-constrain-cursor canvas{cursor:crosshair!important}.viewport-constrain-active{box-shadow:inset 0 0 0 2px var(--accent);transition:box-shadow .2s ease}.ai-edit-preview{border:1px solid var(--stroke);border-radius:var(--radius-lg);background:var(--bg-2);margin:8px 0;overflow:hidden}.ai-edit-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--stroke);background:var(--bg-1)}.ai-edit-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600}.ai-edit-label{color:var(--fg)}.ai-edit-stats{display:flex;gap:6px;font-weight:500;font-size:11px}.ai-edit-stat-add{color:var(--good)}.ai-edit-stat-rm{color:var(--bad)}.ai-edit-reason{padding:6px 12px;font-size:11px;color:var(--fg-2);border-bottom:1px solid var(--stroke)}.ai-edit-diff{max-height:300px;overflow:auto;font-family:var(--font-mono);font-size:11px;line-height:1.5}.ai-diff-hunk{width:100%;border-collapse:collapse}.ai-diff-line td{padding:0 4px;white-space:pre}.ai-diff-gutter{width:36px;min-width:36px;text-align:right;color:var(--fg-3);-webkit-user-select:none;user-select:none;opacity:.5}.ai-diff-marker{width:16px;min-width:16px;text-align:center;-webkit-user-select:none;user-select:none}.ai-diff-text{width:100%}.ai-diff-add{background:color-mix(in srgb,var(--good) 12%,transparent)}.ai-diff-add .ai-diff-marker,.ai-diff-add .ai-diff-text{color:var(--good)}.ai-diff-remove{background:color-mix(in srgb,var(--bad) 12%,transparent)}.ai-diff-remove .ai-diff-marker,.ai-diff-remove .ai-diff-text{color:var(--bad)}.ai-diff-separator{text-align:center;color:var(--fg-3);padding:2px 0;font-size:10px;border-top:1px dashed var(--stroke);border-bottom:1px dashed var(--stroke)}.ai-edit-no-changes{padding:12px;text-align:center;color:var(--fg-3);font-size:11px}.ai-edit-actions{display:flex;gap:8px;padding:8px 12px;border-top:1px solid var(--stroke);justify-content:flex-end}.ai-edit-accept{background:var(--good)!important;color:var(--bg)!important}.ai-edit-accept:hover{filter:brightness(1.1)}.history-diff-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center}.history-diff-modal{background:var(--bg-1);border:1px solid var(--stroke);border-radius:var(--radius-lg);width:min(90vw,900px);max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.history-diff-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--stroke)}.history-diff-header h3{margin:0;font-size:14px}.history-diff-body{flex:1;overflow:auto;font-family:var(--font-mono);font-size:11px;line-height:1.5}.history-diff-empty{padding:24px;text-align:center;color:var(--fg-3)}.toast{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%) translateY(12px);z-index:30;background:#0c1121e0;border:1px solid var(--stroke);border-radius:var(--radius-pill);padding:8px 18px;font-size:12px;color:var(--text);box-shadow:0 4px 16px #00000059;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;white-space:nowrap}.toast-visible{opacity:1;transform:translate(-50%) translateY(0)}:root[data-theme=light] .toast{background:#ffffffeb;border-color:#0f172a26;color:#0f172ad9}.desktop-chat-dock-wrap{position:fixed;bottom:16px;left:calc(50% + 22px);transform:translate(-50%);width:min(640px,calc(100vw - 32px));z-index:26}@media(max-width:960px){.desktop-chat-dock-wrap{display:none}}.mobile-sheet-body .editor-host{min-height:min(44vh,420px)}.mobile-sheet-body .objects-panel,.mobile-sheet-body .chat{min-height:min(58vh,560px)}.mobile-code-fullscreen{flex:1;min-height:0;background:var(--panel2)}.mobile-code-fullscreen .editor-host{display:block!important;height:100%;min-height:0}.three-host{position:absolute;top:0;right:0;bottom:0;left:0}.viewport-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:7;pointer-events:none;opacity:0;border:1px dashed transparent;background:linear-gradient(180deg,#4a9eff14,#4a9eff05 24%,#4a9eff03);transition:opacity .12s ease,border-color .12s ease}.viewport-drop-overlay.is-active{opacity:1;border-color:#4a9eff73}.viewport-drop-hint{position:absolute;top:10px;left:50%;transform:translate(-50%);padding:3px 10px;border-radius:999px;border:1px solid rgba(74,158,255,.45);background:#0b1020d9;color:#ffffffdb;font-size:11px;letter-spacing:.02em;white-space:nowrap}:root[data-theme=light] .viewport-drop-overlay{background:linear-gradient(180deg,#2f6de01a,#2f6de008 24%,#2f6de005)}:root[data-theme=light] .viewport-drop-overlay.is-active{border-color:#2f6de073}:root[data-theme=light] .viewport-drop-hint{border-color:#2f6de06b;background:#ffffffed;color:#0f172acc}.viewport-drop-marker{position:absolute;z-index:8;width:14px;height:14px;border-radius:999px;border:2px solid rgba(74,158,255,.95);background:#4a9eff33;box-shadow:0 0 0 5px #4a9eff24;transform:translate(-50%,-50%) scale(.8);opacity:0;pointer-events:none;transition:opacity .1s ease,transform .1s ease,border-color .1s ease,background .1s ease}.viewport-drop-marker.is-visible{opacity:1;transform:translate(-50%,-50%) scale(1)}.viewport-drop-marker.is-invalid{border-color:#f07080f2;background:#f0708033;box-shadow:0 0 0 5px #f0708021}.props{padding:10px 12px;overflow:auto;flex:1;min-height:0}.props-title{font-size:12px;color:var(--muted);margin-bottom:8px}.props-empty{font-size:12px;color:var(--muted)}.props-body{display:flex;flex-direction:column;gap:8px;font-size:12px}.props-block{margin-top:4px}.props-subtitle{font-size:11px;color:var(--muted);margin:6px 0;text-transform:uppercase;letter-spacing:.06em}.props-note{margin-top:6px}.props-row{display:grid;grid-template-columns:90px 1fr;gap:10px;align-items:center}.props-k{color:var(--muted)}.props-v{color:var(--text)}.props-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.props-slider-group{display:flex;flex-direction:column;gap:4px}.props-slider-item{display:flex;align-items:center;gap:6px}.props-slider-label{font-size:10px;color:var(--muted);width:14px;text-align:right;flex-shrink:0;text-transform:uppercase}.scrub-label{cursor:ew-resize;user-select:none;-webkit-user-select:none;border-radius:2px;padding:0 2px;transition:background .12s ease}.scrub-label:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.scrub-dragging{background:var(--accent-muted);color:var(--accent)}.props-slider-item input[type=range]{flex:1;min-width:0;height:4px;accent-color:var(--accent);cursor:pointer}.props-slider-item input[type=number]{width:56px;flex-shrink:0}.props-slider-item[data-axis=x] .props-slider-label{color:var(--axis-x)}.props-slider-item[data-axis=y] .props-slider-label{color:var(--axis-y)}.props-slider-item[data-axis=z] .props-slider-label{color:var(--axis-z)}.props-slider-item[data-axis=x] input[type=range]{accent-color:var(--axis-x)}.props-slider-item[data-axis=y] input[type=range]{accent-color:var(--axis-y)}.props-slider-item[data-axis=z] input[type=range]{accent-color:var(--axis-z)}.pill{display:inline-flex;gap:6px;align-items:center;border:1px solid var(--stroke);border-radius:999px;padding:4px 10px;background:var(--surface-raised)}.pill-impact{font-size:11px;padding:2px 8px;border-radius:var(--radius-sm)}.props-impact-chips{flex-wrap:wrap;gap:4px}.num{width:80px;border:none;outline:none;background:transparent;color:var(--text);font:inherit}.num:disabled{opacity:.5}.tree{display:flex;flex-direction:column;gap:6px}.tree-row{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:6px 10px;border:1px solid var(--stroke);border-radius:var(--radius);background:var(--surface-raised);transition:background var(--speed),border-color var(--speed)}.tree-row:hover{background:var(--surface-hover)}.tree-label{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.tree-badge{display:inline-block;margin:0 8px;padding:2px 8px;border:1px solid var(--stroke);border-radius:999px;color:var(--muted);background:#ffffff05;font-size:11px}.tree-actions{display:flex;gap:6px;align-items:center}.tree-add{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}.diag-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:auto}.diag-stats{display:flex;gap:16px;padding:8px 12px;font-size:11px;color:var(--muted);border-bottom:1px solid var(--stroke)}.diag-empty{padding:12px;font-size:12px;color:var(--muted);flex:1}.diag-list{margin:0;padding:10px 16px 16px;font-size:12px;color:var(--text);overflow:auto;flex:1}.diag-item{margin:6px 0;color:var(--bad)}.diag-clickable{cursor:pointer;text-decoration:underline;text-decoration-style:dashed;text-underline-offset:3px}.diag-clickable:hover{color:var(--text)}.node-icon{width:16px;height:16px;flex:0 0 auto;color:var(--node-icon-color)}.node-icon *{fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}.node-icon .node-icon-cut{fill:var(--panel)}.bool-editor{display:flex;flex-direction:column;gap:10px}.bool-editor-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.bool-editor-hint{font-size:11px;padding:2px 8px;border:1px dashed var(--stroke);border-radius:var(--radius-pill);background:#ffffff05}.bool-op-legend{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.bool-op-hint{font-size:11px}.bool-op-chip{transform:translateY(-.5px)}.bool-op-more{font-size:11px}.bool-editor-children{display:flex;flex-direction:column;gap:8px}.bool-editor-child{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:6px 10px;border:1px solid var(--stroke);border-radius:var(--radius);background:var(--surface-raised);transition:background var(--speed)}.bool-editor-child:hover{background:var(--surface-hover)}.bool-editor-child[data-selected=true]{background:var(--accent-muted);border-color:var(--accent)}.bool-editor-child-icon{display:flex;align-items:center;gap:8px}.bool-child-role{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);border:1px solid var(--stroke);font-size:11px;line-height:1.2}.bool-child-role[data-role=base]{color:#6cc8ff;border-color:#6cc8ff73;background:#6cc8ff1a}.bool-child-role[data-role=cutter]{color:#ff9c90;border-color:#ff9c9073;background:#ff9c901a}.bool-child-role[data-role=part]{color:#94d98c;border-color:#94d98c73;background:#94d98c1a}.bool-child-role[data-role=operand]{color:#c9b5ff;border-color:#c9b5ff73;background:#c9b5ff1f}.bool-editor-child-actions{display:flex;gap:6px;align-items:center}.bool-editor-add{display:flex;gap:8px;flex-wrap:wrap}.objects-panel{flex:1;min-height:0;display:flex;flex-direction:column;padding:0;gap:0;overflow:hidden}.objects-header{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--stroke);flex-shrink:0}.objects-title{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.objects-meta{font-size:12px}.objects-empty{font-size:12px;padding:12px}.diagnostics-panel{flex:1;min-height:0;overflow-y:auto;padding:8px 12px}.diagnostics-empty{font-size:12px;padding:12px}.diagnostics-list{list-style:none;margin:0;padding:0}.diagnostic-item{font-size:12px;font-family:var(--font-mono, monospace);padding:6px 8px;border-bottom:1px solid var(--border);color:var(--error, #f44);word-break:break-word}.thumb-canvas{width:40px;height:40px;display:block}.objects-layers{flex:1;min-height:0;overflow-y:auto}.layers-list{display:flex;flex-direction:column}.modules-section-header{padding:8px 10px 4px;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.module-uncalled{opacity:.6}.module-uncalled .layer-label{font-style:italic}.layer-row{display:flex;align-items:center;gap:10px;padding:6px 10px;min-height:52px;border-bottom:1px solid color-mix(in srgb,var(--stroke) 65%,transparent);cursor:pointer;transition:background var(--speed)}.layer-row:hover{background:var(--surface-hover)}.layer-row[data-selected=true]{background:var(--accent-muted);border-left:3px solid var(--accent)}.layer-row[data-inspected=true]:not([data-selected=true]){background:#4a9eff1f;border-left:3px solid rgba(74,158,255,.6)}.layer-thumbnail{width:40px;height:40px;flex-shrink:0;border:1px solid color-mix(in srgb,var(--stroke) 85%,transparent);border-radius:6px;background:var(--subtle-bg);overflow:hidden}.layer-thumb-placeholder{width:40px;height:40px}.layer-chevron{width:16px;height:16px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:none;background:none;color:var(--muted);cursor:pointer;padding:0;border-radius:3px;transition:color var(--speed),background var(--speed)}.layer-chevron:hover{color:var(--text);background:var(--surface-hover)}.layer-chevron svg{fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}.layer-chevron-spacer{width:16px;flex-shrink:0}.layer-label{flex:1;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.layer-bool-summary{flex-shrink:0;font-size:10px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-info-btn{width:22px;height:22px;border-radius:999px;border:1px solid var(--stroke);background:var(--surface-raised);color:var(--muted);font-size:11px;font-weight:700;flex-shrink:0;padding:0;cursor:pointer}.layer-info-btn:hover{color:var(--text);background:var(--surface-hover)}.layer-group-edit-btn{width:22px;height:22px;border-radius:4px;border:none;background:none;color:var(--muted);flex-shrink:0;padding:0;cursor:pointer;opacity:0;transition:opacity .12s ease;display:flex;align-items:center;justify-content:center}.layer-row:hover .layer-group-edit-btn{opacity:1}.layer-group-edit-btn:hover{color:var(--accent);background:var(--accent-muted)}.layer-vis-btn{width:22px;height:22px;flex-shrink:0;background:none;border:none;border-radius:4px;color:var(--muted);cursor:pointer;opacity:0;transition:opacity .12s ease,color var(--speed);display:flex;align-items:center;justify-content:center;padding:0}.layer-row:hover .layer-vis-btn,.layer-vis-btn[data-hidden=true]{opacity:1}.layer-vis-btn:hover{color:var(--text);background:var(--surface-hover)}.layer-vis-btn[data-hidden=true]{color:var(--dim)}.layer-row[data-hidden=true]{opacity:.45}.layer-row[data-hidden=true] .layer-label{text-decoration:line-through;text-decoration-color:var(--dim)}.layer-bool-role{flex-shrink:0;font-size:10px;padding:2px 6px}.mobile-bool-tip-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0000005c;display:flex;align-items:flex-end;justify-content:center;padding:12px}.mobile-bool-tip-card{width:min(560px,100%);border:1px solid var(--stroke);border-radius:12px;background:var(--panel);box-shadow:var(--pane-shadow);padding:12px;display:flex;flex-direction:column;gap:10px}.mobile-bool-tip-title{font-size:12px;font-weight:700}.mobile-bool-tip-body{font-size:12px;line-height:1.45}.objects-properties{display:flex;flex-direction:column;gap:2px}.objects-properties .params-panel{padding:0 8px 8px;overflow:visible}.objects-properties .params-empty{padding:8px}.objects-properties[data-inspected=true]{box-shadow:inset 0 0 0 1px #4a9eff59}.panel-list{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.panel-list-empty{padding:16px;text-align:center;font-size:12px}.panel-list-body{display:flex;flex-direction:column;flex:1;min-height:0}.props-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:2px;margin-bottom:8px;font-size:11px}.props-breadcrumb-sep{color:var(--muted);margin:0 2px;font-size:13px}.props-breadcrumb-item{background:none;border:none;color:var(--muted);padding:2px 4px;cursor:pointer;border-radius:var(--radius-sm, 4px);font-size:11px;transition:all var(--speed)}.props-breadcrumb-item:hover{color:var(--text);background:var(--surface-hover)}.props-breadcrumb-item.active{color:var(--text);font-weight:500}.props-section{border-radius:6px}.props-section[data-active=true]{background:#4a9eff14;box-shadow:inset 2px 0 #4a9effbf}.props-section-header{display:flex;align-items:center;gap:6px;width:100%;padding:7px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:none;border:none;cursor:pointer}.props-section-header:hover{color:var(--fg)}.props-section-chevron{flex-shrink:0;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:transform .15s ease}.props-section-chevron[data-open=true]{transform:rotate(90deg)}.monaco-editor .scad-highlight{background:var(--inline-highlight-bg);border-bottom:1px solid var(--inline-highlight-border)}@media(max-width:900px){.floating-panel-code{width:280px}.floating-panel-properties{width:260px}}.gizmo-label{position:absolute;display:none;pointer-events:none;z-index:10;padding:4px 8px;border-radius:6px;background:#000000bf;color:#ffffffe6;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:11px;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.context-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:19}@keyframes long-press-ring{0%{transform:translate(-50%,-50%) scale(.3);opacity:.5}to{transform:translate(-50%,-50%) scale(1);opacity:0}}.long-press-indicator{position:absolute;width:48px;height:48px;border-radius:50%;border:2px solid var(--accent);pointer-events:none;z-index:10;animation:long-press-ring .45s ease-out forwards}.context-menu{position:absolute;z-index:20;min-width:160px;padding:4px 0;border-radius:var(--radius);border:1px solid var(--elevated-border);background:var(--context-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--context-shadow)}.context-menu-item{display:block;width:100%;padding:7px 14px;border:none;background:transparent;color:var(--text);font-size:12px;text-align:left;cursor:pointer;transition:background var(--speed)}.context-menu-item:hover{background:var(--accent-muted);color:var(--accent)}.context-menu-item[data-active=true]{color:var(--accent)}.context-menu-item:disabled{opacity:.4;cursor:not-allowed}.context-menu-item:disabled:hover{background:transparent}.context-menu-sep{height:1px;margin:4px 8px;background:var(--stroke)}.params-panel{flex:1;min-height:0;overflow:auto;padding:8px 12px}.variables-focus-bar{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}.variables-filter-row{margin-bottom:8px}.variables-filter-input{width:100%;padding:6px 8px;border:1px solid var(--stroke);border-radius:6px;background:var(--bg);color:var(--text);font-size:12px}.variables-filter-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.variables-empty-focus{font-size:11px;padding:6px 8px;border:1px dashed var(--stroke);border-radius:6px;margin-bottom:8px}.variables-tree-card{border:1px solid var(--stroke);border-radius:8px;padding:8px;margin-bottom:8px;background:color-mix(in srgb,var(--panel) 86%,transparent)}.variables-tree-title{font-size:11px;font-weight:600;margin-bottom:6px}.variables-tree-node{padding:6px 0;border-top:1px dashed var(--stroke)}.variables-tree-node:first-of-type{border-top:none;padding-top:0}.variables-tree-root{font-size:11px;font-weight:600}.variables-tree-row{font-size:11px;margin-top:2px}.params-empty{padding:12px;font-size:12px;flex:1}.param-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--stroke)}.param-row:last-child{border-bottom:none}.param-row.var-focused{background:color-mix(in srgb,var(--var-focus-color, var(--accent)) 14%,transparent);box-shadow:inset 2px 0 color-mix(in srgb,var(--var-focus-color, var(--accent)) 76%,transparent)}.param-row.var-related{background:color-mix(in srgb,var(--var-focus-color, var(--accent)) 8%,transparent);box-shadow:inset 2px 0 color-mix(in srgb,var(--var-focus-color, var(--accent)) 38%,transparent)}.param-label{font-size:11px;color:var(--muted);min-width:70px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.param-control{flex:1;display:flex;align-items:center;gap:6px}.param-control input[type=range]{flex:1;height:4px;accent-color:var(--accent);cursor:pointer}.param-control input.num{width:60px;padding:4px 6px;font-size:11px;background:var(--bg);border:1px solid var(--stroke);border-radius:4px;color:var(--text);text-align:right;transition:border-color var(--speed);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.param-control input.num:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.param-vector{gap:4px}.param-vector input.num{flex:1;min-width:0;width:auto;text-align:center}.param-check{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);cursor:pointer}.param-check input[type=checkbox]{accent-color:var(--accent)}.param-control input[type=text]{flex:1;min-width:0}.pane-viewport>.pane-title{display:flex;align-items:center}.mobile-quick-actions{position:relative;display:inline-flex;align-items:center;gap:6px;z-index:36;pointer-events:auto}.mobile-quick-actions::-webkit-scrollbar{display:none}.mobile-quick-actions .btn[data-active=true]{background:var(--accent-muted);border-color:color-mix(in srgb,var(--accent) 35%,var(--stroke));color:var(--accent);box-shadow:inset 0 -2px color-mix(in srgb,var(--accent) 60%,transparent);font-weight:600}.mobile-main-menu{position:absolute;right:0;top:calc(100% + 6px);width:min(320px,calc(100vw - 20px));max-height:min(68vh,calc(100vh - 60px),520px);overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--stroke);border-radius:12px;background:color-mix(in srgb,var(--panel) 97%,transparent);box-shadow:0 10px 24px #00000047;padding:8px;display:grid;gap:8px;z-index:35}.mobile-main-menu-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.mobile-main-menu-head-copy{display:grid;gap:2px}.mobile-main-menu-brand{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text)}.mobile-main-menu-title{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.mobile-main-menu-section{border:1px solid var(--stroke);border-radius:10px;background:color-mix(in srgb,var(--surface-raised) 84%,transparent);padding:8px;display:grid;gap:6px}.mobile-main-menu-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.mobile-main-menu-item,.mobile-main-menu-link{display:block;width:100%;border:1px solid var(--stroke);border-radius:8px;background:var(--surface-raised);color:var(--text);padding:7px 10px;font-size:12px;text-align:left;text-decoration:none;cursor:pointer;touch-action:manipulation}.mobile-main-menu-item:hover,.mobile-main-menu-link:hover{background:var(--surface-hover)}.mobile-main-menu-item:disabled{opacity:.6;cursor:not-allowed}.mobile-main-menu-field{display:grid;gap:4px}.mobile-main-menu-label-inline{font-size:11px;color:var(--muted)}.mobile-main-menu-select{width:100%}.mobile-main-menu-meta{font-size:11px}.export-dropdown{position:relative;margin-left:auto}.activity-bar .export-dropdown{margin-left:0}.activity-bar .export-dropdown>.btn{width:62px;min-height:46px;display:flex;flex-direction:column;gap:2px;align-items:center;justify-content:center;border-radius:var(--radius);border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all var(--speed);padding:0;font-size:10px;line-height:1;letter-spacing:.02em}.activity-bar .export-dropdown>.btn:hover{color:var(--text);background:var(--surface-hover)}.activity-bar .export-dropdown .export-menu{position:fixed;top:auto;left:74px;right:auto;bottom:auto}.mobile-quick-actions .btn,.export-menu-item{touch-action:manipulation}.export-menu{position:absolute;top:100%;right:0;z-index:100;background:var(--bg);border:1px solid var(--stroke);border-radius:6px;padding:4px 0;min-width:140px;max-width:calc(100vw - 16px);box-shadow:0 4px 12px #0000004d}.export-menu-item{display:block;width:100%;padding:6px 12px;text-align:left;font-size:12px;color:var(--text);background:none;border:none;cursor:pointer}.export-menu-item:hover{background:var(--accent-muted);color:var(--accent)}.export-menu-item:disabled{opacity:.6;cursor:wait}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scroll-thumb-hover)}::selection{background:var(--selection-bg)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.viewcube-container{position:absolute;top:12px;right:12px;z-index:5;display:flex;flex-direction:column;align-items:center;gap:4px;pointer-events:auto;-webkit-user-select:none;user-select:none}.viewcube-wrapper{width:80px;height:80px;perspective:300px;display:flex;align-items:center;justify-content:center;cursor:grab}.viewcube-wrapper:active{cursor:grabbing}.viewcube{width:54px;height:54px;position:relative;transform-style:preserve-3d;transition:transform 50ms linear}.vc-face{position:absolute;width:54px;height:54px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--viewcube-face-text);background:var(--viewcube-face-bg);border:1px solid var(--viewcube-face-border);backface-visibility:hidden;cursor:pointer;transition:background var(--speed),color var(--speed)}.vc-face:hover{background:var(--viewcube-face-hover-bg);color:var(--viewcube-face-hover-text);border-color:var(--viewcube-face-hover-border)}.vc-front,.vc-back,.vc-right,.vc-left,.vc-top,.vc-bottom{border-radius:0}.viewcube-axes{display:flex;gap:6px;font-size:9px;font-weight:700;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.vc-axis-x{color:var(--axis-x)}.vc-axis-y{color:var(--axis-y)}.vc-axis-z{color:var(--axis-z)}.axis-indicator{position:absolute;bottom:12px;left:12px;z-index:5;width:50px;height:50px;perspective:200px;pointer-events:none}.axis-indicator-scene{width:50px;height:50px;position:relative;transform-style:preserve-3d}.axis-line{position:absolute;top:50%;left:50%;width:20px;height:2px;transform-origin:0 50%;border-radius:1px}.axis-x{background:#f05050;transform:rotateY(90deg)}.axis-y{background:#50d060;transform:rotateX(0) translateZ(0)}.axis-z{background:#5080f0;transform:rotateX(-90deg)}.axis-label{position:absolute;font-size:9px;font-weight:700;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;transform-style:preserve-3d}.axis-label-x{color:#f05050;top:50%;left:50%;transform:rotateY(90deg) translate(22px) translateY(-50%)}.axis-label-y{color:#50d060;top:50%;left:50%;transform:translateZ(22px) translateY(-50%)}.axis-label-z{color:#5080f0;top:50%;left:50%;transform:rotateX(-90deg) translate(22px) translateY(-50%)}.nav-hints{position:absolute;bottom:70px;left:12px;z-index:6;pointer-events:auto}.nav-hints-card{background:var(--panel2);border:1px solid var(--stroke);border-radius:var(--radius);padding:10px 14px;box-shadow:0 4px 16px #0000004d;display:flex;flex-direction:column;gap:4px;min-width:150px}.nav-hints-title{font-size:11px;font-weight:600;color:var(--text);margin-bottom:2px}.nav-hints-row{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:8px}.nav-hints-row kbd{display:inline-block;font-size:10px;font-family:inherit;background:var(--surface-raised);border:1px solid var(--stroke);border-radius:3px;padding:1px 5px;color:var(--text);min-width:52px;text-align:center}.nav-hints-card .btn{margin-top:4px;align-self:flex-end}.viewport-toolbar{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:5;display:flex;align-items:center;gap:2px;padding:3px 4px;border-radius:10px;border:1px solid var(--viewport-toolbar-border);background:var(--viewport-toolbar-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--viewport-toolbar-shadow);pointer-events:auto;-webkit-user-select:none;user-select:none}.viewport-panel-toggles{position:absolute;top:116px;right:8px;z-index:5;display:flex;align-items:center;gap:2px;padding:3px 4px;border-radius:10px;border:1px solid var(--viewport-toolbar-border);background:var(--viewport-toolbar-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--viewport-toolbar-shadow);pointer-events:auto;-webkit-user-select:none;user-select:none;opacity:.85;transition:opacity var(--speed)}.viewport-panel-toggles:hover{opacity:1}.toolbar-group{display:flex;align-items:center;gap:1px}.toolbar-sep{width:1px;height:20px;margin:0 4px;background:var(--viewport-toolbar-sep)}.toolbar-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 8px;border:none;border-radius:6px;background:transparent;color:var(--viewport-toolbar-btn);font-size:11px;cursor:pointer;transition:background var(--speed),color var(--speed);white-space:nowrap}.toolbar-btn:hover{background:var(--viewport-toolbar-btn-hover-bg);color:var(--viewport-toolbar-btn-hover-text)}.toolbar-btn[data-active=true]{background:var(--accent-muted);color:var(--accent);box-shadow:inset 0 -2px 0 var(--accent);font-weight:600}.toolbar-btn[data-active=true]:hover{background:#4a9eff38}.toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.toolbar-btn:disabled:hover{background:transparent}.toolbar-group--dimmed{opacity:.45}.toolbar-group--dimmed .toolbar-btn{pointer-events:auto}.toolbar-label{display:none}@media(min-width:1100px){.toolbar-label{display:inline}}.snap-settings-popup{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:6px;background:var(--viewport-toolbar-bg);border:1px solid var(--viewport-toolbar-border);border-radius:8px;box-shadow:var(--viewport-toolbar-shadow);z-index:10;min-width:180px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.snap-settings-header{padding:8px 12px;border-bottom:1px solid var(--viewport-toolbar-sep)}.snap-settings-content{padding:8px 12px}.snap-settings-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:3px 0}.snap-settings-label{font-size:11px;color:var(--viewport-toolbar-btn);white-space:nowrap;flex:1}.snap-settings-row input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--accent)}.snap-settings-select{padding:3px 6px;border:1px solid var(--viewport-toolbar-border);border-radius:4px;background:transparent;color:var(--viewport-toolbar-btn);font-size:10px;cursor:pointer;min-width:80px}.snap-settings-select:hover{background:var(--viewport-toolbar-btn-hover-bg)}.box-select-rect{position:absolute;border:1px dashed var(--accent);background:#4a9eff14;pointer-events:none;z-index:20}.shortcuts-body{max-height:70vh;overflow-y:auto}.shortcuts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:600px){.shortcuts-grid{grid-template-columns:1fr}}.shortcuts-group{display:flex;flex-direction:column;gap:4px}.shortcuts-heading{font-size:12px;font-weight:700;color:var(--accent);margin:0 0 6px;text-transform:uppercase;letter-spacing:.06em}.shortcut-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 0}.shortcut-keys{display:flex;gap:3px;align-items:center;flex-shrink:0}.shortcut-kbd{display:inline-block;padding:2px 6px;border:1px solid var(--stroke);border-radius:4px;background:var(--surface-raised);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:11px;min-width:20px;text-align:center;white-space:nowrap}.shortcut-sep{font-size:10px;color:var(--muted)}.shortcut-desc{font-size:12px;color:var(--muted);text-align:right}.dim-label{position:absolute;pointer-events:none;z-index:8;padding:2px 6px;border-radius:4px;background:#000000b3;color:#ffffffe6;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:10px;white-space:nowrap;transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.15)}.dim-label.var-focus{border-width:2px;box-shadow:0 0 0 1px color-mix(in srgb,currentColor 24%,transparent)}:root[data-theme=light] .dim-label{background:#ffffffe6;color:#0f172ad9;border-color:#0f172a33}.param-dim-label{position:absolute;pointer-events:auto;z-index:9;padding:3px 9px;border-radius:4px;background:#060a12e0;color:#fffffff2;font-family:IBM Plex Sans,Segoe UI,PingFang SC,Noto Sans,sans-serif;font-size:11px;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1;white-space:nowrap;transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1.5px solid currentColor;cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;gap:3px;transition:background .15s,transform .15s,opacity .15s}.param-dim-label:hover{background:#060a12fa;transform:translate(-50%,-50%) scale(1.05);box-shadow:0 0 10px color-mix(in srgb,currentColor 60%,transparent)}:root[data-theme=light] .param-dim-label{background:#fffffff5;color:#0f172af0}:root[data-theme=light] .param-dim-label:hover{background:#fff}.param-dim-label.locked{border-style:dashed;opacity:.85;cursor:pointer}.param-dim-label.locked.multi-var{cursor:pointer;opacity:.75}.param-dim-label.locked.unsolvable{opacity:.5;cursor:not-allowed;border-style:dotted}.param-dim-label.related{border-style:dashed;opacity:.72;filter:saturate(.85)}.param-dim-label.secondary{border-style:dashed;opacity:.68;filter:saturate(.82)}.constraint-dim-label{pointer-events:auto;z-index:8}.param-dim-label.readonly{pointer-events:none;cursor:default}.param-dim-label.readonly:hover{transform:translate(-50%,-50%);box-shadow:none}.param-dim-label.var-focus-primary{opacity:1;border-width:2px;filter:saturate(1.2) brightness(1.08);box-shadow:0 0 0 2px color-mix(in srgb,currentColor 28%,transparent)}.param-dim-label.var-focus-related{opacity:.86;border-style:dashed;filter:saturate(1.02) brightness(1.02);box-shadow:0 0 0 1px color-mix(in srgb,currentColor 16%,transparent)}.param-dim-label.var-dimmed{opacity:.35;filter:saturate(.6)}@keyframes constraint-dim-flash{0%{filter:brightness(1.95)}to{filter:brightness(1)}}.constraint-dim-label.constraint-flash{animation:constraint-dim-flash .52s ease-out}.param-dim-lock{width:11px;height:11px;display:inline-flex;align-items:center;justify-content:center;opacity:.9}.param-dim-lock svg{width:11px;height:11px}.param-dim-name{opacity:.92}.param-dim-sep{opacity:.72}.param-dim-value{font-weight:620;letter-spacing:.01em}@keyframes dim-label-shake{0%,to{transform:translate(-50%,-50%)}20%,60%{transform:translate(calc(-50% + 4px),-50%)}40%,80%{transform:translate(calc(-50% - 4px),-50%)}}.param-dim-label.error-flash{animation:dim-label-shake .4s ease;border-color:var(--bad, #ef4444)!important;color:var(--bad, #ef4444)!important}@keyframes dim-label-value-flash{0%{filter:brightness(1.65)}to{filter:brightness(1)}}.param-dim-label.value-flash{animation:dim-label-value-flash .24s ease-out}@keyframes dim-label-dep-pulse{0%{box-shadow:0 0 color-mix(in srgb,currentColor 70%,transparent)}65%{box-shadow:0 0 0 7px transparent}to{box-shadow:0 0 0 0 transparent}}.param-dim-label.dep-pulse{animation:dim-label-dep-pulse .72s ease-out}@media(prefers-reduced-motion:reduce){.param-dim-label{transition:none}.param-dim-label:hover{transform:translate(-50%,-50%);box-shadow:none}.param-dim-label.error-flash,.param-dim-label.value-flash,.param-dim-label.dep-pulse,.constraint-dim-label.constraint-flash{animation:none}}.var-picker-popup{position:absolute;z-index:11;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;background:#000000eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.15);font-size:11px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:nowrap;pointer-events:auto}.var-picker-title{color:#fff9;font-size:10px}.var-picker-btn{padding:2px 8px;border-radius:3px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;cursor:pointer;font-family:inherit;font-size:11px;transition:background .1s}:root[data-theme=light] .var-picker-title{color:#0f172a80}:root[data-theme=light] .var-picker-btn{border-color:#0f172a33;color:#0f172a}:root[data-theme=light] .var-picker-btn:hover{background:#0f172a14}.param-dim-input{position:absolute;z-index:10;transform:translate(-50%,-50%);width:72px;padding:2px 6px;border-radius:4px;background:#000000f2;color:#fff;font-family:IBM Plex Sans,Segoe UI,PingFang SC,Noto Sans,sans-serif;font-size:11px;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1;border:2px solid;outline:none;text-align:center}.param-dim-input:focus{box-shadow:0 0 0 2px #fff3}:root[data-theme=light] .param-dim-input{background:#fff;color:#0f172a}:root[data-theme=light] .param-dim-input:focus{box-shadow:0 0 0 2px #0000001a}.var-picker-popup{position:absolute;z-index:11;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;background:#000000eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.15);font-size:11px;pointer-events:auto}.var-picker-title{color:#fff9;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:nowrap}.var-picker-btn{padding:2px 8px;border-radius:3px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;cursor:pointer;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:11px;transition:background .12s}.var-picker-btn:hover{background:#ffffff26}:root[data-theme=light] .var-picker-popup{background:#fffffff2;border-color:#0000001f}:root[data-theme=light] .var-picker-title{color:#0f172a99}:root[data-theme=light] .var-picker-btn{color:#0f172a;border-color:#0003}:root[data-theme=light] .var-picker-btn:hover{background:#00000014}@media(max-width:768px){.param-dim-label{font-size:9px;padding:1px 5px}.param-dim-input{font-size:9px;width:60px}}.settings-panel{font-size:12px}.sidebar-settings-panel{flex:1;overflow-y:auto}.settings-section{padding:8px 12px;border-bottom:1px solid var(--stroke)}.settings-section:last-child{border-bottom:none;padding-bottom:12px}.settings-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:6px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:3px 0}.settings-label{font-size:11px;opacity:.7;white-space:nowrap}.settings-row .select-compact{flex:1;min-width:0;max-width:140px}.settings-row input[type=checkbox]{width:14px;height:14px;cursor:pointer}.settings-range{flex:1;min-width:0;max-width:140px;height:4px;cursor:pointer;accent-color:var(--accent)}.settings-theme-group{display:flex;gap:4px}.settings-theme-btn{flex:1;padding:4px 8px;border:1px solid var(--stroke);border-radius:6px;background:transparent;color:inherit;font-size:11px;cursor:pointer;transition:background var(--speed),border-color var(--speed)}.settings-theme-btn:hover{background:var(--surface-hover)}.settings-theme-btn[data-active=true]{background:var(--accent-muted);border-color:var(--accent);color:var(--accent);font-weight:600}.settings-cycle-btn{padding:3px 8px;border:1px solid var(--stroke);border-radius:5px;background:transparent;color:inherit;font-size:11px;cursor:pointer;transition:background var(--speed),border-color var(--speed)}.settings-cycle-btn:hover{background:var(--surface-hover);border-color:var(--accent)}.settings-size-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0;max-width:140px}.settings-custom-input{display:flex;align-items:center;gap:4px}.settings-custom-input .input-compact{flex:1;min-width:0}.settings-input-unit{font-size:10px;opacity:.6;white-space:nowrap}.settings-legal{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 12px 8px;border-bottom:none}.settings-legal-link{background:none;border:none;color:var(--muted);font-size:10px;cursor:pointer;padding:0}.settings-legal-link:hover{color:var(--accent);text-decoration:underline}.settings-legal-sep{color:var(--muted);font-size:10px;opacity:.5}.inline-diagnostics{border-top:1px solid var(--stroke);padding:6px 8px;flex-shrink:0;max-height:120px;overflow-y:auto}.inline-diagnostics-header{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--bad);margin-bottom:4px}.inline-diag-item{font-size:11px;padding:2px 4px;border-radius:3px;color:var(--bad);line-height:1.4;transition:background var(--speed)}.inline-diag-item:hover{background:var(--bad-bg)}.sidebar-history-section{border-top:1px solid var(--stroke);margin-top:4px;flex-shrink:0}.sidebar-history-section>summary{padding:6px 10px;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}.sidebar-history-section>summary:before{content:"▶";display:inline-block;margin-right:6px;font-size:8px;transition:transform var(--speed)}.sidebar-history-section[open]>summary:before{transform:rotate(90deg)}.sidebar-diagnostics-panel{flex:1;overflow-y:auto;padding:8px}.sidebar-history-panel{flex:1;overflow-y:auto}.activity-bar-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 3px;border-radius:7px;background:var(--bad);color:#fff;font-size:9px;font-weight:700;line-height:14px;text-align:center;pointer-events:none}.shape-library{background:var(--panel);flex-shrink:0;border:1px solid var(--stroke);border-radius:8px;box-shadow:0 2px 8px #00000040;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);max-height:320px;overflow-y:auto;overflow-x:hidden}.viewport>.shape-library{position:absolute;top:8px;left:8px;z-index:6;width:160px;max-height:calc(100% - 52px);background:var(--panel);border-radius:var(--radius-lg);box-shadow:var(--pane-shadow);overflow:hidden}.shape-library-collapsed{overflow:hidden}.shape-library-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.shape-library-title{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.shape-library-toggle{padding:2px 6px!important;font-size:13px!important}.shape-library-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:0 6px 6px}.shape-library-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;transition:background var(--speed),color var(--speed);min-width:0;overflow:hidden}.shape-library-item:hover,.shape-library-item.is-dragging{background:var(--accent-muted);color:var(--accent)}.shape-library-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.shape-library-icon .thumb-canvas{width:28px;height:28px;border-radius:3px}.shape-library-name{font-size:9px;text-transform:uppercase;letter-spacing:.04em;text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shape-library-divider{font-size:9px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:6px 8px 2px;border-top:1px solid var(--border);margin-top:2px}.shape-library-search{position:relative;padding:0 8px 6px}.shape-library-search input{width:100%;padding:4px 24px 4px 8px;font-size:11px;border:1px solid var(--stroke);border-radius:4px;background:var(--bg);color:var(--fg);outline:none}.shape-library-search input:focus{border-color:var(--accent)}.shape-library-search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;line-height:1;padding:0 2px}.shape-library-search-clear:hover{color:var(--fg)}.shape-library-empty{padding:8px 12px;font-size:11px;color:var(--muted);text-align:center}.align-buttons{gap:3px!important;flex-wrap:wrap}.align-buttons .btn{padding:4px 6px;min-width:26px;font-size:10px}.history-panel{flex:1;min-height:0;overflow-y:auto;padding:0}.history-empty{padding:12px;font-size:12px}.history-list{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}.history-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 12px;border:none;border-bottom:1px solid var(--stroke);background:transparent;color:var(--text);font-size:12px;cursor:pointer;text-align:left;transition:background var(--speed)}.history-item:hover{background:var(--surface-hover)}.history-item-current{background:var(--accent-muted);border-left:3px solid var(--accent);font-weight:600}.history-item-redo{opacity:.45}.history-item-compare{outline:2px solid var(--accent);outline-offset:-2px}.history-icon{flex-shrink:0;opacity:.5;margin-right:6px}.history-icon[data-category]{opacity:.75}.history-icon[data-category=code]{opacity:.5}.history-icon[data-category=modeling]{color:var(--good)}.history-icon[data-category=transform]{color:var(--accent)}.history-icon[data-category=parameters]{color:var(--warn)}.history-icon[data-category=structure]{color:#b388ff}.history-icon[data-category=code]{color:var(--muted)}.history-icon[data-category=ai]{color:#8b5cf6}.history-icon[data-category=project]{color:#60a5fa}.history-actor-badge{flex-shrink:0;font-size:9px;font-weight:600;padding:1px 5px;border-radius:999px;margin-left:4px;text-transform:uppercase;letter-spacing:.04em}.history-actor-badge[data-actor=ai]{background:#8b5cf626;color:#8b5cf6e6}.history-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-transform:capitalize}.history-time{font-size:10px;flex-shrink:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.history-time-sep{display:flex;align-items:center;gap:8px;padding:4px 12px;font-size:10px;color:var(--muted)}.history-time-sep:before,.history-time-sep:after{content:"";flex:1;height:1px;background:var(--stroke)}.export-stats{padding:6px 12px;font-size:11px;color:var(--muted);border-bottom:1px solid var(--stroke);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.export-mode-toggle{display:flex;gap:2px;padding:4px 8px;border-bottom:1px solid var(--stroke)}.export-mode-toggle label{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:3px 6px;font-size:11px;color:var(--muted);border-radius:4px;cursor:pointer;transition:background .15s,color .15s}.export-mode-toggle label.active{background:var(--accent-muted);color:var(--accent)}.export-mode-toggle input[type=radio]{display:none}.export-part-list{max-height:140px;overflow-y:auto;padding:4px 0;border-bottom:1px solid var(--stroke)}.export-part-item{display:flex;align-items:center;gap:6px;padding:3px 10px;font-size:11px;color:var(--text);cursor:pointer}.export-part-item:hover{background:var(--accent-muted)}.export-part-item input[type=checkbox]{width:13px;height:13px;accent-color:var(--accent);flex-shrink:0}.export-part-label{flex-shrink:0;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:10px}.export-part-group-input{flex:1;min-width:0;padding:1px 4px;font-size:11px;border:1px solid var(--stroke);border-radius:3px;background:var(--bg);color:var(--text);outline:none;font-family:inherit}.export-part-group-input:focus{border-color:var(--accent)}.export-part-tris{color:var(--muted);font-size:10px;flex-shrink:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.export-group-preview{padding:4px 10px;border-bottom:1px solid var(--stroke);font-size:10px;color:var(--muted)}.export-group-preview-item{padding:1px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.export-group-preview-item:before{content:"→"}.coord-display{position:absolute;bottom:8px;left:68px;z-index:5;padding:3px 8px;border-radius:6px;background:#000000a6;color:#ffffffbf;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:10px;white-space:nowrap;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}:root[data-theme=light] .coord-display{background:#ffffffd9;color:#0f172ab3}:root[data-theme=light] .gizmo-label{background:#ffffffe0;color:#0f172ae6}:root[data-theme=light] .nav-hints-card{box-shadow:0 4px 16px #0f172a1a}:root[data-theme=light] .nav-hints-row kbd{background:#0f172a0f}:root[data-theme=light] .layer-vis-btn:hover{background:#0f172a14}.workplane-gear-btn{position:absolute;bottom:90px;right:10px;z-index:23;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--viewport-toolbar-border);border-radius:6px;background:var(--viewport-toolbar-bg);color:var(--viewport-toolbar-btn);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--viewport-toolbar-shadow);transition:background var(--speed),color var(--speed),border-color var(--speed)}.workplane-gear-btn:hover{background:var(--viewport-toolbar-btn-hover-bg);color:var(--viewport-toolbar-btn-hover-text);border-color:color-mix(in srgb,var(--accent) 28%,var(--viewport-toolbar-border))}:root[data-theme=light] .workplane-gear-btn{background:var(--viewport-toolbar-bg);color:var(--viewport-toolbar-btn)}:root[data-theme=light] .workplane-gear-btn:hover{background:var(--viewport-toolbar-btn-hover-bg);color:var(--viewport-toolbar-btn-hover-text)}.workplane-settings{position:absolute;bottom:126px;right:8px;z-index:24;width:240px;border-radius:10px;background:#0c1121f2;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 24px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#ffffffd9;font-size:12px}:root[data-theme=light] .pane{box-shadow:0 8px 24px #0f172a1f,inset 0 1px #ffffffa6}:root[data-theme=light] .workplane-settings{background:#fffffff5;border:1px solid rgba(15,23,42,.12);box-shadow:0 8px 24px #0000001f;color:#0f172ad9}.workplane-settings-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 4px;border-bottom:1px solid rgba(255,255,255,.08)}:root[data-theme=light] .workplane-settings-header{border-bottom:1px solid rgba(15,23,42,.08)}.workplane-settings-title{font-weight:600;font-size:12px;letter-spacing:.02em}.workplane-settings-close{background:none;border:none;color:inherit;cursor:pointer;font-size:16px;line-height:1;opacity:.5;padding:0 2px}.workplane-settings-close:hover{opacity:1}.workplane-settings-body{padding:8px 12px 12px;display:flex;flex-direction:column;gap:8px}.workplane-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.workplane-label{font-size:11px;opacity:.7;white-space:nowrap}.workplane-row .select-compact{flex:1;min-width:0;max-width:140px}.workplane-row input[type=checkbox]{width:14px;height:14px;cursor:pointer}.workplane-size-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0;max-width:140px}.workplane-size-group .select-compact{max-width:none}.workplane-custom-input{display:flex;align-items:center;gap:4px}.input-compact{width:100%;padding:3px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:inherit;font-size:11px;font-family:inherit;outline:none}.input-compact:focus{border-color:var(--accent, #3b82f6)}:root[data-theme=light] .input-compact{border:1px solid rgba(15,23,42,.15);background:#0f172a0a}.workplane-input-unit{font-size:10px;opacity:.5;white-space:nowrap}@media(max-width:768px){.toolbar-btn{padding:8px 10px;min-height:36px}.toolbar-label{display:none!important}.viewport-toolbar{padding:4px 6px;gap:3px;left:8px;right:8px;transform:none;flex-wrap:wrap;justify-content:center}.toolbar-sep{height:16px}.floating-panel{display:none}.shape-library{border:none;border-top:1px solid var(--stroke);border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;max-height:none}.shape-library-grid{grid-template-columns:repeat(3,1fr)}.shortcuts-grid{grid-template-columns:1fr}.dim-label{font-size:9px;padding:1px 4px}.layer-thumbnail,.layer-thumb-placeholder{width:30px;height:30px}.layer-bool-summary{max-width:80px}.layer-row{gap:6px}}@media(hover:none)and (pointer:coarse){.toolbar-btn{padding:10px 12px;min-height:40px}.btn,.btn-sm{min-height:44px;min-width:44px;padding:10px 14px;font-size:12px}.tab{min-height:44px;min-width:44px;padding:8px 12px}.layer-row{min-height:58px}.layer-chevron,.layer-info-btn{width:44px;height:44px}.group-scope-link{min-height:44px;display:inline-flex;align-items:center}.context-menu-item{padding:10px 14px}.mobile-quick-actions .btn,.mobile-main-menu .btn,.mobile-main-menu-item,.mobile-main-menu-link{min-width:0;min-height:44px;padding:9px 12px}.mobile-bottom-nav-btn,.mobile-sheet-close{min-height:44px}.btn,.toolbar-btn,.layer-row,.layer-chevron,.layer-vis-btn,.layer-info-btn,.context-menu-item,.props-breadcrumb-item,.tab{touch-action:manipulation}.btn:active{background:var(--surface-hover);border-color:#ffffff24}.btn-primary:active{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost:active{background:var(--surface-hover);border-color:var(--stroke)}.toolbar-btn:active{background:var(--viewport-toolbar-btn-hover-bg);color:var(--viewport-toolbar-btn-hover-text)}.context-menu-item:active:not(:disabled){background:var(--accent-muted);color:var(--accent)}.export-menu-item:active:not(:disabled){background:var(--accent-muted);color:var(--accent)}.layer-row:active{background:var(--surface-hover)}.layer-chevron:active{color:var(--accent);background:var(--accent-muted)}.layer-vis-btn:active,.layer-info-btn:active,.props-breadcrumb-item:active{color:var(--text);background:var(--surface-hover)}.mobile-main-menu-item:active,.mobile-main-menu-link:active,.tab:active{background:var(--surface-hover)}}@media(hover:none)and (pointer:coarse){.nav-hints{display:none!important}}.gesture-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:40;pointer-events:all;cursor:pointer;animation:gesture-hint-fadein .3s ease}@keyframes gesture-hint-fadein{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.gesture-hint-items{display:flex;flex-direction:column;gap:10px;background:color-mix(in srgb,var(--panel, #1e1e2e) 80%,transparent);-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);border:1px solid color-mix(in srgb,var(--stroke, #fff) 20%,transparent);border-radius:16px;padding:20px 28px;box-shadow:0 8px 32px #0006}.gesture-hint-item{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text, #e0e0e0);font-weight:500}.gesture-hint-icon{font-size:22px;line-height:1;width:28px;text-align:center}.gesture-hint-dismiss{font-size:11px;color:var(--muted, #888);text-align:center;letter-spacing:.02em}.mobile-viewport-controls{position:absolute;right:12px;bottom:calc(102px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:8px;z-index:10;pointer-events:all}.mobile-vp-btn{width:46px;height:46px;border-radius:10px;border:1px solid color-mix(in srgb,var(--stroke, #fff) 20%,transparent);background:color-mix(in srgb,var(--panel, #1e1e2e) 85%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text, #e0e0e0);font-size:18px;font-weight:400;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;box-shadow:0 2px 8px #0000004d;line-height:1;-webkit-user-select:none;user-select:none}.mobile-vp-btn:disabled{opacity:.45;cursor:default;transform:none}.mobile-vp-btn:active{background:color-mix(in srgb,var(--accent, #7c6be8) 30%,var(--panel, #1e1e2e));border-color:color-mix(in srgb,var(--accent, #7c6be8) 50%,transparent)}.error-boundary-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 16px;width:100%;height:100%;min-height:120px;color:var(--muted);text-align:center}.error-boundary-icon{opacity:.4}.error-boundary-title{font-weight:600;font-size:13px;color:var(--text)}.error-boundary-message{font-size:11px;max-width:360px;word-break:break-word;opacity:.7}
