*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--primary-bg: #eff6ff;--sidebar-bg: #f8fafc;--sidebar-width: 340px;--sidebar-right-width: 220px;--header-bg: #0f172a;--header-height: 52px;--border: #e2e8f0;--border-focus: #93c5fd;--text: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--surface: #ffffff;--radius: 8px;--radius-sm: 6px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--transition: .15s ease}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;color:var(--text);overflow:hidden;background:#0f172a}#app{display:flex;flex-direction:column;height:100vh}.app-header{background:var(--header-bg);color:#fff;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06);z-index:10}.header-brand{display:flex;align-items:center;gap:10px}.header-brand-text{display:flex;flex-direction:column;gap:2px;line-height:1.25}.header-logo{width:30px;height:30px;color:#fff;flex-shrink:0}.app-header h1{font-size:16px;font-weight:600;letter-spacing:.3px;margin:0;color:#fff}.header-slogan{margin:0;font-size:11px;font-weight:400;letter-spacing:.2px;color:#94a3b8}.header-actions{display:flex;align-items:center;gap:8px}.header-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff14;color:#e2e8f0;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.header-btn:hover{background:#ffffff26;border-color:#ffffff4d}.header-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.header-btn-primary:hover{background:var(--primary-hover)}.header-cs-wrap{position:relative;display:inline-flex;align-items:center}.header-cs-popover{position:absolute;top:calc(100% + 8px);right:0;padding:10px 12px 12px;min-width:0;background:var(--surface);color:var(--text);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0f172a1a,0 0 0 1px #0f172a0f;border:1px solid var(--border);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .18s ease,visibility .18s ease,transform .18s ease;pointer-events:none;z-index:200;text-align:center}.header-cs-wrap:hover .header-cs-popover,.header-cs-wrap:focus-within .header-cs-popover{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.header-cs-caption{margin:0 0 6px;font-size:11px;font-weight:500;letter-spacing:.02em;color:var(--text-secondary)}.header-cs-qrcode{display:block;width:120px;height:auto;max-width:min(120px,56vw);margin:0 auto;border-radius:4px;box-shadow:inset 0 0 0 1px #0f172a0f}.header-cs-phone{margin:10px 0 0;display:flex;flex-direction:column;align-items:center;gap:4px}.header-cs-phone-label{font-size:11px;font-weight:500;color:var(--text-secondary);line-height:1.2}.header-cs-phone-num{font-size:17px;font-weight:600;letter-spacing:.06em;color:var(--primary);text-decoration:none;line-height:1.2;font-variant-numeric:tabular-nums}.header-cs-phone-num:hover{color:var(--primary-hover);text-decoration:underline}.header-user-btn{gap:8px}.user-avatar-small{width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;overflow:hidden;flex-shrink:0}.user-avatar-small .avatar-img-fill{width:100%;height:100%;object-fit:cover;display:block}.user-avatar-small .avatar-letter-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.dropdown-item{display:block;width:100%;padding:8px 12px;border:none;background:none;color:var(--text);font-size:13px;text-align:left;cursor:pointer;border-radius:6px;text-decoration:none;transition:background .15s}.dropdown-item:hover{background:#f1f5f9}.dropdown-divider{height:1px;background:var(--border);margin:4px 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;width:100%;max-width:440px;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px;font-weight:600}.modal-close{width:28px;height:28px;border:none;background:none;font-size:20px;color:var(--text-secondary);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#f1f5f9}.modal-body{padding:20px 24px}.modal-body .form-group{margin-bottom:16px}.modal-body .form-group:last-child{margin-bottom:0}.modal-body .form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.modal-body .form-group input,.modal-body .form-group select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;outline:none;transition:border-color .15s}.modal-body .form-group input:focus,.modal-body .form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modal-footer-save{flex-wrap:wrap}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px 20px;border-top:1px solid var(--border)}.modal-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;border:1.5px solid var(--border)}.modal-btn-cancel{background:#fff;color:var(--text-secondary)}.modal-btn-cancel:hover{background:#f1f5f9}.modal-btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.modal-btn-primary:hover{background:var(--primary-hover)}.modal-btn-primary:disabled{opacity:.6;cursor:not-allowed}.app-body{display:flex;flex:1;overflow:hidden;position:relative}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;padding:12px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.sidebar:not(.sidebar-right){display:flex;flex-direction:column;min-height:0}.sidebar::-webkit-scrollbar{width:5px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sidebar-icp{margin-top:auto;padding-top:12px;border-top:1px solid var(--border);font-size:11px;line-height:1.4;text-align:center;color:var(--text-muted);flex-shrink:0}.sidebar-icp a{color:var(--text-muted);text-decoration:none}.sidebar-icp a:hover{color:var(--text-secondary);text-decoration:underline}.sidebar.sidebar-right{position:absolute;top:16px;right:16px;height:auto;max-height:calc(100% - 32px);width:var(--sidebar-right-width);display:flex;flex-direction:column;gap:16px;border:1px solid rgba(226,232,240,.7);border-radius:10px;box-shadow:0 8px 24px #0f172a1a;z-index:10;background:#f8fafcd1;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.sidebar.sidebar-right .panel{background:#fffffff0;box-shadow:var(--shadow-sm);border:1px solid rgba(226,232,240,.95);margin-bottom:0;border-radius:var(--radius)}.sidebar.sidebar-right .panel+.panel{margin-top:16px}.panel{background:var(--surface);border-radius:var(--radius);padding:14px;margin-bottom:10px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.panel-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}.panel-title svg{color:var(--primary);flex-shrink:0}.unit-hint{font-weight:400;color:var(--text-muted);font-size:12px}.template-nav{position:absolute;top:12px;left:12px;display:flex;flex-direction:row;gap:8px;z-index:5;pointer-events:none}.template-card{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid rgba(255,255,255,.55);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:#ffffffd1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-user-select:none;user-select:none;pointer-events:all;white-space:nowrap;box-shadow:var(--shadow-sm)}.template-card:hover{border-color:var(--primary);background:#fffffff5;box-shadow:var(--shadow)}.template-card.active{border-color:var(--primary);background:var(--primary);box-shadow:0 2px 8px #2563eb59}.template-card .icon{display:inline-flex;align-items:center;flex-shrink:0;color:var(--text-secondary)}.template-card:hover .icon{color:var(--primary)}.template-card.active .icon{color:#fff}.template-card .name{font-size:13px;font-weight:500;color:var(--text)}.template-card:hover .name{color:var(--primary)}.template-card.active .name{color:#fff;font-weight:600}.template-menu-notice{position:fixed;left:50%;top:0;z-index:1000;padding:10px 16px;border-radius:999px;background:#0f172aeb;color:#fff;font-size:13px;font-weight:500;box-shadow:0 10px 30px #0f172a47;transform:translate(-50%,-4px);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.template-menu-notice.is-visible{opacity:1;transform:translate(-50%)}.param-row{display:flex;gap:10px;margin-bottom:2px}.param-group{flex:1;margin-bottom:8px}.param-group label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap input{width:100%;padding:7px 36px 7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition);background:#fff;font-family:SF Mono,Cascadia Code,Consolas,monospace}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.input-wrap input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.input-wrap input:disabled{background:#f1f5f9;color:var(--text-muted);cursor:not-allowed}.input-unit{position:absolute;right:10px;font-size:12px;color:var(--text-muted);pointer-events:none}.panel-profile-shelf .param-group{margin-bottom:0}.finish-options{display:grid;grid-template-columns:1fr 1fr;gap:8px}.side-panel-acrylic-row-wrap{margin-bottom:0}.side-panel-acrylic-row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.side-panel-acrylic-toggle{flex-shrink:0;padding-right:2px}.side-panel-acrylic-select-wrap{flex:1;min-width:0}.side-panel-acrylic-select-wrap select:disabled{cursor:not-allowed;opacity:.65;background:#f1f5f9;color:var(--text-muted)}.finish-option{position:absolute;opacity:0;pointer-events:none}.finish-option+label{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;font-size:13px;font-weight:500}.finish-option+label:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.finish-option:checked+label{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f;color:var(--text)}.finish-swatch{width:18px;height:18px;border-radius:999px;border:1px solid rgba(15,23,42,.12);flex-shrink:0}.finish-swatch-silver{background:linear-gradient(135deg,#f7f8fa,#c4cbd2 48%,#9099a3)}.finish-swatch-black{background:linear-gradient(135deg,#616a73,#282d33 45%,#111417)}.assembly-mode-select-wrap select:disabled{cursor:not-allowed;opacity:.65;background-color:#f8fafc}.assembly-mode-hint{margin:8px 2px 0;font-size:12px;line-height:1.5;color:#94a3b8}.plant-rack-toggle{flex:1;padding-left:0}.checkbox-group{display:flex;flex-direction:column;gap:4px}.checkbox-label{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);position:relative}.checkbox-label:hover{background:#f1f5f9}.checkbox-label.is-disabled{cursor:not-allowed;opacity:.55}.checkbox-label.is-disabled:hover{background:transparent}.checkbox-label input[type=checkbox]{position:absolute;width:0;height:0;margin:0;padding:0;border:0;opacity:0;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.checkbox-custom{width:18px;height:18px;border:2px solid #cbd5e1;border-radius:4px;flex-shrink:0;transition:all var(--transition);position:relative;overflow:hidden}.checkbox-label input:checked~.checkbox-custom{background:var(--primary);border-color:var(--primary)}.checkbox-label input:checked~.checkbox-custom:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);box-sizing:border-box}#panel-top-enabled~.checkbox-custom{border-radius:50%}.checkbox-text{position:relative;z-index:1;font-size:14px;font-weight:500;color:var(--text)}.accessory-select-row{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:var(--radius-sm);transition:background var(--transition)}.accessory-select-row:hover{background:#f1f5f9}.accessory-select-row.is-disabled{opacity:.55}.accessory-select-row.is-disabled:hover{background:transparent}.accessory-select-copy{display:flex;flex-direction:column;gap:2px;min-width:0}.accessory-select-wrap{margin-left:auto;width:108px;flex-shrink:0}.panel-position-wrap{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.panel-position-wrap label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.panel-note{margin-top:8px;color:var(--text-secondary);font-size:12px;line-height:1.5}.panel-note.is-disabled{color:#ef4444}.shelf-layout-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:10px 12px;border-radius:12px;background:linear-gradient(180deg,#eff6fff2,#f8fafcf2);border:1px solid rgba(191,219,254,.85)}.shelf-layout-summary{flex:1;font-size:12px;color:#334155;line-height:1.5;font-weight:500}.shelf-layout-reset{border:1px solid var(--border);background:#fff;color:var(--primary);border-radius:var(--radius-sm);padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition)}.shelf-layout-reset:hover:not(:disabled){border-color:var(--primary);background:var(--primary-bg)}.shelf-layout-reset:disabled{cursor:not-allowed;color:var(--text-muted);background:#f8fafc}.shelf-layout-list{display:flex;flex-direction:column;gap:8px}.shelf-layout-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(226,232,240,.9);background:linear-gradient(180deg,#fffffffa,#f8fafcfa);box-shadow:0 1px 3px #0f172a0a;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.shelf-layout-row.is-active{border-color:#60a5fae6;box-shadow:0 0 0 3px #3b82f61f;transform:translateY(-1px)}.shelf-layout-label{width:112px;flex-shrink:0;display:flex;align-items:center;gap:8px;margin-bottom:0}.shelf-layout-badge{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#2563eb1f;color:var(--primary);font-size:12px;font-weight:700;flex-shrink:0}.shelf-layout-label-copy{font-size:12px;font-weight:600;color:var(--text-secondary)}.shelf-layout-input-wrap{flex:1}.shelf-layout-input-wrap.is-shelf-bay-readonly input{background:#f1f5f9;color:var(--text-secondary);cursor:default}.shelf-layout-note{margin-top:10px;font-size:12px;line-height:1.5;color:var(--text-muted)}.select-wrap select{width:100%;padding:7px 30px 7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);outline:none;background:#fff;cursor:pointer;transition:border-color var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.select-wrap select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.select-wrap select.is-locked{background-image:none;padding-right:10px;cursor:not-allowed}.viewport{flex:1;position:relative;background:#fff;overflow:hidden;overscroll-behavior:contain}.viewport canvas{display:block}.viewport-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#1e293ba6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#e2e8f0;font-size:12px;padding:6px 16px;border-radius:20px;pointer-events:none;z-index:5;white-space:nowrap;border:1px solid rgba(255,255,255,.1)}.header-btn-toggle.active{background:#16a34a;border-color:#16a34a;color:#fff;box-shadow:0 2px 8px #16a34a59}.header-btn-toggle.active:hover{background:#15803d;border-color:#15803d}.hint-touch{display:none}@media(hover:none)and (pointer:coarse){.hint-mouse{display:none}.hint-touch{display:inline}}.webgl-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;padding:40px;text-align:center;color:#475569;background:#f8fafc}.webgl-error svg{color:#f59e0b}.webgl-error h2{font-size:18px;font-weight:600;color:#1e293b}.webgl-error p{font-size:14px;margin-bottom:4px}.webgl-error ul{list-style:disc;text-align:left;font-size:13px;line-height:1.8;padding-left:20px;color:#64748b}@media(max-width:900px){.sidebar{width:260px}}@media(max-width:680px){#app{height:100dvh;height:100vh}.app-body{flex-direction:column;overflow:auto}.sidebar{width:100%;max-height:45vh;border-right:none;border-left:none;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar.sidebar-right{border-left:none}.viewport{min-height:300px}.template-nav{flex-wrap:wrap;max-width:calc(100% - 24px)}.template-card{padding:5px 10px;font-size:12px}.viewport-hint{font-size:11px;padding:5px 12px;bottom:10px}.app-header h1{font-size:14px}.header-slogan{font-size:10px}.header-actions{gap:4px}.header-btn{padding:5px 8px;font-size:12px}.header-btn svg{display:none}}
