*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0}html{touch-action:manipulation;-webkit-text-size-adjust:100%;text-size-adjust:100%;overscroll-behavior:none}body{touch-action:manipulation;overscroll-behavior:none;-webkit-tap-highlight-color:transparent}input,select,textarea{font-size:16px!important;touch-action:manipulation}@media(display-mode:standalone){html,body{overscroll-behavior:none;overflow:hidden;position:fixed;width:100%;height:100%}#root{overflow-y:auto;-webkit-overflow-scrolling:touch;height:100%}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#0f172a;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#6366f1;text-decoration:inherit}a:hover{color:#4f46e5}body{margin:0;padding:0;min-width:320px;min-height:100vh;min-height:-webkit-fill-available;width:100%;height:100%;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#0f172a;background-color:#f8fafc}a:hover{color:#6366f1}button{background-color:#f9f9f9}}.sidebar{width:280px;height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;overflow-y:auto;overflow-x:hidden;box-shadow:4px 0 24px #00000040;z-index:1000;border-right:1px solid rgba(255,255,255,.05);transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1),width .25s cubic-bezier(.4,0,.2,1)}.sidebar--abierto{transform:translate(0)}.sidebar-toggle{display:none}.sidebar-header{display:flex;align-items:center;gap:10px;padding:16px 12px;border-bottom:1px solid rgba(255,255,255,.08);background:#00000040;flex-shrink:0;min-height:64px}.sidebar-logo{width:40px;height:40px;min-width:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden}.sidebar-logo img{width:100%;height:100%;object-fit:cover;border-radius:10px}.sidebar-header h2{margin:0;font-size:20px;font-weight:700;color:#fff;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;flex:1}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto;overflow-x:hidden}.nav-section{margin-bottom:4px}.section-title{padding:12px 16px 6px;font-size:10px;font-weight:700;letter-spacing:.1em;color:#ffffff59;text-transform:uppercase;white-space:nowrap;overflow:hidden}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 16px;color:#ffffffb3;text-decoration:none;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);position:relative;font-size:14px;font-weight:500;margin:2px 8px;border-radius:8px;white-space:nowrap;overflow:hidden}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active,.nav-item.active-link{background:#6366f126;color:#fff;font-weight:600}.nav-item.active-link:before{content:"";position:absolute;left:-8px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#6366f1,#8b5cf6);border-radius:0 3px 3px 0}.nav-item.expandable{justify-content:space-between}.nav-item.expandable .arrow{transition:transform .2s ease;opacity:.6;flex-shrink:0}.nav-item.expandable.active .arrow{transform:rotate(90deg)}.subitems{background:#0003;padding:4px 0;margin:2px 8px;border-radius:8px;overflow:hidden;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-subitem{display:flex;align-items:center;padding:11px 16px 11px 36px;color:#ffffffa6;text-decoration:none;font-size:13px;transition:all .15s;position:relative;border-radius:6px;margin:2px 6px;white-space:nowrap}.nav-subitem:hover{background:#ffffff14;color:#ffffffe6}.nav-subitem.active{background:#6366f126;color:#fff;font-weight:600}.nav-subitem.active:before{content:"";position:absolute;left:18px;top:50%;transform:translateY(-50%);width:4px;height:4px;background:#6366f1;border-radius:50%}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.btn-logout{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ef44441a;color:#fca5a5;border:1.5px solid rgba(239,68,68,.2);border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .15s;white-space:nowrap;overflow:hidden;flex-shrink:0}.btn-logout:hover{background:#ef444426;color:#fecaca;border-color:#ef44444d}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000001a}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff40}@media(min-width:768px){.sidebar{transform:translate(0);width:68px}.sidebar--abierto{width:260px}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;padding:0;background:#ffffff1f;border:1.5px solid rgba(255,255,255,.25);border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;transition:all .15s ease;margin-left:auto}.sidebar-toggle:hover{background:#ffffff38;border-color:#fff6}.sidebar-toggle:active{transform:scale(.92)}.sidebar:not(.sidebar--abierto) .sidebar-header{flex-direction:column;justify-content:center;padding:14px 8px;gap:8px}.sidebar:not(.sidebar--abierto) .sidebar-toggle{margin-left:0;width:40px;height:40px;background:#6366f140;border-color:#6366f180}.sidebar:not(.sidebar--abierto) .sidebar-toggle:hover{background:#6366f166;border-color:#6366f1b3}.sidebar:not(.sidebar--abierto) .nav-item{justify-content:center;padding:13px;margin:2px 6px;gap:0}.sidebar:not(.sidebar--abierto) .btn-logout{justify-content:center;padding:12px;gap:0}.sidebar:not(.sidebar--abierto) .nav-section{margin-bottom:2px}}.layout{display:flex;min-height:100vh;width:100%;background:#f8fafc}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:999;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.sidebar-backdrop--visible{display:block}.layout-content{flex:1;margin-left:0;display:flex;flex-direction:column;min-height:100vh;width:100%;background:#f8fafc;transition:margin-left .25s cubic-bezier(.4,0,.2,1),width .25s cubic-bezier(.4,0,.2,1)}.layout-header{background:#fff;padding:12px 16px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:12px;box-shadow:0 1px 3px #0000000a;position:sticky;top:0;z-index:100}.btn-hamburger{display:flex;align-items:center;justify-content:center;width:42px;height:42px;min-width:42px;padding:0;background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:10px;color:#334155;cursor:pointer;transition:all .15s ease;flex-shrink:0;box-shadow:0 1px 3px #0000000f}.btn-hamburger:hover{background:#e2e8f0;border-color:#cbd5e1;color:#0f172a;box-shadow:0 2px 6px #0000001a}.btn-hamburger:active{transform:scale(.95)}.layout-header .page-title{margin:0;font-size:17px;font-weight:600;color:#0f172a;letter-spacing:-.01em;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info{display:flex;align-items:center;flex-shrink:0}.user-name{font-size:13px;color:#64748b;font-weight:500;background:#f1f5f9;padding:6px 10px;border-radius:8px;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}.layout-body{flex:1;padding:16px;overflow-y:auto;max-width:100%}@media(min-width:768px){.sidebar-backdrop{display:none!important}.layout-content{margin-left:68px;width:calc(100% - 68px)}.layout-content--expandido{margin-left:260px;width:calc(100% - 260px)}.layout-header{padding:14px 24px}.layout-body{padding:20px 24px}.user-name{max-width:none;padding:7px 14px}}@media(min-width:1024px){.layout-header{padding:18px 32px}.layout-header .page-title{font-size:20px}.layout-body{padding:24px 32px}.user-name{font-size:14px;padding:8px 16px}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#4e73df,#224abe);padding:20px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:500px;height:500px;background:#ffffff0d;border-radius:50%;top:-250px;left:-250px}.login-container:after{content:"";position:absolute;width:400px;height:400px;background:#ffffff08;border-radius:50%;bottom:-200px;right:-200px}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:50px 40px;width:100%;max-width:450px;position:relative;z-index:1;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:40px}.login-header h1{font-size:42px;font-weight:700;color:#2c3e50;margin:0 0 10px;letter-spacing:-1px}.login-header p{font-size:15px;color:#7f8c8d;margin:0;font-weight:400}form{display:flex;flex-direction:column;gap:20px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:20px;color:#95a5a6;display:flex;align-items:center;pointer-events:none;z-index:2}.input-group input{width:100%;padding:18px 20px 18px 60px;border:2px solid rgba(78,115,223,.3);border-radius:50px;font-size:15px;background:#ffffffe6;color:#2c3e50;transition:all .3s ease}.input-group input::placeholder{color:#95a5a6}.input-group input:focus{outline:none;border-color:#4e73df;background:#fff;box-shadow:0 0 0 4px #4e73df1a}.input-group input:focus+.input-icon,.input-group input:not(:placeholder-shown)+.input-icon{color:#4e73df}.input-group input:disabled{background-color:#ecf0f1;cursor:not-allowed;opacity:.7}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:12px;padding:12px 20px;color:#c0392b;font-size:14px;text-align:center;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-button{background:linear-gradient(135deg,#4e73df,#224abe);color:#fff;border:none;border-radius:50px;padding:18px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;margin-top:10px;box-shadow:0 4px 15px #4e73df66}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4e73df99}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #4e73df66}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:768px){.login-card{padding:40px 30px;max-width:400px}.login-header h1{font-size:36px}.login-header p{font-size:14px}}@media(max-width:480px){.login-container{padding:15px}.login-card{padding:35px 25px;border-radius:15px}.login-header h1{font-size:32px}.login-header p{font-size:13px}.input-group input{padding:16px 20px 16px 55px;font-size:14px}.login-button{padding:16px;font-size:15px}}.modal-overlay{position:fixed;inset:0;background-color:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .2s ease}.modal-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000040,0 0 1px #0003;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);width:100%;border:1px solid rgba(226,232,240,.8)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-small{max-width:400px}.modal-medium{max-width:650px}.modal-large{max-width:900px}.modal-xlarge{max-width:1200px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid #e2e8f0;background:linear-gradient(to bottom,#fff,#fafafa)}.modal-header h2{margin:0;font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.02em}.modal-close{background:#fff;border:1.5px solid #e2e8f0;cursor:pointer;padding:8px;color:#64748b;transition:all .15s cubic-bezier(.4,0,.2,1);border-radius:8px;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.modal-close:hover{background:#f8fafc;border-color:#cbd5e0;color:#0f172a;transform:scale(1.05)}.modal-body{padding:32px;overflow-y:auto;flex:1;background-color:#fafbfc}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.modal-body::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:10px}.modal-body::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media(max-width:768px){.modal-container{max-height:95vh}.modal-small,.modal-medium,.modal-large,.modal-xlarge{max-width:100%}.modal-header{padding:15px 20px}.modal-header h2{font-size:18px}.modal-body{padding:20px}}.form-moderno{display:flex;flex-direction:column;gap:20px}.form-group-moderno{display:flex;flex-direction:column;gap:8px}.form-group-moderno label{font-size:14px;font-weight:600;color:#334155;display:flex;align-items:center;gap:4px}.form-group-moderno label .required{color:#ef4444;font-weight:700}.form-group-moderno input,.form-group-moderno select,.form-group-moderno textarea{padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;transition:all .2s;background:#fafbfc;color:#1e293b}.form-group-moderno input:focus,.form-group-moderno select:focus,.form-group-moderno textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.form-group-moderno input.input-error,.form-group-moderno select.input-error,.form-group-moderno textarea.input-error{border-color:#ef4444}.form-group-moderno input.input-error:focus,.form-group-moderno select.input-error:focus,.form-group-moderno textarea.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.form-group-moderno .error-text{font-size:12px;color:#ef4444;font-weight:500}.form-group-moderno textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:24px;border-top:1px solid #e2e8f0}.btn-cancelar-moderno{padding:12px 24px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancelar-moderno:hover{background:#f8fafc;border-color:#cbd5e0;color:#475569}.btn-guardar-moderno{padding:12px 24px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6366f14d}.btn-guardar-moderno:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-guardar-moderno:active{transform:translateY(0)}.dialogo-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.dialogo-container{background:#fff;border-radius:16px;padding:32px;max-width:440px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;text-align:center}.dialogo-icono{width:80px;height:80px;margin:0 auto 24px;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:scaleIn .4s ease-out}.dialogo-icono-advertencia{background:linear-gradient(135deg,#fef3c7,#fbbf24);color:#92400e}.dialogo-icono-peligro{background:linear-gradient(135deg,#fee2e2,#ef4444);color:#991b1b}.dialogo-icono-info{background:linear-gradient(135deg,#dbeafe,#3b82f6);color:#1e40af}.dialogo-titulo{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 12px}.dialogo-mensaje{font-size:16px;color:#6b7280;line-height:1.6;margin:0 0 28px}.dialogo-opcion-impresion{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:16px;margin:0 0 24px;transition:all .2s ease}.dialogo-opcion-impresion:hover{border-color:#d1d5db;background:#f3f4f6}.checkbox-container{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.checkbox-container input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:relative;height:24px;width:24px;background-color:#fff;border:2px solid #d1d5db;border-radius:6px;transition:all .2s ease;flex-shrink:0}.checkbox-container:hover .checkmark{border-color:#3b82f6}.checkbox-container input:checked~.checkmark{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb}.checkmark:after{content:"";position:absolute;display:none;left:7px;top:3px;width:6px;height:11px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-label{font-size:15px;font-weight:500;color:#374151;text-align:left}.dialogo-botones{display:flex;gap:12px;justify-content:center}.dialogo-btn{padding:12px 28px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;min-width:130px}.dialogo-btn-cancelar{background:#f3f4f6;color:#374151}.dialogo-btn-cancelar:hover{background:#e5e7eb;transform:translateY(-1px)}.dialogo-btn-confirmar{color:#fff;box-shadow:0 4px 12px #00000026}.dialogo-btn-confirmar-advertencia{background:linear-gradient(135deg,#f59e0b,#d97706)}.dialogo-btn-confirmar-advertencia:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 6px 16px #d9770666}.dialogo-btn-confirmar-peligro{background:linear-gradient(135deg,#ef4444,#dc2626)}.dialogo-btn-confirmar-peligro:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 16px #dc262666}.dialogo-btn-confirmar-info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.dialogo-btn-confirmar-info:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}@media(max-width:480px){.dialogo-container{padding:24px}.dialogo-icono{width:64px;height:64px}.dialogo-icono svg{width:32px;height:32px}.dialogo-titulo{font-size:20px}.dialogo-mensaje{font-size:14px}.dialogo-botones{flex-direction:column-reverse}.dialogo-btn{width:100%}}.formulario-producto{width:100%;display:flex;flex-direction:column;gap:24px;background:#fff;padding:8px;border-radius:8px}.formulario-producto h3{display:none}.formulario-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{display:flex;flex-direction:column;gap:8px;position:relative}.form-group label{font-size:14px;font-weight:600;color:#334155;display:flex;align-items:center;gap:4px;-webkit-user-select:none;user-select:none}.obligatorio{color:#ef4444;font-weight:700}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;color:#1e293b;transition:all .2s cubic-bezier(.4,0,.2,1);background-color:#fff;box-sizing:border-box}.form-group select{padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%236366f1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}.form-group select::-ms-expand{display:none}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a;transform:translateY(-1px)}.form-group input:hover:not(:disabled),.form-group textarea:hover:not(:disabled),.form-group select:hover:not(:disabled){border-color:#cbd5e1}.form-group input::placeholder,.form-group textarea::placeholder{color:#94a3b8}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background-color:#f8fafc;color:#94a3b8;cursor:not-allowed;border-color:#e2e8f0}.form-group select:disabled{background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}.input-error{border-color:#ef4444!important;background-color:#fef2f2!important}.input-error:focus{box-shadow:0 0 0 3px #ef44441a!important}.mensaje-error{font-size:13px;color:#ef4444;display:flex;align-items:center;gap:4px;margin-top:-4px;font-weight:500}.mensaje-error:before{content:"⚠";font-size:14px}.mensaje-info{font-size:12px;color:#64748b;display:flex;align-items:center;gap:4px;margin-top:-4px;font-style:italic}.mensaje-info:before{content:"ℹ";font-size:14px;color:#6366f1}.formulario-botones{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:24px;border-top:1.5px solid #e2e8f0}.btn{padding:13px 28px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;min-width:150px}.btn svg{flex-shrink:0}.btn-primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 4px 12px #6366f14d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background:linear-gradient(135deg,#94a3b8,#64748b);cursor:not-allowed;opacity:.6;box-shadow:none}.btn-secondary{background:#fff;color:#475569;border:1.5px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.formulario-producto>.form-group{grid-column:1 / -1}.formulario-producto>.form-group textarea{background-color:#fafbfc}.form-group label{position:relative;padding-left:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.input-error{animation:shake .3s ease}@media(max-width:640px){.formulario-grid{grid-template-columns:1fr;gap:16px}.formulario-botones{flex-direction:column-reverse;gap:8px}.btn{width:100%;justify-content:center;min-width:unset}.form-group input,.form-group textarea{font-size:16px}.formulario-producto{padding:4px}.form-group label:before,.form-group:has(input[disabled][id=stock]) label:after{display:none}}.form-group input[type=number]::-webkit-inner-spin-button,.form-group input[type=number]::-webkit-outer-spin-button{opacity:1}.form-group:has(#precioVentaVariante) label:before,.form-group:has(#precioMayoristaVariante) label:before,.form-group:has(#precioCostoVariante) label:before{content:"💰";margin-right:4px;font-size:14px}.form-group:has(#stock) label:before{content:"📦";margin-right:4px;font-size:14px}.form-group:has(#codigo) label:before{content:"🏷️";margin-right:4px;font-size:14px}.form-group:has(#nombre) label:before{content:"📝";margin-right:4px;font-size:14px}.form-group:has(#marca) label:before{content:"🏷️";margin-right:4px;font-size:14px}.form-group:has(#categoria) label:before{content:"📂";margin-right:4px;font-size:14px}.form-group:has(#tipoProducto) label:before{content:"📦";margin-right:4px;font-size:14px}.form-group:has(#genero) label:before{content:"👤";margin-right:4px;font-size:14px}.form-group:has(#descripcion) label:before{content:"📋";margin-right:4px;font-size:14px}.form-group input[disabled][id=stock]{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px dashed #cbd5e1;font-style:italic;position:relative}.form-group:has(input[disabled][id=stock]) label:after{content:"🔒";margin-left:6px;font-size:12px;opacity:.6}.form-group input[title]:hover:after{content:attr(title);position:absolute;background:#1e293b;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:1000;margin-top:-35px;margin-left:10px}.form-group input:invalid:not(:placeholder-shown):not(:focus){border-color:#fbbf24}.form-group input:valid:not(:placeholder-shown):not(:focus){border-color:#10b981}.btn:disabled:after{content:"";display:inline-block;width:14px;height:14px;margin-left:8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.input-select-busqueda{width:100%;padding:12px 16px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;color:#1e293b;transition:all .2s cubic-bezier(.4,0,.2,1);background-color:#fff;box-sizing:border-box;cursor:pointer}.input-select-busqueda:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a;transform:translateY(-1px)}.opciones-desplegables{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:250px;overflow-y:auto;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-shadow:0 10px 25px #0000001a;z-index:1000;animation:slideDown .2s ease-out}.opcion-item em{color:#94a3b8;font-style:italic}.productos-container{width:100%;max-width:1400px;margin:0 auto}.mensaje{padding:16px 20px;border-radius:12px;margin-bottom:24px;font-weight:500;font-size:14px;display:flex;align-items:center;gap:12px;animation:slideDown .3s ease;border-left:4px solid;box-shadow:0 2px 8px #00000014}.mensaje-exito{background:linear-gradient(to right,#ecfdf5,#f0fdf4);border-left-color:#10b981;color:#065f46}.mensaje-error{background:linear-gradient(to right,#fef2f2 0% 100%);border-left-color:#ef4444;color:#991b1b}.productos-header-actions{margin-bottom:32px}.header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}.header-text h2{margin:0 0 6px;font-size:28px;font-weight:700;color:#0f172a;letter-spacing:-.02em}.header-text p{margin:0;font-size:15px;color:#64748b;font-weight:400}.header-actions{display:flex;gap:12px;align-items:center}.btn-nuevo-producto{display:flex;align-items:center;gap:10px;padding:12px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #6366f140;position:relative;overflow:hidden}.btn-nuevo-producto:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#7c3aed,#a855f7);opacity:0;transition:opacity .2s}.btn-nuevo-producto:hover:before{opacity:1}.btn-nuevo-producto:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f159}.btn-nuevo-producto:active{transform:translateY(0)}.btn-nuevo-producto svg,.btn-nuevo-producto span{position:relative;z-index:1}.tabla-section{background:#fff;border-radius:16px;padding:0;box-shadow:0 1px 3px #0000000d,0 4px 12px #00000008;border:1px solid #f1f5f9;overflow:hidden}.tabla-container{width:100%}.tabla-info{padding:20px 28px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.tabla-info p{margin:0;font-size:13px;color:#64748b;font-weight:500}.tabla-wrapper{overflow-x:auto}.tabla-productos{width:100%;min-width:700px;border-collapse:collapse;font-size:14px}.tabla-productos thead{background-color:#f8fafc;position:sticky;top:0;z-index:10}.tabla-productos th{padding:16px 28px;text-align:left;font-weight:600;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0;white-space:nowrap}.tabla-productos th.acciones-th{text-align:center}.tabla-productos td{padding:18px 28px;border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px}.tabla-productos tbody tr{transition:all .15s ease;cursor:default}.tabla-productos tbody tr:hover{background-color:#f8fafc}.tabla-productos tbody tr:last-child td{border-bottom:none}.codigo{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-weight:600;color:#475569;font-size:13px;background:#f1f5f9;padding:4px 10px;border-radius:6px;display:inline-block}.nombre{font-weight:600;color:#0f172a}.stock{text-align:center}.badge-stock{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;font-weight:600;font-size:13px;box-shadow:0 1px 2px #0000000d}.badge-stock:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block}.stock-ok:before{background-color:#10b981}.stock-medio{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.stock-medio:before{background-color:#f59e0b}.stock-bajo{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#991b1b}.stock-bajo:before{background-color:#ef4444}.precio{font-weight:600;color:#0f172a;font-variant-numeric:tabular-nums}.acciones{display:flex;gap:8px;justify-content:center;align-items:center}.btn-accion{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);background-color:#fff;color:#64748b}.btn-accion:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000014}.btn-editar{color:#6366f1;border-color:#e0e7ff}.btn-editar:hover{background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#4f46e5;border-color:#c7d2fe}.btn-eliminar{color:#ef4444;border-color:#fee2e2}.btn-eliminar:hover{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;border-color:#fecaca}.tabla-cargando{text-align:center;padding:80px 20px;color:#64748b}.spinner{width:44px;height:44px;margin:0 auto 24px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.tabla-cargando p{font-size:15px;font-weight:500}.tabla-vacia{text-align:center;padding:80px 20px;color:#64748b}.tabla-vacia svg{color:#cbd5e0}.tabla-vacia p:first-of-type{font-size:18px;font-weight:600;color:#334155;margin-bottom:8px}.tabla-vacia p:last-of-type{font-size:14px;color:#94a3b8}.paginacion{display:flex;justify-content:center;align-items:center;gap:6px;padding:24px 28px;background:#f8fafc;border-top:1px solid #e2e8f0}.btn-paginacion{display:flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;border-radius:8px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);font-size:14px;font-weight:600}.btn-paginacion:hover:not(:disabled):not(.active){background-color:#f1f5f9;border-color:#cbd5e0;transform:translateY(-1px)}.btn-paginacion.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:transparent;box-shadow:0 4px 12px #6366f140}.btn-paginacion:disabled{opacity:.3;cursor:not-allowed}.paginacion-dots{color:#94a3b8;padding:0 6px;font-weight:600}.formulario-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}@media(min-width:600px){.formulario-grid{grid-template-columns:repeat(2,1fr)}}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#334155;letter-spacing:-.01em}.obligatorio{color:#ef4444}.form-group input,.form-group textarea{padding:11px 14px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s;color:#0f172a;background-color:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input:disabled{background-color:#f8fafc;cursor:not-allowed;color:#94a3b8}.form-group textarea{resize:vertical;min-height:90px}.formulario-botones{display:flex;gap:12px;margin-top:28px;padding-top:24px;border-top:1px solid #e2e8f0}.btn{padding:11px 22px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1)}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 2px 8px #6366f133}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-secondary{background-color:#fff;color:#64748b;border:1.5px solid #e2e8f0}.btn-secondary:hover{background-color:#f8fafc;border-color:#cbd5e0}.btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.productos-container{padding:0 16px}.header-content{flex-direction:column;align-items:stretch}.header-text h2{font-size:24px}.btn-nuevo-producto{justify-content:center}.tabla-section{border-radius:12px}.tabla-info,.paginacion{padding:16px 20px}.tabla-productos th,.tabla-productos td{padding:14px 20px}.paginacion{flex-wrap:wrap}}.variantes-section{margin-top:32px;padding:28px;background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px;border:2px solid #e2e8f0;box-shadow:0 4px 12px #0000000a}.variantes-section h3{margin:0 0 24px;font-size:19px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:8px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.variante-form{margin-bottom:28px;padding:24px;background:#fff;border-radius:12px;border:1.5px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.variante-form .formulario-grid{margin-bottom:16px}.variante-form .btn{margin-top:12px;display:flex;align-items:center;gap:8px;font-size:14px}.variantes-tabla{margin-top:24px;border-radius:16px;overflow:hidden;background:#fff;border:2px solid #e2e8f0;box-shadow:0 4px 16px #0000000f}.variantes-tabla-titulo{margin:0;padding:18px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:15px;font-weight:700;display:flex;align-items:center;letter-spacing:.3px}.variantes-count{margin-left:auto;background:#fff3;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600}.variantes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:24px}.variante-card{background:#fff;border-radius:12px;border:2px solid #e2e8f0;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.variante-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#cbd5e1}.variante-existente-card{border-color:#86efac;background:linear-gradient(to bottom,#f0fdf4,#fff)}.variante-existente-card:hover{border-color:#4ade80}.variante-nueva-card{border-color:#fde047;background:linear-gradient(to bottom,#fefce8,#fff)}.variante-nueva-card:hover{border-color:#facc15}.variante-card-header{padding:12px 16px;background:#f8fafc80;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.variante-card-body{padding:16px}.variante-info-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.variante-info-row:last-child{margin-bottom:0}.variante-info-item{display:flex;flex-direction:column;gap:4px}.variante-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.variante-valor-card{font-weight:700;color:#0f172a;font-size:15px;padding:6px 10px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0 50%);border-radius:6px;display:inline-block}.stock-valor-card{font-weight:800;color:#059669;background:linear-gradient(135deg,#d1fae5,#a7f3d0);padding:6px 12px;border-radius:6px;display:inline-block;font-variant-numeric:tabular-nums;font-size:16px;text-align:center}.codigo-variante-card{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-weight:600;color:#6366f1;font-size:12px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);padding:6px 10px;border-radius:6px;display:inline-block}.precio-valor-card{font-weight:700;color:#8b5cf6;font-variant-numeric:tabular-nums;font-size:14px;background:linear-gradient(135deg,#f5f3ff,#ede9fe);padding:6px 10px;border-radius:6px;display:inline-block}.variante-card-footer{padding:12px 16px;background:#f8fafc80;border-top:1px solid #e2e8f0;display:flex;gap:8px;justify-content:flex-end}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:#fff;border:1.5px solid #e2e8f0}.btn-icon:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.btn-edit{color:#6366f1;border-color:#c7d2fe}.btn-edit:hover{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-color:#a5b4fc}.btn-delete{color:#ef4444;border-color:#fecaca}.btn-delete:hover{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fca5a5}.variante-edit-form{padding:16px;background:linear-gradient(to bottom,#fafafa,#fff)}.variante-edit-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.form-group-inline{display:flex;flex-direction:column;gap:4px}.form-group-inline label{font-size:11px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px}.input-small{padding:8px 12px;border:1.5px solid #e2e8f0;border-radius:6px;font-size:13px;font-family:inherit;transition:all .2s;background:#fff}.input-small:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.variante-edit-actions{display:flex;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0}.btn-xs{padding:8px 16px;font-size:12px;font-weight:600;border-radius:6px;display:flex;align-items:center;gap:6px}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;box-shadow:0 2px 6px #10b98140}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 10px #10b98159}.btn-small{padding:6px 12px;font-size:12px;display:inline-flex;align-items:center;gap:6px;border-radius:6px}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;box-shadow:0 2px 6px #ef444440}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 10px #ef444459}.mensaje-info-inline{color:#64748b;font-size:13px;font-weight:400;font-style:italic}.mensaje-info{padding:14px 18px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left:4px solid #3b82f6;color:#1e40af;border-radius:10px;font-size:14px;font-weight:500;box-shadow:0 2px 8px #3b82f61a}.badge-existente{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 6px #10b98140}.badge-nueva{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 6px #f59e0b40}@media(max-width:768px){.variantes-grid,.variante-edit-row{grid-template-columns:1fr}}.historial-producto-container{display:flex;flex-direction:column;gap:1.5rem;max-height:75vh}.historial-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.producto-info h3{margin:0;font-size:1.25rem;font-weight:600}.producto-codigo{margin:.25rem 0 0;opacity:.9;font-size:.875rem}.producto-stock-actual{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.producto-stock-actual .label{font-size:.75rem;opacity:.9;text-transform:uppercase;letter-spacing:.05em}.producto-stock-actual .valor{font-size:2rem;font-weight:700;line-height:1}.historial-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stat-box{padding:1rem;border-radius:8px;text-align:center;border:2px solid;transition:transform .2s,box-shadow .2s}.stat-box:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-numero{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.stat-label{font-size:.875rem;opacity:.8}.stat-total{background-color:#f0f4ff;border-color:#4f46e5;color:#4f46e5}.stat-compra{background-color:#f0fdf4;border-color:#10b981;color:#10b981}.stat-venta{background-color:#fef3c7;border-color:#f59e0b;color:#f59e0b}.stat-ajuste{background-color:#fce7f3;border-color:#ec4899;color:#ec4899}.historial-filtros{display:flex;gap:.5rem;padding:.5rem;background:#f9fafb;border-radius:8px}.historial-filtros .filtro-btn{flex:1;padding:.5rem 1rem;border:2px solid #e5e7eb;background:#fff;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.historial-filtros .filtro-btn:hover{border-color:#d1d5db;background:#f9fafb}.historial-filtros .filtro-btn.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.historial-tabla-container{overflow-x:auto;overflow-y:auto;max-height:450px;border:1px solid #e5e7eb;border-radius:8px}.historial-tabla{width:100%;border-collapse:collapse;font-size:.875rem}.historial-tabla thead{position:sticky;top:0;background:#f9fafb;z-index:10}.historial-tabla th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;white-space:nowrap}.historial-tabla td{padding:.75rem 1rem;border-bottom:1px solid #f3f4f6}.historial-tabla tbody tr{transition:background-color .15s}.historial-tabla tbody tr:hover{background-color:#f9fafb}.historial-tabla tbody tr.tipo-compra{border-left:3px solid #10b981}.historial-tabla tbody tr.tipo-venta{border-left:3px solid #f59e0b}.historial-tabla tbody tr.tipo-ajuste{border-left:3px solid #ec4899}.historial-tabla tbody tr.tipo-otro{border-left:3px solid #6b7280}.tipo-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:6px;font-weight:500;font-size:.75rem;text-transform:capitalize}.tipo-compra .tipo-badge{background:#d1fae5;color:#065f46}.tipo-venta .tipo-badge{background:#fef3c7;color:#92400e}.tipo-ajuste .tipo-badge{background:#fce7f3;color:#9f1239}.tipo-otro .tipo-badge{background:#e5e7eb;color:#374151}.tipo-badge svg{width:16px;height:16px}.descripcion-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fecha-cell{color:#6b7280;font-size:.8125rem}.cantidad-cell{font-weight:600;font-family:Courier New,monospace}.cantidad-cell.positivo{color:#10b981}.cantidad-cell.negativo{color:#ef4444}.text-right{text-align:right!important}.text-muted{color:#9ca3af}.text-success{color:#10b981;font-weight:600}.historial-loading,.historial-error,.historial-vacio{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6b7280}.historial-loading .spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#4f46e5;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.historial-loading p{margin:0;font-weight:500}.historial-error svg,.historial-vacio svg{color:#d1d5db;margin-bottom:1rem}.historial-error p,.historial-vacio p{margin:0;font-weight:600;color:#374151;font-size:1.125rem}.historial-error small,.historial-vacio small{display:block;margin-top:.5rem;color:#9ca3af}.btn-reintentar{margin-top:1rem;padding:.5rem 1.5rem;background:#4f46e5;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-reintentar:hover{background:#4338ca}.historial-footer{display:flex;justify-content:flex-end;padding-top:1rem;border-top:1px solid #e5e7eb}.btn-cerrar{padding:.625rem 1.5rem;background:#6b7280;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-cerrar:hover{background:#4b5563}@media(max-width:1024px){.historial-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.historial-header{flex-direction:column;gap:1rem;text-align:center}.producto-stock-actual{align-items:center}.historial-stats{grid-template-columns:1fr}.historial-filtros{flex-wrap:wrap}.historial-tabla{font-size:.75rem}.historial-tabla th,.historial-tabla td{padding:.5rem}.descripcion-cell{max-width:120px}}.productos-modernos-container{width:100%;max-width:100%;margin:0;padding:0;min-height:100vh}.mensaje-moderno{padding:14px 18px;border-radius:10px;margin-bottom:20px;font-weight:600;font-size:14px;display:flex;align-items:center;gap:10px;animation:slideDown .3s ease;box-shadow:0 4px 12px #0000001a}.mensaje-exito{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.mensaje-error{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.header-moderno{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-info h1{font-size:32px;font-weight:800;color:#1e293b;margin:0 0 4px}.header-info p{font-size:15px;color:#64748b;margin:0}.btn-nuevo-moderno{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6366f14d}.btn-nuevo-moderno:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.stats-modernas{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;margin-bottom:20px}.stat-item{display:flex;align-items:center;gap:12px}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-azul{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.stat-verde{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.stat-amarillo{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.stat-rojo{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.stat-indigo{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3}.stat-info{flex:1}.stat-label{font-size:12px;color:#64748b;margin:0 0 2px;font-weight:500}.stat-valor{font-size:24px;font-weight:800;color:#1e293b;margin:0}.stat-valor-pequeño{font-size:14px;font-weight:700;color:#1e293b;margin:0}.filtros-moderno{background:#fff;padding:20px 24px;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;margin-bottom:20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}.filtros-modernos{background:#fff;padding:20px 24px;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;margin-bottom:20px}.filtros-content{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:12px}.busqueda-moderno{flex:1;min-width:250px;position:relative}.busqueda-moderno svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8}.busqueda-moderno input{width:100%;padding:10px 12px 10px 40px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s}.busqueda-moderno input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.search-box-moderno{flex:1;min-width:300px;position:relative}.search-box-moderno svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.search-box-moderno input{width:100%;padding:12px 16px 12px 44px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;transition:all .2s;background:#fafbfc}.search-box-moderno input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.checkbox-moderno{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 16px;border-radius:8px;transition:all .2s}.checkbox-moderno:hover{background:#f8fafc}.checkbox-moderno input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#6366f1}.checkbox-moderno span{font-size:14px;font-weight:600;color:#475569}.filtros-stock{display:flex;gap:8px}.filtro-btn{padding:10px 16px;border:2px solid #e2e8f0;background:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#64748b}.filtro-btn:hover{background:#f8fafc}.filtro-btn.active{background:#6366f1;color:#fff;border-color:#6366f1;box-shadow:0 4px 12px #6366f14d}.toggle-vista{display:flex;gap:4px;background:#f1f5f9;padding:4px;border-radius:8px}.toggle-vista button{padding:8px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:all .2s;color:#64748b}.toggle-vista button:hover{background:#e2e8f0}.toggle-vista button.active{background:#fff;color:#6366f1;box-shadow:0 1px 3px #0000001a}.info-resultados{display:flex;justify-content:space-between;padding-top:12px;border-top:1px solid #e2e8f0;font-size:13px;color:#64748b;font-weight:500}.table-container-moderno{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;overflow:hidden}.tabla-moderno{width:100%;border-collapse:collapse}.tabla-moderno thead{background:linear-gradient(to bottom,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0}.tabla-moderno th{padding:16px 20px;text-align:left;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.tabla-moderno td{padding:16px 20px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155}.tabla-moderno tbody tr{transition:all .15s ease}.tabla-moderno tbody tr:hover{background:#f8fafc}.tabla-moderno tbody tr:last-child td{border-bottom:none}.tabla-moderna-wrapper{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;overflow:hidden}.tabla-scroll{overflow-x:auto}.tabla-moderna{width:100%;border-collapse:collapse}.tabla-moderna thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.tabla-moderna th{padding:16px 20px;text-align:left;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.tabla-moderna th.centrado{text-align:center}.tabla-moderna th.derecha{text-align:right}.tabla-moderna td{padding:16px 20px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155}.tabla-moderna tbody tr:hover{background:#f8fafc}.tabla-moderna td.centrado{text-align:center}.tabla-moderna td.derecha{text-align:right}.producto-cell{display:flex;align-items:center;gap:12px}.producto-icono{width:36px;height:36px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#6366f1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.producto-nombre{font-weight:600;color:#1e293b}.producto-nombre-clickable{cursor:pointer;transition:all .2s}.producto-nombre-clickable:hover{color:#6366f1;text-decoration:underline}.codigo-badge{display:inline-block;padding:4px 10px;background:#f1f5f9;border-radius:6px;font-family:Courier New,monospace;font-size:12px;font-weight:600;color:#475569}.categoria-texto{font-size:13px;color:#64748b}.stock-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:8px;font-weight:700;font-size:12px}.stock-ok{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.stock-bajo{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.stock-sin{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.precio-cell{font-weight:600;color:#1e293b}.acciones-cell{display:flex;gap:6px;justify-content:center}.btn-accion-moderno{padding:8px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s}.btn-historial-moderno{color:#8b5cf6}.btn-historial-moderno:hover{background:#faf5ff;border-color:#e9d5ff}.btn-editar-moderno{color:#6366f1}.btn-editar-moderno:hover{background:#eef2ff;border-color:#c7d2fe}.btn-eliminar-moderno{color:#ef4444}.btn-eliminar-moderno:hover{background:#fef2f2;border-color:#fecaca}.grid-moderna{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.card-producto-moderna{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:16px;transition:all .3s ease}.card-producto-moderna:hover{box-shadow:0 8px 24px #0000001a;border-color:#c7d2fe;transform:translateY(-4px)}.card-header-moderna{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.producto-icono-grande{width:48px;height:48px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#6366f1;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px}.card-body-moderna{margin-bottom:12px}.codigo-texto{font-family:Courier New,monospace;font-size:11px;color:#64748b;margin:0 0 6px}.nombre-producto{font-size:15px;font-weight:700;color:#1e293b;margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.nombre-producto-clickable{cursor:pointer;transition:all .2s}.nombre-producto-clickable:hover{color:#6366f1}.card-precios{padding:12px 0;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;margin-bottom:12px}.precio-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.precio-item:last-child{margin-bottom:0}.precio-label{font-size:12px;color:#64748b}.precio-valor{font-size:16px;font-weight:700;color:#1e293b}.precio-valor-small{font-size:13px;font-weight:600;color:#64748b}.card-acciones{display:flex;gap:8px}.btn-card-historial{padding:10px 12px;background:#faf5ff;color:#8b5cf6;border:1px solid #e9d5ff;border-radius:8px;cursor:pointer;transition:all .2s}.btn-card-historial:hover{background:#f3e8ff;transform:translateY(-1px)}.btn-card-editar{flex:1;padding:10px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.btn-card-editar:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-card-eliminar{padding:10px 12px;background:#fef2f2;color:#ef4444;border:1px solid #fecaca;border-radius:8px;cursor:pointer;transition:all .2s}.btn-card-eliminar:hover{background:#fee2e2}.cell-nombre{font-weight:600;color:#1e293b}.badge-moderno{display:inline-flex;align-items:center;padding:6px 12px;border-radius:8px;font-weight:700;font-size:12px}.badge-activo{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.badge-inactivo{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#64748b}.acciones-moderno{display:flex;gap:8px;justify-content:flex-end}.btn-icono-moderno{padding:8px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icono-moderno svg{display:block}.btn-editar{color:#6366f1}.btn-editar:hover{background:#eef2ff;border-color:#c7d2fe;transform:translateY(-1px);box-shadow:0 2px 8px #6366f133}.btn-eliminar{color:#ef4444}.btn-eliminar:hover{background:#fef2f2;border-color:#fecaca;transform:translateY(-1px);box-shadow:0 2px 8px #ef444433}.btn-reactivar{color:#10b981}.btn-reactivar:hover{background:#d1fae5;border-color:#a7f3d0;transform:translateY(-1px);box-shadow:0 2px 8px #10b98133}.fila-inactiva{opacity:.6;background:#f8fafc}.fila-inactiva:hover{opacity:.8}.paginacion-moderna{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px}.btn-pag{padding:10px;border:1px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;color:#64748b}.btn-pag:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e0}.btn-pag:disabled{opacity:.4;cursor:not-allowed}.numeros-pag{display:flex;gap:4px}.btn-numero{min-width:40px;padding:10px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#64748b}.btn-numero:hover{background:#f8fafc}.btn-numero.active{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border-color:transparent;box-shadow:0 4px 12px #6366f14d}.loading-moderno{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:60px 20px;text-align:center;color:#64748b;font-size:15px;font-weight:500}.empty-state-moderno{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:80px 20px;text-align:center}.empty-state-moderno svg{color:#cbd5e1;margin-bottom:16px}.empty-state-moderno p{font-size:16px;font-weight:600;color:#64748b;margin:0 0 24px}.tabla-cargando-moderna,.tabla-vacia-moderna{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:60px 20px;text-align:center}.spinner-moderno{width:48px;height:48px;margin:0 auto 20px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.icono-vacio{font-size:64px;margin-bottom:16px}.tabla-vacia-moderna h3{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 8px}.tabla-vacia-moderna p{font-size:14px;color:#64748b;margin:0}@media(min-width:1600px){.grid-moderna{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media(max-width:1400px){.stats-modernas{grid-template-columns:repeat(3,1fr)}}@media(max-width:1200px){.stats-modernas{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.ocultar-tablet{display:none!important}.stats-modernas{grid-template-columns:repeat(2,1fr)}.grid-moderna{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.header-moderno{flex-direction:column;align-items:stretch;gap:12px}.btn-nuevo-moderno{justify-content:center}.stats-modernas{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px}.filtros-modernos{padding:16px}.filtros-content{flex-direction:column;align-items:stretch}.busqueda-moderno{min-width:100%}.filtros-stock{flex-wrap:wrap}.info-resultados{flex-direction:column;gap:4px}.ocultar-movil{display:none!important}.grid-moderna{grid-template-columns:1fr}}@media(max-width:768px){.table-container-moderno{background:transparent!important;border:none!important;box-shadow:none!important;overflow:visible!important}.tabla-moderno thead{display:none!important}.tabla-moderno,.tabla-moderno tbody{display:block!important;width:100%!important}.tabla-moderno tbody tr{display:flex!important;flex-direction:column!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:12px!important;padding:16px!important;margin-bottom:12px!important;box-shadow:0 1px 4px #0000000f!important;gap:6px!important}.tabla-moderno tbody tr.fila-inactiva{opacity:.6!important;background:#f8fafc!important}.tabla-moderno tbody tr td{display:flex!important;align-items:center!important;justify-content:space-between!important;padding:4px 0!important;border:none!important;border-bottom:none!important;font-size:14px!important;min-height:24px!important;width:100%!important}.tabla-moderno tbody tr td:before{content:attr(data-label);font-weight:600;color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;margin-right:12px;white-space:nowrap}.tabla-moderno tbody tr td:first-child{padding-bottom:10px!important;border-bottom:1px solid #e2e8f0!important;margin-bottom:4px!important}.tabla-moderno tbody tr td:first-child:before{display:none!important}.tabla-moderno tbody tr td:first-child .cell-nombre strong{font-size:16px;color:#1e293b}.tabla-moderno tbody tr td:last-child{justify-content:flex-end!important;padding-top:10px!important;border-top:1px solid #e2e8f0!important;margin-top:4px!important}.tabla-moderno tbody tr td:last-child:before{display:none!important}.acciones-moderno{gap:10px}.btn-icono-moderno{padding:10px}}@media(max-width:480px){.stats-modernas{grid-template-columns:1fr}.stat-valor{font-size:20px}}.ventas-container{width:100%;max-width:100%;margin:0;padding:0;min-height:100vh}.ventas-header{margin-bottom:24px}.ventas-header .header-info h1{font-size:32px;font-weight:800;color:#1e293b;margin:0 0 4px}.ventas-header .header-info p{font-size:15px;color:#64748b;margin:0}.ventas-layout{display:grid;grid-template-columns:1fr 400px;gap:24px;align-items:start}.ventas-panel-principal{display:flex;flex-direction:column;gap:20px}.venta-seccion{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0}.venta-label{display:block;font-size:14px;font-weight:600;color:#334155;margin-bottom:8px}.venta-select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;transition:all .2s;background:#fafbfc;color:#1e293b}.venta-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.buscador-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.resultados-header{padding:12px 16px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-bottom:1px solid #e2e8f0;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;z-index:1}.resultado-item:hover{background:#f8fafc}.btn-agregar-rapido{width:32px;height:32px;border:none;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border-radius:8px;font-size:20px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-agregar-rapido:hover{transform:scale(1.1);box-shadow:0 4px 12px #6366f166}.tabla-carrito thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.tabla-carrito th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.tabla-carrito tbody tr:hover{background:#f8fafc}.stock-badge{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-radius:6px;font-size:12px;font-weight:700}.btn-cantidad{width:28px;height:28px;padding:0;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-cantidad:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e0;color:#1e293b}.cantidad-input:focus{outline:none;border-color:#6366f1}.descuento-control{display:flex;align-items:center;gap:4px;justify-content:center}.descuento-input{width:70px;padding:6px 8px;border:2px solid #e2e8f0;border-radius:6px;text-align:center;font-size:13px;font-weight:600;background:#fafbfc;color:#1e293b}.descuento-input:focus{outline:none;border-color:#f59e0b;background:#fff}.descuento-input::-webkit-inner-spin-button,.descuento-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.tipo-descuento-select{padding:6px 4px;border:2px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:600;background:#fff;color:#64748b;cursor:pointer;transition:all .2s}.tipo-descuento-select:focus{outline:none;border-color:#f59e0b}.tipo-descuento-select:hover{border-color:#cbd5e0}.btn-eliminar-item{width:28px;height:28px;padding:0;border:1.5px solid #fecaca;background:#fff;color:#ef4444;border-radius:6px;font-size:20px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.tipo-precio-select{padding:6px 10px;border:2px solid #e2e8f0;border-radius:6px;font-size:13px;font-weight:600;color:#1e293b;background:#fff;cursor:pointer;transition:all .2s;min-width:110px}.tipo-precio-select:focus{outline:none;border-color:#6366f1;background:#f8fafc}.tipo-precio-select:hover{border-color:#cbd5e1}.ventas-panel-resumen{position:sticky;top:20px}.resumen-cliente,.resumen-forma-pago,.resumen-tipo-comprobante,.resumen-observaciones{margin-bottom:20px}.resumen-cliente label,.resumen-forma-pago label,.resumen-tipo-comprobante label,.resumen-observaciones label{display:block;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.cliente-seleccionado{padding:12px 16px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:600;color:#1e293b}.forma-pago-select,.tipo-comprobante-select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-weight:600;transition:all .2s;background:#fafbfc;color:#1e293b}.forma-pago-select:focus,.tipo-comprobante-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.observaciones-textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.resumen-descuento-global{margin-bottom:20px;padding:16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:10px}.resumen-descuento-global label{display:block;font-size:13px;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.descuento-global-control{display:flex;align-items:center;gap:8px}.descuento-global-control .descuento-input{flex:1;width:auto;font-size:16px;font-weight:700;color:#92400e;background:#fff;border:2px solid #fbbf24}.descuento-global-control .descuento-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.descuento-global-control .tipo-descuento-select{width:60px;padding:10px 6px;font-size:14px;font-weight:700;color:#92400e;background:#fff;border:2px solid #fbbf24}.descuento-global-control .tipo-descuento-select:focus{border-color:#f59e0b}.descuento-global-control .descuento-input:disabled,.descuento-global-control .tipo-descuento-select:disabled{opacity:.5;cursor:not-allowed}.total-row.descuento{color:#dc2626;font-weight:600}.total-row.descuento .total-valor{color:#dc2626}.total-valor-final{font-size:28px;font-weight:800;color:#6366f1}.btn-confirmar-venta{width:100%;padding:16px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.btn-confirmar-venta:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-confirmar-venta:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-cancelar-venta{width:100%;padding:14px 24px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancelar-venta:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e0;color:#475569}.btn-cancelar-venta:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.modal-header{padding:24px;border-bottom:2px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:20px;font-weight:700;color:#1e293b;margin:0}.modal-close{width:32px;height:32px;border:none;background:#f1f5f9;color:#64748b;border-radius:8px;font-size:24px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#e2e8f0;color:#1e293b}.modal-body{padding:24px}.modal-footer{padding:20px 24px;border-top:2px solid #f1f5f9;display:flex;gap:12px;justify-content:flex-end}@media(max-width:1200px){.ventas-layout{grid-template-columns:1fr 350px;gap:20px}}.venta-seccion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.btn-nuevo-cliente{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #6366f14d}.btn-nuevo-cliente:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-nuevo-cliente:active{transform:translateY(0)}.btn-nuevo-cliente svg{flex-shrink:0}@media(max-width:1024px){.ventas-layout{grid-template-columns:1fr}.ventas-panel-resumen{position:static}}@media(max-width:768px){.ventas-header .header-info h1{font-size:24px}.venta-seccion{padding:16px}.resumen-card{padding:20px}}@media(max-width:1024px)and (min-width:641px){.tabla-carrito th:nth-child(5),.tabla-carrito td:nth-child(5){display:none}.tabla-carrito th,.tabla-carrito td{padding:10px 8px;font-size:13px}.tipo-precio-select{min-width:90px;font-size:12px;padding:5px 8px}.cantidad-input{width:44px}}@media(max-width:640px){.tabla-carrito thead{display:none}.tabla-carrito,.tabla-carrito tbody{display:block;width:100%}.tabla-carrito tr{display:grid;grid-template-areas:"producto  producto    borrar" "stock     cantidad    tipoprecio" "precio    precio      subtotal";grid-template-columns:auto 1fr auto;gap:8px;padding:12px;margin-bottom:10px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;box-shadow:0 1px 4px #0000000f}.tabla-carrito tbody tr:hover{background:#fff}.tabla-carrito td{padding:0;border:none;font-size:13px;display:flex;align-items:center}.tabla-carrito td.centrado,.tabla-carrito td.derecha{text-align:left;justify-content:flex-start}.tabla-carrito td:nth-child(1){grid-area:producto;flex-direction:column;align-items:flex-start}.tabla-carrito td:nth-child(2){grid-area:stock;align-self:center}.tabla-carrito td:nth-child(3){grid-area:cantidad;justify-content:center;align-self:center}.tabla-carrito td:nth-child(4){grid-area:tipoprecio;justify-content:flex-end;align-self:center}.tabla-carrito td:nth-child(5){grid-area:precio;font-size:12px;color:#94a3b8;align-self:center}.tabla-carrito td:nth-child(5):before{content:"P.unit: ";font-weight:600;margin-right:2px}.tabla-carrito td:nth-child(6){grid-area:subtotal;justify-content:flex-end;align-self:center;font-size:15px;font-weight:800;color:#6366f1}.tabla-carrito td:nth-child(7){grid-area:borrar;justify-content:flex-end;align-items:flex-start}.cantidad-control{gap:4px}.btn-cantidad{width:26px;height:26px;font-size:14px;padding:0}.cantidad-input{width:40px;padding:4px 6px;font-size:13px}.tipo-precio-select{min-width:unset;width:auto;max-width:100px;font-size:12px;padding:5px 6px}}.input-select-busqueda:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.opcion-item:hover{background-color:#f8fafc;color:#6366f1}.opcion-item.seleccionado{background-color:#eef2ff;color:#6366f1;font-weight:600}.opcion-item.seleccionado:after{content:"✓";float:right;color:#6366f1;font-weight:700}.opcion-item em{color:#64748b;font-style:italic;font-weight:500}.compras-container{width:100%;max-width:100%;margin:0;padding:0;min-height:100vh}.compras-header{margin-bottom:24px}.compras-header .header-info h1{font-size:32px;font-weight:800;color:#1e293b;margin:0 0 4px}.compras-header .header-info p{font-size:15px;color:#64748b;margin:0}.compras-layout{display:grid;grid-template-columns:1fr 400px;gap:24px;align-items:start}.compras-panel-principal{display:flex;flex-direction:column;gap:20px}.compra-seccion{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0}.compra-label{display:block;font-size:14px;font-weight:600;color:#334155;margin-bottom:8px}.compra-select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;transition:all .2s;background:#fafbfc;color:#1e293b}.compra-select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;background:#fff}.buscador-productos{position:relative;display:flex;align-items:center}.buscador-productos svg{position:absolute;left:14px;color:#94a3b8;pointer-events:none}.buscador-input{width:100%;padding:14px 16px 14px 44px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:all .2s;background:#fafbfc}.buscador-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;background:#fff}.buscando-spinner{position:absolute;right:14px;font-size:18px}.resultados-busqueda{margin-top:12px;max-height:400px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:10px;background:#fff;box-shadow:0 4px 12px #00000014}.resultados-busqueda::-webkit-scrollbar{width:8px}.resultados-busqueda::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.resultados-busqueda::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.resultados-busqueda::-webkit-scrollbar-thumb:hover{background:#94a3b8}.resultados-header{padding:12px 16px;background:linear-gradient(135deg,#f0fdf4,#d1fae5);border-bottom:1px solid #e2e8f0;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;z-index:1}.resultados-titulo{font-size:13px;font-weight:700;color:#1e293b;text-transform:uppercase;letter-spacing:.05em}.resultados-subtitulo{font-size:12px;color:#64748b}.resultado-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:all .15s;border-bottom:1px solid #f1f5f9}.resultado-item:last-child{border-bottom:none}.resultado-item:hover{background:#f0fdf4}.resultado-info{flex:1}.resultado-nombre{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:4px}.resultado-detalles{font-size:12px;color:#64748b}.btn-agregar-rapido{width:32px;height:32px;border:none;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:8px;font-size:20px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-agregar-rapido:hover{transform:scale(1.1);box-shadow:0 4px 12px #10b98166}.carrito-seccion{min-height:400px}.carrito-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.carrito-header h3{font-size:18px;font-weight:700;color:#1e293b;margin:0}.btn-limpiar-carrito{padding:8px 16px;background:#fff;color:#ef4444;border:1.5px solid #fecaca;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-limpiar-carrito:hover{background:#fef2f2;border-color:#ef4444}.carrito-vacio{text-align:center;padding:60px 20px;color:#cbd5e1}.carrito-vacio svg{margin-bottom:16px}.carrito-vacio p{font-size:16px;font-weight:600;color:#64748b;margin:0 0 8px}.carrito-vacio span{font-size:13px;color:#94a3b8}.carrito-items{overflow-x:auto}.tabla-carrito{width:100%;border-collapse:collapse}.tabla-carrito thead{background:#f0fdf4;border-bottom:2px solid #d1fae5}.tabla-carrito th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;color:#047857;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.tabla-carrito td{padding:16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155}.tabla-carrito tbody tr:hover{background:#f0fdf4}.centrado{text-align:center}.derecha{text-align:right}.item-nombre{font-weight:600;color:#1e293b;margin-bottom:4px}.item-variante{font-size:12px;color:#64748b}.stock-badge{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-radius:6px;font-size:12px;font-weight:700}.cantidad-control{display:flex;align-items:center;gap:8px;justify-content:center}.btn-cantidad{width:28px;height:28px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-cantidad:hover:not(:disabled){background:#f0fdf4;border-color:#10b981;color:#1e293b}.btn-cantidad:disabled{opacity:.4;cursor:not-allowed}.cantidad-input{width:60px;padding:6px 8px;border:2px solid #e2e8f0;border-radius:6px;text-align:center;font-size:14px;font-weight:600}.cantidad-input:focus{outline:none;border-color:#10b981}.cantidad-input::-webkit-inner-spin-button,.cantidad-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.precio-input{width:100px;padding:6px 8px;border:2px solid #e2e8f0;border-radius:6px;text-align:right;font-size:14px;font-weight:600;color:#1e293b;transition:all .2s}.precio-input:focus{outline:none;border-color:#10b981;background:#f0fdf4}.precio-input::-webkit-inner-spin-button,.precio-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.precio-subtotal{font-weight:700;color:#1e293b;font-size:15px}.btn-eliminar-item{width:28px;height:28px;border:1.5px solid #fecaca;background:#fff;color:#ef4444;border-radius:6px;font-size:20px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-eliminar-item:hover{background:#fef2f2;border-color:#ef4444}.compras-panel-resumen{position:sticky;top:20px}.resumen-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;border:1px solid #e2e8f0;padding:24px}.resumen-card h3{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 20px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.resumen-proveedor,.resumen-tipo-comprobante,.resumen-numero-comprobante,.resumen-observaciones{margin-bottom:20px}.resumen-proveedor label,.resumen-tipo-comprobante label,.resumen-numero-comprobante label,.resumen-observaciones label{display:block;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.tipo-comprobante-select,.numero-comprobante-input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-weight:600;transition:all .2s;background:#fafbfc;color:#1e293b}.tipo-comprobante-select:focus,.numero-comprobante-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;background:#fff}.observaciones-textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;resize:vertical;transition:all .2s;background:#fafbfc;color:#1e293b}.observaciones-textarea:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;background:#fff}.resumen-totales{margin:24px 0;padding:20px 0;border-top:2px solid #e2e8f0;border-bottom:2px solid #e2e8f0}.total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;color:#64748b}.total-row:last-child{margin-bottom:0}.total-final{margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.total-final span{font-size:18px;font-weight:800;color:#1e293b}.total-valor{font-weight:700;color:#334155}.impacto-positivo{color:#10b981;font-weight:800}.total-valor-final{font-size:28px;font-weight:800;color:#10b981}.resumen-acciones{display:flex;flex-direction:column;gap:12px}.btn-confirmar-compra{width:100%;padding:16px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.btn-confirmar-compra:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-confirmar-compra:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-cancelar-compra{width:100%;padding:14px 24px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancelar-compra:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e0;color:#475569}.btn-cancelar-compra:disabled{opacity:.5;cursor:not-allowed}.compra-seccion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.btn-nuevo-proveedor{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #10b9814d}.btn-nuevo-proveedor:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.btn-nuevo-proveedor:active{transform:translateY(0)}.btn-nuevo-proveedor svg{flex-shrink:0}.select-busqueda{position:relative;width:100%}.input-select-busqueda{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;color:#1e293b;transition:all .2s cubic-bezier(.4,0,.2,1);background-color:#fafbfc;box-sizing:border-box;cursor:pointer}.input-select-busqueda:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;background:#fff}.input-select-busqueda:hover:not(:disabled){border-color:#cbd5e1}.input-select-busqueda:disabled{background-color:#f8fafc;color:#94a3b8;cursor:not-allowed;border-color:#e2e8f0}.input-select-busqueda::placeholder{color:#94a3b8}.input-select-busqueda.input-error,.numero-comprobante-input.input-error{border-color:#ef4444;background:#fef2f2}.opciones-desplegables{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:250px;overflow-y:auto;background:#fff;border:2px solid #e2e8f0;border-radius:10px;box-shadow:0 10px 25px #0000001a;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.opcion-item{padding:12px 16px;cursor:pointer;font-size:14px;color:#1e293b;transition:all .15s ease;border-bottom:1px solid #f1f5f9}.opcion-item:last-child{border-bottom:none}.opcion-item:hover{background-color:#f0fdf4;color:#10b981}.opcion-item.seleccionado{background-color:#d1fae5;color:#10b981;font-weight:600}.opcion-item.seleccionado:after{content:"✓";float:right;color:#10b981;font-weight:700}.opcion-item.sin-resultados{color:#94a3b8;font-style:italic;cursor:default;text-align:center}.opcion-item.sin-resultados:hover{background-color:transparent;color:#94a3b8}.opcion-secundaria{color:#64748b;font-size:13px;font-weight:400}.opciones-desplegables::-webkit-scrollbar{width:8px}.opciones-desplegables::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.opciones-desplegables::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.opciones-desplegables::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(max-width:1200px){.compras-layout{grid-template-columns:1fr 350px;gap:20px}}@media(max-width:1024px){.compras-layout{grid-template-columns:1fr}.compras-panel-resumen{position:static}}@media(max-width:768px){.compras-header .header-info h1{font-size:24px}.compra-seccion{padding:16px}.tabla-carrito th,.tabla-carrito td{padding:12px 8px;font-size:13px}.cantidad-input{width:50px}.precio-input{width:80px}.resumen-card{padding:20px}}@media(max-width:768px){.historial-compras .carrito-items{overflow:visible}.historial-compras .tabla-carrito thead{display:none}.historial-compras .tabla-carrito,.historial-compras .tabla-carrito tbody{display:block;width:100%}.historial-compras .tabla-carrito tr{display:grid;grid-template-areas:"id       estado" "proveedor proveedor" "fecha    total" "tipo     comprobante" "acciones acciones";grid-template-columns:1fr 1fr;gap:8px;padding:16px;margin-bottom:12px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;box-shadow:0 1px 4px #0000000f}.historial-compras .tabla-carrito tbody tr:hover{background:#fff}.historial-compras .tabla-carrito td{padding:0;border:none;font-size:13px;display:flex;flex-direction:column;align-items:flex-start}.historial-compras .tabla-carrito td.derecha,.historial-compras .tabla-carrito td.centrado{text-align:left}.historial-compras .tabla-carrito td:nth-child(1){grid-area:id}.historial-compras .tabla-carrito td:nth-child(1):before{content:"ID";font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.historial-compras .tabla-carrito td:nth-child(2){grid-area:fecha}.historial-compras .tabla-carrito td:nth-child(2):before{content:"Fecha";font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.historial-compras .tabla-carrito td:nth-child(3){grid-area:proveedor;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.historial-compras .tabla-carrito td:nth-child(3) .item-nombre{font-size:15px;font-weight:700;color:#1e293b}.historial-compras .tabla-carrito td:nth-child(4){grid-area:tipo}.historial-compras .tabla-carrito td:nth-child(4):before{content:"Tipo";font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.historial-compras .tabla-carrito td:nth-child(5){grid-area:comprobante}.historial-compras .tabla-carrito td:nth-child(5):before{content:"N° Comprob.";font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.historial-compras .tabla-carrito td:nth-child(6){grid-area:total;align-items:flex-end}.historial-compras .tabla-carrito td:nth-child(6):before{content:"Total";font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.historial-compras .tabla-carrito td:nth-child(6).precio-subtotal{font-size:15px;font-weight:800;color:#10b981}.historial-compras .tabla-carrito td:nth-child(7){grid-area:estado;align-items:flex-end}.historial-compras .tabla-carrito td:nth-child(8){grid-area:acciones;padding-top:8px;border-top:1px solid #f1f5f9;align-items:center}.historial-compras .tabla-carrito td:nth-child(8) button{width:100%;justify-content:center}}@media(max-width:640px){.historial-compras div[style*="justify-content: center"]{flex-wrap:wrap}}.ajuste-stock-container{padding:24px;max-width:1400px;margin:0 auto}.ajuste-stock-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.ajuste-stock-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.vista-botones{display:flex;gap:12px}.vista-botones button{padding:10px 20px;border:2px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;font-weight:500;color:#4a5568;transition:all .2s}.vista-botones button:hover{border-color:#4299e1;color:#2b6cb0}.vista-botones button.activo{background:#4299e1;border-color:#4299e1;color:#fff}.mensaje{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-weight:500;animation:slideDown .3s ease}.mensaje-success{background:#c6f6d5;color:#22543d;border-left:4px solid #38a169}.mensaje-error{background:#fed7d7;color:#742a2a;border-left:4px solid #e53e3e}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pasos-indicador{display:flex;justify-content:center;align-items:center;gap:60px;margin:40px 0;padding:30px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.paso{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;opacity:.4;transition:opacity .3s}.paso.activo{opacity:1}.paso-numero{width:50px;height:50px;border-radius:50%;background:#e2e8f0;color:#718096;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;transition:all .3s}.paso.activo .paso-numero{background:#4299e1;color:#fff;box-shadow:0 4px 12px #4299e166}.paso-texto{font-size:14px;font-weight:500;color:#4a5568}.paso:not(:last-child):after{content:"";position:absolute;left:calc(100% + 10px);top:25px;width:60px;height:2px;background:#e2e8f0}.paso-contenido{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:30px;margin-top:20px}.motivo-form{max-width:600px;margin:0 auto}.motivo-form label{display:block;margin-bottom:8px;font-weight:600;color:#2d3748}.motivo-form textarea{width:100%;padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:border-color .2s}.motivo-form textarea:focus{outline:none;border-color:#4299e1}.motivo-form button{margin-top:20px;width:100%}.seleccion-container{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.seleccion-izquierda,.seleccion-derecha{background:#f7fafc;border-radius:8px;padding:20px;max-height:500px;display:flex;flex-direction:column}.seleccion-izquierda h3,.seleccion-derecha h3{margin:0 0 15px;font-size:18px;color:#2d3748}.busqueda-input{padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;margin-bottom:15px;font-size:14px;transition:border-color .2s}.busqueda-input:focus{outline:none;border-color:#4299e1}.lista-productos{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.producto-item{padding:12px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.producto-item:hover{border-color:#4299e1;transform:translate(4px)}.producto-item.seleccionado{background:#ebf8ff;border-color:#4299e1}.producto-codigo{font-size:12px;color:#718096;font-weight:500}.producto-nombre{font-size:14px;color:#2d3748;font-weight:600;margin-top:4px}.lista-variantes{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.variante-item{padding:15px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;align-items:center;gap:15px}.variante-info{flex:1}.variante-detalles{display:flex;gap:12px;margin-bottom:6px}.variante-talla,.variante-color{font-size:13px;color:#4a5568;background:#edf2f7;padding:4px 10px;border-radius:4px}.variante-stock{font-size:14px;color:#2d3748}.variante-stock strong{color:#4299e1;font-size:16px}.variante-acciones{display:flex;gap:8px;align-items:center}.input-cantidad{width:100px;padding:8px;border:2px solid #e2e8f0;border-radius:6px;text-align:center;font-size:14px;font-weight:600}.input-cantidad:focus{outline:none;border-color:#4299e1}.btn-agregar{padding:8px 16px;background:#48bb78;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-agregar:hover:not(:disabled){background:#38a169}.btn-agregar:disabled{background:#cbd5e0;cursor:not-allowed}.sin-seleccion{text-align:center;color:#a0aec0;padding:40px 20px;font-style:italic}.carrito-ajustes{background:#f7fafc;border-radius:8px;padding:20px}.carrito-ajustes h3{margin:0 0 15px;font-size:18px;color:#2d3748}.carrito-vacio{text-align:center;color:#a0aec0;padding:30px;font-style:italic}.tabla-carrito{width:100%;border-collapse:collapse;margin-bottom:20px}.tabla-carrito th,.tabla-carrito td{padding:12px;text-align:left;border-bottom:1px solid #e2e8f0}.tabla-carrito th{background:#fff;font-weight:600;color:#4a5568;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.tabla-carrito td{font-size:14px;color:#2d3748}.ajuste-positivo{color:#38a169;font-weight:600}.ajuste-negativo{color:#e53e3e;font-weight:600}.stock-final{font-weight:600;color:#2b6cb0}.stock-historico{color:#805ad5;font-weight:500;background:#f5f3ff}.stock-actual{color:#2b6cb0;font-weight:500;font-style:italic}.btn-eliminar{background:#fc8181;color:#fff;border:none;border-radius:4px;padding:6px 10px;cursor:pointer;font-size:16px;transition:background .2s}.btn-eliminar:hover{background:#f56565}.carrito-acciones{display:flex;justify-content:flex-end;gap:12px}.confirmacion-container{max-width:900px;margin:0 auto}.confirmacion-container h3{font-size:22px;color:#2d3748;margin-bottom:20px}.confirmacion-info{background:#edf2f7;padding:15px;border-radius:8px;margin-bottom:20px}.confirmacion-info p{margin:8px 0;color:#2d3748}.tabla-confirmacion{width:100%;border-collapse:collapse;margin-bottom:30px}.tabla-confirmacion th,.tabla-confirmacion td{padding:12px;text-align:left;border-bottom:1px solid #e2e8f0}.tabla-confirmacion th{background:#edf2f7;font-weight:600;color:#4a5568}.confirmacion-acciones{display:flex;justify-content:flex-end;gap:12px}.btn-primary,.btn-secondary,.btn-confirmar{padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s}.btn-primary{background:#4299e1;color:#fff}.btn-primary:hover:not(:disabled){background:#3182ce;transform:translateY(-1px);box-shadow:0 4px 12px #4299e14d}.btn-primary:disabled{background:#cbd5e0;cursor:not-allowed}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover{background:#cbd5e0}.btn-confirmar{background:#48bb78;color:#fff}.btn-confirmar:hover:not(:disabled){background:#38a169;transform:translateY(-1px);box-shadow:0 4px 12px #48bb784d}.btn-confirmar:disabled{background:#cbd5e0;cursor:not-allowed}.historial-container h3{font-size:20px;color:#2d3748;margin-bottom:20px}.sin-historial{text-align:center;color:#a0aec0;padding:40px;font-style:italic}.tabla-historial{width:100%;border-collapse:collapse;background:#fff}.tabla-historial th,.tabla-historial td{padding:15px;text-align:left;border-bottom:1px solid #e2e8f0}.tabla-historial th{background:#f7fafc;font-weight:600;color:#4a5568;font-size:13px;text-transform:uppercase}.tabla-historial td{font-size:14px;color:#2d3748}.btn-ver{background:#4299e1;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-ver:hover{background:#3182ce}.modal-detalles{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-contenido{background:#fff;border-radius:12px;padding:30px;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;position:relative;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-contenido h3{margin:0 0 20px;font-size:22px;color:#2d3748}.modal-contenido p{margin:8px 0;color:#4a5568}.modal-cerrar{position:absolute;top:20px;right:20px;background:#e2e8f0;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:20px;color:#4a5568;transition:background .2s}.modal-cerrar:hover{background:#cbd5e0}.tabla-detalles{width:100%;border-collapse:collapse;margin-top:20px}.tabla-detalles th,.tabla-detalles td{padding:12px;text-align:left;border-bottom:1px solid #e2e8f0}.tabla-detalles th{background:#f7fafc;font-weight:600;color:#4a5568;font-size:13px}.tabla-detalles td{font-size:14px;color:#2d3748}.lista-productos::-webkit-scrollbar,.lista-variantes::-webkit-scrollbar,.modal-contenido::-webkit-scrollbar{width:8px}.lista-productos::-webkit-scrollbar-track,.lista-variantes::-webkit-scrollbar-track,.modal-contenido::-webkit-scrollbar-track{background:#edf2f7;border-radius:4px}.lista-productos::-webkit-scrollbar-thumb,.lista-variantes::-webkit-scrollbar-thumb,.modal-contenido::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.lista-productos::-webkit-scrollbar-thumb:hover,.lista-variantes::-webkit-scrollbar-thumb:hover,.modal-contenido::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media(max-width:1024px){.seleccion-container{grid-template-columns:1fr}}@media(max-width:768px){.ajuste-stock-header{flex-direction:column;gap:15px;align-items:flex-start}.pasos-indicador{gap:20px;padding:20px}.paso:not(:last-child):after{display:none}.tabla-carrito,.tabla-confirmacion,.tabla-historial{font-size:12px}.tabla-carrito th,.tabla-carrito td,.tabla-confirmacion th,.tabla-confirmacion td{padding:8px}}*{margin:0;padding:0;box-sizing:border-box}.impresion-container{background-color:#f5f5f5;min-height:100vh;width:100vw;padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;font-family:Courier New,monospace;position:relative;overflow-x:hidden}.impresion-ticket{background-color:#fff;width:80mm;padding:10mm;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;font-size:12px;line-height:1.4;color:#000}.impresion-cargando,.impresion-error{text-align:center;padding:40px;font-size:16px}.impresion-error{color:#e53e3e}.ticket-header{text-align:center;margin-bottom:10px}.ticket-logo{width:40mm;height:auto;display:block;margin:0 auto 6px;object-fit:contain}.ticket-empresa{font-size:18px;font-weight:700;margin:0 0 5px;letter-spacing:1px}.ticket-info{font-size:11px;margin:2px 0}.ticket-separador{text-align:center;margin:8px 0;font-weight:700;overflow:hidden;white-space:nowrap}.ticket-tipo{text-align:center;margin:10px 0}.ticket-tipo h2{font-size:16px;font-weight:700;margin:0 0 5px;letter-spacing:2px}.ticket-tipo p{font-size:12px;margin:0}.ticket-datos{margin:10px 0}.ticket-datos p{margin:4px 0;font-size:11px}.ticket-datos strong{font-weight:700}.ticket-items{margin:10px 0}.ticket-tabla{width:100%;border-collapse:collapse;font-size:10px}.ticket-tabla thead th{border-bottom:1px solid #000;padding:4px 2px;font-weight:700;text-align:left}.ticket-tabla tbody td{padding:4px 2px;vertical-align:top}.col-desc{width:45%;text-align:left}.col-cant{width:15%;text-align:center}.col-precio,.col-total{width:20%;text-align:right}.item-nombre{font-weight:700;margin-bottom:2px}.item-detalle{font-size:9px;color:#555}.ticket-totales{margin:10px 0}.total-row{display:flex;justify-content:space-between;padding:3px 0;font-size:12px}.total-final{font-size:14px;font-weight:700;border-top:2px solid #000;border-bottom:2px solid #000;padding:6px 0;margin-top:5px}.ticket-observaciones{margin:10px 0;font-size:11px}.ticket-observaciones p{margin:3px 0}.ticket-footer{text-align:center;margin:15px 0 10px;font-size:11px}.ticket-footer p{margin:3px 0}.ticket-barcode{text-align:center;margin-top:15px}.barcode-text{font-family:"Libre Barcode 128",Courier New,monospace;font-size:24px;letter-spacing:2px;margin:0}.impresion-acciones{display:flex;gap:15px;margin-top:20px}.btn-imprimir,.btn-cerrar{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-imprimir{background-color:#3b82f6;color:#fff}.btn-imprimir:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.btn-cerrar{background-color:#6b7280;color:#fff}.btn-cerrar:hover{background-color:#4b5563;transform:translateY(-1px);box-shadow:0 4px 8px #6b72804d}@media print{body{margin:0;padding:0}.impresion-container{background:#fff;padding:0;min-height:auto}.impresion-ticket{width:80mm;max-width:80mm;box-shadow:none;margin:0;padding:5mm}.impresion-acciones{display:none!important}.ticket-empresa{font-size:16px}.ticket-tipo h2{font-size:14px}.ticket-tabla{font-size:9px}.impresion-ticket,.ticket-items{page-break-inside:avoid}*{color:#000!important;background:transparent!important}.ticket-separador,.total-final{border-color:#000!important}}@media screen and (max-width:480px){.impresion-container{padding:10px}.impresion-ticket{width:100%;max-width:80mm}.impresion-acciones{flex-direction:column;width:100%;max-width:80mm}.btn-imprimir,.btn-cerrar{width:100%}}.reporte-container{padding:20px;max-width:1400px;margin:0 auto}.reporte-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap}.reporte-header h2{margin:0 0 4px;color:#1e293b;font-size:24px;font-weight:700}.reporte-subtitulo{margin:0;color:#64748b;font-size:14px}.reporte-filtros{display:flex;align-items:flex-end;gap:12px;margin-bottom:24px;flex-wrap:wrap;background:#fff;padding:16px 20px;border-radius:12px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0}.filtro-grupo{display:flex;flex-direction:column;gap:4px}.filtro-grupo label{font-size:12px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em}.filtro-grupo input[type=date]{padding:8px 12px;border:1.5px solid #cbd5e1;border-radius:8px;font-size:14px;color:#334155;background:#f8fafc;transition:border-color .15s;min-width:150px}.filtro-grupo input[type=date]:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.btn-reporte-buscar{padding:8px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-reporte-buscar:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-reporte-buscar:disabled{opacity:.6;cursor:not-allowed;transform:none}.filtros-rapidos{display:flex;gap:6px;flex-wrap:wrap;width:100%;margin-top:4px}.btn-rapido{padding:5px 12px;background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;color:#475569;cursor:pointer;transition:all .15s}.btn-rapido:hover{background:#e0e7ff;border-color:#a5b4fc;color:#4338ca}.btn-rapido-activo{background:#6366f1;color:#fff;border-color:#6366f1}.btn-rapido-activo:hover{background:#4f46e5;border-color:#4f46e5;color:#fff}.reporte-cargando{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#64748b}.reporte-cargando .spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.reporte-error{background:#fef2f2;color:#dc2626;padding:14px 20px;border-radius:10px;border:1px solid #fecaca;margin-bottom:20px;font-size:14px;font-weight:500}.kpis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:flex-start;gap:14px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;transition:box-shadow .2s}.kpi-card:hover{box-shadow:0 4px 12px #00000014}.kpi-icono{width:44px;height:44px;min-width:44px;border-radius:10px;display:flex;align-items:center;justify-content:center}.kpi-info{display:flex;flex-direction:column;gap:2px;min-width:0}.kpi-label{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.kpi-valor{font-size:22px;font-weight:700;color:#1e293b;line-height:1.2;word-break:break-word}.kpi-detalle{font-size:12px;color:#94a3b8;margin-top:2px}.kpi-ventas .kpi-icono{background:#ede9fe;color:#7c3aed}.kpi-ticket .kpi-icono{background:#e0f2fe;color:#0284c7}.kpi-ganancia .kpi-icono{background:#dcfce7;color:#16a34a}.kpi-anuladas .kpi-icono{background:#fee2e2;color:#dc2626}.kpi-productos .kpi-icono{background:#ede9fe;color:#7c3aed}.kpi-stock .kpi-icono{background:#e0f2fe;color:#0284c7}.kpi-valor .kpi-icono{background:#dcfce7;color:#16a34a}.kpi-alertas .kpi-icono{background:#fef3c7;color:#d97706}.info-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;color:#1e40af;font-size:13px;margin-bottom:24px}.info-banner-success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.reporte-seccion{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0}.reporte-seccion-alerta{border-color:#fecaca;background:#fffbfb}.seccion-titulo{display:flex;align-items:center;gap:10px;margin:0 0 16px;font-size:16px;font-weight:700;color:#1e293b}.seccion-titulo svg{color:#6366f1;flex-shrink:0}.seccion-titulo-alerta svg{color:#dc2626}.seccion-titulo-warning svg{color:#d97706}.seccion-descripcion{color:#64748b;font-size:13px;margin:-8px 0 16px 30px;line-height:1.5}.sin-datos{color:#94a3b8;text-align:center;padding:30px;font-size:14px}.reporte-grid-2col{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}@media(min-width:900px){.reporte-grid-2col{grid-template-columns:1fr 1fr}.reporte-grid-2col .reporte-seccion{margin-bottom:0}}.tabla-reporte{overflow-x:auto;-webkit-overflow-scrolling:touch}.tabla-reporte table{width:100%;border-collapse:collapse;font-size:13px}.tabla-reporte thead th{padding:12px 14px;text-align:left;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#1e293b;background:#eef2f7;border-bottom:2px solid #cbd5e1;white-space:nowrap}.tabla-reporte tbody td{padding:12px 14px;border-bottom:1px solid #e2e8f0;color:#1e293b;vertical-align:middle}.tabla-reporte tbody tr:nth-child(2n){background:#f8fafc}.tabla-reporte tbody tr:hover{background:#eef2ff}.tabla-reporte tbody tr:last-child td{border-bottom:none}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.text-muted{color:#94a3b8}.text-success{color:#16a34a;font-weight:600}.text-danger{color:#dc2626;font-weight:600}.text-warning{color:#d97706;font-weight:600}.nombre-truncado{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#f1f5f9;border-radius:6px;font-size:11px;font-weight:700;color:#475569}.badge-forma-pago{display:inline-block;padding:3px 10px;background:#e0e7ff;color:#4338ca;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.variante-badge{display:inline-block;padding:2px 8px;background:#f1f5f9;color:#475569;border-radius:4px;font-size:12px}.badge-stock{display:inline-block;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.05em}.badge-sin-stock{background:#fee2e2;color:#dc2626}.badge-stock-bajo{background:#fef3c7;color:#d97706}.fila-critica{background:#fff5f5!important}.fila-advertencia{background:#fffbeb!important}.barra-porcentaje-container{display:flex;align-items:center;gap:8px;min-width:100px}.barra-porcentaje-container span{font-size:12px;font-weight:600;color:#475569;white-space:nowrap;min-width:40px;text-align:right}.barra-porcentaje{height:6px;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:3px;min-width:2px;transition:width .5s ease}.grafico-barras{display:flex;align-items:flex-end;gap:4px;height:260px;padding:10px 0 0;overflow-x:auto;-webkit-overflow-scrolling:touch}.barra-dia{display:flex;flex-direction:column;align-items:center;flex:1;min-width:36px;max-width:80px;height:100%}.barra-valor{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;position:relative}.barra-fill{width:70%;min-height:4px;background:linear-gradient(180deg,#6366f1,#818cf8);border-radius:4px 4px 0 0;position:relative;transition:height .5s ease;cursor:pointer}.barra-fill:hover{background:linear-gradient(180deg,#4f46e5,#6366f1)}.barra-monto{position:absolute;top:-22px;left:50%;transform:translate(-50%);font-size:9px;font-weight:600;color:#475569;white-space:nowrap}.barra-label{font-size:11px;color:#1e293b;margin-top:6px;white-space:nowrap;font-weight:700;line-height:1}.barra-fecha{font-size:9px;color:#94a3b8;white-space:nowrap;font-weight:500;margin-top:1px}.barra-cantidad{font-size:9px;color:#94a3b8;font-weight:600}.distribucion-lista{display:flex;flex-direction:column;gap:12px}.distribucion-item{display:flex;flex-direction:column;gap:4px}.distribucion-header{display:flex;justify-content:space-between;align-items:baseline}.distribucion-nombre{font-size:13px;font-weight:600;color:#334155}.distribucion-meta{font-size:11px;color:#94a3b8}.distribucion-barra-bg{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.distribucion-barra{height:100%;background:linear-gradient(90deg,#6366f1,#818cf8);border-radius:4px;min-width:2px;transition:width .5s ease}.distribucion-barra-alt{background:linear-gradient(90deg,#0ea5e9,#38bdf8)}.distribucion-valor{font-size:12px;font-weight:600;color:#475569;font-family:SF Mono,Fira Code,monospace}.reporte-resumen-final{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:12px;padding:24px;margin-top:8px;color:#fff}.resumen-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1)}.resumen-item:last-child{border-bottom:none}.resumen-label{font-size:13px;color:#ffffffb3}.resumen-valor{font-size:15px;font-weight:700;color:#fff;font-family:SF Mono,Fira Code,monospace}.resumen-positivo{color:#4ade80}.resumen-negativo{color:#f87171}@media(max-width:640px){.reporte-container{padding:12px}.reporte-header{flex-direction:column;gap:12px}.reporte-header h2{font-size:20px}.reporte-filtros{flex-direction:column;align-items:stretch}.filtro-grupo input[type=date]{width:100%;min-width:unset}.kpis-grid{grid-template-columns:1fr}.kpi-valor{font-size:18px}.reporte-seccion{padding:14px}.seccion-titulo{font-size:14px}.tabla-reporte{font-size:12px}.nombre-truncado{max-width:140px}.grafico-barras{height:200px}.barra-dia{min-width:28px}.reporte-resumen-final{padding:16px}.resumen-item{flex-direction:column;align-items:flex-start;gap:4px}.resumen-valor{font-size:14px}}@media(max-width:480px){.kpis-grid{grid-template-columns:1fr;gap:10px}.kpi-card{padding:14px}.barra-monto{display:none}}.input-busqueda-reporte{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;width:100%;transition:border-color .2s}.input-busqueda-reporte:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.select-reporte{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;background:#fff;cursor:pointer;min-width:140px}.select-reporte:focus{outline:none;border-color:#6366f1}.stock-controles{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:0 4px}.stock-controles-info{font-size:13px;color:#64748b}.stock-lista{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.stock-producto{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;transition:box-shadow .2s}.stock-producto:hover{box-shadow:0 2px 8px #0000000f}.stock-producto-agotado{border-left:3px solid #ef4444}.stock-producto-bajo{border-left:3px solid #f59e0b}.stock-producto-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;cursor:pointer;gap:16px;-webkit-user-select:none;user-select:none}.stock-producto-header:hover{background:#f8fafc}.stock-producto-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.stock-expand-icon{flex-shrink:0;color:#94a3b8;transition:transform .2s}.stock-expand-icon-abierto{transform:rotate(90deg)}.stock-producto-nombre-grupo{display:flex;flex-direction:column;gap:2px;min-width:0}.stock-producto-nombre{font-weight:600;font-size:14px;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stock-producto-meta{font-size:12px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stock-codigo{font-family:SF Mono,Fira Code,monospace;background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:11px}.stock-meta-sep{margin:0 4px;opacity:.5}.stock-producto-resumen{display:flex;align-items:center;gap:16px;flex-shrink:0}.stock-producto-numeros{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.stock-numero-principal{font-weight:700;font-size:16px;color:#1e293b}.stock-numero-principal small{font-weight:400;font-size:11px;color:#94a3b8}.stock-numero-secundario{font-size:11px;color:#94a3b8}.stock-producto-valor{display:flex;flex-direction:column;align-items:flex-end;gap:1px;min-width:110px}.stock-valor-costo{font-weight:600;font-size:13px;color:#475569;font-family:SF Mono,Fira Code,monospace}.stock-valor-label{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.stock-variantes{border-top:1px solid #f1f5f9;padding:0;overflow-x:auto}.stock-variantes-tabla{width:100%;border-collapse:collapse;font-size:12px}.stock-variantes-tabla th{background:#eef2f7;padding:8px 12px;text-align:left;font-weight:700;color:#334155;font-size:11px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-bottom:2px solid #cbd5e1}.stock-variantes-tabla td{padding:8px 12px;border-bottom:1px solid #e2e8f0;color:#1e293b;white-space:nowrap}.stock-variantes-tabla tbody tr:hover{background:#f8fafc}.stock-variantes-total{background:#f1f5f9}.stock-variantes-total td{border-bottom:none;padding:10px 12px}.stock-cantidad{display:inline-block;padding:2px 8px;border-radius:6px;font-weight:700;font-size:13px;min-width:32px;text-align:center}.stock-cantidad-ok{background:#ecfdf5;color:#059669}.stock-cantidad-bajo{background:#fef3c7;color:#d97706}.stock-cantidad-cero{background:#fee2e2;color:#dc2626}.badge-stock-ok{background:#ecfdf5;color:#059669}.reporte-error{background:#fee2e2;color:#b91c1c;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}@media(max-width:768px){.stock-producto-header{flex-direction:column;align-items:flex-start;padding:12px 14px;gap:10px}.stock-producto-resumen{width:100%;justify-content:space-between}.stock-producto-valor{min-width:auto}.stock-controles{flex-direction:column;align-items:flex-start;gap:8px}.stock-variantes{font-size:11px}.stock-variantes-tabla th,.stock-variantes-tabla td{padding:6px 8px}}.detalle-entidad-expandido{padding:16px 20px 20px}.detalle-resumen-rapido{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;padding:14px 16px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:10px;margin-bottom:16px;border:1px solid #e2e8f0}.detalle-resumen-item{display:flex;flex-direction:column;gap:2px}.detalle-resumen-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.detalle-resumen-valor{font-size:14px;font-weight:700;color:#1e293b;font-family:SF Mono,Fira Code,monospace}.detalle-resumen-destacado{color:#6366f1;font-size:16px}.detalle-transaccion{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;overflow:hidden;background:#fff;transition:box-shadow .2s}.detalle-transaccion:hover{box-shadow:0 2px 8px #0000000f}.detalle-transaccion:last-child{margin-bottom:0}.detalle-transaccion-anulada{border-color:#fecaca;background:#fffbfb;opacity:.7}.detalle-transaccion-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:12px;background:#f8fafc;border-bottom:1px solid #f1f5f9;flex-wrap:wrap}.detalle-transaccion-info{display:flex;flex-direction:column;gap:2px;min-width:0}.detalle-transaccion-numero{font-weight:700;font-size:13px;color:#1e293b}.detalle-transaccion-fecha{font-size:12px;color:#94a3b8}.detalle-transaccion-badges{display:flex;gap:6px;align-items:center}.detalle-badge-anulado{display:inline-block;padding:3px 8px;background:#fee2e2;color:#dc2626;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.05em}.detalle-transaccion-total{font-size:16px;font-weight:700;color:#1e293b;font-family:SF Mono,Fira Code,monospace;white-space:nowrap}.detalle-transaccion-descuento{padding:6px 16px 10px;font-size:12px;color:#d97706;font-weight:500;background:#fffbeb;border-top:1px solid #fef3c7}.detalle-transaccion-obs{padding:8px 16px;font-size:12px;color:#64748b;background:#f8fafc;border-top:1px solid #f1f5f9;font-style:italic}@media(max-width:640px){.detalle-entidad-expandido{padding:12px}.detalle-resumen-rapido{grid-template-columns:1fr 1fr;gap:8px;padding:10px 12px}.detalle-transaccion-header{flex-direction:column;align-items:flex-start;padding:10px 12px;gap:6px}.detalle-transaccion-total,.detalle-resumen-destacado{font-size:14px}}@media(max-width:480px){.detalle-resumen-rapido{grid-template-columns:1fr}}.reporte-tabs{display:flex;gap:4px;margin-bottom:20px;background:#f1f5f9;padding:4px;border-radius:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.reporte-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:none;border-radius:10px;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s;white-space:nowrap;flex:1;justify-content:center}.reporte-tab:hover{color:#334155;background:#fff9}.reporte-tab-activo{background:#fff;color:#1e293b;box-shadow:0 1px 3px #0000001a}.reporte-tab-activo:hover{background:#fff;color:#1e293b}.reporte-tab svg{flex-shrink:0}.reporte-tab-activo svg{color:#6366f1}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#fee2e2;color:#dc2626;border-radius:10px;font-size:11px;font-weight:700}.fila-clickeable{cursor:pointer;transition:background .15s}.fila-clickeable:hover{background:#f0f4ff!important}.fila-clickeable td{vertical-align:middle}.cliente-celda{display:flex;flex-direction:column;gap:1px}.cliente-celda-nombre{font-weight:600;color:#1e293b;font-size:13px}.cliente-celda-doc{font-size:11px;color:#94a3b8;font-family:SF Mono,Fira Code,monospace}.fila-detalle-productos td{padding:0!important;background:#f0f4ff;border-bottom:2px solid #c7d2fe;border-top:1px solid #c7d2fe}.fila-detalle-productos .stock-variantes-tabla{background:#f8faff}.fila-detalle-productos .stock-variantes-tabla th{background:#e8ecf7;color:#3730a3;border-bottom-color:#c7d2fe}.fila-detalle-productos .stock-variantes-tabla td{border-bottom-color:#dde3f0;color:#1e293b}.badge-dias-inactivo{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.02em}.badge-dias-moderado{background:#fef3c7;color:#d97706}.badge-dias-alto{background:#fed7aa;color:#c2410c}.badge-dias-critico{background:#fee2e2;color:#dc2626}.btn-volver-ficha{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:8px;font-size:13px;font-weight:600;color:#475569;cursor:pointer;transition:all .15s;margin-bottom:20px}.btn-volver-ficha:hover{background:#e2e8f0;color:#1e293b}.ficha-cliente-header{display:flex;align-items:center;gap:20px;padding:24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;margin-bottom:20px;color:#fff}.ficha-cliente-avatar{width:64px;height:64px;min-width:64px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ficha-cliente-info h2{margin:0 0 6px;font-size:22px;font-weight:700;color:#fff}.ficha-cliente-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:#ffffffd9}.ficha-cliente-meta strong{color:#fff9;font-weight:500}.ficha-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.ficha-stat-card{background:#fff;border-radius:10px;padding:16px 18px;display:flex;flex-direction:column;gap:4px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;transition:box-shadow .2s}.ficha-stat-card:hover{box-shadow:0 4px 12px #00000014}.ficha-stat-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.ficha-stat-valor{font-size:18px;font-weight:700;color:#1e293b;font-family:SF Mono,Fira Code,monospace}.ficha-stat-destacado{color:#6366f1}@media(max-width:640px){.reporte-tabs{flex-direction:column}.reporte-tab{justify-content:flex-start}.ficha-cliente-header{flex-direction:column;align-items:flex-start;padding:18px;gap:12px}.ficha-cliente-avatar{width:48px;height:48px;min-width:48px;font-size:22px}.ficha-cliente-info h2{font-size:18px}.ficha-cliente-meta{flex-direction:column;gap:4px}.ficha-stats-grid{grid-template-columns:1fr 1fr}.ficha-stat-valor{font-size:15px}}@media(max-width:480px){.ficha-stats-grid{grid-template-columns:1fr}}#root{width:100%;height:100%;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
