*{box-sizing:border-box}::placeholder{color:#cbd5e1;opacity:1}input::placeholder,textarea::placeholder{color:#cbd5e1}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;margin:0;padding:20px;background:#fff;color:#222;height:100vh;display:flex;flex-direction:column;overflow:hidden}h1{margin:0 0 24px;font-size:24px;font-weight:700}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:10px;flex-shrink:0}.header-logo{height:44px;width:auto}.app-layout{flex:1;display:flex;gap:20px;min-height:0;min-width:0;overflow:hidden}.sidebar{width:200px;flex-shrink:0;display:flex;flex-direction:column;min-width:0;min-height:0;background:#fff;border:1px solid #e5e5e5;border-radius:8px;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border-bottom:1px solid #e5e5e5;background:#fafafa}.sidebar-header h2{margin:0;font-size:11px;text-transform:uppercase;letter-spacing:2px;color:#3b82f6;font-weight:600}.btn-icon-minimal:hover{background:#f8fafc;border-color:#e2e8f0;color:#3b82f6}.btn-icon-minimal:active{background:#f1f5f9;transform:scale(.95)}.btn-icon-minimal .material-symbols-outlined{font-size:18px}.main-workspace{flex:1;display:flex;flex-direction:column;gap:12px;min-width:0;min-height:0;overflow:hidden}.workspace-top{flex:1;display:flex;gap:4px;min-height:0;overflow:hidden}.results-resize-handle{width:5px;cursor:col-resize;background:transparent;flex-shrink:0;position:relative;z-index:10;transition:background-color .2s ease}.results-resize-handle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:3px;height:40px;background:repeating-linear-gradient(to bottom,#cbd5e1 0px,#cbd5e1 4px,transparent 4px,transparent 8px);border-radius:2px;transition:opacity .2s ease}.results-resize-handle:hover{background-color:#3b82f61a}.results-resize-handle:hover:before{background:repeating-linear-gradient(to bottom,#3b82f6 0px,#3b82f6 4px,transparent 4px,transparent 8px)}.results-resize-handle.resizing{background-color:#3b82f626}.results-resize-handle.resizing:before{background:repeating-linear-gradient(to bottom,#3b82f6 0px,#3b82f6 4px,transparent 4px,transparent 8px)}.results-panel{width:380px;flex-shrink:0;display:flex;flex-direction:column;background:#fff;border:1px solid #e5e5e5;border-radius:8px;overflow:hidden;min-height:0}.results-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-bottom:1px solid #e5e5e5;background:#fafafa;flex-shrink:0}.results-header h3{margin:0;font-size:11px;text-transform:uppercase;letter-spacing:2px;color:#3b82f6;font-weight:600}.results-runner-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.results-actions-divider{width:1px;height:18px;background:#d1d5db;flex-shrink:0}.btn-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#475569;cursor:pointer;transition:all .15s}.btn-icon:hover:not(:disabled){background:#f1f5f9;color:#0f172a;border-color:#94a3b8}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-icon .material-symbols-outlined{font-size:18px}.btn-icon.btn-run{background:#10b981;border-color:#10b981;color:#fff}.btn-icon.btn-run:hover:not(:disabled){background:#059669;border-color:#059669}.btn-icon.btn-run:disabled{background:#94a3b8;border-color:#94a3b8;opacity:.6}.btn-icon.btn-cancel{background:transparent;border-color:transparent;color:#94a3b8}.btn-icon.btn-cancel:hover:not(:disabled){color:#ef4444;background:#fef2f2;border-color:#fca5a5}.btn-icon.btn-cancel:disabled{opacity:.35}.results-status{display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-bottom:1px solid #eef2f7;background:#fff;flex-shrink:0}.results-debug{display:none;flex-direction:column;gap:6px;margin-top:4px;border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;overflow:hidden}.results-debug.is-visible{display:flex}.debug-console-toggle{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:11px;color:#64748b;-webkit-user-select:none;user-select:none;white-space:nowrap}.debug-console-toggle input{display:none}.debug-toggle-track{width:28px;height:16px;background:#cbd5e1;border-radius:8px;position:relative;flex-shrink:0;transition:background .2s}.debug-toggle-track:after{content:"";position:absolute;width:12px;height:12px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .2s}.debug-console-toggle input:checked+.debug-toggle-track{background:#3b82f6}.debug-console-toggle input:checked+.debug-toggle-track:after{transform:translate(12px)}.results-debug-header{padding:8px 10px;border-bottom:1px solid #e2e8f0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#475569;background:#f1f5f9}.results-debug-output{margin:0;padding:10px;min-height:84px;max-height:180px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;font-size:11px;line-height:1.45;color:#1e293b;background:#f8fafc}.results-plots{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px;overflow:auto;padding:14px;background:#fff}.plot-placeholder{min-height:220px;display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;color:#334155;font-size:16px;line-height:1.4}.plot-placeholder .material-symbols-outlined{font-size:28px;color:#1f2937}.plot-placeholder.error{color:#991b1b}.plot-container{background:#fff;overflow:hidden;border:.5px solid #eee;border-radius:0;flex-shrink:0}.plot-container .plot-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.plot-container .plot-title{font-size:11px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:1px}.plot-actions{display:flex;align-items:center;gap:8px}.plot-scale-toggle{display:flex;gap:2px;background:#e2e8f0;border-radius:4px;padding:2px}.plot-scale-toggle .scale-btn{padding:3px 8px;font-size:10px;font-weight:600;background:transparent;border:none;color:#475569;cursor:pointer;border-radius:3px;transition:all .15s}.plot-scale-toggle .scale-btn:hover{color:#0f172a}.plot-scale-toggle .scale-btn.active{background:#3b82f6;color:#fff}.plot-export-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:#fff;border:1px solid #dbe2ea;border-radius:4px;color:#475569;cursor:pointer;transition:all .15s}.plot-export-btn:hover{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.plot-export-btn .material-symbols-outlined{font-size:16px}.plot-container .plot-area{height:260px;width:100%;border-width:0px}.plot-container .plot-area:has(.op-table){height:auto}.op-table{width:100%;border-collapse:collapse;font-size:13px}.op-table th{text-align:left;padding:7px 14px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#64748b;border-bottom:1px solid #e5e7eb;background:#f8fafc}.op-table td{padding:8px 14px;border-bottom:1px solid #f1f5f9;color:#1e293b}.op-table tbody tr:last-child td{border-bottom:none}.op-table .op-probe{font-weight:500;color:#475569;width:50%}.op-table .op-value{font-family:monospace;font-size:12px;color:#0f172a}.op-table-empty{padding:24px;text-align:center;color:#94a3b8;font-size:13px}.plot-message{min-height:260px;display:flex;align-items:center;justify-content:center;gap:16px;padding:24px;color:#64748b}.plot-message.error{color:#b91c1c}.plot-message .material-symbols-outlined{font-size:40px;color:#ef4444;opacity:.8}.plot-message-copy{display:flex;flex-direction:column;gap:6px;max-width:560px}.plot-message-copy strong{font-size:12px;color:#b91c1c;text-transform:uppercase;letter-spacing:.08em}.plot-mode-toggle{display:flex;gap:2px;background:#e2e8f0;border-radius:4px;padding:2px}.plot-mode-toggle .mode-btn{padding:3px 8px;font-size:10px;font-weight:600;background:transparent;border:none;color:#475569;cursor:pointer;border-radius:3px;transition:all .15s}.plot-mode-toggle .mode-btn:hover{color:#0f172a}.plot-mode-toggle .mode-btn.active{background:#3b82f6;color:#fff}.plot-xy-selectors{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.xy-selector-label{font-size:11px;font-weight:600;color:#475569}.xy-axis-select{min-width:0;padding:5px 8px;border:1px solid #dbe2ea;border-radius:6px;background:#fff;color:#0f172a;font-size:12px}.plot-message-copy span{font-size:13px;line-height:1.5}.plot-yrange-controls{display:flex;flex-direction:column;gap:3px;padding:5px 10px;border-top:1px solid #e5e7eb;background:#f8fafc}.yrange-row{display:flex;align-items:center;gap:4px}.yrange-label{font-size:10px;font-weight:600;color:#64748b;min-width:60px;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;flex-shrink:0}.yrange-input{width:72px;padding:3px 5px;border:1px solid #dbe2ea;border-radius:4px;background:#fff;color:#0f172a;font-size:11px;font-family:monospace;flex-shrink:0}.yrange-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #bfdbfe55}.yrange-sep{font-size:11px;color:#94a3b8;flex-shrink:0}.yrange-auto-btn{padding:3px 7px;font-size:10px;font-weight:600;background:#fff;border:1px solid #dbe2ea;border-radius:4px;color:#475569;cursor:pointer;transition:all .15s;flex-shrink:0}.yrange-auto-btn:hover{background:#e2e8f0;color:#0f172a}.btn-small{padding:6px 10px;font-size:12px}.btn-small .material-symbols-outlined{font-size:16px}.workspace-grid{--workspace-top-height: 640px;display:grid;grid-template-columns:240px minmax(500px,1fr);grid-template-rows:var(--workspace-top-height) minmax(0,1fr);gap:20px;align-items:stretch;min-width:0;height:100%;min-height:0}.components-panel{grid-column:1;grid-row:1;min-width:0;min-height:0;height:var(--workspace-top-height);display:flex;flex-direction:column;overflow:hidden}.canvas-panel{grid-column:2;grid-row:1;height:var(--workspace-top-height)}.panel{background:#fff;border-radius:6px;padding:16px;border:1px solid #e5e5e5;box-shadow:none}.panel h2{margin:0 0 15px;font-size:11px;text-transform:uppercase;letter-spacing:2px;color:#3b82f6;font-weight:600}.components-panel .json-header{padding-top:8px;margin-top:12px;margin-bottom:6px}.component-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;overflow-y:auto;align-content:start;border:1px solid #e5e5e5;border-radius:8px;padding:6px}.component-item{padding:4px;background:#fff;border-radius:6px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;border:1.5px solid #e5e5e5;position:relative;min-width:0;aspect-ratio:1}.component-item:hover{background:#fafafa;border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.component-item.selected{background:#eff6ff;border:2px solid #3b82f6;box-shadow:0 0 0 2px #3b82f61a}.component-item svg{width:42px;height:30px;flex-shrink:0;transform:scale(1.2)}.component-item svg path,.component-item svg circle,.component-item svg polygon,.component-item svg ellipse{stroke:#333!important;fill:none!important}.component-item svg polygon{fill:#333!important}.component-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.component-meta,.component-name{display:none}.component-desc{font-size:11px;color:#666}.component-item.tool-item .material-symbols-outlined{font-size:18px;color:#333}.component-item.tool-item .component-thumb{background:#f8fafc;border:1px dashed #e2e8f0;border-radius:6px}.component-item.draft{border:1px dashed #999;background:#fff;color:#555;cursor:default;flex-direction:column;justify-content:center;text-align:center;min-height:60px;gap:4px}.component-item.draft:hover{background:#fff}.component-item.draft .draft-label{font-weight:600;font-size:8px;text-transform:uppercase;letter-spacing:1px}.component-item.draft .draft-subtext{font-size:11px;color:#888}.component-item.dirty{border:1px dashed #f97316}.component-item.dirty.selected{border:2px dashed #f97316;background:#fff7ed}.btn{padding:8px 12px;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:4px}.btn .material-symbols-outlined{font-size:18px}.btn-icon{padding:8px;min-width:36px}.btn-primary{background:#3b82f6;color:#fff;border:1px solid #3b82f6;font-weight:500;border-radius:6px}.btn-primary:hover{background:#2563eb;border-color:#2563eb}.btn-secondary{background:#fff;color:#333;border:1px solid #e5e5e5;font-weight:500;border-radius:6px}.btn-secondary:hover{background:#fafafa;border-color:#d4d4d4}.btn-nav{background:#fff;color:#3b82f6;border:1.5px solid #bfdbfe;border-radius:8px;padding:10px 18px;font-weight:500;text-decoration:none;box-shadow:0 1px 3px #3b82f614;transition:background .15s,border-color .15s,box-shadow .15s}.btn-nav:hover{background:#eff6ff;border-color:#93c5fd;box-shadow:0 2px 6px #3b82f626}.tool-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.tool-btn.active:hover{background:#2563eb;border-color:#2563eb}.tool-btn[data-tool=probe].active{background:#e11d48;border-color:#e11d48}.tool-btn[data-tool=probe].active:hover{background:#be123c;border-color:#be123c}.tool-btn[data-tool=delete].active{background:#ef4444;border-color:#ef4444}.tool-btn[data-tool=delete].active:hover{background:#dc2626;border-color:#dc2626}.component-item.tool-item.active{background:#f0fdf4;border:2px solid #10b981;color:inherit}.component-item.tool-item.active .material-symbols-outlined{color:#10b981}.btn-danger{background:#ef4444;color:#fff;border-radius:6px}.btn-danger:hover{background:#dc2626}.btn-group{display:flex;gap:8px;margin-top:15px;flex-wrap:wrap}.small-btn{padding:4px 8px;font-size:11px}.canvas-container{display:flex;flex-direction:column;gap:16px;height:100%;min-height:0;max-height:none;overflow:hidden}.toolbar{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap;align-items:center}.toolbar .separator{width:1px;height:24px;background:#ccc;margin:0 8px}.toolbar label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:1px}.toolbar input[type=number]{width:48px;padding:4px 8px;border:1px solid #e5e5e5;border-radius:4px;background:#fff;color:#222;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.zoom-indicator{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:1px}.canvas-layout{display:flex;gap:16px;align-items:stretch;flex:1;min-height:0}.canvas-main{flex:1;display:flex;flex-direction:column;gap:10px;order:1;min-height:0}.canvas-wrapper{flex:1;background:#fff;border-radius:6px;overflow:hidden;position:relative;border:1px solid #e5e5e5;box-shadow:none;min-height:0;height:100%;display:flex;justify-content:flex-start;align-items:flex-start}canvas{width:100%;height:100%;background:#fdfdfd;border:0;touch-action:none;cursor:crosshair;display:block}#canvas{width:100%;height:100%;cursor:crosshair;display:block}.canvas-info{position:absolute;bottom:10px;left:10px;font-size:10px;color:#999;pointer-events:none;font-family:monospace;display:flex;gap:12px;text-transform:uppercase}.label-preview-section{display:flex;flex-direction:column;gap:12px;width:220px;flex-shrink:0;order:2;height:100%;min-height:0}.label-preview{border:1px solid #e5e5e5;background:#fff;border-radius:6px;padding:10px;flex:1;display:flex;flex-direction:column;min-height:0}.label-preview-title{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}.label-preview canvas{width:100%;height:100%;border:none;background:#fff;display:block;flex:1}.label-chip{font-size:9px;color:#999;border:1px solid #ccc;padding:1px 4px;border-radius:2px}.properties{display:flex;flex-direction:column;gap:15px;overflow-y:auto;align-self:stretch;height:100%}.prop-group{background:#fff;border-radius:6px;padding:12px;border:1px solid #e5e5e5}.prop-group h3{margin:0 0 10px;font-size:10px;color:#3b82f6;text-transform:uppercase;letter-spacing:1px;font-weight:600}.prop-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.prop-row:last-child{margin-bottom:0}.prop-row label{font-size:11px;color:#666;min-width:70px}.prop-row input[type=text],.prop-row input[type=number],.prop-row select{flex:1;padding:6px 10px;border:1px solid #e5e5e5;border-radius:4px;background:#fff;color:#222;font-size:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;transition:border-color .2s}.prop-row input[type=text]::placeholder,.prop-row input[type=number]::placeholder{color:#c3c3c3}.prop-row input[type=text]:focus,.prop-row input[type=number]:focus{outline:none;border-color:#10b981}.prop-row textarea{flex:1;min-height:64px;padding:6px 10px;border:1px solid #e5e5e5;border-radius:4px;background:#fff;color:#222;font-size:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;transition:border-color .2s;resize:vertical}.prop-row textarea:focus{outline:none;border-color:#10b981}.prop-row input[type=checkbox]{width:16px;height:16px}.pin-list,.element-list{display:flex;flex-direction:column;gap:8px}.pin-item,.element-item{background:#fff;padding:8px;border-radius:4px;font-size:11px;border:1px solid #e5e5e5}.pin-item.selected,.element-item.selected{border:2px solid #10b981;background:#f0fdf4}.model-list{display:flex;flex-direction:column;gap:4px}.model-item{background:#fff;border-radius:4px;font-size:11px;border:1px solid #e5e5e5;transition:all .2s ease}.model-item-expanded{border-color:#3b82f6;box-shadow:0 1px 3px #3b82f61a}.model-header{display:flex;align-items:center;justify-content:space-between;padding:8px;font-size:11px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.model-header:hover{background-color:#f9fafb}.model-item-expanded .model-header{border-bottom:1px solid #e5e5e5;background-color:#f9fafb}.model-header-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.model-expand-icon{color:#9ca3af;font-size:9px;width:10px;flex-shrink:0;transition:transform .2s ease}.model-name-display{font-weight:600;color:#111;flex-shrink:0}.model-preview{color:#6b7280;font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-left:8px}.model-details{padding:12px 8px 8px;display:flex;flex-direction:column;gap:12px}.model-field{display:flex;flex-direction:column;gap:4px}.model-field label{font-size:11px;color:#666;font-weight:500}.model-field input[type=text],.model-field textarea{width:100%;padding:6px 8px;border:1px solid #e5e5e5;border-radius:4px;font-size:11px;font-family:Courier New,monospace}.model-field input[type=text]:focus,.model-field textarea:focus{outline:none;border-color:#3b82f6}.model-actions{display:flex;gap:6px;flex-shrink:0}.model-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;min-width:0}.model-row label{min-width:70px;flex-shrink:0}.model-row input[type=text],.model-row textarea{flex:1;min-width:0}.model-text-row{align-items:flex-start}.model-text-row label{padding-top:6px}.model-empty{border:1px dashed #e5e5e5;border-radius:4px;padding:8px;font-size:11px;color:#999;background:#fafafa}.pin-header,.element-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.pin-coords,.element-coords{display:flex;gap:8px}.pin-coords input,.pin-label-coords input,.element-coords input{width:50px;padding:4px;border:1px solid #e5e5e5;border-radius:4px;background:#fff;color:#222;font-size:11px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.pin-label-coords{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:10px;color:#666}.pin-label-coords span{min-width:50px}.label-coords{display:flex;gap:6px;flex-wrap:wrap}.label-coords input{width:60px}.json-output{grid-column:1 / span 2;margin-top:0;display:flex;flex-direction:column;gap:10px;min-height:0}.json-output h2{display:flex;justify-content:space-between;align-items:center}#jsonOutput{width:100%;flex:1;min-height:0;background:#fff;border:1px solid #e5e5e5;border-radius:6px;color:#222;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;font-size:12px;padding:10px;resize:none}.mode-indicator{padding:4px 12px;border-radius:0;font-size:10px;font-weight:400;border:1px solid #333;letter-spacing:1px}.modal-overlay{position:fixed;inset:0;background:#0f172a73;display:none;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-overlay.is-open{display:flex}.modal{background:#fff;border-radius:10px;padding:20px;width:min(420px,92vw);max-height:min(88vh,960px);box-shadow:0 20px 60px #0f172a40;border:1px solid #e5e5e5;display:flex;flex-direction:column;min-height:0}.modal-large{width:min(720px,92vw)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-shrink:0}.modal-header h3{margin:0;font-size:16px;font-weight:600;color:#111}.modal-body{display:flex;flex-direction:column;gap:12px;min-height:0;overflow:auto}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;flex-shrink:0}.modal-field{display:flex;flex-direction:column;gap:6px}.modal-field label{font-size:12px;color:#475569}.modal-field input{padding:8px 10px;border-radius:6px;border:1px solid #e5e5e5;font-size:13px}.modal-field input:disabled{background:#f8fafc;color:#94a3b8}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.runner-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;background:#f1f5f9;color:#0f172a}.runner-status.run-ready{background:#ecfdf3;color:#166534}.runner-status.run-running{background:#fef3c7;color:#b45309}.runner-status.run-running:before{content:"";width:8px;height:8px;border-radius:50%;background:#f59e0b;animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.runner-status.run-error{background:#fee2e2;color:#b91c1c}.runner-status-detail{font-size:11px;color:#64748b;min-height:14px}.runner-progress{display:flex;flex-direction:column;gap:4px}.runner-progress.is-hidden{display:none}.runner-progress-track{position:relative;height:6px;border-radius:999px;overflow:hidden;background:#e2e8f0}.runner-progress-bar{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,#f59e0b,#f97316);transition:width .12s linear}.runner-progress.is-indeterminate .runner-progress-bar{position:relative;animation:runner-indeterminate 1.1s ease-in-out infinite}.runner-progress-label{font-size:11px;color:#475569}@keyframes runner-indeterminate{0%{transform:translate(-120%)}to{transform:translate(320%)}}.mode-select{background:#fff;color:#333}.mode-line,.mode-circle,.mode-arc,.mode-polygon,.mode-polyline,.mode-pin{background:#333;color:#fff}#fileInput{display:none}main{flex:1;display:flex;gap:16px;padding:0;align-items:flex-start}.side-panel{width:230px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.palette{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.palette button{border:1px solid #c0c0c0;border-radius:4px;padding:10px;background:#fafafa;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:64px;transition:all .2s}.palette button:hover{border-color:#3b82f6;background:#f5f8ff}.palette button img{max-width:62px;max-height:44px;object-fit:contain;filter:drop-shadow(0 1px 1px rgba(0,0,0,.08));pointer-events:none}.palette button.active{border-color:#2563eb;color:#0f172a;background:#e0ecff;font-weight:600;box-shadow:inset 0 0 0 1px #2563eb}.tool-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.tool-actions button{border:1px solid #c0c0c0;border-radius:6px;padding:8px 10px;font-size:13px;background:#fafafa;cursor:pointer;flex:1;transition:all .2s}.tool-actions button:hover{border-color:#3b82f6;background:#f5f8ff}.tool-actions button.active{border-color:#2563eb;color:#0f172a;background:#e0ecff;font-weight:600}.status-line{font-size:13px;color:#555;margin:0}.netlist-panel{width:320px;flex-shrink:0;background:#fff;border:1px solid #e5e5e5;border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:none}.netlist-panel h2{margin:0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:#3b82f6}.netlist-output{min-height:140px;max-height:100%;border:1px solid #e5e5e5;border-radius:6px;padding:8px;background:#f8f8f8;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;font-size:13px;white-space:pre;overflow:auto;min-width:0}.circuit-editor-container{flex:1;display:flex;flex-direction:column;gap:0;min-width:0;min-height:0;background:#fff;border:1px solid #e5e5e5;border-radius:8px;overflow:hidden}.circuit-toolbar{display:flex;gap:8px;align-items:center;padding:8px 12px;background:#fafafa;border-bottom:1px solid #e5e5e5}.circuit-toolbar .separator{width:1px;height:24px;background:#e5e5e5;margin:0 4px}.circuit-toolbar .tool-btn{display:inline-flex;align-items:center;gap:4px}.circuit-toolbar .tool-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.circuit-toolbar .tool-btn.active:hover{background:#2563eb;border-color:#2563eb}.probe-type-selector{display:inline-flex;gap:4px;align-items:center;padding:2px;background:#f1f5f9;border-radius:6px;margin-left:4px}.probe-type-btn{min-width:36px;padding:4px 8px;font-size:12px;font-weight:600;border-radius:4px;transition:all .15s ease}.probe-type-btn .material-symbols-outlined{font-size:16px}.probe-type-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 1px 2px #3b82f633}.probe-type-btn.active:hover{background:#2563eb;border-color:#2563eb}.probe-type-btn:not(.active){background:transparent;color:#64748b;border-color:transparent}.probe-type-btn:not(.active):hover{background:#e2e8f0;color:#334155;border-color:transparent}.circuit-canvas-wrapper{flex:1;position:relative;background:#fdfdfd;overflow:hidden;min-height:0;min-width:0}.circuit-canvas-wrapper canvas{width:100%;height:100%;display:block;cursor:crosshair}.circuit-canvas-wrapper .canvas-info{position:absolute;bottom:10px;left:10px;font-size:10px;color:#666;pointer-events:none;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;display:flex;gap:16px;background:#ffffffe6;padding:4px 8px;border-radius:4px}.circuit-status-bar{padding:6px 12px;background:#f8fafc;border-top:1px solid #e5e5e5;font-size:11px;color:#64748b}.simulation-badge{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:4px;padding:4px 10px;background:#fffffff2;border:1px solid #e5e5e5;border-radius:16px;font-size:11px;font-weight:600;color:#94a3b8;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000000d}.simulation-badge:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 2px 8px #0000001a}.simulation-badge .material-symbols-outlined{font-size:16px}.simulation-badge.active{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.sim-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid #e5e5e5}.sim-tab{padding:8px 16px;background:transparent;border:none;border-bottom:2px solid transparent;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.sim-tab:hover{color:#334155;background:#f8f9fa}.sim-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.sim-content{position:relative;min-height:200px}.sim-panel{display:none}.sim-panel.active{display:block}.sim-panel button.btn-primary{margin-top:16px}.modal-field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.modal-field select{padding:8px 10px;border-radius:6px;border:1px solid #e5e5e5;font-size:13px;background:#fff}.directive-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:6px;font-family:Courier New,monospace;font-size:12px;color:#334155}.directive-item-actions{display:flex;gap:4px}.directive-item-actions button{padding:2px 6px;font-size:11px;background:transparent;border:1px solid #cbd5e1;border-radius:4px;cursor:pointer;color:#64748b;transition:all .15s}.directive-item-actions button:hover{background:#fff;color:#ef4444;border-color:#ef4444}.compare-modal-controls{display:flex;align-items:center;gap:10px}.compare-group-select{padding:5px 8px;border-radius:6px;border:1px solid #e2e8f0;font-size:12px;color:#334155;background:#fff;cursor:pointer}.compare-plot-area{width:100%;height:350px;min-height:280px;overflow:hidden;box-sizing:border-box}#compare-modal .modal-body{overflow-x:hidden}#compare-modal .modal{width:min(900px,94vw);min-height:80vh}.compare-probe-legend{display:flex;flex-wrap:wrap;gap:6px 16px;padding:8px 12px;border-top:1px solid #e5e7eb;background:#f8fafc;border-radius:0 0 6px 6px}.compare-probe-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#334155;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.compare-probe-legend-item input[type=checkbox]{width:13px;height:13px;margin:0;accent-color:#3b82f6;cursor:pointer;flex-shrink:0}.compare-probe-legend-item svg{flex-shrink:0}.compare-analysis-blocks{display:flex;flex-direction:column;gap:6px;flex:1;min-height:0;overflow-y:auto;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;background:#fafafa;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;font-size:12px;line-height:1.5}.compare-analysis-block{display:flex;align-items:flex-start;gap:6px;padding:4px 8px;border-left:3px solid currentColor;border-radius:0 4px 4px 0;background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none}.compare-analysis-block input[type=checkbox]{width:13px;height:13px;margin:2px 0 0;accent-color:currentColor;cursor:pointer;flex-shrink:0}.compare-analysis-block span{white-space:pre-wrap;word-break:break-word}
