@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--accent-primary:#3b82f6;--accent-secondary:#2563eb;--border-color:#e2e8f0;--cabinet-bg:#ffffffd9;--cabinet-border:#94a3b8;--cabinet-shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--cabinet-hover-border:#3b82f6;--cabinet-selected-border:#2563eb;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--border-color:#334155;--cabinet-bg:#1e293bd9;--cabinet-border:#475569;--cabinet-shadow:0 4px 6px -1px #00000080, 0 2px 4px -2px #00000080}}*{box-sizing:border-box;margin:0;padding:0}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}#root{width:100vw;height:100vh}.app-layout{background-color:var(--bg-tertiary);width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:10;flex-direction:column;width:300px;min-width:300px;display:flex;box-shadow:2px 0 10px #0000000d}.sidebar-header{border-bottom:1px solid var(--border-color);padding:1.5rem}.sidebar-header h2{margin-bottom:.25rem;font-size:1.25rem;font-weight:600}.sidebar-header p{color:var(--text-secondary);font-size:.875rem}.preset-list{flex-direction:column;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.preset-btn{background-color:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;text-align:left;color:var(--text-primary);border-radius:.5rem;align-items:center;gap:1rem;padding:1rem;transition:all .2s;display:flex}.preset-btn:hover{border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 6px -1px #3b82f61a}.preset-icon{color:var(--accent-primary);background:#3b82f61a;border-radius:.375rem;justify-content:center;align-items:center;padding:.5rem;display:flex}.preset-info{flex-direction:column;display:flex}.preset-label{font-size:.95rem;font-weight:500}.preset-dim{color:var(--text-secondary);margin-top:.125rem;font-size:.75rem}.view-container{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.view-toggle{background:var(--bg-primary);border:1px solid var(--border-color);z-index:50;border-radius:9999px;padding:.25rem;display:flex;position:absolute;top:1rem;right:2rem;box-shadow:0 4px 6px -1px #0000001a}.toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:9999px;padding:.5rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:var(--accent-primary);color:#fff;box-shadow:0 2px 4px #3b82f64d}.canvas-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.canvas-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:5;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;box-shadow:0 1px 3px #0000000d}.canvas-header h2{font-size:1.125rem;font-weight:600}.canvas-stats{color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:9999px;padding:.375rem .75rem;font-size:.875rem}.canvas-scroll-area{background-image:radial-gradient(var(--border-color) 1px, transparent 1px);background-size:16px 16px;flex:1;padding:2rem;overflow:auto}.canvas-wall{background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;position:relative;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.canvas-wall.with-grid{background-image:linear-gradient(to right, var(--border-color) 1px, transparent 1px), linear-gradient(to bottom, var(--border-color) 1px, transparent 1px);background-size:96px 96px}.canvas-ruler-wrapper{background:var(--bg-primary);border-radius:8px;flex-direction:column;width:fit-content;margin:auto;padding-bottom:24px;padding-right:24px;display:flex;box-shadow:0 4px 6px -1px #0000001a}.ruler-x{border-bottom:1px solid var(--border-color);height:24px;margin-left:24px;position:relative}.ruler-marker-x{color:var(--text-secondary);flex-direction:column;align-items:center;font-size:10px;display:flex;position:absolute;top:0;transform:translate(-50%)}.ruler-tick{background-color:var(--border-color);width:1px;height:8px;margin-bottom:2px}.ruler-y{border-right:1px solid var(--border-color);width:24px;position:relative}.ruler-marker-y{color:var(--text-secondary);align-items:center;font-size:10px;display:flex;position:absolute;left:0;transform:translateY(-50%)}.ruler-tick-y{background-color:var(--border-color);width:8px;height:1px;margin-right:2px}.rnd-component{background-color:var(--cabinet-bg);border:2px solid var(--cabinet-border);box-shadow:var(--cabinet-shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:4px;justify-content:center;align-items:center;transition:box-shadow .2s,border-color .2s;display:flex}.rnd-component:hover{border-color:var(--cabinet-hover-border);z-index:100!important}.rnd-component.selected{border-color:var(--cabinet-selected-border);box-shadow:0 0 0 2px #2563eb33, var(--cabinet-shadow);z-index:100!important}.component-inner{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:.5rem;display:flex;position:relative;overflow:hidden}.component-label{color:var(--text-primary);-webkit-user-select:none;user-select:none;font-size:.875rem;font-weight:600}.component-dims{color:var(--text-secondary);-webkit-user-select:none;user-select:none;margin-top:.25rem;font-size:.75rem}.delete-btn{color:#fff;cursor:pointer;opacity:.8;z-index:10;background-color:#ef4444;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;font-weight:700;transition:opacity .2s;display:flex;position:absolute;top:4px;right:4px}.delete-btn:hover{opacity:1}.properties-panel{background-color:var(--bg-secondary);border-left:1px solid var(--border-color);z-index:10;flex-direction:column;width:300px;min-width:300px;display:flex;overflow:hidden auto}.panel-content{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.prop-group{flex-direction:column;gap:.5rem;display:flex}.prop-group label{color:var(--text-primary);font-size:.875rem;font-weight:600}.prop-group select,.prop-group input{border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);border-radius:.25rem;padding:.5rem}.prop-group select:focus,.prop-group input:focus{border-color:var(--accent-primary);outline:none}.help-text{color:var(--text-secondary);font-size:.75rem}.prop-group.row{flex-direction:row;gap:1rem}.col{flex-direction:column;flex:1;gap:.5rem;display:flex}.prop-item-header{border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.prop-item-header h3{color:var(--text-primary);font-size:1rem}
