.canvas-2d-wrapper{width:100%;height:100%;display:flex;flex-direction:column;background:var(--white);position:relative}.canvas-2d-empty{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;padding-bottom:32px;background:var(--bg)}.canvas-2d-scroll{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:20px;min-height:0}.view-toggle{display:flex;border-bottom:1px solid var(--border);padding:0 32px;flex-shrink:0;background:var(--white)}.view-toggle-btn{padding:14px 20px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;font-family:var(--font-body);color:var(--mid-grey);border-bottom:2px solid transparent;transition:all .15s ease;margin-bottom:0}.view-toggle-btn:hover{color:var(--text)}.view-toggle-btn.active{color:var(--text);border-bottom-color:var(--accent)}.view-toggle-spacer{flex:1}.view-toggle-reset{color:var(--mid-grey);border:1px solid var(--border);border-radius:2px;margin:8px 0;padding:6px 16px!important}.view-toggle-reset:hover{color:var(--accent);border-color:var(--accent)}@media (max-width: 768px){.canvas-2d-scroll{padding:20px 16px;align-items:flex-start}.view-toggle{padding:0 16px}}.panel-section{padding:0}.panel-section-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.panel-section-header h3{font-family:var(--font-display);font-weight:400;font-size:28px;color:var(--text);letter-spacing:.08em;line-height:1;margin-bottom:4px}.panel-hint{font-size:10px;color:var(--mid-grey);letter-spacing:.06em;text-transform:uppercase}.module-list{padding:12px}.module-card{display:flex;align-items:center;gap:14px;width:100%;padding:12px 14px;border-radius:2px;border:1px solid var(--border);background:var(--white);margin-bottom:6px;transition:all .15s ease;text-align:left}.module-card:hover{border-color:var(--text);background:var(--surface)}.module-card-visual{flex-shrink:0;display:flex;align-items:center}.module-preview-box{background:linear-gradient(135deg,#d8d8d8,silver);border-radius:2px;border:1px solid var(--border)}.module-card-info{flex:1;display:flex;flex-direction:column;gap:2px}.module-name{font-weight:600;font-size:13px;color:var(--text);letter-spacing:.01em}.module-dims{font-size:11px;color:var(--mid-grey);letter-spacing:.02em}.module-price{font-size:12px;color:var(--accent);font-weight:600;margin-top:2px}.module-add-icon{font-size:22px;color:var(--light-grey);flex-shrink:0;font-weight:300;transition:color .15s}.module-card:hover .module-add-icon{color:var(--accent)}.selected-modules{border-top:1px solid var(--border);padding:12px;flex-shrink:0;background:var(--surface)}.selected-modules-header{display:flex;justify-content:space-between;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mid-grey);margin-bottom:8px}.selected-module-tags{display:flex;flex-wrap:wrap;gap:6px}.module-tag{display:flex;align-items:center;gap:6px;background:var(--white);border:1px solid var(--border);border-radius:2px;padding:4px 10px 4px 12px;font-size:11px;color:var(--text)}.module-tag-remove{font-size:15px;color:var(--mid-grey);line-height:1;padding:0;transition:color .15s}.module-tag-remove:hover{color:var(--accent)}.color-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:16px;align-content:start}.color-swatch{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 8px;border-radius:2px;border:1.5px solid var(--border);background:var(--white);transition:all .15s ease;position:relative}.color-swatch:hover{border-color:var(--text)}.color-swatch.selected{border-color:var(--accent)}.color-swatch-dot{width:48px;height:48px;border-radius:50%;box-shadow:0 2px 6px #0000001a}.color-swatch-name{font-size:10px;text-align:center;color:var(--mid-grey);letter-spacing:.02em;line-height:1.3}.color-swatch-check{position:absolute;top:6px;right:6px;width:16px;height:16px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center}.countertop-list{padding:12px;display:flex;flex-direction:column;gap:6px}.countertop-card{border:1.5px solid var(--border);border-radius:2px;background:var(--white);overflow:hidden;transition:border-color .15s}.countertop-card:hover{border-color:var(--text)}.countertop-card.selected{border-color:var(--accent)}.countertop-card-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;width:100%;text-align:left}.countertop-card-title{display:flex;flex-direction:column;gap:2px}.ct-name{font-size:12px;font-weight:600;color:var(--text);letter-spacing:.02em}.ct-desc{font-size:11px;color:var(--mid-grey)}.countertop-toggle{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--mid-grey);transition:all .15s;flex-shrink:0}.countertop-toggle.active{background:var(--accent);border-color:var(--accent);color:#fff;font-size:11px}.countertop-swatches{display:flex;gap:5px;padding:0 16px 13px}.ct-swatch{width:20px;height:20px;border-radius:2px;flex-shrink:0}.back-btn{font-size:11px;color:var(--mid-grey);letter-spacing:.04em;transition:color .15s;margin-top:4px;text-transform:uppercase}.back-btn:hover{color:var(--accent)}.config-summary{margin:16px;background:var(--surface);border-radius:2px;padding:14px;border:1px solid var(--border)}.summary-row{display:flex;justify-content:space-between;font-size:12px;color:var(--mid-grey);padding:5px 0;border-bottom:1px solid var(--border)}.summary-row:last-child{border-bottom:none}.summary-row.total{color:var(--text);font-weight:600;font-size:14px;margin-top:4px;padding-top:10px}.form-fields{padding:0 16px 24px;display:flex;flex-direction:column;gap:10px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.form-row .form-group input,.form-group input{width:100%;box-sizing:border-box}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mid-grey);font-weight:500}.form-group input{padding:9px 12px;border:1.5px solid var(--border);border-radius:2px;background:var(--white);color:var(--text);outline:none;transition:border-color .15s}.form-group input:focus{border-color:var(--text)}.checkbox-label{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--mid-grey);line-height:1.5;cursor:pointer;padding:4px 0}.checkbox-label input[type=checkbox]{width:15px;height:15px;margin-top:1px;flex-shrink:0;accent-color:var(--accent)}.form-error{font-size:12px;color:var(--accent);padding:8px 12px;background:#fef2f2;border-radius:2px;border:1px solid #FECACA}.btn-primary{background:var(--text);color:#fff;padding:13px 24px;border-radius:2px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;transition:all .15s ease;margin-top:4px;font-family:var(--font-body)}.btn-primary:hover:not(:disabled){background:var(--accent)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.success-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 32px;gap:16px;flex:1}.success-icon{width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center}.success-state h3{font-family:var(--font-display);font-weight:400;font-size:32px;letter-spacing:.08em}.success-state p{font-size:13px;color:var(--mid-grey);line-height:1.7;max-width:260px}.empty-message{text-align:center;padding:32px 16px;font-size:12px;color:var(--mid-grey);line-height:1.6}.notice{margin:12px 16px;padding:10px 14px;background:#fef2f2;border:1px solid #FECACA;border-radius:2px;font-size:12px;color:var(--accent)}.selected-info{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--mid-grey);flex-shrink:0}.clear-btn{font-size:11px;color:var(--mid-grey);text-decoration:underline;text-underline-offset:2px;transition:color .15s}.clear-btn:hover{color:var(--accent)}.color-grid-large{display:grid;grid-template-columns:repeat(2,1fr);gap:20px 16px;padding:20px 20px 32px}.color-swatch-large{display:flex;flex-direction:column;align-items:flex-start;gap:8px;background:none;border:none;padding:0;cursor:pointer;text-align:left}.color-swatch-square{width:100%;aspect-ratio:1 / 1;border-radius:2px;position:relative;transition:transform .15s ease;outline:2px solid transparent;outline-offset:2px}.color-swatch-large:hover .color-swatch-square{transform:translateY(-2px)}.color-swatch-large.selected .color-swatch-square{outline-color:var(--accent)}.color-swatch-selected-indicator{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center}.color-swatch-label{font-size:11px;color:var(--text);letter-spacing:.03em;line-height:1.3;font-weight:400;text-transform:lowercase}.module-thumb-img-wrap{width:80px;height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:2px;overflow:hidden}.module-thumb-img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}.module-swatch-square{background:var(--surface)!important;display:flex;align-items:center;justify-content:center;overflow:hidden}.module-swatch-img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply;padding:0}.module-swatch-name{font-size:13px;font-family:var(--font-body);font-weight:600;color:var(--text);text-align:center;line-height:1.3;letter-spacing:.01em}.module-swatch-desc{font-size:11px;color:var(--mid-grey);text-align:left;line-height:1.3;letter-spacing:.03em;font-weight:400}.module-swatch-price{font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.02em}.save-load-config{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.save-config-btn{padding:7px 14px;background:var(--text);color:#fff;border-radius:2px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;font-family:var(--font-body);transition:background .15s;white-space:nowrap}.save-config-btn:hover:not(:disabled){background:var(--accent)}.save-config-btn:disabled{opacity:.4;cursor:not-allowed}.load-toggle-btn{padding:7px 14px;background:transparent;color:var(--mid-grey);border:1px solid var(--border);border-radius:2px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;font-family:var(--font-body);transition:all .15s;white-space:nowrap}.load-toggle-btn:hover{border-color:var(--text);color:var(--text)}.saved-code-box{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.saved-code-label{font-size:11px;color:var(--mid-grey);text-transform:uppercase;letter-spacing:.06em}.saved-code{font-family:var(--font-display);font-size:18px;color:var(--text);letter-spacing:.12em}.copy-btn{padding:5px 10px;background:var(--surface);border:1px solid var(--border);border-radius:2px;font-size:10px;color:var(--mid-grey);font-family:var(--font-body);transition:all .15s}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.load-config-box{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}.load-config-input{padding:7px 12px;border:1.5px solid var(--border);border-radius:2px;font-family:var(--font-display);font-size:16px;letter-spacing:.12em;color:var(--text);width:130px;text-transform:uppercase;outline:none;transition:border-color .15s}.load-config-input:focus{border-color:var(--text)}.load-error{font-size:11px;color:var(--accent);width:100%;margin:0}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app-header{height:var(--header-height);background:var(--text);display:flex;align-items:center;justify-content:space-between;padding:0 28px;flex-shrink:0;z-index:10}.header-brand{display:flex;align-items:center;gap:12px}.brand-name{font-family:var(--font-display);font-size:26px;color:var(--white);letter-spacing:.1em;line-height:1}.header-logo{height:28px;width:auto;display:block}.brand-divider{width:1px;height:18px;background:#444;flex-shrink:0}.brand-sub{font-size:10px;color:var(--mid-grey);text-transform:uppercase;letter-spacing:.16em;font-weight:400}.header-actions{display:flex;align-items:center;gap:16px}.price-badge{font-family:var(--font-display);font-size:22px;color:var(--white);letter-spacing:.06em}.request-btn{padding:8px 20px;background:var(--accent);color:var(--white);border-radius:2px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;transition:background .15s ease;font-family:var(--font-body)}.request-btn:hover{background:var(--accent-hover)}.app-body{flex:1;display:flex;overflow:hidden;min-height:0}.canvas-area{flex:1;position:relative;overflow:hidden;background:var(--bg)}.canvas-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:5;background:var(--bg);font-size:13px;color:var(--mid-grey)}.canvas-overlay.error{color:var(--accent)}.loading-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.canvas-empty-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:center;padding-bottom:32px;pointer-events:none;z-index:2}.hint-box{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--border);border-radius:2px;padding:10px 20px}.hint-icon{font-size:16px;color:var(--accent)}.hint-box p{font-size:11px;color:var(--mid-grey);line-height:1.5;letter-spacing:.03em}.camera-hint{position:absolute;bottom:14px;right:16px;font-size:10px;color:var(--light-grey);letter-spacing:.04em;pointer-events:none}.side-panel{width:var(--panel-width);flex-shrink:0;background:var(--panel-bg);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.panel-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.panel-tab-btn{flex:1;padding:14px 8px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mid-grey);font-weight:600;font-family:var(--font-body);border-bottom:2px solid transparent;transition:all .15s ease;background:var(--white)}.panel-tab-btn:hover{color:var(--text)}.panel-tab-btn.active{color:var(--text);border-bottom-color:var(--accent);background:var(--white)}.panel-content{flex:1;overflow-y:auto;overflow-x:hidden}.mobile-tab-bar{display:none}@media (max-width: 768px){.app-body{flex-direction:column;overflow:auto}.canvas-area{height:40vh;min-height:40vh;flex:none}.side-panel{width:100%;border-left:none;border-top:none;flex:1;overflow:hidden}.panel-tabs{display:flex;position:sticky;top:0;z-index:10;background:var(--white);border-bottom:1px solid var(--border);border-top:1px solid var(--border)}.panel-content{padding-bottom:20px}.mobile-tab-bar,.brand-sub,.brand-divider{display:none}}.lang-toggle{padding:6px 12px;border:1px solid #444;border-radius:2px;font-size:10px;letter-spacing:.12em;font-weight:600;color:#888;font-family:var(--font-body);transition:all .15s ease}.lang-toggle:hover{border-color:var(--white);color:var(--white)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #FAFAFA;--white: #FFFFFF;--text: #212121;--mid-grey: #757575;--light-grey: #BDBDBD;--border: #E0E0E0;--border-dark: #9E9E9E;--accent: #E5271B;--accent-hover: #C41F14;--panel-bg: #FFFFFF;--surface: #F5F5F5;--font-display: "Bebas Neue", sans-serif;--font-body: "Work Sans", sans-serif;--panel-width: 360px;--header-height: 60px}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:13px;letter-spacing:.01em;-webkit-font-smoothing:antialiased}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}input,textarea,select{font-family:var(--font-body);font-size:13px}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--light-grey);border-radius:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease forwards}
