:root{color:#1f2933;background:#f4f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,select{font:inherit}.planner-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.planner-toolbar{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 24px;border-bottom:1px solid #d8d1c3;background:#fffdf8}.planner-toolbar h1,.panel-heading h2{margin:0;font-size:20px;line-height:1.2;font-weight:650}.planner-toolbar small,.panel-heading small{color:#667085}.eyebrow{margin:0 0 4px;color:#667085;font-size:12px;text-transform:uppercase}.toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toolbar-actions button,.filter-grid button,.canvas-tools button,.product-card{border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;min-height:36px;padding:0 12px;cursor:pointer}.share-role-toggle{display:inline-flex;align-items:center;overflow:hidden;border:1px solid #cfc7b8;border-radius:6px;background:#fff}.share-role-toggle button{min-height:34px;border:0;border-radius:0;background:transparent}.share-role-toggle button+button{border-left:1px solid #cfc7b8}.share-role-toggle button.is-active{background:#1f2933;color:#fff}.toolbar-actions button:disabled{opacity:.45;cursor:not-allowed}.toolbar-actions .primary{border-color:#1f2933;background:#1f2933;color:#fff}.planner-body{min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 360px}.canvas-panel{min-width:0;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:#ece7dc}.canvas-tools,.material-controls{display:flex;align-items:center;gap:10px;padding:12px 16px}.canvas-tools{justify-content:flex-end}.catalog-toggle{display:none}.material-controls{border-top:1px solid #d8d1c3;background:#fffdf8}.material-controls label{display:inline-flex;align-items:center;gap:8px;color:#475467}.material-controls select{height:34px;border:1px solid #cfc7b8;border-radius:6px;background:#fff;padding:0 10px}.floorplan-stage{position:relative;min-height:0;margin:24px;overflow:hidden;border:1px solid #cfc7b8;background:linear-gradient(135deg,rgba(255,255,255,.55),transparent 45%),#eef0ec;cursor:grab}.floorplan-stage:has(.placed-furniture){cursor:default}.floorplan-stage.is-panning{cursor:grabbing}.floorplan-viewport{--stage-zoom: 1;--stage-pan-x: 0px;--stage-pan-y: 0px;position:absolute;top:0;right:0;bottom:0;left:0;transform:translate3d(var(--stage-pan-x),var(--stage-pan-y),0) scale(var(--stage-zoom));transform-origin:top left}.geometry-stage{width:100%;height:100%;min-height:560px;display:block}.source-floorplan-preview{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:28px;background:linear-gradient(135deg,rgba(255,255,255,.72),transparent 42%),#eef0ec}.source-floorplan-preview img{max-width:100%;max-height:100%;object-fit:contain;border:1px solid rgba(77,67,54,.22);background:#fff;box-shadow:0 18px 48px #20181029}.source-floorplan-preview span{position:absolute;left:16px;bottom:16px;padding:6px 10px;border:1px solid #d8d1c3;border-radius:6px;background:#fffdf8eb;color:#475467;font-size:12px}.floor{position:absolute;left:23%;top:24%;width:54%;height:46%;transform:skewY(-12deg) rotate(-1deg);border:1px solid rgba(77,67,54,.25)}.floor-wood{background:repeating-linear-gradient(90deg,rgba(82,58,31,.12) 0 2px,transparent 2px 42px),linear-gradient(135deg,#b69a72,#d3bf98)}.room-label{position:absolute;top:16px;left:16px;color:#1f2933a6;font-size:13px}.wall{position:absolute;background:#f4f1ea;border:1px solid rgba(77,67,54,.3)}.wall-top{left:23%;top:19%;width:54%;height:28px}.wall-side{left:21%;top:23%;width:28px;height:48%;background:#d7d0c2}.contact-shadow{position:absolute;left:48%;top:58%;width:160px;height:28px;transform:translate(-50%,-50%) rotate(-5deg);border-radius:999px;background:#00000029;filter:blur(10px)}.furniture-card{position:absolute;left:48%;top:48%;width:150px;height:74px;display:grid;place-items:center;transform:translate(-50%,-50%);border:1px solid rgba(66,48,34,.35);border-radius:8px;background:linear-gradient(135deg,#8b735b,#c1a98c);color:#fff;box-shadow:0 2px 3px #00000014}.placed-furniture-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.placed-furniture{--flip-x: 1;--flip-y: 1;position:absolute;width:132px;height:82px;display:grid;place-items:center;transform:translate(-50%,-50%);pointer-events:auto;cursor:grab;-webkit-user-select:none;user-select:none}.placed-furniture:active{cursor:grabbing}.placed-furniture:before{content:"";position:absolute;left:12%;right:12%;bottom:4px;height:18px;border-radius:999px;background:#18141033;filter:blur(10px);transform:skew(-12deg)}.placed-furniture img,.placed-furniture>span{position:relative;z-index:1;width:100%;height:100%;display:grid;place-items:center;border-radius:6px;object-fit:contain;transform:scaleX(var(--flip-x)) scaleY(var(--flip-y))}.placed-furniture>span{border:1px solid rgba(66,48,34,.35);background:#b69a72;color:#fff;font-size:13px;text-align:center;padding:8px}.placed-furniture.is-vertical{width:82px;height:132px}.placed-furniture.is-selected{outline:2px solid #1f2933;outline-offset:3px}.placed-furniture-controls{position:absolute;z-index:2;left:50%;top:-34px;display:inline-flex;gap:4px;transform:translate(-50%);padding:3px;border:1px solid #cfc7b8;border-radius:6px;background:#fffdf8;box-shadow:0 6px 16px #2018101f}.placed-furniture-controls button{min-width:28px;height:24px;border:1px solid #cfc7b8;border-radius:4px;background:#fff;color:#1f2933;font-size:11px;padding:0 6px;cursor:pointer}.product-panel{min-width:0;min-height:0;display:flex;flex-direction:column;gap:16px;padding:18px;border-left:1px solid #d8d1c3;background:#fffdf8}.recent-project-list{display:grid;gap:6px}.recent-project-list>span{color:#475467;font-size:12px}.recent-project-list button{min-height:34px;overflow:hidden;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;padding:0 10px;text-align:left;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.recent-project-list button.is-active{border-color:#1f2933;background:#f3eee4}.filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.filter-grid label{display:grid;gap:5px;color:#475467;font-size:12px}.filter-grid select{width:100%;min-width:0;height:36px;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;padding:0 9px}.filter-grid button:disabled{opacity:.45;cursor:not-allowed}.product-search{display:grid;gap:6px;color:#475467;font-size:13px}.product-search input{width:100%;height:38px;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;padding:0 10px;font:inherit}.product-list{display:grid;gap:10px;overflow:auto}.product-card{height:auto;min-height:68px;display:grid;justify-items:start;gap:4px;padding:12px;text-align:left}.product-card small{color:#667085}.catalog-card{grid-template-columns:56px minmax(0,1fr);align-items:center;column-gap:12px}.catalog-card img,.product-thumb-fallback{grid-row:span 2;width:56px;height:56px;display:block;border-radius:6px;border:1px solid #ded6c7;background:#eee7dc;object-fit:cover}.catalog-card span,.catalog-card small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-card{border-color:#9f8f75;background:#faf4e8}.product-load-more{min-height:38px;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;cursor:pointer}.product-empty{min-height:72px;display:grid;place-items:center;border:1px dashed #cfc7b8;border-radius:6px;color:#667085;background:#fbf7ef;font-size:13px}.planner-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:20px;background:#1f29335c}.planner-modal{width:min(560px,100%);max-height:min(720px,calc(100vh - 40px));display:grid;gap:12px;overflow:auto;border:1px solid #cfc7b8;border-radius:8px;background:#fffdf8;padding:18px;box-shadow:0 20px 50px #1f29333d}.planner-modal-heading,.planner-modal-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.planner-modal-heading h2{margin:0;font-size:20px}.planner-modal-heading button{width:32px;height:32px;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;cursor:pointer}.planner-modal label{display:grid;gap:6px;color:#475467;font-size:13px}.planner-modal input,.planner-modal textarea{width:100%;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;font:inherit;padding:9px 10px}.planner-modal textarea{min-height:110px;resize:vertical}.planner-modal-actions{justify-content:flex-end}.planner-modal-actions button{min-height:36px;border:1px solid #cfc7b8;border-radius:6px;background:#fff;color:#1f2933;padding:0 14px;cursor:pointer}.planner-modal-actions .primary{border-color:#1f2933;background:#1f2933;color:#fff}@media (max-width: 860px){.planner-toolbar{align-items:flex-start;flex-direction:column}.planner-body{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto}.product-panel{max-height:42vh;border-left:0;border-top:1px solid #d8d1c3;border-radius:14px 14px 0 0;transition:max-height .18s ease,padding .18s ease}.product-panel.is-collapsed{max-height:0;overflow:hidden;padding-top:0;padding-bottom:0;border-top:0}.catalog-toggle{display:inline-flex}.floorplan-stage{min-height:58vh;margin:12px}}
