:root{--xs:4px;--sm:8px;--md:16px;--lg:24px;--xl:32px;--bg:#ffffff;--panel:#f1f5f9;--field:#ffffff;--border:#cbd5e1;--accent:#f59e0b;--destructive:#dc2626;--ink:#0f172a;--ink-quiet:#64748b;--font-ui:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--font-mono:ui-monospace,"SF Mono","Cascadia Code",Consolas,monospace;--row-min:32px;--radius-sm:4px;--radius:6px;--radius-lg:8px;--radius-card:10px;--sheet:#ffffff;--sheet-head:#f1f5f9;--sheet-border:#e2e8f0;--sheet-title:#64748b;--workspace-hover:#e2e8f0;--row-tint:rgba(15,23,42,0.02);--accent-tint:rgba(245,158,11,0.1);--destructive-soft:rgba(220,38,38,0.4);--destructive-tint:rgba(220,38,38,0.08);--scrim:rgba(15,23,42,0.4);--shadow-panel:0 1px 3px rgba(0,0,0,0.1);--shadow-card:0 4px 16px rgba(0,0,0,0.12)}*{box-sizing:border-box}body,html{margin:0;height:100%}body{font-family:var(--font-ui);font-size:14px;line-height:1.5;color:var(--ink);background:var(--bg)}#app{display:grid;grid-template-columns:clamp(360px,28vw,480px) 1fr;grid-gap:var(--md);gap:var(--md);height:100vh;padding:var(--lg)}#app>*,#editor{min-height:0}#editor{background:var(--panel);padding:var(--md);display:flex;flex-direction:column;gap:var(--md);overflow-y:auto;overflow-x:hidden;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-panel)}.editor-head{gap:var(--sm)}.editor-head,.head-actions{display:flex;align-items:center}.head-actions{margin-left:auto;gap:var(--xs)}.panel-section{display:flex;flex-direction:column;gap:var(--sm)}.panel-section-label{margin:0;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-quiet)}#help-toggle{margin-left:auto;font-family:var(--font-ui);font-size:14px;line-height:1;min-width:var(--row-min);min-height:var(--row-min);padding:var(--sm);background:var(--field);color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}#help-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#add-layer{font-family:var(--font-ui);font-size:14px;min-height:var(--row-min);padding:var(--sm) var(--md);background:var(--field);color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}#add-layer:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#layer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--xs);flex:0 0 auto}.layer-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sm);row-gap:var(--xs);min-height:var(--row-min);padding:var(--xs) var(--sm);background:var(--row-tint);border:1px solid var(--border);border-radius:var(--radius)}.layer-row.active{border-color:var(--accent);background:var(--accent-tint);box-shadow:inset 0 0 0 1px var(--accent)}.layer-row.dragging{opacity:.5}.layer-row[draggable=true]{cursor:-webkit-grab;cursor:grab}.layer-wood{font-family:var(--font-mono);font-weight:600;color:var(--ink);min-width:1ch;text-align:center}.row-btn{flex:none;font-family:var(--font-ui);font-size:14px;line-height:1;min-width:var(--row-min);min-height:var(--row-min);padding:0 var(--sm);background:var(--field);color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.row-btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.row-remove{color:var(--destructive);border-color:var(--destructive-soft)}.row-btn.row-remove:hover{background:var(--destructive-tint);border-color:var(--destructive)}.layer-index{min-width:2ch;text-align:right}.layer-index,.layer-joint{flex:none}.layer-index,.layer-joint,.layer-thickness{font-family:var(--font-mono);font-weight:600}.layer-thickness{flex:1 1 8ch;min-width:0;font-size:14px;text-align:right;min-height:var(--row-min);padding:var(--xs) var(--sm);border:1px solid var(--border);border-radius:var(--radius);background:var(--field);color:var(--ink);transition:border-color .15s ease,background-color .15s ease}.layer-thickness:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.body-width-field{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--sm)}.body-width-label{font-size:13px;color:var(--ink-quiet)}#body-width{flex:none;width:12ch;font-family:var(--font-mono);font-weight:600;font-size:14px;text-align:right;min-height:var(--row-min);padding:var(--xs) var(--sm);border:1px solid var(--border);border-radius:var(--radius);background:var(--field);color:var(--ink);transition:border-color .15s ease,background-color .15s ease}#body-width:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.layer-meta{flex-basis:100%;display:flex;align-items:center;gap:var(--sm);padding-left:calc(2ch + var(--sm));color:var(--ink-quiet);font-size:12px}.layer-meta:empty{display:none}.layer-seam-pct{flex:none;width:9ch;font-family:var(--font-mono);font-weight:600;font-size:14px;text-align:right;min-height:var(--row-min);padding:var(--xs) var(--sm);border:1px solid var(--border);border-radius:var(--radius);background:var(--field);color:var(--ink);transition:border-color .15s ease,background-color .15s ease}.layer-seam-pct:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}#cap-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--xs)}.cap-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sm);row-gap:var(--xs);min-height:var(--row-min);padding:var(--xs) var(--sm);background:var(--row-tint);border:1px solid var(--border);border-radius:var(--radius)}.cap-row.active{border-color:var(--accent);background:var(--accent-tint);box-shadow:inset 0 0 0 1px var(--accent)}.cap-side{flex:none;min-width:5ch}.cap-height,.cap-side,.cap-width{font-family:var(--font-mono);font-weight:600}.cap-height,.cap-width{flex:1 1 7ch;min-width:0;font-size:14px;text-align:right;min-height:var(--row-min);padding:var(--xs) var(--sm);border:1px solid var(--border);border-radius:var(--radius);background:var(--field);color:var(--ink);transition:border-color .15s ease,background-color .15s ease}.cap-height:focus-visible,.cap-width:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.empty-state{color:var(--ink)}.empty-heading{font-weight:600;margin:0 0 var(--xs) 0}.empty-body{margin:0;color:var(--ink-quiet)}.template-save{gap:var(--sm)}.template-field,.template-save{display:flex;flex-direction:column}.template-field{gap:var(--xs)}.template-label{font-size:13px;color:var(--ink-quiet)}#template-name,#template-tags{text-align:left;font-family:var(--font-ui);font-weight:400}#export-json,#export-svg,#save-template,.action-btn{font-family:var(--font-ui);font-size:14px;min-height:var(--row-min);padding:var(--sm) var(--md);background:var(--field);color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-self:flex-start;transition:border-color .15s ease,background-color .15s ease}#export-json:focus-visible,#export-svg:focus-visible,#save-template:focus-visible,.action-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#add-layer:hover,#export-json:hover,#export-svg:hover,#help-toggle:hover,#save-template:hover,.action-btn:not(:disabled):hover,.row-btn:not(.row-remove):hover{background:var(--workspace-hover)}#action-bar{display:flex;flex-direction:column;gap:var(--sm)}.action-group{display:flex;align-items:center;flex-wrap:wrap;gap:var(--xs)}.action-group-label{flex:none;width:5.5em;font-size:12px;color:var(--ink-quiet)}.action-btn{padding:var(--xs) var(--sm)}.action-group .action-btn{align-self:center}.action-btn:disabled{opacity:.3;cursor:not-allowed}.template-export{flex-direction:row;flex-wrap:wrap;gap:var(--sm)}.template-heading{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-quiet);margin:var(--md) 0 var(--xs) 0}#template-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--xs);flex:0 0 auto}.template-row{display:flex;align-items:baseline;gap:var(--sm);min-height:var(--row-min);padding:var(--xs) var(--sm);border:1px solid var(--border);border-radius:var(--radius);background:var(--field)}.template-row-label{font-weight:600}.notice,.template-row-tags{font-size:14px;color:var(--ink-quiet)}.notice{margin:0}#help-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--scrim);padding:var(--md)}#help-overlay[hidden]{display:none}.help-dialog{flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--md);max-width:520px;width:100%;max-height:80vh;overflow:auto}.help-dialog,.help-head{display:flex;gap:var(--sm)}.help-head{align-items:center}.help-title{margin:0;font-size:14px;font-weight:600}#help-close{margin-left:auto;font-family:var(--font-ui);font-size:14px;line-height:1;min-width:var(--row-min);min-height:var(--row-min);padding:var(--sm);background:var(--field);color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}#help-close:hover{background:var(--workspace-hover)}#help-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.help-section{display:flex;flex-direction:column;gap:var(--xs)}.help-section h3{margin:0;font-size:14px;font-weight:600}.help-section dl{margin:0;display:grid;grid-template-columns:max-content 1fr;grid-gap:var(--xs) var(--sm);gap:var(--xs) var(--sm);font-size:14px}.help-section dt{font-family:var(--font-mono);font-weight:600;color:var(--accent)}.help-section dd{margin:0}.help-hint{margin:0;font-size:14px;color:var(--ink-quiet)}#preview{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:var(--bg);gap:var(--xl);overflow:auto;padding-top:var(--sm)}#preview>*{flex-shrink:0}.blueprint-card{background:var(--sheet);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);overflow:hidden;display:flex;flex-direction:column;width:100%;max-width:760px}.blueprint-header{background:var(--sheet-head);padding:var(--sm) var(--md);border-bottom:1px solid var(--sheet-border);display:flex;align-items:center;justify-content:space-between}.blueprint-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--sheet-title)}#svg-host{padding:var(--xl);background:var(--sheet)}#svg-host svg{display:block;width:100%;height:auto;max-width:100%}#price-panel{width:100%;max-width:760px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}#price-table{width:100%;border-collapse:collapse;font-family:var(--font-mono)}#price-table th{font-family:var(--font-ui);font-weight:600;font-size:11px;letter-spacing:.03em;text-transform:uppercase;text-align:center;padding:var(--sm) 2px;border-bottom:1px solid var(--border);color:var(--ink-quiet);white-space:nowrap}#price-table th span{display:block;font-weight:400;font-size:10px;text-transform:none;color:var(--ink-quiet);opacity:.7}#price-table td{padding:2px;vertical-align:middle}.price-in{width:100%;box-sizing:border-box;min-width:5ch;font-family:var(--font-mono);font-weight:600;font-size:13px;text-align:right;min-height:var(--row-min);padding:var(--xs) var(--sm);border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--ink);transition:border-color .15s ease,background-color .15s ease}.price-in:focus{background:var(--field);border-color:var(--accent)}.price-in:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.price-out{display:block;font-weight:600;font-size:13px;text-align:right;padding:var(--xs) var(--sm);color:var(--ink)}.price-auto{color:var(--ink-quiet)}.price-suma{font-size:15px;color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent-tint)}.doc-tools{width:100%;max-width:760px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:var(--lg);gap:var(--lg);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--md)}.doc-tools-save,.doc-tools-templates{display:flex;flex-direction:column;gap:var(--sm);min-width:0}.doc-tools-templates .template-heading{margin-top:0}@media (max-width:899px){#app{display:flex;flex-direction:column;height:auto;gap:var(--md);padding:var(--md)}#preview{order:-1}#editor,#preview{overflow:visible}#svg-host{padding:var(--md)}.doc-tools{grid-template-columns:1fr}#price-table thead{display:none}#price-table tr{display:flex;flex-direction:column}#price-table td{display:flex;justify-content:space-between;align-items:center;gap:var(--sm);padding:var(--sm) var(--md);border-bottom:1px solid var(--border)}#price-table td:last-child{border-bottom:none}#price-table td:before{content:attr(data-label);font-family:var(--font-ui);font-size:13px;font-weight:400;text-transform:none;color:var(--ink-quiet)}.price-in,.price-out{width:auto;min-width:80px;flex:none}}