.calibration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.calibration-modal{background:#2a2a2a;border:1px solid #444;border-radius:8px;padding:20px;width:340px;color:#e0e0e0;font-size:13px}.calibration-modal h3{margin:0 0 12px;font-size:15px;color:#fff}.calibration-modal p{margin:0 0 14px;color:#aaa;font-size:12px}.calibration-input-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.calibration-input-row label{flex-shrink:0;color:#e0e0e0}.calibration-input-row input[type=number]{flex:1;padding:4px 8px;background:#1e1e1e;border:1px solid #555;border-radius:4px;color:#e0e0e0;font-size:13px;min-width:0}.calibration-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.calibration-actions button{padding:6px 16px;border-radius:4px;border:1px solid #555;background:#333;color:#e0e0e0;cursor:pointer;font-size:13px}.calibration-actions button.primary{background:#0078d4;border-color:#0078d4;color:#fff}.calibration-actions button.primary:disabled{background:#0078d480;border-color:#0078d480;cursor:not-allowed}.ref-img-settings{display:flex;flex-direction:column;gap:6px;padding:6px 4px;min-width:200px}.ref-img-import-btn{display:flex;align-items:center;gap:5px;width:100%;padding:5px 8px;background:#4a9eff1f;border:1px solid rgba(74,158,255,.3);border-radius:5px;color:var(--accent, #4a9eff);font-size:11px;cursor:pointer;transition:background .12s}.ref-img-import-btn:hover:not(:disabled){background:#4a9eff38}.ref-img-import-btn:disabled{opacity:.4;cursor:not-allowed}.ref-img-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.ref-img-item{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:5px;padding:5px 6px;display:flex;flex-direction:column;gap:4px}.ref-img-row{display:flex;align-items:center;gap:4px}.ref-img-row-top{justify-content:space-between}.ref-img-name{font-size:11px;color:#ffffffbf;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.ref-img-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.ref-img-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:4px;cursor:pointer;color:#fff6;transition:background .1s,color .1s;padding:0}.ref-img-btn:hover{background:#ffffff1a;color:#ffffffd9}.ref-img-btn.active{color:var(--accent, #4a9eff)}.ref-img-btn-calibrate:hover{color:#f0c040}.ref-img-btn-remove:hover{color:#ff5a5a}.ref-img-row-opacity{gap:6px}.ref-img-label{font-size:10px;color:#fff6;flex-shrink:0}.ref-img-slider{flex:1;min-width:0;height:2px;accent-color:var(--accent, #4a9eff);cursor:pointer}.ref-img-value{font-size:10px;color:#fff6;width:26px;text-align:right;flex-shrink:0}.submenu-trigger{position:relative;width:100%}.submenu-trigger-btn{display:flex;align-items:center;width:100%;padding:6px 12px;border:none;background:transparent;color:#e0e0e0;cursor:pointer;font-size:13px;text-align:left;gap:8px;font-family:Inter,Helvetica Neue,sans-serif}.submenu-trigger-btn:hover{background:#2d2d2d}.submenu-icon{width:20px;text-align:center;font-size:14px;flex-shrink:0}.submenu-label{flex:1}.submenu-arrow{color:#888;font-size:11px;margin-left:12px}.submenu-panel{position:absolute;left:100%;top:0;min-width:180px;background:#1e1e1e;border:1px solid #3a3a3a;border-radius:6px;box-shadow:0 4px 16px #0006;padding:4px 0;z-index:1010;font-family:Inter,Helvetica Neue,sans-serif;font-size:13px;color:#e0e0e0}.submenu-item{display:flex;align-items:center;width:100%;padding:6px 12px;border:none;background:transparent;color:#e0e0e0;cursor:pointer;font-size:13px;text-align:left;gap:8px;font-family:Inter,Helvetica Neue,sans-serif}.submenu-item:hover:not(:disabled){background:#2d2d2d}.submenu-item:disabled{color:#555;cursor:default}.submenu-shortcut{font-size:11px;color:#666;margin-left:12px}.submenu-separator{height:1px;background:#333;margin:2px 8px}.pattern-editor{width:100%;height:100%;overflow:hidden;cursor:crosshair}.pattern-svg{display:block}.pattern-piece{cursor:pointer;transition:opacity .15s}.pattern-piece:hover path:first-child{fill:#4a9eff33}.pattern-piece.selected path:first-child{stroke:var(--selected);stroke-width:2}.snapshot-bar{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;background:#1e1e1ed9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:6px 12px;z-index:10;pointer-events:auto}.snapshot-bar .snap-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#ffffffb3;font-size:11px;font-family:Inter,sans-serif;cursor:pointer;transition:all .15s;white-space:nowrap}.snapshot-bar .snap-chip:hover{background:#ffffff1f;color:#ffffffe6}.snapshot-bar .snap-chip.active{background:#4a9eff33;border-color:var(--accent);color:var(--accent)}.snapshot-bar .snap-chip .snap-delete{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:none;background:transparent;color:inherit;font-size:10px;cursor:pointer;opacity:0;transition:opacity .15s;padding:0}.snapshot-bar .snap-chip:hover .snap-delete{opacity:.6}.snapshot-bar .snap-chip .snap-delete:hover{opacity:1;background:#ffffff26}.snapshot-bar .snap-save-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px dashed rgba(255,255,255,.2);background:transparent;color:#fff6;font-size:14px;cursor:pointer;transition:all .15s}.snapshot-bar .snap-save-btn:hover{border-color:#fff6;color:#fffc;background:#ffffff0f}.snapshot-bar .snap-save-btn:disabled{opacity:.3;cursor:default}.cb-panel-wrapper{position:absolute;top:0;right:0;width:280px;height:100%;display:flex;flex-direction:column;pointer-events:auto;z-index:20}.cb-panel{background:#1e1e1ef2;border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;height:100%;color:#ccc;font-family:Inter,sans-serif;font-size:12px}.cb-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.1)}.cb-panel-header h3{margin:0;font-size:13px;font-weight:600;color:#fff}.cb-panel-close{background:none;border:none;color:#888;font-size:16px;cursor:pointer;padding:2px 6px}.cb-panel-close:hover{color:#fff}.cb-panel-scroll{flex:1;overflow-y:auto;padding:10px 14px}.cb-import-btn{width:100%;padding:8px;background:#4a9eff26;border:1px dashed rgba(74,158,255,.4);border-radius:6px;color:#4a9eff;cursor:pointer;font-size:12px;margin-bottom:10px}.cb-import-btn:hover{background:#4a9eff40}.cb-body-item{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:10px;margin-bottom:8px}.cb-body-item.selected{border-color:#4a9eff80;background:#4a9eff14}.cb-body-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cb-body-name{background:none;border:none;color:#fff;font-size:12px;font-weight:500;padding:2px 4px;border-radius:3px;width:120px}.cb-body-name:focus{outline:1px solid rgba(74,158,255,.5);background:#0000004d}.cb-body-actions{display:flex;gap:4px}.cb-icon-btn{background:none;border:none;color:#888;cursor:pointer;padding:2px 5px;font-size:13px;border-radius:3px}.cb-icon-btn:hover{color:#fff;background:#ffffff1a}.cb-icon-btn.active{color:#4a9eff}.cb-icon-btn.danger:hover{color:#ff5252}.cb-slider-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.cb-slider-label{width:55px;font-size:11px;color:#999}.cb-slider-row input[type=range]{flex:1;height:3px;accent-color:#4a9eff}.cb-slider-value{width:40px;font-size:11px;text-align:right;color:#bbb}.render-panel-wrapper{position:absolute;top:0;right:0;width:280px;height:100%;display:flex;flex-direction:column;pointer-events:auto;z-index:20}.render-panel{background:#1e1e1ef2;border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;height:100%;color:#ccc;font-family:Inter,sans-serif;font-size:12px}.render-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.1)}.render-panel-header h3{margin:0;font-size:13px;font-weight:600;color:#fff}.render-panel-close{background:none;border:none;color:#888;font-size:16px;cursor:pointer;padding:2px 6px}.render-panel-close:hover{color:#fff}.render-panel-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:0}.render-hdri-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.render-hdri-item{padding:6px 4px;border:1px solid var(--border-color, #444);border-radius:4px;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #ccc);cursor:pointer;font-size:10px;text-align:center;transition:border-color .15s}.render-hdri-item:hover{background:var(--bg-hover, #333)}.render-hdri-item.active{border-color:var(--accent, #007acc);background:#007acc26;color:var(--accent, #007acc)}.render-color-row{display:flex;align-items:center;gap:8px}.render-color-row input[type=color]{width:28px;height:22px;border:1px solid var(--border-color, #444);border-radius:3px;background:none;cursor:pointer;padding:0}.render-light-item{display:flex;flex-direction:column;gap:4px;padding:6px;border:1px solid rgba(255,255,255,.06);border-radius:4px;margin-bottom:4px}.render-light-header{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600}.viewport3d{width:100%;height:100%;position:relative;flex:1;min-height:0}.viewport3d canvas{display:block}.sim-status{position:absolute;bottom:12px;right:12px;font-size:10px;font-weight:600;letter-spacing:1px;color:var(--text-muted);padding:4px 10px;background:#0009;border-radius:4px;pointer-events:none}.sim-status.running{color:var(--grainline-color)}.template-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s cubic-bezier(0,0,.2,1)}.template-overlay.open{opacity:1;pointer-events:auto}.template-overlay.closed{opacity:0;pointer-events:none;transition:opacity .15s cubic-bezier(.4,0,1,1)}.template-library{background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;width:560px;max-height:80vh;overflow-y:auto;position:relative;transform:scale(.95);transition:transform .2s cubic-bezier(0,0,.2,1)}.template-overlay.open .template-library{transform:scale(1)}.template-overlay.closed .template-library{transform:scale(.95);transition:transform .15s cubic-bezier(.4,0,1,1)}.template-header{padding:24px 24px 16px;border-bottom:1px solid var(--border);position:relative}.template-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.template-subtitle{font-size:12px;color:var(--text-muted);margin-top:6px}.template-close{position:absolute;top:16px;right:16px;width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);font-size:16px;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center}.template-close:hover{background:var(--border);color:var(--text-primary)}.template-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:20px 24px}.template-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s ease;color:var(--text-primary)}.template-card:hover{border-color:var(--accent);background:var(--accent-dim);transform:translateY(-2px)}.template-icon{font-size:32px;line-height:1}.template-name{font-size:14px;font-weight:600}.template-name-es{font-size:11px;color:var(--text-muted);font-style:italic}.template-desc{font-size:11px;color:var(--text-secondary);text-align:center;line-height:1.4}.template-footer{padding:12px 24px 16px;border-top:1px solid var(--border)}.template-hint{font-size:11px;color:var(--text-muted)}.solver-metrics{position:fixed;bottom:8px;right:8px;z-index:9999;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,monospace;font-size:10px}.solver-metrics-toggle{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#000c;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#ffffffb3;cursor:pointer;font-family:inherit;font-size:inherit}.solver-metrics-toggle:hover{background:#000000e6;color:#fff}.solver-metrics-dot{width:6px;height:6px;border-radius:50%;background:#555}.solver-metrics-dot--active{background:#4a9eff;animation:solver-dot-pulse .5s ease-in-out infinite}@keyframes solver-dot-pulse{0%,to{opacity:1}50%{opacity:.4}}.solver-metrics--expanded .solver-metrics-toggle{border-radius:4px 4px 0 0;border-bottom:none}.solver-metrics-body{background:#000000e6;border:1px solid rgba(255,255,255,.1);border-top:none;border-radius:0 0 4px 4px;padding:8px;min-width:180px}.solver-metrics-row{display:flex;justify-content:space-between;padding:2px 0;color:#fff9}.solver-metrics-row span:last-child{color:#ffffffe6;font-weight:500}.solver-metrics-section{margin-top:8px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1);color:#ffffff80;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.solver-metrics-section--error{color:#ff6b6b}.solver-metrics-error{padding:2px 0;color:#ff8a8a;font-size:9px;word-break:break-all}:root{--bg-base: #0c0c14;--bg-deeper: #08080f;--bg-surface: #10101c;--bg-elevated: #1a1a2e;--border: #1a1a2e;--border-subtle: #12121f;--text-primary: #e2e8f0;--text-secondary: #a0a0c0;--text-muted: #8888a8;--text-ghost: #6a6a8a;--text-dim: #4a4a6a;--accent: #6366f1;--accent-hover: #818cf8;--accent-subtle: rgba(99, 102, 241, .13);--accent-border: rgba(99, 102, 241, .27);--success: #22c55e;--destructive: #ef4444;--warning: #f59e0b;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono: "SF Mono", "JetBrains Mono", "Fira Code", monospace;--text-xs: clamp(10px, .55vw + 3px, 13px);--text-sm: clamp(11px, .6vw + 3px, 14px);--text-ui: clamp(12px, .65vw + 3px, 15px);--text-input: clamp(13px, .7vw + 3px, 16px);--text-heading: clamp(14px, .75vw + 3px, 17px);--text-title: clamp(16px, .9vw + 4px, 20px);--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--line-height: 1.5;--sp-1: clamp(4px, .3vw, 6px);--sp-2: clamp(8px, .5vw, 10px);--sp-3: clamp(12px, .7vw, 16px);--sp-4: clamp(16px, 1vw, 20px);--sp-6: clamp(24px, 1.4vw, 32px);--sp-8: clamp(32px, 1.8vw, 40px);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--top-bar-h: clamp(36px, 2.5vw, 48px);--unified-bar-h: clamp(44px, 3vw, 56px);--toolbar-btn: clamp(28px, 2vw, 38px);--blur: blur(12px);--transition-fast: .15s ease;--transition-normal: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:var(--text-ui);line-height:var(--line-height);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}::selection{background:var(--accent-subtle);color:var(--text-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in var(--transition-normal) ease-out}.animate-slide-up{animation:slide-up var(--transition-normal) ease-out}.animate-slide-down{animation:slide-down var(--transition-normal) ease-out}.mono{font-family:var(--font-mono)}.muted{color:var(--text-muted)}.ghost{color:var(--text-ghost)}.accent{color:var(--accent)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dot{width:6px;height:6px;border-radius:50%;display:inline-block}.dot--success{background:var(--success)}.dot--error{background:var(--destructive)}.dot--warning{background:var(--warning)}.dot--idle{background:var(--text-muted)}.pill-group{display:flex;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;gap:1px}.pill-group__item{padding:3px 14px;font-size:var(--text-ui);color:var(--text-muted);border-radius:4px;transition:all var(--transition-fast)}.pill-group__item--active{color:var(--text-primary);background:var(--bg-elevated)}.icon-btn{width:var(--toolbar-btn);height:var(--toolbar-btn);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--transition-fast);color:var(--text-muted)}.icon-btn svg{width:50%;height:50%}.icon-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.icon-btn--active{background:var(--accent-subtle);color:var(--accent);border:1px solid var(--accent-border)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.app-shell{display:flex;flex-direction:column;height:100vh;background:var(--bg-base);overflow:hidden}.top-bar{height:var(--top-bar-h);background:var(--bg-deeper);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--sp-3);gap:var(--sp-3);flex-shrink:0;z-index:10}.top-bar__logo{font-size:var(--text-heading);font-weight:var(--weight-semibold);color:var(--text-primary);letter-spacing:-.3px}.top-bar__spacer{flex:1}.top-bar__status{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono)}.canvas-area{flex:1;display:flex;position:relative;overflow:hidden}.canvas-area__2d{position:relative;overflow:hidden;background:#f5f3f0}.canvas-area__divider{width:4px;background:transparent;cursor:col-resize;flex-shrink:0;position:relative;z-index:5;transition:background .15s ease}.canvas-area__divider:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;background:var(--border);transition:background .15s ease}.canvas-area__divider:hover{background:#6366f114}.canvas-area__divider:hover:after{background:var(--accent);width:2px;margin-left:-1px}.canvas-area__3d{position:relative;overflow:hidden}.floating-toolbar{position:absolute;left:var(--sp-3);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:var(--sp-1);background:#10101ccc;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-2);z-index:15;transition:opacity var(--transition-normal)}.floating-toolbar--hidden{opacity:0;pointer-events:none}.floating-toolbar__sep{width:16px;height:1px;background:var(--border);margin:2px auto}.floating-3d{position:absolute;z-index:15}.floating-3d--top-right{top:var(--sp-3);right:var(--sp-3);display:flex;gap:var(--sp-1)}.floating-3d--bottom-left{bottom:var(--sp-3);left:var(--sp-3);display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-xs);color:var(--text-muted)}.floating-3d__pill{padding:4px 10px;font-size:var(--text-sm);font-weight:var(--weight-medium);border-radius:var(--radius-sm);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);transition:all var(--transition-fast)}.floating-3d__pill--default{color:var(--text-muted);background:#10101ccc;border:1px solid var(--border)}.floating-3d__pill--default:hover{color:var(--text-primary);background:var(--bg-elevated)}.floating-3d__pill--primary{color:var(--bg-deeper);background:var(--accent);border:none}.floating-3d__pill--primary:hover{opacity:.85}.context-panel{position:absolute;top:var(--sp-3);right:var(--sp-3);width:300px;max-height:calc(100vh - var(--top-bar-h) - var(--unified-bar-h) - var(--sp-8));background:#08080ff2;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--border);border-radius:var(--radius-xl);overflow-y:auto;z-index:25;animation:slide-down var(--transition-normal) ease-out}.context-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);font-size:var(--text-heading);font-weight:var(--weight-semibold)}.context-panel__body{padding:var(--sp-3) var(--sp-4)}.logo-menu__trigger{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;cursor:pointer;transition:background .1s ease}.logo-menu__trigger:hover,.logo-menu__trigger--active{background:#6366f11a}.logo-menu__logo-text{font-size:var(--text-heading);font-weight:var(--weight-semibold);color:var(--text-primary);letter-spacing:-.3px}.logo-menu__trigger--active .logo-menu__logo-text{color:var(--accent)}.logo-menu__trigger svg{color:var(--text-muted)}.logo-menu{position:absolute;top:calc(100% + 6px);left:0;background:#08080feb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,.15);border-radius:14px;box-shadow:0 8px 32px #0006;z-index:200;min-width:240px;padding:6px;animation:slide-down .1s ease-out}.logo-menu__separator{height:1px;background:#6366f114;margin:4px 10px}.logo-menu__item{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;cursor:pointer;transition:background .08s ease;position:relative}.logo-menu__item:hover,.logo-menu__item--hovered{background:#6366f11a}.logo-menu__item--disabled{opacity:.35;cursor:not-allowed}.logo-menu__item--disabled:hover{background:transparent}.logo-menu__check{width:16px;font-size:12px;color:var(--accent);text-align:center;flex-shrink:0}.logo-menu__label{flex:1;font-size:14px;color:var(--text-primary);white-space:nowrap}.logo-menu__shortcut{font-size:12px;color:var(--text-dim);margin-left:24px;font-family:var(--font-mono);white-space:nowrap}.logo-menu__chevron{color:var(--text-dim);flex-shrink:0;margin-left:auto}.logo-menu__submenu{position:absolute;left:calc(100% + 4px);top:-6px;background:#08080feb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,.15);border-radius:12px;box-shadow:0 8px 32px #0006;padding:6px;min-width:220px;z-index:210}.unified-bar{position:fixed;z-index:100;width:560px;height:58px;background:#08080feb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,.15);border-radius:29px;display:flex;align-items:center;padding:0 10px 0 12px;gap:10px;box-shadow:0 8px 32px #0006;transition:border-radius .15s ease;-webkit-user-select:none;user-select:none}.unified-bar--panel-open{border-radius:0 0 29px 29px}.unified-bar--draggable{cursor:grab}.unified-bar--dragging{cursor:grabbing}.unified-bar__modes{display:flex;gap:4px;flex-shrink:0}.unified-bar__mode-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer}.unified-bar__mode-btn:hover{color:var(--text-primary);background:var(--bg-elevated)}.unified-bar__mode-btn--active{color:var(--text-primary);background:#6366f11a;border:1px solid rgba(99,102,241,.2)}.unified-bar__mode-btn svg{width:16px;height:16px}.unified-bar__input-wrap{flex:1;height:40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;display:flex;align-items:center;padding:0 18px;gap:var(--sp-2);transition:border-color var(--transition-fast)}.unified-bar__input-wrap:focus-within{border-color:var(--accent-border)}.unified-bar__input{flex:1;background:none;border:none;outline:none;font-size:15px;color:var(--text-primary);-webkit-user-select:text;user-select:text;cursor:text}.unified-bar__input::placeholder{color:var(--text-ghost)}.unified-bar__send{width:40px;height:40px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity var(--transition-fast);cursor:pointer}.unified-bar__send svg{width:18px;height:18px;color:#fff}.unified-bar__send:hover{opacity:.85}.unified-bar__send:disabled{opacity:.3;cursor:not-allowed}.unified-bar__model{display:none}.unified-bar__shortcut{font-size:11px;color:var(--text-dim);background:var(--border-subtle);padding:3px 8px;border-radius:4px;border:1px solid var(--border)}.unified-bar__meta{display:none}.unified-bar__panel{position:absolute;bottom:100%;left:0;right:0;width:560px;background:#08080ff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,.15);border-bottom:none;border-radius:16px 16px 0 0;max-height:50vh;overflow-y:auto;animation:slide-up var(--transition-normal) ease-out;box-shadow:0 -4px 24px #0000004d}.chat-message{display:flex;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);align-items:flex-start}.chat-message--user{justify-content:flex-end}.chat-message__avatar{width:22px;height:22px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:9px;color:#fff;font-weight:var(--weight-semibold)}.chat-message__text{font-size:14px;color:var(--text-secondary);line-height:1.6;max-width:85%}.chat-message--user .chat-message__text{color:var(--text-primary);background:var(--bg-elevated);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md)}.btn-icon{width:28px;height:28px;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;flex-shrink:0}.btn-icon:hover{background:#ffffff0f;color:var(--text-primary)}.btn-icon:disabled{opacity:.25;cursor:default}.btn-icon:disabled:hover{background:none;color:var(--text-secondary)}.btn-bordered{display:flex;align-items:center;gap:6px;padding:5px 12px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.btn-bordered:hover{background:#ffffff0f;border-color:var(--accent);color:var(--text-primary)}.btn-accent{padding:8px 16px;background:var(--accent-dim);border:1px solid var(--accent);border-radius:6px;color:var(--accent);font-size:12px;font-weight:500;cursor:pointer;transition:color .15s,background .15s}.btn-accent:hover{background:var(--accent);color:#fff}.btn-danger{background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:10px;font-weight:500;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.btn-danger:hover{border-color:#ff6b6b66;color:var(--seam-color);background:#ff6b6b14}.input{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);padding:4px 8px;font-size:12px;font-family:inherit;outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.input-narrow{width:64px;text-align:right}.toggle-label{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;color:var(--text-secondary);cursor:pointer}.toggle-label input[type=checkbox]{accent-color:var(--accent)}.section-header{width:100%;background:none;border:none;padding:12px 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:color .15s}.section-header:hover .section-title{color:var(--text-primary)}.section-title{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-family:Inter,sans-serif}.section-chevron{color:var(--text-muted);transition:transform .15s ease}.section-chevron.collapsed{transform:rotate(-90deg)}.pill-toggle{display:flex;gap:2px;background:var(--bg-primary);border-radius:6px;padding:2px}.pill-toggle button{flex:1;background:none;border:none;color:var(--text-secondary);padding:4px 12px;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:color .15s,background .15s}.pill-toggle button:hover{color:var(--text-primary)}.pill-toggle button.active{background:var(--accent-dim);color:var(--accent)}.field-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px}.field-row label{color:var(--text-secondary)}.input-with-unit{display:flex;align-items:center;gap:4px}.unit-label{font-size:11px;color:var(--text-muted)}.separator{width:1px;height:20px;background:var(--border);flex-shrink:0}.panel-bg{background:var(--bg-secondary);border-left:1px solid var(--border)}.scroll-y{overflow-y:auto}.scroll-y::-webkit-scrollbar{width:6px}.scroll-y::-webkit-scrollbar-track{background:transparent}.scroll-y::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}:root{--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-panel: #2a2a2a;--bg-canvas: #f5f3f0;--bg-grid: #e8e4df;--text-secondary: #b0b0b0;--accent: #4a9eff;--accent-hover: #6bb3ff;--accent-dim: rgba(74, 158, 255, .15);--seam-color: #ff6b6b;--grainline-color: #6bff6b;--selected: #ffd700;--color-error: #ef4444;--color-error-dark: #dc2626;--color-warning: #cca700;--color-success: #10b981;--color-info: #3794ff;--color-copilot: #8b5cf6;--color-copilot-light: #a78bfa;--border-light: #4a4a4a;--btn-bg-hover: rgba(255, 255, 255, .06);--btn-bg-active: rgba(255, 255, 255, .12);--btn-transition: color .15s, background .15s, border-color .15s;--activitybar-bg: #1e1e1e;--activitybar-fg: #858585;--activitybar-fg-active: #ffffff;--activitybar-indicator: #4a9eff;--activitybar-width: 48px;--sidebar-bg: #252526;--sidebar-header-bg: #252526;--sidebar-header-fg: #bbbbbb;--sidebar-fg: #cccccc;--sidebar-width: 280px;--editor-bg: #1e1e1e;--editor-fg: #d4d4d4;--panel-bg: #1e1e1e;--panel-header-bg: #252526;--panel-tab-active-border: #4a9eff;--panel-height: 200px;--statusbar-bg: #007acc;--statusbar-fg: #ffffff;--statusbar-height: 22px;--titlebar-bg: #323233;--titlebar-fg: #cccccc;--titlebar-height: 44px;--palette-bg: #252526;--palette-fg: #cccccc;--palette-input-bg: #3c3c3c;--palette-highlight: #4a9eff;--palette-shadow: 0 8px 30px rgba(0,0,0,.5);--focus-border: #4a9eff;--separator: #3a3a3a;--icon-size: 20px;--font-size-small: 11px;--toolbar-height: 44px;--panel-width: 280px;--divider-width: 4px;--toolbar2d-width: 42px}.panel-error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:24px;color:#e0d8cc;background:#1a1a1a;border-radius:8px}.panel-error-icon{font-size:32px;margin-bottom:12px}.panel-error-title{font-size:14px;font-weight:600;margin-bottom:8px}.panel-error-message{font-size:12px;opacity:.7;margin-bottom:16px;text-align:center;max-width:300px}.panel-error-reset{padding:6px 16px;border-radius:4px;border:1px solid #555;background:#2a2a2a;color:#e0d8cc;cursor:pointer;font-size:12px}.panel-error-reset:hover{background:#333}.app-error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:48px;color:#e0d8cc;background:#111;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-error-icon{font-size:48px;margin-bottom:16px}.app-error-title{font-size:20px;font-weight:600;margin-bottom:12px}.app-error-message{font-size:14px;opacity:.7;margin-bottom:20px;text-align:center;max-width:400px}.app-error-save-status{font-size:13px;margin-bottom:20px;padding:8px 16px;border-radius:4px}.app-error-save-ok{color:#a3d9a5;background:#a3d9a51a;border:1px solid rgba(163,217,165,.3)}.app-error-save-fail{color:#e5a3a3;background:#e5a3a31a;border:1px solid rgba(229,163,163,.3)}.app-error-reload{padding:10px 24px;border-radius:6px;border:1px solid #555;background:#2a2a2a;color:#e0d8cc;cursor:pointer;font-size:14px}.app-error-reload:hover{background:#333}
