*,*:before,*:after{box-sizing:border-box}:root{--bg: #f4f4f5;--surface: #ffffff;--border: #e4e4e7;--accent: #6d28d9;--accent-l:#ede9fe;--text: #18181b;--muted: #71717a;--mono: ui-monospace, "SFMono-Regular", Menlo, monospace;--radius: 8px}html,body,#root{margin:0;height:100%;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:14px;color:var(--text);background:var(--bg)}.app-shell{display:flex;flex-direction:column;height:100%}.workspace-split{display:flex;flex:1;min-height:0;width:100%}.workspace-left{display:flex;flex-direction:column;min-height:0;flex:0 0 560px;min-width:0;border-right:1px solid var(--border);background:var(--surface)}.workspace-right{flex:1 1 0;min-width:0;min-height:0;display:flex}.workspace-diagram{flex:1 1 0;min-height:0}.panel-divider{width:1px;background:var(--border);flex-shrink:0}.debug-toolbar{display:flex;align-items:center;gap:14px;padding:5px 12px;border-bottom:1px solid #fbbf24;background:#fffbeb;flex-shrink:0;color:#92400e;font-size:12px}.debug-toolbar label{display:inline-flex;align-items:center;gap:5px;cursor:pointer}.debug-toolbar-links{display:inline-flex;align-items:center;gap:7px;margin-left:auto}.debug-toolbar a{color:#92400e}.app-header{display:flex;align-items:center;gap:10px;padding:10px 18px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.app-title-group{display:flex;align-items:center;gap:8px}.app-logo{width:24px;height:24px;border-radius:5px;flex-shrink:0}.app-title{font-size:15px;font-weight:700;letter-spacing:-.01em}.app-filename{font-size:12px;color:var(--muted);margin-left:8px;font-family:var(--mono)}.header-pills{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}.header-history{display:flex;gap:4px}.header-file-actions{display:flex;gap:8px;align-items:center}.header-hamburger-wrap{display:none;position:relative}.header-dropdown{position:absolute;right:0;top:calc(100% + 6px);z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001f;min-width:160px;overflow:hidden}.header-dropdown-item{display:flex;align-items:center;width:100%;padding:10px 14px;border:0;background:transparent;color:var(--text);cursor:pointer;font-family:inherit;font-size:13px;text-align:left}.header-dropdown-item:hover{background:var(--bg)}.header-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.header-help-actions{display:flex;gap:4px}.pill{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:999px;background:var(--bg);border:1px solid var(--border);font-size:12px;color:var(--muted)}.pill strong{color:var(--text)}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .1s;font-family:inherit}.btn:hover{background:var(--bg)}.btn:disabled{opacity:.38;cursor:default}.btn:disabled:hover{background:var(--surface)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:#5b21b6}.btn.primary:disabled:hover{background:var(--accent)}.btn-icon{padding:6px 8px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:20px}.dialog{background:var(--surface);border-radius:12px;box-shadow:0 20px 60px #00000040;padding:28px;width:100%;max-width:340px}.dialog-title{margin:0 0 6px;font-size:16px;font-weight:700}.dialog-body{margin:0 0 20px;color:var(--muted);font-size:13px}.dialog-unit-options{display:flex;gap:8px;margin-bottom:24px}.dialog-unit-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .12s,background .12s}.dialog-unit-option input{display:none}.dialog-unit-option:hover{border-color:#c4b5fd;background:var(--accent-l)}.dialog-unit-option.is-selected{border-color:var(--accent);background:var(--accent-l)}.dialog-unit-label{font-size:18px;font-weight:700;color:var(--text)}.dialog-unit-hint{font-size:10px;color:var(--muted)}.dialog-unit-option.is-selected .dialog-unit-label{color:var(--accent)}.dialog-actions{display:flex;justify-content:flex-end;gap:8px}.dialog-recent{max-width:420px}.dialog-help{max-width:480px}.about-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.about-header .dialog-title{margin:0}.about-logo{width:48px;height:48px;border-radius:10px;flex-shrink:0}.help-steps{margin:0 0 24px;padding-left:20px;display:flex;flex-direction:column;gap:10px}.help-steps li{font-size:13px;line-height:1.5;color:var(--text)}.help-steps li strong{color:var(--text)}.help-steps code,.help-steps kbd{font-family:var(--mono);font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 5px}.recent-list{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-direction:column;gap:6px}.recent-item{display:flex;align-items:stretch;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.recent-item:hover{border-color:#c4b5fd}.recent-item-main{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 12px;border:0;background:transparent;cursor:pointer;font-family:inherit;text-align:left}.recent-item-main:hover{background:var(--accent-l)}.recent-item-name{font-size:13px;font-weight:600;color:var(--text);font-family:var(--mono)}.recent-item-meta{font-size:11px;color:var(--muted)}.recent-item-delete{display:flex;align-items:center;justify-content:center;width:36px;flex-shrink:0;border:0;border-left:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer}.recent-item-delete:hover{background:#fee2e2;color:#dc2626}.drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;pointer-events:none;background:#6d28d91f;border:3px dashed var(--accent);border-radius:0;display:flex;align-items:center;justify-content:center}.drop-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--surface);border-radius:16px;padding:32px 48px;box-shadow:0 8px 32px #00000026;color:var(--accent);font-size:18px;font-weight:600}.drop-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}.drop-zone{width:100%;max-width:480px;border:2px dashed var(--border);border-radius:16px;padding:60px 40px;text-align:center;background:var(--surface)}.drop-zone svg{color:var(--muted);margin-bottom:16px}.drop-zone h2{margin:0 0 8px;font-size:18px;font-weight:600}.drop-zone p{margin:0 0 20px;color:var(--muted);font-size:13px}.drop-zone-actions{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:10px}.drop-zone-actions .btn{padding:9px 24px;font-size:14px;justify-content:center}@media(max-width:420px){.drop-zone-actions{flex-direction:column;align-items:stretch}.drop-zone-actions .btn{width:100%}}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:7px 13px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;min-height:4vh}.panel-header-hint{font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;opacity:.7}.muted{color:var(--muted)}.editor-panel{display:flex;flex-direction:column;width:100%;flex:1 1 0;min-height:0;background:var(--surface)}.category-selector-shell{display:flex;align-items:center;min-width:0;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg)}.category-selector-shell-mobile{display:none}.category-selector-scroll-area{position:relative;min-width:0;flex:1 1 auto}.category-selector{display:flex;align-items:center;gap:4px;padding:5px 28px;background:var(--bg);overflow-x:auto;flex-shrink:0;scrollbar-width:none}.category-selector::-webkit-scrollbar{display:none}.category-scroll-button{position:absolute;z-index:2;top:0;bottom:1px;display:flex;align-items:center;justify-content:center;width:26px;border:0;color:var(--accent);cursor:pointer;font-family:inherit;font-size:24px;font-weight:800;line-height:1;opacity:0;pointer-events:none;transition:opacity .15s}.category-scroll-button.is-visible{opacity:1;pointer-events:auto}.category-scroll-button svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.category-scroll-button.is-left{left:0;background:linear-gradient(90deg,var(--bg) 68%,rgba(248,247,252,0))}.category-scroll-button.is-right{right:0;background:linear-gradient(270deg,var(--bg) 68%,rgba(248,247,252,0))}.cat-tab{display:inline-flex;align-items:center;gap:4px;height:28px;padding:0 10px;border:1px solid transparent;border-radius:999px;background:none;font-size:12px;font-weight:700;cursor:pointer;color:var(--muted);white-space:nowrap;font-family:inherit;transition:background .15s,color .15s,transform .15s,box-shadow .15s,padding .15s,max-width .15s}.cat-tab:hover{background:var(--surface);color:var(--text)}.cat-tab-recommended{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.cat-tab-recommended:hover{background:#dcfce7;color:#166534}.cat-tab-recommended .cat-tab-chip{background:#16a34a}.cat-tab-recommended.is-active{border-color:#16a34a;background:#f0fdf4;color:#166534;box-shadow:0 6px 16px #16a34a1f}.cat-tab-errors{flex-shrink:0;margin-left:5px;padding:0 8px 0 4px;border-color:#fecaca;background:#fef2f2;color:#b91c1c;box-shadow:5px 0 7px var(--bg);white-space:nowrap}.cat-tab-errors:hover{background:#fee2e2;color:#991b1b}.cat-tab-errors .cat-tab-chip{background:#dc2626}.cat-tab.is-active{background:var(--surface);color:var(--text);border-color:var(--accent);padding:0 12px 0 8px;transform:translateY(-1px);box-shadow:0 6px 16px #6d28d91f}.cat-tab-errors.is-active{border-color:#dc2626;background:#fef2f2;color:#991b1b;box-shadow:5px 0 7px var(--bg),0 6px 16px #dc26261f}.cat-tab-letter{font-variant-numeric:tabular-nums}.cat-tab-chip{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;line-height:1;box-shadow:inset 0 -1px #ffffff2e;flex-shrink:0}.cat-tab-name{max-width:0;overflow:hidden;opacity:0;transform:translate(-4px);transition:max-width .18s ease,opacity .18s ease,transform .18s ease}.cat-tab.is-active .cat-tab-name{max-width:14rem;opacity:1;transform:translate(0)}.cat-tab-label{display:none}.editor-toolbar{display:none;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.search-wrap{position:relative;flex:1}.search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search-input{width:100%;height:30px;padding:0 9px 0 30px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:inherit;background:var(--bg);outline:none}.search-input:focus{border-color:var(--accent);background:var(--surface)}.value-filter{height:30px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:inherit;background:var(--bg);color:var(--text);padding:0 7px;outline:none;flex-shrink:0}.value-filter:focus{border-color:var(--accent)}.editor-count{font-size:11px;flex-shrink:0}.table-scroll{flex:1;min-height:0;overflow:auto;padding:12px}.meas-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);font-size:13px;overflow:hidden}.meas-table thead th{padding:9px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1;white-space:nowrap}.meas-table tbody tr{transition:background .08s}.meas-table tbody tr.measurement-detail-row{border-bottom:1px solid var(--border)}.meas-table tbody tr:last-child{border-bottom:none}.meas-table tbody tr:hover{background:#fafafa}.meas-table tbody tr.is-highlighted{background:var(--accent-l)!important}.meas-table tbody tr.has-error{background:#fff5f5}.meas-table tbody tr.missing-value{color:var(--muted)}.meas-table td{padding:9px 12px;vertical-align:middle}.meas-table .measurement-main-row td{padding-bottom:4px}.meas-table .measurement-detail-row td{padding-top:3px;padding-bottom:9px}.empty-cell{text-align:center;padding:40px!important;color:var(--muted)}.badge-id{font-family:var(--mono);font-size:11px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:1px 6px;color:#1d4ed8}.badge-var{font-family:var(--mono);font-size:11px;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 6px;color:var(--accent)}.cell-name{max-width:240px}.cell-name-full{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.cell-name-desc{display:block;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.cell-resolved{font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.cell-resolved.is-formula{color:#0369a1}.is-error{color:#dc2626;font-style:italic}.unit-label{color:var(--muted);font-size:11px;font-weight:400}.badge-formula{display:inline-block;margin-left:5px;font-size:10px;font-weight:600;padding:1px 4px;border-radius:4px;background:#e0f2fe;color:#0369a1}.cell-cm{display:block;font-size:11px;color:var(--muted);font-weight:500;margin-top:1px}.raw-cell-input{font-family:var(--mono);font-size:12px;color:var(--muted);background:transparent;border:1px solid transparent;border-radius:4px;padding:2px 5px;width:100%;min-width:80px;outline:none;transition:border-color .12s,background .12s,color .12s}.raw-cell-input:hover{border-color:var(--border);background:var(--bg)}.raw-cell-input:focus{border-color:var(--accent);background:var(--surface);color:var(--text);box-shadow:0 0 0 2px var(--accent-l)}.raw-cell-input::placeholder{color:var(--border)}.raw-cell-input.is-modified{color:#0369a1}.measurement-list{flex:1;min-height:0;overflow:auto;background:var(--surface)}.measurement-list-section-header{padding:4px 8px;min-height:5em;display:flex;align-items:center;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);background:var(--accent-l);border-left:8px solid var(--accent)}.measurement-list-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;width:100%;border-bottom:1px solid var(--border);background:transparent;color:var(--text)}.measurement-list-row:hover{background:#fafafa}.measurement-list-row.is-missing{background:#fffbeb}.measurement-list-row.has-error{border-color:#fecaca;background:#fef2f2;box-shadow:inset 3px 0 #dc2626}.measurement-list-row.has-error:hover{background:#fee2e2}.measurement-list-row.is-highlighted,.measurement-list-row.is-selected{background:var(--accent-l)}.measurement-list-row.has-error.is-highlighted,.measurement-list-row.has-error.is-selected{background:#fee2e2}.measurement-list-row.is-missing .measurement-list-calculated{color:#b45309}.measurement-list-select{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:9px;align-items:center;min-width:0;padding:8px 7px;border:0;background:transparent;color:var(--text);text-align:left;cursor:pointer;font-family:inherit}.measurement-list-actions{display:flex;align-items:center;gap:3px;padding-right:5px;min-width:2em}.measurement-list-jump{align-self:center;padding:3px 5px;border:1px solid #c4b5fd;border-radius:5px;background:var(--surface);color:var(--accent);cursor:pointer;font-family:inherit;font-size:10px;font-weight:800;white-space:nowrap}.measurement-list-jump:hover{background:var(--accent-l)}.measurement-list-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:0;border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .1s}.measurement-list-clear svg{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.measurement-list-clear:hover{color:#dc2626;background:#fee2e2}.measurement-list-row:hover .measurement-list-clear,.measurement-list-row.is-selected .measurement-list-clear,.measurement-list-row.is-highlighted .measurement-list-clear{opacity:1;pointer-events:auto}.measurement-list-name{min-width:0}.measurement-list-name strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.measurement-list-name code{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:3px;color:var(--muted);font-size:11px}.measurement-list-calculated{width:140px;max-width:260px;overflow:hidden;text-overflow:ellipsis;color:#0369a1;font-family:var(--mono);font-size:12px;font-weight:700;text-align:left;white-space:nowrap}.measurement-list-calculated-line{display:grid;grid-template-columns:3em 62px minmax(0,1fr);gap:4px;align-items:baseline}.measurement-list-calculated-line.is-formula:not(.is-secondary) .measurement-list-calculated-prefix{display:flex;align-items:center}.measurement-list-calculated-prefix{display:inline-block;min-width:45px;text-align:right;margin-right:8px;flex-shrink:0;white-space:nowrap}.measurement-list-calculated-line.is-formula:not(.is-secondary) .measurement-list-calculated-prefix:before{font-style:italic;content:"ƒ(x) ";margin-right:auto}.measurement-list-calculated-line.is-secondary{color:var(--muted);font-weight:500}.measurement-list-calculated-number{text-align:right;font-variant-numeric:tabular-nums}.measurement-list-calculated.is-error{color:#dc2626}.measurement-editor-panel{flex-shrink:0;border-top:1px solid var(--border);background:#fafafa}.measurement-editor-actions{display:flex;align-items:center;gap:4px;padding:4px 10px 0}.measurement-editor-search{position:relative;min-width:88px;flex:1 1 auto}.measurement-editor-search svg{position:absolute;left:6px;top:50%;width:12px;height:12px;transform:translateY(-50%);fill:none;stroke:var(--muted);stroke-width:1.7;stroke-linecap:round;pointer-events:none}.measurement-editor-search input{width:100%;height:22px;padding:0 25px 0 22px;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text);font-family:inherit;font-size:11px;outline:none}.measurement-editor-search input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-l)}.measurement-editor-actions button{display:inline-flex;align-items:center;gap:3px;min-height:22px;padding:2px 7px;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text);cursor:pointer;font-family:inherit;font-size:11px;font-weight:700}.measurement-editor-actions button:hover{background:var(--bg)}.measurement-editor-action-icon{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.measurement-editor-actions .measurement-editor-global-search{position:absolute;right:1px;top:1px;display:flex;align-items:center;justify-content:center;width:20px;min-height:20px;padding:0;border:0;border-radius:4px;background:transparent;color:var(--muted)}.measurement-editor-global-search svg{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}.measurement-editor-actions .measurement-editor-global-search.is-active{background:var(--accent-l);color:var(--accent)}.measurement-editor-actions .measurement-editor-restore-search{border-color:#c4b5fd;background:var(--accent-l);color:var(--accent)}.measurement-editor-actions .measurement-editor-restore-search:hover{background:#ddd6fe}.measurement-editor-actions button.is-danger{color:#b91c1c}.measurement-editor-actions button:disabled{color:var(--muted);cursor:default;opacity:.55}.measurement-editor-actions button:disabled:hover{background:var(--surface)}.measurement-editor{display:flex;flex-direction:column}.measurement-editor,.measurement-editor-empty{padding:6px 10px}.measurement-editor-empty{color:var(--muted);font-size:12px;text-align:center}.measurement-editor-row{display:grid;gap:7px;align-items:end}.measurement-editor-row+.measurement-editor-row{margin-top:5px}.identity-row{grid-template-columns:minmax(0,1fr) minmax(180px,1fr)}.calculation-row{grid-template-columns:minmax(0,1fr) auto minmax(120px,auto)}.measurement-editor-row label,.measurement-name-field,.calculated-field{min-width:0}.measurement-editor-row label>span,.measurement-name-field>span,.calculated-field>span{display:block;margin-bottom:2px;color:var(--muted);font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.measurement-name-field span code{margin-left:4px;color:#1d4ed8}.measurement-name-field strong{display:block;min-height:26px;padding:5px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.measurement-name-mobile{display:none}.measurement-editor-row input{width:100%;height:26px;padding:0 6px;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text);font-family:var(--mono);font-size:12px;outline:none}.measurement-editor-row input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-l)}.variable-field-input-wrap{position:relative}.variable-field-input-wrap input{padding-right:26px}.variable-copy-btn{position:absolute;right:1px;top:1px;display:flex;align-items:center;justify-content:center;width:22px;height:calc(100% - 2px);padding:0;border:1px;border-radius:4px;background:#fff;color:var(--muted);cursor:pointer;border-style:solid;border-color:gray}.variable-copy-btn:hover{background:var(--bg);color:var(--text)}.variable-copy-btn.is-copied{color:#16a34a}.variable-copy-btn svg{width:12px;height:12px}.measurement-editor-row input:disabled{border-color:var(--border);background:var(--bg);color:var(--muted);cursor:not-allowed}.measurement-description-field{display:flex;flex-direction:column;min-width:0;min-height:0;margin-top:5px}.measurement-description-field>span{display:block;margin-bottom:2px;color:var(--muted);font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.measurement-description-field textarea{display:block;width:100%;min-height:38px;flex:1 1 auto;padding:4px 6px;resize:vertical;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text);font-family:inherit;font-size:11px;outline:none}.measurement-description-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-l)}.calculation-arrow{align-self:end;padding:5px 0;color:var(--muted);font-family:var(--mono);font-weight:700}.calculated-field{padding:3px 7px;border:1px solid #bae6fd;border-radius:5px;background:#f0f9ff}.calculated-field strong{display:block;color:#0369a1;white-space:nowrap}.calculated-field strong.is-error{color:#dc2626}.measurement-editor-dependency-section{min-width:0;margin-top:5px}.measurement-editor-dependency-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:4px 6px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);cursor:pointer;font-family:inherit;text-align:left}.measurement-editor-dependency-toggle:hover{border-color:#c4b5fd;background:var(--accent-l)}.measurement-editor-dependency-toggle>span:first-child{font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.measurement-editor-dependency-toggle-hint{margin-left:auto;color:var(--muted);font-size:10px}.measurement-editor-dependency-toggle svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .15s}.measurement-editor-dependency-section.is-expanded .measurement-editor-dependency-toggle svg{transform:rotate(180deg)}.measurement-editor-dependencies{display:flex;gap:8px;margin-top:4px;height:clamp(70px,12vh,108px)}.measurement-editor-dependencies.is-hidden{display:none}@media(min-width:701px){.measurement-editor-dependency-toggle{display:none}.measurement-editor-dependencies.is-hidden{display:flex}}.measurement-editor-links{display:flex;flex-direction:column;align-content:flex-start;gap:3px;color:var(--muted);font-size:10px;min-width:0;overflow:hidden;flex:1 1 0}.measurement-editor-links-content,.measurement-editor-topology-content{display:flex;flex-wrap:wrap;gap:3px;min-width:0}.measurement-editor-links>span,.measurement-editor-topology>span{color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}.measurement-editor-links-empty{color:var(--muted);font-style:italic}.measurement-editor-topology,.measurement-editor-links{padding:5px 6px;border:1px solid var(--border);border-radius:6px;background:#fcfcfd}.measurement-editor-links button,.dependency-tree-node button{padding:1px 5px;border:1px solid #c4b5fd;border-radius:4px;background:var(--accent-l);color:var(--accent);cursor:pointer;font-family:var(--mono);font-size:10px}.measurement-editor-links button:hover,.dependency-tree-node button:hover{background:#ddd6fe}.measurement-editor-links button:disabled,.dependency-tree-node button:disabled{border-color:var(--border);background:var(--bg);color:var(--muted);cursor:default}.measurement-editor-topology{min-width:0;font-size:10px;overflow:hidden;flex:1 1 0}.measurement-editor-topology>em,.measurement-editor-links-empty{color:var(--muted);font-style:italic;padding:1px 0 0 1px}.measurement-editor-topology ul{margin:2px 0 0;padding-left:12px;list-style:none;border-left:1px solid #c4b5fd}.measurement-editor-topology li{position:relative;padding:1px 0}.measurement-editor-topology li:before{content:"";position:absolute;top:10px;left:-12px;width:9px;border-top:1px solid #c4b5fd}.dependency-tree-node{display:flex;align-items:center;gap:5px;min-width:0}.dependency-tree-node em{color:#dc2626;font-size:9px}.measurement-editor-error{margin-top:4px;font-size:10px}.measurement-editor-error{color:#dc2626}.workspace-top-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}.workspace-figure-mobile{flex:1 1 0;min-height:0;display:flex}.mobile-view-tabs{display:none;flex-shrink:0;background:var(--bg);border-bottom:1px solid var(--border)}.mobile-tab{flex:1;padding:7px 12px;border:0;border-bottom:2px solid transparent;background:transparent;color:var(--muted);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;transition:color .12s,border-color .12s}.mobile-tab:hover{color:var(--text)}.mobile-tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}@media(max-width:700px){.mobile-view-tabs{display:flex}.workspace-top-panel .workspace-diagram{flex:1 1 0;min-height:0}}.diagram-panel{display:flex;flex-direction:column;min-width:0;min-height:0;background:#f3f3f3;height:100%}.diagram-viewer{flex:1;overflow:hidden;position:relative}.diagram-touch-overlay{display:block;position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;touch-action:none;cursor:grab}.diagram-touch-overlay:active{cursor:grabbing}.diagram-status{flex-shrink:0;padding:4px 12px;background:var(--surface);border-top:1px solid var(--border);font-size:12px}.diagram-status-var{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--accent-l);border:1px solid #c4b5fd;border-radius:4px;padding:1px 6px}.figure-panel{flex:1 1 0;min-width:0;display:flex;flex-direction:column;min-height:0;background:var(--surface)}.figure-header-actions{display:flex;align-items:center;gap:8px}.figure-toggle{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--muted);text-transform:none;letter-spacing:0}.figure-toggle input{margin:0}.figure-copy-button{padding:3px 7px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--accent);cursor:pointer;font-size:10px;font-weight:700}.figure-copy-button:hover{background:var(--accent-l)}.figure-copy-button:disabled{color:var(--muted);cursor:default;opacity:.55}.figure-copy-button:disabled:hover{background:var(--surface)}.skin-swatches{display:flex;align-items:center;gap:3px}.skin-swatch{width:16px;height:16px;padding:0;border:1px solid rgba(0,0,0,.15);border-radius:50%;cursor:pointer;flex-shrink:0}.skin-swatch.is-active{outline:2px solid var(--accent);outline-offset:1px}.skin-picker{width:22px;height:22px;padding:0;border:1px solid var(--border);border-radius:5px;background:transparent;cursor:pointer}.figure-scroll{flex:1;min-height:0;overflow:hidden;padding:10px 8px;display:flex;justify-content:center;position:relative;touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none}.figure-scroll:active{cursor:grabbing}.figure-reset-zoom{display:none;position:absolute;bottom:10px;right:10px;z-index:10;align-items:center;gap:5px;padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #0000001f}.figure-reset-zoom:hover{background:var(--bg);color:var(--text)}@media(max-width:700px){.figure-reset-zoom{display:flex}}.figure-container{height:100%;display:flex;align-items:stretch;transform-origin:center center}.figure-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;text-align:center;padding:32px;line-height:1.7}.figure-guide-label{cursor:pointer}.figure-guide-label:hover{font-weight:700}.figure-candidates{flex-shrink:0;max-height:240px;overflow:auto;padding:8px 10px;border-top:1px solid var(--border);background:#fffbeb;font-size:11px}.figure-candidates-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.figure-candidates-header button{border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:14px}.figure-candidates-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.figure-candidates h3{margin:0 0 4px;color:var(--muted);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.figure-candidate-table{display:block;width:100%}.figure-candidate-table tbody{display:block}.figure-candidate-table tr{display:grid;grid-template-columns:1.4em 1fr;grid-template-rows:auto auto;column-gap:4px;row-gap:2px;padding:4px 0;border-top:1px solid rgba(0,0,0,.06)}.figure-candidate-table td{display:block;padding:0;border:0}.figure-candidate-mark{grid-column:1;grid-row:1;color:var(--muted);font-family:var(--mono);font-size:10px;padding-top:1px}.figure-candidate-formula{grid-column:2;grid-row:1}.figure-candidate-formula code{font-size:10px;white-space:normal;overflow-wrap:anywhere;word-break:break-all}.figure-candidate-table td.figure-candidate-meta{grid-column:2;grid-row:2;display:flex;align-items:baseline;flex-wrap:nowrap;gap:6px}.figure-candidate-value{font-family:var(--mono);font-size:10px;white-space:nowrap;color:#a9004b}.figure-candidate-value:before{content:"= "}.figure-candidate-kind{color:var(--muted);font-size:10px;white-space:nowrap}.figure-candidate-actions{display:flex;gap:3px}.figure-candidate-actions button{padding:1px 5px;border:1px solid var(--border);border-radius:3px;background:var(--surface);color:var(--accent);cursor:pointer;font-size:10px}.figure-candidate-actions button:hover{background:var(--accent-l)}.figure-candidate-table tr.is-used{color:#166534;font-weight:700}.figure-candidate-table tr.is-missing{color:var(--muted);opacity:.65}.figure-candidate-empty{color:var(--muted);font-style:italic}@media(max-width:700px){.app-header{padding:7px 10px;gap:8px}.app-filename,.header-pills{display:none}.header-history{margin-left:auto}.header-file-actions,.header-help-actions{display:none}.header-hamburger-wrap{display:block}.debug-toolbar,.category-selector-shell-desktop{display:none}.category-selector-shell-mobile{display:flex;min-height:0;border-top:1px solid var(--border)}.category-selector-mobile{display:flex;padding:.28rem 28px}.cat-tab{height:auto;min-height:1.86rem;padding:.12rem .57rem}.cat-tab.is-active{padding:.12rem .71rem .12rem .5rem}.cat-tab-chip{width:1.43rem;height:1.43rem;font-size:.71rem}.workspace-split{flex-direction:column}.workspace-left{display:grid;grid-template-rows:minmax(0,46fr) auto minmax(0,15fr) minmax(160px,20fr);flex:1 1 auto;min-height:0;height:100%;overflow:hidden;border-right:0;border-bottom:1px solid var(--border)}.workspace-right{display:none}.workspace-left>*{min-width:0;min-height:0}.workspace-diagram{min-height:0}.panel-header{min-height:2vh}.diagram-panel{min-height:0;height:100%;overflow:hidden}.diagram-status{display:none}.editor-panel{width:100%;flex:none;border-top:1px solid var(--border)}.category-selector-mobile{display:flex;overflow-x:auto;min-height:0}.editor-toolbar{display:none}.measurement-list-select{padding:6px 4px;grid-template-columns:38px minmax(0,1fr) auto;gap:6px}.measurement-list-name strong{font-size:11px}.measurement-list-calculated{width:112px;max-width:112px;overflow:hidden;text-overflow:ellipsis;font-size:11px}.measurement-list-calculated-line{grid-template-columns:8px 53px minmax(0,1fr);gap:3px}.measurement-list-calculated-prefix{min-width:1.5em}.measurement-list-calculated-line.is-formula:not(.is-secondary) .measurement-list-calculated-prefix:before{content:"ƒ"}.measurement-editor-panel{display:flex;flex-direction:column;min-height:160px;max-height:none;overflow:visible;position:relative}.measurement-editor-actions{padding-inline:6px}.measurement-editor-actions button{padding-inline:5px}.measurement-editor{display:grid;grid-template-rows:auto auto auto;flex:1 1 auto;height:auto;min-height:0;overflow:hidden;position:relative}.measurement-editor-dependency-section.is-expanded{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;flex-direction:column;background:var(--surface);border-top:1px solid var(--border)}.measurement-editor-dependency-section.is-expanded .measurement-editor-dependencies{order:1;flex:1 1 0;min-height:0;height:auto;max-height:none;overflow-y:auto;margin-top:0;padding:6px}.measurement-editor-dependency-section.is-expanded .measurement-editor-dependency-toggle{order:2;flex-shrink:0;border-top:1px solid var(--border);border-radius:0;border-left:0;border-right:0;border-bottom:0}.measurement-name-field,.measurement-description-field{display:none}.identity-row,.calculation-row{grid-template-columns:1fr}.calculation-arrow{display:none}}
