.main-sidebar{width:230px;min-height:100vh;background:#0d111c;padding-top:20px;border-right:1px solid #1b2236}.sidebar-nav ul{list-style:none;margin:0;padding:0}.sidebar-nav li{margin-bottom:6px}.sidebar-nav a{display:block;padding:10px 18px;color:#c5cbe3;text-decoration:none;font-size:14px;border-left:3px solid transparent;transition:.2s}.sidebar-nav a:hover,.sidebar-nav a.active{background:#1b2236;border-left:3px solid #3b82f6;color:#fff}.tree-parent>.tree-title{padding:10px 18px;display:block;color:#aeb7cf;cursor:pointer}.tree-children{padding-left:20px;margin-bottom:10px}.header{width:100%;height:60px;background:#0e121f;padding:0 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #1b2236}.header-title{color:#fff;font-size:20px;font-weight:600}.header-right{display:flex;align-items:center;gap:20px}.header-user{color:#aeb7cf;font-size:14px}.logout-btn{background:#e74c3c;border:none;padding:7px 14px;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;transition:.2s}.logout-btn:hover{background:#c0392b}.app-wrapper{min-height:100vh;display:flex;flex-direction:column;background:#0f172a;color:#fff}.app-body{display:flex;flex:1}.app-content{flex:1;padding:25px;background:#0f172a;color:#fff;overflow-x:auto}header{background:#020617;padding:15px 30px;border-bottom:1px solid #1e293b}footer{background:#020617;padding:15px;text-align:center;border-top:1px solid #1e293b;font-size:13px;color:#94a3b8}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:#2563eb;border-radius:10px}::-webkit-scrollbar-track{background:#020617}@media(max-width:768px){.main-sidebar{display:none}.app-content{padding:15px}}*{box-sizing:border-box;font-family:Segoe UI,Arial,sans-serif}#back{position:fixed;inset:0;background:linear-gradient(135deg,#0f172a,#020617);z-index:-1}.login-box{width:360px;background:#020617;color:#fff;padding:30px;border-radius:14px;margin:8% auto;box-shadow:0 10px 40px #0009}.login-logo{text-align:center}.login-logo img{max-width:150px}.login-box-msg{text-align:center;font-size:18px;margin:25px 0;font-weight:500;color:#c7d2fe}.form-group{margin-bottom:18px}.form-control{width:100%;padding:12px 15px;border-radius:8px;border:1px solid #1e293b;background:#0f172a;color:#e0e7ff;font-size:15px}.form-control::placeholder{color:#94a3b8}.form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.btn-primary{width:100%;padding:12px;background:#2563eb;border:none;border-radius:8px;color:#fff;font-size:15px;cursor:pointer;transition:.2s}.btn-primary:hover{background:#1d4ed8}@media(max-width:450px){.login-box{width:90%;margin-top:40%}}.dashboard{padding:20px;color:#e5ebff}.dashboard-title{font-size:26px;margin-bottom:20px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.stat-card{padding:20px;border-radius:12px;background:#0e1424;box-shadow:0 0 12px #00000080;display:flex;flex-direction:column;justify-content:space-between}.stat-card h3{font-size:16px;opacity:.7}.stat-card p{font-size:26px;font-weight:700}.blue{border-left:4px solid #3b82f6}.green{border-left:4px solid #10b981}.yellow{border-left:4px solid #f59e0b}.red{border-left:4px solid #ef4444}.chart-section,.last-section{background:#0e1424;padding:20px;border-radius:12px;margin-bottom:25px}.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-bottom:20px}.dashboard .box{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:14px 16px}.dashboard .box h2{font-size:16px;margin:0 0 10px}.dashboard .ranking{list-style:none;margin:0;padding:0}.dashboard .ranking li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.dashboard .ranking li:last-child{border-bottom:none}.fake-chart{height:220px;display:flex;align-items:center;justify-content:center;color:#64748b;border:1px dashed #1e293b;margin-top:10px}.last-box{height:150px;display:flex;align-items:center;justify-content:center;color:#64748b;border:1px dashed #1e293b;margin-top:10px}.reportes-container{padding:20px;color:var(--text)}.reportes-container .title{font-size:24px;font-weight:600;margin-bottom:20px}.report-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:24px}.report-card{border-radius:8px;padding:16px 18px;color:#fff;box-shadow:0 2px 4px #00000014}.report-card h4{font-size:14px;margin:0 0 4px;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.report-card h2{font-size:22px;margin:0}.card-sub{margin-top:6px;font-size:11px;opacity:.85}.report-card.blue{background:linear-gradient(135deg,#2196f3,#1976d2)}.report-card.green{background:linear-gradient(135deg,#4caf50,#2e7d32)}.report-card.orange{background:linear-gradient(135deg,#ff9800,#f57c00)}.report-card.red{background:linear-gradient(135deg,#f44336,#d32f2f)}.report-card.purple{background:linear-gradient(135deg,#7e57c2,#512da8)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;align-items:stretch;grid-auto-rows:1fr;margin-bottom:24px}.chart-box{background:var(--bg-panel);color:var(--text);border-radius:10px;border:1px solid var(--border);padding:0;box-shadow:0 6px 18px #00000029;display:flex;flex-direction:column}.chart-box h3{font-size:15px;margin:0;padding:12px 14px;border-bottom:1px solid var(--border)}.chart-placeholder{border:1px dashed var(--border);border-radius:8px;margin:14px;padding:24px 12px;text-align:center;color:var(--text-muted);font-size:13px;background:var(--bg-panel-2);min-height:240px;display:flex;align-items:center;justify-content:center}.chart-hint{display:block;margin-top:6px;font-size:11px;color:var(--text-muted)}.chart-toolbar{display:flex;gap:8px;padding:10px 14px 0}@media(max-width:768px){.chart-placeholder{min-height:200px}}.last-sales{background:var(--bg-panel);color:var(--text);border-radius:10px;border:1px solid var(--border);padding:14px 16px 16px;box-shadow:0 6px 18px #00000029}.last-sales h3{font-size:16px;margin:0 0 12px}.report-table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:10px;max-height:65vh;background:var(--bg-panel-2);box-shadow:0 10px 24px #00000040}.report-table{width:100%;border-collapse:collapse;font-size:13px;color:var(--text);margin:0;background:var(--bg-panel-2)}.report-table thead{background:var(--bg-panel)}.report-table thead th{position:sticky;top:0;background:var(--bg-panel)!important;color:var(--text)!important;z-index:1;border-bottom:1px solid var(--border)!important;padding:8px;text-align:left}.report-table tbody td{border-bottom:1px solid var(--border)!important;padding:6px 8px;color:var(--text)!important}.report-table tbody tr:nth-child(odd){background:var(--bg-panel)!important}.report-table tbody tr:nth-child(2n){background:var(--bg-panel-2)!important}.report-table tbody tr:hover{background:#0e1424}.report-table td.col-money,.report-table th.col-money{text-align:right}.report-table td.col-date,.report-table th.col-date{white-space:nowrap}.last-sales table{width:100%;border-collapse:collapse;font-size:13px;color:var(--text)!important;margin:0;background:var(--bg-panel-2)!important}.last-sales thead th{background:var(--bg-panel);color:var(--text)!important;border-bottom:1px solid var(--border)!important;padding:8px;text-align:left}.last-sales tbody td{border-bottom:1px solid var(--border)!important;padding:6px 8px;color:var(--text)!important}.last-sales tbody tr:nth-child(odd){background:var(--bg-panel)!important}.last-sales tbody tr:nth-child(2n){background:var(--bg-panel-2)!important}.last-sales tbody tr:hover{background:#0e1424}.last-sales td.col-money,.last-sales th.col-money{text-align:right}.last-sales td.col-date,.last-sales th.col-date{white-space:nowrap}.last-sales thead th{background:#f5f5f5;border-bottom:1px solid #e0e0e0;padding:8px;text-align:left;font-weight:600}.last-sales tbody td{border-bottom:1px solid #eee;padding:6px 8px}.last-sales tbody tr:last-child td{border-bottom:none}.table-wrapper{background:var(--bg-panel);padding:15px;border-radius:16px;border:1px solid var(--border);box-shadow:0 10px 25px #00000059;overflow-x:auto}.datatable{width:100%;border-collapse:collapse;min-width:900px;color:var(--text);font-size:14px}.datatable thead{background:var(--bg-panel-2)}.datatable th{padding:14px 12px;text-align:left;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border)}.datatable td{padding:14px 12px;border-bottom:1px solid var(--border)}.datatable tbody tr:hover{background:#3b82f614}.table-wrapper .btn-group .btn{margin-right:5px;border-radius:6px;padding:6px 10px}.table-wrapper .btn-warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.35);color:var(--warning)}.table-wrapper .btn-danger{background:#ef444426;border:1px solid rgba(239,68,68,.35);color:var(--danger)}.table-wrapper .btn-warning:hover,.table-wrapper .btn-danger:hover{opacity:.9;transform:translateY(-1px)}.table-wrapper .btn-group .btn:active{transform:translateY(1px)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(59,130,246,.25);border-top-color:var(--accent);animation:spin .9s linear infinite}.spinner-muted{border-color:#aeb7cf33;border-top-color:var(--text-muted)}.spinner-overlay{position:fixed;inset:0;background:#02061799;display:flex;align-items:center;justify-content:center;z-index:1000}.spinner-box{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 10px 30px #0006}.spinner-text{color:var(--text-muted);font-size:14px}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:modal-fade .18s ease-out}.modal-window,.modal-box{background:var(--bg-panel);border:1px solid var(--border);border-radius:14px;width:100%;max-width:620px;padding:22px;box-shadow:0 16px 50px #0000008c;color:var(--text);transform:translateY(4px) scale(.98);animation:modal-pop .18s ease-out forwards}.modal-box.modal-sm{max-width:420px}.modal-box.modal-lg{max-width:920px}.modal-box.modal-xl{max-width:1200px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border)}.modal-header h3,.modal-header .modal-title{margin:0}.modal-close,.close-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-panel-2);border:1px solid var(--border);border-radius:9999px;font-size:18px;color:var(--text-muted);cursor:pointer;transition:.15s ease}.modal-close:hover,.close-btn:hover{background:var(--bg-panel);border-color:var(--accent);color:var(--text);box-shadow:0 6px 18px #2563eb1f;transform:translateY(-1px)}.modal-close:focus-visible,.close-btn:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-actions button{padding:10px 18px;border-radius:8px}.modal-actions .btn-cancel{background:var(--bg-panel-2);color:var(--text);border:1px solid var(--border);cursor:pointer}.modal-body{max-height:calc(90vh - 120px);overflow:auto}.modal-box .form-group{margin-bottom:14px}.modal-box .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-box .form-row .half{width:100%}@media(max-width:768px){.modal-box{width:calc(100% - 24px);padding:18px}.modal-box.modal-lg,.modal-box.modal-xl{max-width:calc(100% - 24px)}.modal-body{max-height:calc(90vh - 100px)}.modal-box .form-row{grid-template-columns:1fr}}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{to{transform:translateY(0) scale(1)}}.form-vertical{display:flex;flex-direction:column;gap:16px;color:#e5e7eb}.form-row{display:flex;gap:15px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.half{flex:1}.form-group label{font-size:14px;color:#9ca3af}.form-control{padding:10px 12px;border-radius:10px;border:1px solid #1f2937;background:#111827;color:#e5e7eb;outline:none;transition:.2s ease}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.form-control:disabled{background:#0f172a;color:#64748b}.input-group{display:flex;align-items:center}.input-group input{flex:1}.input-group-addon{padding:10px 14px;background:#1f2933;border-radius:0 10px 10px 0;border:1px solid #1f2937;border-left:none;color:#60a5fa}.form-group input[type=checkbox]{margin-right:6px;accent-color:#3b82f6}.text-right{display:flex;justify-content:flex-end}.btn-primary{padding:10px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-weight:600;cursor:pointer;transition:.2s ease}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 20px #3b82f640}.producto-card{border:1px solid #e8eef7;border-radius:10px;background:var(--bg-panel);color:var(--text);padding:14px;text-align:center;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;box-shadow:0 10px 24px #1e293b0f}.producto-card:hover{border-color:#d8e5ff;box-shadow:0 16px 36px #1e293b1f;transform:translateY(-2px)}.producto-img{width:100%;height:140px;object-fit:contain;margin-bottom:8px}.producto-title{font-size:16px;font-weight:600;margin:5px 0}.producto-categoria{font-size:13px;color:var(--text-muted);margin-bottom:6px}.stock-tag{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:3px 8px;border-radius:999px;font-size:12px;display:inline-block;margin-bottom:10px}.precio{font-size:20px;font-weight:700;color:#3c8dbc;margin-bottom:12px}.acciones{display:flex;justify-content:center;gap:8px}.productos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin-top:15px}.vista-switch{float:right;display:flex;gap:10px}.box-body{margin:25px 15px 15px;padding:10px}.clientes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.cliente-card{border:1px solid var(--border);border-radius:10px;background:var(--bg-panel);color:var(--text);padding:12px 14px;display:flex;flex-direction:column;min-height:150px;transition:.2s ease}.cliente-card:hover{border-color:var(--accent);box-shadow:0 8px 24px #2563eb26;transform:translateY(-2px)}.cliente-card-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.cliente-card-header h4{font-size:15px;font-weight:600;margin:0}.cliente-rut{font-size:12px;color:var(--text-muted)}.cliente-card-body p{margin:2px 0;font-size:13px;color:var(--text-muted)}.cliente-card-body i{width:16px}.cliente-observacion{margin-top:4px;font-style:italic;color:var(--text-muted)}.cliente-card-footer{margin-top:8px;padding-top:6px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.cliente-fecha{font-size:11px;color:var(--text-muted)}.cliente-card-footer .btn-group .btn{padding:2px 6px}.cliente-card-footer .btn-group .btn.edit-btn{background:#3b82f6;color:#fff}.cliente-card-footer .btn-group .btn.delete-btn{background:#ef4444;color:#fff}.cliente-form{padding:5px}.cliente-form .form-group{margin-bottom:12px}.cliente-form label{font-weight:600;margin-bottom:4px;display:block}.cliente-form textarea{resize:vertical}.text-right{text-align:right;margin-top:10px}.button-group .btn{min-width:120px}.clientes-header-actions{display:flex;gap:10px}.btn-secondary.active{outline:2px solid #2956ff}.clientes-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:20px}.cliente-card{background:linear-gradient(160deg,#040b1f,#020714);border-radius:18px;padding:18px;box-shadow:0 8px 30px #000000b3;border:1px solid #10172f;display:flex;flex-direction:column;gap:14px;transition:.3s}.cliente-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #000000e6}.cliente-header-card{display:flex;align-items:center;gap:12px}.avatar{width:45px;height:45px;border-radius:50%;background:#2956ff;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px}.cliente-header-card h3{margin:0;font-size:16px;color:#fff}.cliente-header-card small{color:#9baedc;font-size:12px}.cliente-info{font-size:14px;color:#bfcfff;display:flex;flex-direction:column;gap:4px}.cliente-actions{display:flex;justify-content:space-between;gap:10px;margin-top:8px}.cliente-actions .btn-action{width:50%;padding:8px;border-radius:8px;border:none;cursor:pointer;color:#000}.cliente-actions .btn-edit{background:#3b82f6}.clientes-header{display:flex;justify-content:space-between;align-items:center}.clientes-header .btn{min-width:150px}.view-switch{display:flex;gap:8px;margin:10px}.ventas-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:12px;box-shadow:0 6px 18px #00000029}.ventas-toolbar-right{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.ventas-search-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.ventas-view-toggle .btn{min-width:90px}.ventas-view-toggle .active-view{background-color:var(--accent);color:#fff;border-color:var(--accent)}.ventas-table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:10px;max-height:65vh;background:var(--bg-panel-2);box-shadow:0 10px 24px #00000040}.tablaVentas{width:100%;margin:0;color:var(--text)}.tablaVentas thead th{position:sticky;top:0;background:var(--bg-panel);color:var(--text);z-index:1;border-bottom:1px solid var(--border)}.tablaVentas tbody tr:nth-child(odd){background:var(--bg-panel)}.tablaVentas tbody tr:nth-child(2n){background:var(--bg-panel-2)}.tablaVentas tbody tr:hover{background:#0e1424}.tablaVentas td,.tablaVentas th{vertical-align:middle;border-color:var(--border)}.tablaVentas td.col-money,.tablaVentas th.col-money{text-align:right}.tablaVentas td.col-date,.tablaVentas th.col-date,.tablaVentas td.col-actions{white-space:nowrap}.ventas-actions{display:inline-flex;gap:6px}.ventas-actions .btn{opacity:.9}.tablaVentas tbody tr:hover .ventas-actions .btn{opacity:1}.tablaVentas.dense th,.tablaVentas.dense td{padding:6px 8px;font-size:12px}.ventas-density-select{min-width:120px}.ventas-summary{display:flex;justify-content:flex-end;gap:18px;padding:10px 12px;border-top:1px solid var(--border);background:var(--bg-panel)}.ventas-summary .sum-item{display:flex;align-items:center;gap:8px;color:var(--text-muted)}.ventas-summary .sum-item strong{color:var(--text)}.ventas-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.venta-card{background:var(--bg-panel);color:var(--text);border-radius:10px;border:1px solid var(--border);display:flex;flex-direction:column;min-height:180px;box-shadow:0 10px 24px #00000059;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.venta-card:hover{transform:translateY(-2px);box-shadow:0 16px 36px #00000080;border-color:#2a3a5f}.venta-card-header{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,var(--bg-panel) 0%,var(--bg-panel-2) 100%)}.venta-card-label{font-size:11px;text-transform:uppercase;color:#999;display:block;letter-spacing:.5px}.venta-card-header h4{margin:0;font-size:16px}.venta-card-date{font-size:12px;color:var(--text-muted)}.venta-card-body{padding:10px 12px;font-size:13px}.venta-card-row{display:flex;justify-content:space-between;margin-bottom:4px;gap:10px}.venta-card-field{color:var(--text-muted);font-size:12px}.venta-card-value{font-weight:500;text-align:right}.chip{font-size:12px;padding:3px 8px;border-radius:999px;border:1px solid #e5e7eb;background:#f9fafb;color:#374151}.chip-efectivo{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.chip-credito{background:#eff6ff;color:#1e3a8a;border-color:#bfdbfe}.chip-debito{background:#f5f3ff;color:#5b21b6;border-color:#ddd6fe}.chip-transferencia{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.chip-combinado{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.venta-card-totales{margin-top:8px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;font-size:12px}.venta-card-totales>div{display:flex;flex-direction:column;align-items:flex-end}.venta-card-total strong{font-size:14px;color:#3c8dbc}.venta-card-footer{padding:8px 10px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:4px;background:var(--bg-panel)}.ventas-pagination{margin-top:12px;padding:10px 12px;border:1px solid var(--border);background:var(--bg-panel);border-radius:10px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:12px;box-shadow:0 6px 18px #00000029}.ventas-pagination-info{color:var(--text-muted)}.ventas-page-indicator{margin:0 6px;color:var(--text-muted)}@media(max-width:768px){.ventas-toolbar{align-items:flex-start}.ventas-toolbar-right{width:100%;justify-content:space-between}.venta-card-totales{grid-template-columns:repeat(2,minmax(0,1fr))}.ventas-table-wrap{max-height:55vh}}.cart-table-wrapper{margin-bottom:15px}.cart-title{margin-top:0;margin-bottom:10px;font-size:16px;font-weight:600;color:var(--text)}.cart-table .col-num{text-align:right;width:110px;vertical-align:middle}.cart-table .col-actions{width:60px;text-align:center;vertical-align:middle}.cart-empty{text-align:center;color:var(--text-muted);font-style:italic}.qty-input{max-width:80px;margin-left:auto;margin-right:auto;text-align:right}.stock-warning{margin-top:4px;font-size:11px;color:var(--danger)}.row-error{background-color:#ef444414}.product-grid-wrapper{display:flex;flex-direction:column;gap:8px;height:100%}.grid-header h4{margin:0;font-size:16px;font-weight:600}.grid-subtitle{margin:2px 0 8px;font-size:12px;color:var(--text-muted)}.no-products{padding:10px;background:var(--bg-panel);border:1px dashed var(--border);font-size:13px;color:var(--text-muted)}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;max-height:420px;overflow-y:auto;padding-right:4px}.product-card{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);border-radius:10px;display:flex;flex-direction:column;height:100%;box-shadow:0 8px 24px #00000040;transition:box-shadow .15s ease,transform .15s ease,border-color .15s ease}.product-card:hover{transform:translateY(-1px);border-color:var(--accent);box-shadow:0 12px 32px #2563eb26}.product-image{padding:8px;text-align:center;border-bottom:1px solid var(--border)}.product-image img{max-width:100%;max-height:80px;object-fit:contain}.product-body{padding:6px 8px 4px;flex:1;display:flex;flex-direction:column;gap:4px}.product-code{font-size:11px;color:var(--text-muted)}.product-title{font-size:13px;font-weight:600;line-height:1.3;color:var(--text)}.product-category{font-size:11px;color:var(--text-muted)}.product-meta{margin-top:6px;display:flex;justify-content:space-between;align-items:center}.price{font-size:13px;font-weight:700;color:var(--accent-2)}.stock-badge{font-size:11px;padding:2px 6px;border-radius:999px;border:1px solid transparent}.stock-badge.ok{color:#22c55e;border-color:#22c55e59;background:#22c55e1f}.stock-badge.out{color:var(--danger);border-color:#ef444459;background:#ef44441f}.product-footer{padding:6px 8px 8px;border-top:1px solid var(--border)}.product-footer .btn{font-size:12px}.no-stock-badge{background:#e74c3c;color:#fff;padding:3px 6px;font-size:11px;border-radius:4px;margin-left:4px}.buscar-modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;justify-content:center;background:#000000b3;z-index:2000}.buscar-modal{background:#fff;max-width:900px;background:var(--bg-panel);color:var(--text);border:1px solid var(--border);width:85%;max-width:980px;border-radius:14px;padding:20px;animation:fadeIn .2s ease-out;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 16px 50px #0000008c}.buscar-modal from{opacity:0;transform:scale(.95)}.buscar-modal to{opacity:1;transform:scale(1)}.buscar-modal-header{display:flex;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--border);align-items:center;margin-bottom:15px}.close-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-panel-2);border:1px solid var(--border);border-radius:9999px;font-size:18px;color:var(--text-muted);cursor:pointer;transition:.15s ease}.close-btn:hover{background:var(--bg-panel);border-color:var(--accent);color:var(--text);box-shadow:0 6px 18px #2563eb1f;transform:translateY(-1px)}.close-btn:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}color: #555; } .buscar-controls{display:flex;gap:10px;margin-bottom:15px}.buscar-resultado{overflow-y:auto;flex-grow:1}.buscar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}border: 1px solid var(--border); padding: 10px; border-radius: 10px; text-align: center; cursor: pointer; background: var(--bg-panel-2); transition: .16s ease; box-shadow: 0 10px 24px rgba(30,41,59,.06); background: #fafafa; transition: .2s; } background: var(--bg-panel); border-color: #d8e5ff; box-shadow: 0 16px 36px rgba(30,41,59,.12); transform: translateY(-1px); .buscar-card:hover{background:#eef6ff}.buscar-card img{width:100%;height:120px;object-fit:contain}font-weight: bold; color: var(--accent-2); font-weight: bold; color: #1a73e8; } font-size: 12px; color: var(--text-muted); font-size: 12px; color: #797979; } .buscar-card .nombre{margin:8px 0;color:var(--text);font-weight:500;color:#333}color: #fff; } .toggle-view-btn i{margin-right:6px}.modal-bg{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-box{background:var(--bg-panel);color:var(--text);border:1px solid var(--border);width:480px;max-height:80vh;padding:20px;border-radius:14px;box-shadow:0 16px 50px #0000008c;overflow-y:auto}.cliente-lista{margin-top:15px;max-height:300px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;background:var(--bg-panel-2)}.cliente-item{padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;color:var(--text)}.cliente-item:hover{background:#0e1424}.modal-footer{display:flex;justify-content:space-between;margin-top:15px}.crear-venta-header{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin-bottom:15px}.crear-venta-header label{color:var(--text-muted);font-size:13px}.crear-venta-layout{display:flex;gap:18px;align-items:flex-start;flex-wrap:wrap}.crear-venta-col{flex:1;min-width:0}.productos-col{flex:1.4}.detalle-col{flex:1;min-width:320px}.crear-venta-bottom{display:flex;gap:15px;margin-top:15px;flex-wrap:wrap}.crear-venta-nota{flex:1.2;min-width:240px}.crear-venta-totales{flex:1;min-width:220px;border:1px solid var(--border);border-radius:10px;padding:12px 14px;background:var(--bg-panel);color:var(--text);box-shadow:0 8px 24px #00000040}.totales-line{display:flex;align-items:center;justify-content:space-between;font-size:13px;margin-bottom:4px}.totales-line span{color:var(--text-muted)}.totales-line strong{font-weight:700}.totales-total{border-top:1px solid var(--border);padding-top:6px;margin-top:6px;font-size:14px}.totales-total strong{font-size:16px;color:var(--accent-2)}.editar-venta-wrapper{max-width:900px;margin:0 auto}.loading{padding:20px;text-align:center;font-size:18px}.venta-resumen{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-bottom:25px}.res-box{border:1px solid #ddd;padding:12px;border-radius:6px;background:#fafafa}.res-box h4{margin:0 0 5px;font-size:14px;color:#555}.res-box p{margin:0;font-size:16px;font-weight:700}.mt-10{margin-top:10px}.totales{text-align:right;margin-top:20px}.footer-buttons{display:flex;justify-content:space-between;padding:15px}.footer-buttons .btn{min-width:140px}.nota-wrapper{max-width:900px;margin:0 auto}.nota-resumen{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);padding:15px;border-radius:10px;margin-bottom:15px;line-height:1.6;box-shadow:0 8px 24px #00000040}.nota-total{margin:20px 0;text-align:right}.nota-total h3{color:var(--accent-2)}.buttons{display:flex;justify-content:space-between;gap:10px}.loading{text-align:center;padding:20px;font-size:16px;color:var(--text)}.print-area{background:#fff;color:#000;padding:20px;border-radius:10px;border:1px solid #e5e7eb;margin-bottom:20px;font-family:Arial,sans-serif;box-shadow:0 8px 24px #00000026}.print-header{text-align:center;margin-bottom:20px}.print-header h2{margin:0;font-size:22px;font-weight:700}.print-sub{margin:0;font-size:12px;color:#555}.print-info,.print-client{margin-bottom:10px;line-height:1.5}.print-table{width:100%;border-collapse:collapse;margin-top:15px}.print-table th,.print-table td{border:1px solid #000;padding:6px;font-size:13px}.print-totales{margin-top:20px;text-align:right;font-size:14px;line-height:1.5}@media print{body *{visibility:hidden!important}.print-area,.print-area *{visibility:visible!important}.print-area{position:absolute;top:0;left:0;width:100%;padding:0;border:none}.print-table th,.print-table td{border:1px solid #000!important;color:#000!important}.print-header h2{font-size:20px}}.datatable td,.datatable th{vertical-align:middle}.form-vertical .form-group{margin-bottom:15px}textarea.form-control{resize:none}.btn-group .btn{margin-right:4px}.user-card{display:flex;gap:20px;align-items:center;padding:20px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text);border-radius:10px;box-shadow:0 8px 24px #00000040;transition:.2s ease}.user-card:hover{border-color:var(--accent);box-shadow:0 12px 32px #2563eb26;transform:translateY(-1px)}.user-card-img img{width:110px;height:110px;border-radius:100%;object-fit:cover;border:3px solid var(--accent)}.user-card-info h2{margin:0;font-size:22px;font-weight:600}.user-card-info p{margin:4px 0;color:var(--text-muted)}.perfil-rol i,.perfil-usuario i,.perfil-fecha i{margin-right:5px}.user-card-actions{margin-top:15px}@media(max-width:600px){.user-card{flex-direction:column;text-align:center}}.password-form .form-group{margin-bottom:15px}.password-form input{height:40px}.perfil-wrapper{max-width:900px;margin:0 auto;padding:20px}.perfil-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.perfil-box{background:var(--bg-panel);color:var(--text);border-radius:10px;border:1px solid var(--border);padding:20px;box-shadow:0 10px 25px #00000059}.perfil-header{display:flex;align-items:center;gap:20px;border-bottom:1px solid var(--border);padding-bottom:20px;margin-bottom:25px}.perfil-header img{width:120px;height:120px;object-fit:cover;border-radius:50%;border:2px solid var(--accent)}.perfil-info{flex-grow:1}.perfil-info h2{margin:0;font-size:28px;font-weight:600}.perfil-info p{margin:4px 0;color:var(--text-muted);font-size:14px}.perfil-form{margin-top:10px}.perfil-form .form-group{margin-bottom:18px}.perfil-form label{font-weight:600;margin-bottom:5px;display:block}.perfil-form input{font-size:14px}.perfil-buttons{display:flex;justify-content:flex-end;gap:10px;padding-top:15px;border-top:1px solid var(--border)}.btn-guardar{background:var(--accent);border:1px solid var(--accent);color:#fff}.btn-guardar:hover{background:var(--accent-2);border-color:var(--accent-2)}.btn-cancelar{background:var(--bg-panel-2);color:var(--text);border:1px solid var(--border)}.btn-cancelar:hover{border-color:var(--accent)}.perfil-password-box{background:var(--bg-panel);color:var(--text);padding:16px;border-radius:10px;border:1px solid var(--border);margin-top:25px;box-shadow:0 8px 24px #00000040}.perfil-password-box h4{margin:0 0 10px;font-weight:600}.perfil-password-box .form-group{margin-bottom:12px}@media(max-width:600px){.perfil-header{flex-direction:column;align-items:center;text-align:center}.perfil-buttons{flex-direction:column;width:100%}.perfil-buttons button{width:100%}}.provider-table-container{margin-top:15px}.datatable th,.datatable td{text-align:left}.provider-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;margin-top:15px}.provider-card{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);padding:18px;border-radius:10px;transition:.2s ease}.provider-card:hover{border-color:var(--accent);box-shadow:0 8px 24px #2563eb26;transform:translateY(-2px)}.provider-date{font-size:12px;color:var(--text-muted);margin-top:10px;display:block}.provider-name{font-size:20px;font-weight:600;margin:10px 0 6px}.provider-form-box{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);padding:20px;margin-bottom:25px;border-radius:10px}.provider-form-box h3{margin-bottom:15px}.form-buttons{display:flex;justify-content:flex-end;gap:10px}.btn-submit{background:var(--success);border:1px solid var(--success);color:#052e16;padding:8px 16px;border-radius:8px}.btn-submit:hover{filter:brightness(.95)}.proveedores-wrapper{padding:20px}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.header-actions{display:inline-flex;gap:10px}.detalle-venta-container{padding:20px}.detalle-venta-box{background:#fff;border-radius:6px;padding:20px;border:1px solid #dcdcdc;box-shadow:0 2px 4px #0000000d}.detalle-venta-header{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.detalle-venta-header h2{font-size:22px;margin:0;font-weight:600}.detalle-venta-actions button{margin-left:5px}.detalle-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px 25px;margin-bottom:25px}.detalle-info-item{background:#f8f8f8;padding:12px 15px;border-radius:4px;border:1px solid #e3e3e3}.detalle-info-label{font-size:12px;color:#777;text-transform:uppercase}.detalle-info-value{display:block;font-size:15px;margin-top:3px;font-weight:600}.detalle-productos-table{width:100%;border-collapse:collapse;margin-top:10px}.detalle-productos-table th{background:#f3f3f3;padding:10px;font-size:13px;text-align:left;border-bottom:2px solid #ddd}.detalle-productos-table td{padding:10px;border-bottom:1px solid #e5e5e5;font-size:14px}.detalle-productos-table tfoot td{font-weight:700;background:#fafafa}.detalle-totales-box{margin-top:25px;width:300px;background:#fafafa;padding:15px;border-radius:6px;border:1px solid #dfdfdf}.detalle-totales-row{display:flex;justify-content:space-between;padding:6px 0;font-size:15px}.detalle-totales-row.total-final{border-top:2px solid #ccc;padding-top:10px;font-size:17px;font-weight:700}.detalle-footer-buttons{margin-top:25px;display:flex;gap:10px}@media(max-width:768px){.detalle-info-grid{grid-template-columns:1fr}.detalle-totales-box{width:100%}}.nota-wrapper{max-width:980px;margin:0 auto}.loading{font-size:18px;font-weight:600;text-align:center;padding:20px}.table-wrapper{overflow-x:auto;margin-top:15px}.datatable{width:100%;border-collapse:collapse}.datatable th,.datatable td{padding:8px 10px;border:1px solid #ddd;font-size:14px}.datatable th{background:#f4f4f4;font-weight:600}.nota-resumen{background:#f8f8f8;padding:12px 15px;border-radius:4px;margin-bottom:20px;border:1px solid #ddd}.nota-resumen p{margin:2px 0;font-size:14px}.nota-total{background:#eef7ff;padding:15px;border-left:4px solid #3196f3;margin:20px 0;font-size:18px;font-weight:600}.print-area{width:100%;padding:20px;border:1px solid #e1e1e1;margin-bottom:25px;background:#fff;border-radius:6px}.print-header h2{text-align:center;margin:0;font-size:26px;font-weight:700}.print-sub{text-align:center;font-size:13px;color:#777;margin-top:3px}.print-info,.print-client{margin-top:15px;font-size:14px;line-height:1.4}.print-table{width:100%;margin-top:15px;border-collapse:collapse}.print-table th,.print-table td{border:1px solid #ccc;padding:6px 8px;font-size:14px}.print-table th{background:#f0f0f0;font-weight:600}.print-totales{margin-top:20px;font-size:15px;border-top:1px solid #ccc;padding-top:10px}.buttons{display:flex;justify-content:space-between;margin-top:25px}.buttons .btn{min-width:150px}@media print{body *{visibility:hidden!important}.print-area,.print-area *{visibility:visible!important}.print-area{position:absolute;left:0;top:0;width:100%!important;box-shadow:none!important;border:none!important}.buttons,.nota-resumen,.datatable,.box-header{display:none!important}}:root{--bg: #0f172a;--bg-panel: #0d111c;--bg-panel-2: #0e121f;--border: #1b2236;--text: #ffffff;--text-muted: #aeb7cf;--accent: #2563eb;--accent-2: #3b82f6;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--info: #38bdf8}.text-muted{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--border);background:var(--bg-panel-2);color:var(--text);padding:8px 14px;border-radius:8px;font-size:14px;cursor:pointer;transition:.15s ease}.btn:hover{border-color:var(--accent);box-shadow:0 6px 18px #2563eb1f;transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-xs{padding:4px 8px;font-size:12px;border-radius:6px}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-2);border-color:var(--accent-2)}.btn-default{background:var(--bg-panel-2);border-color:var(--border);color:var(--text)}.btn-default:hover{border-color:var(--accent)}.btn-secondary{background:var(--bg-panel);border-color:var(--border);color:var(--text-muted)}.btn-secondary:hover{border-color:var(--accent);color:var(--text)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.9)}.btn-warning{background:var(--warning);border-color:var(--warning);color:#111827}.btn-warning:hover{filter:brightness(.95)}.btn-info{background:var(--info);border-color:var(--info);color:#0b1220}.btn-info:hover{filter:brightness(.95)}.btn-success{background:var(--success);border-color:var(--success);color:#052e16}.btn-success:hover{filter:brightness(.95)}.btn-group{display:inline-flex;gap:8px}.btn-icon{width:32px;height:32px;padding:0;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center}.btn-icon.btn-xs{width:26px;height:26px}.btn-icon i{font-size:13px;line-height:1}.btn[data-tip],.has-tip[data-tip]{position:relative}.btn[data-tip]:after,.has-tip[data-tip]:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);background:var(--bg-panel-2);border:1px solid var(--border);color:var(--text);padding:6px 8px;border-radius:6px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:.15s ease;z-index:10}.btn[data-tip]:hover:after,.has-tip[data-tip]:hover:after{opacity:1;transform:translate(-50%) translateY(0)}form,.form-vertical{color:var(--text)}.form-group{margin-bottom:12px}.form-row{display:flex;gap:12px}.form-row .half{flex:1}label{display:block;margin-bottom:6px;color:var(--text-muted);font-size:13px}.form-control,select,textarea,input[type=text],input[type=number],input[type=password],input[type=email]{width:100%;background:var(--bg-panel-2);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:8px;outline:none;transition:.15s ease}.form-control:focus,select:focus,textarea:focus,input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f633}.input-group{display:flex;align-items:stretch}.input-group .form-control{border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon{display:inline-flex;align-items:center;padding:0 10px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text-muted);border-top-right-radius:8px;border-bottom-right-radius:8px}.text-right{text-align:right}
