*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;color:#1a1a1a;background-color:#f8f9fa}.suggestion-dropdown-container{position:relative;width:100%}.form-input{padding:.75rem 1rem;border:1px solid #ced4da;border-radius:.375rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-input:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.suggestion-dropdown-list{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;max-height:250px;overflow-y:auto;background-color:#fff;border:1px solid #ced4da;border-radius:.375rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.15);list-style:none;padding:0;z-index:1000}.suggestion-dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .15s ease-in-out;font-size:1rem;color:#1a1a1a}.suggestion-dropdown-item:hover{background-color:#f8f9fa}.suggestion-dropdown-item:active{background-color:#e9ecef}.suggestion-dropdown-list::-webkit-scrollbar{width:8px}.suggestion-dropdown-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:0 .375rem .375rem 0}.suggestion-dropdown-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.suggestion-dropdown-list::-webkit-scrollbar-thumb:hover{background:#555}body{margin:0;min-height:100vh;background-color:#f8f9fa}.logo-header{position:fixed;top:0;left:0;width:100%;height:60px;background-color:#fff;border-bottom:1px solid #e9ecef;z-index:1000}.logo-container,.logo-header{display:flex;align-items:center}.logo-container{padding:0 1rem}.container{max-width:1200px;margin:0 auto;padding:80px 1rem 0}.header{padding:1rem 2rem;border-bottom:1px solid #e9ecef;background-color:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.job-info{display:flex;justify-content:space-between;align-items:center}.job-label{font-size:1.1rem;font-weight:600;color:#495057}.job-id{display:flex;align-items:center;gap:.5rem;color:#007bff;font-weight:500}.title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:2rem;color:#1a1a1a}.search-container{position:relative;max-width:400px;margin:0 auto 2rem}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6c757d;z-index:1}.search-input{width:100%;padding:12px 40px;border:1px solid #dee2e6;border-radius:8px;font-size:1rem;background-color:#fff;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.1)}.category-tabs{display:flex;justify-content:center;gap:0;margin-bottom:3rem;border-bottom:1px solid #dee2e6}.category-tab{padding:1rem 1.5rem;background:none;font-size:.95rem;font-weight:500;color:#6c757d;cursor:pointer;border:none;border-bottom:2px solid transparent;transition:all .2s ease;white-space:nowrap}.category-tab:hover{color:#007bff}.category-tab.active{color:#007bff;border-bottom-color:#007bff}.materials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-top:2rem}.material-card{background:#fff;border-radius:12px;padding:1.5rem;text-align:center;cursor:pointer;border:2px solid #e9ecef;transition:all .2s ease;box-shadow:0 2px 4px rgba(0,0,0,.05)}.material-card:hover{border-color:#007bff;box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px)}.material-image{width:120px;height:120px;margin:0 auto 1rem;border-radius:8px;overflow:hidden;background-color:#f8f9fa;display:flex;align-items:center;justify-content:center}.material-image img{width:100%;height:100%;object-fit:cover}.material-name{font-size:1.1rem;font-weight:600;color:#1a1a1a}.loading,.no-results{text-align:center;padding:3rem;color:#6c757d;font-size:1.1rem}.no-results{grid-column:1/-1}.back-button{background:#007bff;border:1px solid #007bff;border-radius:4px;color:#fff;font-size:1rem;cursor:pointer;margin-top:1.5rem;margin-bottom:1rem;padding:.75rem 1.5rem;display:flex;align-items:center;gap:.5rem;transition:background-color .2s,border-color .2s}.back-button:hover{background:#0056b3;border-color:#0056b3}.grade-selection{display:flex;gap:1rem;justify-content:center;margin-bottom:3rem;flex-wrap:wrap}.grade-option{position:relative;cursor:pointer}.grade-radio{position:absolute;opacity:0;cursor:pointer}.grade-label{display:block;padding:1rem 2rem;border:2px solid #dee2e6;border-radius:8px;background-color:#fff;font-weight:500;text-align:center;min-width:80px;transition:all .2s ease}.grade-radio:checked+.grade-label{border-color:#007bff;background-color:#007bff;color:#fff}.grade-label:hover{border-color:#007bff}.material-specs{max-width:600px;margin:0 auto}.specs-title{font-size:1.5rem;font-weight:600;text-align:center;margin-bottom:2rem;color:#495057}.size-inputs{display:grid;grid-template-columns:1fr 1fr;grid-gap:2rem;gap:2rem;margin-bottom:3rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-label{font-weight:500;color:#495057;margin-bottom:.5rem}.input-with-unit{display:flex;align-items:center;gap:.5rem;background-color:#fff;border:1px solid #dee2e6;border-radius:8px;padding:.75rem}.size-input,.thickness-input{border:none;outline:none;font-size:1rem;flex:1 1;background:transparent}.unit-separator{color:#6c757d;font-weight:500;margin:0 .5rem}.unit-select{border:none;outline:none;background:transparent;cursor:pointer;min-width:60px}.unit-label,.unit-select{font-size:1rem;color:#495057}.unit-label{font-weight:500;min-width:30px}.thickness-section{margin-bottom:3rem}.thickness-title{font-size:1.25rem;font-weight:600;text-align:center;margin-bottom:1.5rem;color:#495057}.thickness-section .input-group{max-width:300px;margin:0 auto}.action-buttons{margin-top:3rem}.continue-button{background-color:#007bff;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.continue-button:hover{background-color:#0056b3}.job-form-container{max-width:500px;margin:0 auto;padding:3rem 2rem}.job-form{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px rgba(0,0,0,.1)}.form-grid-2,.form-group{margin-bottom:1.5rem}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:1.5rem;gap:1.5rem}@media (max-width:768px){.form-grid-2{grid-template-columns:1fr}}.form-label{display:block;font-size:1rem}.form-input{width:100%;padding:1rem 1.25rem;border:2px solid #dee2e6;border-radius:8px;font-size:1rem;transition:border-color .2s ease;background-color:#fff}.form-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.1);background-color:#fff}.form-help{display:block;margin-top:.5rem;color:#6c757d;font-size:.875rem}.form-actions{margin-top:2rem}.create-job-button{background-color:#007bff;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:200px}.create-job-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,123,255,.3)}.create-job-button:disabled{background-color:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.error-message{background-color:#f8d7da;color:#721c24;padding:.75rem 1rem;border-radius:8px;border:1px solid #f5c6cb;margin-bottom:1rem;font-size:.9rem}.piercing-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.piercing-dialog{background:linear-gradient(135deg,#e3f2fd,#f8f9fa);border-radius:16px;padding:3rem;max-width:600px;width:100%;box-shadow:0 8px 32px rgba(0,0,0,.1);text-align:center;position:relative}.info-icon{margin-bottom:2rem}.icon-circle{width:60px;height:60px;background-color:#007bff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 4px 12px rgba(0,123,255,.3)}.icon-text{color:#fff;font-size:1.5rem;font-weight:700}.message-content{margin-bottom:2.5rem;line-height:1.8}.greeting{font-size:1.2rem;color:#2c3e50;margin-bottom:1.5rem;font-weight:500}.instruction{margin-bottom:1.5rem}.conclusion,.instruction{font-size:1.1rem;color:#495057}.conclusion{margin-bottom:0;font-style:italic}.operation-selection{margin-bottom:3rem;padding:2rem;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05)}.selection-title{font-size:1.3rem;font-weight:600;color:#2c3e50;margin-bottom:1.5rem}.radio-options{gap:2rem;flex-wrap:wrap}.radio-option,.radio-options{display:flex;justify-content:center}.radio-option{align-items:center;gap:.75rem;cursor:pointer;padding:1rem 1.5rem;border:2px solid #dee2e6;border-radius:12px;background-color:#f8f9fa;transition:all .3s ease;min-width:150px}.radio-option:hover{border-color:#007bff;background-color:#e3f2fd}.radio-input{width:20px;height:20px;accent-color:#007bff;cursor:pointer}.radio-input:checked+.radio-label{color:#007bff;font-weight:600}.radio-option:has(.radio-input:checked){border-color:#007bff;background-color:#e3f2fd;box-shadow:0 4px 12px rgba(0,123,255,.2)}.radio-label{font-size:1.1rem;color:#495057;cursor:pointer;transition:color .3s ease}.action-buttons{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.back-btn{background-color:#6c757d;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.back-btn:hover{background-color:#5a6268;transform:translateY(-2px)}.confirm-btn{background-color:#007bff;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:200px}.confirm-btn:hover{background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,123,255,.3)}.header-center{display:flex;justify-content:center;flex:1 1}.piercing-icon{background-color:#007bff;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.content-layout{display:grid;grid-template-columns:1fr 1fr;grid-gap:2rem;gap:2rem;margin-top:1.5rem}@media (max-width:1024px){.content-layout{grid-template-columns:1fr}}.devices-section,.operating-form{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}.devices-section{max-height:800px;overflow-y:auto}.devices-title{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.select-hint{font-size:.9rem;font-weight:400;color:#6c757d;font-style:italic}.no-devices{text-align:center;color:#6c757d;padding:2rem;font-size:1.1rem}.devices-list{display:flex;flex-direction:column;gap:1rem}.device-card{border:2px solid #dee2e6;border-radius:8px;padding:1.25rem;transition:all .2s ease;background-color:#fff}.device-card:hover{border-color:#007bff;box-shadow:0 4px 12px rgba(0,123,255,.15)}.device-card.selected{border-color:#28a745;background-color:#f0f9f4;box-shadow:0 4px 12px rgba(40,167,69,.2)}.device-card.disabled{opacity:.5;background-color:#f8f9fa}.device-header{justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e9ecef}.device-header,.device-status{display:flex;align-items:center}.device-status{gap:.75rem}.status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-dot.connected{background-color:#28a745;box-shadow:0 0 0 3px rgba(40,167,69,.2)}.status-dot.disconnected{background-color:#dc3545;box-shadow:0 0 0 3px rgba(220,53,69,.2)}.device-name{font-size:1.1rem;font-weight:600;color:#2c3e50}.selected-badge{background-color:#28a745}.disconnected-badge,.selected-badge{color:#fff;padding:.35rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.disconnected-badge{background-color:#dc3545}.device-details{font-size:.95rem;color:#495057;line-height:1.8}.device-details p{margin:.4rem 0}.device-details strong{color:#2c3e50;font-weight:600;min-width:130px;display:inline-block}.task-badge{padding:.25rem .6rem;border-radius:4px;font-size:.85rem;font-weight:600}.task-badge.task-yes{background-color:#d4edda;color:#155724}.task-badge.task-no{background-color:#f8d7da;color:#721c24}.force-complete-btn{width:100%;margin-top:1rem;padding:.75rem;background-color:#ffc107;color:#212529;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.force-complete-btn:hover{background-color:#e0a800;transform:translateY(-1px);box-shadow:0 4px 8px rgba(255,193,7,.3)}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.dialog-content{background-color:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;box-shadow:0 8px 32px rgba(0,0,0,.3)}.dialog-title{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-bottom:1rem}.dialog-message{font-size:1rem;color:#495057;line-height:1.6;margin-bottom:1.5rem}.dialog-actions{display:flex;gap:1rem;justify-content:flex-end}.dialog-btn{padding:.75rem 2rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.dialog-btn-no{background-color:#6c757d;color:#fff}.dialog-btn-no:hover{background-color:#5a6268}.dialog-btn-yes{background-color:#ffc107;color:#212529}.dialog-btn-yes:hover{background-color:#e0a800}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:3rem;gap:3rem;margin-bottom:3rem}.form-group{display:flex;flex-direction:column;gap:.75rem}.form-label{font-size:1.1rem;font-weight:600;color:#495057;margin-bottom:.5rem}.form-select{border:2px solid #dee2e6;border-radius:8px;font-size:1rem;background-color:#fff;color:#495057;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1rem;padding:1rem 3rem 1rem 1.25rem}.form-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.1)}.form-select:hover{border-color:#adb5bd}.form-actions{text-align:center;margin-top:3rem}.start-job-button{background-color:#28a745;color:#fff;border:none;padding:1rem 2.5rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:200px}.start-job-button:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 12px rgba(40,167,69,.3)}.start-job-button:disabled{background-color:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.page-title{font-size:2.5rem;font-weight:700;color:#212529;margin:2rem 0;text-align:center}.subtitle{text-align:center;font-size:1.2rem;color:#495057;margin:1.5rem 0 3rem;line-height:1.6}.job-options{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:0 auto}.option-button{padding:1.25rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#fff}.continue-button{background-color:#28a745}.continue-button:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 12px rgba(40,167,69,.3)}.new-button{background-color:#007bff}.new-button:hover{background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,123,255,.3)}.cycles-card{max-width:500px;margin:3rem auto;padding:2.5rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.start-button{width:100%;background-color:#28a745;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:1.5rem}.start-button:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 12px rgba(40,167,69,.3)}.start-button:active{transform:translateY(0)}.stage-header{text-align:center;margin:2rem 0 3rem;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.stage-title{font-size:2.5rem;font-weight:700;margin:0 0 .5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.stage-subtitle{font-size:1.1rem;margin:0;opacity:.9}.stage-form{max-width:1000px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.status-container{max-width:900px;margin:0 auto;padding:2rem}.status-title{font-size:1.8rem;font-weight:700;text-align:left;margin-bottom:2rem;color:#2c3e50}.device-logs-container{background-color:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);width:400px;flex-shrink:0;overflow:hidden;align-self:flex-start}.device-logs-header{background-color:#007bff;color:#fff;padding:.75rem 1rem;font-weight:600;font-size:1rem;border-bottom:2px solid #0056b3}.device-logs-content{max-height:250px;overflow-y:auto;padding:1rem;background-color:#f8f9fa}.device-log-item{display:flex;gap:1rem;padding:.5rem;margin-bottom:.5rem;background-color:#fff;border-radius:6px;border-left:3px solid #007bff;font-size:.9rem;box-shadow:0 1px 3px rgba(0,0,0,.05)}.device-log-item:last-child{margin-bottom:0}.log-time{color:#6c757d;font-weight:600;min-width:100px;font-size:.85rem}.log-action{color:#495057;flex:1 1}.device-logs-content::-webkit-scrollbar{width:6px}.device-logs-content::-webkit-scrollbar-track{background:#e9ecef;border-radius:10px}.device-logs-content::-webkit-scrollbar-thumb{background:#007bff;border-radius:10px}.device-logs-content::-webkit-scrollbar-thumb:hover{background:#0056b3}.loading-section{text-align:center;padding:4rem 2rem}.loading-spinner{width:60px;height:60px;border:4px solid #f3f3f3;border-top-color:#007bff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.loading-text{font-size:1.3rem;font-weight:600;color:#495057;margin-bottom:.5rem}.loading-subtext{font-size:1rem;color:#6c757d;margin-bottom:0}.status-legend{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:3rem;padding:1.5rem;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05)}.legend-item{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:#495057}.legend-color{width:20px;height:20px;border-radius:4px;flex-shrink:0}.legend-color.red{background-color:#dc3545}.legend-color.orange{background-color:#fd7e14}.legend-color.green{background-color:#28a745}.status-bars{display:flex;gap:.5rem;margin-bottom:1rem;padding:2rem;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);flex-wrap:wrap;justify-content:center}.status-bar-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.status-bar{width:40px;height:120px;border-radius:6px;transition:all .3s ease;box-shadow:0 2px 6px rgba(0,0,0,.1)}.status-bar:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.bar-number{font-size:.9rem;font-weight:600;color:#495057}.status-actions{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.confirm-status-btn{background-color:#007bff;color:#fff;border:none;padding:1rem 3rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:150px}.confirm-status-btn:hover{background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,123,255,.3)}.retry-btn{background-color:#6c757d;color:#fff;border:none;padding:1rem 3rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:150px}.retry-btn:hover{background-color:#545b62;transform:translateY(-2px);box-shadow:0 4px 12px hsla(208,7%,46%,.3)}.loading-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.error-section,.processing-section{text-align:center;max-width:1000px;width:100%}.processing-layout{display:flex;gap:2rem;align-items:flex-start;justify-content:center;margin-top:2rem}.processing-content{flex:1 1;max-width:500px}.loading-spinner-large{width:80px;height:80px;border:6px solid #f3f3f3;border-top-color:#007bff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-title{font-size:2rem;font-weight:700;color:#1a1a1a;margin-bottom:1rem}.loading-subtitle{font-size:1.1rem;color:#6c757d;margin-bottom:3rem;line-height:1.5}.job-parameters{background-color:#f8f9fa;border-radius:8px;padding:2rem;margin-bottom:2rem;border:1px solid #e9ecef}.parameter-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e9ecef}.parameter-item:last-child{border-bottom:none}.parameter-label{font-weight:600;color:#495057}.parameter-value{color:#007bff;font-weight:500}.error-section{padding:3rem 2rem}.error-icon{font-size:4rem;margin-bottom:1rem}.error-title{font-size:2rem;font-weight:700;color:#dc3545;margin-bottom:1rem}.error-message{font-size:1.1rem;color:#6c757d;margin-bottom:2rem}.result-tab{margin-top:2rem;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.06);padding:1.5rem}.result-tab-header{font-size:1.25rem;font-weight:700;color:#2c3e50;margin-bottom:1rem}.dropdown-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem;margin-bottom:1.5rem}.result-field{display:flex;flex-direction:column;gap:.5rem}.result-label{font-weight:600;color:#495057}.result-select{border:2px solid #dee2e6;border-radius:8px;font-size:1rem;background-color:#fff;color:#495057;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1rem;padding:.875rem 3rem .875rem 1rem}input[type=number].result-select{background-image:none;padding-right:1rem}input[type=number].result-select::-webkit-inner-spin-button,input[type=number].result-select::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number].result-select{-moz-appearance:textfield}.result-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.1)}.controls-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem 2rem;gap:1rem 2rem;margin-bottom:1.5rem}.control-item{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;padding:1rem}.control-label{font-size:.95rem;color:#495057;margin-bottom:.5rem}.control-row{display:grid;grid-template-columns:48px 1fr 48px;align-items:center;grid-gap:.75rem;gap:.75rem}.control-btn{font-size:1.25rem;cursor:pointer}.control-btn,.control-value{background-color:#fff;border:2px solid #dee2e6;border-radius:8px;font-weight:700;height:44px}.control-value{align-items:center}.control-value,.result-tab-actions{display:flex;justify-content:center}.result-tab-actions{margin-top:1rem}@media (max-width:768px){.container{padding:0 .5rem}.job-info{flex-direction:column;gap:.5rem;align-items:flex-start}.title{font-size:1.5rem}.category-tabs{flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.category-tab{padding:.75rem 1rem;font-size:.9rem}.materials-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.grade-selection{gap:.5rem}.grade-label{padding:.75rem 1.5rem;min-width:60px;font-size:.9rem}.processing-layout{flex-direction:column;align-items:center}.device-logs-container{width:100%;max-width:500px}.size-inputs{grid-template-columns:1fr;gap:1.5rem}.specs-title{font-size:1.25rem}.thickness-title{font-size:1.1rem}.controls-grid,.dropdown-row{grid-template-columns:1fr}}.device-management-section{max-width:800px;margin:3rem auto 0;padding:0 1rem}.section-title{font-size:1.75rem;font-weight:700;text-align:center;margin-bottom:2rem;color:#2c3e50}.device-buttons{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1.5rem;gap:1.5rem;width:100%}.device-nav-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem 1rem;background:#fff;border:2px solid #e9ecef;border-radius:16px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(0,0,0,.08);text-align:center;grid-column:span 1;min-height:180px}.device-nav-button:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}.device-connection-btn:hover{border-color:#28a745;background:linear-gradient(135deg,rgba(40,167,69,.05),rgba(40,167,69,.02))}.device-data-btn:hover,.old-device-data-btn:hover{border-color:#667eea;background:linear-gradient(135deg,rgba(102,126,234,.05),rgba(118,75,162,.02))}.button-icon{font-size:3rem;line-height:1;flex-shrink:0}.button-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.button-title{font-size:1.1rem;font-weight:700;color:#2c3e50}.button-description{font-size:.85rem;color:#6c757d;line-height:1.4;text-align:center}@media (max-width:768px){.device-buttons{grid-template-columns:1fr}.device-nav-button{padding:1.5rem}.button-icon{font-size:2.5rem}.button-title{font-size:1.1rem}.button-description{font-size:.875rem}}.admin-layout{display:flex;min-height:calc(100vh - 60px);margin-top:60px}.admin-sidebar{width:280px;background-color:#2c3e50;color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:60px;bottom:0;overflow-y:auto;z-index:100;box-shadow:2px 0 8px rgba(0,0,0,.1)}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid hsla(0,0%,100%,.1);background-color:#1a252f}.sidebar-header h2{font-size:1.5rem;font-weight:700;margin:0;color:#fff}.sidebar-nav{flex:1 1;padding:1.5rem 0}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-menu li{margin:0}.sidebar-menu-item{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem 1.5rem;background:none;color:hsla(0,0%,100%,.7);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:left;border:none;border-left:4px solid transparent}.sidebar-menu-item:hover{background-color:hsla(0,0%,100%,.05);color:#fff}.sidebar-menu-item.active{background-color:rgba(0,123,255,.15);color:#fff;border-left-color:#007bff}.sidebar-icon{font-size:1.5rem;line-height:1}.sidebar-label{flex:1 1}.sidebar-footer{padding:1.5rem;border-top:1px solid hsla(0,0%,100%,.1);background-color:#1a252f}.sidebar-footer-text{font-size:.875rem;color:hsla(0,0%,100%,.5);margin:0;text-align:center}.admin-main-content{flex:1 1;margin-left:280px;padding:2rem;background-color:#f8f9fa;min-height:calc(100vh - 60px)}.admin-content-section{max-width:1200px;margin:0 auto}.admin-content-section h1{font-size:2.5rem;font-weight:700;color:#2c3e50;margin-bottom:2rem}.admin-content-section p{font-size:1.1rem;color:#6c757d;line-height:1.6}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h1{margin-bottom:0}.add-machine-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background-color:#28a745;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px rgba(40,167,69,.2)}.add-machine-btn:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 8px rgba(40,167,69,.3)}.add-machine-btn:active{transform:translateY(0)}.add-machine-btn .btn-icon{font-size:1.25rem;font-weight:700;line-height:1}.admin-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2rem;gap:2rem;margin-top:2rem}.admin-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px rgba(0,0,0,.08);transition:all .3s ease;border:2px solid transparent}.admin-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.12);border-color:#007bff}.admin-card h3{font-size:1rem;font-weight:600;color:#6c757d;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.admin-stat{font-size:3rem;font-weight:700;color:#007bff;margin:0;line-height:1}@media (max-width:1024px){.admin-sidebar{width:240px}.admin-main-content{margin-left:240px}}@media (max-width:768px){.admin-sidebar{position:fixed;left:-280px;transition:left .3s ease}.admin-sidebar.open{left:0}.admin-main-content{margin-left:0}.admin-content-section h1{font-size:2rem}.admin-cards{grid-template-columns:1fr;gap:1rem}}.machines-table-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px rgba(0,0,0,.08);overflow-x:auto;overflow-y:auto;margin-top:1.5rem;max-height:calc(100vh - 200px);min-height:600px}.machines-table-container::-webkit-scrollbar{width:8px;height:8px}.machines-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.machines-table-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.machines-table-container::-webkit-scrollbar-thumb:hover{background:#555}.machines-table{width:100%;border-collapse:collapse;font-size:.95rem}.machines-table thead{background-color:#f8f9fa;position:-webkit-sticky;position:sticky;top:0;z-index:10}.machines-table th{padding:1rem;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6;white-space:nowrap}.machines-table td{padding:1rem;border-bottom:1px solid #e9ecef;color:#212529;vertical-align:middle}.machines-table tbody tr{transition:background-color .2s ease}.actions-cell{vertical-align:middle;text-align:center}.machines-table tbody tr:hover{background-color:#f8f9fa}.machines-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-block;text-transform:capitalize}.status-badge.status-active{background-color:#d4edda;color:#155724}.status-badge.status-inactive{background-color:#f8d7da;color:#721c24}.status-badge.status-maintenance{background-color:#fff3cd;color:#856404}.status-badge.status-operational{background-color:#d1ecf1;color:#0c5460}.sequence-badge{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:12px;font-size:1rem;font-weight:600;line-height:1;letter-spacing:.05em}.sequence-badge.sequence-asc{background-color:#e3f2fd;color:#1565c0}.sequence-badge.sequence-desc{background-color:#fce4ec;color:#c2185b}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;line-height:1;letter-spacing:.05em}.status-badge.status-connected{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-badge.status-disconnected{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.device-id-cell{font-family:Courier New,monospace;color:#667eea;font-weight:600}.machine-name-cell{font-weight:600;color:#007bff}.no-records-cell{text-align:center;padding:3rem 1rem!important;color:#6c757d;font-size:1.1rem;font-style:italic}.action-menu-container{position:relative;display:inline-block}.action-menu-btn{background:none;border:none;font-size:1.5rem;font-weight:700;color:#495057;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease;line-height:1}.action-menu-btn:hover{background-color:#f8f9fa;color:#212529}.action-dropdown{position:absolute;right:0;top:100%;margin-top:.25rem;background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);min-width:150px;z-index:1000;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:#fff;color:#212529;font-size:.95rem;cursor:pointer;text-align:left;transition:background-color .2s ease}.dropdown-item:hover{background-color:#f8f9fa}.dropdown-item .item-icon{font-size:1.1rem}.edit-item:hover{background-color:rgba(255,193,7,.1)}.delete-item{color:#dc3545}.delete-item:hover{background-color:rgba(220,53,69,.1)}@media (max-width:768px){.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.add-machine-btn{width:100%;justify-content:center}.machines-table-container{padding:1rem;min-height:400px;max-height:calc(100vh - 250px)}.machines-table{font-size:.875rem}.machines-table td,.machines-table th{padding:.75rem .5rem}.action-dropdown{min-width:130px}.dropdown-item{padding:.625rem .875rem;font-size:.875rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e9ecef}.modal-header h2{font-size:1.75rem;font-weight:700;color:#2c3e50;margin:0}.modal-close-btn{background:none;border:none;font-size:2rem;color:#6c757d;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1}.modal-close-btn:hover{background-color:#f8f9fa;color:#212529}.modal-body{padding:2rem}.modal-loading{padding:3rem 2rem;text-align:center}.modal-loading .loading-spinner{margin:0 auto 1rem}.modal-loading p{color:#6c757d;margin:0}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e9ecef;background-color:#f8f9fa;border-radius:0 0 12px 12px}.modal-btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-btn{background-color:#6c757d;color:#fff}.cancel-btn:hover{background-color:#5a6268}.save-btn{background-color:#007bff;color:#fff}.save-btn:hover{background-color:#0056b3;box-shadow:0 2px 8px rgba(0,123,255,.3)}@media (max-width:768px){.modal-content{max-width:100%;margin:1rem}.modal-body,.modal-footer,.modal-header{padding:1rem 1.5rem}.modal-footer{flex-direction:column}.modal-btn{width:100%}}.required-star{color:#dc3545;font-weight:700;margin-left:.25rem}.input-error,.input-error:focus{border-color:#dc3545!important}.input-error:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.25)!important}.error-text{display:block;color:#dc3545;font-size:.875rem;margin-top:.5rem;font-weight:500}.delete-dialog{max-width:500px}.delete-warning{text-align:center;padding:1rem 0}.warning-icon{font-size:4rem;margin-bottom:1rem;line-height:1}.delete-message{font-size:1.1rem;color:#2c3e50;margin-bottom:.75rem;line-height:1.6}.delete-message strong{color:#dc3545}.delete-submessage{font-size:.95rem;color:#6c757d;margin:0}.delete-confirm-btn{background-color:#dc3545;color:#fff}.delete-confirm-btn:hover{background-color:#c82333;box-shadow:0 2px 8px rgba(220,53,69,.3)}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin:2rem 0 1rem}.pagination-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px rgba(102,126,234,.3)}.pagination-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.5)}.pagination-btn:disabled{background:#ccc;cursor:not-allowed;box-shadow:none}.pagination-numbers{display:flex;gap:.5rem}.pagination-number{width:40px;height:40px;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.pagination-number:hover{background:#667eea;color:#fff;transform:scale(1.1)}.pagination-number.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#764ba2;box-shadow:0 2px 8px rgba(102,126,234,.4)}.pagination-info{text-align:center;color:#666;font-size:.95rem;margin-bottom:2rem}.timestamp-cell{font-size:.875rem;color:#6c757d;white-space:nowrap}.status-badge.status-pending{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.status-badge.status-in-progress,.status-badge.status-in_progress{background-color:#cfe2ff;color:#084298;border:1px solid #b6d4fe}.status-badge.status-completed{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-badge.status-failed{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width:768px){.pagination{flex-direction:column;gap:1rem}.pagination-numbers{flex-wrap:wrap;justify-content:center}}