body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,.App,body,html{font-family:Century Gothic,Arial,Helvetica Neue,Helvetica,sans-serif!important}.sidebar-menu-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-family:Century Gothic,Arial,Helvetica Neue,Helvetica,sans-serif;font-size:15px;font-weight:500;gap:12px;margin-bottom:4px;outline:none;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.sidebar-menu-btn.selected{background:#1976d2;box-shadow:0 2px 8px #1976d233;color:#fff;font-weight:600}.sidebar-menu-btn:not(.selected):hover{background:#f1f5f9;color:#334155;transform:translateX(2px)}.clickable,[role=button],a:active,a:focus,a:hover,button{cursor:pointer}.App{text-align:center}@keyframes flash{0%,50%{opacity:1}25%,75%{opacity:.3}}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.call-offs-page{margin:0 auto;max-width:1400px;padding:20px}.page-header h1{color:#333;font-size:2em;margin:0 0 10px}.page-header p{color:#666;font-size:1.1em;margin:0}.filters{align-items:end;background:#f8f9fa;border-radius:8px;display:flex;gap:20px;margin-bottom:20px;padding:15px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{color:#333;font-size:.9em;font-weight:500}.filter-group select{border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:150px;padding:8px 12px}.refresh-button{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;height:-webkit-fit-content;height:fit-content;padding:8px 16px}.refresh-button:hover{background:#218838}.call-offs-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.summary-card{background:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;text-align:center}.summary-card h3{color:#666;font-size:.9em;font-weight:500;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.summary-number{color:#333;font-size:2em;font-weight:700}.call-offs-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.call-offs-table{border-collapse:collapse;font-size:14px;width:100%}.call-offs-table th{background:#f8f9fa;border-bottom:2px solid #dee2e6;color:#333;font-size:.85em;font-weight:600;letter-spacing:.5px;padding:12px 8px;text-align:left;text-transform:uppercase}.call-offs-table td{border-bottom:1px solid #dee2e6;padding:12px 8px;vertical-align:top}.call-off-row:hover{background:#f8f9fa}.call-off-row.status-scheduled{border-left:4px solid #007bff}.call-off-row.status-converted{border-left:4px solid #28a745}.call-off-row.status-cancelled{border-left:4px solid #dc3545;opacity:.7}.work-ticket{color:#333;font-weight:600}.product-code strong{color:#333;display:block;margin-bottom:2px}.product-code small{color:#666;font-size:.85em}.quantity{font-weight:600;text-align:center}.days-until{font-weight:500}.days-until.overdue{color:#dc3545;font-weight:600}.status-badge{font-size:.75em;font-weight:600;letter-spacing:.5px}.status-scheduled{background:#e3f2fd;color:#1976d2}.status-converted{background:#e8f5e8;color:#2e7d32}.status-cancelled{background:#ffebee;color:#c62828}.actions{display:flex;flex-wrap:wrap;gap:8px}.convert-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px}.convert-button:hover{background:#0056b3}.cancel-button{background:#dc3545;font-size:12px;font-weight:500;padding:6px 12px}.cancel-button:hover{background:#c82333}.converted-info{color:#666;font-size:.8em;font-style:italic}.no-data{color:#666;padding:40px}.call-off-note{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;font-size:.9em;margin-top:10px;padding:10px}.loading{color:#666;font-size:1.1em}.error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin:20px 0;padding:15px}@media (max-width:1200px){.call-offs-table-container{overflow-x:auto}.call-offs-table{min-width:1000px}}@media (max-width:768px){.call-offs-page{padding:15px}.filters{align-items:stretch;flex-direction:column;gap:15px}.filter-group{align-items:center;flex-direction:row;gap:10px}.filter-group label{min-width:80px}.filter-group select{flex:1 1;min-width:auto}.call-offs-summary{grid-template-columns:1fr}.actions{flex-direction:column}.actions button{width:100%}}.call-off-modal{max-width:600px;width:90%}.stock-info{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;margin-bottom:20px;padding:15px}.stock-info h3{color:#333;font-size:1.2em;margin:0 0 5px}.stock-info p{color:#666;font-size:.95em;margin:0 0 10px}.stock-details{color:#555;display:flex;font-size:.9em;gap:20px}.call-off-form .form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-bottom:15px}.call-off-form .form-group{margin-bottom:15px}.call-off-form label{color:#333;display:block;font-weight:500;margin-bottom:5px}.call-off-form input,.call-off-form textarea{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:8px 12px;width:100%}.call-off-form input:focus,.call-off-form textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.form-help{color:#666;display:block;font-size:.85em;font-style:italic;margin-top:5px}.error-message{background:#f8d7da;margin-bottom:15px;padding:10px}.modal-actions{border-top:1px solid #eee;gap:10px;margin-top:20px;padding-top:20px}.cancel-button{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px}.cancel-button:hover{background:#5a6268}.submit-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;min-width:120px;padding:10px 20px}.submit-button:hover:not(:disabled){background:#0056b3}.submit-button:disabled{background:#6c757d;cursor:not-allowed}.call-off-info{background:#e7f3ff;border-left:4px solid #007bff;border-radius:8px;margin-top:20px;padding:15px}.call-off-info h4{color:#0056b3;font-size:1em;margin:0 0 10px}.call-off-info ul{margin:0;padding-left:20px}.call-off-info li{color:#555;font-size:.9em;margin-bottom:5px}@media (max-width:768px){.call-off-form .form-row{gap:10px;grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.supplier-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;padding:0;width:95%}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2)}.form-section:last-of-type{margin-bottom:24px}.form-section h3:before{background:linear-gradient(135deg,#667eea,#764ba2)}.form-group input,.form-group textarea{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:14px;padding:12px 16px;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none;transform:translateY(-1px)}.form-group input:disabled,.form-group textarea:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.7}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);min-width:140px}.btn-primary:hover:not(:disabled){box-shadow:0 8px 15px #667eea4d}@media (max-width:768px){.supplier-modal{margin:20px;max-height:calc(100vh - 40px);width:95vw}.modal-header{padding:20px 24px}.modal-header h2{font-size:20px}.modal-form{padding:24px}.form-row{gap:16px;grid-template-columns:1fr}.modal-actions{flex-direction:column;gap:12px}.modal-actions button{width:100%}}@media (max-width:480px){.supplier-modal{border-radius:0;height:100vh;margin:0;max-height:100vh;width:100vw}.modal-header{border-radius:0}}.material-type-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:700px;overflow-y:auto;padding:0;width:95%}.modal-header{background:linear-gradient(135deg,#007bff,#0056b3);border-radius:12px 12px 0 0;color:#fff;justify-content:space-between;padding:24px 32px;position:relative}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{font-size:24px;font-weight:700;gap:8px;margin:0}.modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:40px;justify-content:center;line-height:1;transition:all .2s ease;width:40px}.modal-close:hover:not(:disabled){background:#ffffff4d;transform:scale(1.1)}.modal-close:disabled{cursor:not-allowed;opacity:.5}.modal-form{padding:32px}.form-row{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-row:has(.form-group:only-child){grid-template-columns:1fr}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.form-group label{align-items:center;color:#2c3e50;display:flex;font-size:14px;font-weight:600;gap:6px}.required{color:#e74c3c;font-weight:700}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:14px;padding:12px 16px;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none;transform:translateY(-1px)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.7}.form-group textarea{font-family:inherit;min-height:80px;resize:vertical}.form-group select:disabled{background-color:#e3f2fd;border-color:#007bff;color:#0056b3;font-weight:500}.modal-actions{border-top:2px solid #e9ecef;display:flex;gap:16px;justify-content:flex-end;margin-top:32px;padding-top:24px}.btn-primary{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);border-radius:8px;display:flex;font-weight:600;gap:8px;justify-content:center;min-width:160px;padding:12px 24px;transition:all .2s ease}.btn-primary:hover:not(:disabled){box-shadow:0 8px 15px #007bff4d;transform:translateY(-2px)}.btn-primary:disabled{background:#b2bec3;box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{background:#6c757d;border-radius:8px;font-size:14px;font-weight:600;min-width:100px;padding:12px 24px;transition:all .2s ease}.btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.btn-secondary:disabled{background:#b2bec3;cursor:not-allowed;transform:none}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.form-section{margin-bottom:32px}.form-section h3{align-items:center;border-bottom:2px solid #e9ecef;color:#2c3e50;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0 0 20px;padding-bottom:8px}.form-section h3:before{background:linear-gradient(135deg,#007bff,#0056b3);border-radius:2px;content:"";height:20px;width:4px}@media (max-width:768px){.material-type-modal{margin:20px;max-height:calc(100vh - 40px);width:95vw}.modal-header{padding:20px 24px}.modal-header h2{font-size:20px}.modal-form{padding:24px}.form-row{gap:16px;grid-template-columns:1fr}.modal-actions{flex-direction:column;gap:12px}.modal-actions button{width:100%}}@media (max-width:480px){.material-type-modal{border-radius:0;height:100vh;margin:0;max-height:100vh;width:100vw}.modal-header{border-radius:0}}.material-types-list-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:1000px;overflow:hidden;padding:0;width:95%}.material-types-count{color:#6c757d;font-size:14px;font-weight:500}.material-types-table-container{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow-x:auto}.material-types-table{border-collapse:collapse;font-size:14px;width:100%}.material-types-table thead{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #dee2e6}.material-types-table th{border-right:1px solid #dee2e6;color:#495057;font-weight:600;padding:12px 8px;text-align:left;white-space:nowrap}.material-types-table th:last-child{border-right:none}.material-types-table tbody tr{border-bottom:1px solid #e9ecef;transition:all .2s ease}.material-types-table tbody tr:hover{background-color:#f8f9fa}.material-types-table tbody tr:last-child{border-bottom:none}.material-types-table td{border-right:1px solid #f1f3f4;padding:10px 8px;vertical-align:middle}.material-types-table td:last-child{border-right:none}.product-code{color:#2c3e50;font-weight:600;min-width:120px}.roll-count{background:linear-gradient(135deg,#007bff,#0056b3);border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:500;min-width:20px;padding:2px 8px;text-align:center}.actions-cell{text-align:center;width:80px}.action-buttons{gap:4px;justify-content:center}.btn-delete-small,.btn-edit-small{align-items:center;background:#0000;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;display:flex;font-size:12px;height:28px;justify-content:center;padding:4px 8px;transition:all .2s ease;width:28px}.btn-edit-small{border-color:#28a745;color:#28a745}.btn-edit-small:hover{background:#28a745;color:#fff;transform:translateY(-1px)}.btn-delete-small{border-color:#dc3545}@media (max-width:768px){.material-types-list-modal{margin:20px;max-height:calc(100vh - 40px);width:95vw}.modal-body{padding:20px 24px}.action-bar{align-items:stretch;flex-direction:column;gap:16px}.material-types-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.material-types-table{min-width:700px}.material-types-table td,.material-types-table th{font-size:12px;padding:8px 6px}.action-buttons{flex-direction:column;gap:2px}.btn-delete-small,.btn-edit-small{font-size:10px;height:24px;width:24px}.modal-footer{padding:16px 24px}}@media (max-width:480px){.material-types-list-modal{border-radius:0;height:100vh;margin:0;max-height:100vh;width:100vw}.modal-footer,.modal-header{border-radius:0}.material-type-actions{flex-direction:column;gap:8px}.material-type-actions button{width:100%}}.supplier-management-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;padding:0;width:95%}.suppliers-count{color:#6c757d;font-size:14px;font-weight:500}.loading-state .loading-spinner{border:3px solid #667eea4d;border-top-color:#667eea}.suppliers-list{grid-gap:16px;display:grid;gap:16px}.supplier-card{align-items:flex-start;background:#fff;border:2px solid #e9ecef;border-radius:12px;display:flex;justify-content:space-between;position:relative;transition:all .2s ease}.supplier-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.supplier-info{flex:1 1;min-width:0}.supplier-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.supplier-header h3{color:#2c3e50;flex:1 1;font-size:18px;font-weight:600;margin:0;min-width:0}.supplier-stats{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:12px;font-weight:500;margin-left:12px;padding:4px 12px;white-space:nowrap}.supplier-details{grid-gap:8px;display:grid;gap:8px}.contact-item{align-items:center;color:#495057;display:flex;font-size:14px;gap:8px}.contact-icon{opacity:.7;text-align:center;width:20px}.supplier-actions{flex-shrink:0;gap:8px;margin-left:16px}.btn-materials{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:8px 16px;transition:all .2s ease}.btn-materials:hover{background:#0056b3;transform:translateY(-1px)}.btn-edit{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:8px 16px;transition:all .2s ease}.btn-edit:hover{background:#218838;transform:translateY(-1px)}.btn-delete{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:8px 16px;transition:all .2s ease}.btn-delete:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.btn-delete:disabled{background:#6c757d;cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.supplier-management-modal{margin:20px;max-height:calc(100vh - 40px);width:95vw}.modal-body{padding:20px 24px}.action-bar{align-items:stretch}.action-bar,.supplier-card{flex-direction:column;gap:16px}.supplier-header{align-items:flex-start;flex-direction:column;gap:8px}.supplier-stats{align-self:flex-start;margin-left:0}.supplier-actions{justify-content:flex-end;margin-left:0}.modal-footer{padding:16px 24px}}@media (max-width:480px){.supplier-management-modal{border-radius:0;height:100vh;margin:0;max-height:100vh;width:100vw}.modal-footer,.modal-header{border-radius:0}.supplier-actions{flex-direction:column;gap:8px}.supplier-actions button{width:100%}}.material-order-modal{max-height:90vh;max-width:1200px;overflow-y:auto}.form-row{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr;margin-bottom:1rem}.form-row .form-group{flex:1 1}.form-row .form-group input,.form-row .form-group select{max-width:none;width:100%}.form-row.two-columns{grid-template-columns:1fr 1fr}.form-row.three-columns{grid-template-columns:1fr 1fr 1fr}.form-row.four-columns{grid-template-columns:1fr 1fr 1fr 1fr}.form-row.five-columns{grid-template-columns:1fr 1fr 1fr 1fr 1fr}.readonly-field{background-color:#f8f9fa!important;color:#6c757d!important;cursor:not-allowed!important}.material-info-row{grid-gap:1rem;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:grid;gap:1rem;grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:1rem;padding:15px;width:100%}.width-breakdown-section{clear:both;margin:15px 0;width:100%}.width-row{background-color:#fafafa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:10px;padding:10px}.width-row-header{align-items:center;color:#333;display:flex;font-weight:600;justify-content:space-between;margin-bottom:10px}.width-fields{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr}.add-width-btn{margin-top:10px}.width-usage-section{background-color:#f0f8ff;border:1px solid #b3d9ff;border-radius:8px;clear:both;margin-top:20px;order:999;padding:15px;width:100%}.width-usage-header{margin-bottom:10px}.width-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-top:10px}.width-stat{display:flex;justify-content:space-between;padding:5px 0}.width-stat .label{color:#666;font-weight:500}.width-stat .value{font-weight:600}.width-stat .value.success{color:#28a745}.width-stat .value.error{color:#dc3545}.order-items-section{margin-top:20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.section-header h3{color:#333;margin:0}.order-item{background-color:#f9f9f9;border:1px solid #ddd;border-radius:8px;flex-direction:column;padding:15px;width:100%}.order-item,.order-item-header{display:flex;margin-bottom:15px}.order-item-header{align-items:center;border-bottom:1px solid #eee;justify-content:space-between;padding-bottom:10px}.order-item-header span{color:#333;font-weight:700}.no-items{color:#666;font-style:italic;padding:30px;text-align:center}.order-summary{background-color:#f0f8ff;border:1px solid #007bff;border-radius:8px;margin-top:20px;padding:15px}.total-value{color:#007bff;font-size:18px;text-align:right}.info-message{background-color:#e3f2fd;border:1px solid #2196f3;border-radius:8px;color:#1976d2;margin:15px 0;padding:15px}.info-message p{font-weight:500;margin:0}.jumbo-width-display{background-color:#e8f5e8;border:1px solid #4caf50;border-radius:4px;color:#2e7d32;font-size:14px;padding:8px 12px}.width-calculation-section{background-color:initial;border:none;margin:10px 0 0;padding:0}.width-section-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:5px}.width-section-header h4{color:#333;font-size:16px;margin:0}.width-calculation-section h4{border-bottom:1px solid #eee;color:#333;font-size:16px;margin:0 0 15px;padding-bottom:8px}.width-summary{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:15px;padding:15px}.width-visual-container{margin-bottom:15px}.width-visual-header{margin-bottom:10px}.width-label{color:#495057;font-size:14px;font-weight:600}.width-progress-bar{background-color:#28a745;border:2px solid #dee2e6;border-radius:12px;height:24px;overflow:hidden;position:relative}.width-used{background-color:#fd7e14;border-radius:10px 0 0 10px;height:100%;transition:width .3s ease}.width-modal{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-height:90vh;max-width:1200px;overflow-y:auto;padding:24px;width:95%}.width-marker{background-color:#343a40;cursor:pointer;height:100%;position:absolute;top:0;width:2px;z-index:10}.width-marker:before{top:-4px}.width-marker:after,.width-marker:before{background-color:#343a40;border-radius:50%;content:"";height:8px;left:-3px;position:absolute;width:8px}.width-marker:after{bottom:-4px}.width-legend{display:flex;font-size:12px;gap:20px;margin-top:8px}.legend-item{align-items:center;display:flex;gap:6px}.legend-color{border:1px solid #dee2e6;border-radius:2px;height:12px;width:16px}.legend-color.used{background-color:#fd7e14}.legend-color.available{background-color:#28a745}.width-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.width-info:last-child{margin-bottom:0}.width-info .label{color:#495057;font-weight:500}.width-info .value{background-color:#e9ecef;border-radius:4px;font-weight:600;padding:4px 8px}.width-info .value.success{background-color:#d4edda;color:#155724}.error-message,.width-info .value.error{background-color:#f8d7da;color:#721c24}.error-message{border:1px solid #f5c6cb;border-radius:4px;font-size:14px;margin-top:10px;padding:8px 12px}.width-item{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;margin-bottom:15px;padding:12px}.width-item-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:6px}.width-item-header span{color:#495057;font-size:14px;font-weight:500}.readonly{background-color:#f5f5f5;cursor:not-allowed}.btn-small{font-size:.8rem;padding:.25rem .5rem}@media (max-width:768px){.form-row{grid-template-columns:1fr}.material-order-modal{margin:1rem;max-width:95vw}.order-item-header,.section-header{align-items:stretch;flex-direction:column;gap:.5rem}}.material-orders-list-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;padding:0;width:95%}.modal-body{flex:1 1;overflow-y:auto;padding:24px 32px}.action-bar{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.orders-count{color:#6c757d;font-size:14px;font-weight:500}.btn-refresh{align-items:center;background:#17a2b8;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:8px 16px;transition:all .2s ease}.btn-refresh:hover:not(:disabled){background:#138496;transform:translateY(-1px)}.btn-refresh:disabled{cursor:not-allowed;opacity:.6}.loading-state{align-items:center;color:#6c757d;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-state .loading-spinner{animation:spin 1s linear infinite;border:3px solid #007bff4d;border-radius:50%;border-top-color:#007bff;height:32px;margin-bottom:16px;width:32px}.empty-state{color:#6c757d;padding:60px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state h3{color:#495057;font-size:20px;margin:0 0 8px}.empty-state p{font-size:16px;margin:0 0 24px}.orders-list{grid-gap:20px;display:grid;gap:20px}.order-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:24px;position:relative;transition:all .2s ease}.order-card:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.order-header{align-items:flex-start;border-bottom:1px solid #e9ecef;margin-bottom:16px;padding-bottom:16px}.order-info h3{color:#2c3e50;font-size:20px;font-weight:600;margin:0 0 8px}.order-meta{align-items:center;display:flex;gap:12px}.supplier-name{color:#6c757d;font-size:14px;font-weight:500}.order-status{border-radius:20px;color:#fff;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.order-value{text-align:right}.value-label{color:#6c757d;display:block;font-size:12px;margin-bottom:4px}.value-amount{color:#2c3e50;display:block;font-size:18px;font-weight:600}.order-details{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.detail-row{align-items:center;display:flex;font-size:14px;gap:8px;padding:4px 0}.detail-label{color:#6c757d;font-weight:600;min-width:100px}.detail-value{color:#495057;flex:1 1}.order-items{margin-bottom:20px}.order-items h4{color:#495057;font-size:14px;font-weight:600;margin:0 0 12px}.items-list{grid-gap:8px;display:grid;gap:8px}.order-item{grid-gap:12px;align-items:center;background:#f8f9fa;border-radius:6px;display:grid;font-size:13px;gap:12px;grid-template-columns:2fr 1fr 1fr 1fr;padding:8px 12px}.item-material{color:#2c3e50;font-weight:600}.item-specs{color:#6c757d}.item-quantity{color:#495057}.item-price{color:#28a745;font-weight:600;text-align:right}.order-actions{align-items:center;border-top:1px solid #e9ecef;justify-content:space-between;padding-top:16px}.status-actions{display:flex;gap:8px}.btn-status{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:8px 16px;transition:all .2s ease}.btn-ordered{background:#2196f3;color:#fff}.btn-ordered:hover{background:#1976d2;transform:translateY(-1px)}.btn-received{background:#4caf50;color:#fff}.btn-received:hover{background:#388e3c;transform:translateY(-1px)}.btn-cancel{background:#f44336;color:#fff}.btn-cancel:hover{background:#d32f2f;transform:translateY(-1px)}.status-complete{color:#4caf50;font-size:14px;font-weight:600}.status-cancelled{color:#f44336;font-size:14px;font-weight:600}.action-buttons{display:flex;gap:8px}.btn-delete-small{align-items:center;background:#0000;border:1px solid #dc3545;border-radius:4px;color:#dc3545;cursor:pointer;display:flex;font-size:12px;height:32px;justify-content:center;padding:6px 10px;transition:all .2s ease;width:32px}.btn-delete-small:hover:not(:disabled){background:#dc3545;color:#fff;transform:translateY(-1px)}.btn-delete-small:disabled{border-color:#6c757d;color:#6c757d;cursor:not-allowed;opacity:.6}.btn-delete-small:disabled:hover{background:#0000;transform:none}.modal-footer{background:#f8f9fa;border-radius:0 0 12px 12px;border-top:2px solid #e9ecef;display:flex;justify-content:flex-end;padding:20px 32px}.error-message{background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-radius:8px;box-shadow:0 4px 6px #ff6b6b33;color:#fff;font-weight:500;margin:20px 0;padding:16px 20px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.material-orders-list-modal{margin:20px;max-height:calc(100vh - 40px);width:95vw}.modal-body{padding:20px 24px}.action-bar{align-items:stretch;flex-direction:column;gap:16px}.order-header{align-items:flex-start;flex-direction:column;gap:12px}.order-value{text-align:left}.order-details,.order-item{grid-template-columns:1fr}.order-item{gap:4px}.order-actions{align-items:stretch;flex-direction:column;gap:12px}.action-buttons,.status-actions{justify-content:center}.modal-footer{padding:16px 24px}}@media (max-width:480px){.material-orders-list-modal{border-radius:0;height:100vh;margin:0;max-height:100vh;width:100vw}.modal-footer,.modal-header{border-radius:0}}.raw-materials-page{margin:0 auto;max-width:1400px;padding:20px}.page-header{margin-bottom:30px;text-align:center}.page-header h1{color:#2c3e50;font-family:Century Gothic,sans-serif;margin-bottom:10px}.page-header p{color:#7f8c8d;font-size:16px}.raw-materials-tabs{border-bottom:2px solid #ecf0f1;display:flex;gap:5px;justify-content:center;margin-bottom:30px}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#7f8c8d;cursor:pointer;font-family:Century Gothic,sans-serif;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.tab-button:hover{background-color:#f8f9fa;color:#2c3e50}.tab-button.active{background-color:#f8f9fa;border-bottom-color:#3498db;color:#3498db}.raw-materials-content{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:30px}.content-header{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:15px}.content-header h2{color:#2c3e50;font-family:Century Gothic,sans-serif;margin:0}.header-actions{align-items:center;display:flex;gap:10px}.btn-primary{background-color:#3498db;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .3s ease}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-right:5px;padding:8px 16px;transition:background-color .3s ease}.btn-secondary:hover{background-color:#7f8c8d}.btn-danger{background-color:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:background-color .3s ease}.btn-danger:hover{background-color:#c0392b}.btn-success{background-color:#27ae60;border:none;border-radius:4px;cursor:pointer;font-size:12px;margin-right:5px;padding:8px 16px;transition:background-color .3s ease}.btn-success:hover{background-color:#229954}.btn-small{font-size:11px;margin-right:3px;padding:6px 12px}.loading{color:#7f8c8d;font-size:16px;padding:40px;text-align:center}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;margin-bottom:20px;padding:15px}.suppliers-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.supplier-card{background:#fafbfc;border:1px solid #ecf0f1;border-radius:8px;padding:20px;transition:box-shadow .3s ease}.supplier-card:hover{box-shadow:0 4px 12px #0000001a}.supplier-card h3{color:#2c3e50;font-family:Century Gothic,sans-serif;margin-bottom:15px}.supplier-details p{color:#5a6c7d;font-size:14px;margin:8px 0}.supplier-stats{border-top:1px solid #ecf0f1;display:flex;gap:20px;margin:15px 0;padding:10px 0}.stat{color:#7f8c8d;font-size:14px}.supplier-actions{display:flex;gap:10px;margin-top:15px}.materials-table,.rolls-table,.substitutions-table,.waste-table{overflow-x:auto;width:100%}.materials-table table,.rolls-table table,.substitutions-table table,.waste-table table{border-collapse:collapse;margin-top:10px;width:100%}.materials-table td,.materials-table th,.rolls-table td,.rolls-table th,.substitutions-table td,.substitutions-table th,.waste-table td,.waste-table th{border-bottom:1px solid #ecf0f1;padding:12px;text-align:left}.materials-table th,.rolls-table th,.substitutions-table th,.waste-table th{background-color:#f8f9fa;color:#2c3e50;font-family:Century Gothic,sans-serif;font-weight:600}.materials-table tr:hover,.rolls-table tr:hover,.substitutions-table tr:hover,.waste-table tr:hover{background-color:#f8f9fa}.consumed-roll{background-color:#ffeaa7!important;opacity:.6}.status-badge{border-radius:12px;font-size:11px;font-weight:500;padding:4px 8px;text-transform:uppercase}.status-badge.in_stock{background-color:#d5f4e6;color:#27ae60}.status-badge.consumed{background-color:#fadbd8;color:#e74c3c}.status-badge.checked_out{background-color:#fef9e7;color:#f39c12}.status-badge.pending{background-color:#ebf3fd;color:#3498db}.status-badge.approved{background-color:#d5f4e6;color:#27ae60}.status-badge.rejected{background-color:#fadbd8;color:#e74c3c}.tab-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.orders-table{margin-top:1rem}.order-actions{display:flex;flex-wrap:wrap;gap:.5rem}.order-items-section{background:#f8f9fa;border-radius:8px;margin-top:2rem;padding:1rem}.order-items-section h3{color:#495057;margin:0 0 1rem}.order-details{background:#fff;border:1px solid #dee2e6;border-radius:6px;margin-bottom:1rem;padding:1rem}.order-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.5rem}.order-header-actions{align-items:center;display:flex;gap:15px}.order-header h4{color:#333;margin:0}.order-items-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.order-item-card{align-items:flex-start;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;display:flex;justify-content:space-between;padding:.75rem}.item-info{flex:1 1}.item-info strong{color:#495057;display:block;margin-bottom:.25rem}.item-info div{color:#6c757d;font-size:.85rem;margin-bottom:.1rem}.item-actions{margin-left:1rem}.printed-badge{background:#d4edda;color:#155724}.pending-badge,.printed-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.pending-badge{background:#fff3cd;color:#856404}.all-printed-badge{background:#d4edda;border:1px solid #c3e6cb;border-radius:20px;color:#155724;font-size:.85rem;font-weight:600;padding:.5rem 1rem}.bulk-print-btn{background-color:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background-color .3s ease}.bulk-print-btn:hover{background-color:#218838}.btn-success{background-color:#28a745;border:1px solid #28a745;color:#fff}.btn-success:hover{background-color:#218838;border-color:#1e7e34}.btn-info{background-color:#17a2b8;border:1px solid #17a2b8;color:#fff}.btn-info:hover{background-color:#138496;border-color:#117a8b}.no-data{color:#6c757d;font-style:italic;padding:2rem;text-align:center}.status-badge.pending{background-color:#fff3cd;color:#856404}.status-badge.ordered{background-color:#cce5ff;color:#004085}.status-badge.delivered{background-color:#d4edda;color:#155724}.status-badge.cancelled{background-color:#f8d7da;color:#721c24}@media (max-width:768px){.raw-materials-page{padding:1rem}.tab-navigation{flex-wrap:wrap;gap:.5rem}.tab-button{flex:1 1;min-width:120px}.suppliers-grid{grid-template-columns:1fr}.materials-table table,.orders-table table,.rolls-table table{font-size:.8rem}.materials-table td,.materials-table th,.orders-table td,.orders-table th,.rolls-table td,.rolls-table th{padding:.5rem}.order-actions,.order-header{flex-direction:column}.order-header{align-items:flex-start;gap:.5rem}.order-items-grid{grid-template-columns:1fr}.order-item-card{flex-direction:column;gap:.5rem}.item-actions{margin-left:0}.raw-materials-page{padding:10px}.raw-materials-tabs{flex-wrap:wrap;justify-content:center}.tab-button{font-size:14px;padding:8px 16px}.suppliers-grid{grid-template-columns:1fr}.content-header{align-items:stretch;flex-direction:column;gap:15px}.materials-table,.rolls-table,.substitutions-table,.waste-table{font-size:12px}.materials-table td,.materials-table th,.rolls-table td,.rolls-table th,.substitutions-table td,.substitutions-table th,.waste-table td,.waste-table th{padding:8px}}
/*# sourceMappingURL=main.92619c05.css.map*/