:root{--color-primario-h:220;--color-primario-s:89%;--color-primario-l:52%;--color-primario:hsl(var(--color-primario-h), var(--color-primario-s), var(--color-primario-l));--color-primario-hover:hsl(var(--color-primario-h), var(--color-primario-s), calc(var(--color-primario-l) - 8%));--color-primario-claro:hsl(var(--color-primario-h), 80%, 92%);--color-primario-fondo:hsl(var(--color-primario-h), 80%, 97%);--color-primario-medio:hsl(var(--color-primario-h), 70%, 84%);--color-primario-texto:hsl(var(--color-primario-h), var(--color-primario-s), 28%);--color-exito:#16a34a;--color-exito-texto:#166534;--color-exito-fondo:#dcfce7;--color-exito-borde:#bbf7d0;--color-error:#dc2626;--color-error-hover:#b91c1c;--color-error-fondo:#fef2f2;--color-error-fondo-alt:#fee2e2;--color-error-borde:#fecaca;--color-error-borde-alt:#ef4444;--color-advertencia:#f59e0b;--color-advertencia-texto:#854d0e;--color-advertencia-fondo:#fefce8;--color-advertencia-borde:#fde68a;--gris-900:#111827;--gris-700:#374151;--gris-500:#6b7280;--gris-400:#9ca3af;--gris-300:#d1d5db;--gris-200:#e5e7eb;--gris-100:#f3f4f6;--gris-50:#f9fafb;--fondo-app:#f5f7fa;--fondo-blanco:#fff;--radio-xs:6px;--radio-sm:8px;--radio-md:10px;--radio-lg:12px;--radio-xl:14px;--radio-2xl:18px;--borde-color:var(--gris-300);--borde-color-suave:var(--gris-200);--borde-grosor:1px;--borde-grosor-medio:1.5px;--sombra-sm:0 1px 4px #0000000f;--sombra-md:0 4px 12px #0000001f;--sombra-lg:0 12px 30px #00000038;--sombra-xl:0 24px 60px #00000047;--fuente-base:Arial, sans-serif;--texto-xs:11px;--texto-sm:12px;--texto-base:14px;--texto-md:16px;--texto-lg:18px;--texto-xl:20px;--texto-2xl:24px;--texto-3xl:28px;--sidebar-fondo:#111827;--sidebar-ancho:52px;--sidebar-ancho-open:260px;--transicion-rapida:.15s ease;--transicion-normal:.2s ease;--transicion-lenta:.3s ease;--modal-duracion:.28s;--modal-easing:cubic-bezier(.16, 1, .3, 1)}@keyframes modalEntrada{0%{opacity:0;transform:translateY(20px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes overlayEntrada{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--text:var(--gris-700);--text-h:var(--gris-900);--bg:var(--fondo-app);--border:var(--gris-200);--accent:var(--color-primario);--sans:var(--fuente-base);font-family:var(--fuente-base);color:var(--gris-700);background:var(--fondo-app);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--fondo-app)}#root{box-sizing:border-box;min-height:100vh;display:block}h1,h2{font-family:var(--fuente-base);color:var(--gris-900)}p{margin:0}html,body,#root{width:100%;min-height:100%;margin:0;padding:0}body{background:#f5f7fa;font-family:Arial,sans-serif}.app-layout,.layout{width:100%;min-height:100vh;display:flex;position:relative}.app-content,.main{box-sizing:border-box;flex:1;width:100%;min-width:0;padding:10px;overflow-x:auto}.topbar{background:var(--color-primario);border-radius:0;align-items:center;gap:14px;margin:-10px -10px 16px;padding:12px 16px;display:flex}.topbar-title{margin:0;font-size:28px;font-weight:700;line-height:1}.topbar .topbar-title{color:#fff}.mobile-menu-btn{display:none}.topbar .mobile-menu-btn{color:#fff}.overlay{z-index:900;background:#00000040;width:100%;height:100%;position:fixed;top:0;left:0}.config-card{background:#fff;border-radius:12px;margin-bottom:16px;padding:20px;box-shadow:0 1px 4px #0000000f}.config-card h2{color:#111827;margin:0 0 16px;font-size:16px;font-weight:700}.config-card--peligro{background:#fff9f9;border:1.5px solid #fecaca}.config-card--peligro h2{color:#b91c1c}.config-aviso{color:#6b7280;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:0 0 16px;padding:10px 12px;font-size:13px}.config-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-start;gap:16px;padding:12px 0;display:flex}.config-row:last-child{border-bottom:none;padding-bottom:0}.config-row>div{flex:1}.config-row strong{color:#111827;margin-bottom:4px;font-size:14px;display:block}.config-row p{color:#6b7280;margin:0;font-size:13px;line-height:1.4}.config-message{color:#166534;background:#dcfce7;border:1px solid #bbf7d0;border-radius:8px;margin-top:12px;padding:10px 12px;font-size:13px;font-weight:500}.config-message--error{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.switch{color:#6b7280;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:1.5px solid #d1d5db;border-radius:20px;flex-shrink:0;padding:7px 16px;font-size:13px;font-weight:600;transition:all .2s}.switch.activo{color:#fff;background:#2563eb;border-color:#2563eb}.btn-peligro{color:#b91c1c;cursor:pointer;white-space:nowrap;background:#fee2e2;border:1.5px solid #fca5a5;border-radius:8px;flex-shrink:0;padding:8px 16px;font-size:13px;font-weight:600;transition:background .2s}.btn-peligro:hover{background:#fecaca}.confirmacion-limpieza{flex-direction:column;flex-shrink:0;gap:8px;max-width:280px;display:flex}.confirmacion-texto{color:#b91c1c;margin:0;font-size:13px;font-weight:500;line-height:1.4}.confirmacion-acciones{gap:8px;display:flex}@media (width<=900px){.app-content{padding:20px 16px}.topbar{margin:-20px -16px 16px;padding:12px 16px}.mobile-menu-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex}.config-row{flex-direction:column;align-items:flex-start}.confirmacion-limpieza{width:100%;max-width:100%}}@media (width<=600px){.app-content{padding:10px 14px 14px}.topbar{gap:12px;margin:-10px -14px 12px;padding:12px 14px}.topbar-title{font-size:22px}}.alerta-toast{z-index:9999;border-radius:var(--radio-md);min-width:260px;max-width:90%;font-size:var(--texto-base);box-shadow:var(--sombra-md);opacity:0;transition:all var(--transicion-lenta);justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;font-weight:500;display:flex;position:fixed;top:20px;right:20px;transform:translateY(-10px)}.alerta-toast.show{opacity:1;transform:translateY(0)}.alerta-toast.success{background:var(--color-exito);color:var(--fondo-blanco)}.alerta-toast.error{background:var(--color-error);color:var(--fondo-blanco)}.alerta-toast.warning{background:var(--color-advertencia);color:var(--fondo-blanco)}.cerrar-alerta{color:inherit;cursor:pointer;background:0 0;border:none;font-size:18px}@media (width<=768px){.alerta-toast{width:auto;max-width:none;inset:auto 16px 20px;transform:translateY(0)}.alerta-toast.show{transform:translateY(0)}}.table-container{width:100%;margin-top:10px;position:relative;overflow:auto visible}table,.tabla{border-collapse:collapse;background:var(--fondo-blanco);width:100%;font-size:var(--texto-base);z-index:1;position:relative}th,td{text-align:left;font-size:var(--texto-base);border-bottom:var(--borde-grosor) solid var(--gris-200);vertical-align:middle;padding:9px 10px}th{background:var(--gris-100);white-space:nowrap;cursor:pointer;font-weight:600}td{white-space:nowrap}.empty-row{text-align:center;color:var(--gris-500);padding:20px}.negativo{color:red;font-weight:700}.tabla tbody tr:nth-child(2n){background-color:var(--gris-50)}.tabla tbody tr:hover{background-color:var(--color-primario-fondo)}.td-nombre-producto{white-space:nowrap;z-index:100;min-width:220px;max-width:260px;font-weight:600;position:relative;overflow:visible}.td-numero{white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums}.td-codigo{white-space:nowrap;font-size:var(--texto-sm);color:var(--gris-500)}.selector-columnas{margin-bottom:10px;display:inline-block;position:relative}.selector-columnas-btn{font-size:var(--texto-base);border-radius:var(--radio-sm);cursor:pointer;padding:8px 12px}.selector-columnas-panel{background:var(--fondo-blanco);border:var(--borde-grosor) solid var(--gris-200);border-radius:var(--radio-md);box-shadow:var(--sombra-md);z-index:10000;min-width:190px;padding:10px;position:absolute;top:40px;left:0}.selector-columnas-item{font-size:var(--texto-base);cursor:pointer;justify-content:space-between;align-items:center;gap:8px;padding:6px 4px;display:flex}.selector-columnas-item input{cursor:pointer}.selector-columnas-label{flex:1}.selector-columnas-acciones{gap:6px;display:flex}.btn-orden{border-radius:var(--radio-xs);background:var(--gris-200);width:28px;height:28px;color:var(--gris-900);font-size:var(--texto-md);cursor:pointer;transition:all var(--transicion-normal);border:none;justify-content:center;align-items:center;font-weight:700;display:flex}.btn-orden:hover{background:var(--color-primario);color:var(--fondo-blanco)}@media (width>=901px){.tabla th:first-child,.tabla td:first-child{z-index:100;border-right:2px solid var(--gris-300);position:sticky;left:0}.tabla th:first-child{z-index:110;background:var(--gris-100)}.tabla td:first-child{background:var(--fondo-blanco)}.tabla tbody tr:nth-child(2n) td:first-child{background:var(--gris-50)}.tabla tbody tr:hover td:first-child{background:var(--color-primario-fondo)}}.celda-nombre-con-menu{align-items:center;gap:8px;display:flex}.btn-menu-fila{cursor:pointer;color:var(--gris-500);border-radius:var(--radio-sm);background:0 0;border:none;flex-shrink:0;padding:2px 8px;font-size:20px}.btn-menu-fila:hover{background:var(--gris-200);color:var(--gris-900)}.nombre-texto{text-overflow:ellipsis;max-width:190px;display:inline-block;overflow:hidden}.modal-acciones-overlay{z-index:999999;animation:overlayEntrada var(--modal-duracion) ease;background:#11182773;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.modal-acciones{background:var(--fondo-blanco);border-radius:var(--radio-2xl);width:min(420px,92vw);box-shadow:var(--sombra-xl);animation:modalEntrada var(--modal-duracion) var(--modal-easing);padding:22px 24px}.modal-acciones h3{text-align:center;font-size:var(--texto-lg);color:var(--gris-900);margin:0 0 8px;font-weight:800}.modal-acciones-producto{text-align:center;color:var(--color-primario);font-size:var(--texto-md);border-bottom:var(--borde-grosor) solid var(--gris-200);text-transform:uppercase;white-space:normal;margin-bottom:14px;padding-bottom:12px;font-weight:800}.modal-accion-btn{text-align:left;border-radius:var(--radio-lg);width:100%;font-size:var(--texto-md);color:var(--gris-900);cursor:pointer;background:0 0;border:none;padding:14px 12px;font-weight:600;display:block}.modal-accion-btn:hover{background:var(--gris-100)}.modal-accion-btn.peligro{color:var(--color-error-hover);border:var(--borde-grosor) solid var(--color-error-borde-alt);margin-top:8px}.modal-accion-btn.peligro:hover{background:var(--color-error-fondo)}.modal-accion-btn.secundario{color:var(--gris-500);text-align:center;margin-top:10px}.fila-oculta-pos{background-color:var(--gris-100)!important}.fila-oculta-pos td,.fila-oculta-pos .nombre-texto{color:var(--gris-400)!important}.fila-oculta-pos .nombre-texto{font-style:italic}.paginacion-tabla{color:var(--gris-700);justify-content:flex-end;align-items:center;gap:22px;padding:14px 8px 18px;font-size:15px;display:flex}.paginacion-select{color:var(--gris-700);cursor:pointer;background:0 0;border:none;outline:none;padding:6px 4px;font-size:15px}.paginacion-rango{white-space:nowrap;font-weight:500}.paginacion-flecha{color:var(--gris-900);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:34px;line-height:1}.paginacion-flecha:disabled{color:var(--gris-300);cursor:not-allowed}@media (width<=768px){.paginacion-tabla{font-size:var(--texto-base);justify-content:center;gap:16px;padding-bottom:24px}.paginacion-flecha{font-size:30px}}.filtro-productos-wrapper{align-items:center;display:flex}.btn-filtro-productos{border:var(--borde-grosor) solid var(--gris-300);background:var(--fondo-blanco);width:44px;height:44px;color:var(--color-primario);border-radius:var(--radio-md);cursor:pointer;font-size:24px;font-weight:700}.btn-filtro-productos.activo{background:var(--color-primario-fondo);border-color:var(--color-primario)}.filtro-modal-overlay{z-index:9998;animation:overlayEntrada var(--modal-duracion) ease;background:#11182759;justify-content:center;align-items:flex-start;padding-top:120px;display:flex;position:fixed;inset:0}.filtro-modal{background:var(--fondo-blanco);border-radius:var(--radio-xl);width:min(520px,92vw);box-shadow:var(--sombra-xl);animation:modalEntrada var(--modal-duracion) var(--modal-easing);padding:22px}.filtro-modal-header{border-bottom:var(--borde-grosor) solid var(--gris-200);justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;display:flex}.filtro-modal-header h3{font-size:var(--texto-lg);margin:0;font-weight:800}.filtro-modal-cerrar{color:var(--color-error);cursor:pointer;background:0 0;border:none;font-size:34px}.filtro-modal-item{font-size:17px}.filtro-modal-footer{justify-content:space-between;margin-top:28px;display:flex}.btn-filtro-limpiar,.btn-filtro-aplicar{cursor:pointer;text-transform:uppercase;background:0 0;border:none;font-size:15px;font-weight:800}.btn-filtro-limpiar{color:var(--color-error)}.btn-filtro-aplicar{color:var(--color-primario)}@media (width<=768px){.filtro-modal-overlay{padding-top:140px}.filtro-modal{width:88vw;padding:20px}}.productos-buscador-fila{align-items:center;gap:10px;margin-bottom:12px;display:flex}.productos-buscador-input{border:var(--borde-grosor) solid var(--gris-300);border-radius:var(--radio-lg);min-width:0;font-size:var(--texto-base);background:var(--fondo-blanco);flex:1;padding:11px 14px}.btn-filtro-productos{border-radius:var(--radio-lg);width:46px;height:46px;font-size:0;position:relative}.btn-filtro-productos:before{content:"⏬";color:var(--color-primario);font-size:20px}@media (width<=768px){.productos-buscador-fila{width:100%}.productos-buscador-input{font-size:15px}}.th-contenido{align-items:center;gap:6px;display:flex}.btn-icon-columnas{cursor:pointer;font-size:var(--texto-md);background:0 0;border:none;justify-content:center;align-items:center;margin-right:6px;padding:0;display:inline-flex}.selector-columnas-modal{background:var(--fondo-blanco);border:var(--borde-grosor) solid var(--gris-200);border-radius:var(--radio-sm);z-index:20;box-shadow:var(--sombra-md);margin-top:8px;padding:10px;position:absolute}.selector-item{justify-content:space-between;align-items:center;gap:8px;padding:4px 0;display:flex}.selector-item label{font-size:var(--texto-sm)}.selector-item .acciones button{cursor:pointer;font-size:var(--texto-base);background:0 0;border:none}.acciones-barra{background:0 0;align-items:center;gap:14px;margin-bottom:16px;padding:10px 0;display:flex}.acciones-productos{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.btn-nuevo{font-size:var(--texto-base);padding:8px 14px;width:auto!important}.btn-importar,.btn-exportar{font-size:var(--texto-sm);padding:8px 12px}@media (width<=600px){.acciones-barra{margin-bottom:12px;padding:8px 0}.acciones-productos{justify-content:flex-start}.btn-nuevo,.btn-importar,.btn-exportar{flex:none}}.modal-overlay{animation:overlayEntrada var(--modal-duracion) ease;z-index:1000;background:#1118278c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0;overflow:hidden}.modal-base{animation:modalEntrada var(--modal-duracion) var(--modal-easing);background:var(--fondo-blanco);border-radius:var(--radio-xl);width:100%;max-width:720px;box-shadow:var(--sombra-lg);flex-direction:column;max-height:calc(100vh - 32px);display:flex;overflow:hidden}.modal-producto{width:100%}.modal-header{border-bottom:var(--borde-grosor) solid var(--gris-200);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.modal-header h2{font-size:var(--texto-xl);color:var(--gris-900);margin:0;font-weight:700}.btn-close{font-size:var(--texto-2xl);color:var(--gris-500);cursor:pointer;background:0 0;border:none;padding:0;font-weight:700;line-height:1}.btn-close:hover{color:var(--gris-900)}.modal-body{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:18px;overflow-y:auto}.field-group{flex-direction:column;min-width:0;display:flex}.floating-label{font-size:var(--texto-md);color:var(--gris-700);margin-bottom:2px;font-weight:600;transform:translateY(-4px)}.field-group input,.field-group select,.textarea-base,.inline-create-popover input{border:var(--borde-grosor-medio) solid var(--gris-300);border-radius:var(--radio-md);width:100%;font-size:var(--texto-base);color:var(--gris-900);background:var(--fondo-blanco);box-sizing:border-box;box-shadow:none;transition:border-color var(--transicion-rapida);outline:none;padding:9px 10px}.field-group input{text-indent:2px}.field-group input:focus,.field-group select:focus,.textarea-base:focus,.inline-create-popover input:focus{border-color:var(--gris-300);box-shadow:none}.input-destacado{border-color:var(--color-primario)!important;box-shadow:0 0 0 3px #2563eb1f!important}.textarea-base{resize:vertical;min-height:90px;font-family:var(--fuente-base);background:var(--fondo-blanco)!important;color:var(--gris-900)!important}.field-group input:-webkit-autofill{transition:background-color 9999s ease-out;-webkit-box-shadow:0 0 0px 1000px var(--fondo-blanco) inset!important;-webkit-text-fill-color:var(--gris-900)!important}.field-group input:-webkit-autofill:hover{transition:background-color 9999s ease-out;-webkit-box-shadow:0 0 0px 1000px var(--fondo-blanco) inset!important;-webkit-text-fill-color:var(--gris-900)!important}.field-group input:-webkit-autofill:focus{transition:background-color 9999s ease-out;-webkit-box-shadow:0 0 0px 1000px var(--fondo-blanco) inset!important;-webkit-text-fill-color:var(--gris-900)!important}.inline-create-popover input:-webkit-autofill{transition:background-color 9999s ease-out;-webkit-box-shadow:0 0 0px 1000px var(--fondo-blanco) inset!important;-webkit-text-fill-color:var(--gris-900)!important}.textarea-base:-webkit-autofill{transition:background-color 9999s ease-out;-webkit-box-shadow:0 0 0px 1000px var(--fondo-blanco) inset!important;-webkit-text-fill-color:var(--gris-900)!important}.select-wrapper{width:100%;position:relative}.field-group select{appearance:none;padding-right:38px}.select-arrow{border-right:2px solid var(--gris-500);border-bottom:2px solid var(--gris-500);pointer-events:none;width:10px;height:10px;position:absolute;top:50%;right:14px;transform:translateY(-50%)rotate(45deg)}.categoria-group{position:relative;overflow:visible}.inline-create-row{grid-template-columns:1fr auto;align-items:center;gap:10px;display:grid}.btn-inline-add{white-space:nowrap;border-radius:var(--radio-md);justify-content:center;align-items:center;width:38px;min-width:38px;height:38px;padding:0;font-size:22px;line-height:1;display:inline-flex}.inline-create-popover{z-index:30;border:var(--borde-grosor) solid var(--color-primario-claro);border-radius:var(--radio-lg);background:var(--fondo-blanco);width:100%;box-shadow:var(--sombra-md);padding:12px;position:absolute;top:calc(100% + 8px);left:0}.inline-create-actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.inline-error{font-size:var(--texto-sm);color:var(--color-error-hover);margin-top:8px;font-weight:500}.modal-actions{flex-shrink:0;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:8px;display:flex}.form-error-box{border:var(--borde-grosor) solid var(--color-error-borde);background:var(--color-error-fondo);color:var(--color-error-hover);border-radius:var(--radio-md);font-size:var(--texto-base);margin-top:16px;padding:10px 12px;font-weight:500}.btn-primary,.btn-secondary{border-radius:var(--radio-md);font-size:var(--texto-base);border:var(--borde-grosor) solid transparent;cursor:pointer;padding:9px 14px;font-weight:600}.btn-primary{background:var(--color-primario);color:var(--fondo-blanco)}.btn-primary:hover{background:var(--color-primario-hover)}.btn-secondary{background:var(--gris-50);color:var(--gris-700);border-color:var(--gris-300)}.btn-secondary:hover{background:var(--gris-100)}.modal-full-row{grid-column:1/-1}.modal-section-title{text-align:left;grid-column:1/-1;margin-top:10px;margin-bottom:4px}.modal-section-title h3{color:var(--gris-900);margin:0;font-size:15px;font-weight:600}.price-section{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;width:100%;display:grid}.price-row{grid-template-columns:32% 28% 25% 30px;align-items:center;gap:6px;width:100%;display:grid}.price-cell{min-width:0}.price-cell .floating-label{margin-bottom:4px}.price-cell.readonly-cell input{background:var(--fondo-blanco);color:var(--gris-900)}.price-action-cell{z-index:5;justify-content:center;align-items:center;min-height:40px;display:flex;position:relative}.price-actions-inline{gap:6px}.icon-action-btn{border-radius:var(--radio-md);cursor:pointer;z-index:10;pointer-events:auto;width:38px;min-width:38px;height:38px;transition:transform var(--transicion-rapida), opacity var(--transicion-rapida);border:none;justify-content:center;align-items:center;padding:0;font-size:22px;font-weight:700;line-height:1;display:inline-flex;position:relative}.icon-action-btn:hover{transform:scale(1.04)}.icon-add-btn{background:var(--color-primario-claro);color:var(--color-primario)}.icon-add-btn.disabled-btn,.icon-add-btn:disabled{background:var(--gris-200)!important;color:var(--gris-400)!important;cursor:not-allowed!important;opacity:1!important}.icon-add-btn:hover{background:var(--color-primario-medio);color:var(--color-primario-hover)}.icon-delete-btn{background:var(--color-error-fondo-alt);color:var(--color-error)}.icon-delete-btn:hover{background:var(--color-error-borde);color:var(--color-error-hover)}.icon-delete-btn .trash-icon{width:18px;height:18px;display:block}.stock-row{grid-template-columns:70px 1fr 85px;gap:6px;display:grid}.stock-row-simple{grid-template-columns:70px 1fr;gap:6px;display:grid}.stock-units-extra{align-items:center;gap:4px;display:flex}.stock-units-extra input{width:45px}.stock-units-extra span{font-size:var(--texto-sm);font-weight:600}.stock-select-wrapper{width:140px}.select-right{text-align:right;width:100%}.producto-imagen-wrapper{flex-direction:column;gap:10px;padding-top:4px;display:flex}.producto-imagen-preview{border-radius:var(--radio-sm);border:var(--borde-grosor-medio) solid var(--gris-300);background:var(--gris-50);justify-content:center;align-items:center;width:120px;height:120px;display:flex;overflow:hidden}.producto-imagen-img{object-fit:cover;width:100%;height:100%}.producto-imagen-placeholder{opacity:.3;font-size:48px}.producto-imagen-acciones{align-items:center;gap:8px;display:flex}.btn-eliminar-imagen{background:var(--color-error-fondo-alt);color:var(--color-error-hover);border:var(--borde-grosor) solid var(--color-error-borde);border-radius:var(--radio-xs);font-size:var(--texto-sm);cursor:pointer;padding:6px 10px;line-height:1}.btn-eliminar-imagen:hover{background:var(--color-error-borde)}.filtro-modal-overlay{z-index:1000;background:#1118278c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.filtro-modal{background:var(--fondo-blanco);border-radius:var(--radio-xl);flex-direction:column;width:100%;max-width:500px;max-height:calc(100vh - 40px);display:flex;overflow:hidden}.filtro-modal-header{flex-shrink:0}.filtro-modal-body{-webkit-overflow-scrolling:touch;flex:1;padding:16px;overflow-y:auto}.filtro-modal-footer{flex-shrink:0}.barra-progreso-importacion{background:var(--gris-200);border-radius:999px;width:100%;height:10px;margin:8px 0;overflow:hidden}.barra-progreso-importacion-activa{background:var(--color-primario);height:100%;transition:width var(--transicion-normal);border-radius:999px}@media (width<=700px){.modal-overlay{animation:overlayEntrada var(--modal-duracion) ease;justify-content:stretch!important;align-items:stretch!important;width:100%!important;height:100dvh!important;margin:0!important;padding:0!important;overflow:hidden!important}.modal-base{animation:modalEntrada var(--modal-duracion) var(--modal-easing);border-radius:0!important;flex-direction:column!important;width:auto!important;max-width:none!important;height:100dvh!important;max-height:100dvh!important;display:flex!important;position:fixed!important;inset:0!important;overflow:hidden!important}.modal-header{flex-shrink:0!important}.modal-body{padding:16px 16px 96px;-webkit-overflow-scrolling:touch!important;flex:auto!important;min-height:0!important;overflow-y:auto!important}.form-grid{grid-template-columns:1fr;gap:18px}.field-group.full,.modal-full-row,.modal-section-title{grid-column:1/-1}.inline-create-popover{width:100%;margin-top:10px;position:static}.price-section{grid-template-columns:1fr!important}.price-row{grid-template-rows:auto auto;align-items:center;gap:8px;grid-template-columns:repeat(10,1fr)!important;display:grid!important}.price-row .field-group:first-child{grid-area:1/1/auto/8}.price-row .price-action-cell{grid-area:1/8/auto/11;justify-content:flex-end;align-items:center;margin-top:0}.price-row .field-group:nth-child(2){grid-area:2/1/auto/6}.price-row .field-group:nth-child(3){grid-area:2/6/auto/11}.price-row .field-group{width:100%;min-width:0}.modal-actions{flex-direction:column-reverse;padding-bottom:16px}.modal-actions .btn-primary,.modal-actions .btn-secondary{width:100%}.floating-label{font-size:var(--texto-md)!important;color:var(--gris-700)!important;font-weight:600!important;font-family:var(--fuente-base)!important}.filtro-modal-overlay{justify-content:stretch!important;align-items:stretch!important;padding:0!important}.filtro-modal{border-radius:0;flex-direction:column;height:100dvh;max-height:100dvh;display:flex;position:fixed;inset:0}.filtro-modal-body{flex:1;padding-bottom:90px;overflow-y:auto}.filtro-modal-footer{background:var(--fondo-blanco);padding:12px}}.compuesto-fila{border-radius:var(--radio-sm);background:var(--gris-50);border:var(--borde-grosor) solid var(--gris-200);align-items:flex-end;gap:8px;padding:8px;display:flex}@media (width<=700px){.compuesto-fila{flex-wrap:wrap}.compuesto-fila .field-group{flex:100%!important}}.btn-primary{background:var(--color-primario);color:var(--fondo-blanco);border-radius:var(--radio-xs);cursor:pointer;font-size:var(--texto-sm);border:none;padding:7px 12px}.btn-secondary{background:var(--fondo-blanco);color:var(--gris-900);border:var(--borde-grosor) solid var(--gris-300);border-radius:var(--radio-xs);cursor:pointer;font-size:var(--texto-sm);padding:7px 12px}.filters-bar{background:var(--fondo-blanco);border-radius:var(--radio-sm);justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:10px 12px;display:flex}.checkbox-label{font-size:var(--texto-base);align-items:center;gap:8px;display:flex}.filter-info{font-size:var(--texto-sm);color:var(--gris-700)}.producto-form{flex-direction:column;gap:12px;display:flex}.form-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.field-group{border:var(--borde-grosor-medio) solid var(--gris-300);border-radius:var(--radio-xs);background:var(--fondo-blanco);min-height:auto;padding:16px 10px 12px;position:relative}.field-group.full{grid-column:1/-1}.floating-label{background:var(--fondo-blanco);font-size:var(--texto-sm);color:var(--gris-500);padding:0 5px;font-weight:600;position:absolute;top:-8px;left:10px}.field-group input,.field-group select,.field-group textarea{width:100%;font-size:var(--texto-md);color:var(--gris-900);background:0 0;border:none;outline:none;height:24px;padding:0;line-height:24px}.field-group select{cursor:pointer;min-height:32px;line-height:32px}.filtro-modal-body{flex-direction:column;gap:12px;display:flex}.filtro-grupo{flex-direction:column;gap:8px;display:flex}.filtro-titulo{font-size:var(--texto-base);color:var(--gris-700);margin-bottom:2px;font-weight:700}.filtro-modal-item{color:var(--gris-700);font-size:15px}.filtro-modal-item input{width:18px;height:18px}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.alerta{border-radius:var(--radio-xs);font-size:var(--texto-base);justify-content:space-between;align-items:center;margin-bottom:12px;padding:10px 14px;display:flex}.alerta-success{background:var(--color-exito-fondo);color:var(--color-exito-texto)}.alerta-error{background:var(--color-error-fondo-alt);color:var(--color-error-hover)}.alerta-cerrar{font-size:var(--texto-md);cursor:pointer;background:0 0;border:none}@media (width<=900px){.filters-bar{flex-direction:column;align-items:flex-start}.form-grid{grid-template-columns:1fr}.field-group.full{grid-column:auto}}@media (width<=600px){.btn-primary{width:100%}.modal-actions{flex-direction:column}.modal-actions .btn-primary,.modal-actions .btn-secondary{width:100%}}.uppercase-input{text-transform:uppercase}.field-hint{font-size:var(--texto-xs);border-radius:4px;margin:6px 0 0;padding:4px 6px;font-weight:500;line-height:1.4}.field-hint--bloqueado{background:var(--color-advertencia-fondo);color:var(--color-advertencia-texto);border:var(--borde-grosor) solid var(--color-advertencia-borde)}.field-hint--error{background:var(--color-error-fondo);color:var(--color-error-hover);border:var(--borde-grosor) solid var(--color-error-borde)}.field-hint--info{color:#0369a1;border:var(--borde-grosor) solid #bae6fd;background:#f0f9ff}.sidebar{width:var(--sidebar-ancho);height:100vh;color:var(--gris-800,#1f2937);box-sizing:border-box;transition:width var(--transicion-lenta), left var(--transicion-lenta);z-index:1000;will-change:width, left;border-right:1px solid var(--gris-200,#e5e7eb);background:#fff;flex-direction:column;padding:10px 8px 14px;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar.abierto{width:var(--sidebar-ancho-open)}.sidebar-toggle-btn{border-radius:var(--radio-sm);background:var(--gris-100,#f3f4f6);width:36px;height:36px;color:var(--gris-700,#374151);cursor:pointer;z-index:1200;border:none;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex;position:absolute;top:12px;left:8px}.sidebar.abierto .sidebar-toggle-btn{opacity:0;visibility:hidden;pointer-events:none}.sidebar-header,.sidebar h2,.menu-btn{opacity:1;visibility:visible;transition:opacity var(--transicion-normal)}.sidebar:not(.abierto) .sidebar-header,.sidebar:not(.abierto) h2,.sidebar:not(.abierto) .menu-btn{opacity:0;visibility:hidden;pointer-events:none}.sidebar-header{z-index:10;border-bottom:1px solid var(--gris-200,#e5e7eb);background:#fff;justify-content:space-between;align-items:center;margin-bottom:0;padding:4px 6px 6px;display:flex;position:sticky;top:0}.sidebar-user{color:var(--gris-700,#374151);font-size:16px;font-weight:600;line-height:1}.sidebar-close-btn{border-radius:var(--radio-md);width:32px;height:32px;color:var(--gris-600,#4b5563);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:22px;display:flex}.sidebar-close-btn:hover{background:var(--gris-100,#f3f4f6)}.sidebar h2{text-transform:uppercase;letter-spacing:.6px;color:var(--gris-500,#6b7280);white-space:nowrap;margin:10px 6px 8px;font-size:13px;font-weight:700}.menu-btn{width:100%;color:var(--gris-700,#374151);text-align:left;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:17px;font-weight:500;transition:background .12s,color .12s;display:flex;position:relative}.menu-btn svg{color:var(--gris-500,#6b7280);flex-shrink:0;transition:color .12s}.menu-btn:hover{background:var(--gris-100,#f3f4f6);color:var(--gris-900,#111827)}.menu-btn:hover svg{color:var(--gris-700,#374151)}.menu-btn.activo{background:var(--color-primario-claro,#2563eb1a);color:var(--color-primario,#2563eb);font-weight:600}.menu-btn.activo svg{color:var(--color-primario,#2563eb)}.menu-btn.activo:before{content:"";background:var(--color-primario,#2563eb);border-radius:0 3px 3px 0;width:3px;height:50%;position:absolute;top:25%;left:0}.menu-btn[style*="paddingLeft: 38"]{color:var(--gris-600,#4b5563);padding-top:7px;padding-bottom:7px;font-size:13px}.menu-btn[style*="paddingLeft: 38"]:hover{color:var(--gris-900,#111827)}.app-content{margin-left:var(--sidebar-ancho);transition:margin-left var(--transicion-lenta)}.app-layout.sidebar-open .app-content{margin-left:var(--sidebar-ancho)}@media (width<=900px){.sidebar{width:82%;height:100vh;transition:left var(--transicion-lenta);padding:10px 14px 16px;left:-82%;overflow:hidden auto}.sidebar.abierto{width:82%;left:0}.sidebar h2{margin:8px 6px}.sidebar-toggle-btn{display:none}.sidebar.abierto .sidebar-header,.sidebar.abierto h2,.sidebar.abierto .menu-btn{opacity:1;visibility:visible;pointer-events:auto}.app-content{margin-left:0}}@media (width<=768px){.topbar-title--oculto-movil{display:none}}.login-page{background:var(--fondo-app);box-sizing:border-box;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:24px 16px;display:flex}.login-card{background:var(--fondo-blanco);border-radius:var(--radio-xl);width:100%;max-width:420px;box-shadow:var(--sombra-lg);box-sizing:border-box;padding:32px}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{color:var(--color-primario);letter-spacing:.5px;margin:0 0 6px;font-size:28px;font-weight:800}.login-logo p{font-size:var(--texto-sm);color:var(--gris-500);margin:0}.login-form{flex-direction:column;gap:18px;display:flex}.form-error-box{background:var(--color-error-fondo);color:var(--color-error-hover);border:var(--borde-grosor) solid var(--color-error-borde);border-radius:var(--radio-xs);font-size:var(--texto-sm);padding:10px 12px;font-weight:600}.login-btn{width:100%;font-size:var(--texto-md);border-radius:var(--radio-md);transition:background var(--transicion-rapida);margin-top:4px;padding:14px;font-weight:600}.login-btn:hover:not(:disabled){background:var(--color-primario-hover)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;font-size:var(--texto-sm);color:var(--gris-500);margin-top:22px;line-height:1.7}.login-footer a{color:var(--color-primario);transition:color var(--transicion-rapida);font-weight:600;text-decoration:none}.login-footer a:hover{color:var(--color-primario-hover);text-decoration:underline}@media (width<=480px){.login-page{padding:16px 12px}.login-card{width:92%;max-width:100%;padding:24px 20px}.login-logo{margin-bottom:22px}.login-logo h1{font-size:24px}}.cfg-preview{border-radius:var(--radio-lg);border:1px solid var(--gris-200);box-shadow:var(--sombra-sm);height:130px;margin-bottom:20px;display:flex;overflow:hidden}.cfg-preview-sidebar{background:var(--sidebar-fondo);flex-direction:column;flex-shrink:0;gap:3px;width:110px;padding:10px 8px;display:flex}.cfg-preview-logo{border-radius:var(--radio-sm);background:var(--color-primario);color:#fff;justify-content:center;align-items:center;width:28px;height:28px;margin-bottom:6px;font-size:10px;font-weight:700;display:flex}.cfg-preview-item{color:#ffffff73;border-radius:4px;padding:4px 7px;font-size:10px}.cfg-preview-item--activo{background:var(--color-primario);color:#fff;font-weight:600}.cfg-preview-body{background:var(--fondo-app);flex-direction:column;flex:1;display:flex}.cfg-preview-topbar{background:var(--color-primario);justify-content:space-between;align-items:center;padding:7px 12px;display:flex}.cfg-preview-btn{color:#fff;background:#ffffff38;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.cfg-preview-badge{background:var(--color-primario-claro);color:var(--color-primario-texto,var(--color-primario));border-radius:20px;padding:2px 9px;font-size:10px;font-weight:600}.cfg-preview-badge--outline{border:1.5px solid var(--color-primario);color:var(--color-primario);background:0 0}.cfg-preview-bar-wrap{background:var(--gris-200);border-radius:10px;flex:1;min-width:50px;height:5px;overflow:hidden}.cfg-preview-bar{background:var(--color-primario);border-radius:10px;width:58%;height:100%}.cfg-temas-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:8px;margin-bottom:4px;display:grid}.cfg-tema-btn{background:var(--fondo-blanco);border:2px solid var(--gris-200);border-radius:var(--radio-lg);cursor:pointer;transition:border-color var(--transicion-rapida), box-shadow var(--transicion-rapida);color:var(--gris-700);align-items:center;gap:9px;padding:9px 12px;font-size:12px;font-weight:500;display:flex}.cfg-tema-btn:hover:not(:disabled){border-color:var(--tc);box-shadow:0 0 0 3px color-mix(in srgb, var(--tc) 18%, transparent)}.cfg-tema-btn--activo{border-color:var(--tc);background:color-mix(in srgb, var(--tc) 7%, white)}.cfg-tema-btn:disabled{opacity:.6;cursor:not-allowed}.cfg-tema-circulo{background:var(--tc);width:20px;height:20px;box-shadow:0 2px 5px color-mix(in srgb, var(--tc) 35%, transparent);border-radius:50%;flex-shrink:0}.cfg-tema-nombre{text-align:left;flex:1}.cfg-tema-check{color:var(--tc);font-size:12px;font-weight:800}.cfg-picker-wrap{background:var(--fondo-blanco);border:2px solid var(--gris-200);border-radius:var(--radio-lg);align-items:center;gap:10px;padding:7px 14px;display:flex}.cfg-color-input{border-radius:var(--radio-sm);cursor:pointer;background:0 0;border:none;width:36px;height:36px;padding:0}.cfg-toast-inline{background:var(--color-exito-fondo);color:var(--color-exito-texto);border:1px solid var(--color-exito-borde);border-radius:var(--radio-lg);margin-top:12px;padding:7px 16px;font-size:13px;font-weight:600;animation:.2s fadeIn;display:inline-block}@media (width<=600px){.cfg-temas-grid{grid-template-columns:1fr 1fr}.cfg-preview{height:110px}.cfg-preview-sidebar{width:90px}}
