.canvas-container.svelte-19k9qwp{touch-action:none;background:#faf7f2;border-radius:8px;position:relative;overflow:hidden}.toolbar.svelte-mdimun{background:#1c1714;border-radius:8px 8px 0 0;flex-wrap:wrap;align-items:center;gap:4px;padding:6px 10px;display:flex}.tool-group.svelte-mdimun{align-items:center;gap:2px;display:flex}.tool-divider.svelte-mdimun{background:#3d3226;width:1px;height:24px;margin:0 4px}.tool-btn.svelte-mdimun{color:#a89880;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:5px;align-items:center;gap:5px;padding:5px 9px;font-family:inherit;font-size:12px;transition:all .12s;display:flex}.tool-btn.svelte-mdimun:hover{color:#e8ddd0;background:#2d2420}.tool-btn.active.svelte-mdimun{color:#fde68a;background:#78350f;border-color:#92400e}.tool-btn.danger.svelte-mdimun:hover{color:#fca5a5;background:#3b1212}.icon.svelte-mdimun{font-size:14px;line-height:1}.label.svelte-mdimun{font-size:11px;font-weight:500}@media (width<=480px){.label.svelte-mdimun{display:none}.tool-btn.svelte-mdimun{padding:6px 8px}}.grid-size-label.svelte-mdimun{color:#a89880;align-items:center;gap:4px;padding:2px 6px;font-size:11px;display:flex}.grid-size-label.svelte-mdimun input:where(.svelte-mdimun){color:#e8ddd0;text-align:right;background:#2d2420;border:1px solid #3d3226;border-radius:4px;width:48px;padding:2px 4px;font-size:11px}.tool-hint.svelte-mdimun{color:#78716c;margin-left:auto;padding:0 4px;font-family:monospace;font-size:11px}.panel.svelte-ek1e1{background:#faf7f2;border:1px solid #e5ddd0;border-radius:8px;padding:14px 16px}.panel-title.svelte-ek1e1{color:#44332a;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;font-family:monospace;font-size:13px;font-weight:600}.empty-hint.svelte-ek1e1{color:#a89880;margin:0;font-size:12px}.stat-grid.svelte-ek1e1{grid-template-columns:1fr 1fr;gap:8px;display:grid}.stat.svelte-ek1e1{background:#f2ede6;border-radius:6px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.stat.highlight.svelte-ek1e1{background:#78350f;grid-column:1/-1}.stat.highlight.svelte-ek1e1 .stat-label:where(.svelte-ek1e1){color:#fde68a}.stat.highlight.svelte-ek1e1 .stat-value:where(.svelte-ek1e1){color:#fff}.stat-label.svelte-ek1e1{color:#a89880;text-transform:uppercase;letter-spacing:.05em;font-size:10px}.stat-value.svelte-ek1e1{color:#44332a;font-family:monospace;font-size:16px;font-weight:600}.stat-value.red.svelte-ek1e1{color:#b91c1c}.sub-title.svelte-ek1e1{color:#78716c;text-transform:uppercase;letter-spacing:.05em;margin:12px 0 6px;font-size:11px;font-weight:600}.hole-row.svelte-ek1e1{background:#f2ede6;border-radius:5px;align-items:center;gap:8px;margin-bottom:4px;padding:5px 8px;display:flex}.hole-label.svelte-ek1e1{color:#44332a;flex:1;font-size:12px}.hole-area.svelte-ek1e1{color:#78350f;font-family:monospace;font-size:12px}.hole-area.incomplete.svelte-ek1e1{color:#a89880;font-style:italic}.remove-btn.svelte-ek1e1{color:#a89880;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:11px}.remove-btn.svelte-ek1e1:hover{color:#7f1d1d;background:#fca5a5}.panel.svelte-5qruty{background:#faf7f2;border:1px solid #e5ddd0;border-radius:8px;flex-direction:column;gap:10px;padding:14px 16px;display:flex}.panel-title.svelte-5qruty{color:#44332a;text-transform:uppercase;letter-spacing:.05em;margin:0;font-family:monospace;font-size:13px;font-weight:600}.row.svelte-5qruty{flex-direction:column;gap:4px;display:flex}.two-col.svelte-5qruty{grid-template-columns:1fr 1fr;gap:10px;display:grid}.field-label.svelte-5qruty{text-transform:uppercase;letter-spacing:.06em;color:#a89880;font-size:10px;font-weight:600}.select-wrap.svelte-5qruty select:where(.svelte-5qruty),input[type=number].svelte-5qruty{color:#44332a;box-sizing:border-box;background:#f2ede6;border:1px solid #d6cfc4;border-radius:5px;width:100%;padding:6px 8px;font-family:inherit;font-size:13px}.select-wrap.svelte-5qruty select:where(.svelte-5qruty):focus,input.svelte-5qruty:focus{outline-offset:-1px;outline:2px solid #92400e}.unit-tabs.svelte-5qruty{gap:2px;display:flex}.unit-tab.svelte-5qruty{color:#78716c;cursor:pointer;background:#f2ede6;border:1px solid #d6cfc4;border-radius:4px;flex:1;padding:5px;font-family:inherit;font-size:12px}.unit-tab.active.svelte-5qruty{color:#fde68a;background:#78350f;border-color:#92400e}.input-suffix.svelte-5qruty{align-items:center;gap:4px;display:flex}.input-suffix.svelte-5qruty input:where(.svelte-5qruty){flex:1}.input-suffix.svelte-5qruty span:where(.svelte-5qruty){color:#a89880;white-space:nowrap;font-size:11px}.slab-list.svelte-5qruty{flex-direction:column;gap:8px;display:flex}.slab-card.svelte-5qruty{background:#f2ede6;border:1px solid #e0d8cc;border-radius:7px;flex-direction:column;gap:8px;padding:10px;display:flex}.slab-header.svelte-5qruty{align-items:center;gap:7px;display:flex}.slab-color-dot.svelte-5qruty{border:1px solid #00000026;border-radius:50%;flex-shrink:0;width:12px;height:12px}.slab-label.svelte-5qruty{color:#44332a;flex:1;font-family:monospace;font-size:13px;font-weight:600}.icon-btn.svelte-5qruty{cursor:pointer;color:#a89880;background:0 0;border:none;border-radius:3px;padding:2px 5px;font-size:12px}.icon-btn.remove.svelte-5qruty:hover{color:#7f1d1d;background:#fca5a5}.slab-fields.svelte-5qruty{grid-template-columns:1fr 1fr 80px;align-items:end;gap:6px;display:grid}.field-group.svelte-5qruty{flex-direction:column;gap:3px;display:flex}.ratio-bar-track.svelte-5qruty{background:#d6cfc4;border-radius:2px;height:4px;overflow:hidden}.ratio-bar-fill.svelte-5qruty{border-radius:2px;height:100%;transition:width .2s}.slab-options.svelte-5qruty{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.check-label.svelte-5qruty,.color-label.svelte-5qruty{color:#78716c;cursor:pointer;align-items:center;gap:5px;font-size:11px;display:flex}.check-label.svelte-5qruty input[type=checkbox]:where(.svelte-5qruty){cursor:pointer}.color-label.svelte-5qruty input[type=color]:where(.svelte-5qruty){cursor:pointer;background:0 0;border:1px solid #d6cfc4;border-radius:3px;width:20px;height:20px;padding:0}.ratio-summary.svelte-5qruty{color:#78716c;background:#f2ede6;border-radius:5px;align-items:center;gap:8px;padding:6px 8px;font-size:12px;display:flex}.ratio-summary.warn.svelte-5qruty{color:#92400e;background:#fef3c7}.ratio-summary.svelte-5qruty .ok:where(.svelte-5qruty){color:#15803d}.norm-btn.svelte-5qruty{color:#fde68a;cursor:pointer;background:#78350f;border:none;border-radius:4px;margin-left:auto;padding:3px 8px;font-family:inherit;font-size:11px}.add-btn.svelte-5qruty{color:#a89880;cursor:pointer;background:0 0;border:1px dashed #d6cfc4;border-radius:6px;padding:8px;font-family:inherit;font-size:12px;transition:all .15s}.add-btn.svelte-5qruty:hover{color:#78350f;background:#fef3c7;border-color:#92400e}.panel.svelte-1huy54a{background:#faf7f2;border:1px solid #e5ddd0;border-radius:8px;flex-direction:column;gap:12px;padding:14px 16px;display:flex}.panel-title.svelte-1huy54a{color:#44332a;text-transform:uppercase;letter-spacing:.05em;margin:0;font-family:monospace;font-size:13px;font-weight:600}.field-label.svelte-1huy54a{text-transform:uppercase;letter-spacing:.06em;color:#a89880;margin-bottom:5px;font-size:10px;font-weight:600;display:block}.field-group.svelte-1huy54a{flex-direction:column;gap:4px;display:flex}.two-col.svelte-1huy54a{grid-template-columns:1fr 1fr;gap:10px;display:grid}.bond-options.svelte-1huy54a{flex-direction:column;gap:4px;display:flex}.bond-btn.svelte-1huy54a{cursor:pointer;text-align:left;background:#f2ede6;border:1px solid #e0d8cc;border-radius:6px;flex-direction:column;align-items:flex-start;padding:8px 10px;font-family:inherit;transition:all .12s;display:flex}.bond-btn.svelte-1huy54a:hover{border-color:#92400e}.bond-btn.active.svelte-1huy54a{background:#78350f;border-color:#92400e}.bond-btn.active.svelte-1huy54a .bond-name:where(.svelte-1huy54a){color:#fde68a}.bond-btn.active.svelte-1huy54a .bond-desc:where(.svelte-1huy54a){color:#fed7aa}.bond-name.svelte-1huy54a{color:#44332a;font-size:13px;font-weight:600}.bond-desc.svelte-1huy54a{color:#a89880;font-size:11px}input[type=number].svelte-1huy54a{color:#44332a;box-sizing:border-box;background:#f2ede6;border:1px solid #d6cfc4;border-radius:5px;flex:1;padding:6px 8px;font-family:inherit;font-size:13px}.input-suffix.svelte-1huy54a{align-items:center;gap:5px;display:flex}.input-suffix.svelte-1huy54a span:where(.svelte-1huy54a){color:#a89880;font-size:11px}.hint.svelte-1huy54a{color:#a89880;font-size:10px;font-style:italic}.hint.inline.svelte-1huy54a{margin-left:4px}.check-label.svelte-1huy54a{color:#44332a;cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.unit-tabs.svelte-1huy54a{gap:3px;display:flex}.unit-tab.svelte-1huy54a{color:#78716c;cursor:pointer;text-transform:capitalize;background:#f2ede6;border:1px solid #d6cfc4;border-radius:4px;flex:1;padding:5px 8px;font-family:inherit;font-size:12px}.unit-tab.active.svelte-1huy54a{color:#fde68a;background:#78350f;border-color:#92400e}.panel.svelte-u173d3{background:#1c1714;border:1px solid #3d3226;border-radius:8px;flex-direction:column;gap:10px;padding:14px 16px;display:flex}.panel-title.svelte-u173d3{color:#fde68a;text-transform:uppercase;letter-spacing:.05em;margin:0;font-family:monospace;font-size:13px;font-weight:600}.summary.svelte-u173d3{grid-template-columns:1fr 1fr;gap:6px;display:grid}.stat.svelte-u173d3{background:#2d2420;border-radius:5px;flex-direction:column;gap:2px;padding:7px 9px;display:flex}.stat-label.svelte-u173d3{color:#78716c;text-transform:uppercase;letter-spacing:.05em;font-size:10px}.stat-value.svelte-u173d3{color:#e8ddd0;font-family:monospace;font-size:15px;font-weight:600}.warnings.svelte-u173d3{flex-direction:column;gap:4px;display:flex}.warning-row.svelte-u173d3{color:#fed7aa;background:#451a03;border:1px solid #78350f;border-radius:5px;padding:6px 10px;font-size:12px}.generate-btn.svelte-u173d3{color:#fde68a;cursor:pointer;background:#78350f;border:1px solid #92400e;border-radius:7px;padding:12px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s}.generate-btn.svelte-u173d3:hover:not(:disabled){background:#92400e}.generate-btn.svelte-u173d3:disabled{opacity:.4;cursor:not-allowed}.json-toggle.svelte-u173d3{align-items:center;gap:10px;display:flex}.link-btn.svelte-u173d3{color:#78716c;cursor:pointer;background:0 0;border:none;padding:0;font-family:monospace;font-size:11px;text-decoration:underline}.link-btn.svelte-u173d3:hover{color:#a89880}.json-output.svelte-u173d3{color:#c4a882;white-space:pre;background:#0f0e0c;border:1px solid #2d2420;border-radius:5px;max-height:300px;margin:0;padding:10px;font-family:monospace;font-size:10px;overflow:auto}.empty.svelte-u173d3{color:#78716c;margin:0;font-size:12px}*{box-sizing:border-box}.input-layer.svelte-5ingws{color:#44332a;background:#f5f0e8;flex-direction:column;min-height:100dvh;font-family:DM Sans,Segoe UI,system-ui,sans-serif;display:flex}.input-layer.embedded.svelte-5ingws{min-height:unset;background:0 0}.app-header.svelte-5ingws{background:#1c1714;border-bottom:1px solid #3d3226;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.logo.svelte-5ingws{color:#fde68a;align-items:center;gap:8px;display:flex}.logo-icon.svelte-5ingws{font-size:20px}.logo-text.svelte-5ingws{letter-spacing:-.02em;font-family:monospace;font-size:16px;font-weight:700}.header-meta.svelte-5ingws{color:#78716c;font-family:monospace;font-size:11px}.mobile-tabs.svelte-5ingws{background:#1c1714;border-bottom:1px solid #3d3226;display:flex}.tab.svelte-5ingws{color:#78716c;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px;font-family:inherit;font-size:13px;transition:all .15s}.tab.active.svelte-5ingws{color:#fde68a;background:#2d2420;border-bottom-color:#92400e}.mobile-panel.svelte-5ingws{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.desktop-layout.svelte-5ingws{flex:1;gap:0;display:flex;overflow:hidden}.canvas-col.svelte-5ingws{flex-direction:column;flex:1;gap:10px;min-width:0;padding:12px;display:flex;overflow:hidden}.sidebar.svelte-5ingws{background:#ede8df;border-left:1px solid #d6cfc4;flex-shrink:0;width:330px}.sidebar-scroll.svelte-5ingws{flex-direction:column;gap:12px;height:100%;padding:12px;display:flex;overflow-y:auto}.runner.svelte-1rzmf9s{flex-direction:column;gap:12px;font-family:monospace;display:flex}.empty.svelte-1rzmf9s{color:#78716c;font-size:13px}.controls.svelte-1rzmf9s{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.run-btn.svelte-1rzmf9s{color:#fde68a;cursor:pointer;background:#78350f;border:1px solid #92400e;border-radius:6px;padding:9px 18px;font-family:monospace;font-size:13px;transition:background .15s}.run-btn.svelte-1rzmf9s:hover:not(:disabled){background:#92400e}.run-btn.svelte-1rzmf9s:disabled{opacity:.5;cursor:not-allowed}.progress-bar.svelte-1rzmf9s{background:#3d3226;border-radius:3px;flex:1;min-width:80px;height:6px;overflow:hidden}.progress-fill.svelte-1rzmf9s{background:#fde68a;border-radius:3px;height:100%;transition:width .2s}.progress-label.svelte-1rzmf9s{color:#a89880;font-size:11px}.error-box.svelte-1rzmf9s{color:#fca5a5;background:#3b1212;border:1px solid #7f1d1d;border-radius:5px;padding:8px 12px;font-size:12px}.result-grid.svelte-1rzmf9s{grid-template-columns:1fr 1fr;gap:6px;display:grid}.metric.svelte-1rzmf9s{background:#2d2420;border-radius:5px;flex-direction:column;gap:2px;padding:7px 9px;display:flex}.label.svelte-1rzmf9s{color:#78716c;text-transform:uppercase;letter-spacing:.05em;font-size:10px}.value.svelte-1rzmf9s{color:#e8ddd0;font-size:15px;font-weight:600}.value.bad.svelte-1rzmf9s{color:#fca5a5}.warnings.svelte-1rzmf9s{flex-direction:column;gap:4px;display:flex}.warning.svelte-1rzmf9s{color:#fed7aa;background:#451a03;border:1px solid #78350f;border-radius:4px;padding:5px 8px;font-size:11px}.renderer.svelte-yig52r{-webkit-user-select:none;user-select:none;background:#1c1714;border-radius:8px;flex-direction:column;font-family:monospace;display:flex;overflow:hidden}.toolbar.svelte-yig52r{background:#12100e;border-bottom:1px solid #2d2420;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 12px;display:flex}.tool-group.svelte-yig52r{align-items:center;gap:3px;display:flex}.tool-label.svelte-yig52r{color:#78716c;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;margin-right:3px;font-size:10px}.tool-divider.svelte-yig52r{background:#2d2420;width:1px;height:20px;margin:0 4px}.pill.svelte-yig52r{color:#78716c;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #3d3226;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-family:monospace;font-size:11px;transition:all .12s;display:flex}.pill.svelte-yig52r:hover{color:#a89880;border-color:#78716c}.pill.active.svelte-yig52r{color:#fde68a;background:#78350f;border-color:#92400e}.pill-badge.svelte-yig52r{color:#fff;background:#ef4444;border-radius:7px;justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 3px;font-size:9px;font-weight:700;line-height:1;display:inline-flex}.metrics-row.svelte-yig52r{background:#2d2420;border-top:1px solid #2d2420;gap:1px;display:flex;overflow-x:auto}.metric-card.svelte-yig52r{background:#1c1714;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:70px;padding:8px 4px;display:flex}.metric-card.warn.svelte-yig52r{background:#3b1a0a}.mc-label.svelte-yig52r{text-transform:uppercase;letter-spacing:.06em;color:#78716c;white-space:nowrap;font-size:9px}.mc-value.svelte-yig52r{color:#e8ddd0;font-size:15px;font-weight:600}.metric-card.warn.svelte-yig52r .mc-value:where(.svelte-yig52r){color:#fca5a5}.legend-row.svelte-yig52r{background:#12100e;border-top:1px solid #2d2420;flex-wrap:wrap;gap:12px;padding:10px 14px;display:flex}.legend-item.svelte-yig52r{align-items:flex-start;gap:7px;display:flex}.legend-swatch.svelte-yig52r{border:1px solid #0003;border-radius:3px;flex-shrink:0;width:14px;height:14px;margin-top:1px}.legend-text.svelte-yig52r{flex-direction:column;gap:1px;display:flex}.legend-label.svelte-yig52r{color:#e8ddd0;font-size:12px}.legend-sub.svelte-yig52r{color:#78716c;font-size:10px}.legend-target.svelte-yig52r{color:#92400e}.warnings.svelte-yig52r{background:#12100e;border-top:1px solid #2d2420;flex-direction:column;gap:3px;padding:8px 12px;display:flex}.warning-row.svelte-yig52r{color:#fed7aa;background:#451a03;border:1px solid #78350f;border-radius:4px;padding:4px 8px;font-size:11px}*,:before,:after{box-sizing:border-box}body{background:#1c1714;margin:0}.app.svelte-1uha8ag{flex-direction:column;min-height:100dvh;font-family:DM Sans,system-ui,sans-serif;display:flex}.step-nav.svelte-1uha8ag{background:#12100e;border-bottom:1px solid #2d2420;align-items:center;padding:10px 20px;display:flex}.step.svelte-1uha8ag{cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:6px 10px;transition:background .12s;display:flex}.step.svelte-1uha8ag:hover:not(.disabled){background:#2d2420}.step.disabled.svelte-1uha8ag{cursor:default;opacity:.4}.step-num.svelte-1uha8ag{color:#78716c;background:#3d3226;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-family:monospace;font-size:11px;font-weight:600;transition:all .15s;display:flex}.step.active.svelte-1uha8ag .step-num:where(.svelte-1uha8ag){color:#fde68a;background:#92400e}.step-label.svelte-1uha8ag{color:#78716c;white-space:nowrap;font-size:13px}.step.active.svelte-1uha8ag .step-label:where(.svelte-1uha8ag){color:#e8ddd0}.step-connector.svelte-1uha8ag{background:#3d3226;flex:1;max-width:60px;height:1px;margin:0 4px;transition:background .3s}.step-connector.done.svelte-1uha8ag{background:#92400e}.result-view.svelte-1uha8ag{background:#1c1714;flex-direction:column;flex:1;gap:16px;padding:16px;display:flex}.result-header.svelte-1uha8ag{flex-wrap:wrap;align-items:baseline;gap:14px;display:flex}.back-btn.svelte-1uha8ag{color:#78716c;cursor:pointer;background:0 0;border:1px solid #3d3226;border-radius:5px;padding:5px 10px;font-family:monospace;font-size:12px;transition:all .12s}.back-btn.svelte-1uha8ag:hover{color:#e8ddd0;border-color:#78716c}.result-title.svelte-1uha8ag{color:#e8ddd0;margin:0;font-size:16px;font-weight:600}.result-sub.svelte-1uha8ag{color:#78716c;font-family:monospace;font-size:12px}.runner-row.svelte-1uha8ag{background:#12100e;border:1px solid #2d2420;border-radius:8px;padding:14px 16px}.renderer-wrap.svelte-1uha8ag{border:1px solid #2d2420;border-radius:8px;overflow:hidden}
