.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#1f2937;color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-brand{padding:1rem;border-bottom:1px solid #374151;background:#fff;display:flex;justify-content:center}.sidebar-nav{flex:1;padding:.75rem .5rem;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .85rem;border-radius:8px;color:#9ca3af;text-decoration:none;font-size:.88rem;transition:all .15s}.nav-item:hover{background:#374151;color:#e5e7eb}.nav-item.active{background:#a87154;color:#fff}.nav-icon{font-size:1.05rem;width:22px;text-align:center}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid #374151}.user-info{margin-bottom:.75rem}.user-name{font-weight:600;font-size:.9rem;color:#e5e7eb}.user-meta{display:flex;align-items:center;gap:.5rem;margin-top:.3rem}.role-badge{font-size:.7rem;padding:.15rem .5rem;border-radius:9999px;font-weight:600;text-transform:capitalize}.role-admin{background:#a87154;color:#fff}.role-comprador{background:#34d399;color:#064e3b}.role-receptor{background:#08c;color:#fff}.almacen-label{font-size:.72rem;color:#6b7280}.logout-btn{width:100%;padding:.5rem;background:transparent;border:1px solid #4b5563;color:#9ca3af;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#374151;color:#e5e7eb;border-color:#6b7280}.main-content{flex:1;margin-left:240px;padding:2rem;background:var(--gray-50);min-height:100vh}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;color:var(--gray-900);font-weight:700}.page-header p{color:var(--gray-600);font-size:.9rem;margin-top:.25rem}.card{background:#fff;border:1px solid var(--gray-200);border-radius:12px;padding:1.5rem;margin-bottom:1.25rem}.card-title{font-size:.85rem;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border:1px solid var(--gray-200);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between}.stat-card .stat-label{font-size:.8rem;color:var(--gray-600);font-weight:500;min-height:2.4em}.stat-card .stat-value{font-size:1.8rem;font-weight:800;color:var(--gray-900);margin-top:.25rem}.stat-card .stat-sub{font-size:.75rem;color:#9ca3af;margin-top:.15rem}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th{text-align:left;padding:.65rem .75rem;background:var(--gray-50);color:var(--gray-600);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--gray-200)}.data-table td{padding:.6rem .75rem;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}.data-table tr:hover{background:var(--gray-50)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.72rem;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.badge-neutral{background:var(--gray-100);color:var(--gray-700)}.trend-up{color:#059669}.trend-down{color:#dc2626}.trend-flat{color:var(--gray-600)}.form-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:1.25rem}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field label{font-size:.8rem;font-weight:600;color:var(--gray-800)}.form-field select,.form-field input{padding:.55rem .75rem;border:1.5px solid var(--gray-300);border-radius:6px;font-size:.88rem;outline:none}.form-field select:focus,.form-field input:focus{border-color:#a87154;box-shadow:0 0 0 3px #a8715426}.btn{padding:.55rem 1.25rem;border-radius:6px;font-size:.88rem;font-weight:600;border:none;cursor:pointer;transition:all .15s}.btn-primary{background:#a87154;color:#fff}.btn-primary:hover{background:#7d4e39}.btn-secondary{background:var(--gray-100);color:var(--gray-800);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-200)}.btn-success{background:#059669;color:#fff}.btn-success:hover{background:#047857}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.empty-state{text-align:center;padding:3rem 1rem;color:#9ca3af}.empty-state .empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state p{font-size:.95rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1f2937,#111827);padding:1rem}.login-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.8rem;color:#a87154;margin-bottom:.25rem}.login-header p{color:#777;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.85rem;font-weight:600;color:#333}.form-group input{padding:.7rem .9rem;border:1.5px solid #ccc;border-radius:8px;font-size:.95rem;transition:border-color .2s;outline:none}.form-group input:focus{border-color:#a87154;box-shadow:0 0 0 3px #a8715426}.login-error{background:#fef2f2;color:#dc2626;padding:.6rem .9rem;border-radius:8px;font-size:.85rem;border:1px solid #fecaca}.login-btn{background:#a87154;color:#fff;border:none;padding:.75rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.login-btn:hover{background:#7d4e39}.login-demo{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e1e1e1}.login-demo>p{font-size:.8rem;color:#777;margin-bottom:.5rem;font-weight:600}.login-demo table{width:100%;font-size:.75rem;border-collapse:collapse}.login-demo th,.login-demo td{text-align:left;padding:.3rem .5rem;border-bottom:1px solid #f5f5f5}.login-demo th{color:#777;font-weight:600}.login-demo td{color:#333;font-family:monospace}.traspasos-page{padding:1.5rem;max-width:1200px}.traspasos-page h2{margin-bottom:1rem}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e5e7eb;padding-bottom:0}.tabs button{padding:.5rem 1rem;border:none;background:none;cursor:pointer;color:#6b7280;font-size:.9rem;border-bottom:2px solid transparent;margin-bottom:-2px;position:relative}.tabs button.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.tabs .badge{background:#ef4444;color:#fff;font-size:.7rem;padding:.1rem .4rem;border-radius:9999px;margin-left:.4rem}.section{margin-bottom:2rem}.section h3{margin-bottom:1rem}.filters-row{display:flex;gap:1rem;margin-bottom:1rem;align-items:center}.filters-row label{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.filters-row select{padding:.3rem .5rem;border-radius:4px;border:1px solid #d1d5db}.actions-row{display:flex;gap:.5rem;margin-bottom:1rem}.actions-row button{padding:.4rem .8rem;font-size:.85rem;border:1px solid #d1d5db;background:#f9fafb;border-radius:4px;cursor:pointer}.actions-row button:hover{background:#f3f4f6}.traspasos-table{width:100%;border-collapse:collapse;font-size:.9rem;margin-bottom:1rem}.traspasos-table th,.traspasos-table td{padding:.5rem;text-align:left;border-bottom:1px solid #e5e7eb}.traspasos-table th{background:#f9fafb;font-weight:600;font-size:.8rem;color:#6b7280;text-transform:uppercase}.traspasos-table tr.selected{background:#eff6ff}.traspasos-table select,.traspasos-table input[type=number]{padding:.3rem .4rem;border:1px solid #d1d5db;border-radius:4px;width:100%;min-width:60px}.btn-remove{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1rem;padding:.2rem .4rem}.btn-primary{padding:.6rem 1.5rem;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;margin-top:.5rem}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-danger{padding:.3rem .6rem;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:4px;cursor:pointer;font-size:.8rem;margin-left:.3rem}.summary{margin:.5rem 0;font-size:.9rem;color:#374151}.notas-row{margin:.5rem 0}.notas-row label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem}.notas-row textarea{padding:.4rem;border:1px solid #d1d5db;border-radius:4px;resize:vertical}.success-msg{margin-top:.5rem;padding:.5rem 1rem;background:#d1fae5;color:#065f46;border-radius:6px;font-size:.9rem}.empty{color:#9ca3af;font-style:italic}.confirm-form{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.confirm-form h4{margin-bottom:.5rem}.notas-emisor{margin-bottom:.75rem;padding:.5rem;background:#fef3c7;border-radius:4px;font-size:.85rem}.hint{font-size:.75rem;color:#f59e0b;margin-top:.2rem}.inner-table{width:100%;border-collapse:collapse;margin:.5rem 0;font-size:.85rem}.inner-table th,.inner-table td{padding:.3rem .5rem;border-bottom:1px solid #f3f4f6}.inner-table th{background:#f3f4f6}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#9ca3af}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-50: #faf6f3;--brand-100: #f0e6de;--brand-200: #e0c9b8;--brand-300: #c9a48a;--brand-400: #b8876a;--brand-500: #A87154;--brand-600: #965f45;--brand-700: #7d4e39;--brand-800: #5e3a2b;--brand-900: #3f271d;--accent: #0088cc;--gray-50: #fbfbfb;--gray-100: #f5f5f5;--gray-200: #e1e1e1;--gray-300: #ccc;--gray-600: #777;--gray-700: #555;--gray-800: #333;--gray-900: #161616}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:var(--gray-800);background:var(--gray-50);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--brand-500);text-decoration:none}a:hover{color:var(--brand-700)}
