.login-container{display:flex;min-height:100vh}.login-left{flex:1;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;animation:moveBackground 20s linear infinite}@keyframes moveBackground{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.login-branding{text-align:center;z-index:1;color:#fff}.login-branding h1{font-size:3rem;font-weight:700;margin-bottom:var(--spacing-md);text-shadow:0 2px 10px rgba(0,0,0,.2)}.login-branding p{font-size:1.5rem;opacity:.9}.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background-color:var(--background)}.login-card{width:100%;max-width:450px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-icon{color:var(--primary);margin-bottom:var(--spacing-md)}.login-header h2{font-size:2rem;color:var(--text);margin-bottom:var(--spacing-sm)}.login-header p{color:var(--text-light);font-size:1rem}.login-form,.form-group{margin-bottom:var(--spacing-lg)}.login-btn{width:100%;padding:var(--spacing-md);font-size:1.1rem;font-weight:600}.login-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border)}.login-footer p{color:var(--text-light);font-size:.875rem}@media (max-width: 768px){.login-container{flex-direction:column}.login-left{min-height:200px}.login-branding h1{font-size:2rem}.login-branding p{font-size:1.2rem}.login-right,.login-card{padding:var(--spacing-lg)}}.dashboard-container{max-width:1400px;margin:0 auto;width:100%;overflow-x:hidden}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--spacing-lg);transition:all .3s ease;border-left:4px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-primary{border-left-color:var(--primary)}.stat-primary .stat-icon{background:linear-gradient(135deg,var(--primary),var(--primary-dark))}.stat-success{border-left-color:var(--success)}.stat-success .stat-icon{background:linear-gradient(135deg,var(--success),#1e7e34)}.stat-warning{border-left-color:var(--warning)}.stat-warning .stat-icon{background:linear-gradient(135deg,var(--warning),#e0a800)}.stat-info{border-left-color:var(--secondary)}.stat-info .stat-icon{background:linear-gradient(135deg,var(--secondary),#e55a00)}.stat-icon{width:64px;height:64px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--text-light);margin-bottom:var(--spacing-xs);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:var(--text);margin:0}.recent-activities{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm)}.section-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--primary)}.section-header h2{font-size:1.5rem;color:var(--text);margin:0}.empty-activities{text-align:center;padding:var(--spacing-xl);color:var(--text-light)}.activities-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.activity-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);background:var(--background);transition:all .2s ease}.activity-item:hover{background:#e9ecef}.activity-dot{width:12px;height:12px;border-radius:50%;background:var(--primary);margin-top:6px;flex-shrink:0}.activity-content{flex:1}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs);flex-wrap:wrap;gap:var(--spacing-sm)}.activity-action{font-weight:600;color:var(--text)}.activity-time{font-size:.875rem;color:var(--text-light)}.activity-details{color:var(--text);margin-bottom:var(--spacing-xs);font-size:.95rem}.activity-user{font-size:.875rem;color:var(--text-light);font-style:italic}.stock-table-container,.table-container{background:#fff;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}.stock-table,.table{width:100%;min-width:700px;border-collapse:collapse;background:#fff}.stock-table thead,.table thead{background:var(--primary);color:#fff;position:sticky;top:0;z-index:10}.stock-table th,.table th{padding:.75rem .5rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;white-space:nowrap}.stock-table td,.table td{padding:.75rem .5rem;border-bottom:1px solid #f3f4f6;font-size:.8125rem}.stock-table tbody tr:active,.table tbody tr:active{background:#f9fafb}.stock-table td:nth-child(1),.table td:nth-child(1){min-width:120px}.stock-table td:nth-child(2),.table td:nth-child(2){min-width:100px}.stock-table td:nth-child(3),.table td:nth-child(3){min-width:200px;max-width:250px}.stock-table td:nth-child(4),.table td:nth-child(4){min-width:80px}.stock-table td:last-child,.table td:last-child{min-width:100px;text-align:center}.action-buttons{display:flex;gap:.375rem;justify-content:center;flex-wrap:nowrap}@media (max-width: 768px) and (orientation: portrait){.dashboard-container{padding:0}.stats-grid{grid-template-columns:1fr;gap:var(--spacing-md);padding:0 1rem;margin-bottom:var(--spacing-lg)}.stat-card{padding:var(--spacing-md)}.stat-icon{width:48px;height:48px}.stat-value{font-size:1.5rem}.recent-activities{border-radius:0;padding:var(--spacing-lg);margin:0}.section-header h2{font-size:1.25rem}.activity-header{flex-direction:column;align-items:flex-start}.stock-table-container,.table-container{margin:0;border-radius:0;box-shadow:none}.stock-table-container:before,.table-container:before{content:"👉 Glissez horizontalement pour voir toutes les colonnes";display:block;padding:.625rem 1rem;background:#eff6ff;color:var(--primary);font-size:.8125rem;text-align:center;border-bottom:1px solid #dbeafe;position:sticky;left:0;z-index:5}}@media (max-width: 768px) and (orientation: landscape){.stats-grid{grid-template-columns:repeat(2,1fr)}.stock-table-container:before,.table-container:before{display:none}.stock-table,.table{min-width:auto}}@media (min-width: 769px){.dashboard-container,.stats-grid{padding:0}.recent-activities{margin:0}.stock-table-container,.table-container{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:var(--spacing-lg) 0}.stock-table,.table{min-width:auto}.stock-table th,.table th{padding:1rem;font-size:.875rem}.stock-table td,.table td{padding:1rem;font-size:.9375rem}.stock-table-container:before,.table-container:before{display:none}}@media (max-width: 400px){.stat-card{gap:var(--spacing-md)}.stat-icon{width:40px;height:40px}.stat-value{font-size:1.25rem}.stat-label{font-size:.75rem}}.stock-container,.page-container{padding:0;background:var(--background);width:100%;overflow-x:hidden}.stock-header,.page-header{background:#fff;padding:1rem;margin:0 0 .5rem;border-bottom:1px solid #e5e7eb}.stock-header h1,.page-header h1{font-size:1.25rem;color:var(--text);margin:0 0 .5rem;font-weight:600}.page-subtitle{color:var(--text-light);font-size:.875rem;margin:0}.stock-actions,.page-actions{display:flex;gap:.5rem;margin-top:1rem}.stock-actions button,.page-actions button{flex:1;min-height:48px;font-size:.9rem;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500}.breadcrumb{background:#fff;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:.5rem;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.breadcrumb-item{background:none;border:none;color:var(--primary);font-size:.875rem;padding:.25rem .5rem;cursor:pointer;border-radius:4px}.breadcrumb-item:active{background:#f3f4f6}.breadcrumb-separator{color:var(--text-light);font-size:.875rem}.documents-grid{display:flex;flex-direction:column;gap:0;padding:0}.document-card{background:#fff;border-bottom:1px solid #f3f4f6;padding:1rem;display:flex;align-items:center;gap:1rem;min-height:72px;transition:background .15s ease}.document-card:active{background:#f9fafb}.document-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:12px}.document-info{flex:1;min-width:0}.document-name{font-weight:500;color:var(--text);font-size:1rem;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-meta{font-size:.8125rem;color:var(--text-light)}.document-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-icon{width:40px;height:40px;min-width:40px;min-height:40px;border-radius:8px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;background:#f3f4f6;color:var(--text)}.btn-icon:active{transform:scale(.95)}.btn-icon-primary,.btn-icon-success{background:var(--primary);color:#fff}.btn-icon-danger,.btn-danger{background:var(--error);color:#fff}.btn-icon-secondary{background:#6c757d;color:#fff}.empty-state{text-align:center;padding:3rem 1.5rem;background:#fff;margin:1rem;border-radius:12px}.empty-icon{color:var(--text-light);margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.125rem;margin-bottom:.5rem;color:var(--text)}.empty-state p{color:var(--text-light);font-size:.875rem;margin-bottom:1.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:2000;padding:0}.modal,.modal-content{background:#fff;border-radius:16px 16px 0 0;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1rem;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:1.125rem;color:var(--text);font-weight:600;margin:0}.modal-close,.btn-close{background:none;border:none;color:var(--text-light);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s ease}.modal-close:active,.btn-close:active{background:#f3f4f6}.modal-body{padding:1.25rem 1rem;overflow-y:auto;flex:1}.modal-actions{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border-top:1px solid #f3f4f6}.modal-actions button{width:100%;min-height:48px;font-size:1rem;font-weight:500;border-radius:8px}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:500;color:var(--text);margin-bottom:.5rem;font-size:.9375rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#fff;color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.stock-table-container{background:#fff;margin:0;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}.stock-table-wrapper{position:relative}.stock-table{width:100%;min-width:800px;border-collapse:collapse;background:#fff}.stock-table thead{background:var(--primary);color:#fff;position:sticky;top:0;z-index:10}.stock-table th{padding:.75rem .5rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;white-space:nowrap}.stock-table td{padding:.75rem .5rem;border-bottom:1px solid #f3f4f6;font-size:.8125rem}.stock-table tbody tr:active{background:#f9fafb}.stock-table td:nth-child(1){min-width:100px}.stock-table td:nth-child(2){min-width:180px;max-width:250px;white-space:normal;word-wrap:break-word}.stock-table td:nth-child(3){min-width:110px}.stock-table td:nth-child(4){min-width:95px;white-space:nowrap}.action-buttons{display:flex;gap:.375rem;justify-content:center;flex-wrap:nowrap;min-width:140px}.scroll-indicator{position:sticky;left:0;bottom:0;width:100%;text-align:center;padding:.5rem;background:linear-gradient(to top,#fff,#ffffffe6);font-size:.75rem;color:var(--primary);border-top:1px solid #e5e7eb;pointer-events:none}.loading{text-align:center;padding:2rem;color:var(--text-light)}@media (max-width: 768px) and (orientation: portrait){.stock-container,.page-container{padding:0}.stock-header,.page-header{padding:.75rem 1rem}.stock-table-container{margin:0;border-radius:0;box-shadow:none}.stock-table-container:before{content:"👉 Glissez horizontalement pour voir toutes les colonnes";display:block;padding:.625rem 1rem;background:#eff6ff;color:var(--primary);font-size:.8125rem;text-align:center;border-bottom:1px solid #dbeafe;position:sticky;left:0;z-index:5}}@media (min-width: 769px){.stock-container,.page-container{max-width:1400px;margin:0 auto;padding:1.5rem}.stock-header,.page-header{flex-direction:row;justify-content:space-between;align-items:center;padding:1.5rem;margin-bottom:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.stock-header h1,.page-header h1{font-size:2rem;margin:0}.stock-actions,.page-actions{margin-top:0;width:auto}.stock-actions button,.page-actions button{flex:none;min-width:150px}.breadcrumb{padding:1rem 1.5rem;border-radius:12px;margin:0 0 1.5rem}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:0}.document-card{flex-direction:column;align-items:flex-start;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;min-height:auto}.document-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.document-icon{width:56px;height:56px}.document-info{width:100%}.document-actions{width:100%;justify-content:flex-start;margin-top:.75rem}.modal-overlay{align-items:center;padding:1rem}.modal,.modal-content{max-width:500px;border-radius:12px;animation:none}.modal-actions{flex-direction:row;justify-content:flex-end}.modal-actions button{width:auto;min-width:120px}.stock-table-container{border-radius:12px;box-shadow:0 1px 3px #0000001a;margin:1rem 0}.stock-table{min-width:auto}.stock-table th{padding:1rem;font-size:.875rem}.stock-table td{padding:1rem;font-size:.9375rem}.stock-table-container:before{display:none}}.quantity-modal{max-width:450px}.part-info-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:center;border:2px solid #bae6fd}.part-info-card h3{color:var(--primary);font-size:1.25rem;margin-bottom:.5rem;font-weight:700}.part-designation{color:var(--text);font-size:1rem;margin-bottom:.75rem;line-height:1.5}.current-stock-info{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #bae6fd}.label-text{font-size:.875rem;color:var(--text-light);font-weight:500}.quantity-badge-large{background:var(--primary);color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:700;font-size:1.25rem;min-width:60px}.quantity-selector{margin-bottom:1rem}.quantity-selector .label{text-align:center;font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text)}.quantity-input-group{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.btn-quantity{width:48px;height:48px;border:2px solid var(--primary);background:#fff;color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-quantity:hover:not(:disabled){background:var(--primary);color:#fff;transform:scale(1.05)}.btn-quantity:active:not(:disabled){transform:scale(.95)}.btn-quantity:disabled{opacity:.3;cursor:not-allowed}.quantity-input{width:100px;height:56px;text-align:center;font-size:1.5rem;font-weight:700;border:2px solid var(--primary);border-radius:12px;color:var(--primary)}.quantity-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #06c3}.new-total-info{text-align:center;font-size:.9375rem;color:var(--text-light);margin-top:.75rem;padding:.75rem;background:#f9fafb;border-radius:8px}.new-total-info strong{color:var(--success);font-size:1.125rem}@media (max-width: 768px){.quantity-modal{max-width:100%}.part-info-card{padding:1.25rem}.part-info-card h3{font-size:1.125rem}.quantity-input-group{gap:.75rem}.btn-quantity{width:44px;height:44px}.quantity-input{width:90px;height:52px;font-size:1.375rem}}.search-bar-container{background:#fff;padding:1rem;border-bottom:1px solid #e5e7eb;position:sticky;top:56px;z-index:10}.search-bar{position:relative;max-width:600px;margin:0 auto}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-light);pointer-events:none}.search-input{width:100%;padding:.875rem 3rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s ease;background:#f9fafb}.search-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #0066cc1a}.search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-light);cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-clear:hover{background:#f3f4f6;color:var(--text)}.search-clear:active{transform:translateY(-50%) scale(.95)}.search-results-info{padding:.75rem 1rem;background:#eff6ff;border-bottom:1px solid #dbeafe;color:var(--primary);font-size:.875rem;font-weight:500;text-align:center}.search-no-results{text-align:center;padding:3rem 1.5rem;background:#fff;margin:1rem;border-radius:12px}.search-no-results .empty-icon{color:var(--text-light);margin-bottom:1rem;opacity:.5}.search-no-results h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text)}.search-no-results p{color:var(--text-light);font-size:.9375rem;margin-bottom:1.5rem}.search-no-results strong{color:var(--primary);font-weight:600}.search-highlight{animation:highlightFade .5s ease}@keyframes highlightFade{0%{background:#eff6ff}to{background:transparent}}@media (max-width: 768px){.search-bar-container{padding:.75rem 1rem;top:56px}.search-input{padding:.75rem 2.75rem;font-size:.9375rem}.search-icon{left:.75rem}.search-clear{right:.5rem}}@media (min-width: 769px){.search-bar-container{position:relative;top:0;margin-bottom:1.5rem;border-radius:12px;border:1px solid #e5e7eb}}.badge-available,.badge-unavailable{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:12px;font-size:.8125rem;font-weight:500}.badge-available{background:#d4edda;color:#155724}.badge-unavailable{background:#f8d7da;color:#721c24}.type-badge{display:inline-block;padding:.25rem .625rem;background:#eff6ff;color:var(--primary);border-radius:8px;font-size:.8125rem;font-weight:500}.document-viewer{width:95vw;height:95vh;max-width:1400px;max-height:900px;background:#fff;border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.document-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;background:#f8fafc}.document-viewer-header h2{margin:0;font-size:1.25rem;color:#1e293b}.document-viewer-content{flex:1;overflow:hidden;background:#f1f5f9}@media (max-width: 768px){.document-viewer{width:100vw;height:100vh;max-width:none;max-height:none;border-radius:0}.document-viewer-header{padding:1rem}.document-viewer-header h2{font-size:1rem}}.drop-zone{border:3px dashed #cbd5e0;border-radius:16px;padding:3rem 2rem;text-align:center;background:#f8fafc;transition:all .3s ease}.drop-zone-active{border-color:var(--primary);background:#dbeafe;transform:scale(1.02)}.drop-zone-icon{color:#94a3b8;margin-bottom:1rem}.scanner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:0}.scanner-modal{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:100vw;max-height:100vh;height:100%;display:flex;flex-direction:column;overflow:hidden;animation:slideUpModal .3s ease}@keyframes slideUpModal{0%{transform:translateY(100%)}to{transform:translateY(0)}}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb;background:#fff;flex-shrink:0}.scanner-title{display:flex;align-items:center;gap:.75rem;color:var(--primary)}.scanner-title h2{font-size:1.125rem;font-weight:600;margin:0;color:var(--text)}.scanner-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;overflow:auto;background:#000}.scanner-viewport{width:100%;max-width:500px;border-radius:12px;overflow:hidden}#barcode-reader{width:100%!important}#barcode-reader video{width:100%!important;height:auto!important;border-radius:12px}.scanner-instructions{text-align:center;margin-top:1.5rem;color:#fff}.scanner-instructions p{font-size:1rem;margin-bottom:.5rem;font-weight:500}.scanner-hint{font-size:.875rem!important;opacity:.8;font-weight:400!important}.btn-switch-camera{position:absolute;top:50%;right:1rem;transform:translateY(-50%);width:48px;height:48px;background:#ffffffe6;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);cursor:pointer;box-shadow:0 2px 8px #0000004d;transition:all .2s ease}.btn-switch-camera:active{transform:translateY(-50%) scale(.95)}.scanner-error{text-align:center;padding:2rem 1rem;color:#fff;max-width:400px}.scanner-error svg{color:var(--error);margin-bottom:1rem}.scanner-error p{font-size:1rem;margin-bottom:1.5rem;line-height:1.6}.permission-help{background:#ffffff1a;border-radius:8px;padding:1rem;margin-top:1rem;text-align:left}.permission-help strong{display:block;margin-bottom:.75rem;font-size:.9375rem}.permission-help ul{list-style:none;padding:0;margin:0;font-size:.875rem;line-height:1.8}.permission-help li:before{content:"• ";color:var(--primary);font-weight:700;margin-right:.5rem}.manual-input-section{text-align:center;padding:2rem 1rem;max-width:400px;width:100%}.manual-input-section svg{color:var(--primary);margin-bottom:1rem}.manual-input-section p{font-size:1rem;margin-bottom:1.5rem;color:#fff}.manual-input-section form{display:flex;flex-direction:column;gap:1rem}.manual-input-section input{padding:1rem;font-size:1.125rem;text-align:center;border:2px solid var(--primary);border-radius:8px;letter-spacing:1px}.manual-input-section input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #06c3}.scanner-footer{display:flex;gap:.75rem;padding:1rem;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}.scanner-footer button{flex:1;min-height:48px;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500}@media (min-width: 769px){.scanner-modal{max-width:600px;max-height:80vh;height:auto;border-radius:16px}.scanner-viewport{max-width:400px}}@media (max-width: 400px){.scanner-title h2{font-size:1rem}.scanner-instructions p{font-size:.875rem}}.layout{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background)}.mobile-header{position:fixed;top:0;left:0;right:0;height:56px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:1000;box-shadow:0 2px 8px #0000001a}.mobile-header-title{font-size:1.125rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.mobile-header-user{display:flex;align-items:center;gap:.75rem}.user-avatar-small{width:36px;height:36px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.btn-header-icon{background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.btn-header-icon:active{background:#ffffff4d;transform:scale(.95)}.main-content{flex:1;padding:72px 0 80px;background-color:var(--background);min-height:100vh}.sidebar{position:fixed;bottom:0;left:0;right:0;height:64px;background:#fff;border-top:1px solid #e5e7eb;display:flex;z-index:1000;box-shadow:0 -2px 10px #0000000d}.sidebar-nav{display:flex;width:100%;justify-content:space-around;align-items:center;padding:0}.sidebar-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;color:var(--text-light);text-decoration:none;font-size:.75rem;transition:all .2s ease;border:none;position:relative}.sidebar-link:active{transform:scale(.95)}.sidebar-link.active{color:var(--primary);font-weight:600}.sidebar-link.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:3px;background:var(--primary);border-radius:0 0 3px 3px}.sidebar-link svg{width:24px;height:24px}.sidebar-header,.sidebar-footer{display:none}@media (min-width: 769px){.layout{flex-direction:row}.mobile-header{display:none}.sidebar{width:280px;height:100vh;position:fixed;top:0;left:0;bottom:auto;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;flex-direction:column;border-top:none;box-shadow:var(--shadow-lg)}.sidebar-header{display:block;padding:var(--spacing-xl);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs)}.sidebar-subtitle{font-size:.875rem;opacity:.8}.sidebar-nav{flex:1;flex-direction:column;padding:var(--spacing-lg) 0;overflow-y:auto}.sidebar-link{flex-direction:row;justify-content:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);color:#fffc;font-size:1rem;border-left:3px solid transparent}.sidebar-link:before{display:none}.sidebar-link:hover{background-color:#ffffff1a;color:#fff}.sidebar-link.active{background-color:#ffffff26;color:#fff;border-left-color:var(--secondary)}.sidebar-footer{display:block;padding:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.user-avatar{width:50px;height:50px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.user-details{flex:1}.user-name{font-weight:600;margin-bottom:var(--spacing-xs)}.user-role{font-size:.875rem;opacity:.8}.user-vehicle{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;opacity:.8;margin-top:var(--spacing-xs)}.btn-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:#ffffff1a;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;font-weight:500}.btn-logout:hover{background-color:#fff3}.main-content{margin-left:280px;padding:var(--spacing-xl)}}.menu-hamburger,.mobile-menu-dropdown,.menu-overlay{display:none}@media (max-width: 768px){.menu-hamburger{display:flex;position:fixed;bottom:76px;right:1rem;width:56px;height:56px;background:var(--primary);color:#fff;border:none;border-radius:50%;align-items:center;justify-content:center;box-shadow:0 4px 16px #06c6;cursor:pointer;z-index:1001;transition:all .3s ease}.menu-hamburger:active{transform:scale(.92)}.mobile-menu-dropdown{display:block;position:fixed;bottom:140px;right:1rem;left:1rem;max-width:320px;margin-left:auto;background:#fff;border-radius:16px;box-shadow:0 12px 32px #0003;padding:.5rem;z-index:1000;animation:slideUpFade .2s ease}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-item{display:flex;align-items:center;gap:1rem;padding:1rem;color:var(--text);text-decoration:none;border-radius:12px;font-size:.9375rem;transition:background .15s ease;font-weight:500}.mobile-menu-item:active{background:#f3f4f6}.mobile-menu-item.active{background:#eff6ff;color:var(--primary);font-weight:600}.mobile-menu-item svg{width:22px;height:22px;flex-shrink:0}.mobile-menu-user-info{display:flex;align-items:center;gap:.75rem;padding:1rem}.mobile-menu-user-info .user-avatar{width:48px;height:48px;font-size:1rem}.menu-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:999;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #0066cc;--primary-dark: #004d99;--secondary: #ff6600;--background: #f5f5f5;--surface: #ffffff;--text: #333333;--text-light: #666666;--border: #e0e0e0;--error: #dc3545;--success: #28a745;--warning: #ffc107;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .15)}html{width:100%;max-width:100vw;overflow-x:hidden;-webkit-text-size-adjust:100%}body{width:100%;max-width:100vw;overflow-y:auto;overflow-x:hidden;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text);line-height:1.6}#root{width:100%;max-width:100vw;overflow-x:hidden}.table-container,.stock-table-container{width:100%;overflow-x:auto!important;-webkit-overflow-scrolling:touch!important}*{max-width:100%}button,input,select,textarea{font-family:inherit;font-size:100%}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.card{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#e55a00;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-danger{background-color:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-outline{background-color:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover:not(:disabled){background-color:var(--primary);color:#fff}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;transition:border-color .2s ease}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0066cc1a}.input-error{border-color:var(--error)}.label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text)}.error-message{color:var(--error);font-size:.875rem;margin-top:var(--spacing-xs)}.table-container{overflow-x:auto;margin:var(--spacing-md) 0}.table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.table thead{background-color:var(--primary);color:#fff}.table th,.table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border)}.table tbody tr:hover{background-color:#f8f9fa}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.badge-success{background-color:#d4edda;color:#155724}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.loading{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.card{padding:var(--spacing-md)}.btn{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}.table th,.table td{padding:var(--spacing-sm);font-size:.875rem}}
