.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#1e1e1e;border-radius:8px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #333}.modal-header h2{margin:0;color:#fff;font-size:24px}.close-btn{background:none;border:none;color:#aaa;font-size:32px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-btn:hover{color:#fff}.modal-actions{display:flex;gap:10px;padding:20px;border-bottom:1px solid #333;flex-wrap:wrap}.error-message{background:#f44;color:#fff;padding:12px;margin:20px 20px 0;border-radius:4px}.config-content{padding:20px}.atc-slots-section{margin-bottom:30px}.atc-slots-section h3{color:#fff;margin-bottom:15px;font-size:18px}.atc-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 768px){.atc-slots{grid-template-columns:repeat(2,1fr)}}.atc-slot{display:flex;align-items:center;gap:8px;padding:10px;background:#2a2a2a;border-radius:4px;min-width:0}.atc-slot label{color:#aaa;min-width:50px;font-weight:500;flex-shrink:0;font-size:14px}.atc-slot select{flex:1;padding:6px 8px;background:#1e1e1e;border:1px solid #444;border-radius:4px;color:#fff;font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.atc-slot select:focus{outline:none;border-color:#007acc}.tools-section h3{color:#fff;margin-bottom:15px;font-size:18px}.tools-list{display:flex;flex-direction:column;gap:15px}.tool-card{background:#2a2a2a;border-radius:4px;padding:15px;border:1px solid #333}.tool-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.tool-header h4{margin:0;color:#fff;font-size:16px}.tool-summary{display:flex;gap:15px;flex-wrap:wrap;color:#aaa;font-size:14px}.tool-summary span{background:#1e1e1e;padding:4px 10px;border-radius:3px}.tool-edit-form{margin-top:15px;padding-top:15px;border-top:1px solid #444;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}.form-row{display:flex;flex-direction:column;gap:5px}.form-row label{color:#aaa;font-size:13px;font-weight:500}.form-row input,.form-row textarea{padding:8px;background:#1e1e1e;border:1px solid #444;border-radius:4px;color:#fff;font-size:14px;font-family:inherit}.form-row input:focus,.form-row textarea:focus{outline:none;border-color:#007acc}.form-row textarea{resize:vertical;min-height:60px}.modal-footer{padding:20px;border-top:1px solid #333;display:flex;justify-content:flex-end}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#007acc;color:#fff}.btn-primary:hover{background:#005a9e}.btn-secondary{background:#444;color:#fff}.btn-secondary:hover{background:#555}.btn-warning{background:#f80;color:#fff}.btn-warning:hover{background:#c60}.btn-small{padding:6px 12px;font-size:13px}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.tools-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.tools-header h3{margin:0;color:#fff;font-size:18px}.tool-actions{display:flex;gap:8px}.add-tool-form{background:#2a2a2a;border:2px dashed #007acc;border-radius:4px;padding:15px;margin-bottom:15px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.add-tool-form .form-row select{padding:8px;background:#1e1e1e;border:1px solid #444;border-radius:4px;color:#fff;font-size:14px}.add-tool-form .form-row select:focus{outline:none;border-color:#007acc}.form-row.full-width{grid-column:1 / -1;display:flex;justify-content:flex-end}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 2rem}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.header-brand{display:flex;align-items:center;gap:.75rem}.header-logo{flex-shrink:0}.header-brand h1{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:1.5rem}.header-project{display:flex;align-items:center;gap:1rem}.project-name{font-weight:500;color:var(--accent-primary)}.project-size{color:var(--text-secondary);font-size:.875rem}.upload-zone-container{width:100%;max-width:600px}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;border:2px dashed var(--border-color);border-radius:12px;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;text-align:center}.upload-zone:hover{border-color:var(--accent-primary);background:var(--bg-tertiary)}.upload-zone.active{border-color:var(--accent-primary);background:#4ade801a}.upload-zone.uploading{pointer-events:none;opacity:.7}.upload-icon{color:var(--accent-primary);margin-bottom:1.5rem}.upload-text h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.upload-text p{color:var(--text-secondary);margin-bottom:1.5rem}.upload-formats{font-size:.75rem;color:var(--text-secondary);padding:.5rem 1rem;background:var(--bg-tertiary);border-radius:4px}.gcode-preview{flex:1;position:relative;background:#0f1117;overflow:hidden}.gcode-toolbar{position:absolute;top:.75rem;left:.75rem;z-index:2;background:#090b10d9;border:1px solid rgba(90,100,120,.4);border-radius:10px;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.35rem;max-width:60%}.gcode-toolbar-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#c8d2e6b3}.gcode-tool-list{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.gcode-tool-toggle{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary)}.gcode-tool-toggle input{accent-color:var(--accent-primary)}.gcode-canvas{position:absolute;top:0;right:0;bottom:0;left:0}.gcode-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0a0c12bf;color:var(--text-secondary);font-size:.95rem;text-align:center;padding:1rem}.gcode-overlay.error{color:#ff6b6b}.board-preview{display:flex;flex-direction:column;height:100%}.preview-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.toolbar-left{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;flex:1;min-width:0}.preview-tabs{display:flex;gap:.5rem;padding-right:1rem;border-right:1px solid var(--border-color)}.preview-tab{border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);padding:.35rem .75rem;border-radius:999px;font-size:.8rem;cursor:pointer;transition:all .2s ease}.preview-tab:hover:not(:disabled){border-color:var(--accent-primary);color:var(--text-primary)}.preview-tab.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#0b0d12}.preview-tab:disabled{opacity:.5;cursor:not-allowed}.layer-toggles{display:flex;gap:1rem;flex-wrap:wrap}.layer-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.layer-toggle input{display:none}.layer-color{width:12px;height:12px;border-radius:2px;opacity:.5;transition:opacity .2s}.layer-toggle input:checked+.layer-color{opacity:1}.layer-name{color:var(--text-secondary)}.layer-toggle input:checked~.layer-name{color:var(--text-primary)}.zoom-controls{display:flex;align-items:center;gap:.5rem}.zoom-controls button{width:32px;height:32px;padding:0;font-size:1.25rem}.zoom-controls span{min-width:50px;text-align:center;font-size:.875rem;color:var(--text-secondary)}.preview-canvas{flex:1;overflow:hidden;background:#0f1117;cursor:grab;position:relative}.preview-canvas:active{cursor:grabbing}.preview-content{position:absolute}.board-background{background:#0b0d12;border:1px solid var(--border-color)}.layer-svg{position:absolute;top:0;left:0}.layer-svg>svg{display:block;width:100%;height:100%}.layer-copper-top{filter:brightness(0) saturate(100%) invert(15%) sepia(100%) saturate(7500%) hue-rotate(0deg) brightness(105%) contrast(115%);opacity:.9}.layer-copper-bottom{filter:brightness(0) saturate(100%) invert(10%) sepia(100%) saturate(7500%) hue-rotate(240deg) brightness(100%) contrast(115%);opacity:.9}.layer-silk-top{filter:brightness(0) saturate(100%) invert(85%) sepia(75%) saturate(1000%) hue-rotate(10deg) brightness(105%) contrast(105%);opacity:.9}.layer-silk-bottom{filter:brightness(0) saturate(100%) invert(55%) sepia(100%) saturate(1000%) hue-rotate(80deg) brightness(100%) contrast(105%);opacity:.9}.layer-mask{filter:brightness(0) saturate(100%) invert(55%) sepia(100%) saturate(1000%) hue-rotate(80deg) brightness(100%) contrast(105%);opacity:.25}.layer-drill{filter:brightness(0) saturate(100%) invert(50%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%);opacity:.9}.layer-outline{filter:brightness(0) saturate(100%) invert(15%) sepia(100%) saturate(5000%) hue-rotate(280deg) brightness(100%) contrast(115%);opacity:.95}.grid-overlay{position:absolute;top:0;left:0;pointer-events:none}.preview-info{display:flex;justify-content:space-between;padding:.5rem 1rem;background:var(--bg-tertiary);border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-secondary)}.toolpath-toggles{display:flex;gap:.75rem;flex-wrap:wrap;padding-left:1rem;border-left:1px solid var(--border-color);margin-left:1rem}.gcode-controls{display:flex;align-items:center;gap:.5rem}.gcode-controls label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.gcode-controls select{min-width:180px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;padding:.35rem .5rem}.toolpath-master{font-weight:500}.toolpath-toggle{font-size:.8rem}.toolpath-svg{position:absolute;top:0;left:0;pointer-events:none}.toolpath-svg>svg{display:block;width:100%;height:100%}.toolpath-isolation svg path,.toolpath-isolation svg line,.toolpath-pockets svg path,.toolpath-pockets svg line,.toolpath-pockets_cleanup svg path,.toolpath-pockets_cleanup svg line,.toolpath-outline svg path,.toolpath-outline svg line,.toolpath-hole_milling svg path,.toolpath-hole_milling svg line,.toolpath-silkscreen svg path,.toolpath-soldermask svg path{filter:drop-shadow(0 0 2px rgba(239,68,68,.6))}.toolpath-drilling svg circle{filter:drop-shadow(0 0 2px rgba(59,130,246,.6))}.operation-panel{display:flex;flex-direction:column;gap:1rem}.operation-panel h2{font-size:1.125rem;margin-bottom:.5rem}.config-section{border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);border:none;color:var(--text-primary);font-size:.9375rem;font-weight:500;text-align:left;cursor:pointer;transition:background .2s}.section-header:hover{background:var(--border-color)}.chevron{font-size:.75rem;color:var(--text-secondary)}.section-content{padding:1rem;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.375rem;font-size:.875rem;color:var(--text-secondary)}.form-group input,.form-group select{width:100%;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.875rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary)}.operation-list{display:flex;flex-direction:column;gap:.75rem}.operation-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer}.operation-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary)}.operation-toggle span{font-size:.9375rem}.help-text{font-size:.75rem;color:var(--text-secondary);margin-top:.75rem;line-height:1.5}.error-message{padding:.75rem 1rem;background:#f871711a;border:1px solid var(--accent-danger);border-radius:6px;color:var(--accent-danger);font-size:.875rem}.generate-btn{width:100%;padding:1rem;font-size:1rem;margin-top:.5rem}.drill-mapping{margin-top:.75rem}.drill-mapping>label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.drill-mapping-list{display:flex;flex-direction:column;gap:.375rem}.drill-mapping-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;background:var(--bg-tertiary);border-radius:4px;font-size:.8125rem}.drill-mapping-item .hole-size{color:var(--text-primary);font-family:monospace;min-width:80px}.drill-mapping-item .arrow{color:var(--text-secondary)}.drill-mapping-item .drill-name{color:var(--accent-primary);font-weight:500}.drill-mapping-item.no-drill{background:#f871711a;border:1px solid var(--accent-danger)}.drill-mapping-item .no-drill-warning{color:var(--accent-danger);font-weight:500}.download-panel{background:linear-gradient(135deg,rgba(74,222,128,.1) 0%,var(--bg-secondary) 100%);border-color:var(--accent-primary)}.download-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--accent-primary)}.download-header h3{font-size:1.125rem;margin:0}.download-info{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.file-list{background:var(--bg-tertiary);border-radius:6px;padding:1rem;margin-bottom:1rem}.file-list h4{font-size:.75rem;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.5rem}.file-list ul{list-style:none;font-size:.875rem;font-family:monospace;margin:0;padding:0}.file-list li{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.25rem 0;color:var(--text-primary)}.file-list li:before{content:"- "}.file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-runtime{color:var(--text-secondary);font-size:.75rem;white-space:nowrap}.download-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem}.upload-section{display:flex;justify-content:center;align-items:center;min-height:60vh}.workspace{display:grid;grid-template-columns:1fr 400px;gap:2rem;height:calc(100vh - 200px)}.workspace-left{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.workspace-right{display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.footer{padding:1rem;text-align:center;color:var(--text-secondary);font-size:.875rem;border-top:1px solid var(--border-color)}@media (max-width: 1024px){.workspace{grid-template-columns:1fr;height:auto}.workspace-left{min-height:400px}}:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #252542;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--accent-primary: #4ade80;--accent-secondary: #60a5fa;--accent-warning: #fbbf24;--accent-danger: #f87171;--border-color: #3a3a5a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}.container{max-width:1400px;margin:0 auto;padding:0 1rem}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;transition:all .2s ease;border:none}.btn-primary{background:var(--accent-primary);color:#000}.btn-primary:hover{background:#22c55e}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn:disabled{opacity:.5;cursor:not-allowed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}
