*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0c0a15;--panel-bg:#13111d;--surface:#1c1a2e;--surface-hover:#24223a;--border:#2e2b47;--border-subtle:#211f36;--text:#eae8f4;--text-dim:#9490b3;--accent:#8b5cf6;--accent-hover:#a378ff;--accent-glow:#8b5cf640;--accent-subtle:#8b5cf614;--success:#34d399;--error:#f87171;--panel-width:370px}html,body{background:var(--bg);height:100%;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overflow:hidden}#app{height:100vh;display:flex}#controls-panel{width:var(--panel-width);min-width:var(--panel-width);background:var(--panel-bg);border-right:1px solid var(--border);flex-direction:column;gap:20px;height:100vh;padding:24px 20px;display:flex;overflow-y:auto}#layers-panel{width:var(--panel-width);min-width:var(--panel-width);background:var(--panel-bg);border-left:1px solid var(--border);flex-direction:column;gap:20px;height:100vh;padding:24px 20px;display:flex;overflow-y:auto}#viewport{flex:1;height:100vh;position:relative}.drop-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:2px dashed var(--accent);background:#8b5cf614;border-radius:0;justify-content:center;align-items:center;display:none;position:absolute;inset:0}.drop-overlay.active{display:flex}.drop-overlay-content{color:var(--accent);letter-spacing:-.01em;flex-direction:column;align-items:center;gap:12px;font-size:16px;font-weight:600;display:flex}.view-cube-container{z-index:10;pointer-events:auto;border-radius:8px;width:120px;height:120px;position:absolute;bottom:16px;right:16px;overflow:hidden}.view-cube-container canvas{display:block}.panel-header{align-items:center;gap:12px;padding-bottom:4px;display:flex}.brand-logo{background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 2px 12px #8b5cf64d}.brand-logo svg,.brand-logo img{border-radius:6px;width:28px;height:28px}.brand-text h1{letter-spacing:-.02em;background:linear-gradient(135deg,#c4b5fd,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:17px;font-weight:700}.brand-text .subtitle{color:var(--text-dim);margin-top:1px;font-size:12px}.control-section{flex-direction:column;gap:12px;display:flex}.section-header-row{justify-content:space-between;align-items:center;display:flex}.clear-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:#ffffff0d;border-radius:6px;padding:3px 10px;font-size:11px;transition:all .15s}.clear-btn:hover{color:var(--error);background:#f871711f;border-color:#f871714d}.control-section h2{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-size:11px;font-weight:600}.preset-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.preset-btn{background:var(--surface);color:var(--text-dim);cursor:pointer;border:2px solid #0000;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;font-size:10px;transition:all .15s;display:flex}.preset-btn:hover{border-color:var(--border);color:var(--text);background:var(--surface-hover)}.preset-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.preset-btn svg{width:32px;height:32px}.upload-area{background:var(--surface);border:2px dashed var(--border);color:var(--text-dim);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:20px;font-size:13px;transition:all .2s;display:flex}.upload-area:hover{border-color:var(--accent);background:var(--accent-subtle);color:var(--text)}.upload-area.drag-over{border-color:var(--accent);color:var(--accent);background:#8b5cf61f}.upload-area svg{opacity:.5}.upload-area:hover svg{opacity:.8}.upload-area .upload-label{font-weight:500}.upload-area .upload-hint{opacity:.6;font-size:11px}.upload-btn{text-align:center;background:var(--surface);border:1px dashed var(--border);color:var(--text-dim);cursor:pointer;border-radius:8px;padding:10px;font-size:13px;transition:all .15s;display:block}.upload-btn:hover{border-color:var(--accent);color:var(--text)}.upload-status{min-height:18px;font-size:12px}.upload-status.success{color:var(--success)}.upload-status.error{color:var(--error)}.slider-group{flex-direction:column;gap:14px;display:flex}.slider-group label{flex-direction:column;gap:6px;display:flex}.label-row{justify-content:space-between;font-size:13px;display:flex}.label-row .value{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:600}.hint{color:var(--text-dim);opacity:.7;font-size:11px}input[type=range]{appearance:none;background:var(--surface);border-radius:3px;outline:none;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:16px;height:16px;transition:transform .1s,box-shadow .15s;box-shadow:0 0 0 3px #8b5cf626}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 5px #8b5cf633}input[type=range]::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.toggle-row{cursor:pointer;justify-content:space-between;align-items:center;font-size:13px;display:flex}input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}input[type=color]{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:8px;width:100%;height:36px;padding:2px}.layer-item{background:var(--surface);border:1px solid var(--border-subtle);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:10px;margin-bottom:8px;padding:10px 12px;transition:border-color .15s,background .15s,box-shadow .15s}.layer-item:hover{border-color:var(--border)}.layer-item-grouped{border:none;border-bottom:1px solid #ffffff0a;border-radius:0;margin-bottom:0;padding:8px 12px}.layer-item-grouped .layer-header{margin-bottom:0}.layer-group{border:2px solid var(--accent);border-radius:12px;margin-bottom:8px;overflow:hidden;box-shadow:0 0 16px #8b5cf614}.layer-group-header{background:#8b5cf60f;border-bottom:1px solid #8b5cf633;padding:10px 12px}.group-label{text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin-bottom:6px;font-size:11px;font-weight:600;display:block}.layer-item.selected{border-color:var(--accent);background:#8b5cf614;box-shadow:0 0 12px #8b5cf626}.layer-item-grouped.selected{background:#8b5cf61a}.section-header-actions{align-items:center;gap:4px;display:flex}.action-btn{background:var(--accent-subtle);color:var(--accent);cursor:pointer;border:1px solid #8b5cf633;border-radius:6px;padding:3px 10px;font-size:11px;transition:all .15s}.action-btn:hover{background:#8b5cf626;border-color:#8b5cf666}.layer-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.layer-body{align-items:stretch;gap:10px;padding-left:40px;display:flex}.layer-body .layer-fields{flex:1;min-width:0}.layer-thumb{border:2px solid var(--border-subtle);cursor:pointer;background:#8b5cf60a;border-radius:6px;flex-shrink:0;width:32px;height:32px;transition:all .15s;overflow:hidden}.layer-thumb:hover{border-color:var(--border)}.layer-thumb.selected{border-color:var(--accent);box-shadow:0 0 8px #8b5cf64d}.layer-thumb svg{width:100%;height:100%}.layer-color-picker-wrapper{cursor:pointer;flex-shrink:0;width:20px;height:20px;position:relative}.layer-color-picker{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.layer-color-swatch{pointer-events:none;border:2px solid #ffffff1f;border-radius:5px;flex-shrink:0;width:20px;height:20px}.layer-name-input{width:100%;color:inherit;background:0 0;border:1px solid #0000;border-radius:6px;min-width:0;padding:2px 6px;font-size:13px;font-weight:500;transition:all .15s}.layer-name-input:hover{border-color:var(--border)}.layer-name-input:focus{border-color:var(--accent);background:#8b5cf60a;outline:none}.layer-name-col{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.layer-stack-label{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;padding-left:6px;font-size:10px;overflow:hidden}.layer-role-select{text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='8' height='5' viewBox='0 0 8 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l3 3 3-3' stroke='%23888' stroke-width='1.2'/%3E%3C/svg%3E");background-position:right 4px center;background-repeat:no-repeat;border-radius:6px;flex-shrink:0;padding:2px 16px 2px 6px;font-family:inherit;font-size:10px;font-weight:600;transition:all .15s}.layer-role-select:focus{outline:none}.layer-role-select.base{border-color:var(--success);color:var(--success);background-color:#34d3991a}.layer-role-select.face{background-color:var(--accent-subtle);border-color:var(--accent);color:var(--accent)}.layer-role-select.independent{color:#fbbf24;background-color:#fbbf241a;border-color:#fbbf24}.layer-visibility-btn{cursor:pointer;color:var(--text-dim);opacity:.7;background:0 0;border:none;flex-shrink:0;padding:2px;transition:opacity .15s}.layer-visibility-btn:hover{opacity:1}.layer-visibility-btn.visible{color:var(--text);opacity:1}.layer-visibility-btn.hidden{opacity:.35}.layer-fields{flex-direction:column;gap:6px;display:flex}.layer-field{flex-direction:column;gap:4px;display:flex}.layer-height-slider,.layer-elevation-slider{background:var(--bg);border-radius:3px;height:6px;box-shadow:inset 0 2px 4px #00000080,inset 0 1px 1px #0000004d}.layer-field-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.layer-field-input{align-items:center;gap:6px;display:flex}.num-input{background:var(--bg);border:1px solid var(--border);width:72px;color:var(--accent);text-align:right;font-variant-numeric:tabular-nums;-moz-appearance:textfield;border-radius:8px;padding:5px 10px;font-family:inherit;font-size:13px;font-weight:600;transition:border-color .15s}.num-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.num-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.num-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #8b5cf626}.unit{color:var(--text-dim);font-size:12px}.export-group{flex-direction:column;gap:8px;margin-top:auto;padding-top:16px;display:flex}.export-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:14px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 12px #8b5cf640}.export-btn.secondary{background:var(--surface);border:1px solid var(--border);box-shadow:none;padding:10px;font-size:13px}.export-btn:hover{background:linear-gradient(135deg,#a378ff,#8b5cf6);transform:translateY(-1px);box-shadow:0 4px 20px #8b5cf659}.export-btn.secondary:hover{background:var(--surface-hover);border-color:var(--accent)}.export-btn:active{transform:scale(.98)}#controls-panel::-webkit-scrollbar{width:6px}#layers-panel::-webkit-scrollbar{width:6px}#controls-panel::-webkit-scrollbar-track{background:0 0}#layers-panel::-webkit-scrollbar-track{background:0 0}#controls-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}#layers-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}#controls-panel::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}#layers-panel::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}#project-header-bar{background:var(--panel-bg);border-bottom:1px solid var(--border);width:100%}.project-header{align-items:center;gap:12px;padding:8px 16px;display:flex}.project-back-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:all .15s;display:flex}.project-back-btn:hover{color:var(--text);background:var(--surface)}#project-name{color:var(--text);background:0 0;border:1px solid #0000;border-radius:6px;flex:1;max-width:300px;padding:4px 8px;font-size:15px;font-weight:600;transition:all .15s}#project-name:hover{border-color:var(--border)}#project-name:focus{border-color:var(--accent);background:var(--surface);outline:none}.project-save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:600;transition:all .15s}.project-save-btn:hover{background:var(--accent-hover)}.project-save-status{color:var(--text-dim);min-width:60px;font-size:12px}#editor-view{flex-direction:column;height:100vh;display:flex}#editor-view #app{flex:1;min-height:0;display:flex;position:relative}.auth-wrapper{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:var(--panel-bg);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:40px 32px}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:12px;width:48px;height:48px;margin-bottom:16px;padding:8px}.auth-header h1{background:linear-gradient(135deg,#c4b5fd,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:700}.auth-subtitle{color:var(--text-dim);margin-top:4px;font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--text-dim);font-size:13px;font-weight:500}.auth-field input{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.auth-field input:focus{border-color:var(--accent);outline:none}.auth-error{color:var(--error);min-height:20px;font-size:13px}.auth-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:10px;padding:12px;font-size:15px;font-weight:600;transition:all .2s}.auth-submit:hover{background:linear-gradient(135deg,#a378ff,#8b5cf6)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{text-align:center;color:var(--text-dim);margin-top:20px;font-size:13px}.auth-toggle-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:600}.auth-toggle-btn:hover{color:var(--accent-hover)}.dashboard-wrapper{background:var(--bg);min-height:100vh}.dashboard-header{background:var(--panel-bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.dashboard-brand{align-items:center;gap:12px;display:flex}.dashboard-logo{background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:8px;width:32px;height:32px;padding:4px}.dashboard-brand h1{background:linear-gradient(135deg,#c4b5fd,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.dashboard-logout-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:8px;padding:6px 16px;font-size:13px;transition:all .15s}.dashboard-logout-btn:hover{border-color:var(--error);color:var(--error)}.dashboard-content{max-width:900px;margin:0 auto;padding:32px}.dashboard-title-row{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.dashboard-title-row h2{font-size:20px;font-weight:600}.dashboard-new-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.dashboard-new-btn:hover{background:linear-gradient(135deg,#a378ff,#8b5cf6);transform:translateY(-1px)}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.project-card{background:var(--panel-bg);border:1px solid var(--border);cursor:pointer;border-radius:12px;transition:all .15s;overflow:hidden}.project-card-thumbnail{background:var(--surface);justify-content:center;align-items:center;width:100%;height:160px;display:flex;overflow:hidden}.project-card-thumbnail img,.project-card-thumbnail svg{object-fit:contain;width:100%;height:100%;padding:12px}.project-card-body{padding:16px 20px 0}.project-card-actions{padding:0 20px 16px}.project-card:hover{border-color:var(--accent);box-shadow:0 0 16px #8b5cf61a}.project-card-name{margin-bottom:4px;font-size:16px;font-weight:600}.project-card-date{color:var(--text-dim);font-size:12px}.project-card-actions{gap:8px;margin-top:12px;display:flex}.project-open-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s}.project-open-btn:hover{background:var(--accent-hover)}.project-delete-btn{color:var(--text-dim);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;font-size:12px;transition:all .15s}.project-delete-btn:hover{border-color:var(--error);color:var(--error)}.projects-empty,.projects-loading,.projects-error{text-align:center;color:var(--text-dim);grid-column:1/-1;padding:40px}#product-types-container{padding:0 20px 20px}.variants-section h2{margin:0}.variants-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.btn-add-variant{background:var(--accent-subtle);border:1px solid var(--accent);color:var(--accent);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600}.btn-add-variant:hover{background:var(--accent);color:#fff}.variants-group{margin-top:12px}.variants-group-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);margin:0 0 6px;font-size:10px;font-weight:700}.variant-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:10px;align-items:center;gap:8px;margin-bottom:6px;padding:10px 12px;display:flex}.variant-card:last-child{margin-bottom:0}.variant-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.variant-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.variant-desc{color:var(--text-dim);font-size:10px}.variant-btns{flex-shrink:0;gap:4px;display:flex}.variant-btns button{cursor:pointer;border:1px solid var(--border-subtle);background:var(--surface-raised,var(--surface));color:var(--text);border-radius:6px;padding:4px 8px;font-size:11px}.variant-btns button:hover{border-color:var(--accent);color:var(--accent)}.variant-btns button:disabled{opacity:.4;cursor:not-allowed}.btn-variant-download{font-weight:600}.variant-card.variant-active{border-color:var(--accent);background:#2dd4bf0f}.variant-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-left:6px;font-size:9px;font-weight:600}.btn-variant-preview.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.btn-variant-preview.active:hover{opacity:.85;color:#000}.btn-variant-delete{color:var(--text-dim)!important}.btn-variant-delete:hover{color:#f87171!important;border-color:#f87171!important}.variant-creator{background:var(--surface);border:1px solid var(--accent);border-radius:10px;margin-bottom:14px;padding:14px}.creator-title{margin:0 0 12px;font-size:13px;font-weight:700}.creator-fields{flex-direction:column;gap:10px;display:flex}.creator-fields label{color:var(--text-dim);flex-direction:column;gap:4px;font-size:11px;font-weight:600;display:flex}.creator-fields input[type=text],.creator-fields input[type=number]{background:var(--bg);border:1px solid var(--border-subtle);color:var(--text);box-sizing:border-box;border-radius:6px;width:100%;padding:6px 8px;font-size:12px}.creator-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.creator-overrides,.creator-hole{flex-direction:column;gap:6px;display:flex}.overrides-subtitle{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin:4px 0 2px;font-size:11px;font-weight:600}.override-layer-swatch{vertical-align:middle;border-radius:3px;width:10px;height:10px;margin-right:2px;display:inline-block}.override-row{align-items:center;gap:6px;font-size:11px;display:flex}.override-check{cursor:pointer;flex:1;align-items:center;gap:5px;color:var(--text)!important;flex-direction:row!important;font-weight:500!important;display:flex!important}.override-val{text-align:right;width:58px!important;padding:4px 6px!important}.override-unit{color:var(--text-dim);white-space:nowrap;font-size:10px}.creator-hole{align-items:center;flex-direction:row!important}.creator-stl-parts{flex-direction:column;gap:8px;margin-top:4px;display:flex}.stl-part-row{background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px;padding:8px;font-size:11px;display:flex}.stl-part-name{min-width:60px;font-weight:600}.stl-part-op{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:4px;padding:2px 4px;font-family:inherit;font-size:10px}.stl-part-pos,.stl-part-rot{gap:4px;display:flex}.stl-part-pos label,.stl-part-rot label,.stl-part-scale{color:var(--text-dim);align-items:center;gap:2px;font-size:10px;display:flex}.stl-part-pos input,.stl-part-rot input,.stl-part-scale input{border:1px solid var(--border);width:48px;color:var(--text);background:#081017;border-radius:4px;padding:2px 4px;font-family:inherit;font-size:10px}.stl-align-btns{flex-wrap:wrap;gap:3px;display:flex}.stl-align-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;white-space:nowrap;border-radius:4px;padding:2px 5px;font-family:inherit;font-size:9px;font-weight:600}.stl-align-btn:hover{border-color:var(--accent);color:var(--accent)}.stl-part-remove{color:var(--text-dim);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:2px 4px;font-size:14px}.stl-part-remove:hover{color:#f44}.stl-upload-btn{border:1px dashed var(--border);color:var(--text-dim);cursor:pointer;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;font-size:11px;transition:all .15s;display:inline-flex}.stl-upload-btn:hover{border-color:var(--accent);color:var(--accent)}.creator-actions{gap:8px;margin-top:12px;display:flex}.btn-save-variant{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:7px;flex:1;padding:7px 12px;font-size:12px;font-weight:600}.btn-save-variant:hover{opacity:.88}.btn-save-preset{border:1px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:7px;padding:7px 12px;font-size:12px;font-weight:600}.btn-save-preset:hover{background:#2dd4bf1a}.variant-card.preset{border-style:dashed}.btn-cancel-variant{border:1px solid var(--border-subtle);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:7px;padding:7px 12px;font-size:12px}.btn-cancel-variant:hover{border-color:var(--text-dim);color:var(--text)}:root{--bg:#0b0f14;--panel-bg:#111820;--surface:#17212b;--surface-hover:#1d2a35;--border:#263441;--border-subtle:#1b2631;--text:#eef3f6;--text-dim:#91a1ad;--accent:#2dd4bf;--accent-hover:#5eead4;--accent-glow:#2dd4bf2e;--accent-subtle:#2dd4bf1a;--panel-width:320px}#app{background:#070b10}#controls-panel{background:#101820;gap:16px;width:320px;min-width:320px;padding:18px 16px}#layers-panel{border-left:1px solid var(--border);opacity:0;pointer-events:none;z-index:10;background:#101820;flex-direction:column;gap:20px;width:360px;min-width:360px;height:100%;padding:18px 16px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .25s;display:flex;position:absolute;top:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 24px #00000059}#app[data-workflow=layers] #layers-panel{opacity:1;pointer-events:auto;transform:translate(0)}#product-types-container{border-left:1px solid var(--border);opacity:0;pointer-events:none;z-index:10;background:#101820;width:380px;min-width:380px;height:100%;padding:18px 16px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .25s;position:absolute;top:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 24px #00000059}#app[data-workflow=variants] #product-types-container{opacity:1;pointer-events:auto;transform:translate(0)}#viewport{background:radial-gradient(circle at 50% 35%,#2dd4bf14,#0000 34%),#070b10}.dimension-svg{pointer-events:none;z-index:5;width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.dimension-line{stroke:#ffffffb3;stroke-width:1px;stroke-dasharray:4 3}.dimension-tick{stroke:#fffc;stroke-width:1.5px}.dimension-label{color:#fff;pointer-events:none;z-index:6;white-space:nowrap;background:#1e2837e0;border:1px solid #ffffff26;border-radius:4px;padding:2px 7px;font-family:Inter,system-ui,sans-serif;font-size:11px;font-weight:600;position:absolute;transform:translate(-50%,-50%)}.workspace-brand{align-items:center;gap:10px;min-height:44px;display:flex}.workspace-brand img{border:1px solid var(--border);background:#17212b;border-radius:8px;width:34px;height:34px;padding:4px}.workspace-brand h1{color:var(--text);font-size:15px;font-weight:700;line-height:1.2}.workspace-brand p,.section-heading p,.panel-subtitle,.inspector-header p{color:var(--text-dim);font-size:12px;line-height:1.45}.workflow-tabs{border:1px solid var(--border-subtle);background:#0c1218;border-radius:8px;flex-direction:column;gap:6px;padding:8px;display:flex}.workflow-tab{min-height:40px;color:var(--text-dim);font:inherit;text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:7px;grid-template-columns:26px 1fr;align-items:center;gap:10px;padding:6px 8px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:grid}.workflow-tab:hover:not(:disabled),.workflow-tab.active{background:var(--surface);border-color:var(--border);color:var(--text)}.workflow-tab.active .workflow-index{background:var(--accent);color:#06110f}.workflow-tab:disabled{opacity:.45;cursor:not-allowed}.workflow-index{width:24px;height:24px;color:var(--text-dim);background:#111a23;border-radius:999px;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.workflow-panel{flex-direction:column;gap:14px;display:none}.workflow-panel.active{display:flex}.section-heading{flex-direction:column;gap:4px;display:flex}.section-heading h2,.control-section h2{letter-spacing:.06em;text-transform:uppercase;color:#c9d6de;font-size:12px;font-weight:700;line-height:1.2}.upload-area{border-color:var(--border);min-height:132px;box-shadow:none;background:#0c1218;border-radius:8px}.upload-area:hover,.upload-area.drag-over{border-color:var(--accent);background:#2dd4bf14}.slider-group,.hole-controls,.layer-inspector{border:1px solid var(--border-subtle);background:#0c1218;border-radius:8px;padding:12px}.mount-hole-toggle{border:1px solid var(--border-subtle);background:#0c1218;border-radius:8px;align-items:flex-start;padding:12px}.mount-hole-toggle span{flex-direction:column;gap:3px;display:flex}.mount-hole-toggle strong{color:var(--text);font-size:13px}.mount-hole-toggle small{color:var(--text-dim);font-size:12px}.workflow-open-panel{border:1px solid var(--border);background:var(--surface);min-height:40px;color:var(--text);font:inherit;cursor:pointer;border-radius:7px;font-size:13px;font-weight:600}.workflow-open-panel:hover:not(:disabled){border-color:var(--accent);color:var(--accent-hover)}.workflow-open-panel:disabled{opacity:.45;cursor:not-allowed}.project-header{background:#0f171f;min-height:50px;padding:8px 14px}.project-save-status{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.project-header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.project-save-btn,.project-export-btn{cursor:pointer;border-radius:7px;min-height:34px;padding:0 12px;font-size:13px;font-weight:700;transition:background .15s,border-color .15s,color .15s}.project-save-btn{background:var(--surface);color:var(--text);border:1px solid var(--border)}.project-export-btn{background:var(--accent);color:#06110f;border:1px solid var(--accent)}.project-export-btn.secondary{color:var(--text-dim);border-color:var(--border);background:0 0}.project-save-btn:hover,.project-export-btn.secondary:hover{border-color:var(--accent);color:var(--accent-hover)}.project-export-btn:hover{background:var(--accent-hover)}.section-header-row{align-items:flex-start;gap:12px}.section-header-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.action-btn,.clear-btn{min-height:30px;padding:0 9px}#layers-list{flex-direction:column;gap:8px;display:flex}.layer-item{border:1px solid var(--border-subtle);background:#0c1218;border-radius:8px;padding:8px}.layer-item.selected{border-color:var(--accent);box-shadow:0 0 0 1px #2dd4bf29}.layer-header{gap:8px}.layer-thumb{border-radius:7px;width:34px;height:34px}.layer-color-picker-wrapper,.layer-color-swatch{width:18px;height:18px}.layer-name-input{font-size:13px}.layer-body{display:none}.layer-inspector{margin-top:12px}.inspector-empty{color:var(--text-dim);font-size:13px;line-height:1.45}.inspector-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.inspector-header h3{color:var(--text);font-size:14px;font-weight:700}.num-input{color:var(--text);background:#081017}.inspector-select{border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;background:#081017;border-radius:6px;padding:6px 10px;font-family:inherit;font-size:13px}.inspector-select:focus{border-color:var(--accent);outline:none}.layer-field-hint{color:var(--text-dim);margin-top:2px;font-size:11px;display:block}.export-group{display:none!important}@media (width<=900px){#app{flex-direction:column}#controls-panel{border-left:0;border-right:0;border-bottom:1px solid var(--border);width:100%;min-width:0;height:auto;max-height:42vh}#layers-panel,#product-types-container{width:85%;min-width:0;max-height:100%}#viewport{min-height:52vh}.workflow-tabs{grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.workflow-tab{text-align:center;grid-template-columns:1fr;justify-items:center;gap:4px}}
