@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:#15181b;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--topbar-height: 66px;--ink: #15181b;--muted: #69717c;--line: #e5e7eb;--panel: #fbfcfd;--panel-strong: #ffffff;--stone: #d1d5db;--accent: #0f8b8d;--accent-strong: #0b6f71;--amber: #b87333;--danger: #9f2d2d;--shadow: 0 8px 18px rgba(15, 23, 42, .07)}*{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;height:100%;margin:0}body{overflow:hidden;font-size:12px}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}.app-shell{height:100%;min-height:100%;background:#f7f8fa}.topbar{position:fixed;inset:0 0 auto;z-index:20;height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 16px;background:#fff;border-bottom:1px solid var(--line);color:var(--ink)}.brand-lockup{display:flex;align-items:center;min-width:220px;gap:12px}.brand-logo{width:42px;height:42px;object-fit:contain;border-radius:5px}.brand-lockup strong,.brand-lockup span{display:block}.brand-lockup strong{font-size:14px;font-weight:600}.brand-lockup span{margin-top:2px;color:#68707a;font-size:12px}.topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}.button{display:inline-flex;align-items:center;justify-content:center;min-height:36px;gap:8px;padding:8px 12px;border:0;border-radius:5px;font-weight:600;font-size:12px;white-space:nowrap;transition:transform .16s ease,border-color .16s ease,background .16s ease}.button:active{transform:translateY(1px)}.button-icon{display:inline-flex;align-items:center}.button-primary{background:#111315;color:#fff;box-shadow:0 8px 18px #11131529}.button-primary:hover{background:#000}.button-secondary{background:#fff;color:#111315;box-shadow:0 6px 16px #0f172a1a}.button-secondary:hover{background:#f8fafc}.topbar .button-secondary{background:#fff;color:#111315;font-weight:400;box-shadow:0 6px 16px #0f172a1a}.topbar .button-secondary:hover{background:#f8fafc}.topbar .button-primary{background:#111315;color:#fff;font-weight:600;box-shadow:0 8px 18px #11131526}.topbar .button-primary:hover{background:#000}.button-ghost{background:transparent;color:inherit}.button-danger{background:#9f2d2d;color:#fff;border-color:#b94a48}.control-section .button{width:100%}.control-section .button-secondary{background:#fff;color:#111315;box-shadow:0 6px 16px #0f172a1a}.control-section .button-secondary:hover{background:#0f8b8d14;border-color:#0f8b8d57}.main-grid{display:grid;grid-template-columns:minmax(248px,292px) minmax(560px,1fr) minmax(260px,300px);gap:12px;height:100%;padding:calc(var(--topbar-height) + 12px) 12px 12px}.sidebar{min-width:0;max-width:100%;overflow-x:hidden;overflow-y:auto;padding-right:2px;scrollbar-color:#cbd5e1 transparent;scrollbar-width:thin}.info-card,.control-section,.workspace-card{border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 4px 12px #0f172a0b}.info-card{padding:12px;margin-bottom:12px}.info-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.info-card h2,.control-section h2{margin:0;color:#667085;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.details-list{display:grid;gap:7px;margin:0}.details-list div{display:grid;grid-template-columns:minmax(84px,.8fr) minmax(0,1.2fr);gap:8px}.details-list dt{color:var(--muted);font-size:12px}.details-list dd{min-width:0;margin:0;color:var(--ink);font-size:12px;font-weight:500;overflow-wrap:anywhere}.material-card,.texture-summary,.compact-row{display:flex;align-items:center;min-width:0;gap:10px}.material-dot{flex:0 0 auto;width:36px;height:36px;border:1px solid rgba(0,0,0,.12);border-radius:8px;box-shadow:inset 0 0 0 2px #ffffff59}.material-card strong,.material-card small{display:block;overflow-wrap:anywhere}.material-card strong{font-size:12px;font-weight:500}.material-card small,.compact-row small,.muted{color:var(--muted);font-size:12px}.muted{display:inline-flex;align-items:center;gap:6px}.compact-list{display:grid;gap:6px}.compact-row{min-height:24px;color:#333942}.compact-row span{min-width:0;flex:1;overflow-wrap:anywhere;font-weight:500;font-size:12px}.project-item-list{display:grid;gap:10px}.project-item-group{display:grid;gap:5px}.project-item-group>strong{color:#667085;font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.project-item-empty{color:#98a2b3;font-size:11px}.project-item-row{display:flex;align-items:center;width:100%;min-height:30px;gap:4px;padding:3px;border:1px solid transparent;border-radius:6px;background:transparent;color:#313840}.project-item-select{display:flex;align-items:center;min-width:0;flex:1;gap:8px;padding:5px 6px;border:0;background:transparent;color:inherit;text-align:left}.project-item-icon{display:inline-grid;width:16px;min-width:16px;place-items:center;line-height:1;color:#475467}.project-item-row:hover,.project-item-row.selected{border-color:#0f8b8d57;background:#0f8b8d17}.project-item-delete{display:grid;flex:0 0 auto;width:26px;height:26px;place-items:center;border:0;border-radius:5px;background:transparent;color:#667085}.project-item-delete:hover{background:transparent;color:var(--danger)}.project-item-list span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace{display:grid;min-width:0;min-height:0;grid-template-rows:minmax(225px,.4fr) minmax(390px,1fr);gap:12px}.workspace-card{min-width:0;min-height:0;overflow:hidden}.workspace-header{display:flex;align-items:center;justify-content:space-between;gap:12px;height:34px;padding:5px 12px;border-bottom:1px solid var(--line);background:#fff}.workspace-header>div{display:flex;align-items:center;min-width:0;gap:8px}.workspace-header span,.workspace-header small{display:inline;color:var(--muted);font-size:12px}.workspace-header strong{display:inline;color:var(--ink);font-size:12px;font-weight:600;white-space:nowrap}.canvas-2d-card{display:grid;grid-template-rows:auto 1fr}.canvas-2d{width:100%;height:100%;min-height:0;background:#fff;touch-action:none}.slab-2d{fill:#f8fafc;stroke:#1f2937;stroke-width:1.5}.shape{cursor:grab}.shape:active{cursor:grabbing}.shape text{fill:#171b20;font-size:6px;font-weight:500;pointer-events:none}.shape.selected .cutout-shape,.shape.selected .accessory-shape,.shape.selected .component-shape,.shape.selected .finish-shape{stroke:#111315;stroke-width:1.8}.cutout-shape{fill:#0f172a24;stroke:#0f172adb;stroke-width:1.2}.finish-shape{fill:#3b82f61a;stroke:#2563ebb8;stroke-dasharray:4 4;stroke-width:1.15}.accessory-shape{fill:#14b8a624;stroke:#0d9488c7;stroke-width:1.1}.accessory-shape.cooktop{fill:#0c0e12ad;stroke:#1f2937db}.accessory-shape.torneira_bancada,.accessory-shape.torneira_gourmet{fill:#cbd5e1a3;stroke:#64748bc7}.accessory-shape.cuba_pedra{fill:#d9d2c33d;stroke:#78716cd1}.accessory-shape.cuba_porcelana,.accessory-shape.cuba_sobrepor{fill:#f8fafcb8;stroke:#94a3b8db}.accessory-shape.tomada_embutida,.accessory-shape.lixeira_embutida{fill:#e2e8f08a;stroke:#64748bc2}.component-shape{fill:#64748b29;stroke:#334155cc;stroke-width:1.4}.component-frontao{fill:#aeeee857;stroke:#0f8b8de6}.component-borda{fill:#ede5ff8c;stroke:#7c3aede6}.component-saia{fill:#dcfce78c;stroke:#16a34adb}.component-fechamento{fill:#ffedd59e;stroke:#ea580ce6}.component-filete{fill:#fee2e29e;stroke:#dc2626e6}.component-rodabase{fill:#e2e8f08f;stroke:#475569db}.measure-layer line{stroke:#111315;stroke-width:.85;stroke-dasharray:4 3}.measure-layer text,.axis-labels text{fill:#111827;font-size:6px;font-weight:600}.measure-layer circle{fill:#111315}.resize-handle-layer{pointer-events:none}.resize-handle{cursor:nwse-resize;pointer-events:auto}.resize-handle path{fill:none;stroke:#11182794;stroke-linecap:round;stroke-linejoin:round;stroke-width:1}.resize-handle circle{fill:#fff;stroke:#111827b8;stroke-width:.9}.scene-card{display:grid;grid-template-rows:auto 1fr}.scene-canvas{position:relative;min-height:0}.scene-canvas canvas{display:block}.right-sidebar{display:grid;align-content:start;gap:12px;min-width:0;padding-right:4px}.left-sidebar{padding-right:4px}.panel-tabs{position:sticky;top:0;z-index:4;display:grid;grid-template-columns:repeat(5,1fr);gap:6px;padding:8px;border:1px solid var(--line);border-radius:8px;background:#fffffff0;backdrop-filter:blur(10px)}.panel-tabs button{display:grid;height:34px;place-items:center;border:1px solid transparent;border-radius:8px;background:transparent;color:#505862}.panel-tabs button:hover,.panel-tabs button.active{border-color:#0f8b8d3d;background:#0f8b8d1c;color:#0b6f71}.control-section{min-width:0;padding:12px}.control-section h2{margin-bottom:12px}.field{display:grid;gap:6px;margin:0 0 12px}.field span{color:#667085;font-size:11px;font-weight:600}.field input,.field select{width:100%;min-height:34px;border:1px solid #d9dee7;border-radius:5px;background:#fff;color:var(--ink);padding:7px 10px;font-size:12px}.field input[type=color]{padding:3px}.field input[type=range]{accent-color:var(--accent)}.file-field{position:relative;display:flex;align-items:center;min-height:34px;gap:10px;padding:8px 10px;border:1px dashed #cbd5e1;border-radius:5px;background:#fff;color:#535c67}.file-field input{min-height:0;padding:0;border:0}.swatch-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.texture-group{display:grid;gap:8px;margin-bottom:10px}.texture-group-toggle{display:flex;align-items:center;justify-content:space-between;min-height:32px;width:100%;padding:7px 8px;border:1px solid var(--line);border-radius:5px;background:#fff;color:#111827;font-size:12px;font-weight:600}.swatch{position:relative;height:36px;padding:3px;border:1px solid #d9dee7;border-radius:5px;background:#fff;overflow:visible}.swatch span{display:block;width:100%;height:100%;border-radius:4px}.swatch.selected{border-color:#111315;box-shadow:0 0 0 2px #1113151f}.swatch:hover:after{position:absolute;left:50%;bottom:calc(100% + 6px);z-index:10;max-width:120px;padding:4px 6px;border-radius:5px;background:#111315;color:#fff;content:attr(data-label);font-size:11px;line-height:1.1;white-space:nowrap;box-shadow:0 8px 18px #0f172a2e;transform:translate(-50%)}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;margin-bottom:12px;border-radius:8px;background:#f1f5f9}.segmented button{min-height:32px;border:0;border-radius:6px;background:transparent;color:#535c67;font-weight:600}.segmented button.active{background:#fff;color:var(--accent-strong);box-shadow:0 4px 12px #1f1a1414}.add-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.compact-add-grid{grid-template-columns:1fr}.add-grid button{display:flex;align-items:center;justify-content:flex-start;min-height:34px;gap:8px;padding:8px;border:0;border-radius:5px;background:#fff;color:#2f363e;box-shadow:0 3px 8px #0f172a12;font-size:12px;font-weight:600;text-align:left}.add-grid button span{overflow-wrap:anywhere}.add-grid button:hover{background:#f8fafc}.divider{height:1px;margin:14px 0;background:var(--line)}.toggle-list{display:grid;gap:8px}.compact-toggle-list{margin-bottom:12px}.toggle-row{display:flex;align-items:center;justify-content:space-between;min-height:34px;gap:12px;width:100%;padding:8px 0;border:0;background:transparent;color:var(--ink);font-size:12px;font-weight:400}.switch{position:relative;flex:0 0 auto;width:38px;height:22px;border-radius:999px;background:#cbd5e1;transition:background .16s ease}.switch span{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:999px;background:#fff;box-shadow:0 2px 5px #0000002e;transition:transform .16s ease}.switch.active{background:#111315}.switch.active span{transform:translate(16px)}.selected-editor{display:grid;gap:0;padding-top:12px;border-top:1px solid var(--line)}.selected-card{display:grid;gap:3px;padding-bottom:8px;border-bottom:1px solid var(--line)}.selected-card strong{font-size:12px;font-weight:600}.selected-card small{color:var(--muted);font-size:12px}.inline-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}.right-content-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:4px;border:1px solid var(--line);border-radius:5px;background:#fff}.settings-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:4px;margin-bottom:12px;border:1px solid var(--line);border-radius:5px;background:#fff}.settings-tabs button{min-height:34px;border:0;border-radius:5px;background:transparent;color:#475569;font-size:12px;font-weight:600}.settings-tabs button.active{background:#111315;color:#fff}.right-content-tabs button{display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:3px;min-height:46px;padding:6px 2px;border:0;border-radius:5px;background:transparent;color:#475569;font-size:12px;font-weight:600;line-height:1.05;min-width:0;text-align:center}.right-content-tabs button svg,.settings-tabs button svg,.editable-list-row svg{flex:0 0 auto}.right-content-tabs button.active{background:#111315;color:#fff}.editable-list{display:grid;gap:8px}.editable-list-row{display:flex;align-items:center;gap:8px;width:100%;min-height:34px;padding:7px 10px;border:0;border-radius:5px;background:#fff;color:#1f2937;box-shadow:0 3px 8px #0f172a12;text-align:left;font-size:12px;font-weight:600}.editable-list-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editable-list-row.active{background:#111315;color:#fff}.confirm-line{display:flex;align-items:center;gap:8px;color:#0b6f71;font-size:12px;font-weight:600}.screen-center{display:grid;min-height:100%;place-items:center;padding:24px;background:#f7f8fa}.status-panel{width:min(440px,100%);padding:28px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow);text-align:center}.status-icon{display:grid;width:48px;height:48px;margin:0 auto 16px;place-items:center;border-radius:8px;background:#9f2d2d1a;color:var(--danger)}.status-panel h1{margin:0 0 8px;font-size:clamp(24px,6vw,34px);letter-spacing:0}.status-panel p{margin:0;color:var(--muted);line-height:1.5}.eyebrow{margin-bottom:8px!important;color:var(--accent-strong)!important;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0}.loader{width:44px;height:44px;margin:0 auto 16px;border:4px solid rgba(15,139,141,.18);border-top-color:var(--accent);border-radius:999px;animation:spin .9s linear infinite}.toast{position:fixed;top:calc(var(--topbar-height) + 14px);right:16px;z-index:40;display:flex;align-items:center;max-width:min(440px,calc(100vw - 32px));gap:12px;padding:13px 14px;border-radius:8px;background:#111315;color:#fff;box-shadow:0 18px 36px #00000047;font-size:12px;font-weight:500}.toast-error{background:#541c1c}.toast button{display:grid;flex:0 0 auto;width:24px;height:24px;place-items:center;border:0;border-radius:6px;background:#ffffff1f;color:#fff}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1180px){body{overflow:auto}.topbar{position:sticky}.main-grid{grid-template-columns:minmax(250px,300px) minmax(360px,1fr);height:auto;min-height:calc(100vh - var(--topbar-height));padding-top:14px}.right-sidebar{grid-column:1 / -1;grid-template-columns:minmax(260px,1fr)}.workspace{min-height:720px}}@media(max-width:760px){.topbar{height:auto;min-height:var(--topbar-height);align-items:flex-start;flex-direction:column}.brand-lockup{width:100%}.topbar-actions{justify-content:stretch;width:100%}.topbar-actions .button{flex:1 1 140px}.main-grid{grid-template-columns:1fr;padding:12px}.workspace{min-height:680px;grid-row:1}.left-sidebar{grid-row:2}.right-sidebar{grid-row:3}.add-grid{grid-template-columns:1fr}}
