.header{background-color:#2d2d30;padding:0 24px;border-bottom:1px solid #3e3e42;display:flex;align-items:center;gap:24px;height:48px}.header-brand{display:flex;align-items:center;flex-shrink:0}.header-title{font-size:18px;font-weight:600;color:#fff;margin:0}.header-nav{display:flex;align-items:center;height:100%;gap:4px}.nav-tab{height:100%;padding:0 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:#858585;font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s,background-color .15s;white-space:nowrap}.nav-tab:hover{color:#d4d4d4;background-color:#ffffff0d}.nav-tab.active{color:#fff;border-bottom-color:var(--color-primary, #4a9eff)}.button{padding:8px 16px;border-radius:4px;font-size:13px;font-weight:500;border:none;cursor:pointer;transition:background-color .2s,opacity .2s}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background-color:var(--color-primary);color:#fff}.button-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.button-secondary{background-color:#3e3e42;color:#d4d4d4}.button-secondary:hover:not(:disabled){background-color:#4e4e52}.button-full-width{width:100%}.checkbox-input{display:flex;align-items:center;gap:var(--spacing-sm, 8px);color:var(--color-text-primary, #d4d4d4);font-size:var(--font-size-md, 12px);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-input.disabled{opacity:.5;cursor:not-allowed}.checkbox-input input[type=checkbox]{width:var(--checkbox-size, 14px);height:var(--checkbox-size, 14px);cursor:pointer;accent-color:var(--color-primary, #007acc);flex-shrink:0}.checkbox-input.disabled input[type=checkbox]{cursor:not-allowed}.checkbox-indicator{width:12px;height:3px;border-radius:1px;flex-shrink:0}.checkbox-indicator.perimeter{background-color:var(--color-perimeter, #b94d62)}.checkbox-indicator.infill{background-color:var(--color-infill, #eac653)}.checkbox-indicator.extrusion-width{background-color:#eac653b3;border:1px solid #eac653;height:6px}.checkbox-indicator.perimeter-extrusion-width{background-color:#b94d62b3;border:1px solid #b94d62;height:6px}.checkbox-indicator.overlap{background-color:#6038d7b3;border:1px solid #6038d7}.checkbox-indicator.success{background-color:var(--color-success, #4caf50)}.checkbox-indicator.warning{background-color:var(--color-warning, #ff9800)}.checkbox-indicator.error{background-color:var(--color-error, #f44336)}.checkbox-label-text{flex:1}.select-input{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.select-input.inline{flex-direction:row;align-items:center;gap:var(--spacing-sm, 8px)}.select-label{font-size:var(--font-size-sm, 11px);color:var(--color-text-secondary, #858585)}.select-input.inline .select-label{white-space:nowrap}.select-field{height:var(--input-height-md, 28px);padding:0 var(--spacing-sm, 8px);font-size:var(--font-size-md, 12px);color:var(--color-text-primary, #d4d4d4);background-color:var(--color-bg-tertiary, #252526);border:var(--border-width, 1px) solid var(--color-border, #3e3e42);border-radius:var(--radius-sm, 3px);outline:none;cursor:pointer;flex:1}.select-field:focus{border-color:var(--color-border-focus, #007acc)}.select-field:disabled{opacity:.5;cursor:not-allowed}.select-field option{background-color:var(--color-bg-secondary, #2d2d30);color:var(--color-text-primary, #d4d4d4)}.select-field option:disabled{color:var(--color-text-secondary, #858585)}.settings-section{border-bottom:var(--border-width, 1px) solid var(--color-border, #3e3e42)}.settings-section:last-child{border-bottom:none}.settings-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm, 8px) var(--spacing-md, 12px);background-color:var(--color-bg-tertiary, #252526);-webkit-user-select:none;user-select:none}.settings-section-header.clickable{cursor:pointer}.settings-section-header.clickable:hover{background-color:var(--color-bg-hover, #3c3c3c)}.settings-section-title-wrapper{display:flex;align-items:center;gap:var(--spacing-sm, 8px)}.settings-section-icon{color:var(--color-text-secondary, #858585);font-size:var(--font-size-lg, 14px)}.settings-section-title{font-size:var(--font-size-md, 12px);font-weight:var(--font-weight-medium, 500);color:var(--color-text-primary, #d4d4d4)}.settings-section-badge{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #858585);background-color:var(--color-bg-hover, #3c3c3c);padding:2px 6px;border-radius:var(--radius-sm, 3px)}.settings-section-chevron{color:var(--color-text-secondary, #858585);font-size:var(--font-size-xs, 10px);transition:transform var(--transition-fast, .1s ease)}.settings-section-chevron.expanded{transform:rotate(90deg)}.settings-section-content{padding:var(--spacing-md, 12px);display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.collapsible{border:var(--border-width, 1px) solid var(--color-border, #3e3e42);border-radius:var(--radius-md, 4px);overflow:hidden}.collapsible-header{display:flex;align-items:center;gap:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px) var(--spacing-md, 12px);background-color:var(--color-bg-tertiary, #252526);cursor:pointer;-webkit-user-select:none;user-select:none}.collapsible-header:hover{background-color:var(--color-bg-hover, #3c3c3c)}.collapsible-chevron{color:var(--color-text-secondary, #858585);font-size:var(--font-size-xs, 10px);transition:transform var(--transition-fast, .1s ease);flex-shrink:0}.collapsible.expanded .collapsible-chevron{transform:rotate(90deg)}.collapsible-header-content{flex:1;font-size:var(--font-size-md, 12px);color:var(--color-text-primary, #d4d4d4)}.collapsible-body{background-color:var(--color-bg-secondary, #2d2d30)}.collapsible-body.animated{transition:max-height var(--transition-normal, .2s ease)}.collapsible-content{padding:var(--spacing-md, 12px)}.number-input{display:flex;flex-direction:column;gap:6px}.number-input-label{font-size:13px;color:#d4d4d4;font-weight:500}.number-input-controls{display:flex;gap:4px}.number-input-button{width:32px;height:32px;background-color:#3e3e42;border:1px solid #3e3e42;color:#d4d4d4;font-size:16px;border-radius:4px;cursor:pointer;transition:background-color .2s}.number-input-button:hover:not(:disabled){background-color:#4e4e52}.number-input-button:disabled{opacity:.5;cursor:not-allowed}.number-input-field{flex:1;height:32px;background-color:#2d2d30;border:1px solid #3e3e42;color:#d4d4d4;font-size:13px;padding:0 8px;border-radius:4px;text-align:center}.number-input-field:focus{outline:none;border-color:var(--color-primary)}.number-input-field::-webkit-inner-spin-button,.number-input-field::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.number-input-field[type=number]{-moz-appearance:textfield}.text-input{display:flex;flex-direction:column;gap:6px}.text-input-label{font-size:13px;color:#d4d4d4;font-weight:500}.text-input-field{height:32px;background-color:#2d2d30;border:1px solid #3e3e42;color:#d4d4d4;font-size:13px;padding:0 10px;border-radius:4px}.text-input-field:focus{outline:none;border-color:var(--color-primary)}.text-input-field::placeholder{color:#6e6e6e}.text-input-field:disabled{opacity:.5;cursor:not-allowed}.toast{position:fixed;bottom:24px;right:24px;min-width:300px;max-width:500px;padding:16px;border-radius:4px;box-shadow:0 4px 12px #0006;z-index:10000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background-color:#2d5a2d;border-left:4px solid #4caf50}.toast-error{background-color:#5a2d2d;border-left:4px solid #f44336}.toast-warning{background-color:#5a4d2d;border-left:4px solid #ff9800}.toast-info{background-color:#2d3d5a;border-left:4px solid #2196f3}.toast-content{display:flex;align-items:center;justify-content:space-between;gap:16px}.toast-message{color:#fff;font-size:14px;line-height:1.4;flex:1}.toast-close{background:none;border:none;color:#fff;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s}.toast-close:hover{opacity:1}.log-panel{position:fixed;bottom:16px;right:16px;max-width:400px;background-color:#f44336;color:#fff;border-radius:4px;box-shadow:0 4px 6px #0000004d;z-index:1000}.log-panel-content{display:flex;align-items:flex-start;padding:12px 16px;gap:12px}.log-panel-message{flex:1;font-size:14px;line-height:1.4}.log-panel-close{background:none;border:none;color:#fff;font-size:24px;line-height:1;padding:0;cursor:pointer;opacity:.8;transition:opacity .2s}.log-panel-close:hover{opacity:1}.error-boundary-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;height:100%;min-height:200px;background:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;color:#ccc;text-align:center}.error-boundary-icon{width:48px;height:48px;line-height:48px;font-size:24px;font-weight:700;background:#b94d62;color:#fff;border-radius:50%;margin-bottom:1rem}.error-boundary-title{font-size:1.1rem;font-weight:500;margin-bottom:.5rem;color:#e0e0e0}.error-boundary-message{font-size:.85rem;color:#888;margin-bottom:1rem;max-width:300px;word-break:break-word}.error-boundary-retry{padding:.5rem 1rem;font-size:.85rem;background:#0e639c;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.error-boundary-retry:hover{background:#17b}.dialog-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog-container{background-color:#2a2a2d;border:1px solid #3e3e42;border-radius:8px;padding:20px;box-shadow:0 4px 20px #0006;max-height:80vh;overflow-y:auto}.dialog-small{width:280px;min-width:280px}.dialog-medium{width:360px;min-width:320px}.dialog-large{width:480px;min-width:400px}.dialog-title{margin:0 0 16px;font-size:16px;font-weight:600;color:#fff}.dialog-content{margin-bottom:20px}.dialog-content .param-group{margin-bottom:12px}.dialog-content .param-group:last-child{margin-bottom:0}.dialog-content .param-group label{display:block;font-size:12px;color:#ccc;margin-bottom:6px}.dialog-content .param-group input[type=number],.dialog-content .param-group input[type=text],.dialog-content .param-group select{width:100%;padding:8px 10px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;color:#fff;font-size:13px;box-sizing:border-box}.dialog-content .param-group input:focus,.dialog-content .param-group select:focus{outline:none;border-color:#6038d7}.dialog-content .param-group small{display:block;font-size:11px;color:#858585;margin-top:4px}.dialog-buttons{display:flex;gap:8px;justify-content:flex-end}.dialog-buttons button{min-width:80px}.param-group{margin-bottom:12px}.param-group:last-child{margin-bottom:0}.param-group label{display:block;font-size:12px;color:#ccc;margin-bottom:6px}.param-group input[type=number],.param-group input[type=text],.param-group select{width:100%;padding:8px 10px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;color:#fff;font-size:13px;box-sizing:border-box}.param-group input:focus,.param-group select:focus{outline:none;border-color:#6038d7}.param-group small{display:block;font-size:11px;color:#858585;margin-top:4px}.param-group.horizontal{display:flex;align-items:center;gap:12px}.param-group.horizontal label{margin-bottom:0;min-width:100px;flex-shrink:0}.param-group.horizontal input,.param-group.horizontal select{flex:1}.param-group.horizontal small{flex-basis:100%;margin-top:4px}.printer-selection-tab{display:flex;flex-direction:column;gap:24px}.subsection-title{font-size:12px;font-weight:600;color:#a0a0a0;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.custom-printer-section{display:flex;flex-direction:column;gap:12px;padding:12px;background:#6038d70d;border:1px solid rgba(96,56,215,.2);border-radius:4px;margin-top:8px}.printer-info{font-size:13px;color:#9e9e9e;padding:8px 0;display:flex;flex-direction:column;gap:4px}.input-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px}.printhead-temp-list{display:flex;flex-direction:column;gap:8px}.printhead-temp-row{display:flex;align-items:center;gap:8px}.printhead-label{font-size:12px;font-weight:500;color:#a0a0a0;min-width:30px}.delete-confirm{margin-top:8px;padding:12px;background:#ff4d4d1a;border:1px solid rgba(255,77,77,.3);border-radius:4px}.delete-confirm p{margin:0 0 12px;color:#ff6b6b;font-size:13px}.add-printer-section{display:flex;flex-direction:column;gap:12px;padding:12px;background:#6038d70d;border:1px solid rgba(96,56,215,.2);border-radius:4px}.template-list{display:flex;flex-direction:column;gap:8px}.template-label{font-size:12px;color:#a0a0a0;font-weight:500}.info-message{margin-bottom:8px;padding:8px 12px;background:#6038d71a;border:1px solid rgba(96,56,215,.3);border-radius:4px;color:#a0a0ff;font-size:13px}.validation-error{margin-top:-8px;margin-bottom:4px;padding:4px 8px;color:#ff6b6b;font-size:12px}.validation-hint{padding:4px 8px;color:#fa0;font-size:12px;text-align:center}.placeholder-section{padding:16px;background:#ffffff08;border:1px dashed #3e3e42;border-radius:4px}.placeholder-text{font-size:12px;color:#6e6e6e;text-align:center;font-style:italic}.file-upload{display:flex;flex-direction:column;gap:8px}.file-upload-hint{font-size:12px;color:#858585;text-align:center}.mesh-info{background-color:#2d2d30;border-radius:4px;padding:12px;display:flex;flex-direction:column;gap:8px}.mesh-info-row{display:flex;justify-content:space-between;font-size:13px}.mesh-info-label{color:#858585;font-weight:500}.mesh-info-value{color:#d4d4d4;text-align:right}.model-loading-tab{display:flex;flex-direction:column;gap:24px}.shape-generator-section{margin-top:12px;display:flex;flex-direction:column;gap:12px;padding:12px;background:#6038d70d;border:1px solid rgba(96,56,215,.2);border-radius:4px}.shape-parameters{display:flex;flex-direction:column;gap:12px}.button-group{display:flex;flex-direction:column;gap:8px}.error-message{margin-top:8px;padding:8px 12px;background:#ff4d4d1a;border:1px solid rgba(255,77,77,.3);border-radius:4px;color:#ff4d4d;font-size:13px}.layer-pattern-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px)}.groups-list{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.group-row{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px);padding:var(--spacing-sm, 8px);background:#1e1e2280;border-radius:var(--radius-md, 4px);border:1px solid var(--color-border, #3e3e42)}.group-header{display:flex;align-items:center;justify-content:space-between}.group-label{font-size:var(--font-size-sm, 11px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-secondary, #888)}.group-name-input{flex:1;padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background:var(--color-bg-tertiary, #252526);border:1px solid var(--color-border, #3e3e42);border-radius:var(--radius-sm, 3px);color:var(--color-text-primary, #ccc);font-size:var(--font-size-sm, 11px)}.group-name-input:focus{outline:none;border-color:var(--color-primary, #6038d7)}.group-actions{display:flex;align-items:center;gap:var(--spacing-xs, 4px);margin-left:auto}.group-move-btn{width:20px;height:20px;padding:0;background:transparent;border:1px solid var(--color-border, #3e3e42);color:var(--color-text-secondary, #888);font-size:12px;cursor:pointer;border-radius:var(--radius-sm, 3px);transition:all .15s ease;display:flex;align-items:center;justify-content:center}.group-move-btn:hover:not(:disabled){background:#6038d733;border-color:var(--color-primary, #6038d7);color:var(--color-primary, #6038d7)}.group-move-btn:disabled{opacity:.3;cursor:not-allowed}.group-remove-btn{width:20px;height:20px;padding:0;background:transparent;border:none;color:var(--color-text-secondary, #888);font-size:16px;cursor:pointer;border-radius:var(--radius-sm, 3px);transition:all .15s ease}.group-remove-btn:hover:not(:disabled){background:#b94d6233;color:#b94d62}.group-remove-btn:disabled{opacity:.3;cursor:not-allowed}.group-fields{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.group-fields .select-input,.group-fields>.number-input{display:inline-flex}.group-settings-row{display:flex;align-items:flex-end;gap:var(--spacing-sm, 8px)}.group-settings-row>*{flex:1}.layer-height-info{font-size:var(--font-size-xs, 10px);color:var(--color-info, #29b6f6);background:#29b6f61a;padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);border-radius:var(--radius-sm, 3px);margin-top:var(--spacing-xs, 4px)}.layer-height-status{display:flex;align-items:center;gap:var(--spacing-sm, 8px);margin-top:var(--spacing-xs, 4px);font-size:var(--font-size-xs, 10px)}.layer-height-status .status-text{padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);border-radius:var(--radius-sm, 3px)}.layer-height-status .status-text.auto{color:var(--color-info, #29b6f6);background:#29b6f61a}.layer-height-status .status-text.manual{color:var(--color-warning, #eac653);background:#eac6531a}.reload-material-btn{padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background:transparent;border:1px solid var(--color-border, #3e3e42);border-radius:var(--radius-sm, 3px);color:var(--color-text-secondary, #888);font-size:var(--font-size-xs, 10px);cursor:pointer;transition:all .15s ease}.reload-material-btn:hover{background:#29b6f61a;border-color:var(--color-info, #29b6f6);color:var(--color-info, #29b6f6)}.layer-range{display:flex;align-items:center;gap:var(--spacing-xs, 4px)}.layer-range .number-input{flex:1}.range-separator{color:var(--color-text-secondary, #888);font-size:var(--font-size-sm, 11px)}.add-group-btn{padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background:transparent;border:1px dashed var(--color-border, #3e3e42);border-radius:var(--radius-md, 4px);color:var(--color-text-secondary, #888);font-size:var(--font-size-sm, 11px);cursor:pointer;transition:all .15s ease}.add-group-btn:hover{background:#6038d71a;border-color:var(--color-primary, #6038d7);color:var(--color-primary, #6038d7)}.layers-by-printhead{margin-top:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px);background:#1e1e2280;border-radius:var(--radius-md, 4px);border:1px solid var(--color-border, #3e3e42)}.layers-by-printhead .summary-label{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888);margin-bottom:var(--spacing-xs, 4px)}.layers-by-printhead .summary-items{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.layers-by-printhead .summary-item{display:flex;align-items:center;gap:var(--spacing-sm, 6px)}.layers-by-printhead .summary-color{width:12px;height:12px;border-radius:var(--radius-full, 50%);flex-shrink:0}.layers-by-printhead .summary-text{font-size:var(--font-size-sm, 11px);color:var(--color-text-primary, #ccc)}.layer-preview{margin-top:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px);background:#1e1e2280;border-radius:var(--radius-md, 4px);border:1px solid var(--color-border, #3e3e42)}.preview-label{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888);margin-bottom:var(--spacing-xs, 4px)}.preview-layers{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.preview-layer{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, 3px);font-size:var(--font-size-xs, 10px);font-weight:var(--font-weight-semibold, 600);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);cursor:default}.preview-ellipsis{color:var(--color-text-secondary, #888);font-size:var(--font-size-sm, 11px);margin-left:var(--spacing-xs, 4px)}.uniform-config{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.uniform-config .mode-toggle-row{display:flex;align-items:center;gap:var(--spacing-sm, 8px)}.uniform-config .mode-label{font-size:var(--font-size-sm, 11px);color:var(--color-text-secondary, #888)}.uniform-config .mode-btn{padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background:var(--color-bg-tertiary, #252526);border:1px solid var(--color-border, #3e3e42);border-radius:var(--radius-sm, 3px);color:var(--color-text-secondary, #888);font-size:var(--font-size-xs, 10px);cursor:pointer;transition:all .15s ease}.uniform-config .mode-btn:hover{border-color:var(--color-primary, #6038d7);color:var(--color-text-primary, #ccc)}.uniform-config .mode-btn.active{background:var(--color-primary, #6038d7);border-color:var(--color-primary, #6038d7);color:#fff}.uniform-config .layer-height-source{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888);font-style:italic;margin-left:var(--spacing-sm, 8px)}.uniform-config .model-height-info{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888);padding:var(--spacing-xs, 4px) 0}.alternating-config,.grouped-config{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px);background:#6038d70d;border-radius:var(--radius-md, 4px);border-left:3px solid var(--color-primary, #6038d7)}.slicing-settings{display:flex;flex-direction:column;gap:12px}.slicing-settings .mode-toggle-row{display:flex;align-items:center;gap:8px}.slicing-settings .mode-label{font-size:12px;color:var(--text-secondary, #888)}.slicing-settings .mode-btn{padding:4px 12px;background:var(--bg-tertiary, #3e3e42);color:var(--text-secondary, #888);border:1px solid var(--border-color, #4e4e52);border-radius:4px;font-size:12px;cursor:pointer;transition:all .15s ease}.slicing-settings .mode-btn:hover{background:var(--bg-hover, #4e4e52)}.slicing-settings .mode-btn.active{background:var(--accent-color, #4a9eff);color:#fff;border-color:var(--accent-color, #4a9eff)}.slicing-settings .layer-height-source{font-size:12px;color:var(--text-tertiary, #666);font-style:italic;margin-top:-8px}.slicing-settings .model-height-info{font-size:12px;color:var(--text-tertiary, #666);padding:4px 0;border-top:1px solid var(--border-color, #3e3e42);margin-top:4px}.printhead-settings{display:flex;flex-direction:column;gap:16px}.printhead-list{display:flex;flex-direction:column;gap:8px}.printhead-header{display:grid;grid-template-columns:60px 1fr 1fr 28px;gap:8px;font-size:11px;font-weight:600;color:var(--text-secondary, #888);text-transform:uppercase;padding-bottom:4px;border-bottom:1px solid var(--border-color, #333)}.printhead-row{display:grid;grid-template-columns:60px 1fr 1fr 28px;gap:8px;align-items:center}.printhead-label{font-weight:600;font-size:13px}.printhead-material-select,.printhead-nozzle-select{width:100%}.printhead-material-select .select-field,.printhead-nozzle-select .select-field{font-size:12px;padding:4px 8px}.printhead-remove-btn{width:24px;height:24px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--text-secondary, #888);font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.printhead-remove-btn:hover:not(:disabled){background:var(--danger-bg, rgba(220, 53, 69, .15));color:var(--danger-color, #dc3545)}.printhead-remove-btn:disabled{opacity:.3;cursor:not-allowed}.printhead-add-btn{margin-top:4px;padding:6px 12px;border:1px dashed var(--border-color, #444);border-radius:4px;background:transparent;color:var(--text-secondary, #888);font-size:12px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.printhead-add-btn:hover{background:var(--bg-hover, rgba(255, 255, 255, .05));color:var(--text-primary, #fff);border-color:var(--text-secondary, #888)}.layer-height-settings{display:flex;flex-direction:column;gap:8px}.layer-height-header{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;font-size:11px;font-weight:600;color:var(--text-secondary, #888);text-transform:uppercase;padding-bottom:4px;border-bottom:1px solid var(--border-color, #333)}.layer-height-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;align-items:center}.layer-height-row:has(.layer-height-input){grid-template-columns:1fr 2fr}.layer-height-header:has(+.layer-height-row .layer-height-input){grid-template-columns:1fr 2fr}.layer-height-mode-select,.layer-height-source-select,.layer-height-input{width:100%}.layer-height-value{display:flex;flex-direction:column;gap:2px}.layer-height-value .value{font-weight:600;color:var(--accent-color, #4a9eff);font-size:14px}.layer-height-value .source{font-size:11px;color:var(--text-tertiary, #666);font-style:italic}.slicing-tab{display:flex;flex-direction:column;gap:24px}.section-title{font-size:14px;font-weight:600;color:#fff;margin:0;padding-bottom:8px;border-bottom:1px solid #3e3e42}.no-model-message{padding:16px;background:#ff98001a;border:1px solid rgba(255,152,0,.3);border-radius:4px;text-align:center}.no-model-message p{margin:0;color:#ff9800;font-size:14px}.no-model-message .hint{margin-top:8px;color:#888;font-size:12px}.pattern-selector{display:flex;flex-direction:column;gap:6px}.pattern-selector-label{font-size:13px;color:#d4d4d4;font-weight:500}.pattern-selector-select{height:32px;background-color:#2d2d30;border:1px solid #3e3e42;color:#d4d4d4;font-size:13px;padding:0 8px;border-radius:4px;cursor:pointer}.pattern-selector-select:focus{outline:none;border-color:var(--color-primary)}.pattern-selector-select option{background-color:#2d2d30;color:#d4d4d4}.infill-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px)}.advanced-settings{display:flex;flex-direction:column;gap:var(--spacing-lg, 16px);margin-top:var(--spacing-md, 12px);padding:var(--spacing-md, 12px);background-color:var(--color-bg-secondary, #2d2d30);border-radius:var(--radius-md, 4px);border:var(--border-width, 1px) solid var(--color-border, #3e3e42)}.mode-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px);padding-left:var(--spacing-md, 12px);border-left:2px solid var(--color-primary, #007acc)}.grid-fill-section{margin-top:var(--spacing-md, 12px);padding-top:var(--spacing-md, 12px);border-top:1px solid var(--color-border, #3e3e42)}.grid-fill-section .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm, 8px)}.grid-fill-count{font-size:var(--font-size-xs, 10px);color:var(--color-info, #29b6f6);background:#29b6f626;padding:2px 8px;border-radius:var(--radius-sm, 3px)}.grid-fill-controls{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px);background:#1e1e2280;border-radius:var(--radius-md, 4px);border-left:2px solid var(--color-info, #29b6f6)}.droplet-grid-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px);padding:var(--spacing-md, 12px);background:#29b6f61a;border-radius:var(--radius-md, 4px);border-left:3px solid var(--color-info, #29b6f6)}.droplet-count-badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background:#29b6f633;border-radius:var(--radius-sm, 3px);font-size:var(--font-size-sm, 11px);font-weight:var(--font-weight-semibold, 600);color:var(--color-info, #29b6f6)}.grid-droplet-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px);margin-top:var(--spacing-md, 12px);padding:var(--spacing-md, 12px);background:#8044ff1a;border-radius:var(--radius-md, 4px);border-left:3px solid #b388ff}.settings-divider{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--spacing-sm, 8px);border-bottom:1px solid rgba(128,68,255,.3);font-size:var(--font-size-sm, 11px);font-weight:var(--font-weight-semibold, 600);color:#b388ff}.width-settings-section{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px);padding:var(--spacing-sm, 8px);background:#1e1e2280;border-radius:var(--radius-md, 4px);border:1px solid var(--color-border, #3e3e42)}.width-toggle-row{display:flex;align-items:center}.width-toggle-row .checkbox-input{font-size:var(--font-size-sm, 11px)}.width-settings-section .number-input{margin-left:var(--spacing-md, 12px);padding-left:var(--spacing-sm, 8px);border-left:2px solid var(--color-primary, #6038d7)}.rectilinear-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px);margin-top:var(--spacing-sm, 8px);padding:var(--spacing-md, 12px);background:#6038d71a;border-radius:var(--radius-md, 4px);border-left:3px solid var(--color-primary, #6038d7)}.rectilinear-settings .settings-divider{border-bottom-color:#6038d74d;color:#9c7ce8}.rectilinear-info{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888);font-style:italic;padding:var(--spacing-xs, 4px) 0}.extruder-assignment-section{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px);background:#1e1e2280;border-radius:var(--radius-md, 4px);border:1px solid var(--color-border, #3e3e42)}.extruder-assignment-section .settings-divider{border-bottom-color:var(--color-border, #3e3e42);color:var(--color-text-secondary, #888);font-size:var(--font-size-xs, 10px)}.extruder-assignment-section .select-input{flex:1}.dual-lines-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px);padding:var(--spacing-md, 12px);background:#eac6531a;border-radius:var(--radius-md, 4px);border-left:3px solid #eac653}.dual-lines-settings .settings-divider{border-bottom-color:#eac6534d;color:#eac653}.infill-tab{display:flex;flex-direction:column;gap:24px}.infill-tab-placeholder{padding:24px;text-align:center;color:#858585;font-size:14px}.infill-info{padding:12px;background-color:#2d2d30;border-radius:4px;font-size:13px;color:#d4d4d4}.visualization-toggles{display:flex;flex-direction:column;gap:8px}.visualization-toggles .checkbox-input{font-size:13px}.points-tab{display:flex;flex-direction:column;gap:16px;padding:12px}.points-tab-placeholder{padding:20px;text-align:center;color:#888;font-style:italic}.points-tab .section{display:flex;flex-direction:column;gap:8px}.points-tab .section-title{font-size:13px;font-weight:600;color:#d4d4d4;margin:0;padding-bottom:4px;border-bottom:1px solid #3e3e42}.points-tab .section-description{font-size:11px;color:#888;margin:0 0 4px}.points-info{background-color:#2d2d30;border-radius:4px;padding:8px 12px}.info-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px}.info-label{color:#888}.info-value{color:#d4d4d4;font-weight:500}.points-loading{padding:12px;text-align:center;color:#4fc3f7;font-size:12px;background-color:#1e3a5f;border-radius:4px}.points-tab .split-section{margin-top:8px;padding-top:8px;border-top:1px solid #3e3e42}.points-tab .split-combine-buttons{display:flex;gap:8px}.points-tab .split-combine-buttons button{flex:1}.points-tab .section-hint{font-size:11px;color:#888;margin:4px 0 0;font-style:italic}.points-tab .junction-buttons{display:flex;gap:8px;margin-top:4px}.points-tab .junction-buttons button{flex:1}.points-tab .reset-section{margin-top:8px;padding-top:8px;border-top:1px solid #3e3e42}.parameter-analysis-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.parameter-analysis-popup{background:#1e1e22;border:1px solid #3e3e42;border-radius:8px;width:600px;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#28282ccc;border-bottom:1px solid #3e3e42}.popup-header h3{margin:0;font-size:14px;font-weight:500;color:#e0e0e0}.close-btn{background:none;border:none;color:#888;font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.close-btn:hover{color:#fff}.popup-content{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.axis-selectors{display:grid;grid-template-columns:1fr 1fr;gap:16px}.axis-selector{display:flex;flex-direction:column;gap:8px}.axis-selector>label{font-size:11px;font-weight:500;color:#888;text-transform:uppercase}.axis-selector .select-input{width:100%}.range-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:4px}.range-inputs .number-input{font-size:11px}.range-inputs .number-input label{font-size:10px}.range-inputs .number-input input{padding:4px 6px;font-size:11px}.multi-width-controls{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:#28282c80;border-radius:6px}.multi-width-toggle{display:flex;align-items:center;gap:8px;font-size:12px;color:#aaa;cursor:pointer}.multi-width-toggle input{cursor:pointer}.width-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.width-chip{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#3c3c4099;border:2px solid;border-radius:4px;font-size:11px;color:#ccc}.width-chip .remove-width{background:none;border:none;color:#888;font-size:14px;cursor:pointer;padding:0;line-height:1;margin-left:2px}.width-chip .remove-width:hover{color:#d46b7d}.add-width-btn{padding:4px 10px;background:#6038d733;border:1px dashed rgba(96,56,215,.5);border-radius:4px;color:#9c7ce8;font-size:11px;cursor:pointer;transition:all .15s}.add-width-btn:hover{background:#6038d74d;border-style:solid}.chart-container{background:#12121a;border-radius:6px;padding:8px;display:flex;flex-direction:column;align-items:center;gap:8px}.chart-legend{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:8px}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#aaa}.legend-color-box{width:12px;height:12px;border-radius:2px}.analysis-chart{background:#0a0a10;border-radius:4px}.analysis-chart .axis-label{font-size:10px;fill:#666}.analysis-chart .axis-title{font-size:11px;fill:#888;font-weight:500}.current-values{background:#1e1e2280;border-radius:6px;padding:12px}.current-values h4{margin:0 0 8px;font-size:12px;font-weight:500;color:#888}.value-grid{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:6px 12px;font-size:11px}.value-grid span:nth-child(odd){color:#666}.value-grid span:nth-child(2n){color:#ccc;font-weight:500}.analysis-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border:none;border-radius:4px;background:#6038d733;color:#9c7ce8;font-size:11px;cursor:pointer;transition:all .15s}.analysis-btn:hover{background:#6038d74d;color:#b89cf0}.analysis-btn svg{width:14px;height:14px}.parameters-tab.compact{display:flex;flex-direction:column;gap:8px;font-size:12px}.stats-bar{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#1e1e2280;border-radius:4px;font-size:11px;color:#888}.stats-bar .stat{padding:2px 6px;border-radius:3px;font-weight:500}.stats-bar .stat.perimeter{background:#b94d6233;color:#d46b7d}.stats-bar .stat.infill{background:#eac65333;color:#eac653}.stats-bar .stat.gridfill{background:#29b6f633;color:#29b6f6}.stats-bar .checkbox-input{font-size:10px}.stats-bar .analysis-btn{margin-left:auto;display:flex;align-items:center;gap:4px;padding:3px 8px;border:none;border-radius:3px;background:#6038d733;color:#9c7ce8;font-size:10px;cursor:pointer;transition:all .15s}.stats-bar .analysis-btn:hover{background:#6038d74d;color:#b89cf0}.stats-bar .analysis-btn svg{width:12px;height:12px}.section-header{display:flex;align-items:center;gap:6px;padding:6px 8px;background:#3c3c3c4d;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;color:#d4d4d4;-webkit-user-select:none;user-select:none}.section-header:hover{background:#46464666}.toggle-icon{font-size:8px;color:#888;width:10px}.selection-badge{margin-left:auto;padding:2px 6px;background:#6464ff4d;border-radius:3px;font-size:10px;color:#aaf}.param-target{margin-left:auto;display:flex;gap:4px}.target-badge{padding:2px 5px;border-radius:3px;font-size:10px;font-weight:500}.target-badge.perimeter{background:#b94d624d;color:#d46b7d}.target-badge.infill{background:#eac6534d;color:#eac653}.target-badge.gridfill{background:#29b6f64d;color:#29b6f6}.segment-section{display:flex;flex-direction:column;gap:6px}.select-buttons{display:flex;gap:4px}.mini-btn{flex:1;padding:4px 6px;border:none;border-radius:3px;background:#3c3c3c80;color:#aaa;font-size:10px;cursor:pointer;transition:all .15s}.mini-btn:hover{background:#50505099;color:#fff}.mini-btn.perimeter:hover{background:#b94d624d;color:#d46b7d}.mini-btn.infill:hover{background:#eac6534d;color:#eac653}.mini-btn.gridfill:hover{background:#29b6f64d;color:#29b6f6}.segment-list{display:flex;flex-wrap:wrap;gap:4px;max-height:150px;overflow-y:auto;padding:4px;background:#1414184d;border-radius:4px}.segment-item{display:flex;align-items:center;gap:4px;padding:3px 6px;border-radius:3px;background:#32323680;border:1px solid transparent;cursor:pointer;font-size:10px;color:#888;transition:all .15s}.segment-item:hover{background:#46464a99;color:#ccc}.segment-item.perimeter{border-left:2px solid #b94d62}.segment-item.infill{border-left:2px solid #eac653}.segment-item.gridfill{border-left:2px solid #29b6f6}.segment-item.selected{background:#6464ff33;border-color:#6464ff80;color:#fff}.segment-item.selected.perimeter{background:#b94d6240;border-color:#b94d6299}.segment-item.selected.infill{background:#eac65340;border-color:#eac65399}.segment-item.selected.gridfill{background:#29b6f640;border-color:#29b6f699}.seg-type{font-weight:600;width:10px}.segment-item.perimeter .seg-type{color:#d46b7d}.segment-item.infill .seg-type{color:#eac653}.segment-item.gridfill .seg-type{color:#29b6f6}.seg-info{color:#aaa}.seg-extruder{font-size:9px;font-weight:600}.seg-points{color:#666;font-size:9px}.params-section{display:flex;flex-direction:column;gap:8px;padding:8px;background:#1e1e224d;border-radius:4px}.apply-section{display:flex;justify-content:center;padding-bottom:8px;border-bottom:1px solid #3e3e42;margin-bottom:4px}.apply-section .apply-btn{flex:1;padding:8px 16px;font-size:12px;font-weight:600}.param-row{display:flex;align-items:center;gap:8px}.param-row label{font-size:11px;color:#888;min-width:24px}.extruder-row{padding-bottom:6px;border-bottom:1px solid #3e3e42}.extruder-btns{display:flex;gap:4px;flex:1}.ext-btn{flex:1;padding:6px 8px;border:2px solid transparent;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;opacity:.6}.ext-btn:hover{opacity:.9;transform:translateY(-1px)}.ext-btn.active{opacity:1;border-color:#fff;box-shadow:0 0 6px #fff3}.ext-btn.ext-0{background:linear-gradient(135deg,#b94d62,#8a3949);color:#fff}.ext-btn.ext-1{background:linear-gradient(135deg,#eac653,#c4a43f);color:#111}.ext-btn.ext-2{background:linear-gradient(135deg,#6038d7,#4c2cb0);color:#fff}.ext-btn.ext-3{background:linear-gradient(135deg,#242d75,#1a2058);color:#fff}.ext-btn.more-btn,.ext-btn.collapse-btn{flex:0 0 auto;width:28px;padding:6px 0;background:#50505066;color:#aaa;font-size:14px;font-weight:400}.ext-btn.more-btn:hover,.ext-btn.collapse-btn:hover{background:#64646480;color:#fff}.ext-btn.collapse-btn{font-size:16px;line-height:1}.param-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.param-grid .number-input{font-size:11px}.param-grid .number-input label{font-size:10px}.param-grid .number-input input{padding:4px 6px;font-size:11px}.param-subsection{margin-top:8px;padding-top:8px;border-top:1px solid rgba(100,100,100,.3)}.param-subsection-header{font-size:10px;font-weight:500;color:#888;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.extrusion-mode-section{margin-top:8px;padding-top:8px;border-top:1px solid rgba(100,100,100,.3)}.mode-toggle{display:flex;gap:4px;margin-bottom:10px}.mode-btn{flex:1;padding:6px 10px;background:#3c3c4199;border:1px solid rgba(100,100,100,.3);color:#999;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.mode-btn:hover{background:#50505599;color:#ccc}.mode-btn.active{background:#6038d74d;border-color:#6038d780;color:#9c7ce8}.mode-btn.pending{box-shadow:0 0 0 2px #ffaa0080}.sync-buttons{display:flex;gap:6px;margin-top:4px}.sync-btn{flex:1;padding:5px 8px;border:none;border-radius:3px;background:#3c3c3c80;color:#aaa;font-size:10px;cursor:pointer;transition:all .15s}.sync-btn:hover{background:#50505099;color:#fff}.summary-section{display:flex;flex-direction:column;gap:4px;padding:6px 8px;background:#1e1e224d;border-radius:4px}.summary-row{display:flex;align-items:center;gap:8px;font-size:10px;color:#888}.summary-label{font-weight:500;min-width:55px}.summary-label.perimeter{color:#d46b7d}.summary-label.infill{color:#eac653}.ext-badge{padding:2px 5px;border-radius:3px;font-size:9px;font-weight:600}.ext-badge.ext-0{background:#b94d624d;color:#d46b7d}.ext-badge.ext-1{background:#44ff444d;color:#6f6}.ext-badge.ext-2{background:#eac6534d;color:#eac653}.ext-badge.ext-3{background:#ffaa444d;color:#fb6}.no-paths-message{padding:16px;background:#ff98001a;border:1px solid rgba(255,152,0,.3);border-radius:4px;text-align:center}.no-paths-message p{margin:0;color:#ff9800;font-size:13px}.no-paths-message .hint{display:block;margin-top:4px;color:#888;font-size:11px}.segment-list::-webkit-scrollbar{width:6px}.segment-list::-webkit-scrollbar-track{background:#1e1e224d;border-radius:3px}.segment-list::-webkit-scrollbar-thumb{background:#64646480;border-radius:3px}.segment-list::-webkit-scrollbar-thumb:hover{background:#78787899}.droplet-conversion{display:flex;flex-direction:column;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid #3e3e42}.droplet-controls{display:flex;align-items:flex-end;gap:8px}.droplet-controls .number-input{flex:1;font-size:11px}.droplet-controls .number-input label{font-size:10px}.droplet-controls .number-input input{padding:4px 6px;font-size:11px}.droplet-btn{background:#8044ff4d!important;color:#b388ff!important}.droplet-btn:hover:not(:disabled){background:#8044ff80!important;color:#d4b8ff!important}.droplet-btn:disabled{opacity:.4;cursor:not-allowed}.droplet-info{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:#8044ff26;border-radius:4px;font-size:11px;color:#b388ff}.clear-droplets{background:#b94d6233!important;color:#d46b7d!important;padding:2px 8px!important}.clear-droplets:hover{background:#b94d6266!important;color:#e08899!important}.reverse-btn{background:#fa43!important;color:#fb6!important}.reverse-btn:hover:not(:disabled){background:#fa46!important;color:#fd8!important}.reverse-btn:disabled{opacity:.4;cursor:not-allowed}.apply-btn{background:#44c8444d!important;color:#6c6!important}.apply-btn:hover:not(:disabled){background:#44c84480!important;color:#8d8!important}.apply-btn:disabled{opacity:.4;cursor:not-allowed}.apply-btn.has-pending{background:#ffc84466!important;color:#fd6!important;animation:pending-pulse 1.5s ease-in-out infinite}.apply-btn.has-pending:hover:not(:disabled){background:#ffc84499!important;color:#fe8!important}@keyframes pending-pulse{0%,to{opacity:1}50%{opacity:.7}}.param-grid.has-pending .number-input.pending{position:relative}.param-grid.has-pending .number-input.pending:after{content:"";position:absolute;inset:0;border:2px solid rgba(255,200,68,.6);border-radius:4px;pointer-events:none}.param-grid.has-pending .number-input.pending .number-input-field{background:#ffc84426;color:#fd6}.param-grid.has-pending .number-input.pending .number-input-label{color:#fd6}.extruder-row.has-pending{position:relative}.extruder-row.has-pending:before{content:"⏳";position:absolute;right:-20px;top:50%;transform:translateY(-50%);font-size:12px}.ext-btn.pending{box-shadow:0 0 0 3px #ffc844cc!important;animation:pending-pulse 1.5s ease-in-out infinite}.segment-group{display:flex;flex-direction:column;width:100%;margin-top:4px;border-radius:4px;background:#28283266;border:1px solid rgba(100,100,120,.2);overflow:hidden}.segment-group.selected{border-color:#6464ff80;background:#3c3c5066}.segment-group.partial{border-color:#6464ff4d}.segment-group-header{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#3c3c4680;cursor:pointer;font-size:10px;color:#999;transition:all .15s}.segment-group-header:hover{background:#50505a99;color:#ccc}.segment-group.selected .segment-group-header{background:#64649666;color:#aaf}.group-icon{font-size:9px;color:#777}.group-label{font-weight:500}.group-check{margin-left:auto;color:#6f6;font-size:11px}.segment-group-items{display:flex;flex-wrap:wrap;gap:3px;padding:4px 6px 6px 16px}.segment-item.in-group{font-size:9px;padding:2px 5px}.segment-item.in-group .seg-type{width:8px;font-size:9px}.segment-item.in-group .seg-info{font-size:9px}.segment-item.in-group .seg-extruder,.segment-item.in-group .seg-points{font-size:8px}.split-btn{background:#44a8ff33!important;color:#68b8ff!important}.split-btn:hover:not(:disabled){background:#44a8ff66!important;color:#88d8ff!important}.split-btn:disabled{opacity:.4;cursor:not-allowed}.visualization-options{display:flex;gap:12px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(100,100,100,.3)}.visualization-options .checkbox-input{font-size:11px}.visualization-options .checkbox-input.pending{color:#fd6}.visualization-options .checkbox-input.pending input[type=checkbox]{box-shadow:0 0 0 2px #ffc84499}.path-mode-section{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(100,100,100,.3)}.path-mode-label{font-size:11px;color:#a0a0a0;white-space:nowrap}.path-mode-btns{display:flex;gap:4px;flex:1}.path-mode-btn{flex:1;padding:4px 8px;font-size:10px;border:1px solid #555;border-radius:3px;background:#2d2d30;color:silver;cursor:pointer;transition:all .15s ease}.path-mode-btn:hover{background:#3d3d40;border-color:#666}.path-mode-btn.active{background:linear-gradient(135deg,#48f,#36c);border-color:#59f;color:#fff;font-weight:500}.export-settings{display:flex;flex-direction:column;gap:var(--spacing-md, 12px)}.filename-input{display:flex;flex-direction:column;gap:4px}.filename-input label{font-size:11px;color:#888;text-transform:uppercase;font-weight:500}.filename-input input{padding:8px 10px;background:#1e1e22cc;border:1px solid #3e3e42;border-radius:4px;color:#e0e0e0;font-size:13px;font-family:inherit}.filename-input input:focus{outline:none;border-color:var(--color-primary)}.filename-input input::placeholder{color:#666}.speed-preview{display:flex;gap:16px;padding:8px 10px;background:#6038d71a;border-radius:4px;font-size:11px;color:#9c7ce8}.export-tab{display:flex;flex-direction:column;gap:24px}.export-tab-placeholder{padding:24px;text-align:center;color:#858585;font-size:14px}.export-buttons{display:flex;flex-direction:column;gap:8px}.buffer-settings{margin-bottom:12px}.buffer-settings-header{color:#6038d7;font-size:12px}.buffer-settings-content{padding:12px;background:#6038d70d;border:1px solid rgba(96,56,215,.2);border-radius:4px}.buffer-settings .param-group{margin-bottom:8px}.buffer-settings .param-group:last-child{margin-bottom:0}.buffer-settings .param-group label{font-size:11px;color:#fff;display:block;margin-bottom:4px}.buffer-settings .param-group select,.buffer-settings .param-group input[type=number]{width:100%;padding:6px 8px;background:#2a2a2d;border:1px solid #3e3e42;border-radius:3px;color:#fff;font-size:12px;box-sizing:border-box}.buffer-settings .param-group small{font-size:10px;color:#858585;margin-top:4px}.pattern-parameters-panel{background-color:#2d2d30;border-radius:4px;padding:16px;margin-bottom:16px}.pattern-parameters-panel h4{margin:0 0 16px;font-size:14px;color:#fff;font-weight:600}.pattern-type-selector{margin-bottom:16px}.pattern-type-selector label{display:block;font-size:12px;color:#d4d4d4;font-weight:500;margin-bottom:6px}.pattern-select{width:100%;padding:6px 8px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:3px;color:#d4d4d4;font-size:13px;font-family:inherit;cursor:pointer}.pattern-select:focus{outline:none;border-color:var(--color-primary)}.pattern-params-content{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.params-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.param-group{display:flex;flex-direction:column;gap:4px}.param-group.full-width{grid-column:1 / -1}.param-group label{font-size:12px;color:#d4d4d4;font-weight:500}.param-group input[type=number],.param-group select{padding:6px 8px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:3px;color:#d4d4d4;font-size:13px;font-family:inherit}.param-group input[type=number]:focus,.param-group select:focus{outline:none;border-color:var(--color-primary)}.param-group select{cursor:pointer}.pattern-hint{font-size:11px;color:#858585;font-style:italic;text-align:center;padding:8px;background-color:#1e1e1e;border-radius:3px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:12px;color:#d4d4d4;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.checkbox-label span{font-weight:500}.template-panel{display:flex;flex-direction:column;gap:16px}.template-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.template-controls label{font-size:13px;font-weight:500;color:#d4d4d4}.template-select{flex:1;min-width:150px;padding:6px 10px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;color:#d4d4d4;font-size:13px;cursor:pointer}.template-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.custom-dimensions{padding:12px;background-color:#2d2d30;border-radius:4px;border:1px solid #3e3e42}.custom-dimensions h4{margin:0 0 12px;font-size:13px;font-weight:600;color:#fff}.dimension-inputs{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.input-group{display:flex;align-items:center;gap:8px}.input-group label{font-size:13px;color:#d4d4d4;min-width:70px}.input-group input[type=number]{flex:1;padding:6px 10px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;color:#d4d4d4;font-size:13px}.input-group input[type=number]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.template-info{padding:12px;background-color:#2d2d30;border-radius:4px;border:1px solid #3e3e42}.template-info p{margin:4px 0;font-size:13px;color:#d4d4d4}.template-info strong{color:#fff}.path-drawing-tab{display:flex;height:100%;width:100%}.path-drawing-controls{width:100%;background-color:#252526;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.section{display:flex;flex-direction:column;gap:12px}.section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0;margin-bottom:0;transition:background-color .2s;border-radius:4px}.section-header:hover{background-color:#ffffff0d}.section-title{margin:0;font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;padding-bottom:8px;border-bottom:1px solid #3e3e42}.section-header .section-title{padding-bottom:0;border-bottom:none}.section-content{margin-top:12px}.tool-buttons{display:flex;flex-direction:column;gap:8px}.tool-buttons-compact{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.compact-section{gap:8px}.pattern-buttons{display:flex;flex-direction:column;gap:8px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;color:#d4d4d4;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label:hover{color:#fff}.path-count{padding:12px;background-color:#2d2d30;border-radius:4px;font-size:13px;color:#d4d4d4;text-align:center}.path-list-section{flex:1;display:flex;flex-direction:column;min-height:300px;max-height:500px}.path-list-section h3{margin-bottom:12px}.path-drawing-controls::-webkit-scrollbar{width:10px}.path-drawing-controls::-webkit-scrollbar-track{background:#1e1e1e}.path-drawing-controls::-webkit-scrollbar-thumb{background:#424242;border-radius:5px}.path-drawing-controls::-webkit-scrollbar-thumb:hover{background:#4e4e4e}.control-panel{position:relative;flex-shrink:0;min-width:300px;max-width:800px;height:100%;display:flex;flex-direction:column;background-color:#252526;border-right:1px solid #3e3e42;z-index:100}.tab-content{flex:1;overflow-y:auto;padding:16px}.resize-handle{position:absolute;top:0;right:0;width:8px;height:100%;cursor:col-resize;z-index:10000;background:transparent;pointer-events:auto;touch-action:none}.resize-handle:after{content:"";position:absolute;top:0;right:0;width:2px;height:100%;background:var(--border-color, #3e3e42);transition:background .15s}.resize-handle:hover:after,.resize-handle.resizing:after{background:var(--color-primary, #4a9eff)}.compatibility-overlay{position:absolute;top:50%;left:0;transform:translateY(-50%);z-index:10;display:flex;align-items:center}.compatibility-collapse-tab{display:flex;align-items:center;justify-content:center;width:24px;min-height:80px;background-color:#1e1e1ef2;border:1px solid #3e3e42;border-left:none;border-radius:0 6px 6px 0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease;writing-mode:vertical-rl;text-orientation:mixed;padding:8px 4px}.compatibility-collapse-tab:hover{background-color:#323232f2}.collapse-tab-content{display:flex;align-items:center;gap:6px;transform:rotate(180deg)}.collapse-tab-count{font-size:12px;font-weight:600;padding:2px 6px;border-radius:8px}.collapse-tab-count.has-compatible{background-color:#00c85333;color:#00c853}.collapse-tab-count.no-compatible{background-color:#ff4d4d33;color:#ff4d4d}.collapse-tab-label{font-size:10px;color:#858585;white-space:nowrap}.collapse-tab-arrow{font-size:10px;color:#858585;transition:transform .2s ease}.compatibility-overlay.expanded .collapse-tab-arrow{transform:rotate(180deg)}.compatibility-panel{background-color:#1e1e1ef2;border:1px solid #3e3e42;border-left:none;border-radius:0 6px 6px 0;min-width:220px;max-width:280px;max-height:400px;overflow:hidden;transform:translate(-100%);opacity:0;transition:transform .25s ease,opacity .25s ease;pointer-events:none;position:absolute;left:0}.compatibility-overlay.expanded .compatibility-panel{transform:translate(0);opacity:1;pointer-events:auto}.compatibility-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #3e3e42}.compatibility-panel-title{display:flex;align-items:center;gap:8px}.panel-count{font-size:14px;font-weight:600;padding:2px 8px;border-radius:10px}.panel-count.has-compatible{background-color:#00c85333;color:#00c853}.panel-count.no-compatible{background-color:#ff4d4d33;color:#ff4d4d}.panel-label{font-size:12px;color:#d4d4d4;font-weight:500}.panel-close-btn{background:none;border:none;color:#858585;font-size:16px;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s ease}.panel-close-btn:hover{color:#d4d4d4}.compatibility-panel-content{padding:10px 12px;max-height:320px;overflow-y:auto}.compat-groups{display:flex;flex-direction:column;gap:8px}.compat-type-group{border:1px solid #3e3e42;border-radius:4px;overflow:hidden}.compat-type-header{display:flex;align-items:center;gap:8px;padding:8px 10px;background-color:#ffffff08;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.compat-type-header:hover{background-color:#ffffff0f}.compat-type-arrow{font-size:8px;color:#858585;width:10px}.compat-type-name{flex:1;font-size:11px;font-weight:600;color:#d4d4d4}.compat-type-count{font-size:10px;font-weight:600;padding:1px 6px;border-radius:8px}.compat-type-count.has-compatible{background-color:#00c85333;color:#00c853}.compat-type-count.no-compatible{background-color:#ff4d4d33;color:#ff4d4d}.compat-type-items{border-top:1px solid #3e3e42;padding:4px 0}.compat-item{display:flex;align-items:flex-start;gap:6px;padding:5px 10px;font-size:11px;transition:background-color .15s ease}.compat-item.clickable{cursor:pointer}.compat-item.clickable:hover{background-color:#ffffff14}.compat-item.selected{background-color:#6038d74d;border-left:2px solid var(--color-primary);padding-left:8px}.compat-item.compatible{color:#b8e6c9}.compat-item.incompatible{color:#e6b8b8}.compat-icon{font-size:10px;width:14px;text-align:center;margin-top:2px}.compat-item.compatible .compat-icon{color:#00c853}.compat-item.incompatible .compat-icon{color:#ff6b6b}.compat-item-details{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.compat-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.compat-dimensions{font-size:9px;color:#858585;white-space:nowrap}.compat-item.compatible .compat-dimensions{color:#7ab892}.compat-item.incompatible .compat-dimensions{color:#b89292}.panel-visualization-toggle{display:flex;align-items:center;gap:8px;font-size:11px;color:#d4d4d4;cursor:pointer;padding:6px 8px;margin:0 -4px 8px;background-color:#6038d726;border:1px solid rgba(96,56,215,.3);border-radius:4px}.panel-visualization-toggle:hover{background-color:#6038d740}.panel-visualization-toggle input[type=checkbox]{cursor:pointer;width:14px;height:14px}.panel-visualization-toggle span{white-space:nowrap}.panel-ignore-height-toggle{display:flex;align-items:center;gap:8px;font-size:11px;color:#aaa;cursor:pointer;padding:6px 0 10px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:10px}.panel-ignore-height-toggle input[type=checkbox]{cursor:pointer;width:14px;height:14px}.panel-ignore-height-toggle span{white-space:nowrap}.panel-tolerance-input{padding:6px 0 10px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:10px}.panel-tolerance-input label{display:flex;align-items:center;gap:8px;font-size:11px;color:#aaa}.panel-tolerance-input input[type=number]{width:50px;padding:3px 5px;background:#2a2a2d;border:1px solid #3e3e42;border-radius:3px;color:#fff;font-size:11px}.panel-tolerance-input input[type=number]:focus{outline:none;border-color:#007acc}.compatibility-panel-content::-webkit-scrollbar{width:4px}.compatibility-panel-content::-webkit-scrollbar-track{background:transparent}.compatibility-panel-content::-webkit-scrollbar-thumb{background:#3e3e42;border-radius:2px}.compatibility-panel-content::-webkit-scrollbar-thumb:hover{background:#4e4e52}.mesh-viewer{width:100%;height:100%;position:relative}.mesh-viewer-controls{position:absolute;top:16px;right:16px;z-index:10;background-color:#2d2d30e6;padding:8px 12px;border-radius:4px;display:flex;flex-direction:column;gap:6px}.mesh-viewer-toggle{display:flex;align-items:center;gap:8px;color:#d4d4d4;font-size:13px;cursor:pointer}.mesh-viewer-toggle input[type=checkbox]{cursor:pointer}.mesh-viewer-info{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background-color:#2d2d30e6;color:#d4d4d4;padding:8px 16px;border-radius:4px;font-size:12px;pointer-events:none}.mesh-viewer-center-toggle{background-color:#6038d733;padding:4px 8px;margin:4px -8px;border-radius:4px;border-left:3px solid var(--color-primary)}.mesh-viewer-position-controls{display:flex;flex-direction:column;gap:6px;margin-top:4px;padding-top:8px;border-top:1px solid #3e3e42}.position-input-group{display:flex;align-items:center;gap:8px}.position-input-group label{color:#d4d4d4;font-size:12px;min-width:16px}.position-input-group input[type=number]{width:80px;padding:4px 8px;background-color:#3c3c3c;border:1px solid #555;border-radius:3px;color:#d4d4d4;font-size:12px}.position-input-group input[type=number]:focus{outline:none;border-color:var(--color-primary)}.position-reset-btn{padding:4px 12px;background-color:#3c3c3c;border:1px solid #555;border-radius:3px;color:#d4d4d4;font-size:12px;cursor:pointer;transition:background-color .2s}.position-reset-btn:hover{background-color:#4c4c4c}.container-select{width:100%;padding:6px 8px;background-color:#3c3c3c;border:1px solid #555;border-radius:3px;color:#d4d4d4;font-size:12px;cursor:pointer}.container-select:focus{outline:none;border-color:var(--color-primary)}.container-select option{background-color:#2d2d30;color:#d4d4d4}.container-select optgroup{background-color:#252526;color:#858585;font-weight:600}.vertical-layer-slider{position:absolute;right:var(--spacing-md, 12px);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm, 8px);background-color:var(--color-bg-overlay, rgba(30, 30, 34, .95));padding:var(--spacing-md, 12px) var(--spacing-sm, 8px);border-radius:var(--radius-lg, 6px);border:var(--border-width, 1px) solid var(--color-border, #3e3e42);box-shadow:var(--shadow-md, 0 2px 8px rgba(0, 0, 0, .3));z-index:var(--z-dropdown, 10)}.layer-btn{width:32px;height:32px;background-color:var(--color-bg-hover, #3c3c3c);border:var(--border-width, 1px) solid var(--color-border-light, #555);border-radius:var(--radius-md, 4px);color:var(--color-text-primary, #d4d4d4);font-size:var(--font-size-md, 12px);cursor:pointer;transition:background-color var(--transition-normal, .2s);display:flex;align-items:center;justify-content:center}.layer-btn:hover:not(:disabled){background-color:var(--color-bg-active, #4c4c4c)}.layer-btn:disabled{opacity:.4;cursor:not-allowed}.slider-track-container{position:relative;display:flex;align-items:center;height:200px}.vertical-slider{-webkit-appearance:slider-vertical;appearance:slider-vertical;writing-mode:vertical-lr;direction:rtl;width:20px;height:200px;background:transparent;cursor:pointer}.vertical-slider::-webkit-slider-runnable-track{width:6px;height:100%;background:var(--color-bg-tertiary, #3e3e42);border-radius:var(--radius-sm, 3px)}.vertical-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary, #007acc);border-radius:var(--radius-full, 50%);cursor:pointer;margin-left:-5px;box-shadow:0 1px 3px #0000004d;transition:transform var(--transition-fast, .1s)}.vertical-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.vertical-slider::-moz-range-track{width:6px;height:100%;background:var(--color-bg-tertiary, #3e3e42);border-radius:var(--radius-sm, 3px)}.vertical-slider::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary, #007acc);border-radius:var(--radius-full, 50%);border:none;cursor:pointer;box-shadow:0 1px 3px #0000004d}.layer-labels{position:absolute;left:26px;top:0;bottom:0;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.layer-label{font-size:var(--font-size-xs, 10px);color:var(--color-text-muted, #666);white-space:nowrap}.layer-label.top{transform:translateY(-2px)}.layer-label.bottom{transform:translateY(2px)}.layer-info{display:flex;flex-direction:column;align-items:center;gap:2px;padding-top:var(--spacing-xs, 4px);border-top:var(--border-width, 1px) solid var(--color-border, #3e3e42);margin-top:var(--spacing-xs, 4px);min-width:50px}.layer-current{font-size:var(--font-size-lg, 14px);font-weight:var(--font-weight-semibold, 600);color:var(--color-primary-light, #00aaff);font-variant-numeric:tabular-nums}.layer-height{font-size:var(--font-size-xs, 10px);color:var(--color-text-muted, #888);font-variant-numeric:tabular-nums}.canvas-2d-viewer{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#1e1e1e;border-radius:4px;overflow:hidden}.canvas-2d-viewer-controls{position:absolute;top:50%;left:8px;transform:translateY(-50%);z-index:10;display:flex;flex-direction:column;gap:6px;max-height:calc(100% - 80px);overflow-y:auto;pointer-events:auto}.canvas-2d-viewer-canvas{width:min(100%,100vh - 120px);height:min(100%,100vh - 120px);aspect-ratio:1 / 1;display:block}.canvas-2d-viewer-info{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:12px;padding:4px 8px;background:#000000d9;border-radius:4px;font-size:11px;color:#ccc;z-index:10;pointer-events:auto}.canvas-2d-viewer-zoom{color:#888;min-width:40px;text-align:right}.canvas-2d-viewer-reset{background:#333;border:1px solid #555;color:#ccc;padding:2px 8px;border-radius:3px;font-size:10px;cursor:pointer;transition:all .15s ease}.canvas-2d-viewer-reset:hover{background:#444;border-color:#666}.canvas-2d-viewer-bg-toggle{background:#333;border:1px solid #555;color:#ccc;padding:2px 8px;border-radius:3px;font-size:10px;cursor:pointer;transition:all .15s ease}.canvas-2d-viewer-bg-toggle:hover{background:#444;border-color:#666}.canvas-2d-viewer-bg-toggle.light{background:#ddd;border-color:#aaa;color:#333}.canvas-2d-viewer-bg-toggle.light:hover{background:#ccc;border-color:#999}.canvas-2d-viewer-legend{position:absolute;top:50%;right:8px;transform:translateY(-50%);display:flex;flex-direction:column;gap:6px;padding:8px 10px;background:#000000b3;border-radius:4px;font-size:10px;color:#aaa;z-index:10;max-height:calc(100% - 80px);overflow-y:auto}.canvas-2d-viewer-legend .legend-item{display:flex;align-items:center;gap:4px}.canvas-2d-viewer-legend .legend-color{width:12px;height:12px;border-radius:2px}.canvas-2d-viewer-legend .legend-color.perimeter{background:#b94d62}.canvas-2d-viewer-legend .legend-color.infill{background:#eac653}.canvas-2d-viewer-legend .legend-color.build-surface{background:#0f6}.canvas-2d-viewer-legend .legend-color.container{background:#0af}.canvas-2d-viewer-legend .legend-color.extrusion-width{background:#eac65366;border:1px solid #eac653}.canvas-2d-viewer-legend .legend-color.perimeter-extrusion-width{background:#b94d6266;border:1px solid #b94d62}.canvas-2d-viewer-legend .legend-color.overlap{background:#6038d7}.canvas-2d-viewer-legend .legend-color.start{background:#0f0;border-radius:50%}.canvas-2d-viewer-legend .legend-color.end{background:red;border-radius:50%}.canvas-2d-viewer-legend .legend-color.perimeter-arrow{background:#ff0}.canvas-2d-viewer-legend .legend-color.infill-arrow{background:#0fa}.canvas-2d-viewer-legend .legend-color.droplet{background:#b388ff;border-radius:50%}.canvas-2d-viewer-legend .legend-color.gridfill{background:#29b6f6;transform:rotate(45deg)}.layer-viewer-container{position:relative;width:100%;height:100%}.layer-viewer{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.layer-viewer-canvas{max-width:100%;max-height:100%;border:var(--border-width, 1px) solid var(--color-border, #3e3e42)}.layer-viewer-info{position:absolute;top:var(--spacing-lg, 16px);left:50%;transform:translate(-50%);background-color:var(--color-bg-overlay, rgba(45, 45, 48, .9));color:var(--color-text-primary, #d4d4d4);padding:var(--spacing-sm, 8px) var(--spacing-lg, 16px);border-radius:var(--radius-md, 4px);font-size:var(--font-size-md, 12px);display:flex;align-items:center;gap:var(--spacing-md, 12px)}.layer-viewer-zoom{color:var(--color-text-muted, #888888);font-variant-numeric:tabular-nums;min-width:3em;text-align:right}.layer-viewer-reset{background-color:var(--color-bg-tertiary, #3e3e42);color:var(--color-text-primary, #d4d4d4);border:var(--border-width, 1px) solid var(--color-border, #555555);border-radius:var(--radius-sm, 2px);padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);font-size:var(--font-size-sm, 11px);cursor:pointer;transition:background-color .15s ease}.layer-viewer-reset:hover{background-color:var(--color-bg-hover, #4e4e52)}.layer-viewer-reset:active{background-color:var(--color-bg-active, #5e5e62)}.layer-viewer-legend{position:absolute;bottom:var(--spacing-md, 12px);right:80px;background-color:var(--color-bg-overlay, rgba(30, 30, 34, .95));padding:var(--spacing-sm, 8px) var(--spacing-md, 12px);border-radius:var(--radius-md, 4px);border:var(--border-width, 1px) solid var(--color-border, #3e3e42);display:flex;flex-direction:column;gap:var(--spacing-sm, 6px);z-index:var(--z-dropdown, 10)}.layer-viewer-legend .legend-item{display:flex;align-items:center;gap:var(--spacing-sm, 6px);font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888)}.layer-viewer-legend .legend-color{width:10px;height:10px;border-radius:var(--radius-full, 50%)}.layer-viewer-legend .legend-color.perimeter{background-color:#b94d62}.layer-viewer-legend .legend-color.infill{background-color:#eac653}.layer-viewer-legend .legend-color.build-surface{background-color:transparent;border:2px dashed #00ff66;border-radius:2px}.layer-viewer-legend .legend-color.container{background-color:transparent;border:2px dashed #ff8800;border-radius:2px}.layer-viewer-legend .legend-title{font-size:var(--font-size-xs, 10px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-primary, #ccc);margin-bottom:var(--spacing-xs, 4px)}.layer-viewer-legend .legend-label{white-space:nowrap}.path-viewer{width:100%;height:100%;position:relative;display:flex;flex-direction:column;background-color:var(--color-bg-canvas, #12121a)}.path-viewer-controls{position:absolute;top:var(--spacing-md, 12px);right:80px;z-index:var(--z-dropdown, 10);background-color:var(--color-bg-overlay, rgba(30, 30, 34, .95));padding:var(--spacing-sm, 10px) var(--spacing-md, 14px);border-radius:var(--radius-lg, 6px);border:var(--border-width, 1px) solid var(--color-border, #3e3e42);box-shadow:var(--shadow-md, 0 2px 8px rgba(0, 0, 0, .3))}.path-viewer-toggles{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.arrow-controls-section{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px);padding-top:var(--spacing-sm, 8px);border-top:1px solid var(--color-border, #3e3e42);margin-top:var(--spacing-xs, 4px)}.arrow-frequency-control{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px);padding-left:var(--spacing-md, 12px);margin-bottom:var(--spacing-xs, 4px)}.arrow-frequency-label{font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888)}.arrow-frequency-slider{width:100%;height:4px;cursor:pointer;accent-color:var(--color-primary, #007acc)}.path-viewer-canvas{flex:1;width:100%;height:100%;display:block}.path-viewer-info{position:absolute;bottom:60px;left:50%;transform:translate(-50%);background-color:var(--color-bg-overlay, rgba(30, 30, 34, .95));color:var(--color-text-primary, #d4d4d4);padding:var(--spacing-sm, 6px) var(--spacing-md, 12px);border-radius:var(--radius-md, 4px);font-size:var(--font-size-sm, 11px);display:flex;gap:var(--spacing-md, 12px);align-items:center;border:var(--border-width, 1px) solid var(--color-border, #3e3e42)}.path-info-layer{font-weight:var(--font-weight-semibold, 600);color:var(--color-text-accent, #fff)}.path-info-height,.path-info-paths{color:var(--color-text-secondary, #888)}.path-info-infill-percent{color:var(--color-success, #4caf50);font-weight:var(--font-weight-semibold, 600)}.path-info-volume{color:var(--color-info, #29b6f6);font-weight:var(--font-weight-semibold, 600)}.path-info-overlap{color:#7c5ce0;font-weight:var(--font-weight-semibold, 600)}.path-info-overlap-volume{color:#7c5ce0;font-size:var(--font-size-xs, 10px);font-weight:var(--font-weight-medium, 500)}.path-info-warning{color:var(--color-warning-light, #ffaa44);font-style:italic}.path-info-zoom{color:var(--color-primary-light, #00aaff);font-weight:var(--font-weight-medium, 500)}.path-info-reset{background-color:var(--color-bg-hover, #3c3c3c);border:var(--border-width, 1px) solid var(--color-border-light, #555);border-radius:var(--radius-sm, 3px);color:var(--color-text-primary, #d4d4d4);padding:2px var(--spacing-sm, 8px);font-size:var(--font-size-sm, 11px);cursor:pointer;transition:background-color var(--transition-normal, .2s)}.path-info-reset:hover{background-color:var(--color-bg-active, #4c4c4c)}.path-viewer-print-times{position:absolute;bottom:100px;left:50%;transform:translate(-50%);background-color:var(--color-bg-overlay, rgba(30, 30, 34, .95));color:var(--color-text-primary, #d4d4d4);padding:var(--spacing-xs, 4px) var(--spacing-md, 12px);border-radius:var(--radius-md, 4px);font-size:var(--font-size-xs, 10px);display:flex;gap:var(--spacing-sm, 8px);align-items:center;border:var(--border-width, 1px) solid var(--color-border, #3e3e42)}.print-times-label{color:var(--color-text-secondary, #888);font-weight:var(--font-weight-medium, 500)}.print-time-item{display:flex;flex-direction:column;align-items:center;gap:1px}.print-time-speed{color:var(--color-text-tertiary, #666);font-size:8px}.print-time-value{color:var(--color-primary-light, #00aaff);font-weight:var(--font-weight-semibold, 600)}.path-viewer-legend{position:absolute;bottom:var(--spacing-md, 12px);right:80px;background-color:var(--color-bg-overlay, rgba(30, 30, 34, .95));padding:var(--spacing-sm, 8px) var(--spacing-md, 12px);border-radius:var(--radius-md, 4px);border:var(--border-width, 1px) solid var(--color-border, #3e3e42);display:flex;flex-direction:column;gap:var(--spacing-sm, 6px);z-index:var(--z-dropdown, 10)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm, 6px);font-size:var(--font-size-xs, 10px);color:var(--color-text-secondary, #888)}.legend-color{width:10px;height:10px;border-radius:var(--radius-full, 50%)}.legend-color.perimeter{background-color:var(--color-perimeter, #b94d62)}.legend-color.infill{background-color:var(--color-infill, #eac653)}.legend-color.extrusion-width{background-color:#eac65380;border:1px solid #eac653;border-radius:2px}.legend-color.perimeter-extrusion-width{background-color:#b94d6280;border:1px solid #b94d62;border-radius:2px}.legend-color.overlap{background-color:#6038d7;border:2px solid #ffffff;box-shadow:0 0 0 1px #6038d7}.legend-color.perimeter-arrow{background-color:#ff0;border:1px solid #000}.legend-color.infill-arrow{background-color:#0fa;border:1px solid #000}.legend-color.start{background-color:var(--color-path-start, #00ff00)}.legend-color.end{background-color:var(--color-path-end, #4444ff)}.legend-color.build-surface{background-color:transparent;border:2px dashed #00ff66;border-radius:2px}.legend-color.container{background-color:transparent;border:2px dashed #ff8800;border-radius:2px}.legend-color.droplet{background-color:#b388ff80;border:2px solid #b388ff}.legend-color.gridfill{background-color:#29b6f680;border:2px solid #29b6f6;transform:rotate(45deg)}.legend-color.debug-cells{background-color:#ffff0080;border:2px solid #ffff00}.legend-color.debug-vertices{background-color:#f0f;border:none;border-radius:50%}.legend-color.debug-edges{background-color:#ff0;border:none}.legend-color.debug-polygons{background-color:#f006;border:2px solid rgba(255,0,0,.8)}.debug-section{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px);padding-top:var(--spacing-sm, 8px);border-top:1px solid var(--color-border, #3e3e42);margin-top:var(--spacing-xs, 4px)}.debug-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background-color:#ffff001a;border:1px solid rgba(255,255,0,.3);border-radius:var(--radius-sm, 3px);color:#ff0;font-size:var(--font-size-xs, 10px);font-weight:var(--font-weight-medium, 500);cursor:pointer;transition:background-color var(--transition-normal, .2s)}.debug-toggle:hover{background-color:#ff03}.debug-toggle.expanded{background-color:#ffff0026;border-color:#ffff0080}.debug-toggle-icon{font-size:8px;margin-left:var(--spacing-sm, 8px)}.debug-sub-controls{display:flex;flex-wrap:wrap;gap:4px 8px;padding-left:16px;margin-top:2px;border-left:2px solid #ffff00}.path-drawing-canvas-container{width:100%;height:100%;position:relative;display:flex;flex-direction:column}.path-drawing-canvas{flex:1;background-color:#1e1e1e}.canvas-controls-top-right{position:absolute;top:8px;right:8px;display:flex;gap:4px;z-index:10;pointer-events:auto}.canvas-control-button-small{width:28px;height:28px;padding:0;background-color:#3c3c3ce6;border:1px solid #555;border-radius:4px;color:#d4d4d4;font-size:16px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.canvas-control-button-small:hover:not(:disabled){background-color:#4c4c4cf2}.canvas-control-button-small:disabled{opacity:.3;cursor:not-allowed}.canvas-info-minimal{position:absolute;bottom:0;left:0;right:0;background-color:#252526d9;color:#d4d4d4;padding:3px 8px;font-size:10px;border-top:1px solid rgba(62,62,66,.5);pointer-events:none;text-align:center}.canvas-info-text{opacity:.8;font-family:Segoe UI,system-ui,sans-serif}.path-list{display:flex;flex-direction:column;height:100%;background-color:#252526;border-radius:4px;overflow:hidden}.path-list-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#2d2d30;border-bottom:1px solid #3e3e42}.path-list-header h4{margin:0;font-size:14px;font-weight:600;color:#ccc}.path-list-header-actions{display:flex;align-items:center;gap:12px}.selection-count{font-size:12px;color:#858585}.toggle-details-btn{padding:4px 8px;background:transparent;border:1px solid #3e3e42;border-radius:3px;cursor:pointer;font-size:14px;color:#858585;transition:all .15s ease}.toggle-details-btn:hover{background-color:#3e3e42;border-color:var(--color-primary);color:#ccc}.create-group-btn{padding:4px 8px;background:transparent;border:1px solid #3e3e42;border-radius:3px;cursor:pointer;font-size:14px;color:#858585;transition:all .15s ease}.create-group-btn:hover{background-color:#3e3e42;border-color:var(--color-primary);color:#ccc}.path-list-items{flex:1;overflow-y:auto;padding:8px}.path-list-empty{padding:32px 16px;text-align:center;color:#858585;font-size:13px}.path-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;margin-bottom:4px;background-color:#1e1e1e;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s ease}.path-list-item:hover{background-color:#2a2d2e;border-color:#3e3e42}.path-list-item.selected{background-color:#37373d;border-color:var(--color-primary)}.path-item-content{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.path-color-indicator{width:12px;height:12px;border-radius:2px;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.path-item-info{flex:1;min-width:0}.path-name{font-size:13px;color:#ccc;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.path-details{font-size:11px;color:#858585;margin-top:2px;text-transform:capitalize}.path-name-input{width:100%;padding:4px 6px;background-color:#3c3c3c;border:1px solid var(--color-primary);border-radius:2px;color:#ccc;font-size:13px;outline:none}.path-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease}.path-list-item:hover .path-item-actions,.path-list-item.selected .path-item-actions{opacity:1}.path-action-btn{padding:4px 8px;background:transparent;border:none;border-radius:3px;cursor:pointer;font-size:14px;transition:background-color .15s ease}.path-action-btn:hover{background-color:#3e3e42}.path-action-btn.delete:hover{background-color:#f48771}.path-list-item.droplet-item{cursor:default}.path-list-item.droplet-item:hover{background-color:#2a2d2e;border-color:#3e3e42}.droplet-indicator{border-radius:50%}.path-list-items::-webkit-scrollbar{width:8px}.path-list-items::-webkit-scrollbar-track{background:#1e1e1e}.path-list-items::-webkit-scrollbar-thumb{background:#424242;border-radius:4px}.path-list-items::-webkit-scrollbar-thumb:hover{background:#4e4e4e}.path-group{margin-bottom:8px}.group-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#2a2d2e;border:1px solid #3e3e42;border-radius:4px;cursor:pointer;transition:all .15s ease}.group-header:hover{background-color:#323437;border-color:var(--color-primary)}.group-toggle-icon{font-size:10px;color:#858585;flex-shrink:0}.group-name{flex:1;font-size:13px;color:#ccc;font-weight:500}.group-name-input{flex:1;padding:4px 6px;background-color:#3c3c3c;border:1px solid var(--color-primary);border-radius:2px;color:#ccc;font-size:13px;outline:none}.group-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease}.group-header:hover .group-actions{opacity:1}.group-action-btn{padding:4px 8px;background:transparent;border:none;border-radius:3px;cursor:pointer;font-size:14px;transition:background-color .15s ease}.group-action-btn:hover{background-color:#3e3e42}.group-action-btn.delete:hover{background-color:#f48771}.group-paths{margin-top:4px;margin-left:24px;padding-left:12px;border-left:2px solid #3e3e42}.grouped-path{margin-bottom:2px}.modal-dialog{background-color:#2d2d30;border:1px solid #3e3e42;border-radius:6px;padding:24px;min-width:400px;box-shadow:0 4px 16px #00000080}.modal-dialog h3{margin:0 0 16px;font-size:16px;color:#fff}.modal-dialog .param-group{margin-bottom:20px}.modal-dialog .param-group label{display:block;font-size:12px;color:#d4d4d4;margin-bottom:8px}.modal-dialog .param-group input{width:100%;padding:8px 12px;background-color:#3c3c3c;border:1px solid #555;border-radius:4px;color:#d4d4d4;font-size:13px;outline:none}.modal-dialog .param-group input:focus{border-color:var(--color-primary)}.modal-btn{padding:8px 16px;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s}.modal-btn.primary{background-color:var(--color-primary);color:#fff}.modal-btn.primary:hover{background-color:var(--color-primary-hover)}.modal-btn.secondary{background-color:#3c3c3c;color:#d4d4d4;border:1px solid #555}.modal-btn.secondary:hover{background-color:#4c4c4c}.path-properties-panel{background-color:#2d2d30;border-radius:4px;padding:16px;margin-top:16px}.panel-header{margin-bottom:16px;border-bottom:1px solid #3e3e42;padding-bottom:12px}.panel-header h3{margin:0;font-size:14px;color:#fff;font-weight:600}.panel-content{display:flex;flex-direction:column;gap:12px}.property-group{display:flex;flex-direction:column;gap:6px}.property-group label{font-size:12px;color:#d4d4d4;font-weight:500}.property-group input[type=text],.property-group input[type=number]{padding:6px 8px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:3px;color:#d4d4d4;font-size:13px;font-family:inherit}.property-group input[type=text]:focus,.property-group input[type=number]:focus{outline:none;border-color:var(--color-primary)}.property-group input[type=color]{width:100%;height:32px;padding:2px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:3px;cursor:pointer}.property-group input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.property-group input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}.panel-actions{display:flex;flex-direction:column;gap:8px;margin-top:8px;padding-top:12px;border-top:1px solid #3e3e42}.smoothing-controls-panel{background-color:#2d2d30;border-radius:4px;padding:16px;margin-bottom:16px}.smoothing-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0;margin-bottom:0;transition:background-color .2s;border-radius:4px}.smoothing-header:hover{background-color:#ffffff0d}.smoothing-controls-panel h4{margin:0;font-size:14px;color:#fff;font-weight:600}.toggle-icon{font-size:12px;color:#858585;transition:transform .2s}.smoothing-content{margin-top:16px}.smoothing-slider-group{margin-bottom:16px}.smoothing-slider-group label{display:flex;flex-direction:column;gap:8px;font-size:12px;color:#d4d4d4;font-weight:500}.slider-hint{font-size:11px;color:#858585;font-weight:400}.smoothness-slider{width:100%;height:6px;border-radius:3px;background:#3e3e42;outline:none;-webkit-appearance:none;appearance:none}.smoothness-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;transition:background .2s}.smoothness-slider::-webkit-slider-thumb:hover{background:var(--color-primary-hover)}.smoothness-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;transition:background .2s}.smoothness-slider::-moz-range-thumb:hover{background:var(--color-primary-hover)}.smoothing-checkboxes{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.smoothing-checkboxes .checkbox-label{display:flex;align-items:center;gap:8px;font-size:12px;color:#d4d4d4;cursor:pointer;-webkit-user-select:none;user-select:none}.smoothing-checkboxes .checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.smoothing-checkboxes .checkbox-label:hover{color:#fff}.path-manipulation-panel{background-color:#252526;padding:16px;border-radius:4px;display:flex;flex-direction:column;gap:12px}.path-manipulation-panel .section-title{margin:0;font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;padding-bottom:8px;border-bottom:1px solid #3e3e42}.manipulation-buttons{display:flex;flex-direction:column;gap:8px}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{background-color:#2d2d30;border:1px solid #3e3e42;border-radius:8px;padding:24px;min-width:400px;max-width:500px;box-shadow:0 4px 6px #0000004d}.modal-dialog h3{margin:0 0 20px;font-size:16px;font-weight:600;color:#fff}.param-group{margin-bottom:20px}.param-group label{display:block;margin-bottom:8px;font-size:13px;font-weight:500;color:#d4d4d4}.param-group input[type=number]{width:100%;padding:8px 12px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;color:#d4d4d4;font-size:14px;font-family:inherit}.param-group input[type=number]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.modal-buttons{display:flex;gap:12px;justify-content:flex-end}.preview-panel{position:relative;flex:1;min-width:0;height:100%;display:flex;flex-direction:row;background-color:#1e1e1e}.viewer-container{flex:1;display:flex;flex-direction:column;width:100%;height:100%;position:relative}.preview-content{flex:1;width:100%;min-width:400px}.layer-navigation-container{padding:16px;background-color:#252526;border-top:1px solid #3e3e42}.preview-placeholder{flex:1;display:flex;align-items:center;justify-content:center}.preview-placeholder-text{font-size:18px;color:#858585}.path-management-panel{width:320px;background-color:#252526;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:20px;border-left:1px solid #3e3e42}.path-management-panel .section{display:flex;flex-direction:column;gap:12px}.path-management-panel .section-title{margin:0;font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;padding-bottom:8px;border-bottom:1px solid #3e3e42}.path-management-panel .path-list-section{flex:1;display:flex;flex-direction:column;min-height:200px}.path-management-panel::-webkit-scrollbar{width:10px}.path-management-panel::-webkit-scrollbar-track{background:#1e1e1e}.path-management-panel::-webkit-scrollbar-thumb{background:#424242;border-radius:5px}.path-management-panel::-webkit-scrollbar-thumb:hover{background:#4e4e4e}.panel-collapse-toggle{position:absolute;right:0;top:50%;transform:translateY(-50%);width:24px;height:60px;background-color:#3c3c3ce6;border:1px solid #555;border-right:none;border-radius:4px 0 0 4px;color:#d4d4d4;font-size:14px;cursor:pointer;transition:all .2s;z-index:100;display:flex;align-items:center;justify-content:center;padding:0}.panel-collapse-toggle:hover{background-color:#4c4c4cf2;width:28px}.view-toggle{position:absolute;top:12px;left:12px;z-index:100;display:flex;gap:0;background-color:#252526f2;border-radius:6px;border:1px solid #3e3e42;overflow:hidden}.view-toggle-btn{padding:8px 16px;background-color:transparent;border:none;color:#858585;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.view-toggle-btn:hover{background-color:#ffffff0d;color:#d4d4d4}.view-toggle-btn.active{background-color:#0e639c;color:#fff}.view-toggle-btn:first-child{border-right:1px solid #3e3e42}.main-layout{flex:1;display:flex;flex-direction:row;overflow:hidden;position:relative}.app{width:100%;height:100%;display:flex;flex-direction:column;background-color:#1e1e1e;color:#d4d4d4}.app-error-fallback{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:#1e1e1e;color:#d4d4d4}.app-error-content{text-align:center;padding:2rem;max-width:400px}.app-error-content h1{color:#b94d62;font-size:1.5rem;margin-bottom:1rem}.app-error-content p{color:#888;margin-bottom:1.5rem;line-height:1.5}.app-error-content button{padding:.75rem 1.5rem;font-size:1rem;background:#0e639c;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.app-error-content button:hover{background:#17b}:root{--color-bg-primary: #1e1e1e;--color-bg-secondary: #2d2d30;--color-bg-tertiary: #252526;--color-bg-canvas: #1a1a1e;--color-bg-hover: #3c3c3c;--color-bg-active: #4c4c4c;--color-bg-selected: #094771;--color-bg-overlay: rgba(30, 30, 34, .95);--color-border: #3e3e42;--color-border-light: #555;--color-border-focus: #6038d7;--color-text-primary: #d4d4d4;--color-text-secondary: #858585;--color-text-accent: #ffffff;--color-text-disabled: #5a5a5a;--color-primary: #6038d7;--color-primary-hover: #4c2cb0;--color-primary-light: #7c5ce0;--color-brand-gold: #eac653;--color-brand-red: #b94d62;--color-brand-dark: #202123;--color-brand-light: #faf8f9;--color-brand-navy: #242d75;--color-error: #f44336;--color-error-light: #ff6659;--color-success: #4caf50;--color-success-light: #80e27e;--color-warning: #ff9800;--color-warning-light: #ffaa44;--color-info: #2196f3;--color-perimeter: #b94d62;--color-infill: #eac653;--color-path-start: #00ff00;--color-path-end: #4444ff;--color-build-surface: #00ff66;--color-container: #00c8ff;--color-grid-minor: #2a2a2e;--color-grid-major: #3a3a3e;--color-grid-axis: #555;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-family-mono: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;--font-size-xs: 10px;--font-size-sm: 11px;--font-size-md: 12px;--font-size-lg: 14px;--font-size-xl: 16px;--font-size-2xl: 20px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--radius-sm: 3px;--radius-md: 4px;--radius-lg: 6px;--radius-xl: 8px;--radius-full: 9999px;--border-width: 1px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4);--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--panel-width-sm: 200px;--panel-width-md: 280px;--panel-width-lg: 350px;--input-height-sm: 24px;--input-height-md: 28px;--input-height-lg: 32px;--checkbox-size: 14px;--toggle-width: 36px;--toggle-height: 18px}.section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-tertiary);border-bottom:var(--border-width) solid var(--color-border);cursor:pointer;-webkit-user-select:none;user-select:none}.section-header:hover{background-color:var(--color-bg-hover)}.section-header-title{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.section-header-icon{color:var(--color-text-secondary);transition:transform var(--transition-fast)}.section-header-icon.expanded{transform:rotate(90deg)}.section-content{padding:var(--spacing-md)}.info-box{background-color:var(--color-bg-overlay);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.info-box-dark{background-color:var(--color-bg-tertiary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.list-item{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:background-color var(--transition-fast);border-bottom:var(--border-width) solid var(--color-border)}.list-item:hover{background-color:var(--color-bg-hover)}.list-item.selected{background-color:var(--color-bg-selected)}.list-item:last-child{border-bottom:none}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text-primary);background-color:var(--color-bg-hover);border:var(--border-width) solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-normal);-webkit-user-select:none;user-select:none}.btn:hover:not(:disabled){background-color:var(--color-bg-active)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-accent)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.form-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.form-input{height:var(--input-height-md);padding:0 var(--spacing-sm);font-size:var(--font-size-md);color:var(--color-text-primary);background-color:var(--color-bg-tertiary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition-fast)}.form-input:focus{border-color:var(--color-border-focus)}.form-input:disabled{opacity:.5;cursor:not-allowed}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-primary);font-size:var(--font-size-md);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:var(--checkbox-size);height:var(--checkbox-size);cursor:pointer;accent-color:var(--color-primary)}.form-select{height:var(--input-height-md);padding:0 var(--spacing-sm);font-size:var(--font-size-md);color:var(--color-text-primary);background-color:var(--color-bg-tertiary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-sm);outline:none;cursor:pointer}.form-select:focus{border-color:var(--color-border-focus)}.scrollbar-dark{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg-primary)}.scrollbar-dark::-webkit-scrollbar{width:8px;height:8px}.scrollbar-dark::-webkit-scrollbar-track{background:var(--color-bg-primary)}.scrollbar-dark::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-full);border:2px solid var(--color-bg-primary)}.scrollbar-dark::-webkit-scrollbar-thumb:hover{background-color:var(--color-border-light)}.flex-row{display:flex;flex-direction:row}.flex-col{display:flex;flex-direction:column}.flex-row-gap{display:flex;flex-direction:row;gap:var(--spacing-sm)}.flex-col-gap{display:flex;flex-direction:column;gap:var(--spacing-sm)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-1{flex:1}.flex-grow{flex-grow:1}.flex-shrink-0{flex-shrink:0}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-accent{color:var(--color-text-accent)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-mono{font-family:var(--font-family-mono)}.toggle-indicator{width:12px;height:3px;border-radius:1px;flex-shrink:0}.toggle-indicator.perimeter{background-color:var(--color-perimeter)}.toggle-indicator.infill{background-color:var(--color-infill)}.legend{display:flex;flex-direction:column;gap:var(--spacing-sm)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.legend-color{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}.legend-color.perimeter{background-color:var(--color-perimeter)}.legend-color.infill{background-color:var(--color-infill)}.legend-color.start{background-color:var(--color-path-start)}.legend-color.end{background-color:var(--color-path-end)}.canvas-overlay-panel{position:absolute;background-color:var(--color-bg-overlay);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);border:var(--border-width) solid var(--color-border);box-shadow:var(--shadow-md);z-index:var(--z-dropdown)}.canvas-controls{position:absolute;top:var(--spacing-md);right:var(--spacing-md)}.canvas-info-bar{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%)}.canvas-legend{position:absolute;bottom:120px;right:var(--spacing-md)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-primary);color:var(--color-text-primary)}code{font-family:var(--font-family-mono)}#root{width:100vw;height:100vh;overflow:hidden}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}
