*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-bg: #f8fafc;--c-surface: #ffffff;--c-border: rgba(15,23,42,.1);--c-text: #0f172a;--c-muted: #64748b;--c-primary: #3b82f6;--c-primary-dark: #1d4ed8;--c-success: #22c55e;--c-warning: #f59e0b;--c-error: #ef4444;--radius: 12px;--shadow: 0 2px 12px rgba(15,23,42,.08)}body{font-family:system-ui,-apple-system,sans-serif;background:var(--c-bg);color:var(--c-text);min-height:100vh}.v2-app{display:flex;flex-direction:column;min-height:100vh}.v2-nav{background:var(--c-surface);border-bottom:1px solid var(--c-border);padding:0 1.5rem;height:56px;display:flex;align-items:center;justify-content:space-between}.v2-nav-brand{font-weight:700;font-size:1.1rem;color:var(--c-primary)}.v2-nav-brand span{color:var(--c-text)}.v2-nav-actions{display:flex;gap:.75rem;align-items:center}.v2-main{flex:1;padding:2rem 1.5rem;max-width:1200px;margin:0 auto;width:100%}.v2-sidebar{position:fixed;left:0;top:0;z-index:200;height:100vh;width:60px;background:var(--c-surface);border-right:1px solid var(--c-border);box-shadow:2px 0 8px #0000000f;display:flex;flex-direction:column;align-items:stretch;padding:.5rem 0;gap:0;transition:width .2s ease;overflow:hidden}.v2-sidebar:hover{width:200px}.v2-sidebar-logo{font-weight:800;font-size:1rem;color:var(--c-primary);text-align:center;padding:.75rem 0;border-bottom:1px solid var(--c-border);margin-bottom:.5rem;white-space:nowrap}.v2-sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.1rem;padding:.25rem 0}.v2-sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;font-size:.85rem;white-space:nowrap;color:var(--c-text);background:none;border:none;text-decoration:none;transition:background .15s;border-radius:0}.v2-sidebar-item:hover,.v2-sidebar-item.active{background:var(--c-bg);color:var(--c-primary)}.v2-sidebar-item.router-link-active{background:#eff6ff;color:var(--c-primary);font-weight:600}.v2-sidebar-icon{font-size:1.2rem;flex-shrink:0;width:28px;text-align:center}.v2-sidebar-label{opacity:0;transition:opacity .15s .05s;overflow:hidden}.v2-sidebar:hover .v2-sidebar-label{opacity:1}.v2-sidebar-bottom{border-top:1px solid var(--c-border);padding:.25rem 0}.v2-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.v2-card+.v2-card{margin-top:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--c-primary-dark)}.btn-ghost{background:transparent;color:var(--c-text);border:1px solid var(--c-border)}.btn-ghost:hover:not(:disabled){background:var(--c-bg)}.btn-danger{background:var(--c-error);color:#fff}.btn-lg{padding:.75rem 2rem;font-size:1rem;border-radius:12px}.field{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;font-weight:500;color:var(--c-muted)}.field input,.field select,.field textarea{border:1px solid var(--c-border);border-radius:8px;padding:.5rem .75rem;font-size:.9rem;color:var(--c-text);background:var(--c-surface);outline:none;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--c-primary)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.project-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:1.25rem;cursor:pointer;transition:all .15s}.project-card:hover{border-color:var(--c-primary);box-shadow:0 4px 20px #3b82f61f;transform:translateY(-1px)}.project-card h3{font-size:1rem;margin-bottom:.25rem}.project-card .meta{font-size:.8rem;color:var(--c-muted)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-interior{background:#dbeafe;color:#1d4ed8}.badge-exterior{background:#f0fdf4;color:#15803d}.wizard-steps{display:flex;gap:0;margin-bottom:2rem}.wizard-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.8rem;color:var(--c-muted)}.wizard-step-num{width:32px;height:32px;border-radius:50%;border:2px solid var(--c-border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.wizard-step.active .wizard-step-num{background:var(--c-primary);border-color:var(--c-primary);color:#fff}.wizard-step.done .wizard-step-num{background:var(--c-success);border-color:var(--c-success);color:#fff}.wizard-step-line{flex:1;height:2px;background:var(--c-border);margin:15px -8px 0}.wizard-step.done+.wizard-step>.wizard-step-line{background:var(--c-success)}.zone-editor{display:flex;gap:1rem;align-items:flex-start}.zone-canvas-wrap{position:relative;flex:1;border-radius:var(--radius);overflow:hidden;border:1px solid var(--c-border)}.zone-canvas-wrap canvas{display:block;max-width:100%}.zone-panel{width:320px;flex-shrink:0}.zone-hover-info{position:absolute;top:8px;left:8px;background:#000000b3;color:#fff;padding:4px 10px;border-radius:6px;font-size:.8rem;pointer-events:none}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:1000;display:flex;align-items:center;justify-content:center}.onboarding-popup{background:var(--c-surface);border-radius:20px;padding:2rem;max-width:480px;width:90%;box-shadow:0 20px 60px #0f172a33}.onboarding-popup h2{font-size:1.3rem;margin-bottom:.5rem}.onboarding-popup p{color:var(--c-muted);font-size:.9rem;line-height:1.6;margin-bottom:1rem}.onboarding-choices{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}.onboarding-choice{flex:1;min-width:160px;border:2px solid var(--c-border);border-radius:12px;padding:1.25rem;cursor:pointer;text-align:center;transition:all .15s}.onboarding-choice:hover{border-color:var(--c-primary);background:#eff6ff}.onboarding-choice .ico{font-size:2rem;margin-bottom:.5rem}.onboarding-choice h4{font-size:.95rem}.onboarding-choice p{font-size:.8rem;margin-bottom:0}.before-after{position:relative;overflow:hidden;border-radius:var(--radius);cursor:ew-resize}.before-after img{display:block;width:100%}.before-after .after-layer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.before-after .slider-line{position:absolute;top:0;bottom:0;width:3px;background:#fff;box-shadow:0 0 8px #0006;cursor:ew-resize}.before-after .slider-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:36px;height:36px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;display:flex;align-items:center;justify-content:center;font-size:1rem}.quantity-result{background:#f0fdf4;border:1px solid #86efac;border-radius:10px;padding:1rem;margin-top:.75rem}.quantity-result .qty-main{font-size:1.4rem;font-weight:700;color:#15803d}.quantity-result .qty-detail{font-size:.8rem;color:var(--c-muted);margin-top:.25rem}.upload-zone{border:2px dashed var(--c-border);border-radius:var(--radius);padding:2rem;text-align:center;cursor:pointer;transition:all .15s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--c-primary);background:#eff6ff}.upload-zone .upload-ico{font-size:2.5rem;margin-bottom:.75rem}.upload-zone p{color:var(--c-muted);font-size:.9rem}.error-banner{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:.75rem 1rem;color:#991b1b;font-size:.875rem;display:flex;align-items:center;gap:.5rem}@media (max-width: 768px){.zone-editor{flex-direction:column}.zone-panel{width:100%;position:static;max-height:none}.wizard-steps{font-size:.7rem}.v2-main{padding:1rem .75rem}.v2-card{padding:1rem}.v2-nav{padding:0 .75rem;gap:.5rem}.v2-nav-actions{gap:.35rem;flex-wrap:wrap;justify-content:flex-end;max-width:70vw}.v2-nav-actions .btn{font-size:.72rem;padding:.25rem .5rem}.btn-lg{padding:.65rem 1.25rem;font-size:.9rem}.project-grid{grid-template-columns:1fr}.project-panel{width:100%}.onboarding-popup{padding:1.25rem}.onboarding-choices{flex-direction:column}.onboarding-choice{min-width:unset}.wizard-toolbar-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.25rem}.wizard-toolbar-scroll>div{min-width:max-content}.wizard-steps{max-width:100%!important}}.wm-app{display:flex;flex-direction:column;min-height:100vh;background:var(--c-bg)}.wm-header{background:var(--c-surface);border-bottom:1px solid var(--c-border);padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;position:sticky;top:0;z-index:100}.wm-header-back{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;flex-shrink:0;color:var(--c-text)}.wm-header-info{flex:1;min-width:0}.wm-header-title{font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wm-header-sub{font-size:.75rem;color:var(--c-muted)}.wm-progress{display:flex;gap:4px;align-items:center}.wm-dot{width:8px;height:8px;border-radius:50%;background:var(--c-border);transition:all .2s}.wm-dot.done{background:var(--c-success)}.wm-dot.active{background:var(--c-primary);width:22px;border-radius:4px}.wm-body{flex:1;padding:1.25rem 1rem;display:flex;flex-direction:column;gap:1rem;max-width:560px;margin:0 auto;width:100%}.wm-step-title{font-size:1.15rem;font-weight:700}.wm-step-sub{font-size:.85rem;color:var(--c-muted)}.wm-upload-zone{border:2px dashed var(--c-border);border-radius:14px;min-height:220px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--c-surface);overflow:hidden;transition:border-color .15s}.wm-upload-zone:hover,.wm-upload-zone.drag-over{border-color:var(--c-primary);background:#eff6ff}.wm-upload-zone img{width:100%;height:100%;object-fit:cover;display:block;max-height:320px}.wm-upload-placeholder{text-align:center;padding:2rem}.wm-upload-ico{font-size:3rem;margin-bottom:.75rem}.wm-upload-placeholder p{color:var(--c-muted);font-size:.9rem}.wm-btn-row{display:flex;gap:.75rem;flex-wrap:wrap}.wm-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all .15s;width:100%}.wm-btn-outline{background:var(--c-surface);border:2px solid var(--c-border);color:var(--c-text)}.wm-btn-outline:hover{border-color:var(--c-primary);color:var(--c-primary)}.wm-btn-primary{background:var(--c-primary);color:#fff}.wm-btn-primary:hover:not(:disabled){background:var(--c-primary-dark)}.wm-btn-primary:disabled{opacity:.4;cursor:not-allowed}.wm-btn-ghost{background:none;border:1px solid var(--c-border);color:var(--c-muted)}.wm-field{display:flex;flex-direction:column;gap:.4rem}.wm-field label{font-size:.85rem;font-weight:600;color:var(--c-muted)}.wm-field input{border:1.5px solid var(--c-border);border-radius:10px;padding:.7rem 1rem;font-size:1rem;color:var(--c-text);background:var(--c-surface);outline:none;transition:border-color .15s}.wm-field input:focus{border-color:var(--c-primary)}.wm-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.wm-cat-row{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:12px;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.wm-cat-row.checked{border-color:var(--c-primary);background:#eff6ff}.wm-cat-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.wm-cat-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--c-border);display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;transition:all .15s}.wm-cat-row.checked .wm-cat-check{background:var(--c-primary);border-color:var(--c-primary);color:#fff}.wm-cat-section{display:flex;flex-direction:column;gap:.6rem}.wm-cat-section-title{font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.wm-mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}.wm-mat-card{border:2px solid var(--c-border);border-radius:10px;padding:.5rem;cursor:pointer;transition:all .15s;background:var(--c-surface);text-align:center;position:relative}.wm-mat-card.selected{border-color:var(--c-primary);background:#eff6ff}.wm-mat-card.selected:after{content:"✓";position:absolute;top:4px;right:6px;color:var(--c-primary);font-weight:700;font-size:.75rem}.wm-mat-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;display:block}.wm-mat-name{font-size:.68rem;color:var(--c-muted);margin-top:.3rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wm-detect-box{background:var(--c-surface);border:1px solid var(--c-border);border-radius:14px;padding:1.25rem 1rem;text-align:center}.wm-detect-ico{font-size:3rem;margin-bottom:.75rem}.wm-progress-bar{height:6px;background:var(--c-bg);border-radius:3px;overflow:hidden;margin-top:1rem}.wm-progress-bar-fill{height:100%;background:var(--c-primary);border-radius:3px;animation:wm-progress 2.5s ease-in-out infinite}@keyframes wm-progress{0%{width:0%;margin-left:0}50%{width:70%;margin-left:0}to{width:0%;margin-left:100%}}.wm-pbar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.wm-pbar-label{font-size:.88rem;font-weight:600;color:var(--c-text)}.wm-pbar-pct{font-size:.95rem;font-weight:700;color:var(--c-primary);min-width:3rem;text-align:right}.wm-pbar-track{height:10px;background:var(--c-bg);border-radius:5px;overflow:hidden}.wm-pbar-fill{height:100%;background:var(--c-primary);border-radius:5px;transition:width .35s ease}.wm-pbar-hint{font-size:.75rem;color:var(--c-muted);margin-top:.35rem;text-align:left}.wm-pbar-waiting{opacity:.45;pointer-events:none}.wm-result-card{background:var(--c-surface);border:1px solid #86efac;border-radius:12px;padding:1rem;display:flex;align-items:center;justify-content:space-between}.wm-result-name{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem}.wm-result-area{font-size:1.1rem;font-weight:700;color:var(--c-text)}.wm-result-qty{font-size:.75rem;color:var(--c-muted)}.wm-nav{display:flex;gap:.75rem;padding-top:.5rem}.wm-nav .wm-btn{flex:1}.wm-nav .wm-btn-ghost{flex:0 0 auto;width:auto;padding:.65rem 1.1rem}.v2-sidebar-sep{height:1px;background:var(--c-border);margin:.5rem}.project-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:500;display:flex;align-items:stretch;justify-content:flex-end}.project-panel{width:min(480px,100%);background:var(--c-surface);display:flex;flex-direction:column;box-shadow:-8px 0 40px #0f172a2e;height:100%;overflow-y:auto}.project-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--c-border);gap:.75rem}.project-panel-body{padding:1rem 1.25rem;flex:1}.panel-close-btn{background:none;border:1px solid var(--c-border);border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.panel-close-btn:hover{background:var(--c-bg)}.panel-slide-enter-active{transition:transform .25s ease,opacity .2s ease}.panel-slide-leave-active{transition:transform .2s ease,opacity .15s ease}.panel-slide-enter-from,.panel-slide-leave-to{transform:translate(100%);opacity:0}.room-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid var(--c-border);border-radius:8px;transition:border-color .15s}.room-row:hover{border-color:var(--c-primary)}.btn-icon-danger{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;border-radius:6px;opacity:.5;transition:opacity .15s,background .15s;flex-shrink:0}.btn-icon-danger:hover{opacity:1;background:#fef2f2}
