:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.cad-toolbar{background-color:#fff;border-right:1px solid #e0e0e0;flex-direction:column;padding:1.5rem 1rem;display:flex;box-shadow:2px 0 4px #0000000d}.toolbar-group{margin-bottom:1rem;position:relative}.toolbar-group>button{color:#495057;cursor:pointer;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-size:14px;font-weight:500;transition:all .2s;display:flex}.toolbar-group>button:hover{background-color:#e9ecef;border-color:#ced4da;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.toolbar-group>button.active{color:#fff;background-color:#495057;border-color:#495057}.toolbar-group>button.active:hover{background-color:#343a40;border-color:#343a40}.shape-dropdown{z-index:10;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;flex-direction:column;margin-top:.5rem;padding:.5rem;display:flex;position:absolute;top:100%;left:0;right:0;box-shadow:0 4px 12px #00000026}.shape-dropdown button{cursor:pointer;color:#495057;background-color:#fff;border:none;border-radius:6px;align-items:center;gap:.75rem;margin-bottom:.25rem;padding:.75rem 1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-size:14px;font-weight:500;transition:all .2s;display:flex}.shape-dropdown button:last-child{margin-bottom:0}.shape-dropdown button:hover{color:#212529;background-color:#f8f9fa;transform:translate(4px)}.shape-dropdown button svg{color:#6c757d;width:18px;height:18px}.shape-dropdown button:hover svg{color:#495057}.sketch-tools{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;flex-direction:column;gap:.5rem;margin-top:.75rem;padding:.75rem;display:flex}.sketch-tools button{color:#495057;cursor:pointer;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:13px;font-weight:500;transition:all .2s;display:flex}.sketch-tools button:hover{background-color:#e9ecef;border-color:#ced4da}.sketch-tools button.active{color:#fff;background-color:#6c757d;border-color:#6c757d}.sketch-tools button.active:hover{background-color:#5a6268;border-color:#5a6268}.dimension-editor{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dimension-editor-content{background:#fff;border-radius:8px;min-width:300px;padding:24px;box-shadow:0 4px 12px #00000026}.dimension-editor-content h3{color:#2c3e50;margin:0 0 16px}.current-value{color:#495057;background-color:#f8f9fa;border-radius:4px;margin-bottom:16px;padding:8px 12px;font-family:monospace}.input-group{margin-bottom:16px}.input-group label{color:#495057;margin-bottom:4px;font-weight:500;display:block}.input-group input{border:1px solid #ced4da;border-radius:4px;width:100%;padding:8px 12px;font-size:14px}.button-group{justify-content:flex-end;gap:8px;display:flex}.apply-btn,.cancel-btn{cursor:pointer;border:none;border-radius:4px;padding:8px 16px;font-weight:500}.apply-btn{color:#fff;background-color:#28a745}.apply-btn:hover{background-color:#218838}.cancel-btn{color:#fff;background-color:#6c757d}.cancel-btn:hover{background-color:#5a6268}.property-panel{color:#333;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;overflow-y:auto}.property-panel h2{color:#2c3e50;border-bottom:1px solid #e0e0e0;margin-top:0;margin-bottom:1.5rem;padding-bottom:1rem;font-size:1.25rem}.property-panel h3{color:#34495e;margin:0 0 .75rem;font-size:1rem;font-weight:600}.property-panel p{margin:0 0 1rem;font-size:14px}.no-selection{text-align:center;color:#7f8c8d}.selection-help{text-align:left;background-color:#f8f9fa;border-radius:8px;margin-top:2rem;padding:1rem}.selection-help ul{margin:.5rem 0 0;padding:0;list-style:none}.selection-help li{border-bottom:1px solid #e9ecef;padding:.5rem 0;font-size:13px}.selection-help li:last-child{border-bottom:none}.property-group{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.property-item{border-bottom:1px solid #e9ecef;align-items:center;gap:8px;margin-bottom:.75rem;padding:.5rem 0;display:flex}.property-item:last-child{border-bottom:none;margin-bottom:0}.property-item label{color:#495057;min-width:80px;font-size:13px;font-weight:600}.property-item span{color:#6c757d;flex:1;font-size:13px}.selection-type{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:.25rem .5rem;font-size:11px;font-weight:600}.selection-type.shape{color:#1976d2;background-color:#e3f2fd}.selection-type.face{color:#388e3c;background-color:#e8f5e8}.selection-type.edge{color:#d32f2f;background-color:#ffebee}.transform-buttons{flex-wrap:wrap;gap:.5rem;display:flex}.transform-btn{color:#495057;cursor:pointer;background-color:#f8f9fa;border:1px solid #ced4da;border-radius:4px;padding:.5rem 1rem;font-size:.8rem;font-weight:500;transition:all .2s}.transform-btn:hover{background-color:#e9ecef;border-color:#adb5bd}.transform-btn:active,.transform-btn.active{color:#fff;background-color:#495057;border-color:#495057}.transform-help{background-color:#f8f9fa;border-left:3px solid #495057;border-radius:4px;margin-top:.75rem;padding:.75rem}.transform-help p{color:#6c757d;margin:0;font-size:.8rem;line-height:1.4}.property-item{align-items:center;gap:8px;display:flex}.edit-dimension-btn{cursor:pointer;color:#6c757d;background:0 0;border:1px solid #ced4da;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.edit-dimension-btn:hover{color:#495057;background-color:#f8f9fa;border-color:#495057}.property-panel.draggable{border:1px solid #ccc;box-shadow:0 4px 12px #00000026}.property-header{cursor:grab;-webkit-user-select:none;user-select:none;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.property-header:active{cursor:grabbing}.property-header h2{text-align:center;flex:1;margin:0;font-size:14px}.drag-handle{color:#6c757d;align-items:center;display:flex}.close-btn{color:#6c757d;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.close-btn:hover{color:#495057;background-color:#e9ecef}.sketch-panel{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.sketch-panel-header{border-bottom:1px solid #e9ecef;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.sketch-panel-header h3{color:#2c3e50;margin:0;font-size:1rem;font-weight:600}.sketch-controls{gap:.5rem;display:flex}.snap-button,.clear-button{cursor:pointer;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.snap-button:hover,.clear-button:hover{background-color:#e9ecef;border-color:#ced4da}.snap-button.active{color:#fff;background-color:#495057;border-color:#495057}.clear-button{color:#6c757d}.clear-button:hover{color:#495057;background-color:#f8f9fa;border-color:#dee2e6}.sketches-list h4{color:#495057;margin:0 0 .75rem;font-size:.9rem;font-weight:600}.no-sketches{color:#6c757d;text-align:center;margin:0;padding:1rem;font-style:italic}.sketch-items{max-height:200px;overflow-y:auto}.sketch-item{cursor:pointer;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:.5rem;padding:.75rem;transition:all .2s}.sketch-item:hover{background-color:#e9ecef;border-color:#ced4da}.sketch-item.selected{background-color:#f8f9fa;border-color:#495057;box-shadow:0 0 0 2px #49505733}.sketch-info{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.sketch-type{color:#2c3e50;text-transform:capitalize;font-weight:600}.sketch-id{color:#6c757d;font-family:monospace;font-size:.8rem}.sketch-details{color:#495057;font-size:.8rem}.extrude-section{border-top:1px solid #e9ecef;margin-top:1.5rem;padding-top:1rem}.extrude-section h4{color:#495057;margin:0 0 1rem;font-size:.9rem;font-weight:600}.extrude-controls{flex-direction:column;gap:1rem;display:flex}.input-group{align-items:center;gap:.5rem;display:flex}.input-group label{color:#495057;min-width:50px;font-size:.9rem;font-weight:500}.input-group input{border:1px solid #ced4da;border-radius:4px;flex:1;padding:.5rem;font-size:.9rem}.input-group input:focus{border-color:#495057;outline:none;box-shadow:0 0 0 2px #49505740}.extrude-button{color:#fff;cursor:pointer;background-color:#495057;border:none;border-radius:6px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-weight:500;transition:all .2s;display:flex}.extrude-button:hover{background-color:#343a40;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.sketch-help{border-top:1px solid #e9ecef;margin-top:1.5rem;padding-top:1rem}.sketch-help h4{color:#495057;margin:0 0 .75rem;font-size:.9rem;font-weight:600}.sketch-help ul{margin:0;padding:0;list-style:none}.sketch-help li{color:#6c757d;padding:.25rem 0;font-size:.8rem}.sketch-help li strong{color:#495057}.sketch-actions{margin-top:8px}.edit-btn{color:#fff;cursor:pointer;background-color:#28a745;border:none;border-radius:4px;padding:4px 8px;font-size:12px}.edit-btn:hover{background-color:#218838}.editing-section{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;margin-bottom:16px;padding:12px}.editing-section h4{color:#856404;margin:0 0 8px}.import-export-panel{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.action-buttons{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.export-btn,.import-btn{cursor:pointer;border:1px solid #ced4da;border-radius:6px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.export-btn{color:#fff;background-color:#495057;border-color:#495057}.export-btn:hover:not(:disabled){background-color:#343a40;border-color:#343a40;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.import-btn{color:#fff;background-color:#6c757d;border-color:#6c757d}.import-btn:hover:not(:disabled){background-color:#5a6268;border-color:#5a6268;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.export-btn:disabled,.import-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-result{text-align:center;border-radius:4px;margin-bottom:1rem;padding:.75rem;font-size:.8rem;font-weight:500}.action-result.success{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb}.action-result.error{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.panel-info li{color:#6c757d;padding:.25rem 0 .25rem 1rem;font-size:.8rem;position:relative}.panel-info li:before{content:"•";color:#495057;position:absolute;left:0}.undo-redo-panel{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.panel-header{border-bottom:1px solid #e9ecef;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.panel-header h3{color:#2c3e50;margin:0;font-size:1rem;font-weight:600}.history-info{color:#6c757d;font-family:monospace;font-size:.8rem}.action-buttons{gap:.5rem;margin-bottom:1rem;display:flex}.undo-btn,.redo-btn,.clear-btn{cursor:pointer;border:1px solid #ced4da;border-radius:4px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s;display:flex}.undo-btn{color:#fff;background-color:#6c757d;border-color:#6c757d}.undo-btn:hover:not(:disabled){background-color:#5a6268;border-color:#5a6268}.redo-btn{color:#fff;background-color:#495057;border-color:#495057}.redo-btn:hover:not(:disabled){background-color:#343a40;border-color:#343a40}.clear-btn{color:#6c757d;background-color:#f8f9fa;border-color:#ced4da}.clear-btn:hover:not(:disabled){color:#495057;background-color:#e9ecef;border-color:#adb5bd}.undo-btn:disabled,.redo-btn:disabled,.clear-btn:disabled{opacity:.4;cursor:not-allowed}.panel-info{border-top:1px solid #e9ecef;padding-top:1rem}.panel-info h4{color:#495057;margin:0 0 .75rem;font-size:.9rem;font-weight:600}.panel-info ul{margin:0;padding:0;list-style:none}.panel-info li{color:#6c757d;padding:.25rem 0;font-size:.8rem}.dimension-overlay{pointer-events:none;z-index:1000;position:absolute;top:20px;left:50%;transform:translate(-50%)}.dimension-text{color:#fff;white-space:nowrap;background-color:#000c;border-radius:4px;padding:.5rem 1rem;font-family:monospace;font-size:14px;font-weight:700}.group-panel{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.group-panel-header{border-bottom:1px solid #e9ecef;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.group-panel-header h3{color:#2c3e50;align-items:center;gap:.5rem;margin:0;font-size:1rem;font-weight:600;display:flex}.selection-info h4,.groups-list h4{color:#495057;margin:0 0 .75rem;font-size:.9rem;font-weight:600}.selection-actions{gap:.5rem;margin-bottom:.5rem;display:flex}.create-group-btn,.clear-selection-btn{cursor:pointer;border:1px solid #e0e0e0;border-radius:4px;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.create-group-btn{color:#fff;background-color:#28a745;border-color:#28a745}.create-group-btn:hover:not(:disabled){background-color:#218838}.create-group-btn:disabled{cursor:not-allowed;background-color:#6c757d}.clear-selection-btn{color:#6c757d;background-color:#f8f9fa}.clear-selection-btn:hover{background-color:#e9ecef}.selection-hint{color:#6c757d;margin:0;font-size:.8rem;font-style:italic}.no-groups{color:#6c757d;text-align:center;margin:0;padding:1rem;font-style:italic}.group-items{max-height:200px;overflow-y:auto}.group-item{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem;display:flex}.group-info{flex:1}.group-name-display{flex-direction:column;gap:.25rem;display:flex}.group-name{color:#2c3e50;font-weight:600}.group-count{color:#6c757d;font-size:.8rem}.group-rename input{border:1px solid #ced4da;border-radius:4px;width:100%;padding:.25rem .5rem;font-size:.9rem}.group-actions{gap:.25rem;display:flex}.rename-btn,.ungroup-btn,.delete-group-btn{cursor:pointer;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;display:flex}.rename-btn{color:#007bff}.rename-btn:hover{background-color:#e7f3ff;border-color:#007bff}.ungroup-btn{color:#ffc107}.ungroup-btn:hover{background-color:#fff3cd;border-color:#ffc107}.delete-group-btn{color:#dc3545}.delete-group-btn:hover{background-color:#f8d7da;border-color:#dc3545}.group-help{border-top:1px solid #e9ecef;margin-top:1.5rem;padding-top:1rem}.group-help h4{color:#495057;margin:0 0 .75rem;font-size:.9rem;font-weight:600}.group-help ul{margin:0;padding:0;list-style:none}.group-help li{color:#6c757d;padding:.25rem 0;font-size:.8rem}.group-help li strong{color:#495057}.top-nav{color:#333;background-color:#fff;border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex;box-shadow:0 1px 2px #0000000d}.logo{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-size:1.5rem;font-weight:700}.history-controls{align-items:center;gap:.5rem;display:flex}.nav-btn{color:#495057;cursor:pointer;background-color:#f8f9fa;border:1px solid #ced4da;border-radius:4px;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s;display:flex}.nav-btn:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.history-counter{color:#6c757d;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:.5rem;font-family:monospace;font-size:.8rem}.App{background-color:#f8f9fa;flex-direction:column;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;display:flex}.top-nav-container{z-index:100;flex-shrink:0}.main-content{background-color:#fff;flex-grow:1;display:flex;overflow:hidden}.cad-toolbar{background-color:#fff;flex-shrink:0;width:200px}canvas{cursor:grab;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);flex-grow:1}canvas:active{cursor:grabbing}.right-panel{background-color:#fff;flex-direction:column;flex-shrink:0;gap:1rem;width:320px;padding:1rem;display:flex;overflow-y:auto}.property-panel{background-color:#0000;border-left:none;padding:0}
