:root{color:#374151;-webkit-font-smoothing:antialiased;background:#f8fafc;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:16px}*,:before,:after{box-sizing:border-box}body{margin:0}#root{height:100%}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:opacity .15s,background .15s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{color:#dc2626;background:#fef2f2}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-sm{padding:6px 12px;font-size:13px}.btn-full{width:100%}.form-group{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-group label{color:#374151;font-size:13px;font-weight:500}.form-group input,.form-group select,.form-group textarea{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:7px;outline:none;width:100%;padding:9px 12px;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.stat-card-small{background:#fff;border:1px solid #e5e7eb;border-radius:10px;min-width:140px;padding:14px 20px}.stat-card-small.warn{border-color:#fbbf24}.stat-card-small.danger{border-color:#fca5a5}.stat-label-sm{color:#6b7280;margin-bottom:4px;font-size:12px}.stat-val-sm{color:#111827;font-size:24px;font-weight:700}.stat-card-small.warn .stat-val-sm{color:#d97706}.stat-card-small.danger .stat-val-sm{color:#dc2626}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.login-page{background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px;box-shadow:0 20px 60px #0006}.login-brand{text-align:center;margin-bottom:32px}.login-logo{color:#fff;background:#3b82f6;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:20px;font-weight:700;display:flex}.login-brand h1{color:#111827;margin:0 0 6px;font-size:24px;font-weight:700}.login-brand p{color:#6b7280;margin:0;font-size:14px}.login-form{flex-direction:column;gap:18px;display:flex}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:14px}.login-footer{text-align:center;color:#9ca3af;margin:24px 0 0;font-size:12px}.sidebar{color:#cbd5e1;background:#1e293b;flex-direction:column;flex-shrink:0;width:240px;min-height:100vh;display:flex}.sidebar-brand{border-bottom:1px solid #334155;align-items:center;gap:12px;padding:24px 20px 20px;display:flex}.brand-mark{color:#fff;background:#3b82f6;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.brand-name{color:#f1f5f9;letter-spacing:.5px;font-size:16px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.nav-item{color:#94a3b8;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#f1f5f9;background:#334155}.nav-item.active{color:#fff;background:#3b82f6}.nav-icon{font-size:16px}.nav-separator{text-transform:uppercase;letter-spacing:.8px;color:#475569;padding:16px 12px 4px;font-size:11px;font-weight:600}.sidebar-footer{border-top:1px solid #334155;flex-direction:column;gap:10px;padding:16px 12px;display:flex}.user-info{align-items:center;gap:10px;display:flex}.user-avatar{color:#f1f5f9;background:#475569;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:13px;font-weight:600;overflow:hidden}.user-rol{color:#64748b;font-size:11px}.logout-btn{color:#94a3b8;cursor:pointer;text-align:center;background:#334155;border:none;border-radius:6px;padding:8px;font-size:13px;transition:background .15s}.logout-btn:hover{color:#fff;background:#ef4444}.layout{min-height:100vh;display:flex}.layout-main{background:#f8fafc;flex-direction:column;flex:1;display:flex;overflow:auto}.page-header{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:28px 32px 20px;display:flex}.page-title{color:#111827;margin:0;font-size:22px;font-weight:700}.page-subtitle{color:#6b7280;margin:4px 0 0;font-size:14px}.page-action{gap:10px;display:flex}.page-content{flex:1;padding:28px 32px}.dash-loading{color:#6b7280;padding:32px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px 24px;box-shadow:0 1px 4px #00000012}.stat-card.stat-alert{border-color:#fca5a5}.stat-label{color:#6b7280;margin-bottom:8px;font-size:13px}.stat-value{color:#111827;font-size:32px;font-weight:700}.stat-alert .stat-value{color:#dc2626}.dash-cols{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}@media (width<=768px){.dash-cols{grid-template-columns:1fr}}.dash-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px 24px;box-shadow:0 1px 4px #00000012}.dash-panel h3{color:#374151;margin:0 0 16px;font-size:15px;font-weight:600}.mov-row{border-bottom:1px solid #f3f4f6;align-items:center;gap:12px;padding:8px 0;font-size:13px;display:flex}.mov-row:last-child{border:none}.mov-tipo{min-width:100px;font-weight:600}.mov-user{color:#374151;flex:1}.mov-date{color:#9ca3af}.bodega-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.bodega-row:last-child{border:none}.bodega-nombre{color:#111827;font-size:13px;font-weight:600}.bodega-ubi{color:#9ca3af;font-size:12px}.bodega-cap{color:#6b7280;font-size:12px}.dash-breakdown{margin-top:0}.breakdown-grid{gap:16px;display:flex}.breakdown-item{text-align:center;border:2px solid;border-radius:10px;flex:1;padding:16px}.breakdown-val{font-size:28px;font-weight:700}.breakdown-lbl{color:#374151;margin-top:4px;font-size:12px;font-weight:600}.breakdown-sub{color:#9ca3af;font-size:11px}.empty-msg{color:#9ca3af;font-size:13px}.dt-wrapper{border:1px solid #e5e7eb;border-radius:10px;overflow-x:auto}.dt{border-collapse:collapse;width:100%;font-size:14px}.dt thead th{text-align:left;color:#374151;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:12px 16px;font-weight:600}.dt tbody tr{border-bottom:1px solid #f3f4f6;transition:background .1s}.dt tbody tr:last-child{border-bottom:none}.dt tbody tr:hover{background:#f9fafb}.dt tbody td{color:#374151;vertical-align:middle;padding:12px 16px}.dt-actions{white-space:nowrap;gap:8px;display:flex}.dt-empty{text-align:center;color:#9ca3af;padding:32px 16px}.dt-loading{text-align:center;color:#6b7280;padding:32px}.modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-header h2{color:#111;margin:0;font-size:18px;font-weight:600}.modal-close{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:18px}.modal-close:hover{background:#f3f4f6}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}
