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}.App{background:#f5f7fa;display:flex;flex-direction:column;min-height:100vh}.App-header{background:linear-gradient(135deg,#2c3e50,#3498db);box-shadow:0 2px 10px #0000001a;color:#fff;padding:30px 20px;text-align:center}.App-header h1{font-size:2.5em;font-weight:600;margin:0}.subtitle{font-size:1.1em;margin:10px 0 0;opacity:.9}.App-nav{background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:center;padding:0}.App-nav button{background:none;border:none;border-bottom:3px solid #0000;color:#555;cursor:pointer;font-size:1.1em;padding:20px 40px;transition:all .3s}.App-nav button:hover{background:#f8f9fa;color:#2c3e50}.App-nav button.active{border-bottom-color:#3498db;color:#3498db;font-weight:600}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724}.error-message,.success-message{margin:20px auto;max-width:800px;padding:15px 20px;text-align:center}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24}.App-main{flex:1 1;margin:0 auto;max-width:1400px;padding:20px;width:100%}.App-footer{background:#2c3e50;color:#fff;margin-top:40px;padding:20px;text-align:center}.App-footer p{margin:0}.user-selector{align-items:center;background:#eef2f7;border-bottom:1px solid #ddd;display:flex;gap:10px;justify-content:center;padding:12px 20px}.user-selector label{color:#2c3e50;font-weight:600}.user-selector select{background:#fff;border:1px solid #ccc;border-radius:4px;font-size:.95em;min-width:400px;padding:8px 12px}.support-tab{margin:0 auto;max-width:1200px}.support-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:0 20px}.support-header h2{color:#333;margin:0}.btn-new-ticket{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .2s}.btn-new-ticket:hover{background-color:#45a049}.product-catalog{padding:20px}.product-catalog h2{color:#333;margin-bottom:20px}.filters{background:#f5f5f5;border-radius:8px;margin-bottom:20px;padding:15px}.filters label{align-items:center;display:flex;font-weight:500;gap:10px}.filters select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 12px}.product-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.product-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;transition:box-shadow .3s}.product-card:hover{box-shadow:0 4px 12px #0000001a}.product-header{align-items:start;display:flex;justify-content:space-between;margin-bottom:10px}.product-header h3{color:#2c3e50;font-size:1.2em;margin:0}.product-sku{color:#7f8c8d;font-size:.85em}.product-description{color:#555;line-height:1.5;margin:10px 0}.product-details{align-items:center;display:flex;justify-content:space-between;margin:15px 0}.product-category{background:#e8f4f8;border-radius:12px;color:#2980b9;font-size:.9em;padding:4px 12px}.product-price{color:#27ae60;font-size:1.3em;font-weight:700}.product-stock{margin:10px 0}.in-stock{color:#27ae60;font-weight:500}.out-of-stock{color:#e74c3c;font-weight:500}.product-actions{display:flex;gap:10px;margin-top:15px}.quantity-input{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px;width:70px}.add-to-cart-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-weight:500;padding:10px 20px;transition:background .3s}.add-to-cart-btn:hover{background:#2980b9}.error,.loading{font-size:1.1em;padding:40px;text-align:center}.error{color:#e74c3c}.shopping-cart{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.shopping-cart h2{color:#333;margin-bottom:20px}.shopping-cart.empty{padding:40px;text-align:center}.shopping-cart.empty p{color:#7f8c8d;font-size:1.1em}.cart-items{margin-bottom:20px}.cart-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:15px}.cart-item:last-child{border-bottom:none}.item-info h3{color:#2c3e50;font-size:1.1em;margin:0 0 5px}.item-price{color:#7f8c8d;margin:0}.item-actions{align-items:center;display:flex;gap:15px}.item-total{color:#27ae60;font-weight:700;margin:0;min-width:80px;text-align:right}.remove-btn{background:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:18px;height:32px;transition:background .3s;width:32px}.remove-btn:hover{background:#c0392b}.cart-summary{border-top:2px solid #eee;margin-top:20px;padding-top:20px}.total{align-items:center;display:flex;font-size:1.2em;font-weight:700;justify-content:space-between;margin-bottom:20px}.total-amount{color:#27ae60;font-size:1.4em}.checkout-btn{background:#27ae60;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1.1em;font-weight:500;padding:15px;transition:background .3s;width:100%}.checkout-btn:hover:not(:disabled){background:#229954}.checkout-btn:disabled{background:#95a5a6;cursor:not-allowed;opacity:.7}.approval-dashboard{padding:20px 0}.approval-dashboard h2{color:#2c3e50;margin:0 0 20px}.approval-dashboard .loading{color:#666;padding:40px;text-align:center}.no-approvals{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#888;padding:60px 20px;text-align:center}.approval-message{border-radius:4px;margin-bottom:16px;padding:12px 16px;text-align:center}.approval-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.approval-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.approval-list{display:flex;flex-direction:column;gap:20px}.approval-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #00000014;padding:24px}.approval-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.order-info{align-items:center;display:flex;gap:12px}.order-info h3{color:#2c3e50;margin:0}.step-badge{border-radius:12px;color:#fff;font-size:.85em;font-weight:600;padding:4px 12px}.step-department{background:#3498db}.step-it{background:#9b59b6}.step-provider{background:#e67e22}.order-date{color:#888;font-size:.9em}.approval-details{grid-gap:8px;background:#f8f9fa;border-radius:4px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px;padding:12px}.detail-row{display:flex;gap:8px}.detail-row .label{color:#555;font-weight:600;min-width:100px}.status-text{color:#e67e22;font-weight:600}.order-items-section{margin-bottom:16px}.order-items-section h4{color:#2c3e50;margin:0 0 8px}.items-table{border-collapse:collapse;width:100%}.items-table td,.items-table th{border-bottom:1px solid #eee;padding:8px 12px;text-align:left}.items-table th{background:#f8f9fa;color:#555;font-size:.9em;font-weight:600}.items-table tfoot td{border-top:2px solid #ddd;font-weight:600}.approval-progress{margin-bottom:16px}.approval-progress h4{color:#2c3e50;margin:0 0 12px}.progress-steps{align-items:flex-start;display:flex;gap:8px}.progress-step{align-items:center;background:#f0f0f0;border:2px solid #0000;border-radius:6px;display:flex;flex:1 1;gap:8px;padding:10px 14px}.progress-step.approved{background:#d4edda;border-color:#28a745}.progress-step.rejected{background:#f8d7da;border-color:#dc3545}.progress-step.pending{background:#fff3cd;border-color:#ffc107}.step-indicator{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.9em;font-weight:700;height:28px;justify-content:center;width:28px}.progress-step.approved .step-indicator{background:#28a745;color:#fff}.progress-step.rejected .step-indicator{background:#dc3545;color:#fff}.progress-step.pending .step-indicator{background:#ffc107;color:#333}.check,.cross,.pending-dot{font-size:.85em}.step-info{display:flex;flex-direction:column;gap:2px}.step-name{color:#2c3e50;font-size:.9em;font-weight:600}.step-approver{color:#666;font-size:.8em}.step-time{color:#888;font-size:.75em}.approval-actions{border-top:1px solid #eee;padding-top:16px}.comment-input{margin-bottom:12px}.comment-input input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:.95em;padding:10px 14px;width:100%}.action-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.approve-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1em;font-weight:600;padding:10px 24px;transition:background .2s}.approve-btn:hover:not(:disabled){background:#218838}.approve-btn:disabled{cursor:not-allowed;opacity:.6}.reject-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1em;font-weight:600;padding:10px 24px;transition:background .2s}.reject-btn:hover:not(:disabled){background:#c82333}.reject-btn:disabled{cursor:not-allowed;opacity:.6}.reject-form{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.reject-form input{border:1px solid #dc3545;border-radius:4px;font-size:.95em;min-width:250px;padding:8px 12px}.reject-confirm-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px}.reject-confirm-btn:hover:not(:disabled){background:#c82333}.reject-cancel-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px}.reject-cancel-btn:hover{background:#5a6268}.order-history{padding:20px 0}.order-history h2{color:#2c3e50;margin:0 0 20px}.order-history .loading,.order-history .no-orders{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#666;padding:40px;text-align:center}.orders-table-wrapper{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;overflow:hidden}.orders-table{border-collapse:collapse;width:100%}.orders-table th{background:#f8f9fa;border-bottom:2px solid #dee2e6;color:#555;font-size:.9em;font-weight:600;padding:14px 16px;text-align:left}.orders-table td{border-bottom:1px solid #eee;padding:12px 16px}.order-row{cursor:pointer;transition:background .2s}.order-row:hover{background:#f8f9fa}.order-row.expanded{background:#eef2f7}.order-id{color:#3498db}.amount,.order-id{font-weight:600}.expand-toggle{color:#888;font-size:.8em}.status-badge{border-radius:12px;font-size:.85em;font-weight:600;padding:4px 10px;white-space:nowrap}.status-pending{background:#fff3cd;color:#856404}.status-approved{background:#d4edda;color:#155724}.status-rejected{background:#f8d7da;color:#721c24}.status-completed{background:#d1ecf1;color:#0c5460}.status-default{background:#e2e3e5;color:#383d41}.order-detail-row td{background:#fafbfc;padding:0}.order-detail{padding:20px 24px}.detail-sections{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.detail-section h4{color:#2c3e50}.detail-items-table{border-collapse:collapse;width:100%}.detail-items-table td,.detail-items-table th{border-bottom:1px solid #eee;font-size:.9em;padding:6px 10px;text-align:left}.detail-items-table th{background:#f0f0f0;color:#555;font-weight:600}.approval-timeline{display:flex;flex-direction:column;gap:0;position:relative}.timeline-item{align-items:flex-start;display:flex;gap:12px;padding:10px 0;position:relative}.timeline-item:not(:last-child):after{background:#ddd;bottom:-2px;content:"";left:13px;position:absolute;top:38px;width:2px}.timeline-item.approved:not(:last-child):after{background:#28a745}.timeline-marker{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.85em;height:28px;justify-content:center;width:28px;z-index:1}.marker-approved{background:#28a745}.marker-approved,.marker-rejected{align-items:center;border-radius:50%;color:#fff;display:flex;height:28px;justify-content:center;width:28px}.marker-rejected{background:#dc3545}.marker-pending{align-items:center;background:#e0e0e0;border-radius:50%;color:#888;display:flex;font-size:.7em;height:28px;justify-content:center;width:28px}.timeline-content{display:flex;flex-direction:column;gap:2px}.timeline-content strong{color:#2c3e50;font-size:.95em}.timeline-status{font-size:.85em}.approved-text{color:#28a745}.rejected-text{color:#dc3545}.pending-text{color:#888}.timeline-comment{color:#666;font-size:.85em;font-style:italic}.timeline-time{color:#999;font-size:.8em}.rejection-info{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-top:16px;padding:12px}.ticket-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:800px;padding:24px}.ticket-form h3{color:#333;margin-top:0}.ticket-form .form-group,.ticket-form h3{margin-bottom:20px}.ticket-form label{color:#555;display:block;font-weight:600;margin-bottom:8px}.ticket-form input,.ticket-form select,.ticket-form textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:10px;width:100%}.ticket-form input:focus,.ticket-form select:focus,.ticket-form textarea:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a;outline:none}.ticket-form textarea{min-height:100px;resize:vertical}.ticket-form small{color:#888;display:block;font-size:12px;margin-top:4px}.ticket-form .form-actions{display:flex;gap:12px;margin-top:24px}.ticket-form .btn-primary,.ticket-form .btn-secondary{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.ticket-form .btn-primary{background-color:#4caf50;color:#fff}.ticket-form .btn-primary:hover:not(:disabled){background-color:#45a049}.ticket-form .btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.ticket-form .btn-secondary{background-color:#f5f5f5;color:#333}.ticket-form .btn-secondary:hover:not(:disabled){background-color:#e0e0e0}.ticket-form .btn-secondary:disabled{cursor:not-allowed;opacity:.6}.ticket-form .error-message{background-color:#ffebee;border-left:4px solid #c62828;border-radius:4px;color:#c62828;margin-bottom:16px;padding:12px}.ticket-list-container{padding:20px}.ticket-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.ticket-list-header h2{color:#333;margin:0}.btn-refresh{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.btn-refresh:hover{background-color:#45a049}.no-tickets,.ticket-list-error,.ticket-list-loading{color:#666;padding:40px;text-align:center}.error-banner,.ticket-list-error{background-color:#ffebee;border-left:4px solid #c62828;border-radius:4px;color:#c62828;margin-bottom:16px;padding:12px}.ticket-list-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.tickets-grid{display:flex;flex-direction:column;gap:12px;max-height:70vh;overflow-y:auto}.ticket-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;padding:16px;transition:all .2s}.ticket-card:hover{border-color:#4caf50;box-shadow:0 2px 8px #0000001a}.ticket-card.selected{background-color:#f1f8f4;border-color:#4caf50}.ticket-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.ticket-id{color:#333;font-size:12px;font-weight:700}.ticket-category,.ticket-priority,.ticket-status{border-radius:4px;font-size:11px;font-weight:600;padding:4px 8px;text-transform:uppercase}.priority-urgent{background-color:#c62828;color:#fff}.priority-high{background-color:#ff6f00;color:#fff}.priority-medium{background-color:#fbc02d;color:#333}.priority-low{background-color:#9e9e9e;color:#fff}.ticket-title{color:#333;font-size:16px;font-weight:600;margin:8px 0}.ticket-meta{display:flex;gap:8px;margin:8px 0}.status-open{background-color:#2196f3;color:#fff}.status-in-progress{background-color:#ff9800;color:#fff}.status-waiting{background-color:#9c27b0;color:#fff}.status-resolved{background-color:#4caf50;color:#fff}.status-closed{background-color:#757575;color:#fff}.ticket-category{background-color:#e0e0e0;color:#555}.ticket-footer{border-top:1px solid #e0e0e0;color:#666;display:flex;font-size:12px;justify-content:space-between;margin-top:12px;padding-top:12px}.ticket-details{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:70vh;overflow-y:auto;padding:20px}.ticket-details-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.ticket-details-header h3{color:#333;margin:0}.btn-close{background:none;border:none;color:#999;cursor:pointer;font-size:32px;height:32px;line-height:1;padding:0;width:32px}.btn-close:hover{color:#333}.ticket-details-content{display:flex;flex-direction:column;gap:20px}.detail-section{border-bottom:1px solid #e0e0e0;padding-bottom:16px}.detail-section:last-child{border-bottom:none}.detail-section h4{color:#333;font-size:18px;margin:0 0 12px}.detail-section strong{color:#555;display:block;margin-bottom:8px}.detail-meta{display:flex;gap:8px;margin-top:8px}.detail-category,.detail-priority,.detail-status{border-radius:4px;font-size:12px;font-weight:600;padding:6px 12px;text-transform:uppercase}.ticket-description{color:#333;line-height:1.6;margin:8px 0;white-space:pre-wrap}.detail-info-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:8px}.detail-info-grid div{display:flex;flex-direction:column;gap:4px}.detail-info-grid label{color:#666;font-size:12px;font-weight:600}.detail-info-grid span{color:#333;font-size:14px}.admin-controls{display:flex;gap:16px;margin-top:8px}.control-group{display:flex;flex:1 1;flex-direction:column;gap:8px}.control-group label{color:#555;font-size:13px;font-weight:600}.control-group select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px}.comments-list{display:flex;flex-direction:column;gap:12px;margin:12px 0}.no-comments{color:#999;font-style:italic;margin:12px 0}.comment{background-color:#f5f5f5;border-radius:6px;padding:12px}.comment-header{display:flex;justify-content:space-between;margin-bottom:8px}.comment-header strong{color:#333;font-size:14px}.comment-header small{color:#666;font-size:12px}.comment-text{color:#555;line-height:1.5;margin:0;white-space:pre-wrap}.comment-form{display:flex;flex-direction:column;gap:12px;margin-top:16px}.comment-form textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:10px;resize:vertical}.comment-form textarea:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a;outline:none}.comment-form button{align-self:flex-end;background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .2s}.comment-form button:hover:not(:disabled){background-color:#45a049}.comment-form button:disabled{background-color:#ccc;cursor:not-allowed}@media (max-width:1024px){.ticket-list-content{grid-template-columns:1fr}.ticket-details{max-height:none}}
/*# sourceMappingURL=main.3d881cc0.css.map*/