.layout{min-height:100vh;display:flex;flex-direction:column}.header{height:var(--header-height);background:#fff;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center;gap:1rem}.menu-toggle{background:none;border:none;cursor:pointer;color:var(--text-primary);display:none;padding:.5rem;border-radius:var(--border-radius);transition:var(--transition)}.menu-toggle:hover{background:var(--bg-secondary)}.app-title{font-size:1.25rem;font-weight:600;color:var(--primary-color)}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.username{font-weight:500}.user-role{color:var(--text-secondary);font-size:.875rem;text-transform:capitalize}.logout-btn{background:none;border:none;cursor:pointer;color:var(--danger-color);padding:.5rem;border-radius:var(--border-radius);transition:var(--transition)}.logout-btn:hover{background:#ef44441a}.layout-main{display:flex;flex:1;position:relative}.sidebar{width:var(--sidebar-width);background:#fff;border-right:1px solid var(--border-color);padding:1.5rem 0;transition:var(--transition)}.sidebar-nav{display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;color:var(--text-secondary);text-decoration:none;transition:var(--transition);border-left:3px solid transparent}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item-active{background:#2563eb1a;color:var(--primary-color);border-left-color:var(--primary-color);font-weight:500}.content{flex:1;padding:2rem;overflow-y:auto;background:var(--bg-secondary)}@media (max-width: 768px){.menu-toggle{display:block}.sidebar{position:fixed;top:var(--header-height);left:-100%;height:calc(100vh - var(--header-height));z-index:99;box-shadow:var(--shadow-lg)}.sidebar-open{left:0}.sidebar-overlay{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:#00000080;z-index:98}.content{padding:1rem}.user-info{padding:.5rem}.username{display:none}}.app-logo{height:50px;width:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:500;cursor:pointer;transition:var(--transition);text-decoration:none}.btn:disabled,.btn-disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background:#059669}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-outline:hover:not(:disabled){background:var(--primary-color);color:#fff}.btn-small{padding:.5rem 1rem;font-size:.875rem}.btn-medium{padding:.75rem 1.5rem;font-size:1rem}.btn-large{padding:1rem 2rem;font-size:1.125rem}.btn-full{width:100%}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.alert-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:400px}.alert{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:var(--border-radius);box-shadow:var(--shadow-md);animation:slideIn .3s ease;position:relative}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.alert-icon{flex-shrink:0}.alert-message{flex:1;font-size:.95rem}.alert-close{background:none;border:none;cursor:pointer;font-size:1.5rem;opacity:.6;transition:var(--transition);padding:0;line-height:1}.alert-close:hover{opacity:1}.alert-success{background:#d1fae5;color:#065f46;border-left:4px solid var(--success-color)}.alert-error{background:#fee2e2;color:#991b1b;border-left:4px solid var(--danger-color)}.alert-warning{background:#fef3c7;color:#92400e;border-left:4px solid var(--warning-color)}.alert-info{background:#dbeafe;color:#1e40af;border-left:4px solid var(--info-color)}@media (max-width: 768px){.alert-container{right:.5rem;left:.5rem;max-width:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,#1e40af 100%);padding:1rem}.login-container{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:420px;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;color:var(--primary-color);margin-bottom:.5rem}.login-header p{color:var(--text-secondary);font-size:.95rem}.login-form{margin-bottom:2rem}.login-footer{text-align:center;padding-top:1.5rem;border-top:1px solid var(--border-color)}.login-footer p{color:var(--text-secondary);font-size:.875rem}@media (max-width: 480px){.login-container{padding:2rem 1.5rem}.login-header h1{font-size:1.75rem}}.login-logo{height:84px;width:auto;margin-bottom:8px}.dashboard{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:2rem}.dashboard-header{background:transparent;padding:1.5rem 1rem 1rem;color:#fff}.header-content h1{font-size:1.75rem;font-weight:700;margin:0 0 .25rem;color:#fff}.header-subtitle{font-size:.875rem;opacity:.9;margin:0;font-weight:400;text-transform:capitalize}.stats-container{padding:0 1rem 1.5rem}.stats-grid-mobile{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card-mobile{background:#fff;border-radius:16px;padding:1rem;box-shadow:0 2px 8px #00000014;transition:transform .2s ease,box-shadow .2s ease;min-height:100px;display:flex;flex-direction:column;justify-content:space-between}.stat-card-mobile:active{transform:scale(.98)}.stat-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.stat-icon-mobile{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-primary .stat-icon-mobile{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-warning .stat-icon-mobile{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.stat-success .stat-icon-mobile{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.stat-info .stat-icon-mobile{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.stat-label{font-size:.813rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:#1e293b;line-height:1}.dashboard-content{padding:0 1rem}.dashboard-section{background:#fff;border-radius:16px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #00000014}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header h2{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0}.badge-count{background:#fee2e2;color:#dc2626;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:700}.badge-count.badge-warning{background:#fef3c7;color:#f59e0b}.section-list{display:flex;flex-direction:column;gap:.5rem}.list-item-mobile{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:#f8fafc;border-radius:12px;transition:background .2s ease;min-height:64px}.list-item-mobile:active{background:#f1f5f9}.list-item-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:1.25rem}.alert-icon{background:#fef3c7;color:#f59e0b}.movement-icon{font-size:1.5rem}.movement-icon-in{background:#d1fae5;color:#10b981}.movement-icon-out{background:#fee2e2;color:#ef4444}.movement-icon-adjustment{background:#dbeafe;color:#3b82f6}.maintenance-icon{background:#e0e7ff;color:#6366f1}.list-item-content{flex:1;min-width:0}.list-item-title{font-size:.938rem;font-weight:600;color:#1e293b;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item-subtitle{font-size:.813rem;color:#64748b;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item-stock{display:flex;align-items:center;gap:.25rem;font-weight:700;flex-shrink:0}.stock-value{font-size:1rem}.stock-danger{color:#ef4444}.stock-min{color:#94a3b8}.stock-separator{color:#cbd5e1;font-weight:400}.list-item-badge{flex-shrink:0}.quantity-badge{padding:.375rem .625rem;border-radius:8px;font-size:.875rem;font-weight:700;display:inline-block;min-width:48px;text-align:center}.quantity-in{background:#d1fae5;color:#10b981}.quantity-out{background:#fee2e2;color:#ef4444}.quantity-adjustment{background:#dbeafe;color:#3b82f6}.list-item-status{flex-shrink:0}.status-badge{padding:.375rem .625rem;border-radius:8px;font-size:.75rem;font-weight:600;display:inline-block;white-space:nowrap}.status-pending{background:#fef3c7;color:#f59e0b}.status-in_progress{background:#dbeafe;color:#3b82f6}.status-pending_parts{background:#fee2e2;color:#ef4444}.status-completed{background:#d1fae5;color:#10b981}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.loading-container p{margin-top:1rem;font-size:1rem;opacity:.9}@media (min-width: 768px){.dashboard{background:#f8fafc;padding:2rem}.dashboard-header{background:#fff;border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.header-content h1{font-size:2rem;color:#1e293b}.header-subtitle{font-size:1rem;color:#64748b}.stats-container{padding:0;margin-bottom:1.5rem}.stats-grid-mobile{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card-mobile{padding:1.5rem;min-height:120px}.stat-icon-mobile{width:48px;height:48px;border-radius:12px}.stat-value{font-size:2.5rem}.dashboard-content{padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.dashboard-section{padding:1.5rem;margin-bottom:0}.section-header h2{font-size:1.25rem}.list-item-mobile{padding:1rem;min-height:72px}.list-item-icon{width:48px;height:48px;border-radius:12px}.list-item-title{font-size:1rem}.list-item-subtitle{font-size:.875rem}}@media (min-width: 1024px){.dashboard{max-width:1400px;margin:0 auto}.stats-grid-mobile{grid-template-columns:repeat(4,1fr)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-small{width:100%;max-width:400px}.modal-medium{width:100%;max-width:600px}.modal-large{width:100%;max-width:900px}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.5rem;border-radius:var(--border-radius);transition:var(--transition)}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}@media (max-width: 768px){.modal-content{max-height:95vh}.modal-small,.modal-medium,.modal-large{max-width:100%}}.table-container{overflow-x:auto;background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:collapse}.table thead{background:var(--bg-secondary)}.table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-secondary)}.table-row-clickable{cursor:pointer;transition:var(--transition)}.table-empty{text-align:center;padding:3rem 1rem!important;color:var(--text-light)}@media (max-width: 768px){.table th,.table td{padding:.75rem .5rem;font-size:.875rem}}.scanner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.scanner-container{background:#fff;border-radius:12px;max-width:500px;width:100%;overflow:hidden}.scanner-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.scanner-header h3{font-size:1.25rem;color:var(--text-primary)}.scanner-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.5rem;border-radius:var(--border-radius);transition:var(--transition)}.scanner-close:hover{background:var(--bg-secondary)}.scanner-body{padding:1.5rem}#scanner-container{border-radius:var(--border-radius);overflow:hidden}.scanner-hint{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.9rem}.scanner-error{background:var(--danger-color);color:#fff;padding:1rem;border-radius:var(--border-radius);margin-bottom:1rem}.page-container{max-width:1400px;margin:0 auto;padding:0}.page-content{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.empty-state{text-align:center;padding:3rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014}.empty-state p{color:var(--text-light);font-size:.95rem}.search-bar{display:flex;gap:.75rem;margin-bottom:1rem;background:#fff;padding:.875rem;border-radius:12px;box-shadow:0 1px 3px #00000014}.search-bar input{flex:1;padding:.75rem 1rem;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.95rem;transition:all .2s ease}.search-bar input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.filters-container{background:#fff;padding:1.25rem;border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:1rem}.filter-actions{display:flex;gap:.75rem;margin-top:1rem}.filters-mobile-header{display:none}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-group{margin-bottom:0}.input-with-button{display:flex;gap:.5rem}.input-with-button input{flex:1}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.mobile-cards-container{display:none;flex-direction:column;gap:.75rem}.mobile-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease;border:1px solid rgba(0,0,0,.04)}.mobile-card:active{transform:scale(.99);box-shadow:0 2px 8px #0000001f}.mobile-card-header{padding:.875rem 1rem;background:linear-gradient(to bottom,#fafafa,#fff);border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.mobile-card-header h3{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0;flex:1;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.mobile-card-header>div{flex:1}.movement-date{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem;font-weight:400}.mobile-card-body{padding:1rem}.barcode-container{display:flex;justify-content:center;align-items:center;padding:1rem .5rem;background:#fafafa;border-radius:8px;margin-bottom:1rem}.barcode-container svg{max-width:100%;height:auto}.mobile-card-info{display:flex;flex-direction:column;gap:.625rem}.info-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;padding-bottom:.625rem;border-bottom:1px solid #f5f5f5}.info-row:last-child{border-bottom:none;padding-bottom:0}.info-label{font-weight:600;color:var(--text-primary);font-size:.85rem;flex-shrink:0;min-width:85px}.info-value{color:var(--text-secondary);font-size:.85rem;text-align:right;word-break:break-word;flex:1;line-height:1.4}.mobile-card-actions{padding:.875rem 1rem;background:#fafafa;border-top:1px solid #f0f0f0;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.625rem}.mobile-card-actions button{margin:0}.stock-badge,.type-badge,.movement-badge,.maintenance-status{padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.badge-success,.movement-badge.movement-in{background:#10b981;color:#fff}.badge-danger,.movement-badge.movement-out{background:#ef4444;color:#fff}.badge-primary{background:#3b82f6;color:#fff}.badge-secondary{background:#6b7280;color:#fff}.movement-badge.movement-adjustment{background:#f59e0b;color:#fff}.quantity-badge{font-weight:700;font-size:.95rem}.quantity-badge.movement-in{color:#10b981}.quantity-badge.movement-out{color:#ef4444}.quantity-badge.movement-adjustment{color:#f59e0b}.status-in_progress{background:#dbeafe;color:#1e40af}.status-pending_parts{background:#fee2e2;color:#991b1b}.stock-form-container,.reports-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:1.5rem}.stock-form{max-width:700px;margin:0 auto}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #f0f0f0}.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h3{margin-bottom:1rem;color:var(--text-primary);font-size:1.05rem}.selected-product-card{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#f8fafc;border-radius:8px;border:2px solid var(--primary-color)}.product-info h4{font-size:1.05rem;margin-bottom:.5rem;color:var(--text-primary)}.product-info p{color:var(--text-secondary);font-size:.875rem;margin:.25rem 0}.product-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;cursor:pointer;transition:background .15s ease;border-bottom:1px solid #f5f5f5}.product-item:hover{background:#f9fafb}.product-item:active{background:#f3f4f6}.product-item h4{font-size:.95rem;margin-bottom:.25rem;color:var(--text-primary)}.product-item p{font-size:.85rem;color:var(--text-secondary)}.no-results{padding:2rem;text-align:center;color:var(--text-light);font-size:.9rem}.parts-list{margin-bottom:1rem}.part-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:.5rem}.part-info h4{font-size:.95rem;margin-bottom:.25rem}.part-info p{font-size:.85rem;color:var(--text-secondary)}.part-quantity input{width:80px;padding:.5rem;border:1.5px solid #e5e7eb;border-radius:6px;text-align:center;font-weight:600}.parts-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #f0f0f0}.parts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.parts-details{margin-top:1rem;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.parts-table thead{background:#f9fafb}.parts-table th{padding:.75rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--text-primary);border-bottom:2px solid #e5e7eb;text-transform:uppercase;letter-spacing:.5px}.parts-table td{padding:.875rem .75rem;border-bottom:1px solid #f5f5f5;color:var(--text-secondary);font-size:.875rem}.parts-table tbody tr:hover{background:#fafafa}.parts-table .text-center{text-align:center}.part-quantity{display:inline-block;background:var(--primary-color);color:#fff;padding:.3rem .75rem;border-radius:6px;font-weight:600;font-size:.85rem;min-width:40px;text-align:center}.history-list{max-height:500px;overflow-y:auto;padding-right:.5rem}.history-item{padding:1.25rem;border-left:3px solid var(--primary-color);background:#fafafa;border-radius:8px;margin-bottom:1rem;transition:box-shadow .2s ease}.history-item:hover{box-shadow:0 2px 8px #0000001a}.history-item:last-child{margin-bottom:0}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.history-date{font-size:.95rem;font-weight:600;color:var(--primary-color)}.history-details{display:flex;flex-direction:column;gap:.75rem}.history-info-row{display:flex;gap:.75rem;align-items:flex-start}.report-section{margin-bottom:1.5rem}.report-section h3{margin-bottom:1rem;color:var(--text-primary);font-size:1.05rem}.report-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.report-type-card{padding:1.25rem;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.report-type-card:hover{border-color:var(--primary-color);background:#2563eb0a}.report-type-card.active{border-color:var(--primary-color);background:#2563eb14}.report-type-card h4{font-size:1rem;margin-bottom:.5rem;color:var(--text-primary)}.report-type-card p{font-size:.85rem;color:var(--text-secondary)}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.barcode-cell{display:flex;justify-content:center;align-items:center;padding:.5rem;background:#fafafa;border-radius:6px;min-height:70px}.barcode-cell svg{max-width:100%;height:auto}.text-danger{color:var(--danger-color)!important;font-weight:600}.text-secondary{color:var(--text-secondary)}.warning-text{color:var(--warning-color);font-weight:500}.header-icon{color:var(--primary-color)}.stock-change{color:var(--text-secondary);font-size:.875rem;font-weight:500}.comment-text{color:var(--text-secondary);font-size:.85rem}.welcome-text{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem;font-weight:400}.history-list::-webkit-scrollbar,.product-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track,.product-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:3px}.history-list::-webkit-scrollbar-thumb,.product-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.history-list::-webkit-scrollbar-thumb:hover,.product-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 991.98px){.history-list{max-height:600px}.parts-header{gap:.5rem}.table th:nth-child(2),.table td:nth-child(2){min-width:180px}}@media (max-width: 768px){.mobile-cards-container{display:flex}.page-content{display:none}.page-header{flex-direction:row;align-items:center;gap:.75rem}.page-header h1{font-size:1.4rem;flex:1}.page-header button{min-width:auto;white-space:nowrap;padding:.625rem 1rem;font-size:.9rem}.search-bar{gap:.625rem;padding:.75rem;margin-bottom:.875rem}.search-bar input{font-size:16px;padding:.625rem .875rem}.search-bar button{min-width:44px;padding:.625rem}.filters-mobile-closed{display:none}.filters-mobile-open{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:1000;overflow-y:auto;padding:1rem;display:block}.filters-mobile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.filters-mobile-header h3{font-size:1.15rem;margin:0;font-weight:600}.filters-close{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);border-radius:6px;transition:all .15s ease}.filters-close:active{background:#f5f5f5}.filters-container:not(.filters-mobile-open){display:none}.filter-actions{grid-template-columns:1fr 1fr;gap:.625rem}.filter-actions button{margin:0}.form-row{grid-template-columns:1fr;gap:.875rem}.stock-form-container,.reports-container{padding:1rem}.report-types{grid-template-columns:1fr}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.5rem}.modal-content{max-height:90vh;margin:1rem}.modal-actions{grid-template-columns:1fr 1fr;gap:.625rem}.modal-actions button{margin:0}.history-item{padding:1rem}.history-header{flex-direction:column;align-items:flex-start;gap:.5rem}.history-date{font-size:.875rem}.history-info-row{flex-direction:column;gap:.25rem}.info-label{min-width:auto;font-size:.8rem}.info-value{font-size:.8rem;text-align:left}.parts-header{flex-direction:column;align-items:stretch;gap:.75rem}.parts-table{font-size:.8rem}.parts-table th,.parts-table td{padding:.5rem}.maintenance-status{font-size:.7rem;padding:.25rem .5rem}.part-quantity{font-size:.8rem;padding:.25rem .6rem;min-width:35px}.part-item{flex-direction:column;align-items:stretch;padding:.875rem}}@media (min-width: 769px){.mobile-cards-container{display:none}.page-content{display:block}.filters-mobile-header{display:none}.filters-container{display:block!important}.table th:nth-child(2),.table td:nth-child(2){min-width:200px;text-align:center}}@media (max-width: 480px){.page-header h1{font-size:1.25rem}.mobile-card-header h3{font-size:.9rem}.mobile-card-actions{grid-template-columns:1fr}.barcode-container svg{transform:scale(.85)}.info-label{min-width:75px}.stats-grid,.dashboard-grid{grid-template-columns:1fr}}@media (hover: none) and (pointer: coarse){.mobile-card{cursor:pointer}.mobile-card-actions button,.filter-actions button{min-height:44px}input,select,textarea{font-size:16px}button{-webkit-tap-highlight-color:transparent}}@media print{.search-bar,.action-buttons,.mobile-card-actions,.parts-header button,.modal-actions,.filters-container{display:none!important}.parts-details{display:block!important}.history-item{page-break-inside:avoid;box-shadow:none;border:1px solid #ddd}.parts-table{page-break-inside:auto}.parts-table tr{page-break-inside:avoid;page-break-after:auto}}.active-maintenance-alert{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 4px 6px #0000001a}.active-maintenance-alert .alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.active-maintenance-alert h4{margin:0;font-size:1.2rem}.active-maintenance-alert p{margin:.5rem 0;opacity:.95}.active-maintenance-alert button{margin-top:1rem;background:#fff;color:#667eea}.active-maintenance-alert button:hover{background:#ffffffe6}.maintenance-status{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-pending{background:#fef3c7;color:#92400e}.status-in-progress{background:#dbeafe;color:#1e40af}.status-completed{background:#d1fae5;color:#065f46}.status-pending-parts{background:#fee2e2;color:#991b1b}.status-history-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.status-timeline{margin-top:.75rem;padding-left:1rem;border-left:3px solid #e5e7eb}.status-change-item{margin-bottom:1rem;padding-left:1rem;position:relative}.status-change-item:before{content:"";position:absolute;left:-1.4rem;top:.5rem;width:10px;height:10px;background:#667eea;border-radius:50%;border:3px solid white;box-shadow:0 0 0 2px #667eea}.status-change-arrow{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.status-change-info small{color:#6b7280;font-size:.875rem}.status-change-info p{margin:.5rem 0 0;color:#374151;font-style:italic}.current-status{padding:1rem;border-radius:8px;text-align:center;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.search-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-bar input{flex:1}.search-bar button{flex-shrink:0}@media (max-width: 768px){.active-maintenance-alert .alert-header{flex-direction:column;align-items:flex-start;gap:.75rem}.status-change-arrow{flex-direction:column;align-items:flex-start}.search-bar{flex-wrap:wrap}.search-bar button svg{margin:0}}.parts-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.parts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.parts-details{margin-top:.75rem;background:#f9fafb;border-radius:8px;padding:1rem}.parts-table{width:100%;border-collapse:collapse}.parts-table th{background:#f3f4f6;padding:.75rem;text-align:left;font-weight:600;font-size:.875rem;color:#374151}.parts-table td{padding:.75rem;border-bottom:1px solid #e5e7eb}.parts-table tbody tr:last-child td{border-bottom:none}.part-quantity{display:inline-block;background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:12px;font-weight:600;font-size:.875rem}.text-secondary{color:#6b7280}.empty-state{text-align:center;padding:3rem 1rem;color:#6b7280}.empty-state p{margin:0;font-size:1.1rem}.parts-list{margin-bottom:1.5rem;background:#f9fafb;border-radius:8px;padding:1rem}.part-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:8px;margin-bottom:.75rem;border:1px solid #e5e7eb}.part-item:last-child{margin-bottom:0}.part-info{flex:1}.part-info h4{margin:0 0 .25rem;font-size:1rem;color:#111827}.part-info p{margin:0;font-size:.875rem;color:#6b7280}.part-quantity{display:flex;align-items:center;gap:.5rem}.part-quantity label{font-size:.875rem;font-weight:500;color:#374151;margin:0}.part-quantity input{width:80px;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;text-align:center}.part-quantity input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.product-list{max-height:300px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px;margin-top:.5rem}.product-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .2s}.product-item:hover{background-color:#f9fafb}.product-item:last-child{border-bottom:none}.product-item h4{margin:0 0 .25rem;font-size:.95rem;color:#111827}.product-item p{margin:0;font-size:.85rem;color:#6b7280}.no-results{padding:2rem;text-align:center;color:#6b7280;font-style:italic}.form-section h3{font-size:1.1rem;font-weight:600;color:#111827;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.form-section .search-bar{position:relative;margin-bottom:0}.form-section .search-bar input{padding-right:2.5rem}.form-section .search-bar svg{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.modal.size-large .modal-content{max-width:800px;max-height:90vh;overflow-y:auto}@media (max-width: 768px){.part-item{flex-direction:column;align-items:stretch}.part-quantity{justify-content:space-between;width:100%}.part-quantity input{flex:1}.product-item{flex-direction:column;align-items:flex-start;gap:.75rem}.product-item button{width:100%}.modal.size-large .modal-content{max-width:95%;margin:1rem}}.active-maintenance-alert button{font-size:.95rem;padding:.75rem 1.5rem}.part-info .low-stock-warning{color:#dc2626;font-weight:600;font-size:.875rem;margin-top:.25rem}.parts-list{position:relative}.parts-list:before{content:"✓ Repuestos agregados";position:absolute;top:-.5rem;right:1rem;background:#10b981;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}:root{--primary-color: #0d9488;--secondary-color: #10b981;--danger-color: #dc2626;--warning-color: #f59e0b;--success-color: #059669;--info-color: #06b6d4;--bg-primary: #ffffff;--bg-secondary: #f0fdfa;--bg-tertiary: #ccfbf1;--text-primary: #134e4a;--text-secondary: #4b5563;--text-light: #9ca3af;--border-color: #d1d5db;--border-radius: 8px;--shadow-sm: 0 1px 2px 0 rgba(13, 148, 136, .05);--shadow-md: 0 4px 6px -1px rgba(13, 148, 136, .1);--shadow-lg: 0 10px 15px -3px rgba(13, 148, 136, .15);--sidebar-width: 250px;--header-height: 60px;--transition: all .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{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;color:var(--text-primary);background-color:var(--bg-secondary)}#root{min-height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;transition:var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0d94881a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.form-group textarea{resize:vertical;min-height:100px}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}@media (max-width: 575.98px){.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.page-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-icon{width:48px;height:48px}.stat-content h3{font-size:1.5rem}.dashboard-grid{grid-template-columns:1fr}.search-bar{flex-direction:column}.search-bar input{width:100%}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:600px}.modal-content{margin:0;max-height:100vh;border-radius:0}.modal-body{max-height:calc(100vh - 120px)}.form-row{grid-template-columns:1fr}.input-with-button{flex-direction:column}.input-with-button input{width:100%}.action-buttons{flex-direction:column;width:100%}.action-buttons button{width:100%;justify-content:center}.selected-product-card{flex-direction:column;gap:1rem}.selected-product-card button{width:100%}.part-item{flex-direction:column;align-items:stretch;gap:.75rem}.part-quantity input{width:100%}.report-types{grid-template-columns:1fr}.scanner-overlay{padding:0}.scanner-container{max-width:100%;border-radius:0;max-height:100vh}}@media (min-width: 576px) and (max-width: 767.98px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}@media (min-width: 768px) and (max-width: 991.98px){.stats-grid,.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.stats-grid{grid-template-columns:repeat(4,1fr)}.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (hover: none) and (pointer: coarse){.btn{min-height:44px;padding:.875rem 1.5rem}.nav-item{min-height:48px}input,select,textarea{min-height:44px;font-size:16px}.product-item,.alert-item,.movement-item,.maintenance-item{min-height:60px}.product-list,.history-list{-webkit-overflow-scrolling:touch}}@media print{.header,.sidebar,.page-header button,.action-buttons,.search-bar,.alert-container{display:none!important}.content{padding:0}.page-container{max-width:100%}.table{font-size:10pt}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.loading-content{background:#fff;padding:2rem 3rem;border-radius:12px;text-align:center;box-shadow:var(--shadow-lg)}.spinner-large{width:60px;height:60px;border:5px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.loading-content p{color:var(--text-primary);font-size:1.125rem;margin:0}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:2rem}.error-content{text-align:center;background:#fff;padding:3rem;border-radius:12px;box-shadow:var(--shadow-lg);max-width:500px}.error-content h1{color:var(--danger-color);margin-bottom:1rem;font-size:2rem}.error-content p{color:var(--text-secondary);margin-bottom:2rem}
