:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1f2933;background:#f4f1ea;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0}button,input,select{letter-spacing:0}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr);background:#f4f1ea}.sidebar{background:#20262b;color:#f8fafc;padding:22px;display:flex;flex-direction:column;gap:24px}.brand{display:flex;gap:12px;align-items:center}.brand strong,.brand span{display:block}.brand span,.sidebar-stats span{color:#aeb8c2;font-size:13px}.sidebar nav{display:grid;gap:7px}.sidebar button,.layer-toolbar button,.wall-tabs button,.report-actions button,.segmented button,.icon-button,.danger-button,.opening-chip{border:1px solid transparent;border-radius:7px;min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font:inherit}.sidebar nav button{color:#dbe3ec;background:transparent;justify-content:flex-start;padding:10px 12px}.sidebar nav button.active,.sidebar nav button:hover{background:#33414b;color:#fff}.sidebar-stats{margin-top:auto;display:grid;grid-template-columns:1fr 1fr;gap:10px}.sidebar-stats div{background:#2b343c;border-radius:8px;padding:12px}.sidebar-stats strong{display:block;font-size:24px}.workspace{min-width:0;padding:24px}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:flex-end;margin-bottom:18px}.topbar h1{margin:4px 0 0;font-size:30px}.eyebrow{color:#7b5f33;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase;margin:0}.topbar-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.topbar-meta span{background:#fff;border:1px solid #d7d1c6;border-radius:999px;padding:7px 11px;color:#48525c;font-size:13px}.file-actions{display:flex;gap:8px;flex-wrap:wrap}.file-actions input{display:none}.file-actions button{min-height:36px;border:1px solid #cfd6dc;background:#fff;color:#25313b;border-radius:7px;padding:7px 11px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;font:inherit;font-size:13px}.split,.editor-layout{display:grid;grid-template-columns:minmax(360px,460px) minmax(0,1fr);gap:18px;align-items:start}.panel,.viewer-shell{background:#fff;border:1px solid #ddd6c9;border-radius:8px;padding:18px;box-shadow:0 14px 34px #2d231614}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-header.compact-header{align-items:center;margin-bottom:8px}.panel h2{margin:4px 0 0;font-size:21px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field,.section-field{display:grid;gap:6px;color:#47515c;font-size:13px}.wide-field{grid-column:1 / -1}input,select{width:100%;min-height:38px;border:1px solid #c9d1d8;border-radius:6px;padding:7px 9px;box-sizing:border-box;font:inherit;background:#fbfcfd}.section-grid{display:grid;gap:12px;margin:14px 0}.form-section{margin-top:16px;display:grid;gap:10px}.section-field div{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:7px}.segmented,.wall-tabs,.layer-toolbar,.button-row,.report-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}.segmented{margin:14px 0}.segmented button,.wall-tabs button,.layer-toolbar button,.report-actions button,.icon-button{background:#eef2f4;color:#26313a;padding:8px 12px}.layer-toolbar button{flex:0 0 auto;height:34px;min-height:34px;padding:6px 10px}.layer-toolbar .export-button{background:#fff;border-color:#cfd6dc;color:#25313b}.segmented button.active,.wall-tabs button.active,.layer-toolbar button.active,.icon-button.active-inline{background:#26313a;color:#fff}.viewer-shell{display:grid;grid-template-rows:auto minmax(0,1fr) auto auto;gap:8px;padding:12px;min-height:620px;height:calc(100vh - 124px);position:sticky;top:16px}.viewer-canvas{height:100%;min-height:0;border-radius:8px;overflow:hidden;background:linear-gradient(#f7fbff,#edf1f4);border:1px solid #d6dee5}.viewer-note{display:flex;gap:8px;align-items:center;margin:0;color:#66717b;font-size:13px}.opening-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.opening-chip{background:#f3f5f6;color:#26313a;padding:8px 10px;flex-direction:column;align-items:flex-start;gap:1px}.opening-chip span{font-size:12px;color:#69737c}.opening-chip.active{background:#dbeafe;border-color:#75a9e8}.danger-button{background:#fff1f1;color:#a33131;border-color:#efb9b9}.preview-panel{min-width:0}.wall-svg,.elevation-svg,.plan-svg{width:100%;height:auto;max-height:70vh;border:1px solid #d8dee4;border-radius:8px;background:#fbfcfd;touch-action:none}.plan-building{fill:#fbf7ef;stroke:#58636f;stroke-width:10}.partition-line{stroke:#8f6139;stroke-width:34;stroke-linecap:round;cursor:grab;opacity:.85}.partition-line.active{stroke:#2f6f95}.partition-door-dot{fill:#53aed7;stroke:#1d7599;stroke-width:8}.plan-label{font-size:82px;font-weight:700;fill:#27313a;text-anchor:middle;dominant-baseline:middle;pointer-events:none}.partition-door-card{background:#f5f7f8;border:1px solid #dce3e8;border-radius:8px;padding:12px;margin-bottom:10px}.wall-bg{fill:#fbf7ef;stroke:#58636f;stroke-width:8}.stud-line{stroke:#a97847;stroke-width:12;opacity:.55}.plate-line{stroke:#8f6139;stroke-width:12}.opening-rect{fill:#53aed761;stroke:#1d7599;stroke-width:8;cursor:grab}.opening-rect.active{fill:#52a65a59;stroke:#27632e}.opening-label,.dimension-text{font-size:90px;fill:#27313a;text-anchor:middle;dominant-baseline:middle;pointer-events:none}.dimension-text{font-size:72px;text-anchor:start}.dimension-text.title{font-size:88px;font-weight:700}.dimension-text.vertical{writing-mode:tb}.frame-rect{fill:#b7834a;stroke:#78522d;stroke-width:4}.frame-rect.header,.frame-rect.sill{fill:#966134}.frame-rect.brace{fill:#7f552f}.dimension-line{stroke:#25313b;stroke-width:5}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{border-bottom:1px solid #e0e5e8;padding:10px;text-align:left;white-space:nowrap}th{color:#56616b;background:#f5f7f8;font-weight:700}.consumables,.report-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}.consumables div,.report-grid div{background:#f5f7f8;border-radius:8px;padding:13px}.consumables strong,.report-grid strong{display:block;font-size:22px}.consumables span,.report-grid span{color:#66717b;font-size:13px}.warning-list{display:grid;gap:7px;margin-top:14px}.warning-list p{margin:0;padding:9px 10px;background:#fff7e6;border:1px solid #f0d49a;border-radius:7px;color:#7a4f12;font-size:13px}.warning-list.compact{margin-top:0}.report-shell{display:grid;gap:12px}.report-actions{justify-content:flex-end}.report-page{background:#fff;border:1px solid #ddd6c9;border-radius:8px;padding:34px}.report-title{border-bottom:2px solid #26313a;padding-bottom:22px;margin-bottom:22px}.report-title h1{margin:6px 0;font-size:34px}.report-section{margin:24px 0}.report-section h2{font-size:20px}.report-elevations{display:grid;grid-template-columns:1fr 1fr;gap:14px}.report-elevations .elevation-svg{max-height:none}.report-warning{margin-top:22px;padding:14px;background:#fff7e6;border:1px solid #edcc8a;border-radius:8px;color:#68420d}@media (max-width: 980px){.app-shell,.split,.editor-layout{grid-template-columns:1fr}.sidebar{position:static}.sidebar nav{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar,.panel-header{align-items:flex-start;flex-direction:column}.form-grid,.consumables,.report-grid,.report-elevations{grid-template-columns:1fr}.viewer-shell{position:static;height:auto;min-height:520px}.viewer-canvas{min-height:420px}}@media print{.sidebar,.topbar,.report-actions{display:none}.app-shell{display:block;background:#fff}.workspace,.report-page{padding:0;border:0;box-shadow:none}}
