@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700&display=swap";:root{--color-bg-primary: #090a0f;--color-bg-secondary: #11141d;--color-bg-panel: rgba(17, 20, 29, .7);--color-bg-hover: #1a2030;--color-border: rgba(255, 255, 255, .08);--color-border-glow: rgba(79, 142, 247, .3);--color-accent: #4f8ef7;--color-accent-hover: #6c9ef8;--color-accent-glow: rgba(79, 142, 247, .5);--color-accent-rgb: 79, 142, 247;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--glass-bg: rgba(17, 20, 29, .65);--glass-border: 1px solid rgba(255, 255, 255, .05);--color-text-primary: #f8fafc;--color-text-secondary:#94a3b8;--color-text-muted: #64748b;--scrollbar-thumb: rgba(255, 255, 255, .12);--scrollbar-hover: rgba(255, 255, 255, .22);--canvas-bg: #0d0f18;--sidebar-width: 280px;--preview-width: 320px;--topbar-height: 60px;--font-base: "Inter", sans-serif;--font-heading: "Outfit", sans-serif;font-family:var(--font-base);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:dark}@media (prefers-color-scheme: light){:root:not([data-theme=dark]){--color-bg-primary: #f4f6fb;--color-bg-secondary: #ffffff;--color-bg-panel: rgba(255, 255, 255, .92);--color-bg-hover: #eef1f8;--color-border: rgba(0, 0, 0, .09);--color-border-glow: rgba(79, 142, 247, .2);--glass-bg: rgba(255, 255, 255, .88);--glass-border: 1px solid rgba(0, 0, 0, .07);--color-text-primary: #0f172a;--color-text-secondary:#475569;--color-text-muted: #94a3b8;--scrollbar-thumb: rgba(0, 0, 0, .12);--scrollbar-hover: rgba(0, 0, 0, .22);--canvas-bg: #e8ecf5;color-scheme:light}}[data-theme=dark]{--color-bg-primary: #090a0f;--color-bg-secondary: #11141d;--color-bg-panel: rgba(17, 20, 29, .7);--color-bg-hover: #1a2030;--color-border: rgba(255, 255, 255, .08);--color-border-glow: rgba(79, 142, 247, .3);--glass-bg: rgba(17, 20, 29, .65);--glass-border: 1px solid rgba(255, 255, 255, .05);--color-text-primary: #f8fafc;--color-text-secondary:#94a3b8;--color-text-muted: #64748b;--scrollbar-thumb: rgba(255, 255, 255, .12);--scrollbar-hover: rgba(255, 255, 255, .22);--canvas-bg: #0d0f18;color-scheme:dark}[data-theme=light]{--color-bg-primary: #f4f6fb;--color-bg-secondary: #ffffff;--color-bg-panel: rgba(255, 255, 255, .92);--color-bg-hover: #eef1f8;--color-border: rgba(0, 0, 0, .09);--color-border-glow: rgba(79, 142, 247, .2);--glass-bg: rgba(255, 255, 255, .88);--glass-border: 1px solid rgba(0, 0, 0, .07);--color-text-primary: #0f172a;--color-text-secondary:#475569;--color-text-muted: #94a3b8;--scrollbar-thumb: rgba(0, 0, 0, .12);--scrollbar-hover: rgba(0, 0, 0, .22);--canvas-bg: #e8ecf5;color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;background:var(--color-bg-primary);color:var(--color-text-primary);transition:background .3s ease,color .3s ease}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{background:transparent;border:none;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;padding:6px;border-radius:50%;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}*,*:before,*:after{transition:background-color .25s ease,border-color .25s ease,color .2s ease,box-shadow .2s ease}canvas,img,svg,video,[class*=konva],.no-transition,*[style*=animation]{transition:none!important}[data-tablet] button:not(.tablet-fab),[data-tablet] input[type=checkbox],[data-tablet] input[type=radio]{min-height:44px;min-width:44px}[data-tablet] input:not([type=checkbox]):not([type=radio]):not([type=color]),[data-tablet] select,[data-tablet] textarea{min-height:44px;font-size:15px!important;padding:10px 12px!important}[data-tablet] .canvas-toolbar button,[data-tablet] .canvas-overlay button{min-height:48px;min-width:48px;font-size:14px;padding:10px 14px}[data-tablet] .parts-input,[data-tablet] .parts-table input,[data-tablet] .parts-table select{min-height:44px;font-size:14px}[data-tablet] .dialog-btn,[data-tablet] .dialog-actions button{min-height:52px;font-size:15px;padding:12px 20px}[data-tablet] [class*=context]{font-size:15px}[data-tablet] html,[data-tablet] body{overscroll-behavior:none;-webkit-overflow-scrolling:touch}.live-preview{display:flex;flex-direction:column;height:100%;width:100%;background:var(--bg-card);transition:all .3s ease;box-shadow:0 10px 25px #00000080;border-radius:8px;overflow:hidden;border:1px solid var(--border-color)}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-card);cursor:grab}.preview-header:active{cursor:grabbing}.preview-title{font-weight:600;font-size:.875rem;color:var(--text-heading);text-transform:uppercase;letter-spacing:.05em}.fullscreen-btn{background:var(--bg-main);border:1px solid var(--border-color);color:var(--text-heading);padding:4px 8px;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .2s}.fullscreen-btn:hover{background:var(--primary-accent);color:#fff;border-color:var(--primary-accent)}.preview-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-canvas);overflow:hidden}.preview-legend{padding:16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--text-main)}.legend-dot{width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.1)}.live-preview.fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;border:none;border-radius:0}.live-preview.fullscreen .preview-header{background:var(--bg-card);padding:24px}.live-preview.fullscreen .preview-title{font-size:1.25rem}.live-preview.fullscreen .fullscreen-btn{font-size:1rem;padding:8px 16px}.parts-list-panel{width:100%;background:var(--color-bg-primary);border:none;display:flex;flex-direction:column;flex:1;height:100%;overflow:hidden;box-shadow:none;font-family:inherit;min-height:0}.parts-list-header{padding:16px;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.parts-list-header h2{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.5px}.parts-list-form{padding:12px;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.parts-list-form input{width:100%;padding:6px 8px;margin-bottom:8px;border:1px solid var(--color-border);border-radius:4px;font-size:12px;background:var(--color-bg-primary);color:var(--color-text-primary)}.parts-list-form .form-row{display:flex;gap:8px;margin-bottom:8px}.parts-list-form .form-row input{margin-bottom:0}.add-btn{background:var(--color-accent);color:#fff;border:none;border-radius:4px;width:32px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s}.add-btn:hover{opacity:.9}.parts-list-items{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;background:var(--color-bg-primary)}.empty-state{text-align:center;font-size:12px;color:var(--color-text-secondary);padding:20px;font-style:italic}.part-card{display:flex;align-items:center;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;padding:8px;cursor:grab;transition:transform .1s,box-shadow .2s}.part-card:active{cursor:grabbing}.part-card:not(.completed):hover{border-color:var(--color-accent);box-shadow:0 2px 4px #0000000d}.part-card.completed{opacity:.6;background:var(--color-bg-primary);cursor:default}.part-card-drag-handle{padding-right:8px;cursor:grab}.part-card-thumb{margin-right:12px;display:flex;align-items:center;justify-content:center;border-radius:4px}.part-card-svg{display:block}.part-card-content{flex:1;display:flex;flex-direction:column}.part-card-title{font-size:13px;font-weight:600;color:var(--color-text-primary)}.part-card-dims{font-size:11px;color:var(--color-text-secondary);margin-top:2px}.part-card-progress{font-size:11px;margin-top:4px;color:var(--color-text-secondary)}.part-card-progress strong{color:var(--color-text-primary)}.part-card-actions{display:flex;align-items:center;justify-content:center;width:24px}.del-btn{background:none;border:none;cursor:pointer;color:var(--color-danger, #ef4444);padding:4px;opacity:.7;transition:opacity .2s}.del-btn:hover{opacity:1}.sidebar{width:300px;min-width:300px;background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-right:var(--glass-border);display:flex;flex-direction:column;height:100%;box-shadow:4px 0 24px #00000014;z-index:50;color:var(--color-text-primary);overflow:hidden}.sidebar--3zone{display:flex;flex-direction:column}.sidebar-zone1{flex-shrink:0;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.sidebar-zone2{flex:1 1 0;display:flex;flex-direction:column;min-height:0;background:var(--color-bg-primary)}.sidebar-zone3{flex-shrink:0;border-top:1px solid var(--color-border);background:var(--color-bg-secondary);padding:10px 12px}.sidebar-zone3__grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.sidebar-brand{padding:14px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--color-border)}.sidebar-logo{width:32px;height:32px;border-radius:8px;object-fit:contain}.sidebar-logo-fallback{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--color-accent),var(--color-secondary, #9b59f7));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px var(--color-accent-glow)}.sidebar-title{font-size:15px;font-weight:700;letter-spacing:-.02em;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-collapse-btn{margin-left:auto;flex-shrink:0}.sidebar-project-card{margin:10px 12px;padding:10px 12px;background:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .15s}.sidebar-project-card:hover{background:var(--color-bg-active, rgba(79,142,247,.1));border-color:var(--color-accent)}.sidebar-project-card__info{flex:1;min-width:0}.sidebar-project-card__name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-project-card__sub{font-size:11px;color:var(--color-text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-project-card__empty{font-size:12px;color:var(--color-text-secondary);font-style:italic}.sidebar-project-card__icon{flex-shrink:0;color:var(--color-text-secondary)}.sidebar-actions{display:flex;flex-direction:column;gap:4px;padding:8px 12px 12px}.sidebar-btn{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--color-text-primary);font-family:var(--font-base);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left}.sidebar-btn:hover{background:var(--color-bg-hover)}.sidebar-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-btn--new{background:var(--color-accent);color:#fff;font-weight:600;box-shadow:0 2px 8px var(--color-accent-glow)}.sidebar-btn--new:hover{filter:brightness(1.1);background:var(--color-accent)}.sidebar-btn--accent{background:var(--color-accent);color:#fff;box-shadow:0 2px 8px var(--color-accent-glow)}.sidebar-btn--accent:hover{filter:brightness(1.1);background:var(--color-accent)}.sidebar-btn--live{color:#10b981;border-color:#10b9814d}.sidebar-btn--live:hover{background:#10b98114}.util-btn{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px;padding:7px 6px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-bg-primary);color:var(--color-text-secondary);font-size:10px;font-weight:500;cursor:pointer;transition:all .15s ease}.util-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-accent)}.util-btn--accent{color:var(--color-accent);border-color:#4f8ef766}.util-btn--danger{color:#ef4444;border-color:#ef44444d}.util-btn--wide{grid-column:span 2;flex-direction:row;gap:6px;padding:7px 10px;font-size:11px}.sidebar--collapsed{width:56px;min-width:56px;display:flex;flex-direction:column;align-items:center;padding:8px 0}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.icon-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.icon-btn--active{background:var(--color-accent);color:#fff!important}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.sidebar-list-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;cursor:pointer;margin-bottom:3px;transition:background .15s;font-size:12px}.sidebar-list-item:hover{background:var(--color-bg-hover)}.sidebar-list-item--active{background:#4f8ef71a;border:1px solid rgba(79,142,247,.3)}.sidebar-heading{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:700;margin-bottom:8px}.sidebar-footer{padding:10px 16px;font-size:11px;color:var(--color-text-muted);border-top:1px solid var(--color-border);text-align:center;flex-shrink:0}[data-tablet] .sidebar{position:fixed!important;left:0;top:0;height:100dvh;z-index:1010;transform:translate(-110%);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;will-change:transform;box-shadow:none}[data-tablet] .sidebar.tablet-drawer-open{transform:translate(0);box-shadow:6px 0 48px #00000073}[data-tablet] .app-body{margin-left:0!important;width:100%!important}.tablet-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;background:#00000085;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:tabletFadeIn .25s ease}@keyframes tabletFadeIn{0%{opacity:0}to{opacity:1}}.tablet-fab{position:fixed;bottom:28px;left:24px;z-index:1020;width:60px;height:60px;border-radius:50%;border:none;background:var(--color-accent);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px var(--color-accent-glow);transition:transform .2s ease,background .15s ease,box-shadow .2s ease;touch-action:manipulation;-webkit-user-select:none;user-select:none}.tablet-fab:hover,.tablet-fab:active{transform:scale(1.08);box-shadow:0 10px 32px var(--color-accent-glow)}.tablet-fab--open{background:var(--color-bg-hover);color:var(--color-text-primary);border:2px solid var(--color-border);box-shadow:0 4px 16px #0000004d}[data-tablet] .sidebar-btn{min-height:48px;font-size:14px;padding:12px 14px}[data-tablet] .util-btn{min-height:52px;min-width:52px;font-size:11px;gap:5px}[data-tablet] .icon-btn{width:44px;height:44px}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#090a0fcc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000}.settings-modal{background:var(--glass-bg);border:var(--glass-border);border-radius:12px;width:min(1000px,96vw);max-height:90vh;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column}.settings-header{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}.settings-header h2{font-family:var(--font-heading);font-size:16px;margin:0;color:var(--color-text-primary)}.settings-close{background:none;border:none;color:var(--color-text-muted);font-size:16px;cursor:pointer}.settings-close:hover{color:var(--color-text-primary)}.settings-body{padding:20px;display:flex;flex-direction:column;gap:16px}.settings-field{display:flex;flex-direction:column;gap:8px}.settings-field label{font-family:var(--font-heading);font-size:13px;color:var(--color-text-secondary)}.settings-field input{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:8px 12px;color:var(--color-text-primary);font-family:var(--font-base);font-size:14px}.settings-field input:focus{outline:none;border-color:var(--color-accent)}.settings-body{overflow-y:auto;max-height:calc(90vh - 140px)}.settings-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:flex-end;background:#0000001a;border-bottom-left-radius:12px;border-bottom-right-radius:12px}.slab-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:11000;display:flex;align-items:center;justify-content:center}.slab-modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;width:90vw;height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.slab-header{padding:16px 24px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;background:var(--color-bg-secondary)}.slab-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.close-btn{background:none;border:none;color:var(--color-text-secondary);font-size:1.5rem;cursor:pointer;transition:color .2s}.close-btn:hover{color:#f44}.slab-body{display:flex;flex:1;min-height:0;overflow:hidden}.slab-sidebar{width:350px;background-color:var(--color-bg-primary);opacity:.95;border-right:1px solid var(--color-border);padding:24px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;flex-shrink:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.slab-sidebar::-webkit-scrollbar{width:4px}.slab-sidebar::-webkit-scrollbar-track{background:transparent}.slab-sidebar::-webkit-scrollbar-thumb{background-color:#ffffff1a;border-radius:4px}.step-item{padding:16px;border:1px solid var(--color-border);border-radius:8px;opacity:.5;transition:all .3s ease}.step-item.active{opacity:1;border-color:var(--primary-accent);background:#4f8ef70d}.step-item h3{margin:0 0 8px;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.step-item p{margin:0;font-size:.875rem;color:var(--text-main);line-height:1.5}.scale-input-box{margin-top:16px;display:flex;flex-direction:column;gap:8px}.scale-input-box label{font-size:.875rem;color:var(--text-main)}.scale-input-box input{background:var(--bg-input);border:1px solid var(--color-border);color:var(--text-main);padding:10px;border-radius:6px;font-size:1rem}.scale-input-box input:focus{outline:none;border-color:var(--primary-accent)}.error-text{color:#fb7185;font-size:.875rem;padding:12px;background:#fb71851a;border-radius:6px;margin-top:auto}.slab-workspace{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-canvas);overflow:hidden;position:relative}.slab-stage{box-shadow:0 4px 20px #0003;max-width:100%;max-height:80vh}@media (max-width: 900px){.slab-modal-content{width:98vw;height:96vh}.slab-body{flex-direction:column}.slab-sidebar{width:100%;max-height:200px;overflow-y:auto;border-right:none;border-bottom:1px solid var(--color-border);padding:12px;gap:10px}.slab-workspace{min-height:0;flex:1}.slab-stage{max-height:60vh}}@media (max-width: 600px){.slab-sidebar{max-height:160px;padding:8px}.slab-header{padding:10px 16px}.slab-header h2{font-size:1rem}}.mt-4{margin-top:16px}.primary-btn{background:var(--primary-accent);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-weight:600;cursor:pointer;width:100%;transition:filter .2s}.primary-btn:hover:not(:disabled){filter:brightness(1.1)}.primary-btn:disabled{background:var(--color-text-secondary);cursor:not-allowed}.initial-setup-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background:linear-gradient(135deg,#1e293b,#0f172a);color:#f8fafc;font-family:inherit}.initial-setup-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:40px;width:100%;max-width:500px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0000004d;text-align:center}.initial-setup-card h1{margin-top:0;margin-bottom:10px;font-size:2rem;color:#38bdf8}.initial-setup-card p{color:#94a3b8;margin-bottom:30px}.form-group{margin-bottom:25px;text-align:left}.form-group label{display:block;font-size:.9rem;font-weight:600;color:#cbd5e1;margin-bottom:8px}.form-group input[type=text],.form-group select{width:100%;padding:12px;border-radius:6px;border:1px solid #475569;background:#0f172a;color:#f8fafc;font-size:1rem;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.form-group input[type=text]:focus,.form-group select:focus{border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf833}.logo-upload-area{display:flex;flex-direction:column;align-items:center;gap:15px;padding:20px;border:2px dashed #475569;border-radius:8px;background:#0f172a;transition:border-color .2s ease}.logo-upload-area:hover{border-color:#38bdf8}.logo-preview{max-width:150px;max-height:100px;object-fit:contain;border-radius:4px}.logo-placeholder{color:#64748b;font-size:.9rem}.form-group input[type=file]{width:100%;color:#94a3b8}.form-actions{margin-top:40px}.finish-button{background:#38bdf8;color:#0f172a;border:none;padding:14px 28px;font-size:1.1rem;font-weight:600;border-radius:6px;cursor:pointer;width:100%;transition:background .2s ease,transform .1s ease}.finish-button:hover{background:#7dd3fc}.finish-button:active{transform:scale(.98)}.settings-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.settings-modal{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:12px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000080;animation:modal-enter .2s cubic-bezier(.16,1,.3,1);overflow:hidden}.settings-header{padding:20px 24px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;background:var(--color-bg-secondary)}.settings-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.settings-close{background:none;border:none;color:var(--color-text-secondary);font-size:1.25rem;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.settings-close:hover{color:var(--color-text-primary);background:#ffffff1a}.settings-body{padding:24px}@keyframes modal-enter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.warehouse-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg-primary);z-index:10005;display:flex;flex-direction:column}.warehouse-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.warehouse-title{display:flex;align-items:center;gap:16px}.warehouse-title h2{margin:0;color:var(--color-text-primary);font-size:20px}.warehouse-count{background:var(--color-accent);color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:700}.warehouse-close{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:700}.warehouse-toolbar{display:flex;gap:12px;padding:16px 24px;background:var(--color-bg-primary);border-bottom:1px solid var(--color-border)}.warehouse-search{flex:1;padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary)}.warehouse-filter{padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);min-width:150px}.warehouse-refresh{padding:8px 16px;background:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);cursor:pointer}.warehouse-body{flex:1;overflow-y:auto;padding:24px;background:var(--color-bg-primary)}.warehouse-error,.warehouse-empty{text-align:center;padding:40px;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:8px;border:1px dashed var(--color-border)}.warehouse-error{color:#ef4444;border-color:#ef44444d}.warehouse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.warehouse-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.warehouse-card-image{height:180px;background-size:contain;background-position:center;background-repeat:no-repeat;background-color:#000;position:relative}.warehouse-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.warehouse-card-image:hover .warehouse-card-overlay{opacity:1}.btn-import{background:var(--color-accent);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:700;cursor:pointer;box-shadow:0 4px 6px #0000004d}.warehouse-card-info{padding:12px;display:flex;flex-direction:column;gap:8px}.warehouse-card-title{font-weight:700;font-size:16px;color:var(--color-text-primary)}.warehouse-card-meta{display:flex;gap:6px;flex-wrap:wrap}.meta-tag{background:var(--color-bg-hover);padding:2px 8px;border-radius:4px;font-size:11px;color:var(--color-text-secondary);border:1px solid var(--color-border)}.id-tag{font-family:monospace;background:#3b82f61a;color:#3b82f6;border-color:#3b82f64d}.btn-edit-meta{margin-top:auto;background:transparent;border:1px solid var(--color-border);padding:6px;border-radius:4px;color:var(--color-text-secondary);cursor:pointer;font-size:12px}.btn-edit-meta:hover{background:var(--color-bg-hover)}.btn-delete-slab{background:transparent;border:1px solid rgba(239,68,68,.3);padding:6px;border-radius:4px;color:#ef4444;cursor:pointer;font-size:12px}.btn-delete-slab:hover{background:#ef44441a}.warehouse-edit-modal{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:60}.warehouse-edit-form{background:var(--color-bg-primary);padding:24px;border-radius:8px;width:400px;display:flex;flex-direction:column;gap:12px}.warehouse-edit-form h3{margin:0 0 12px}.warehouse-edit-form label{font-size:12px;color:var(--color-text-secondary);font-weight:700}.warehouse-edit-form input{padding:8px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-secondary);color:var(--color-text-primary)}.form-actions{display:flex;gap:12px;margin-top:12px}.btn-cancel{flex:1;padding:10px;background:transparent;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);cursor:pointer}.btn-save{flex:1;padding:10px;background:var(--color-accent);border:none;border-radius:4px;color:#fff;font-weight:700;cursor:pointer}.warehouse-add-btn{padding:8px 16px;background:#10b981;color:#fff;border:none;border-radius:6px;font-weight:700;cursor:pointer}.warehouse-add-btn:hover{background:#059669}.warehouse-bulk-modal{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:61}.warehouse-bulk-content{background:var(--color-bg-primary);width:600px;max-width:90vw;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.bulk-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.bulk-header h3{margin:0;color:var(--color-text-primary)}.bulk-close{background:transparent;border:none;color:#ef4444;font-weight:700;cursor:pointer}.bulk-body{display:flex;flex-direction:column;padding:24px;gap:20px}.bulk-image-preview{height:200px;background:#000;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.bulk-image-preview img{max-width:100%;max-height:100%;object-fit:contain}.bulk-form{display:flex;flex-direction:column;gap:12px}.bulk-form label{font-size:12px;font-weight:700;color:var(--color-text-secondary)}.bulk-form input{padding:10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary)}.bulk-row{display:flex;gap:16px}.bulk-row>div{flex:1;display:flex;flex-direction:column;gap:12px}.bulk-actions{margin-top:16px;display:flex;justify-content:flex-end}.btn-bulk-next{padding:12px 24px;background:var(--color-accent);color:#fff;border:none;border-radius:6px;font-weight:700;font-size:14px;cursor:pointer}.btn-bulk-next:disabled{opacity:.7;cursor:not-allowed}.app-shell{display:flex;flex-direction:row;height:100vh;width:100vw;overflow:hidden;background:var(--color-bg-primary)}.app-body{display:flex;flex:1;overflow:hidden;position:relative}.sidebar-left,.sidebar-right{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;flex-direction:column;overflow:hidden;z-index:10;box-shadow:0 4px 30px #00000080}.sidebar-left{width:var(--sidebar-width);min-width:var(--sidebar-width);border-right:var(--glass-border)}.sidebar-right{width:var(--preview-width);min-width:var(--preview-width);border-left:var(--glass-border)}.workspace{flex:1;overflow:hidden;position:relative;background-color:var(--color-bg-primary);background-image:radial-gradient(circle at 2px 2px,rgba(255,255,255,.05) 1px,transparent 0);background-size:32px 32px;box-shadow:inset 0 0 100px #00000080}.theme-light .workspace{background-image:radial-gradient(circle at 2px 2px,rgba(0,0,0,.05) 1px,transparent 0);box-shadow:inset 0 0 100px #0000000d}@media (max-width: 900px){.sidebar-left,.sidebar-right{width:64px;min-width:64px}}.canvas-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#090a0fcc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--color-text-primary);font-family:var(--font-heading);font-size:15px;font-weight:500;letter-spacing:.05em;z-index:100;pointer-events:none}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 15px var(--color-accent-glow)}.error-toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:rgba(2ef,68,68,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(239,68,68,.4);color:#fca5a5;padding:12px 24px;border-radius:12px;font-family:var(--font-heading);font-size:14px;font-weight:500;cursor:pointer;z-index:9999;display:flex;align-items:center;gap:12px;box-shadow:0 10px 30px #00000080,0 0 20px #ef444433;animation:slideUp .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.error-close{opacity:.6;font-size:14px;transition:opacity .2s}.error-toast:hover .error-close{opacity:1}.menu-item-hover:hover{background:var(--color-bg-hover)!important;color:var(--color-accent)!important}
