.sidebar{background:var(--gradient-primary);z-index:1000;width:220px;height:100vh;transition:var(--transition);border-right:1px solid #ffffff0f;flex-direction:column;padding:2rem 1rem;display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #0006}.sidebar-logo{text-align:center;margin-bottom:2.5rem;padding:0 1rem}.nav-logo{filter:brightness(0)invert();opacity:.95;width:100%;max-width:140px;height:auto}.sidebar-menu{flex-direction:column;flex:1;gap:.35rem;list-style:none;display:flex}.sidebar-menu li{border-radius:var(--radius-sm);color:#e2e8f0a6;cursor:pointer;letter-spacing:.01em;transition:var(--transition);align-items:center;gap:11px;padding:11px 14px;font-size:.875rem;font-weight:500;display:flex;position:relative}.sidebar-menu li:hover:not(.active){color:var(--color-text-main);background-color:#ffffff12;transform:translate(4px)}.sidebar-menu li.active{color:#fff;box-shadow:var(--shadow-glow);background-color:#2563eb59;border:1px solid #2563eb66}.sidebar-menu li.active:before{content:"";background:var(--color-primary-bright);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:20%;left:0}.menu-icon{flex-shrink:0;align-items:center;display:flex}.sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;align-items:center;gap:6px;margin-top:1rem;padding-top:1rem;display:flex}.sidebar-footer-label{color:#e2e8f059;text-transform:uppercase;letter-spacing:.08em;font-size:.65rem}.agency-logo{opacity:.4;width:80px;height:auto}.agency-logo:hover{opacity:.75}@media (width<=768px){.sidebar{background:var(--color-bg-card);border-top:1px solid var(--color-border);border-right:none;border-radius:16px 16px 0 0;flex-direction:row;width:100%;height:70px;padding:0 8px;top:auto;bottom:0;left:0;box-shadow:0 -4px 24px #0006}.sidebar-logo,.sidebar-footer{display:none}.sidebar-menu{flex-direction:row;justify-content:space-around;align-items:center;gap:0;width:100%;height:100%}.sidebar-menu li{border-radius:var(--radius-sm);text-align:center;color:var(--color-text-muted);border:none;flex-direction:column;flex:1;justify-content:center;gap:4px;padding:8px 6px;font-size:.65rem}.sidebar-menu li:hover:not(.active){color:var(--color-text-main);background:#2563eb14;transform:none}.sidebar-menu li.active{color:var(--color-primary-bright);box-shadow:none;background:#2563eb2e;border:none}.sidebar-menu li.active:before{display:none}.sidebar-menu li.active:after{content:"";background:var(--color-primary-bright);margin-top:2px;border-radius:50%;width:4px;height:4px;margin-inline:auto;display:block}.menu-icon{justify-content:center}}.dashboard-page{width:100%;max-width:1100px;margin:0 auto;animation:.45s ease-out fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dash-loading{height:60vh;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:.9rem;display:flex}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.dashboard-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.filtro-selector,.fecha-selector{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-main);font-size:.85rem;font-family:var(--font-main);cursor:pointer;transition:var(--transition);outline:none;padding:8px 12px;font-weight:500}.filtro-selector:focus,.fecha-selector:focus{border-color:var(--color-primary-bright);box-shadow:0 0 0 3px #2563eb26}.rango-fechas{align-items:center;gap:8px;display:flex}.rango-sep{color:var(--color-text-muted);font-size:.8rem}.btn-export{color:var(--color-primary-bright);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:#2563eb1f;border:1px solid #2563eb40;align-items:center;gap:6px;padding:8px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.btn-export:hover{box-shadow:var(--shadow-glow);background:#2563eb38}.kpi-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}@media (width<=900px){.kpi-grid{grid-template-columns:1fr 1fr}}@media (width<=540px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:var(--transition);flex-direction:column;gap:4px;padding:1.35rem 1.5rem;display:flex;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-glow);border-color:#2563eb4d;transform:translateY(-2px)}.kpi-card:before{content:"";background:var(--color-border);border-radius:0 3px 3px 0;width:3px;position:absolute;top:15%;bottom:15%;left:0}.kpi-card:nth-child(2):before{background:var(--color-primary-bright)}.kpi-card:nth-child(3):before{background:var(--color-success)}.kpi-highlight{background:var(--gradient-primary);border:none}.kpi-highlight:before{display:none}.kpi-highlight .kpi-label,.kpi-highlight .kpi-sub{color:#ffffffa6}.kpi-highlight .kpi-value{color:#fff}.kpi-icon{border-radius:var(--radius-sm);color:#fff;background:#ffffff26;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:6px;display:flex}.kpi-icon-blue{color:var(--color-primary-bright);background:#2563eb26}.kpi-icon-green{color:var(--color-success);background:#22c55e26}.kpi-label{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);font-size:.72rem;font-weight:600}.kpi-value{color:var(--color-text-heading);font-variant-numeric:tabular-nums;font-size:1.75rem;font-weight:800;line-height:1.1}.kpi-sub{color:var(--color-text-muted);font-size:.75rem}.kpi-badge{border-radius:99px;align-items:center;gap:4px;width:fit-content;margin-top:6px;padding:3px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.badge-up{color:var(--color-success);background:#22c55e1f}.badge-down{color:var(--color-error);background:#dc26261f}.dash-modules{grid-template-columns:2fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}@media (width<=860px){.dash-modules{grid-template-columns:1fr}}.dash-module{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.35rem 1.5rem}.module-header{margin-bottom:1.25rem}.module-header h3{color:var(--color-text-heading);align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.bar-chart{align-items:flex-end;gap:8px;height:140px;display:flex}.bar-col{flex-direction:column;flex:1;align-items:center;gap:6px;height:100%;display:flex}.bar-amount{color:var(--color-text-muted);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.58rem;overflow:hidden}.bar-track{background:#ffffff0a;border-radius:6px 6px 0 0;flex:1;align-items:flex-end;width:100%;display:flex;overflow:hidden}.bar-fill{background:#2563eb73;border-radius:6px 6px 0 0;width:100%;transition:height .8s cubic-bezier(.4,0,.2,1)}.bar-fill-today{background:var(--gradient-primary);box-shadow:0 -4px 12px #2563eb66}.bar-label{color:var(--color-text-muted);text-transform:capitalize;font-size:.68rem}.bar-label-today{color:var(--color-primary-bright);font-weight:700}.cat-list{flex-direction:column;gap:1rem;display:flex}.cat-row{align-items:center;gap:10px;display:flex}.cat-info{align-items:center;gap:6px;min-width:120px;display:flex}.cat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cat-name{color:var(--color-text-muted);white-space:nowrap;font-size:.78rem}.cat-units{color:var(--color-text-muted);margin-left:auto;font-size:.72rem}.cat-bar-track{background:#ffffff0f;border-radius:99px;flex:1;height:6px;overflow:hidden}.cat-bar-fill{border-radius:99px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.cat-pct{color:var(--color-text-muted);text-align:right;min-width:32px;font-size:.72rem;font-weight:700}@media print{.no-print,.sidebar{display:none!important}.page-container{width:100%!important;margin-left:0!important;padding:0!important}.kpi-card,.dash-module,.card{box-shadow:none!important;color:#000!important;background:#fff!important;border:1px solid #ddd!important}.kpi-highlight{color:#fff!important;background:#1e3a5f!important}.bar-fill{-webkit-print-color-adjust:exact;print-color-adjust:exact}.only-print{display:block!important}}.print-footer{color:#666;text-align:center;border-top:1px solid #ddd;margin-top:2rem;padding-top:1rem;font-size:.75rem}.ventas-loading{height:60vh;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:.9rem;display:flex}.loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary-bright);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ventas-form{max-width:640px}.ventas-row{grid-template-columns:2fr 1fr}@media (width<=480px){.ventas-row{grid-template-columns:1fr}}.field-hint{margin-top:5px;font-size:.78rem;font-weight:500;display:block}.field-hint.error{color:var(--color-error)}.field-hint.success{color:var(--color-success)}.form-summary{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#0f172a99;margin:1.25rem 0;padding:1.25rem 1.5rem}.summary-item{color:var(--color-text-muted);justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem;display:flex}.summary-item strong{color:var(--color-text-main)}.summary-item.highlight{border-top:1px dashed var(--color-border);color:var(--color-text-heading);margin-top:.75rem;padding-top:.75rem;font-size:1.1rem}.summary-item.highlight strong{color:var(--color-success);font-size:1.4rem;font-weight:800}.btn-full{justify-content:center;width:100%;padding:12px 20px;font-size:.95rem}.btn-full:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}.table-title{align-items:center;gap:8px;display:flex}.table-count{color:var(--color-primary-bright);background:#2563eb1f;border-radius:99px;margin-left:auto;padding:2px 10px;font-size:.72rem;font-weight:600}.hora-badge{color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-size:.75rem;font-weight:600}.table-footer{border-top:1px solid var(--color-border);color:var(--color-text-muted);justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;font-size:.875rem;display:flex}.total-dia{color:var(--color-success);font-size:1.15rem;font-weight:800}.stock-stats{cursor:pointer;grid-template-columns:repeat(3,1fr)}.stat-clickable{cursor:pointer}.stat-active-success{border-color:#22c55e80!important;box-shadow:0 0 16px #22c55e26!important}.stat-active-warning{border-color:#f59e0b80!important;box-shadow:0 0 16px #f59e0b26!important}.stat-active-error{border-color:#dc262680!important;box-shadow:0 0 16px #dc262626!important}.filtro-activo{color:var(--color-text-muted);align-items:center;gap:10px;margin-bottom:1rem;font-size:.8rem;display:flex}.filtro-activo strong{color:var(--color-text-main)}.filtro-clear{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:var(--transition);background:#ffffff0f;border-radius:99px;padding:3px 10px;font-size:.75rem}.filtro-clear:hover{color:var(--color-error);background:#dc26261a;border-color:#dc26264d}.stock-cell{flex-direction:column;gap:5px;min-width:80px;display:flex}.stock-num{font-variant-numeric:tabular-nums;font-size:.95rem;font-weight:700}.estado-success{color:var(--color-success)}.estado-warning{color:var(--color-warning)}.estado-error{color:var(--color-error)}.stock-bar-track{background:#ffffff12;border-radius:99px;width:100%;height:4px;overflow:hidden}.stock-bar-fill{border-radius:99px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.fill-success{background:var(--color-success)}.fill-warning{background:var(--color-warning)}.fill-error{background:var(--color-error)}.estado-badge-stock{white-space:nowrap;border-radius:99px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.color-success{color:var(--color-success);background:#22c55e1f}.color-warning{color:var(--color-warning);background:#f59e0b1f}.color-error{color:var(--color-error);background:#dc26261f}.btn-reponer{color:var(--color-primary-bright);cursor:pointer;transition:var(--transition);white-space:nowrap;background:#2563eb1f;border:1px solid #2563eb40;border-radius:99px;align-items:center;gap:5px;padding:5px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.btn-reponer:hover{box-shadow:var(--shadow-glow);background:#2563eb38;transform:translateY(-1px)}@media (width<=600px){.stock-stats{grid-template-columns:1fr}.data-table th:nth-child(3),.data-table td:nth-child(3),.data-table th:nth-child(5),.data-table td:nth-child(5){display:none}}:root{--color-primary:#1e3a5f;--color-primary-bright:#2563eb;--color-primary-hover:#1d4ed8;--color-success:#22c55e;--color-error:#dc2626;--color-warning:#f59e0b;--color-bg-main:#0f172a;--color-bg-card:#1e293b;--color-bg-hover:#263348;--color-border:#334155;--color-text-main:#e2e8f0;--color-text-muted:#94a3b8;--color-text-heading:#f8fafc;--gradient-primary:linear-gradient(135deg, #1e3a5f, #2563eb);--gradient-success:linear-gradient(135deg, #166534, #22c55e);--gradient-card:linear-gradient(145deg, #1e293b, #162032);--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 10px 25px #0006;--shadow-glow:0 0 20px #2563eb40;--transition:all .25s cubic-bezier(.4, 0, .2, 1);--font-main:"Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100vw;overflow-x:hidden}body{background-color:var(--color-bg-main);color:var(--color-text-main);font-family:var(--font-main);-webkit-font-smoothing:antialiased;line-height:1.5}.page-container{width:100%;transition:var(--transition);flex-grow:1;padding:1rem}@media (width<=768px){body{padding-bottom:90px;padding-left:0!important}.page-container{overflow-x:hidden;width:100%!important;margin-left:0!important;padding:1rem!important}}@media (width>=769px){.page-container{width:calc(100% - 260px);margin-left:220px;padding:2rem}}.card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);width:100%;transition:var(--transition);padding:1.5rem}.card:hover{box-shadow:var(--shadow-glow);border-color:#2563eb66;transform:translateY(-1px)}h2{color:var(--color-text-heading);margin-bottom:.5rem;font-size:1.5rem;font-weight:700}p{color:var(--color-text-muted);font-size:.95rem}button{cursor:pointer;transition:var(--transition);border:none;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-bg-main)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-bright)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;display:flex}.page-header h2{margin-bottom:.25rem}.header-badge{color:var(--color-primary-bright);white-space:nowrap;background:#2563eb26;border:1px solid #2563eb4d;border-radius:99px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;display:flex}.demo-banner{color:var(--color-warning);border-radius:var(--radius-sm);background:#f59e0b1a;border:1px solid #f59e0b4d;align-items:center;gap:8px;margin-bottom:1.25rem;padding:10px 16px;font-size:.8rem;font-weight:500;display:flex}.demo-toast{color:var(--color-success);border-radius:var(--radius-sm);background:#22c55e1f;border:1px solid #22c55e4d;margin-bottom:1.25rem;padding:10px 16px;font-size:.82rem;font-weight:500;animation:.3s fadeInDown}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.form-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.5rem}.form-title{color:var(--color-text-heading);align-items:center;gap:8px;margin-bottom:1.25rem;font-size:.95rem;font-weight:600;display:flex}.form-group{flex-direction:column;gap:6px;margin-bottom:1rem;display:flex}.form-group label{color:var(--color-text-muted);letter-spacing:.02em;font-size:.8rem;font-weight:500}.form-group input{background:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-main);font-size:.9rem;font-family:var(--font-main);transition:var(--transition);outline:none;padding:10px 14px}.form-group input:focus{border-color:var(--color-primary-bright);box-shadow:0 0 0 3px #2563eb26}.form-group input::placeholder{color:var(--color-text-muted);opacity:.6}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=600px){.form-row{grid-template-columns:1fr}}.btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:8px;margin-top:.5rem;padding:10px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary:hover{opacity:.88;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.table-card{padding:1.5rem}.table-title{color:var(--color-text-heading);margin-bottom:1rem;font-size:.95rem;font-weight:600}.table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead tr{border-bottom:1px solid var(--color-border)}.data-table th{text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;font-size:.75rem;font-weight:600;display:table-cell}.data-table th svg{vertical-align:middle;margin-right:4px;display:inline}.data-table tbody tr{transition:var(--transition);border-bottom:1px solid #33415580}.data-table tbody tr:hover{background:#2563eb0d}.data-table td{padding:12px 14px}.id-badge{color:var(--color-primary-bright);background:#2563eb1f;border-radius:99px;padding:3px 8px;font-size:.75rem;font-weight:700}.td-nombre{color:var(--color-text-heading);font-weight:500}.td-muted{color:var(--color-text-muted)}.stats-row{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}@media (width<=600px){.stats-row{grid-template-columns:1fr}}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:var(--transition);align-items:center;gap:1rem;padding:1.1rem 1.25rem;display:flex}.stat-card:hover{box-shadow:var(--shadow-glow);border-color:#2563eb59;transform:translateY(-1px)}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.stat-label{color:var(--color-text-muted);margin-bottom:2px;font-size:.75rem}.stat-value{color:var(--color-text-heading);font-size:1.15rem;font-weight:700}.form-group select{background:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-main);font-size:.9rem;font-family:var(--font-main);transition:var(--transition);cursor:pointer;outline:none;width:100%;padding:10px 14px}.form-group select:focus{border-color:var(--color-primary-bright);box-shadow:0 0 0 3px #2563eb26}.tipo-badge{letter-spacing:.02em;border-radius:99px;padding:3px 10px;font-size:.72rem;font-weight:600}.td-precio{color:var(--color-success);font-variant-numeric:tabular-nums;font-weight:600}.estado-badge{border-radius:99px;padding:3px 10px;font-size:.72rem;font-weight:600}.estado-badge.activo{color:var(--color-success);background:#22c55e1f}.estado-badge.inactivo{color:var(--color-error);background:#dc26261f}
