@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.catalogo-publico,.producto-publico{min-height:100vh;background-color:#f8fafc}.header-tienda{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 0;box-shadow:0 1px 3px #0000001a}.header-tienda .contenedor{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 1rem}.info-empresa{display:flex;align-items:center;gap:1rem}.logo-empresa{height:50px;width:50px;object-fit:cover;border-radius:8px}.nombre-empresa{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.descripcion-empresa{color:#64748b;margin:0;font-size:.9rem}.nav-tienda{display:flex;gap:1.5rem}.nav-link{color:#475569;text-decoration:none;font-weight:500;transition:color .2s}.filtros-catalogo{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.filtros-catalogo h2{margin:0 0 1rem;color:#1e293b;font-size:1.5rem}.controles-filtros{display:flex;gap:1rem;flex-wrap:wrap}.filtro-select{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.9rem;min-width:180px}.filtro-select:focus{outline:none;border-color:var(--color-primario);box-shadow:0 0 0 3px #3b82f61a}.grid-productos{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.tarjeta-producto{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.tarjeta-producto:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.link-producto{display:block;text-decoration:none;color:inherit}.imagen-producto{position:relative;height:200px;overflow:hidden}.imagen-producto img{width:100%;height:100%;object-fit:cover}.sin-imagen{width:100%;height:100%;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:.9rem}.badge-destacado{position:absolute;top:.5rem;right:.5rem;background:#fbbf24;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.info-producto{padding:1rem}.nombre-producto{font-size:1.1rem;font-weight:600;color:#1e293b;margin:0 0 .5rem;line-height:1.3}.categoria-producto{color:#6b7280;font-size:.85rem;margin:0 0 .25rem}.marca-producto{color:#9ca3af;font-size:.8rem;margin:0 0 .75rem}.precio-stock{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.precio{font-size:1.25rem;font-weight:700;color:var(--color-primario)}.stock{font-size:.8rem;font-weight:500}.stock.disponible{color:#10b981}.stock.agotado{color:#ef4444}.cargando-productos,.error-productos,.sin-productos{text-align:center;padding:3rem 1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.cargando-productos .spinner{margin:0 auto 1rem}.error-productos p{color:#ef4444;margin-bottom:1rem}.sin-productos p{color:#6b7280;margin:0}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem;color:#6b7280;font-size:.9rem}.breadcrumb a{color:var(--color-primario);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.detalle-producto{display:grid;grid-template-columns:1fr 1fr;gap:3rem;background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:1200px;margin:0 auto}.info-producto{display:flex;flex-direction:column;gap:1.5rem;min-width:0}.galeria-producto{display:flex;flex-direction:column;gap:1rem}.imagen-principal{width:100%;height:400px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.imagen-principal img{width:100%;height:100%;object-fit:cover}.sin-imagen-detalle{width:100%;height:100%;background:#f9fafb;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:1.1rem;border:2px dashed #d1d5db;border-radius:8px}.miniaturas{display:flex;gap:.5rem;flex-wrap:wrap}.miniatura{width:80px;height:80px;border-radius:6px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color .2s;padding:0;background:none}.miniatura:hover{border-color:#d1d5db}.miniatura.activa{border-color:var(--color-primario)}.miniatura img{width:100%;height:100%;object-fit:cover}.cabecera-producto{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.cabecera-producto h1{font-size:2rem;font-weight:700;color:#1e293b;margin:0}.precio-producto{margin-bottom:1.5rem}.precio-actual{font-size:2rem;font-weight:700;color:var(--color-primario)}.metadatos-producto{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.metadato{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.metadato .etiqueta{color:#6b7280;font-weight:500;min-width:80px;flex-shrink:0}.metadato .valor{color:#1e293b;font-weight:600;word-wrap:break-word;overflow-wrap:break-word}.descripcion-producto{margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.descripcion-producto h3{color:#1e293b;margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.descripcion-producto p{color:#64748b;line-height:1.6;margin:0;font-size:.9rem;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap}.stock-producto{margin-bottom:1.5rem}.stock-disponible{color:#10b981;font-weight:600}.stock-agotado{color:#ef4444;font-weight:600}.controles-compra{display:flex;flex-direction:column;gap:1rem}.selector-cantidad{display:flex;align-items:center;gap:.5rem}.selector-cantidad label{color:#374151;font-weight:500}.input-cantidad{width:80px;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;text-align:center}.input-cantidad:focus{outline:none;border-color:var(--color-primario);box-shadow:0 0 0 3px #3b82f61a}.botones-compra{display:flex;flex-direction:column;gap:.75rem}.boton-completo{width:100%;padding:.75rem 1.5rem;font-weight:600;border-radius:8px;transition:all .2s;border:none;cursor:pointer;font-size:1rem}.boton-primario{background:var(--color-primario);color:#fff}.boton-primario:hover{background:#1d4ed8}.boton-secundario{background:#f1f5f9;color:var(--color-primario);border:1px solid var(--color-primario)}.boton-secundario:hover{background:var(--color-primario);color:#fff}.cargando-producto,.error-producto,.producto-no-encontrado{text-align:center;padding:3rem 1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.error-producto h2,.producto-no-encontrado h2{color:#ef4444;margin-bottom:1rem}.acciones-error{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.login-cliente{min-height:100vh;background-color:#f8fafc}.formulario-login-cliente{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem 0}.tarjeta-login{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;padding:2rem;width:100%;max-width:400px}.cabecera-login{text-align:center;margin-bottom:2rem}.cabecera-login h2{color:#1e293b;margin:0 0 .5rem;font-size:1.8rem;font-weight:700}.cabecera-login p{color:#6b7280;margin:0;font-size:1rem}.enlaces-login{text-align:center;margin:1rem 0}.enlace-secundario{color:var(--color-primario);text-decoration:none;font-size:.9rem;font-weight:500}.enlace-secundario:hover{text-decoration:underline}.separador{text-align:center;margin:1.5rem 0;position:relative;color:#6b7280;font-size:.9rem}.separador:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb;z-index:1}.separador span{background:#fff;padding:0 1rem;position:relative;z-index:2}@media (max-width: 768px){.header-tienda .contenedor{flex-direction:column;gap:1rem}.controles-filtros{flex-direction:column}.filtro-select{width:100%}.grid-productos{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.detalle-producto{grid-template-columns:1fr;gap:2rem;padding:1rem;margin:0 1rem}.info-producto{gap:1rem}.cabecera-producto{flex-direction:column;align-items:flex-start;gap:.5rem}.cabecera-producto h1{font-size:1.5rem;word-wrap:break-word;overflow-wrap:break-word}.precio-actual{font-size:1.5rem}.metadatos-producto{gap:.75rem}.metadato{flex-direction:column;align-items:flex-start;gap:.25rem}.metadato .etiqueta{min-width:auto}.descripcion-producto{padding:.75rem}.descripcion-producto h3{font-size:1rem}.descripcion-producto p{font-size:.85rem}.acciones-error{flex-direction:column;align-items:center}}@media (max-width: 480px){.grid-productos{grid-template-columns:1fr;gap:.75rem}.imagen-principal{height:250px}.miniaturas{justify-content:center}.producto-card{padding:.75rem}.producto-card .botones-controles{display:flex;flex-direction:column;gap:.5rem;width:100%}.producto-card .controles-cantidad{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.producto-card .boton-cantidad{width:32px;height:32px;border-radius:6px;border:none;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.producto-card .boton-cantidad.restar{background:#ef4444;color:#fff}.producto-card .boton-cantidad.sumar{background:#10b981;color:#fff}.producto-card .cantidad-display{min-width:40px;text-align:center;font-size:14px;font-weight:700;color:#1e293b;background:#fff;padding:6px 8px;border-radius:4px;border:1px solid #e5e7eb}.producto-card .boton-agregar{width:100%;padding:.75rem;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.producto-card .boton-agregar.primario{background:var(--color-primario, #3b82f6);color:#fff}.producto-card .boton-agregar.secundario{background:#f59e0b;color:#fff}.producto-card .boton-agregar.deshabilitado{background:#9ca3af;color:#fff;cursor:not-allowed}.producto-card.vista-lista{display:flex;align-items:center;gap:.75rem;padding:.75rem;height:auto;min-height:100px}.producto-card.vista-lista .imagen-container{width:80px;height:80px;flex-shrink:0;border-radius:8px;overflow:hidden}.producto-card.vista-lista .contenido{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.producto-card.vista-lista .titulo{font-size:14px;font-weight:600;line-height:1.2;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.producto-card.vista-lista .precio{font-size:16px;font-weight:700;margin:0}.producto-card.vista-lista .controles{display:flex;flex-direction:column;gap:.5rem;align-items:stretch;min-width:120px}.filtros-container{padding:1rem;margin-bottom:1rem}.filtros-container .filtro-select{width:100%;padding:.75rem;font-size:14px}.controles-vista{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.controles-vista .boton-vista{padding:.5rem .75rem;font-size:12px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;transition:all .2s ease}.controles-vista .boton-vista.activo{background:var(--color-primario, #3b82f6);color:#fff;border-color:var(--color-primario, #3b82f6)}}@media (min-width: 481px) and (max-width: 768px){.grid-productos{grid-template-columns:repeat(2,1fr);gap:1rem}.producto-card .botones-controles{display:flex;flex-direction:column;gap:.75rem}.producto-card .controles-cantidad{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.producto-card .boton-cantidad{width:36px;height:36px;border-radius:8px;border:none;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.producto-card .cantidad-display{min-width:48px;text-align:center;font-size:16px;font-weight:700;color:#1e293b;background:#fff;padding:8px 12px;border-radius:6px;border:1px solid #e5e7eb}.producto-card .boton-agregar{width:100%;padding:.875rem;border-radius:10px;border:none;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem}}.producto-card{transition:all .3s ease}.producto-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.boton-cantidad:hover{transform:scale(1.05)}.boton-agregar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.producto-card.cargando{opacity:.7;pointer-events:none}.producto-card.cargando:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;border:2px solid #e2e8f0;border-top:2px solid var(--color-primario, #3b82f6);border-radius:50%;animation:spin 1s linear infinite;transform:translate(-50%,-50%)}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}:root{--breakpoint-xs: 480px;--breakpoint-sm: 768px;--breakpoint-md: 1024px;--breakpoint-lg: 1200px;--breakpoint-xl: 1400px}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 16px}.container-fluid{width:100%;padding:0 16px}.grid{display:grid;gap:16px}.grid-1{grid-template-columns:repeat(1,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-5{grid-template-columns:repeat(5,1fr)}.grid-6{grid-template-columns:repeat(6,1fr)}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.p-responsive{padding:16px}.p-responsive-sm{padding:12px}.p-responsive-lg{padding:24px}.m-responsive{margin:16px}.m-responsive-sm{margin:12px}.m-responsive-lg{margin:24px}.text-responsive{font-size:16px;line-height:1.5}.text-responsive-sm{font-size:14px;line-height:1.4}.text-responsive-lg{font-size:18px;line-height:1.6}.btn-responsive{padding:12px 24px;font-size:16px;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.btn-responsive-sm{padding:8px 16px;font-size:14px}.btn-responsive-lg{padding:16px 32px;font-size:18px}.card-responsive{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;transition:all .3s ease}.card-responsive:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}@media (max-width: 480px){.container{padding:0 12px}.grid-2,.grid-3,.grid-4,.grid-5,.grid-6{grid-template-columns:1fr}.flex-row{flex-direction:column}.p-responsive{padding:12px}.m-responsive{margin:12px}.text-responsive{font-size:14px}.btn-responsive{padding:10px 20px;font-size:14px;width:100%}.card-responsive{border-radius:8px}}@media (min-width: 481px) and (max-width: 768px){.container{padding:0 16px}.grid-3,.grid-4,.grid-5,.grid-6,.grid-2{grid-template-columns:repeat(2,1fr)}.text-responsive{font-size:15px}.btn-responsive{padding:11px 22px;font-size:15px}}@media (min-width: 769px) and (max-width: 1024px){.grid-4,.grid-5,.grid-6,.grid-3{grid-template-columns:repeat(3,1fr)}.text-responsive{font-size:16px}.btn-responsive{padding:12px 24px;font-size:16px}}@media (min-width: 1025px) and (max-width: 1200px){.grid-5,.grid-6,.grid-4{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1201px){.grid-5{grid-template-columns:repeat(5,1fr)}.grid-6{grid-template-columns:repeat(6,1fr)}}.navbar-responsive{padding:16px 0;position:sticky;top:0;z-index:1000;background:#fffffff2;backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.1)}.navbar-responsive .nav-links{display:flex;align-items:center;gap:24px}.navbar-responsive .nav-toggle{display:none}@media (max-width: 768px){.navbar-responsive .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:16px;box-shadow:0 4px 12px #0000001a}.navbar-responsive .nav-links.active{display:flex}.navbar-responsive .nav-toggle{display:block}}.dashboard-responsive{display:grid;gap:24px;padding:24px}.dashboard-responsive .stats-grid,.dashboard-responsive .actions-grid{display:grid;gap:16px}@media (max-width: 768px){.dashboard-responsive{padding:16px;gap:16px}.dashboard-responsive .stats-grid,.dashboard-responsive .actions-grid{grid-template-columns:1fr}}@media (min-width: 769px) and (max-width: 1024px){.dashboard-responsive .stats-grid,.dashboard-responsive .actions-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1025px){.dashboard-responsive .stats-grid{grid-template-columns:repeat(4,1fr)}.dashboard-responsive .actions-grid{grid-template-columns:repeat(3,1fr)}}.form-responsive{max-width:600px;margin:0 auto;padding:24px}.form-responsive .form-group{margin-bottom:20px}.form-responsive .form-row{display:grid;gap:16px}@media (max-width: 768px){.form-responsive{padding:16px}.form-responsive .form-row{grid-template-columns:1fr}}@media (min-width: 769px){.form-responsive .form-row{grid-template-columns:repeat(2,1fr)}}.table-responsive{overflow-x:auto;border-radius:8px;box-shadow:0 2px 8px #0000001a}.table-responsive table{width:100%;min-width:600px;border-collapse:collapse}.table-responsive th,.table-responsive td{padding:12px;text-align:left;border-bottom:1px solid #e2e8f0}@media (max-width: 768px){.table-responsive th,.table-responsive td{padding:8px;font-size:14px}}.modal-responsive{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-responsive .modal-content{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;overflow-y:auto;position:relative}@media (max-width: 768px){.modal-responsive{padding:8px}.modal-responsive .modal-content{max-width:95vw;max-height:95vh;border-radius:8px}}.catalog-responsive{display:grid;gap:20px;padding:20px}.catalog-responsive .filters{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.catalog-responsive .products-grid{display:grid;gap:20px}@media (max-width: 480px){.catalog-responsive{padding:12px;gap:16px}.catalog-responsive .filters{flex-direction:column;align-items:stretch}.catalog-responsive .products-grid{grid-template-columns:1fr;gap:16px}}@media (min-width: 481px) and (max-width: 768px){.catalog-responsive .products-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 769px) and (max-width: 1024px){.catalog-responsive .products-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1025px){.catalog-responsive .products-grid{grid-template-columns:repeat(4,1fr)}}.hidden-xs,.hidden-sm,.hidden-md,.hidden-lg,.hidden-xl{display:none}.visible-xs,.visible-sm,.visible-md,.visible-lg,.visible-xl{display:block}@media (min-width: 481px){.hidden-xs{display:block}.visible-xs{display:none}}@media (min-width: 769px){.hidden-sm{display:block}.visible-sm{display:none}}@media (min-width: 1025px){.hidden-md{display:block}.visible-md{display:none}}@media (min-width: 1201px){.hidden-lg{display:block}.visible-lg{display:none}}@media (min-width: 1401px){.hidden-xl{display:block}.visible-xl{display:none}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (hover: none) and (pointer: coarse){.btn-responsive{min-height:44px;min-width:44px}.card-responsive{cursor:default}.card-responsive:hover{transform:none}}.dashboard-container{min-height:100vh;width:100%;overflow-x:hidden}@media screen and (orientation: portrait){.dashboard-container{padding-top:80px}}@media screen and (orientation: landscape) and (max-height: 500px){.dashboard-container{padding-top:60px}}.dashboard-card{min-height:120px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:1rem;border-radius:12px;background:#fff;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.dashboard-grid{display:grid;gap:1rem;width:100%}@media (max-width: 480px){.dashboard-grid{grid-template-columns:1fr;gap:.75rem}.dashboard-card{min-height:100px;padding:.75rem}}@media (min-width: 481px) and (max-width: 768px){.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media (min-width: 769px) and (max-width: 1024px){.dashboard-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}@media (min-width: 1025px){.dashboard-grid{grid-template-columns:repeat(5,1fr);gap:1.5rem}}.dashboard-title{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:700;text-align:center;margin-bottom:.5rem}.dashboard-subtitle{font-size:clamp(.875rem,2.5vw,1.125rem);text-align:center;margin-bottom:2rem}.dashboard-main{max-width:1400px;margin:0 auto;padding:clamp(1rem,3vw,2rem);padding-top:clamp(80px,10vh,120px)}.notifications-container{position:fixed;top:80px;right:1rem;z-index:1000;max-width:350px}@media (max-width: 768px){.notifications-container{top:70px;right:.5rem;left:.5rem;max-width:none}}:root{font-family:Inter,system-ui,sans-serif}:root{--color-primario: #3b82f6;--color-primario-hover: #2563eb;--color-secundario: #f59e0b;--color-exito: #10b981;--color-error: #ef4444;--color-advertencia: #f59e0b;--color-fondo: #f8fafc;--color-fondo-tarjeta: #ffffff;--color-fondo-hover: #f1f5f9;--color-borde: #e2e8f0;--color-texto: #1e293b;--color-texto-secundario: #64748b;--radio-borde: .5rem;--radio-borde-lg: 1rem;--sombra: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--sombra-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--gradiente-primario: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradiente-secundario: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradiente-azul: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:var(--color-texto);background-color:var(--color-fondo)}.pagina-con-navbar{padding-top:4rem}.contenedor{max-width:1200px;margin:0 auto;padding:0 1rem}.contenedor-pequeno{max-width:480px;margin:0 auto;padding:0 1rem}.contenedor-medio{max-width:768px;margin:0 auto;padding:0 1rem}.flex{display:flex}.flex-columna{flex-direction:column}.centrado{align-items:center;justify-content:center}.entre{justify-content:space-between}.items-centro{align-items:center}.h-pantalla{height:100vh}.h-pantalla-minimo{min-height:100vh}.titulo-1{font-size:3rem;font-weight:800;line-height:1.1;margin-bottom:1rem}.titulo-2{font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:.75rem}.titulo-3{font-size:1.875rem;font-weight:600;line-height:1.3;margin-bottom:.5rem}.texto-grande{font-size:1.25rem;line-height:1.6}.texto-medio{font-size:1rem;line-height:1.5}.texto-pequeno{font-size:.875rem;line-height:1.4}.texto-centro{text-align:center}.texto-blanco{color:#fff}.texto-gris{color:var(--color-texto-secundario)}.texto-verde{color:var(--color-exito)}.texto-rojo{color:var(--color-error)}.boton{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:var(--radio-borde);font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease-in-out;min-width:fit-content}.boton-primario{background:var(--gradiente-primario);color:#fff;box-shadow:var(--sombra)}.boton-primario:hover{transform:translateY(-2px);box-shadow:var(--sombra-lg)}.boton-secundario{background-color:#fff;color:var(--color-primario);border:2px solid var(--color-primario)}.boton-secundario:hover{background-color:var(--color-primario);color:#fff}.boton-exito{background-color:var(--color-exito);color:#fff}.boton-exito:hover{background-color:#059669}.boton-completo{width:100%}.boton-grande{padding:1rem 2rem;font-size:1.125rem}.grupo-campo{margin-bottom:1.5rem}.etiqueta{display:block;font-size:.875rem;font-weight:500;color:var(--color-texto);margin-bottom:.5rem}.campo{width:100%;padding:.75rem 1rem;border:2px solid var(--color-borde);border-radius:var(--radio-borde);font-size:1rem;background-color:#fff;transition:border-color .2s,box-shadow .2s}.campo-error{border-color:var(--color-error)}.mensaje-error{color:var(--color-error);font-size:.875rem;margin-top:.25rem}.tarjeta{background-color:var(--color-fondo-tarjeta);border-radius:var(--radio-borde-lg);box-shadow:var(--sombra);padding:2rem;border:1px solid var(--color-borde)}.tarjeta-elevada{box-shadow:var(--sombra-lg)}.tarjeta-gradiente{background:var(--gradiente-azul);color:#fff}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr);gap:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mr-6{margin-right:1.5rem}.ml-2{margin-left:.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.texto-primario{color:var(--color-primario)}.texto-primario:hover{text-decoration:underline}a:hover{text-decoration:none}input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--color-primario)}textarea.campo{resize:vertical;min-height:6rem}.cursor-pointer{cursor:pointer}.navbar{background-color:#fff;border-bottom:1px solid var(--color-borde);box-shadow:var(--sombra);padding:1rem 0;position:sticky;top:0;z-index:100}.navbar-contenido{display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:var(--color-primario);text-decoration:none}.hero{background:var(--gradiente-primario);color:#fff;padding:6rem 0;text-align:center}.caracteristicas{padding:6rem 0;background-color:#fff}.caracteristica{text-align:center;padding:2rem}.icono-caracteristica{width:4rem;height:4rem;background:var(--gradiente-azul);border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff}.animacion-entrada{animation:entrada .6s ease-out}@keyframes entrada{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animacion-flotante{animation:flotante 6s ease-in-out infinite}@keyframes flotante{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.cargando{display:inline-block;width:1.5rem;height:1.5rem;border:2px solid #f3f3f3;border-top:2px solid var(--color-primario);border-radius:50%;animation:girar 1s linear infinite}@keyframes girar{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.alerta{padding:1rem;border-radius:var(--radio-borde);margin-bottom:1rem;border-left:4px solid}.alerta-exito{background-color:#f0f9ff;border-color:var(--color-exito);color:#065f46}.alerta-error{background-color:#fef2f2;border-color:var(--color-error);color:#991b1b}.alerta-advertencia{background-color:#fffbeb;border-color:var(--color-advertencia);color:#92400e}.pagina-cargando,.pagina-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-fondo)}.pagina-cargando{flex-direction:column;gap:1rem}.contenido-error{text-align:center;padding:2rem}.contenido-error h1{font-size:2rem;color:var(--color-error);margin-bottom:1rem}.contenido-error p{color:var(--color-texto-secundario);margin-bottom:.5rem}.tienda-cliente{min-height:100vh;background-color:#fff}.header-tienda{background-color:#fff;border-bottom:1px solid var(--color-borde);box-shadow:var(--sombra);position:sticky;top:0;z-index:100}.header-tienda .contenedor{display:flex;align-items:center;justify-content:space-between;padding:1rem}.logo-empresa{display:flex;align-items:center}.logo-img{height:2.5rem;width:auto;object-fit:contain}.logo-texto{font-size:1.5rem;font-weight:700;color:var(--color-primario)}.nav-tienda{display:flex;align-items:center;gap:2rem}.nav-link{text-decoration:none;color:var(--color-texto);font-weight:500;transition:color .2s}.nav-link:hover{color:var(--color-primario)}.btn-carrito{background:var(--color-primario);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radio-borde);display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:background-color .2s}.btn-carrito:hover{background:var(--color-primario-hover)}.carrito-contador{background:#fff3;padding:.25rem .5rem;border-radius:9999px;font-size:.875rem;font-weight:700}.hero-tienda{background:var(--gradiente-azul);color:#fff;padding:4rem 0;text-align:center}.hero-contenido{max-width:600px;margin:0 auto}.hero-titulo{font-size:3rem;font-weight:700;margin-bottom:1rem}.hero-descripcion{font-size:1.25rem;margin-bottom:2rem;opacity:.9}.btn-hero{background:#fff;color:var(--color-primario);padding:1rem 2rem;font-size:1.125rem;font-weight:600}.btn-hero:hover{background:#f8fafc;transform:translateY(-2px)}.seccion-productos{padding:4rem 0;background-color:#f8fafc}.titulo-seccion{text-align:center;font-size:2.5rem;font-weight:700;margin-bottom:3rem;color:var(--color-texto)}.productos-cargando,.productos-error,.productos-vacio{text-align:center;padding:3rem;background:#fff;border-radius:var(--radio-borde-lg);box-shadow:var(--sombra)}.productos-error .btn-secundario{margin-top:1rem}.grid-productos{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem}.tarjeta-producto{background:#fff;border-radius:var(--radio-borde-lg);box-shadow:var(--sombra);overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:pointer}.tarjeta-producto:hover{transform:translateY(-4px);box-shadow:var(--sombra-lg)}.producto-imagen{width:100%;height:200px;overflow:hidden;background-color:#f8fafc;display:flex;align-items:center;justify-content:center}.producto-imagen img{width:100%;height:100%;object-fit:cover}.placeholder-imagen{font-size:3rem;opacity:.5}.producto-info{padding:1.5rem}.producto-nombre{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:var(--color-texto)}.producto-descripcion{color:var(--color-texto-secundario);margin-bottom:1rem;line-height:1.5}.producto-precio{font-size:1.5rem;font-weight:700;color:var(--color-primario);margin-bottom:.5rem}.producto-stock{margin-bottom:1rem}.stock-disponible{color:var(--color-exito);font-size:.875rem;font-weight:500}.stock-agotado{color:var(--color-error);font-size:.875rem;font-weight:500}.btn-agregar-carrito{width:100%;padding:.75rem;background:var(--color-primario);color:#fff;border:none;border-radius:var(--radio-borde);font-weight:600;cursor:pointer;transition:background-color .2s}.btn-agregar-carrito:hover:not(:disabled){background:var(--color-primario-hover)}.btn-agregar-carrito:disabled{background:#d1d5db;cursor:not-allowed}.footer-tienda{background:var(--color-texto);color:#fff;padding:3rem 0 1rem}.footer-contenido{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer-seccion h4{font-size:1.125rem;font-weight:700;margin-bottom:1rem;color:#fff}.footer-seccion p{color:#cbd5e1;margin-bottom:.5rem}.redes-sociales{display:flex;gap:1rem}.red-social{color:#cbd5e1;text-decoration:none;font-size:.875rem;transition:color .2s}.red-social:hover{color:#fff}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid #374151}.footer-bottom p{color:#9ca3af;font-size:.875rem}.login-cliente-pagina{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.header-login-cliente{background:#ffffff1a;backdrop-filter:blur(10px);padding:1rem 0}.logo-empresa-login{display:inline-flex;align-items:center;text-decoration:none}.logo-empresa-login .logo-img{height:2.5rem;width:auto;object-fit:contain}.logo-empresa-login .logo-texto{font-size:1.5rem;font-weight:700;color:#fff}.contenido-login-cliente{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 0}.tarjeta-login-cliente{background:#fff;border-radius:var(--radio-borde-lg);box-shadow:0 25px 50px -12px #00000040;padding:2.5rem;width:100%;max-width:400px;margin:0 auto}.encabezado-login{text-align:center;margin-bottom:2rem}.titulo-login{font-size:1.875rem;font-weight:700;color:var(--color-texto);margin-bottom:.5rem}.subtitulo-login{color:var(--color-texto-secundario)}.formulario-login-cliente{display:flex;flex-direction:column;gap:1.5rem}.opciones-login{display:flex;justify-content:space-between;align-items:center;margin:-.5rem 0}.checkbox-container{display:flex;align-items:center;cursor:pointer;font-size:.875rem;color:var(--color-texto-secundario)}.checkbox{margin-right:.5rem}.enlace-recuperar{color:var(--color-primario);text-decoration:none;font-size:.875rem;font-weight:500}.enlace-recuperar:hover{text-decoration:underline}.separador-login{text-align:center;margin:1.5rem 0;position:relative;color:var(--color-texto-secundario);font-size:.875rem}.separador-login:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--color-borde);z-index:1}.separador-login span{background:#fff;padding:0 1rem;position:relative;z-index:2}.volver-tienda{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-borde)}.enlace-volver{color:var(--color-texto-secundario);text-decoration:none;font-size:.875rem;transition:color .2s}.enlace-volver:hover{color:var(--color-primario)}.footer-login-cliente{background:#ffffff1a;backdrop-filter:blur(10px);text-align:center;padding:1rem 0;color:#fffc;font-size:.875rem}@media (max-width: 480px){.tarjeta-login-cliente{margin:1rem;padding:2rem 1.5rem}.titulo-login{font-size:1.5rem}}@media (max-width: 768px){.titulo-1{font-size:2rem}.titulo-2{font-size:1.5rem}.grid-2,.grid-3{grid-template-columns:1fr;gap:1rem}.tarjeta{padding:1.5rem}.hero,.caracteristicas{padding:4rem 0}.boton{padding:.875rem 1.25rem}.header-tienda .contenedor{flex-direction:column;gap:1rem}.nav-tienda{justify-content:center;flex-wrap:wrap}.hero-titulo{font-size:2rem}.hero-descripcion{font-size:1rem}.grid-productos{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.footer-contenido{grid-template-columns:1fr;text-align:center}}@media (max-width: 480px){.contenedor,.contenedor-pequeno,.contenedor-medio{padding:0 .75rem}.titulo-1{font-size:1.75rem}.tarjeta{padding:1rem}.hero{padding:3rem 0}}.info-multitenant{background-color:var(--color-fondo);padding:2rem 0;border-top:1px solid var(--color-borde)}.info-detalle{margin-bottom:2rem}.info-detalle p{margin-bottom:.5rem}.info-empresa{background-color:#f8fafc;padding:1rem;border-radius:var(--radio-borde);margin-top:1rem}.info-empresa h4{margin-bottom:.5rem;color:var(--color-primario)}.prueba-subdominios{background-color:#fef3c7;padding:1.5rem;border-radius:var(--radio-borde);border-left:4px solid var(--color-advertencia)}.prueba-subdominios h4{color:#92400e;margin-bottom:1rem}.prueba-subdominios ol{margin-left:1.5rem;margin-bottom:1rem}.prueba-subdominios li{margin-bottom:.5rem}.comando-hosts{background-color:#374151;color:#fff;padding:1rem;border-radius:var(--radio-borde);margin-top:1rem}.comando-hosts h5{margin-bottom:.5rem;font-size:.875rem}.comando-hosts code{background-color:#1f2937;padding:.5rem;border-radius:4px;display:block;font-family:Courier New,monospace}.oculto{display:none}.visible{display:block}.opacidad-50{opacity:.5}.cursor-no-permitido{cursor:not-allowed}.texto-truncado{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sombra{box-shadow:var(--sombra)}.sombra-lg{box-shadow:var(--sombra-lg)}.borde-redondeado{border-radius:var(--radio-borde)}.borde-redondeado-lg{border-radius:var(--radio-borde-lg)}.registro-cliente-pagina{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.tarjeta-registro-cliente{background:#fff;border-radius:var(--radio-borde-lg);box-shadow:0 25px 50px -12px #00000040;padding:2.5rem;width:100%;max-width:500px;margin:0 auto}.formulario-registro-cliente{display:flex;flex-direction:column;gap:1.5rem}.grupo-campos-doble{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkboxes-registro{display:flex;flex-direction:column;gap:.75rem}.checkboxes-registro .checkbox-container{font-size:.875rem;line-height:1.4}.enlace-terminos{color:var(--color-primario);text-decoration:none;font-weight:500}.enlace-terminos:hover{text-decoration:underline}.max-w-2xl{max-width:672px}.max-w-4xl{max-width:896px}.mx-auto{margin-left:auto;margin-right:auto}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.h-12{height:3rem}.border-gray-200{border-color:#e5e7eb}.border-gray-300,.hover\:border-gray-300:hover{border-color:#d1d5db}.transition-colors{transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.bg-gray-50{background-color:#f9fafb}input[type=checkbox]{width:1rem;height:1rem;border:1px solid var(--color-borde);border-radius:.25rem;background-color:#fff;cursor:pointer}input[type=checkbox]:checked{background-color:var(--color-primario);border-color:var(--color-primario)}input[type=color]{padding:.25rem;border:1px solid var(--color-borde);border-radius:var(--radio-borde);cursor:pointer}.spinner{width:2rem;height:2rem;border:3px solid var(--color-borde);border-top:3px solid var(--color-primario);border-radius:50%;animation:spin 1s linear infinite}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.badge-pendiente{background-color:#fef3c7;color:#92400e}.badge-procesando{background-color:#dbeafe;color:#1e40af}.badge-enviado{background-color:#e0e7ff;color:#5b21b6}.badge-entregado{background-color:#d1fae5;color:#065f46}.badge-cancelado{background-color:#fee2e2;color:#991b1b}.campo-grupo{position:relative}.campo:focus{outline:none;border-color:var(--color-primario);box-shadow:0 0 0 3px #3b82f61a}@media (max-width: 640px){.grid-2,.grid-3{grid-template-columns:1fr}.max-w-2xl,.max-w-4xl{max-width:100%}}.text-center{text-align:center}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.025em}.relative{position:relative}.absolute{position:absolute}.top-0{top:0}.right-0{right:0}.z-10{z-index:10}.pagina-productos{background-color:#f8fafc;min-height:100vh}.pagina-productos .contenedor-principal{max-width:1400px;margin:0 auto;padding:20px}.encabezado-productos{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.titulo-seccion h1{font-size:2.2rem;font-weight:700;color:#1e293b;margin:0 0 8px}.titulo-seccion p{color:#64748b;margin:0;font-size:1.1rem}.acciones-principales .boton-primario{display:flex;align-items:center;gap:8px;background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.acciones-principales .boton-primario:hover{background:#2563eb;transform:translateY(-1px)}.acciones-principales .icono{font-size:1.2rem}.seccion-filtros{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:20px}.barra-busqueda{display:flex;gap:10px;margin-bottom:15px}.barra-busqueda input{flex:1;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s}.barra-busqueda input:focus{outline:none;border-color:#3b82f6}.boton-buscar{background:#10b981;color:#fff;border:none;padding:12px 16px;border-radius:8px;cursor:pointer;transition:background-color .2s}.boton-buscar:hover{background:#059669}.filtros-avanzados{display:flex;gap:15px;align-items:center;flex-wrap:wrap;margin-bottom:15px}.filtros-avanzados select{padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.95rem}.filtros-avanzados select:focus{outline:none;border-color:#3b82f6}.boton-secundario{background:#f1f5f9;color:#475569;border:2px solid #e2e8f0;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.boton-secundario:hover{background:#e2e8f0;border-color:#cbd5e1}.opciones-vista{display:flex;justify-content:flex-end}.toggle-vista{display:flex;background:#f1f5f9;border-radius:8px;overflow:hidden}.boton-vista{background:transparent;border:none;padding:10px 16px;cursor:pointer;font-weight:500;color:#64748b;transition:all .2s}.boton-vista:hover:not(.activo){background:#e2e8f0}.info-resultados{margin-bottom:20px}.info-resultados p{color:#64748b;font-size:.95rem;margin:0}.vista-lista{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden}.tabla-productos{width:100%}.encabezado-tabla{display:grid;grid-template-columns:80px 2fr 120px 140px 120px 100px 140px;gap:16px;padding:16px;background:#f8fafc;border-bottom:2px solid #e2e8f0;font-weight:600;color:#374151;font-size:.9rem}.fila-producto{display:grid;grid-template-columns:80px 2fr 120px 140px 120px 100px 140px;gap:16px;padding:16px;border-bottom:1px solid #f1f5f9;align-items:center;transition:background-color .2s}.fila-producto:hover{background:#f8fafc}.imagen-producto-mini{width:60px;height:60px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0}.info-producto h3{margin:0 0 4px;font-size:1rem;font-weight:600;color:#1e293b;cursor:pointer;transition:color .2s}.info-producto p{margin:0 0 4px;color:#64748b;font-size:.9rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.info-producto .marca{color:#8b5cf6;font-size:.85rem;font-weight:500}.precio{font-size:1.1rem;font-weight:700;color:#059669}.unidad{color:#64748b;font-size:.9rem;margin-left:4px}.control-stock{display:flex;align-items:center;gap:8px}.boton-stock{background:#3b82f6;color:#fff;border:none;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:600;transition:all .2s}.boton-stock:hover:not(:disabled){background:#2563eb;transform:scale(1.05)}.boton-stock:disabled{background:#cbd5e1;cursor:not-allowed}.stock{font-weight:600;font-size:1rem;min-width:40px;text-align:center;color:#059669}.stock.stock-bajo{color:#dc2626}.alerta-stock{color:#dc2626;font-size:.8rem;font-weight:500;margin-top:4px}.estado.activo{color:#059669;font-weight:600}.estado.inactivo{color:#64748b;font-weight:600}.destacado{background:#fbbf24;color:#fff;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:600;margin-top:4px;display:inline-block}.acciones-producto{display:flex;gap:8px}.boton-accion{background:#f1f5f9;border:none;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:.9rem}.boton-accion:hover{background:#e2e8f0;transform:scale(1.05)}.boton-accion.peligro:hover{background:#fecaca;color:#dc2626}.vista-cuadricula{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px}.grilla-productos{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.tarjeta-producto{background:#fff;border:2px solid #f1f5f9;border-radius:12px;overflow:hidden;transition:all .3s;cursor:pointer}.tarjeta-producto:hover{border-color:#3b82f6;box-shadow:0 8px 25px #3b82f626;transform:translateY(-4px)}.imagen-container{position:relative;height:200px;overflow:hidden}.imagen-producto{width:100%;height:100%;object-fit:cover;transition:transform .3s}.tarjeta-producto:hover .imagen-producto{transform:scale(1.05)}.overlay-acciones{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .3s}.tarjeta-producto:hover .overlay-acciones{opacity:1}.boton-overlay{background:#ffffffe6;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;backdrop-filter:blur(4px)}.boton-overlay:hover{background:#fff;transform:scale(1.1)}.badge-destacado{position:absolute;top:8px;left:8px;background:#fbbf24;color:#fff;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.badge-inactivo{position:absolute;top:8px;left:8px;background:#64748b;color:#fff;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.info-tarjeta{padding:16px}.info-tarjeta h3{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:#1e293b}.info-tarjeta .descripcion{color:#64748b;font-size:.9rem;margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.precio-stock{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.control-stock-mini{display:flex;align-items:center;gap:6px}.boton-stock-mini{background:#3b82f6;color:#fff;border:none;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s}.boton-stock-mini:hover:not(:disabled){background:#2563eb}.boton-stock-mini:disabled{background:#cbd5e1;cursor:not-allowed}.metadata{display:flex;gap:8px;flex-wrap:wrap}.categoria,.marca{background:#f1f5f9;color:#475569;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:500}.marca{background:#f3e8ff;color:#8b5cf6}.paginacion{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:30px;padding:20px}.boton-paginacion{background:#fff;border:2px solid #e2e8f0;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:500;color:#64748b;transition:all .2s}.boton-paginacion:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.boton-paginacion:disabled{background:#f1f5f9;color:#cbd5e1;cursor:not-allowed}.numeros-pagina{display:flex;gap:4px}.numero-pagina{background:#fff;border:2px solid #e2e8f0;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:600;transition:all .2s}.numero-pagina:hover{border-color:#3b82f6;color:#3b82f6}.numero-pagina.activo{background:#3b82f6;border-color:#3b82f6;color:#fff}.sin-productos{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.sin-productos .ilustracion{font-size:4rem;margin-bottom:20px}.sin-productos h3{color:#1e293b;font-size:1.5rem;margin:0 0 8px}.sin-productos p{color:#64748b;margin:0 0 24px;font-size:1.1rem}.pagina-detalle-producto{background-color:#f8fafc;min-height:100vh}.navegacion-superior{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.boton-volver{background:#f1f5f9;color:#475569;border:2px solid #e2e8f0;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.boton-volver:hover{background:#e2e8f0;border-color:#cbd5e1}.detalle-contenido{display:grid;grid-template-columns:1fr 1fr;gap:40px;background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000000d}.galeria-imagenes{display:flex;flex-direction:column;gap:16px}.imagen-principal{position:relative;background:#f8fafc;border-radius:12px;overflow:hidden;border:2px solid #e2e8f0}.imagen-grande{width:100%;height:400px;object-fit:cover;display:block}.controles-imagen{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:#000000b3;padding:8px 16px;border-radius:24px;color:#fff}.boton-control{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;transition:all .2s}.boton-control:hover:not(:disabled){background:#ffffff4d}.boton-control:disabled{opacity:.3;cursor:not-allowed}.contador-imagenes{font-size:.9rem;font-weight:500}.miniaturas{display:flex;gap:8px;overflow-x:auto;padding:8px 0}.miniatura{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0;cursor:pointer;transition:all .2s;flex-shrink:0}.miniatura:hover{border-color:#3b82f6}.miniatura.activa{border-color:#3b82f6;transform:scale(1.05)}.informacion-producto{display:flex;flex-direction:column;gap:24px}.encabezado-producto{border-bottom:2px solid #f1f5f9;padding-bottom:20px}.titulo-y-estado h1{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 12px}.badges{display:flex;gap:8px;flex-wrap:wrap}.badge-estado{padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.badge-estado.activo{background:#dcfce7;color:#166534}.badge-estado.inactivo{background:#f1f5f9;color:#64748b}.badge-destacado{background:#fef3c7;color:#d97706;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.badge-stock-bajo{background:#fecaca;color:#dc2626;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.precio-principal{margin-top:16px}.precio-principal .precio{font-size:2.5rem;font-weight:800;color:#059669}.precio-principal .unidad{color:#64748b;font-size:1.2rem;margin-left:8px}.seccion-descripcion h3,.seccion-informacion h3,.seccion-stock h3,.seccion-acciones h3{font-size:1.2rem;font-weight:600;color:#1e293b;margin:0 0 12px}.seccion-descripcion p{color:#64748b;line-height:1.6;margin:0}.tabla-informacion{display:flex;flex-direction:column;gap:8px}.fila-info{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f1f5f9}.fila-info .etiqueta{font-weight:500;color:#64748b}.fila-info .valor{font-weight:600;color:#1e293b}.controles-stock{display:flex;flex-direction:column;gap:16px}.stock-actual{display:flex;justify-content:space-between;align-items:center}.control-stock-detalle{display:flex;align-items:center;gap:12px}.control-stock-detalle .boton-stock{width:36px;height:36px;font-size:1.2rem}.control-stock-detalle .stock{font-size:1.3rem;min-width:50px}.stock-minimo{display:flex;justify-content:space-between;align-items:center}.alerta-stock-bajo{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:8px;font-weight:500;margin-top:12px}.botones-accion{display:flex;flex-direction:column;gap:12px}.boton-toggle{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;font-weight:500;transition:all .2s;text-align:left}.boton-toggle.activo{border-color:#dc2626;background:#fef2f2;color:#dc2626}.boton-toggle.inactivo{border-color:#10b981;background:#f0fdf4;color:#10b981}.boton-toggle.destacado{border-color:#d97706;background:#fffbeb;color:#d97706}.boton-toggle.normal{border-color:#fbbf24;background:#fefce8;color:#d97706}.boton-editar{background:#3b82f6;color:#fff;border:none;padding:12px 16px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.boton-editar:hover{background:#2563eb;transform:translateY(-1px)}.gestor-imagenes{margin-bottom:1.5rem}.imagenes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:.5rem;margin-bottom:1rem}.imagen-item{aspect-ratio:1;border-radius:var(--radio-borde);overflow:hidden;border:2px dashed var(--color-borde);position:relative}.imagen-preview{width:100%;height:100%;position:relative}.imagen-preview img{width:100%;height:100%;object-fit:cover;border-radius:calc(var(--radio-borde) - 2px)}.btn-eliminar-imagen{position:absolute;top:.5rem;right:.5rem;background:#ef4444e6;color:#fff;border:none;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;font-weight:700;transition:all .2s ease}.btn-eliminar-imagen:hover{background:#ef4444;transform:scale(1.1)}.btn-agregar-imagen{width:100%;height:100%;border:none;background:transparent;color:var(--color-texto-secundario);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease;font-size:.875rem;text-align:center;padding:1rem}.btn-agregar-imagen:hover{background:var(--color-fondo-hover);color:var(--color-primario);border-color:var(--color-primario)}.btn-agregar-imagen:disabled{opacity:.6;cursor:not-allowed}.icono-mas{font-size:2rem;font-weight:700}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:.5rem}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--color-borde);border-top:2px solid var(--color-primario);border-radius:50%;animation:spin 1s linear infinite}.info-imagenes{margin-top:.5rem}.info-imagenes .text-muted{color:var(--color-texto-secundario);font-size:.875rem;line-height:1.4}.navbar-admin{background:#fffffff2;backdrop-filter:blur(20px);border-bottom:1px solid var(--color-borde);position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:var(--sombra)}.navbar-admin-contenedor{max-width:1400px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;min-height:4rem}.navbar-admin-logo{flex-shrink:0}.navbar-admin-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;font-size:1.5rem;font-weight:700;color:var(--color-texto);transition:all .2s ease}.navbar-admin-brand:hover{transform:translateY(-1px)}.navbar-admin-brand-icon{font-size:1.75rem;color:var(--color-primario)}.navbar-admin-brand-text{background:var(--gradiente-primario);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-admin-empresa{color:var(--color-primario);font-weight:600;padding:.25rem .75rem;background-color:#3b82f61a;border-radius:var(--radio-borde);font-size:.875rem;border:1px solid rgba(59,130,246,.2)}.navbar-admin-nav{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center}.navbar-admin-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;text-decoration:none;color:var(--color-texto-secundario);border-radius:var(--radio-borde);font-weight:500;font-size:.875rem;transition:all .2s ease;position:relative}.navbar-admin-link:hover{background-color:var(--color-fondo-hover);color:var(--color-texto);transform:translateY(-1px)}.navbar-admin-link.activo{background-color:var(--color-primario);color:#fff;box-shadow:var(--sombra)}.navbar-admin-link.activo:hover{background-color:var(--color-primario-hover);transform:translateY(-1px)}.navbar-admin-link-icon{font-size:1.125rem}.navbar-admin-link-text{font-weight:500}.navbar-admin-user{display:flex;align-items:center;gap:1rem;flex-shrink:0}.navbar-admin-user-info{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#3b82f60d;border-radius:var(--radio-borde-lg);border:1px solid rgba(59,130,246,.1)}.navbar-admin-user-avatar{width:2rem;height:2rem;background:var(--gradiente-primario);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;color:#fff;font-weight:600}.navbar-admin-user-name{font-size:.875rem;color:var(--color-texto);font-weight:500}.navbar-admin-logout{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fff;color:var(--color-error);border:2px solid var(--color-error);border-radius:var(--radio-borde);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.navbar-admin-logout:hover{background:var(--color-error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.navbar-admin-logout-icon{font-size:1rem}.navbar-admin-logout-text{font-weight:600}@media (max-width: 1024px){.navbar-admin-nav{gap:.25rem}.navbar-admin-link{padding:.5rem .75rem}.navbar-admin-link-text{display:none}.navbar-admin-link-icon{font-size:1.25rem}}@media (max-width: 768px){.navbar-admin-contenedor{flex-direction:column;gap:1rem;padding:1rem}.navbar-admin-nav{order:2;width:100%;justify-content:space-between}.navbar-admin-user{order:3;width:100%;justify-content:center}.navbar-admin-user-name,.navbar-admin-logout-text{display:none}}.navbar-admin-pages{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:0;box-shadow:0 4px 6px -1px #0000001a;position:sticky;top:0;z-index:1000}.navbar-admin-pages-contenedor{max-width:1400px;margin:0 auto;padding:.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;min-height:3rem}.navbar-admin-pages-logo{flex-shrink:0}.navbar-admin-pages-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:#fff;font-weight:600;font-size:1.25rem;transition:opacity .2s ease}.navbar-admin-pages-brand:hover{opacity:.9}.navbar-admin-pages-brand-icon{font-size:1.5rem}.navbar-admin-pages-brand-text{font-weight:700}.navbar-admin-pages-empresa{font-size:.875rem;opacity:.9;font-weight:400;margin-left:.5rem;padding-left:.5rem;border-left:1px solid rgba(255,255,255,.3)}.navbar-admin-pages-nav{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center;margin:0 2rem}.navbar-admin-pages-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;text-decoration:none;color:#fffc;border-radius:.5rem;font-weight:500;transition:all .2s ease;position:relative}.navbar-admin-pages-link:hover{color:#fff;background-color:#ffffff1a;transform:translateY(-1px)}.navbar-admin-pages-link.activo{color:#fff;background-color:#fff3;box-shadow:0 2px 4px #0000001a}.navbar-admin-pages-link.activo:hover{background-color:#ffffff40}.navbar-admin-pages-link-icon{font-size:1.125rem}.navbar-admin-pages-link-text{font-size:.875rem}.navbar-admin-pages-user{display:flex;align-items:center;gap:1rem;flex-shrink:0}.navbar-admin-pages-user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background-color:#ffffff1a;border-radius:.5rem;backdrop-filter:blur(10px)}.navbar-admin-pages-user-avatar{width:2rem;height:2rem;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#fff}.navbar-admin-pages-user-name{font-size:.875rem;font-weight:500;color:#fff}.navbar-admin-pages-logout{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#ef4444e6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.navbar-admin-pages-logout:hover{background-color:#dc2626;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.navbar-admin-pages-logout-icon{font-size:1rem}.navbar-admin-pages-logout-text{font-size:.875rem}@media (max-width: 1024px){.navbar-admin-pages-nav{gap:.25rem}.navbar-admin-pages-link{padding:.5rem .75rem}.navbar-admin-pages-link-text{font-size:.75rem}.navbar-admin-pages-link-icon{font-size:1rem}}@media (max-width: 768px){.navbar-admin-pages-contenedor{padding:.75rem 1rem}.navbar-admin-pages-nav{display:none}.navbar-admin-pages-user{gap:.5rem}.navbar-admin-pages-user-name,.navbar-admin-pages-logout-text{display:none}}.animate-spin{animation:spin 1s linear infinite}:root{--color-fondo: #f8fafc;--color-fondo-secundario: #ffffff;--color-texto-principal: #1e293b;--color-texto-secundario: #64748b;--color-texto-terciario: #94a3b8;--color-borde: #e2e8f0;--color-borde-secundario: #cbd5e1;--color-sombra: rgba(0, 0, 0, .1);--color-sombra-fuerte: rgba(0, 0, 0, .2);--color-navbar: rgba(255, 255, 255, .95);--color-card: #ffffff;--color-card-hover: #f8fafc;--gradiente-fondo: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);--gradiente-titulo: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}:root.dark{--color-fondo: #0f172a;--color-fondo-secundario: #1e293b;--color-texto-principal: #f1f5f9;--color-texto-secundario: #94a3b8;--color-texto-terciario: #64748b;--color-borde: #334155;--color-borde-secundario: #475569;--color-sombra: rgba(0, 0, 0, .3);--color-sombra-fuerte: rgba(0, 0, 0, .5);--color-navbar: rgba(15, 23, 42, .95);--color-card: #1e293b;--color-card-hover: #334155;--gradiente-fondo: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);--gradiente-titulo: linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%)}:root.light{--color-fondo: #f8fafc;--color-fondo-secundario: #ffffff;--color-texto-principal: #1e293b;--color-texto-secundario: #64748b;--color-texto-terciario: #94a3b8;--color-borde: #e2e8f0;--color-borde-secundario: #cbd5e1;--color-sombra: rgba(0, 0, 0, .1);--color-sombra-fuerte: rgba(0, 0, 0, .2);--color-navbar: rgba(255, 255, 255, .95);--color-card: #ffffff;--color-card-hover: #f8fafc;--gradiente-fondo: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);--gradiente-titulo: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}body{background-color:var(--color-fondo);color:var(--color-texto-principal)}.card{background-color:var(--color-card);border:1px solid var(--color-borde);box-shadow:0 4px 6px -1px var(--color-sombra)}.text-primary{color:var(--color-texto-principal)}.text-secondary{color:var(--color-texto-secundario)}.text-tertiary{color:var(--color-texto-terciario)}.bg-primary{background-color:var(--color-fondo)}.bg-secondary{background-color:var(--color-fondo-secundario)}.border-primary{border-color:var(--color-borde)}.border-secondary{border-color:var(--color-borde-secundario)}.gestor-imagenes{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:#374151;font-size:14px}.imagenes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;margin-bottom:12px}.imagen-item{position:relative;aspect-ratio:1;border:2px dashed #d1d5db;border-radius:8px;overflow:hidden}.imagen-item.agregar{display:flex;align-items:center;justify-content:center}.imagen-preview{position:relative;width:100%;height:100%}.imagen-preview img{width:100%;height:100%;object-fit:cover;border-radius:6px}.btn-eliminar-imagen{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#ef4444e6;color:#fff;border:none;border-radius:50%;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-eliminar-imagen:hover{background:#dc2626;transform:scale(1.1)}.btn-agregar-imagen{width:100%;height:100%;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#6b7280;font-size:12px;transition:all .2s ease}.btn-agregar-imagen:hover{border-color:#3b82f6;background:#eff6ff;color:#3b82f6}.btn-agregar-imagen:disabled{cursor:not-allowed;opacity:.6}.btn-agregar-imagen.btn-camara:hover{border-color:#10b981;background:#ecfdf5;color:#10b981}.icono-mas{font-size:24px;font-weight:700}.icono-galeria,.icono-camara{font-size:20px}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:4px}.spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.info-imagenes{margin-top:8px}.text-muted{color:#6b7280;font-size:12px;line-height:1.4}.modal-camara-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-camara{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-camara-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb}.modal-camara-header h3{margin:0;font-size:18px;font-weight:600;color:#374151}.btn-cerrar-modal{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.btn-cerrar-modal:hover{background:#f3f4f6;color:#374151}.modal-camara-content{padding:20px;display:flex;justify-content:center;background:#000;min-height:300px;align-items:center}.cargando-camara{display:flex;flex-direction:column;align-items:center;gap:16px;color:#fff}.cargando-camara .spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white}.cargando-camara p{margin:0;font-size:16px;font-weight:500}.video-camara{width:100%;max-width:500px;height:auto;border-radius:8px;background:#000}.modal-camara-footer{display:flex;gap:12px;padding:20px;border-top:1px solid #e5e7eb;justify-content:center}.btn-capturar{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.btn-capturar:hover{background:#2563eb;transform:translateY(-1px)}.btn-capturar:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.btn-cancelar{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancelar:hover{background:#e5e7eb;border-color:#9ca3af}@media (max-width: 640px){.imagenes-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.form-label{font-size:13px}.btn-agregar-imagen{font-size:11px}.icono-mas{font-size:20px}.icono-galeria,.icono-camara{font-size:18px}.modal-camara{margin:10px;max-height:95vh}.modal-camara-header{padding:16px}.modal-camara-header h3{font-size:16px}.modal-camara-content{padding:16px;min-height:250px}.modal-camara-footer{padding:16px;flex-direction:column}.btn-capturar,.btn-cancelar{width:100%;justify-content:center}}.importacion-productos-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.importacion-productos-modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.importacion-productos-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.importacion-productos-header h2{margin:0;font-size:1.5rem;font-weight:600}.cerrar-btn{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s}.cerrar-btn:hover{background-color:#fff3}.importacion-productos-content{padding:30px}.paso-importacion{margin-bottom:30px;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.paso-importacion h3{margin:0 0 10px;color:#333;font-size:1.2rem;font-weight:600}.paso-importacion p{margin:0 0 15px;color:#666;line-height:1.5}.btn-descargar-plantilla{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:500;transition:transform .2s,box-shadow .2s}.btn-descargar-plantilla:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-descargar-plantilla:disabled{opacity:.6;cursor:not-allowed}.btn-validar{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;margin-left:15px;transition:transform .2s,box-shadow .2s}.btn-validar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #11998e66}.btn-validar:disabled{opacity:.6;cursor:not-allowed}.btn-importar{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:500;font-size:1rem;transition:transform .2s,box-shadow .2s}.btn-importar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f093fb66}.btn-importar:disabled{opacity:.6;cursor:not-allowed}.archivo-input{width:100%;padding:12px;border:2px dashed #ddd;border-radius:6px;background:#fafafa;cursor:pointer;transition:border-color .3s}.archivo-input:hover{border-color:#667eea}.archivo-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.archivo-seleccionado{display:flex;align-items:center;margin-top:15px;padding:10px;background:#e8f5e8;border-radius:6px;border-left:4px solid #4caf50}.archivo-seleccionado span{flex:1;color:#2e7d32;font-weight:500}.resultado-validacion{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.resultado-validacion h3{margin:0 0 20px;color:#333;font-size:1.3rem;font-weight:600}.estadisticas-validacion,.estadisticas-importacion{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-bottom:20px}.stat{display:flex;flex-direction:column;align-items:center;padding:15px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a}.stat-label{font-size:.9rem;color:#666;margin-bottom:5px}.stat-value{font-size:1.5rem;font-weight:700;color:#333}.stat-value.valido,.stat-value.exito{color:#4caf50}.stat-value.error{color:#f44336}.errores-validacion,.errores-importacion{margin-top:20px}.errores-validacion h4,.errores-importacion h4{margin:0 0 15px;color:#f44336;font-size:1.1rem}.lista-errores{max-height:200px;overflow-y:auto;background:#fff;border-radius:6px;border:1px solid #ffcdd2}.error-item{display:flex;padding:10px 15px;border-bottom:1px solid #ffcdd2}.error-item:last-child{border-bottom:none}.error-fila{font-weight:600;color:#d32f2f;margin-right:10px;min-width:80px}.error-mensaje{color:#333;flex:1}.preview-productos{margin-top:20px}.preview-productos h4{margin:0 0 15px;color:#333;font-size:1.1rem}.btn-toggle-preview{background:#2196f3;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.9rem;margin-bottom:15px;transition:background-color .3s}.btn-toggle-preview:hover{background:#1976d2}.tabla-preview{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.tabla-preview table{width:100%;border-collapse:collapse}.tabla-preview th{background:#f5f5f5;padding:12px 8px;text-align:left;font-weight:600;color:#333;border-bottom:1px solid #ddd;font-size:.9rem}.tabla-preview td{padding:10px 8px;border-bottom:1px solid #eee;font-size:.9rem}.tabla-preview tr:hover{background:#f8f9fa}.preview-nota{padding:10px;background:#e3f2fd;color:#1976d2;font-size:.9rem;margin:0;text-align:center}.acciones-importacion{margin-top:20px;text-align:center}.resultado-importacion{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.resultado-importacion h3{margin:0 0 20px;color:#333;font-size:1.3rem;font-weight:600}.acciones-finales{display:flex;justify-content:space-between;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.btn-limpiar{background:#ff9800;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .3s}.btn-limpiar:hover{background:#f57c00}.btn-cerrar{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .3s}.btn-cerrar:hover{background:#5a6268}@media (max-width: 768px){.importacion-productos-modal{margin:10px;max-height:95vh}.importacion-productos-content{padding:20px}.estadisticas-validacion,.estadisticas-importacion{grid-template-columns:1fr}.archivo-seleccionado{flex-direction:column;align-items:flex-start;gap:10px}.archivo-seleccionado .btn-validar{margin-left:0;width:100%}.acciones-finales{flex-direction:column;gap:10px}.btn-limpiar,.btn-cerrar{width:100%}.tabla-preview{overflow-x:auto}.tabla-preview table{min-width:600px}}.lista-errores::-webkit-scrollbar{width:6px}.lista-errores::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.lista-errores::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.lista-errores::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.pagina-productos{min-height:100vh;background-color:#f8fafc}.sugerencias-marca{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:1000;max-height:200px;overflow-y:auto}.sugerencia-marca{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.sugerencia-marca:last-child{border-bottom:none}.sugerencia-marca:hover,.sugerencia-seleccionada{background:#f8fafc;color:#3b82f6}.sugerencia-seleccionada{background:#eff6ff!important;border-left:3px solid #3b82f6}.sugerencia-marca .icono-sector{font-size:1rem;color:#6b7280}.sugerencia-marca:hover .icono-sector{color:#3b82f6}.sugerencia-marca .texto-sector{flex:1;font-weight:500}.sugerencia-marca .badge-nuevo{background:#10b981;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.sugerencia-marca .badge-existente{background:#6b7280;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.sugerencia-nueva{border-top:2px solid #e5e7eb;background:#fef3c7}.sugerencia-nueva:hover{background:#fde68a!important}.campo-grupo[style*="position: relative"]{position:relative}.campo-grupo[style*="position: relative"] .campo-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sugerencias-marca{animation:slideDown .2s ease-out}@media (max-width: 768px){.sugerencias-marca{max-height:150px}.sugerencia-marca{padding:.5rem .75rem;font-size:.9rem}.sugerencia-marca .badge-nuevo,.sugerencia-marca .badge-existente{font-size:.7rem;padding:.2rem .4rem}}.contenedor-principal{max-width:1200px;margin:0 auto;padding:2rem}.navegacion-superior{margin-bottom:1.5rem}.boton-volver{background:#6b7280;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s;font-size:.875rem}.boton-volver:hover{background:#4b5563}.encabezado-productos{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.titulo-seccion h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.titulo-seccion p{color:#6b7280;margin:0}.acciones-principales .boton-primario{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background-color .2s}.acciones-principales .boton-primario:hover{background:#2563eb}.controles-productos{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.barra-busqueda{width:100%}.input-busqueda{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;background:#fff}.input-busqueda:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filtros-productos{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}@media (max-width: 1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-4{grid-template-columns:1fr}}.select-filtro{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;min-width:150px}.filtro-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.filtro-checkbox input[type=checkbox]{width:1rem;height:1rem}.boton-limpiar{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.boton-limpiar:hover{background:#dc2626}.controles-vista{display:flex;justify-content:space-between;align-items:center}.info-resultados{font-size:.9rem;color:#6b7280}.selector-vista{display:flex;gap:.25rem;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.boton-vista{background:#fff;border:none;padding:.5rem .75rem;cursor:pointer;font-size:1.2rem;transition:background-color .2s}.boton-vista:hover{background:#f3f4f6}.boton-vista.activo{background:#3b82f6;color:#fff}.sin-productos,.sin-resultados{text-align:center;padding:3rem 1.5rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.ilustracion{font-size:4rem;margin-bottom:1rem}.sin-productos h3,.sin-resultados h3{font-size:1.5rem;color:#374151;margin:0 0 .5rem}.sin-productos p,.sin-resultados p{color:#6b7280;margin:0 0 1.5rem}.boton-secundario{background:#6b7280;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer}.boton-secundario:hover{background:#4b5563}.vista-lista{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.tabla-productos{display:flex;flex-direction:column}.encabezado-tabla{display:grid;grid-template-columns:80px 2fr 120px 120px 120px 120px 100px;gap:1rem;padding:1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;color:#374151;font-size:.9rem}.fila-producto{display:grid;grid-template-columns:80px 2fr 120px 120px 120px 120px 100px;gap:1rem;padding:1rem;border-bottom:1px solid #e5e7eb;align-items:center}.fila-producto:hover{background:#f9fafb}.imagen-producto-mini{width:60px;height:60px;object-fit:cover;border-radius:6px}.info-producto h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 .25rem;cursor:pointer}.info-producto h3:hover{color:#3b82f6}.info-producto p{font-size:.85rem;color:#6b7280;margin:0 0 .25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.marca{font-size:.8rem;color:#9ca3af}.precio{font-weight:600;color:#059669}.unidad{font-size:.8rem;color:#6b7280}.control-stock{display:flex;align-items:center;gap:.5rem}.boton-stock{background:#e5e7eb;border:none;border-radius:4px;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700}.boton-stock:hover:not(:disabled){background:#d1d5db}.boton-stock:disabled{opacity:.5;cursor:not-allowed}.stock{font-weight:600;min-width:30px;text-align:center}.stock-bajo{color:#dc2626}.alerta-stock{font-size:.75rem;color:#dc2626;font-weight:500;display:block;margin-top:.25rem}.estado{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.estado.activo{background:#d1fae5;color:#065f46}.estado.inactivo{background:#fee2e2;color:#991b1b}.destacado{background:#fef3c7;color:#92400e;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;margin-top:.25rem;display:inline-block}.acciones-producto{display:flex;gap:.5rem}.boton-accion{background:#f3f4f6;border:none;border-radius:4px;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center}.boton-accion:hover{background:#e5e7eb}.vista-cuadricula{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.grid-productos{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.tarjeta-producto{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s}.tarjeta-producto:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.imagen-tarjeta{position:relative;height:200px}.imagen-tarjeta img{width:100%;height:100%;object-fit:cover;cursor:pointer}.badge-destacado,.badge-inactivo,.badge-stock-bajo{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.badge-destacado{background:#fef3c7;color:#92400e}.badge-inactivo{background:#fee2e2;color:#991b1b}.badge-stock-bajo{background:#fecaca;color:#991b1b;top:2.5rem}.contenido-tarjeta{padding:1rem;display:flex;flex-direction:column;gap:1rem}.info-principal h3{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0 0 .5rem;cursor:pointer}.info-principal h3:hover{color:#3b82f6}.descripcion{font-size:.9rem;color:#6b7280;margin:0 0 .5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.categoria{font-size:.8rem;color:#6b7280;background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;display:inline-block}.precio-stock{display:flex;justify-content:space-between;align-items:center}.precio .valor{font-size:1.2rem;font-weight:700;color:#059669}.acciones-tarjeta{display:flex;gap:.5rem}.boton-accion-tarjeta{flex:1;padding:.5rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.boton-detalle{background:#e0e7ff;color:#3730a3}.boton-detalle:hover{background:#c7d2fe}.boton-editar{background:#fef3c7;color:#92400e}.boton-editar:hover{background:#fde68a}.mensaje-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.cargando{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media (max-width: 1024px){.encabezado-tabla,.fila-producto{grid-template-columns:60px 2fr 100px 100px 100px 80px}.columna-categoria{display:none}}@media (max-width: 768px){.contenedor-principal{padding:1rem}.encabezado-productos{flex-direction:column;gap:1rem;text-align:center}.controles-productos{flex-direction:column;gap:1rem}.filtros-productos{flex-direction:column;align-items:stretch}.select-filtro{min-width:auto}.controles-vista{flex-direction:column;gap:1rem}.vista-lista{overflow-x:auto}.encabezado-tabla,.fila-producto{grid-template-columns:60px 180px 100px 100px 80px;min-width:600px}.columna-categoria,.columna-estado{display:none}.grid-productos{grid-template-columns:1fr}}.tarjeta-estadistica{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;text-align:center;border-left:4px solid #3b82f6;transition:transform .2s,box-shadow .2s}.tarjeta-estadistica:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.estadistica-valor{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.estadistica-etiqueta{font-size:.875rem;color:#6b7280;font-weight:500}.etiqueta-filtro{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.grupo-filtro{display:flex;flex-direction:column;gap:.5rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.filtros-mobile{display:flex;flex-direction:column;gap:1rem}.filtros-mobile .grupo-filtro{width:100%}.botones-filtros{display:flex;gap:1rem;align-items:end}.tabla-productos .encabezado-tabla{display:grid;grid-template-columns:1fr 2fr 1fr 1fr 1fr 1fr 1fr;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px 8px 0 0;font-weight:600;color:#374151;font-size:.875rem}.tabla-productos .fila-producto{display:grid;grid-template-columns:1fr 2fr 1fr 1fr 1fr 1fr 1fr;gap:1rem;padding:1rem;border-bottom:1px solid #e5e7eb;align-items:center;transition:background-color .2s}.tabla-productos .fila-producto:hover{background:#f9fafb}.tabla-productos .fila-producto:last-child{border-bottom:none;border-radius:0 0 8px 8px}.columna-fecha{display:flex;align-items:center}.fecha-operacion{font-size:.875rem;font-weight:500;color:#374151}.columna-producto{display:flex;align-items:center}.info-producto h3{font-size:.875rem;font-weight:600;color:#1f2937;margin:0 0 .25rem;cursor:pointer;transition:color .2s}.info-producto h3:hover{color:#382626}.codigo-barras{font-size:.75rem;color:#6b7280;margin:0}.columna-tipo{display:flex;align-items:center}.badge-tipo{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:50;color:#fff;text-align:center;white-space:nowrap}.columna-cantidad{display:flex;align-items:center;justify-content:center}.cantidad-info{text-align:center}.cantidad-valor{font-size:.875rem;font-weight:600;color:#1f2937}.cantidad-unidad{font-size:.75rem;color:#6b7280}.columna-stock{display:flex;align-items:center;justify-content:center}.stock-info{text-align:center}.stock-anterior{font-size:.75rem;color:#6b7280}.stock-nuevo{font-size:.875rem;font-weight:600;color:#059669}.columna-valor{display:flex;align-items:center;justify-content:center}.valor-info{text-align:center}.valor-total{font-size:.875rem;font-weight:600;color:#1f2937}.valor-unitario{font-size:.75rem;color:#6b7280}.columna-usuario{display:flex;align-items:center}.usuario-info{font-size:.875rem;color:#374151}.columna-metodo{display:flex;align-items:center}.metodo-info{font-size:.875rem;color:#6b7280}.info-mobile{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.5rem}.fecha-mobile{font-size:.75rem;color:#6b7280;font-weight:50}.tipo-mobile{display:flex;align-items:center}.badge-tipo-mobile{padding:.25rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:500;color:#fff;text-align:center;white-space:nowrap}.cantidad-mobile{font-size:.75rem;color:#374151;font-weight:500}.valor-mobile{font-size:.75rem;color:#059669;font-weight:600}@media (max-width: 1200px){.tabla-productos .encabezado-tabla,.tabla-productos .fila-producto{grid-template-columns:1fr 2fr 1fr 1fr 1fr 1fr 1fr;font-size:.8rem}.columna-metodo{display:none}.tabla-productos .encabezado-tabla,.tabla-productos .fila-producto{grid-template-columns:1fr 2fr 1fr 1fr 1fr 1fr 1fr}}@media (max-width: 1024px){.tabla-productos .encabezado-tabla,.tabla-productos .fila-producto{grid-template-columns:1fr 2fr 1fr 1fr 1fr 1fr 1fr;font-size:.75rem}.columna-usuario{display:none}.tabla-productos .encabezado-tabla,.tabla-productos .fila-producto{grid-template-columns:1fr 2fr 1fr 1fr 1fr 1fr 1fr}}@media (max-width: 768px){.tabla-productos .encabezado-tabla,.tabla-productos .fila-producto{grid-template-columns:1fr 1fr;gap:.5rem;padding:.75rem}.columna-fecha,.columna-tipo,.columna-cantidad,.columna-stock,.columna-valor{display:none}.tabla-productos .encabezado-tabla{grid-template-columns:1fr 1fr}.tabla-productos .fila-producto{grid-template-columns:1fr 1fr;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:.5rem}.columna-producto{grid-column:1;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem;margin-bottom:.5rem}.columna-metodo{display:flex;grid-column:1 / -1;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid #e5e7eb}.metodo-info,.fecha-operacion,.info-producto h3{font-size:.8rem}.codigo-barras{font-size:.7rem}}@media (max-width: 480px){.contenedor-principal{padding:1rem}.encabezado-productos{flex-direction:column;gap:1rem;text-align:center}.titulo-seccion h1{font-size:1.5rem}.grid-4{grid-template-columns:repeat(2,1fr)}.tarjeta-estadistica{padding:1rem}.estadistica-valor{font-size:1.5rem}.estadistica-etiqueta{font-size:.75rem}.filtros-mobile .grupo-filtro{margin-bottom:.5rem}.select-filtro,.input-busqueda{padding:.875rem;font-size:1rem}.botones-filtros button{padding:.875rem 1rem;font-size:.9rem}.tabla-productos .fila-producto{padding:.875rem;margin-bottom:.75rem}.info-producto h3{font-size:.85rem}.codigo-barras{font-size:.65rem}.metodo-info{font-size:.75rem}}.estadisticas-mobile{display:grid;grid-template-columns:repeat(2,1fr);gap:00.75rem}.estadisticas-mobile .tarjeta-estadistica{padding:1rem}.estadisticas-mobile .estadistica-valor{font-size:1.5rem;margin-bottom:00.25rem}.estadisticas-mobile .estadistica-etiqueta{font-size:075em}.cart-icon{font-size:2rem;position:relative;display:inline-block}.cart-badge{position:absolute;top:-8px;right:-8px;background:#e74c3c;color:#fff;border-radius:50%;padding:2px 7px;font-size:.9rem;font-weight:700}.permisos-modal{max-width:1000px;width:95%;height:95vh;max-height:95vh;background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;display:flex;flex-direction:column}.permisos-modal .info-card{background:linear-gradient(135deg,#4c51bf,#553c9a);color:#fff;margin:16px 20px;border-radius:12px;padding:12px 16px;box-shadow:0 4px 12px #00000040}.permisos-modal .info-content{display:flex;align-items:center;justify-content:space-between;gap:16px}.permisos-modal .info-text h2{font-size:16px;font-weight:700;margin:0;color:#1f2937;line-height:1.2}.permisos-modal .info-text p{margin:0;color:#ffffffe6;font-size:12px;line-height:1.2}.permisos-modal .info-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.permisos-modal .close-button{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:4px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.permisos-modal .close-button:hover{background-color:#ffffff1a}.permisos-modal .info-button{padding:6px 12px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;font-size:12px;border:1px solid transparent;white-space:nowrap}.permisos-modal .info-button.cancel{background-color:#ffffff1a;color:#fff;border-color:#ffffff4d}.permisos-modal .info-button.cancel:hover{background-color:#fff3;border-color:#ffffff80}.permisos-modal .info-button.save{background-color:#10b981;color:#fff;border-color:#10b981}.permisos-modal .info-button.save:hover{background-color:#059669;border-color:#059669}.permisos-modal .info-button:disabled{opacity:.5;cursor:not-allowed}.permisos-modal .modal-content-body{padding:16px 20px 20px;overflow-y:auto;flex:1;min-height:0}.permisos-modal .loading-container{display:flex;align-items:center;justify-content:center;padding:40px;color:#6b7280}.permisos-modal .spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:12px}.permisos-modal .action-buttons{display:flex;gap:12px;margin-bottom:16px;justify-content:center}.permisos-modal .action-button{padding:12px 20px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:14px}.permisos-modal .action-button.allow-all{background-color:#10b981;color:#fff}.permisos-modal .action-button.allow-all:hover{background-color:#059669}.permisos-modal .action-button.deny-all{background-color:#ef4444;color:#fff}.permisos-modal .action-button.deny-all:hover{background-color:#dc2626}.permisos-modal .permissions-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:20px;padding:8px}.permisos-modal .permission-item{display:flex;flex-direction:column;padding:24px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;transition:all .2s;box-shadow:0 2px 4px #0000000d;min-height:120px}.permisos-modal .permission-item:hover{background-color:#f9fafb;border-color:#d1d5db;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.permisos-modal .permission-info{flex:1;margin-bottom:16px}.permisos-modal .permission-info h3{font-size:18px;font-weight:600;color:#111827;margin:0 0 8px}.permisos-modal .permission-info p{font-size:14px;color:#6b7280;margin:0}.permisos-modal .permission-controls{display:flex;align-items:center;justify-content:center;gap:24px;padding:16px;background-color:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.permisos-modal .radio-group{display:flex;align-items:center;gap:8px}.permisos-modal .radio-group input[type=radio]{margin:0}.permisos-modal .radio-group label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:15px;font-weight:500;padding:8px 12px;border-radius:6px;transition:background-color .2s}.permisos-modal .radio-group .denied{color:#ef4444}.permisos-modal .radio-group .denied:hover{background-color:#fef2f2}.permisos-modal .radio-group .allowed{color:#10b981}.permisos-modal .radio-group .allowed:hover{background-color:#f0fdf4}.permisos-modal .save-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px;display:inline-block}.permisos-modal .permissions-section{margin-bottom:20px}.permisos-modal .section-title{font-size:18px;font-weight:700;color:#1f2937;margin:0 0 12px;padding:12px 16px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:8px;border-left:4px solid #3b82f6}.permisos-modal .permission-item.sub-permission{border-left:4px solid #f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.permisos-modal .sub-section-badge{display:inline-block;background-color:#f59e0b;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:12px;margin-top:8px;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.permisos-modal{width:98%;max-height:98vh}.permisos-modal .permissions-list{grid-template-columns:1fr;gap:16px}.permisos-modal .permission-controls{flex-direction:column;gap:12px}.permisos-modal .radio-group{width:100%;justify-content:center}}.gestion-administradores{min-height:100vh;background:var(--gradiente-fondo);padding-top:5rem}.gestion-administradores .contenedor-principal{max-width:1200px;margin:0 auto;padding:2rem 1rem}.gestion-administradores .card-principal{background:var(--color-card);border-radius:16px;box-shadow:0 10px 25px var(--color-sombra);overflow:hidden;border:1px solid var(--color-borde)}.gestion-administradores .header-card{background:var(--gradiente-titulo);color:#fff;padding:2rem;position:relative}.gestion-administradores .header-card:before{content:"";position:absolute;inset:0;background:#ffffff1a;backdrop-filter:blur(10px)}.gestion-administradores .header-contenido{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}.gestion-administradores .header-info{display:flex;align-items:center;gap:1rem}.gestion-administradores .icono-header{width:3rem;height:3rem;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;backdrop-filter:blur(10px)}.gestion-administradores .titulo-principal{font-size:1.875rem;font-weight:700;margin:0 0 .25rem;text-shadow:0 2px 4px rgba(0,0,0,.1)}.gestion-administradores .descripcion-header{font-size:1rem;opacity:.9;margin:0}.gestion-administradores .boton-asignar{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;backdrop-filter:blur(10px)}.gestion-administradores .boton-asignar:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.gestion-administradores .formulario-asignacion{background:var(--color-fondo-secundario);border-bottom:1px solid var(--color-borde);padding:2rem}.gestion-administradores .formulario-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.gestion-administradores .icono-formulario{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem}.gestion-administradores .titulo-formulario{font-size:1.25rem;font-weight:600;color:var(--color-texto-principal);margin:0}.gestion-administradores .grid-formulario{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.gestion-administradores .campo-formulario{display:flex;flex-direction:column;gap:.5rem}.gestion-administradores .label-campo{font-weight:600;color:var(--color-texto-principal);font-size:.875rem}.gestion-administradores .input-campo{width:100%;padding:.75rem 1rem;border:2px solid var(--color-borde);border-radius:10px;font-size:.875rem;transition:all .2s ease;background:var(--color-card);color:var(--color-texto-principal)}.gestion-administradores .input-campo:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.gestion-administradores .info-card{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.gestion-administradores .info-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.gestion-administradores .icono-info{color:#2563eb;font-size:1.25rem}.gestion-administradores .titulo-info{font-weight:600;color:#1e40af;font-size:.875rem}.gestion-administradores .lista-instrucciones{list-style:none;padding:0;margin:0}.gestion-administradores .item-instruccion{display:flex;align-items:center;gap:.5rem;color:#1e40af;font-size:.8rem;margin-bottom:.25rem}.gestion-administradores .punto-instruccion{width:4px;height:4px;background:#2563eb;border-radius:50%;flex-shrink:0}.gestion-administradores .botones-formulario{display:flex;gap:1rem;margin-top:.5rem}.gestion-administradores .boton-enviar{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.gestion-administradores .boton-enviar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.gestion-administradores .boton-enviar:disabled{opacity:.5;cursor:not-allowed;transform:none}.gestion-administradores .boton-cancelar{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease}.gestion-administradores .boton-cancelar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6b72804d}.gestion-administradores .contenido-lista{padding:2rem}.gestion-administradores .estado-carga{display:flex;justify-content:center;align-items:center;padding:3rem 0}.gestion-administradores .carga-contenido{text-align:center;color:#6b7280}.gestion-administradores .spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.gestion-administradores .estado-vacio{text-align:center;padding:3rem 0;color:#6b7280}.gestion-administradores .icono-vacio{width:4rem;height:4rem;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.5rem;color:#9ca3af}.gestion-administradores .contenedor-tabla{margin-top:1.5rem}.gestion-administradores .tabla-scroll{overflow-x:auto;border-radius:12px;border:1px solid var(--color-borde);background:var(--color-card);box-shadow:0 4px 6px -1px var(--color-sombra)}.gestion-administradores .tabla-contenedor{overflow-x:auto;border-radius:12px;border:1px solid var(--color-borde);background:var(--color-card)}.gestion-administradores .tabla{width:100%;border-collapse:collapse;background:var(--color-card)}.gestion-administradores .tabla-header{background:var(--color-fondo-secundario)}.gestion-administradores .th{padding:1rem 1.5rem;text-align:left;font-size:.75rem;font-weight:700;color:var(--color-texto-principal);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-borde)}.gestion-administradores .fila-admin{border-bottom:1px solid #f3f4f6;transition:all .2s ease}.gestion-administradores .fila-admin:hover{background:var(--color-fondo-secundario)}.gestion-administradores .fila-admin.inactiva{background:#fafafa;opacity:.7}.gestion-administradores .td{padding:1.25rem 1rem;vertical-align:middle;border-bottom:1px solid #f3f4f6;text-align:center}.gestion-administradores .td:first-child{text-align:left}.gestion-administradores .td:last-child{text-align:center}.gestion-administradores .admin-info{display:flex;align-items:center;gap:1rem}.gestion-administradores .avatar-contenedor{position:relative}.gestion-administradores .avatar{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid white;box-shadow:0 2px 8px #00000026}.gestion-administradores .avatar.inactivo{opacity:.6;filter:grayscale(50%)}.gestion-administradores .estado-indicador{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid white}.gestion-administradores .estado-indicador.activo{background:#10b981}.gestion-administradores .estado-indicador.inactivo{background:#ef4444}.gestion-administradores .admin-detalles{flex:1}.gestion-administradores .admin-nombre{font-size:.875rem;font-weight:600;color:var(--color-texto-principal);margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.gestion-administradores .badge-principal{display:inline-flex;align-items:center;padding:.125rem .375rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;border-radius:12px;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 1px 2px #f59e0b33}.gestion-administradores .admin-rol{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;background:#dbeafe;color:#1e40af}.gestion-administradores .email-contenedor{font-family:Courier New,monospace;font-size:.875rem;color:var(--color-texto-secundario);background:var(--color-fondo-secundario);padding:.75rem;border-radius:8px;border:1px solid var(--color-borde);text-align:center;max-width:200px;margin:0 auto}.gestion-administradores .documento-badge{font-size:.875rem;font-weight:600;color:var(--color-texto-principal);background:var(--color-fondo-secundario);padding:.5rem .75rem;border-radius:20px;display:inline-block;border:1px solid var(--color-borde);text-align:center}.gestion-administradores .estado-badge{display:inline-flex;align-items:center;padding:.5rem .75rem;font-size:.75rem;font-weight:600;border-radius:20px;border:1px solid;gap:.5rem}.gestion-administradores .estado-badge.activo{background:#dcfce7;color:#166534;border-color:#bbf7d0}.gestion-administradores .estado-badge.inactivo{background:#fee2e2;color:#991b1b;border-color:#fecaca}.gestion-administradores .estado-punto{width:6px;height:6px;border-radius:50%}.gestion-administradores .estado-punto.activo{background:#10b981}.gestion-administradores .estado-punto.inactivo{background:#ef4444}.gestion-administradores .acciones-contenedor{display:flex;flex-direction:column;gap:.5rem;align-items:center;justify-content:center;min-width:140px;padding:.5rem}.gestion-administradores .boton-accion{display:flex;align-items:center;justify-content:center;padding:.6rem .8rem;border-radius:8px;font-size:.75rem;font-weight:600;border:1px solid;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;min-height:38px;width:100%;max-width:120px;gap:.25rem;text-align:center}.gestion-administradores .boton-accion.desactivar{background:#fef2f2;color:#dc2626;border-color:#fecaca}.gestion-administradores .boton-accion.desactivar:hover{background:#fee2e2;transform:translateY(-1px);box-shadow:0 2px 8px #dc262633}.gestion-administradores .boton-accion.activar{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0}.gestion-administradores .boton-accion.activar:hover{background:#dcfce7;transform:translateY(-1px);box-shadow:0 2px 8px #22c55e33}.gestion-administradores .boton-accion.eliminar{background:#fef2f2;color:#dc2626;border-color:#fca5a5}.gestion-administradores .boton-accion.eliminar:hover{background:#fee2e2;border-color:#f87171;transform:translateY(-1px);box-shadow:0 2px 8px #dc262633}.gestion-administradores .boton-accion.permisos{background:#f0f9ff;color:#0369a1;border-color:#bae6fd}.gestion-administradores .boton-accion.permisos:hover{background:#e0f2fe;border-color:#7dd3fc;transform:translateY(-1px);box-shadow:0 2px 8px #0369a133}.gestion-administradores .boton-accion:disabled{opacity:.5;cursor:not-allowed;background:#f3f4f6!important;color:#9ca3af!important;border-color:#d1d5db!important;transform:none!important;box-shadow:none!important}.gestion-administradores .admin-principal-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280;border-radius:10px;border:1px solid #d1d5db;font-size:.875rem;font-weight:600;width:100%;max-width:120px;margin:0 auto;text-align:center}.gestion-administradores .icono-protegido{font-size:1rem}.gestion-administradores .texto-protegido{font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 1024px){.gestion-administradores .contenedor-principal{padding:1.5rem 1rem}.gestion-administradores .header-contenido{flex-direction:column;text-align:center;gap:1.5rem}.gestion-administradores .grid-formulario{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.gestion-administradores .botones-formulario{flex-direction:column}}@media (max-width: 768px){.gestion-administradores .contenedor-principal{padding:1rem .5rem}.gestion-administradores .header-card,.gestion-administradores .formulario-asignacion,.gestion-administradores .contenido-lista{padding:1.5rem}.gestion-administradores .titulo-principal{font-size:1.5rem}.gestion-administradores .header-info{flex-direction:column;text-align:center}.gestion-administradores .grid-formulario{grid-template-columns:1fr}.gestion-administradores .tabla-contenedor{border-radius:8px}.gestion-administradores .th,.gestion-administradores .td{padding:.75rem .5rem}.gestion-administradores .admin-info{flex-direction:column;align-items:flex-start;gap:.75rem}.gestion-administradores .avatar{width:2.5rem;height:2.5rem;font-size:.75rem}.gestion-administradores .acciones-contenedor{min-width:100px;padding:.25rem}.gestion-administradores .boton-accion{font-size:.7rem;padding:.4rem .6rem;max-width:100px;min-height:32px}.gestion-administradores .admin-principal-badge{max-width:100px;padding:.6rem .8rem;font-size:.8rem}.gestion-administradores .email-contenedor{font-size:.75rem;padding:.5rem}}@media (max-width: 480px){.gestion-administradores .card-principal{border-radius:12px;margin:.5rem}.gestion-administradores .header-card,.gestion-administradores .formulario-asignacion,.gestion-administradores .contenido-lista{padding:1rem}.gestion-administradores .titulo-principal{font-size:1.25rem}.gestion-administradores .icono-header{width:2.5rem;height:2.5rem;font-size:1.25rem}.gestion-administradores .tabla-contenedor{font-size:.875rem}.gestion-administradores .th,.gestion-administradores .td{padding:.5rem .25rem}.gestion-administradores .th:nth-child(3),.gestion-administradores .td:nth-child(3){display:none}.gestion-administradores .admin-principal-badge{padding:.5rem;font-size:.75rem;max-width:90px}.gestion-administradores .texto-protegido{font-size:.7rem}.gestion-administradores .acciones-contenedor{min-width:90px;padding:.2rem}.gestion-administradores .boton-accion{font-size:.65rem;padding:.3rem .5rem;max-width:85px;min-height:30px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px}.modal-content{background:var(--color-card);border-radius:12px;box-shadow:0 25px 50px -12px var(--color-sombra-fuerte);max-width:1000px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.permissions-section{margin-bottom:2rem}.section-title{font-size:1.125rem;font-weight:600;color:var(--color-texto-principal);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-borde)}.sub-permission{background:#f0f9ff!important;border:1px solid #bae6fd!important}.sub-section-badge{display:inline-block;background:#0ea5e9;color:#fff;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;margin-top:.5rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gestion-administradores .card-principal{animation:fadeIn .6s ease-out}.gestion-administradores .fila-admin{animation:fadeIn .4s ease-out}.login-documento{min-height:100vh;background:linear-gradient(135deg,#f0f9ff,#e0f2fe,#f3e8ff);display:flex;align-items:center;justify-content:center;padding:3rem 1rem}.login-documento .contenedor-login{width:100%;max-width:28rem}.login-documento .header-login{text-align:center;margin-bottom:2rem}.login-documento .logo-contenedor{display:flex;justify-content:center;margin-bottom:1rem}.login-documento .logo{width:4rem;height:4rem;object-fit:contain}.login-documento .titulo-marca{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--color-primario),#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}.login-documento .titulo-pagina{font-size:1.5rem;font-weight:700;color:var(--color-texto);margin-bottom:.5rem}.login-documento .descripcion-pagina{font-size:.875rem;color:var(--color-texto-secundario);line-height:1.5}.login-documento .card-login{background:#fffffff2;backdrop-filter:blur(20px);border-radius:1.5rem;box-shadow:var(--sombra-lg);border:1px solid rgba(255,255,255,.2);padding:2rem}.login-documento .formulario{margin-top:0}.login-documento .campos-contenedor{margin-bottom:1.5rem}.login-documento .campo{margin-bottom:1rem}.login-documento .label{display:block;font-size:.875rem;font-weight:500;color:var(--color-texto);margin-bottom:.5rem}.login-documento .input-contenedor{position:relative}.login-documento .input-icono{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:var(--color-texto-secundario);pointer-events:none;z-index:1}.login-documento .input{display:block;width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1px solid var(--color-borde);border-radius:var(--radio-borde-lg);font-size:.875rem;transition:all .2s ease;background:#fff}.login-documento .input:focus{outline:none;border-color:var(--color-primario);box-shadow:0 0 0 3px #3b82f61a}.login-documento .input::placeholder{color:#9ca3af}.login-documento .instrucciones{background:linear-gradient(to right,#dbeafe,#e0f2fe);border:1px solid #bfdbfe;border-radius:var(--radio-borde-lg);padding:1.25rem;margin-bottom:1.5rem}.login-documento .instrucciones-contenido{display:flex;align-items:flex-start;gap:.75rem}.login-documento .icono-instrucciones{width:2rem;height:2rem;background:#dbeafe;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.login-documento .texto-instrucciones{font-size:.875rem;color:#1e40af}.login-documento .titulo-instrucciones{font-weight:600;margin-bottom:.5rem}.login-documento .lista-instrucciones{list-style:none;padding:0;margin:0}.login-documento .item-instruccion{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;color:#1d4ed8}.login-documento .punto-instruccion{width:.375rem;height:.375rem;background:#3b82f6;border-radius:50%;flex-shrink:0}.login-documento .boton-submit{width:100%;background:linear-gradient(135deg,var(--color-primario),#6366f1);color:#fff;padding:.75rem 1rem;border:none;border-radius:var(--radio-borde-lg);font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;margin-bottom:1.5rem}.login-documento .boton-submit:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primario-hover),#5b21b6);transform:scale(1.02)}.login-documento .boton-submit:active{transform:scale(.98)}.login-documento .boton-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-documento .spinner-boton{width:1.25rem;height:1.25rem;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.login-documento .icono-boton{width:1.25rem;height:1.25rem}.login-documento .enlaces-contenedor{text-align:center;padding-top:1rem;border-top:1px solid var(--color-borde)}.login-documento .enlace{font-size:.875rem;font-weight:500;color:var(--color-primario);text-decoration:none;transition:color .2s ease;margin-bottom:.75rem;display:block}.login-documento .enlace:hover{color:var(--color-primario-hover)}.login-documento .enlace-secundario{color:var(--color-texto-secundario)}.login-documento .enlace-secundario:hover{color:var(--color-texto)}.login-documento .cargando .input{opacity:.7;pointer-events:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.login-documento .card-login{animation:fadeIn .6s ease-out}@media (max-width: 640px){.login-documento{padding:2rem .5rem}.login-documento .card-login{padding:1.5rem}.login-documento .titulo-marca{font-size:1.75rem}.login-documento .titulo-pagina{font-size:1.25rem}.login-documento .descripcion-pagina{font-size:.8rem}}.login-documento .input-contenedor:hover .input{border-color:#cbd5e1}.login-documento .campo:focus-within .input-icono{color:var(--color-primario)}.login-documento .card-login:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border-radius:1.5rem;pointer-events:none}.login-documento .card-login{position:relative;overflow:hidden}.login-documento .input:focus-visible{outline:2px solid var(--color-primario);outline-offset:2px}.login-documento .boton-submit:focus-visible{outline:2px solid white;outline-offset:2px}.pagina-sectores{min-height:100vh;background:linear-gradient(135deg,#1e293b,#334155);padding-top:8rem}.contenedor-sectores{max-width:1400px;margin:0 auto;padding:1rem}.pagina-carga{min-height:100vh;background:linear-gradient(135deg,#1e293b,#334155);display:flex;align-items:center;justify-content:center}.tarjeta-carga{background:#fff;border-radius:1rem;padding:2rem;box-shadow:0 20px 40px #0000001a;text-align:center}.tarjeta-carga .spinner{margin:0 auto 1rem}.tarjeta-carga p{color:#64748b;font-size:1rem}.header-sectores{text-align:center;margin-bottom:2rem;color:#fff}.icono-header{font-size:3rem;margin-bottom:1rem;background:#ffffff1a;border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);margin:0 auto 1rem}.titulo-sectores{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.descripcion-sectores{font-size:1rem;opacity:.9;max-width:600px;margin:0 auto}.botones-accion{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center;align-items:center;flex-direction:row}.boton-migrar,.boton-crear,.boton-stock-general,.boton-actualizar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:3px solid transparent;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;box-sizing:border-box;transition:all .3s ease;text-decoration:none;color:#fff;box-shadow:0 4px 15px #0003;white-space:nowrap;min-width:fit-content;flex-shrink:0}.boton-migrar{background:linear-gradient(135deg,#475569,#64748b)}.boton-crear{background:linear-gradient(135deg,#0f172a,#1e293b)}.boton-stock-general{background:linear-gradient(135deg,#059669,#047857)}.boton-stock-general.activo{background:linear-gradient(135deg,#dc2626,#b91c1c)}.boton-migrar:hover,.boton-crear:hover,.boton-stock-general:hover,.boton-actualizar:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.boton-migrar.seleccionado,.boton-crear.seleccionado,.boton-stock-general.seleccionado,.boton-actualizar.seleccionado,.tarjeta-sector.seleccionada{border:3px solid #000000;box-shadow:0 0 0 2px #0000004d;transform:translateY(-2px);box-sizing:border-box}.icono-boton{font-size:1.1rem}.botones-sincronizacion{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center;align-items:center;flex-direction:row}.boton-sincronizacion{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:3px solid transparent;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;box-sizing:border-box;transition:all .3s ease;text-decoration:none;color:#fff;box-shadow:0 4px 15px #0003;white-space:nowrap;min-width:fit-content;flex-shrink:0}.boton-limpiar-stock{background:linear-gradient(135deg,#ff9a9e,#fecfef)}.boton-sincronizar-sector{background:linear-gradient(135deg,#a8edea,#fed6e3)}.boton-limpiar-filtros{background:linear-gradient(135deg,#ffecd2,#fcb69f)}.boton-sincronizacion:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.boton-sincronizacion:disabled{opacity:.6;cursor:not-allowed;transform:none}.seccion-stock-general{background:#fff;border-radius:1.5rem;padding:2rem;margin-bottom:2rem;box-shadow:0 20px 40px #0000001a}.header-stock-general{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.icono-header-stock{font-size:2.5rem;background:linear-gradient(135deg,#43e97b,#38f9d7);border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;color:#fff}.titulo-stock-general{font-size:1.8rem;font-weight:700;color:#1e293b;margin-bottom:.25rem}.descripcion-stock-general{color:#64748b;font-size:1rem}.tarjeta-carga-stock{text-align:center;padding:3rem}.tarjeta-carga-stock .spinner{margin:0 auto 1rem}.tarjeta-carga-stock p{color:#64748b;font-size:1rem}.contenedor-stock-general{display:grid;gap:2rem}.seccion-productos-sectores,.seccion-productos-sin-sector{background:#f8fafc;border-radius:1rem;padding:1.5rem}.titulo-seccion-stock{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.icono-seccion{font-size:1.5rem}.lista-productos-sectores,.lista-productos-sin-sector{display:grid;gap:1rem}.item-stock-sector,.item-stock-sin-sector{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem;border-radius:.75rem;box-shadow:0 2px 8px #0000000d;transition:all .3s ease}.item-stock-sector:hover,.item-stock-sin-sector:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.info-producto-stock{flex:1}.nombre-producto-stock{font-size:1.1rem;color:#1e293b;margin-bottom:.25rem}.codigo-producto-stock{color:#64748b;font-size:.9rem;font-weight:400}.sector-producto-stock{margin-top:.5rem}.badge-sector-stock,.badge-sin-sector{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:500}.badge-sector-stock{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.badge-sin-sector{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.cantidad-producto-stock{text-align:right;min-width:100px}.numero-cantidad{display:block;font-size:1.5rem;font-weight:700;color:#1e293b}.unidad-cantidad{font-size:.85rem;color:#64748b}.tarjeta-vacia-stock{text-align:center;padding:3rem 2rem;color:#64748b}.icono-vacio-stock{font-size:3rem;margin-bottom:1rem;opacity:.5}.tarjeta-vacia-stock h4{font-size:1.2rem;margin-bottom:.5rem;color:#475569}.tarjeta-vacia-stock p{font-size:.95rem}.resumen-stock-general{margin-top:1rem}.tarjeta-resumen{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:1rem;padding:1.5rem;color:#fff}.contenido-resumen{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;text-align:center}.estadistica-resumen{display:flex;flex-direction:column;gap:.5rem}.numero-resumen{font-size:2rem;font-weight:700;color:#fff}.label-resumen{font-size:.9rem;opacity:.9}.estadisticas-sectores{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.tarjeta-estadistica{background:#fff;border-radius:16px;padding:1rem;box-shadow:0 10px 30px #0000001a;transition:all .3s ease;border:2px solid #e2e8f0}.tarjeta-estadistica:hover{transform:translateY(-2px);box-shadow:0 15px 35px #00000026}.contenido-estadistica{display:flex;align-items:center;gap:.75rem}.icono-estadistica{font-size:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;color:#fff}.tarjeta-total .icono-estadistica{background:linear-gradient(135deg,#1e293b,#334155)}.tarjeta-activos .icono-estadistica{background:linear-gradient(135deg,#059669,#047857)}.tarjeta-inactivos .icono-estadistica{background:linear-gradient(135deg,#dc2626,#b91c1c)}.texto-estadistica{flex:1}.label-estadistica{font-size:.8rem;color:#64748b;margin-bottom:.25rem}.numero-estadistica{font-size:1.5rem;font-weight:700;color:#1e293b}.toggle-sectores-inactivos{text-align:center;margin-bottom:2rem}.boton-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:2rem;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);white-space:nowrap}.boton-toggle:hover,.boton-toggle.activo{background:#fff3;border-color:#ffffff4d;transform:translateY(-2px)}.icono-toggle{font-size:1.2rem}.contenedor-grid{display:grid;gap:2rem}.seccion-sectores{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 20px 40px #0000001a}.titulo-seccion{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.titulo-inactivos{color:#64748b}.icono-titulo{font-size:1.5rem}.grid-sectores{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.tarjeta-sector{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000d;transition:all .2s ease;cursor:pointer;animation:fadeInUp .6s ease forwards;opacity:0;transform:translateY(30px);display:flex;flex-direction:column;border:3px solid #e2e8f0;box-sizing:border-box}.tarjeta-sector:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a;border-color:#334155;border-width:3px}.tarjeta-inactiva{opacity:.7}.tarjeta-inactiva:hover{opacity:1}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.header-tarjeta-sector{padding:1rem;color:#fff;position:relative}.contenido-header-sector{display:flex;align-items:center;gap:.75rem}.icono-sector{font-size:1.5rem;background:#fff3;border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px)}.nombre-sector{font-size:1.1rem;font-weight:600;margin:0;flex:1}.badge-estado{position:absolute;top:1rem;right:1rem}.estado-sector{padding:.25rem .75rem;border-radius:1rem;font-size:.8rem;font-weight:500;background:#fff3;backdrop-filter:blur(10px)}.estado-sector.activo{background:#22c55ee6}.estado-sector.inactivo{background:#ef4444e6}.contenido-tarjeta-sector{padding:1rem;display:flex;flex-direction:column;flex:1;min-height:150px}.descripcion-sector{color:#64748b;margin-bottom:1rem;line-height:1.5;min-height:3rem;display:flex;align-items:flex-start}.descripcion-sector:empty:before{content:"Sin descripción";color:#cbd5e1;font-style:italic}.info-sector{display:grid;gap:.75rem;margin-bottom:1.5rem;flex:1;min-height:80px;grid-template-rows:repeat(2,1fr)}.info-item{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.9rem;min-height:24px;padding:.5rem 0}.info-item:first-child{grid-row:1}.info-item:last-child{grid-row:2}.icono-info{font-size:1rem;width:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.texto-info{flex:1;min-height:20px;display:flex;align-items:center}.texto-info:empty:before{content:"Sin información";color:#cbd5e1;font-style:italic}.info-item:nth-child(2) .texto-info,.info-item:nth-child(3) .texto-info{font-weight:700;font-size:1.1rem;color:#1e293b;text-shadow:0 1px 2px rgba(0,0,0,.1);background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:.25rem .5rem;border-radius:6px;border:1px solid #cbd5e1;box-shadow:0 2px 4px #0000000d;transition:all .3s ease}.info-item:nth-child(2) .texto-info:hover,.info-item:nth-child(3) .texto-info:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000001a;background:linear-gradient(135deg,#fff,#f1f5f9)}.info-item:nth-child(2) .icono-info,.info-item:nth-child(3) .icono-info{font-size:1.3rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 6px #3b82f666;transition:all .3s ease;position:relative;z-index:2}.info-item:nth-child(2) .icono-info:hover,.info-item:nth-child(3) .icono-info:hover{transform:scale(1.15) rotate(5deg);box-shadow:0 6px 12px #3b82f680;background:linear-gradient(135deg,#1d4ed8,#1e40af)}.info-item:nth-child(2) .icono-info:before,.info-item:nth-child(3) .icono-info:before{content:"";position:absolute;top:2px;left:2px;right:2px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);border-radius:50%;opacity:.7}.info-item:nth-child(2) .texto-info,.info-item:nth-child(3) .texto-info{position:relative}.info-item:nth-child(2) .texto-info:before,.info-item:nth-child(3) .texto-info:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:8px;z-index:-1;opacity:0;transition:all .3s ease}.info-item:nth-child(2) .texto-info:hover:before,.info-item:nth-child(3) .texto-info:hover:before{opacity:1}.info-item:nth-child(2) .texto-info:after,.info-item:nth-child(3) .texto-info:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:6px;border:1px solid #93c5fd;box-shadow:0 1px 3px #3b82f633;z-index:-1;opacity:.8;transition:all .3s ease}.info-item:nth-child(2) .texto-info:hover:after,.info-item:nth-child(3) .texto-info:hover:after{background:linear-gradient(135deg,#3b82f6,#1d4ed8);opacity:1;transform:scale(1.02);box-shadow:0 2px 6px #3b82f666}.info-item:nth-child(2) .texto-info,.info-item:nth-child(3) .texto-info{font-weight:700;font-size:1.1rem;color:#1e293b;text-shadow:0 1px 2px rgba(0,0,0,.1);position:relative;z-index:1}.info-item:nth-child(2) .texto-info:hover,.info-item:nth-child(3) .texto-info:hover{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3);transform:translateY(-1px)}@keyframes highlightPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.02);opacity:1}}.info-item:nth-child(2),.info-item:nth-child(3){animation:highlightPulse 3s ease-in-out infinite;animation-delay:calc(var(--animation-order, 0) * .5s)}.tarjeta-inactiva .info-item:nth-child(2) .texto-info,.tarjeta-inactiva .info-item:nth-child(3) .texto-info{color:#6b7280;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid #d1d5db}.tarjeta-inactiva .info-item:nth-child(2) .icono-info,.tarjeta-inactiva .info-item:nth-child(3) .icono-info{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 3px 6px #6b728066}.botones-accion-sector{display:flex;gap:.5rem;justify-content:space-between;margin-top:auto;padding-top:1rem;border-top:1px solid #f1f5f9;min-height:60px;align-items:center}.boton-accion{width:48px;height:48px;border:none;border-radius:12px;font-size:1.3rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:48px;min-height:48px;flex-shrink:0;box-shadow:0 2px 8px #0000001a}.boton-asignar{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.boton-productos{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.boton-editar{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff}.boton-desactivar{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.boton-eliminar{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.boton-activar{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.boton-historial{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.boton-historial-general{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d;display:flex;align-items:center;gap:.5rem;min-width:160px;justify-content:center}.boton-historial-general:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166;background:linear-gradient(135deg,#059669,#047857)}.boton-historial-general:active{transform:translateY(0);box-shadow:0 2px 8px #10b9814d}.boton-historial-general.seleccionado{background:linear-gradient(135deg,#047857,#065f46);box-shadow:0 4px 16px #10b98180;transform:scale(1.02)}.boton-accion:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #00000026}.tarjeta-vacia{text-align:center;padding:4rem 2rem;color:#64748b}.icono-vacio{font-size:4rem;margin-bottom:1rem;opacity:.5}.tarjeta-vacia h3{font-size:1.5rem;margin-bottom:.5rem;color:#475569}.tarjeta-vacia p{font-size:1rem;margin-bottom:2rem}.boton-primer-sector{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#4facfe,#00f2fe);border:none;border-radius:.75rem;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none}.boton-primer-sector:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0003}.tarjeta-carga-sectores{text-align:center;padding:4rem 2rem;background:#fff;border-radius:1.5rem;box-shadow:0 20px 40px #0000001a}.tarjeta-carga-sectores .spinner{margin:0 auto 1rem}.tarjeta-carga-sectores p{color:#64748b;font-size:1rem}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-detalle,.modal-formulario{background:#fff;border-radius:1.5rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000040;animation:modalSlideIn .3s ease}.modal-productos{background:#fff;border-radius:1.5rem;max-width:1200px;width:100%;max-height:95vh;overflow-y:auto;box-shadow:0 25px 50px #00000040;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.header-modal{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:2px solid #f1f5f9}.contenido-header-modal{display:flex;align-items:center;gap:1rem}.icono-modal{font-size:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;color:#fff}.titulo-modal{font-size:1.3rem;font-weight:600;color:#1e293b;margin:0}.subtitulo-modal{color:#64748b;font-size:.9rem;margin:0}.boton-cerrar-modal{width:40px;height:40px;border:none;border-radius:50%;background:#f1f5f9;color:#64748b;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.boton-cerrar-modal:hover{background:#e2e8f0;color:#475569}.contenido-modal-detalle,.contenido-modal-formulario{padding:1.5rem}.seccion-info,.seccion-productos{margin-bottom:2rem}.seccion-info h4,.seccion-productos h4{font-size:1.1rem;font-weight:600;color:#1e293b;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f1f5f9}.campos-info{display:grid;gap:1rem}.campo-info{display:grid;gap:.25rem}.campo-info label{font-size:.9rem;font-weight:500;color:#64748b}.campo-info p{color:#1e293b;margin:0;padding:.5rem;background:#f8fafc;border-radius:.5rem}.productos-vacios{text-align:center;padding:2rem;color:#64748b}.icono-productos{font-size:3rem;margin-bottom:1rem;opacity:.5}.lista-productos{display:grid;gap:.75rem}.item-producto{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:.5rem}.nombre-producto{font-weight:500;color:#1e293b;margin:0 0 .25rem}.codigo-producto{font-size:.85rem;color:#64748b;margin:0}.cantidad-producto{font-weight:600;color:#1e293b;background:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.9rem}.productos-adicionales{text-align:center;color:#64748b;font-size:.9rem;font-style:italic;margin:1rem 0 0}.campo-formulario{margin-bottom:1.5rem}.label-campo{display:block;font-size:.9rem;font-weight:500;color:#374151;margin-bottom:.5rem}.requerido{color:#ef4444}.input-campo{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.input-campo:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.input-campo.error{border-color:#ef4444}.mensaje-error{color:#ef4444;font-size:.85rem;margin-top:.25rem}.productos-vacios-grande{text-align:center;padding:4rem 2rem;color:#64748b}.contenedor-productos{margin:1rem 0;max-height:60vh;overflow-y:auto}.productos-mobile-cards{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;margin:.5rem}.producto-mobile-card{background:#fff;border:1px solid #cbd5e1;border-radius:12px;padding:1rem;box-shadow:0 3px 12px #0000001a,0 1px 4px #0000000f;transition:all .2s ease;position:relative;margin-bottom:0}.producto-mobile-card:nth-child(2n){background:#f8fafc;border-color:#e2e8f0}.producto-mobile-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f,0 2px 6px #00000014;border-color:#9ca3af}.producto-mobile-card.fila-seleccionada{border-color:#3b82f6;box-shadow:0 6px 20px #3b82f640,0 2px 6px #3b82f626;background:#eff6ff}.producto-mobile-card:nth-child(2n).fila-seleccionada{background:#dbeafe}.producto-card-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:1rem}.producto-card-row:last-child{margin-bottom:0}.producto-label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem;font-weight:500}.producto-codigo-container,.producto-cantidad-container,.producto-nombre-container,.producto-fecha-container{flex:1;min-width:0}.producto-acciones-container{display:flex;gap:.5rem;align-items:center}.producto-codigo-value{font-family:Courier New,monospace;font-size:.9rem;color:#059669;font-weight:700;background:linear-gradient(135deg,#f0fdf4,#dcfce7);padding:.5rem .75rem;border-radius:8px;border:1px solid rgba(34,197,94,.2);word-break:break-all;box-shadow:0 1px 3px #22c55e1a}.producto-cantidad-value{font-size:1.1rem;color:#1e293b;font-weight:800;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:.5rem .75rem;border-radius:8px;border:1px solid rgba(226,232,240,.5);text-align:center;box-shadow:0 1px 3px #0000000d}.producto-nombre-value{font-size:1rem;color:#1e40af;font-weight:700;background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:.5rem .75rem;border-radius:8px;border:1px solid rgba(59,130,246,.2);word-break:break-word;box-shadow:0 1px 3px #3b82f61a}.producto-fecha-value{font-size:.75rem;color:#9ca3af;font-weight:400}.boton-accion-mobile{width:44px;height:44px;border:none;border-radius:12px;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.boton-transferir-mobile{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.boton-quitar-mobile{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.boton-accion-mobile:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #00000026}.boton-accion-mobile.accion-seleccionada{transform:scale(1.1);box-shadow:0 4px 16px #0003}.tabla-productos{overflow-x:auto;margin:1rem 0;max-height:60vh;overflow-y:auto}.tabla-productos table{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:fixed}.tabla-productos th{background:#f8fafc;padding:1rem .75rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:10}.tabla-productos td{padding:.75rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.tabla-productos tbody tr:hover{background:#f8fafc}.nombre-producto-tabla{font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.tabla-productos th:nth-child(1),.tabla-productos td:nth-child(1){width:15%}.tabla-productos th:nth-child(2),.tabla-productos td:nth-child(2){width:35%}.tabla-productos th:nth-child(3),.tabla-productos td:nth-child(3){width:10%;text-align:center}.tabla-productos th:nth-child(4),.tabla-productos td:nth-child(4){width:20%}.tabla-productos th:nth-child(5),.tabla-productos td:nth-child(5){width:20%;text-align:center}.codigo-producto-tabla{font-family:Courier New,monospace;color:#059669;font-weight:500}.cantidad-producto-tabla{font-weight:600;color:#1e293b;background:#f0fdf4;padding:.25rem .75rem;border-radius:.5rem;border:1px solid #bbf7d0}.fecha-producto-tabla{font-size:.85rem;color:#64748b}.acciones-producto-tabla{text-align:center;vertical-align:middle}.botones-accion-producto{display:flex;gap:.5rem;justify-content:center;align-items:center}.boton-quitar-producto{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.5rem;border-radius:.5rem;cursor:pointer;transition:all .3s ease;font-size:1rem;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;box-shadow:0 2px 8px #ef44444d}.boton-quitar-producto:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef444466;background:linear-gradient(135deg,#dc2626,#b91c1c)}.boton-quitar-producto:active{transform:translateY(0);box-shadow:0 2px 4px #ef44444d}.boton-quitar-producto:disabled{opacity:.6;cursor:not-allowed;transform:none}.accion-seleccionada{transform:scale(1.1)!important;box-shadow:0 0 0 3px #0288d1!important;border:2px solid #0288d1!important;z-index:10;position:relative}.campo-busqueda-productos:focus{outline:none}.botones-modal{display:flex;gap:1rem;padding:1.5rem;border-top:2px solid #f1f5f9;justify-content:flex-end;flex-wrap:wrap}.boton-primario,.boton-secundario,.boton-cancelar{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.boton-primario{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.boton-secundario{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.boton-cancelar{background:#f1f5f9;color:#64748b}.boton-primario:hover,.boton-secundario:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0003}.boton-cancelar:hover{background:#e2e8f0;color:#475569}@media (max-width: 768px){.contenedor-sectores{padding:1rem}.titulo-sectores{font-size:2rem}.botones-accion{flex-direction:row;flex-wrap:wrap;gap:.75rem;justify-content:center}.boton-migrar,.boton-crear,.boton-stock-general,.boton-actualizar{padding:.75rem 1rem;font-size:.9rem;flex:1;min-width:0;justify-content:center;white-space:nowrap;min-height:48px;width:100%}.estadisticas-sectores,.grid-sectores,.contenido-resumen{grid-template-columns:1fr}.botones-modal{flex-direction:column}.contenido-tarjeta-sector{min-height:180px}.info-sector{min-height:70px}.botones-accion-sector{padding-top:.75rem;gap:.6rem;justify-content:space-between}.boton-accion{width:44px;height:44px;font-size:1.2rem;border-radius:10px}.modal-detalle,.modal-formulario{margin:1rem;max-height:calc(100vh - 2rem)}.modal-productos{margin:.5rem;max-width:calc(100vw - 1rem);max-height:calc(100vh - 1rem)}}@media (max-width: 768px){.tabla-productos{font-size:.8rem;max-height:50vh}.tabla-productos th,.tabla-productos td{padding:.5rem .25rem}.tabla-productos th:nth-child(4),.tabla-productos td:nth-child(4){display:none}.boton-quitar-producto{min-width:32px;height:32px;font-size:.9rem}.tabla-productos th:nth-child(1),.tabla-productos td:nth-child(1){width:20%}.tabla-productos th:nth-child(2),.tabla-productos td:nth-child(2){width:45%}.tabla-productos th:nth-child(3),.tabla-productos td:nth-child(3){width:15%}.tabla-productos th:nth-child(5),.tabla-productos td:nth-child(5){width:20%}}@media (max-width: 768px){.tabla-productos{display:none}}@media (max-width: 480px){.producto-card-row{flex-direction:column;align-items:stretch;gap:.5rem}.producto-card-row:first-child{flex-direction:row;align-items:center}.producto-codigo-container,.producto-cantidad-container{flex:none}.producto-nombre-container{flex:1}.producto-fecha-container{flex:none}.producto-acciones-container{justify-content:center;margin-top:.5rem}.boton-accion-mobile{width:48px;height:48px;font-size:1.3rem}}@media (max-width: 480px){.botones-accion{flex-direction:column;gap:.5rem}.boton-migrar,.boton-crear,.boton-stock-general,.boton-actualizar{padding:1rem;font-size:1rem;min-height:56px;width:100%}.contenido-tarjeta-sector{min-height:160px;padding:1rem}.info-sector{min-height:60px}.botones-accion-sector{padding-top:.75rem;gap:.5rem;justify-content:space-between;min-height:70px}.boton-accion{width:52px;height:52px;font-size:1.4rem;border-radius:14px;flex:1;max-width:60px}.botones-accion-sector:has(.boton-editar):not(:has(.boton-asignar)){justify-content:center;gap:1rem}.botones-accion-sector:has(.boton-editar):not(:has(.boton-asignar)) .boton-accion{flex:none;max-width:none}.descripcion-sector{min-height:2.5rem;font-size:.9rem}}.modal-asignar-productos{background:#fff;border-radius:1.5rem;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000040;animation:modalSlideIn .3s ease}.buscador-asignacion{margin-bottom:1.5rem;padding:0 1.5rem}.input-busqueda-asignacion{position:relative;display:flex;align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:.75rem;padding:.75rem 1rem;transition:all .3s ease}.input-busqueda-asignacion:focus-within{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.icono-busqueda-asignacion{font-size:1.1rem;color:#64748b;margin-right:.75rem;flex-shrink:0}.campo-busqueda-asignacion{flex:1;border:none;background:transparent;font-size:.95rem;color:#1e293b;outline:none}.campo-busqueda-asignacion::placeholder{color:#94a3b8}.contenido-asignacion{padding:0 1.5rem 1.5rem}.productos-cargando{text-align:center;padding:3rem 1.5rem;color:#64748b}.productos-cargando .spinner{margin:0 auto 1rem;width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.productos-vacios-grande{text-align:center;padding:3rem 1.5rem;color:#64748b}.icono-productos-grande{font-size:4rem;margin-bottom:1rem;opacity:.5}.productos-vacios-grande p{margin:.5rem 0;font-size:1.1rem}.texto-secundario{font-size:.9rem;opacity:.7}.lista-productos-asignacion{max-height:400px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:.75rem;background:#f8fafc}.item-producto-asignacion{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#fff;transition:all .3s ease}.item-producto-asignacion:last-child{border-bottom:none}.item-producto-asignacion:hover{background:#f1f5f9}.info-producto-asignacion{flex:1;margin-right:1.5rem}.nombre-producto-asignacion{font-weight:600;color:#1e293b;font-size:1rem;margin-bottom:.25rem}.codigo-producto-asignacion{color:#64748b;font-size:.9rem;margin-bottom:.5rem}.stock-info-asignacion{display:flex;gap:1rem;font-size:.85rem}.stock-total{color:#059669;font-weight:500}.stock-disponible{color:#dc2626;font-weight:500}.control-asignacion{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.label-cantidad-asignacion{font-size:.9rem;color:#475569;font-weight:500;white-space:nowrap}.input-cantidad-asignacion{width:80px;padding:.5rem;border:2px solid #e2e8f0;border-radius:.5rem;text-align:center;font-size:.9rem;transition:all .3s ease;background:#fff}.input-cantidad-asignacion:empty{color:#94a3b8}.input-cantidad-asignacion:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a;background:#fff;color:#1e293b}.unidad-asignacion{font-size:.9rem;color:#64748b;white-space:nowrap}.resumen-asignacion{margin-top:1.5rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.75rem;color:#fff}.titulo-resumen{font-weight:600;margin-bottom:.5rem;font-size:1rem}.contenido-resumen{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;font-size:.9rem}.item-resumen{display:flex;justify-content:space-between;align-items:center}.valor-resumen{font-weight:600}.buscador-productos{margin-bottom:1.5rem;padding:0 1.5rem}.input-busqueda-productos{position:relative;display:flex;align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:.75rem;padding:.75rem 1rem;transition:all .3s ease}.input-busqueda-productos:focus-within{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.icono-busqueda-productos{font-size:1.1rem;color:#64748b;margin-right:.75rem;flex-shrink:0}.campo-busqueda-productos{flex:1;border:none;background:transparent;font-size:.95rem;color:#1e293b;outline:none}.campo-busqueda-productos::placeholder{color:#94a3b8}.boton-limpiar-busqueda{background:#e2e8f0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:.8rem;cursor:pointer;transition:all .3s ease;flex-shrink:0}.boton-limpiar-busqueda:hover{background:#cbd5e1;color:#475569}@media (max-width: 768px){.modal-asignar-productos{margin:1rem;max-height:calc(100vh - 2rem)}.buscador-asignacion{padding:0 1rem;margin-bottom:1rem}.input-busqueda-asignacion{padding:.6rem .8rem}.campo-busqueda-asignacion{font-size:.9rem}.contenido-asignacion{padding:0 1rem 1rem}.item-producto-asignacion{flex-direction:column;align-items:flex-start;gap:1rem}.control-asignacion{width:100%;justify-content:space-between}.contenido-resumen{grid-template-columns:1fr}}@media (max-width: 768px){.buscador-productos{padding:0 1rem;margin-bottom:1rem}.input-busqueda-productos{padding:.6rem .8rem}.campo-busqueda-productos{font-size:.9rem}}@media (max-width: 480px){.modal-asignar-productos{margin:.5rem;max-height:calc(100vh - 1rem)}.buscador-asignacion{padding:0 .75rem}.input-busqueda-asignacion{padding:.5rem .75rem}.campo-busqueda-asignacion{font-size:.85rem}.contenido-asignacion{padding:0 .75rem .75rem}.item-producto-asignacion{padding:.75rem 1rem}.nombre-producto-asignacion{font-size:.9rem}.codigo-producto-asignacion{font-size:.8rem}.stock-info-asignacion{flex-direction:column;gap:.25rem}.input-cantidad-asignacion{width:60px;padding:.4rem;font-size:.8rem}.label-cantidad-asignacion,.unidad-asignacion{font-size:.8rem}}@media (max-width: 480px){.buscador-productos{padding:0 .75rem}.input-busqueda-productos{padding:.5rem .75rem}.campo-busqueda-productos{font-size:.85rem}.boton-limpiar-busqueda{width:20px;height:20px;font-size:.7rem}}.modal-formulario{max-width:600px;max-height:90vh;overflow-y:auto}.seccion-transferencia{padding:1rem 0}.seccion-transferencia h4{color:#374151;font-size:1.1rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.campo-transferencia{margin-bottom:1.5rem}.campo-transferencia label{display:block;font-weight:600;color:#374151;margin-bottom:.75rem;font-size:1.1rem}.select-transferencia{width:100%;padding:1rem 1.25rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1.1rem;background-color:#fff;transition:border-color .3s ease;min-height:56px}.select-transferencia:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input-cantidad-transferencia{display:flex;align-items:center;gap:1rem}.input-transferencia{flex:1;padding:1rem 1.25rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1.1rem;background-color:#fff;transition:border-color .3s ease;min-height:56px}.input-transferencia:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.stock-disponible-transferencia{color:#6b7280;font-size:1rem;white-space:nowrap;font-weight:500}.resumen-transferencia{background:#f8fafc;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;margin-top:1.5rem}.resumen-transferencia h4{color:#374151;font-size:1rem;font-weight:600;margin-bottom:1rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.detalles-transferencia p{margin:.5rem 0;color:#4b5563;font-size:.9rem}.detalles-transferencia strong{color:#374151;font-weight:600}.botones-accion-producto{display:flex;gap:.5rem;align-items:center}.boton-transferir-producto{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1rem;box-shadow:0 2px 8px #f59e0b4d}.boton-transferir-producto:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.boton-quitar-producto{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:.9rem}.boton-quitar-producto:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}.producto-seleccionado{background:#f8fafc;border:2px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-top:.5rem}.producto-seleccionado strong{display:block;color:#374151;font-size:1rem;margin-bottom:.5rem}.producto-seleccionado .stock-disponible{color:#6b7280;font-size:.9rem}.boton-accion.boton-transferir{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1rem;box-shadow:0 2px 4px #0000001a}.boton-accion.boton-transferir:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;background:linear-gradient(135deg,#d97706,#b45309)}.boton-accion.boton-transferir:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}@media (max-width: 768px){.modal-transferir{margin:1rem;max-height:calc(100vh - 2rem)}.seccion-transferencia{padding:.75rem 0}.campo-transferencia{margin-bottom:1rem}.input-cantidad-transferencia{flex-direction:column;align-items:stretch;gap:.5rem}.stock-disponible-transferencia{text-align:center;font-size:.8rem}.resumen-transferencia{padding:1rem;margin-top:1rem}}@media (max-width: 480px){.modal-transferir{margin:.5rem;max-height:calc(100vh - 1rem)}.seccion-transferencia h4,.campo-transferencia label{font-size:1rem}.select-transferencia,.input-transferencia{padding:.9rem 1rem;font-size:1rem;min-height:48px}.detalles-transferencia p{font-size:.85rem}}.modal-confirmacion{max-width:500px}.modal-confirmacion .modal-header h3{color:#dc2626;display:flex;align-items:center;gap:.5rem}.modal-confirmacion .modal-body .advertencia{background:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;padding:1rem;margin-top:1rem;color:#92400e;font-size:.9rem}.modal-confirmacion .modal-footer .boton-eliminar{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.modal-confirmacion .modal-footer .boton-eliminar:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 15px #dc26264d}.modal-confirmacion .modal-footer .boton-eliminar:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-historial{max-width:900px;width:95%}.contenido-modal-historial{max-height:70vh;overflow-y:auto;padding:0}.cargando-historial{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.cargando-historial .spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.sin-datos-historial{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#64748b}.sin-datos-historial .icono-sin-datos{font-size:3rem;margin-bottom:1rem;opacity:.5}.sin-datos-historial h4{color:#374151;margin-bottom:.5rem;font-size:1.2rem}.lista-historial{display:flex;flex-direction:column;padding:1rem}.item-historial{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #00000014,0 2px 6px #0000000a;transition:all .3s ease;position:relative}.item-historial:nth-child(2n){background:#f8fafc;border-color:#cbd5e1}.item-historial:hover{box-shadow:0 8px 24px #0000001f,0 4px 12px #00000014;transform:translateY(-2px);border-color:#94a3b8}.item-historial:last-child{margin-bottom:0}.header-item-historial{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.tipo-movimiento{display:flex;align-items:center;gap:.5rem}.icono-tipo{font-size:1.2rem;padding:.25rem;border-radius:6px;background:#f8fafc}.icono-tipo.transferencia{background:#dbeafe;color:#1d4ed8}.icono-tipo.recepcion{background:#dcfce7;color:#16a34a}.icono-tipo.asignacion{background:#fef3c7;color:#d97706}.icono-tipo.remocion{background:#fee2e2;color:#dc2626}.nombre-tipo{font-weight:600;color:#374151;font-size:1rem}.fecha-movimiento{font-size:.875rem;color:#64748b;background:#f8fafc;padding:.25rem .75rem;border-radius:6px}.detalles-movimiento{display:flex;flex-direction:column;gap:.75rem}.producto-movimiento{display:flex;flex-direction:column;gap:.25rem}.producto-nombre-codigo{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.producto-movimiento strong{color:#1f2937;font-size:1.1rem;font-weight:600}.codigo-producto{font-size:.9rem;color:#fff;background:linear-gradient(135deg,#3b82f6,#1d4ed8);padding:.4rem .8rem;border-radius:8px;display:inline-block;font-weight:600;box-shadow:0 2px 4px #3b82f64d;border:1px solid #1d4ed8}.cantidad-movimiento{display:flex;align-items:center}.cantidad{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:1rem}.sectores-movimiento{display:flex;gap:1rem;flex-wrap:wrap}.sector-info{display:flex;align-items:center;gap:.5rem;background:#f8fafc;padding:.5rem .75rem;border-radius:6px;border:1px solid #e2e8f0}.sector-info .label{font-size:.875rem;color:#64748b;font-weight:500}.sector-nombre{font-weight:600;color:#374151}.usuario-movimiento{display:flex;align-items:center;gap:.5rem;background:#f0f9ff;padding:.5rem .75rem;border-radius:6px;border:1px solid #bae6fd}.usuario-movimiento .label{font-size:.875rem;color:#0369a1;font-weight:500}.usuario-nombre{font-weight:600;color:#0c4a6e}.observaciones-movimiento{background:#fefce8;padding:.75rem;border-radius:6px;border:1px solid #fde047}.observaciones-movimiento .label{font-size:.875rem;color:#a16207;font-weight:600;display:block;margin-bottom:.25rem}.observaciones-texto{color:#713f12;font-size:.9rem;line-height:1.4}.modal-historial-general{max-width:1000px;width:95%}.contenido-modal-historial-general{max-height:75vh;overflow-y:auto;padding:0}.filtro-historial-general{background:#f8fafc;padding:1.5rem;border-bottom:1px solid #e2e8f0;margin-bottom:1rem}.campo-filtro{display:flex;flex-direction:column;gap:.5rem}.campo-filtro label{font-weight:600;color:#374151;font-size:1rem}.input-filtro{width:100%;padding:.75rem 1rem;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s ease}.input-filtro:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.info-filtro{margin-top:.5rem;font-size:.875rem;color:#6b7280;font-style:italic}.cargando-historial-general,.sin-datos-historial-general{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.sin-datos-historial-general h4{color:#374151;margin-bottom:.5rem;font-size:1.2rem}.sin-datos-historial-general p{color:#6b7280;font-size:.9rem}.lista-historial-general{display:flex;flex-direction:column;padding:1rem}.item-historial-general{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #00000014,0 2px 6px #0000000a;transition:all .3s ease;position:relative}.item-historial-general:nth-child(2n){background:#f8fafc;border-color:#cbd5e1}.item-historial-general:hover{box-shadow:0 8px 24px #0000001f,0 4px 12px #00000014;transform:translateY(-2px);border-color:#94a3b8}.item-historial-general:last-child{margin-bottom:0}.header-item-historial-general{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.tipo-movimiento-general{display:flex;align-items:center;gap:.5rem}.icono-tipo-general{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;font-size:1rem;font-weight:700}.icono-tipo-general.transferencia{background:#dbeafe;color:#1d4ed8}.icono-tipo-general.recepcion{background:#dcfce7;color:#16a34a}.icono-tipo-general.asignacion{background:#fef3c7;color:#d97706}.icono-tipo-general.remocion{background:#fee2e2;color:#dc2626}.nombre-tipo-general{font-weight:600;color:#1f2937;font-size:1rem}.fecha-movimiento-general{color:#6b7280;font-size:.875rem;font-weight:500}.detalles-movimiento-general{display:flex;flex-direction:column;gap:.75rem}.producto-movimiento-general{display:flex;flex-direction:column;gap:.25rem}.producto-nombre-codigo-general{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.producto-movimiento-general strong{color:#1f2937;font-size:1.1rem;font-weight:600}.codigo-producto-general{font-size:.9rem;color:#fff;background:linear-gradient(135deg,#10b981,#059669);padding:.4rem .8rem;border-radius:8px;display:inline-block;font-weight:600;box-shadow:0 2px 4px #10b9814d;border:1px solid #059669}.cantidad-movimiento-general{display:flex;align-items:center}.cantidad-general{background:#fef3c7;color:#92400e;padding:.25rem .5rem;border-radius:4px;font-weight:600;font-size:.9rem}.sectores-movimiento-general{display:flex;flex-wrap:wrap;gap:1rem}.sector-info-general{display:flex;align-items:center;gap:.5rem}.sector-info-general .label-general{color:#6b7280;font-size:.875rem;font-weight:500}.sector-nombre-general{background:#e0e7ff;color:#3730a3;padding:.25rem .5rem;border-radius:4px;font-weight:600;font-size:.875rem}.usuario-movimiento-general{display:flex;align-items:center;gap:.5rem}.usuario-movimiento-general .label-general{color:#6b7280;font-size:.875rem;font-weight:500}.usuario-nombre-general{color:#374151;font-weight:600;font-size:.875rem}.observaciones-movimiento-general{display:flex;align-items:flex-start;gap:.5rem}.observaciones-movimiento-general .label-general{color:#6b7280;font-size:.875rem;font-weight:500;flex-shrink:0}.observaciones-texto-general{color:#713f12;font-size:.9rem;line-height:1.4}@media (max-width: 768px){.modal-historial,.modal-historial-general{width:98%;max-width:none;margin:1rem}.header-item-historial,.header-item-historial-general{flex-direction:column;align-items:flex-start;gap:.5rem}.sectores-movimiento,.sectores-movimiento-general{flex-direction:column;gap:.5rem}.detalles-movimiento,.detalles-movimiento-general{gap:.5rem}.item-historial,.item-historial-general{padding:1rem;margin-bottom:1rem}.producto-nombre-codigo,.producto-nombre-codigo-general{flex-direction:column;align-items:flex-start;gap:.5rem}.codigo-producto,.codigo-producto-general{font-size:.8rem;padding:.3rem .6rem}.boton-historial-general{padding:.6rem 1rem;font-size:.85rem;min-width:140px}}.stock-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-top:6rem}.stock-container{max-width:1400px;margin:0 auto;padding:.25rem 1rem}.loading-card{background:#fff;border-radius:1rem;padding:3rem 2rem;box-shadow:0 20px 40px #0000001a;text-align:center;margin:2rem auto;max-width:500px}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-card p{color:#64748b;font-size:1rem;margin:0}.stock-header{text-align:center;margin-bottom:1rem;color:#fff}.header-icon{font-size:3rem;background:#ffffff1a;border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);margin:0 auto .5rem}.header-title{font-size:2rem;font-weight:700;margin:0 0 .25rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.header-description{font-size:1rem;opacity:.9;max-width:600px;margin:0 auto}.back-button-container{margin-bottom:2rem;text-align:left}.back-button{display:inline-flex;align-items:center;gap:.5rem;background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.2);padding:.75rem 1.5rem;border-radius:.75rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);text-decoration:none}.back-button:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.stat-card{background:#fff;border-radius:16px;padding:1rem;box-shadow:0 2px 8px #0000000d;display:flex;align-items:center;gap:.75rem;transition:all .2s ease;border:2px solid #e2e8f0}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a;border-color:#667eea}.stat-icon{font-size:1.5rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.stat-content{flex:1}.stat-number{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .25rem;line-height:1}.stat-label{font-size:.8rem;color:#64748b;margin:0;font-weight:500}.filters-section{background:#fff;border-radius:16px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000000d;border:2px solid #e2e8f0}.filters-container{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center}.search-group{position:relative}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;color:#9ca3af;font-size:1.1rem;z-index:1}.search-input{width:100%;padding:.75rem .75rem .75rem 2.5rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;transition:all .3s ease;background:#f8fafc}.search-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.filter-group{min-width:250px}.filter-select{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1rem;background:#f8fafc;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.table-section{background:#fff;border-radius:1.5rem;padding:1rem;box-shadow:0 10px 30px #0000001a;overflow:hidden}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f1f5f9}.table-header h3{font-size:1.5rem;font-weight:600;color:#1e293b;margin:0}.table-controls{display:flex;gap:1rem}.refresh-button{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.75rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.refresh-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.empty-message{text-align:center;padding:4rem 2rem;color:#64748b}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-message h4{font-size:1.5rem;margin:0 0 .5rem;color:#475569}.empty-message p{font-size:1rem;margin:0}.table-wrapper{overflow-x:auto;border-radius:.75rem;border:1px solid #e2e8f0;background:#f8fafc;max-height:70vh;overflow-y:auto}.stock-table{width:100%;border-collapse:collapse;font-size:.95rem;background:#fff}.stock-table thead{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.stock-table th{padding:1.25rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0;white-space:nowrap}.stock-table th:nth-child(1),.stock-table td:nth-child(1){width:25%;vertical-align:middle}.stock-table th:nth-child(2),.stock-table td:nth-child(2){width:20%}.stock-table th:nth-child(3),.stock-table td:nth-child(3){width:30%}.stock-table th:nth-child(4),.stock-table td:nth-child(4){width:15%}.stock-table th:nth-child(5),.stock-table td:nth-child(5){width:15%}.sortable-header{cursor:pointer;transition:all .3s ease;user-select:none;position:relative}.sortable-header:hover{background:#f1f5f9;color:#667eea}.stock-table td{padding:1.25rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;word-wrap:break-word;overflow:hidden;text-overflow:ellipsis}.stock-table tbody tr{transition:all .3s ease}.stock-table tbody tr:hover{background:#f8fafc;transform:translate(4px)}.code-cell{font-family:Courier New,monospace;font-weight:600;color:#059669;background:#f0fdf4;padding:.75rem 1rem;border-radius:.5rem;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;overflow:visible;text-overflow:clip;max-width:none;font-size:.9rem;border:1px solid #bbf7d0;min-width:120px;height:auto;margin:auto 0}@media (max-width: 768px){.code-cell{padding:.5rem .75rem;font-size:.8rem;min-width:100px}}@media (max-width: 480px){.code-cell{padding:.4rem .5rem;font-size:.75rem;min-width:80px}}.name-cell{font-weight:600;color:#1e293b;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sector-cell{text-align:center;white-space:nowrap;position:relative;overflow:auto;max-width:300px;min-width:150px}.sector-cell-content{display:flex;justify-content:center;align-items:center;width:100%;min-height:40px}.sector-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:1rem;font-size:.85rem;font-weight:500;display:inline-block;box-shadow:0 2px 8px #667eea33;white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis}.sector-badge-full{max-width:none!important;overflow:visible!important;text-overflow:clip!important;white-space:nowrap!important;cursor:help;transition:all .3s ease}.sector-badge-full:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea4d;z-index:10;position:relative}@media (max-width: 768px){.sector-cell{max-width:200px;min-width:120px}.sector-badge{padding:.4rem .8rem;font-size:.8rem;max-width:120px}.sector-badge-full{max-width:none!important;font-size:.8rem;padding:.4rem .8rem}}@media (max-width: 480px){.sector-cell{max-width:150px;min-width:100px}.sector-badge{padding:.3rem .6rem;font-size:.75rem;max-width:100px}.sector-badge-full{max-width:none!important;font-size:.75rem;padding:.3rem .6rem}}.no-sector-badge{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.5rem 1rem;border-radius:1rem;font-size:.85rem;font-weight:500;display:inline-block;box-shadow:0 2px 8px #f59e0b33;white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.no-sector-badge{padding:.4rem .8rem;font-size:.8rem;max-width:120px}}@media (max-width: 480px){.no-sector-badge{padding:.3rem .6rem;font-size:.75rem;max-width:100px}}.consolidated-badge{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:.5rem 1rem;border-radius:1rem;font-size:.85rem;font-weight:500;display:inline-block;box-shadow:0 2px 8px #8b5cf633;white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.consolidated-badge{padding:.4rem .8rem;font-size:.8rem;max-width:120px}}@media (max-width: 480px){.consolidated-badge{padding:.3rem .6rem;font-size:.75rem;max-width:100px}}.quantity-cell{text-align:center;white-space:nowrap}@media (max-width: 768px){.quantity-cell{font-size:.8rem}}@media (max-width: 480px){.quantity-cell{font-size:.75rem}}.quantity-number{font-size:1.25rem;font-weight:700;color:#1e293b;display:block;margin-bottom:.25rem}@media (max-width: 768px){.quantity-number{font-size:1.1rem}}@media (max-width: 480px){.quantity-number{font-size:1rem}}.quantity-unit{font-size:.8rem;color:#64748b;font-weight:500}@media (max-width: 768px){.quantity-unit{font-size:.75rem}}@media (max-width: 480px){.quantity-unit{font-size:.7rem}}.date-cell{font-size:.9rem;color:#64748b;text-align:center;font-weight:500;white-space:nowrap}@media (max-width: 768px){.date-cell{font-size:.8rem}}@media (max-width: 480px){.date-cell{font-size:.75rem}}.product-name-container{display:flex;flex-direction:column;gap:.25rem}@media (max-width: 768px){.product-name-container{gap:.2rem}}@media (max-width: 480px){.product-name-container{gap:.15rem}}.product-name{font-weight:600;color:#1e293b}@media (max-width: 768px){.product-name{font-size:.9rem}}@media (max-width: 480px){.product-name{font-size:.85rem}}.stock-total-indicator{font-size:.8rem;color:#64748b;font-weight:500;font-style:italic}@media (max-width: 768px){.stock-total-indicator{font-size:.75rem}}@media (max-width: 480px){.stock-total-indicator{font-size:.7rem}}.table-row:has(.no-sector-badge){background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.table-row:has(.no-sector-badge):hover{background:linear-gradient(135deg,#fde68a,#fcd34d)}.table-row:has(.consolidated-badge){background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-left:4px solid #8b5cf6}.table-row:has(.consolidated-badge):hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db)}.table-row:has(.sector-badge){border-left:4px solid #667eea}.table-row:has(.sector-badge):hover{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.fila-seleccionada{background:#e0f2fe!important;border:2px solid #0288d1;box-shadow:0 0 0 2px #0288d133}.fila-seleccionada td{background:#e0f2fe!important}.fila-seleccionada .code-cell{background:#f0fdf4!important;border:1px solid #bbf7d0!important;color:#059669!important}@media (max-width: 1024px){.stock-container{padding:1.5rem 1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.filters-container{grid-template-columns:1fr;gap:1rem}.filter-group{min-width:auto}}@media (max-width: 768px){.stock-container{padding:1rem .5rem}.stock-header{margin-bottom:2rem}.header-icon{width:80px;height:80px;font-size:2.5rem}.header-title{font-size:2rem}.header-description{font-size:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{padding:1rem}.stat-icon{width:50px;height:50px;font-size:1.5rem}.stat-number{font-size:1.5rem}.filters-section,.table-section{padding:1.5rem}.table-header{flex-direction:column;gap:1rem;align-items:stretch}.table-controls{justify-content:center}.table-wrapper{font-size:.85rem;max-height:60vh;overflow-x:auto;overflow-y:auto}.stock-table{min-width:600px}.stock-table th,.stock-table td{padding:.75rem .5rem;font-size:.8rem}.stock-table th:nth-child(1),.stock-table td:nth-child(1){width:20%;min-width:100px}.stock-table th:nth-child(2),.stock-table td:nth-child(2){width:30%;min-width:150px}.stock-table th:nth-child(3),.stock-table td:nth-child(3){width:30%;min-width:150px}.stock-table th:nth-child(4),.stock-table td:nth-child(4){width:15%;min-width:80px}.stock-table th:nth-child(5),.stock-table td:nth-child(5){width:10%;min-width:100px}.product-name-container{gap:.2rem}.stock-total-indicator{font-size:.75rem}.table-row:has(.no-sector-badge),.table-row:has(.sector-badge){border-left-width:3px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center;gap:.75rem}.stat-icon{width:60px;height:60px;font-size:1.75rem}.table-wrapper{max-height:50vh;font-size:.8rem}.stock-table{min-width:500px}.stock-table th,.stock-table td{padding:.5rem .25rem;font-size:.75rem}.stock-table th:nth-child(4),.stock-table td:nth-child(4){display:none}.stock-table th:nth-child(5),.stock-table td:nth-child(5){display:none}.header-icon{width:60px;height:60px;font-size:2rem}.header-title{font-size:1.75rem}.header-description{font-size:.95rem}.stock-total-indicator{font-size:.7rem}.table-row:has(.no-sector-badge),.table-row:has(.sector-badge){border-left-width:2px}}.table-row.clickeable-row{cursor:pointer;position:relative;transition:all .2s ease}.table-row.clickeable-row:has(.sector-badge):hover{background:linear-gradient(135deg,#e0f2fe,#bae6fd)!important;transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e933;border-left:4px solid #0ea5e9!important}.table-row.clickeable-row:has(.sector-badge):hover:after{content:"🔄 Transferir Stock";position:absolute;top:50%;right:1rem;transform:translateY(-50%);background:#0ea5e9f2;color:#fff;padding:.25rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:500;white-space:nowrap;backdrop-filter:blur(10px);animation:fadeInTooltip .2s ease;z-index:10;box-shadow:0 2px 8px #0ea5e94d}.table-row.clickeable-row:has(.no-sector-badge):hover{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b33;border-left:4px solid #f59e0b!important}.table-row.clickeable-row:has(.no-sector-badge):hover:after{content:"⚠️ Asignar a Sector";position:absolute;top:50%;right:1rem;transform:translateY(-50%);background:#f59e0bf2;color:#fff;padding:.25rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:500;white-space:nowrap;backdrop-filter:blur(10px);animation:fadeInTooltip .2s ease;z-index:10;box-shadow:0 2px 8px #f59e0b4d}@keyframes fadeInTooltip{0%{opacity:0;transform:translateY(-50%) translate(10px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.table-row.clickeable-row.fila-seleccionada:hover{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff}.table-row.clickeable-row.fila-seleccionada:hover:after{background:#fffffff2;color:#667eea;box-shadow:0 2px 8px #ffffff4d}.table-row.clickeable-row:has(.consolidated-badge):hover{background:linear-gradient(135deg,#f3f4f6,#e5e7eb)!important;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf633;border-left:4px solid #8b5cf6!important}.table-row.clickeable-row:has(.consolidated-badge):hover:after{content:"📊 Ver Detalles";position:absolute;top:50%;right:1rem;transform:translateY(-50%);background:#8b5cf6f2;color:#fff;padding:.25rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:500;white-space:nowrap;backdrop-filter:blur(10px);animation:fadeInTooltip .2s ease;z-index:10;box-shadow:0 2px 8px #8b5cf64d}.mobile-cards-wrapper{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;padding:1rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;margin:.5rem}.mobile-cards-wrapper::-webkit-scrollbar{width:6px}.mobile-cards-wrapper::-webkit-scrollbar-track{background:transparent}.mobile-cards-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.mobile-cards-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.mobile-stock-card{position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);margin-bottom:1rem}.mobile-stock-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 32px #0000002e,0 8px 16px #0000001f!important}.mobile-stock-card.card-seleccionada{border-color:#3b82f6!important;box-shadow:0 8px 32px #3b82f640,0 4px 16px #3b82f626!important;transform:translateY(-2px)}.mobile-stock-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.3),transparent);opacity:0;transition:opacity .3s ease}.mobile-stock-card:hover:before{opacity:1}.clickeable-card{position:relative}.clickeable-card:hover:after{content:"📱 Toca para transferir stock";background:linear-gradient(135deg,#3b82f6f2,#2563ebf2);color:#fff;padding:.75rem 1.25rem;border-radius:12px;font-size:.8rem;font-weight:600;white-space:nowrap;position:absolute;top:-50px;left:50%;transform:translate(-50%);z-index:1000;animation:fadeInTooltip .3s ease-out;box-shadow:0 8px 24px #3b82f64d;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(10px)}.clickeable-card.card-seleccionada:hover:after{content:"⌨️ Presiona Enter para transferir stock";background:linear-gradient(135deg,#fffffff2,#f8fafcf2);color:#3b82f6;box-shadow:0 8px 24px #3b82f633;border:2px solid rgba(59,130,246,.3)}.pagina-admin{min-height:100vh;background:var(--gradiente-fondo);padding-top:64px;margin-top:0}.contenido-admin{max-width:1600px;margin:0 auto;padding:2rem 1rem 1rem}.header-admin{text-align:center;margin-bottom:2rem;color:#fff}.header-content{background:var(--gradiente-titulo);padding:2rem;border-radius:16px;border:2px solid #7c3aed;margin-bottom:2rem;display:flex;flex-direction:column;gap:1.5rem}.header-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1.5rem}.header-filters{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1rem}.header-left{text-align:left;flex:1;min-width:0}.header-left h1{font-size:2rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px rgba(0,0,0,.3);line-height:1.2}.header-left p{font-size:1rem;opacity:.9;margin:0}.btn-volver{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;backdrop-filter:blur(10px);margin-bottom:.5rem}.btn-volver:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-2px)}.btn-crear{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#4facfe,#00f2fe);border:none;border-radius:12px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;white-space:nowrap;min-width:fit-content;flex-shrink:0}.btn-crear:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.filtros-busqueda{display:none}.busqueda-container{flex:0 1 auto;min-width:200px;max-width:300px}.input-busqueda{width:100%;padding:.75rem 1rem;border:2px solid rgba(255,255,255,.3);border-radius:8px;font-size:.875rem;background:#ffffff1a;color:#fff;transition:all .3s ease;backdrop-filter:blur(10px)}.input-busqueda::placeholder{color:#ffffffb3}.input-busqueda:focus{outline:none;border-color:#ffffff80;background:#ffffff26}.filtros{display:flex;gap:1rem;align-items:center}.checkbox-container{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;color:#fff;font-weight:500}.checkbox-container input[type=checkbox]{width:1.2rem;height:1.2rem;accent-color:#4facfe}.grid-transportistas{display:grid;grid-template-columns:repeat(auto-fill,280px);gap:1rem;margin-bottom:2rem;justify-content:center}.card-transportista{background:var(--color-card);border-radius:24px;padding:1.5rem;box-shadow:0 4px 20px var(--color-sombra);transition:all .3s ease;cursor:pointer;border:2px solid var(--color-borde);position:relative;overflow:hidden;min-height:180px;display:flex;flex-direction:column;text-align:center}.card-transportista:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a;border-color:#667eea}.card-transportista.seleccionada{border-color:#000;box-shadow:0 0 0 3px #0000004d;transform:translateY(-2px)}.card-transportista.inactiva{opacity:.7;background:#f9fafb}.card-transportista.inactiva:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:#ef4444}.card-header{display:flex;justify-content:center;align-items:center;margin-bottom:1rem;position:relative}.card-icon{width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;box-shadow:0 4px 15px #667eea4d;font-size:1.5rem;color:#fff}.codigo-interno{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;position:absolute;top:0;right:0;box-shadow:0 2px 8px #667eea4d}.estado{padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.estado.activo{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.estado.inactivo{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.card-content{flex:1;display:flex;flex-direction:column;align-items:center}.card-content h3{font-size:1.2rem;font-weight:700;color:var(--color-texto-principal);margin:0 0 .75rem;text-align:center}.empresa{display:none}.info-vehiculos{margin:1rem 0;padding:1rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:20px;border:1px solid #bae6fd;text-align:center;box-shadow:0 2px 8px #0000000d}.info-vehiculos span{color:#0369a1;font-size:.875rem;font-weight:500}.card-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:1rem;justify-content:center;align-items:center}.btn-editar,.btn-estado,.btn-eliminar{width:45px;height:45px;border:none;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;margin:0 .25rem}.btn-editar{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.btn-editar:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.btn-activar{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.btn-activar:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.btn-desactivar{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff}.btn-desactivar:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.btn-eliminar{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.btn-eliminar:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.cargando-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;background:var(--color-card);border-radius:16px;box-shadow:0 2px 8px var(--color-sombra);border:2px solid var(--color-borde)}.spinner{width:3rem;height:3rem;border:4px solid #e5e7eb;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.sin-datos{text-align:center;padding:2rem 1rem;color:var(--color-texto-secundario);background:var(--color-card);border-radius:16px;box-shadow:0 2px 8px var(--color-sombra);border:2px solid var(--color-borde);display:flex;flex-direction:column;align-items:center;justify-content:center}.sin-datos p{font-size:1.125rem;margin-bottom:1.5rem}.sin-datos .btn-crear{margin:0 auto}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem 1rem;backdrop-filter:blur(5px)}.modal{background:var(--color-card);border-radius:1.5rem;max-width:500px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 25px 50px -12px var(--color-sombra-fuerte)}.modal-grande{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid var(--color-borde)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-texto-principal)}.btn-cerrar{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b;padding:.5rem;border-radius:.5rem;transition:all .2s ease}.btn-cerrar:hover{background:#f1f5f9;color:#1e293b}.modal-content{padding:1.5rem 1.5rem 2rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:2px solid #f1f5f9}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--color-texto-principal);margin-bottom:.5rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--color-borde);border-radius:.75rem;font-size:1rem;transition:all .2s ease;box-sizing:border-box;background:var(--color-card);color:var(--color-texto-principal)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error,.form-group textarea.error{border-color:#ef4444}.error-message{color:#ef4444;font-size:.875rem;margin-top:.25rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:end}.btn-cancelar,.btn-guardar,.btn-cerrar-modal{padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancelar{background:#f1f5f9;color:#374151}.btn-cancelar:hover{background:#e2e8f0}.btn-guardar{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.btn-guardar:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.btn-guardar:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.btn-cerrar-modal{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-cerrar-modal:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.formulario-vehiculo{background:var(--color-fondo-secundario);padding:1.5rem;border-radius:1rem;margin-bottom:2rem;border:2px solid var(--color-borde)}.formulario-vehiculo h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--color-texto-principal)}.btn-agregar{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.75rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%}.btn-agregar:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.btn-agregar:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.lista-vehiculos{padding-bottom:1rem}.lista-vehiculos h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--color-texto-principal)}.sin-vehiculos{text-align:center;padding:2rem;color:var(--color-texto-secundario);font-style:italic;background:var(--color-fondo-secundario);border-radius:.75rem;border:2px dashed var(--color-borde)}.vehiculos-grid{display:grid;gap:1rem;margin-bottom:1rem}.vehiculo-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-card);border:2px solid var(--color-borde);border-radius:.75rem;transition:all .2s ease}.vehiculo-item:hover{border-color:#667eea;box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.vehiculo-item.inactivo{opacity:.6;background:#f9fafb}.vehiculo-info{flex:1}.vehiculo-marca-modelo{font-weight:600;color:var(--color-texto-principal);margin-bottom:.25rem}.vehiculo-patente{font-size:.875rem;color:var(--color-texto-secundario);margin-bottom:.25rem}.vehiculo-estado{font-size:.75rem;font-weight:600;text-transform:uppercase;padding:.25rem .5rem;border-radius:.5rem;display:inline-block}.vehiculo-estado.activo{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.vehiculo-estado.inactivo{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.vehiculo-acciones{margin-left:1rem;display:flex;justify-content:center;align-items:center}@media (max-width: 1200px){.grid-transportistas{grid-template-columns:repeat(auto-fill,280px)}}@media (max-width: 900px){.grid-transportistas{grid-template-columns:repeat(auto-fill,280px)}}@media (max-width: 768px){.contenido-admin{padding:1rem .5rem}.header-content{padding:1.5rem}.header-top{flex-direction:column;align-items:center;gap:1rem}.header-left{text-align:center}.header-left h1{font-size:1.75rem}.header-left p{font-size:.9rem}.header-filters{flex-direction:column;align-items:stretch;gap:1rem}.busqueda-container{min-width:auto;max-width:none}.grid-transportistas{grid-template-columns:repeat(auto-fill,280px);gap:.75rem}.card-actions{flex-direction:row;gap:.5rem}.btn-editar,.btn-estado,.btn-eliminar{width:40px;height:40px;font-size:1rem}.form-row{grid-template-columns:1fr}.vehiculo-item{flex-direction:row;align-items:center;gap:.5rem;padding:.75rem}.vehiculo-acciones{margin-left:0;flex-shrink:0}.vehiculo-acciones .btn-estado{width:36px;height:36px;font-size:1rem}.modal{margin:.5rem;max-height:calc(100vh - 4rem)}}@media (max-width: 480px){.contenido-admin{padding:.5rem}.header-content{padding:1rem}.header-top{gap:.75rem}.header-left h1{font-size:1.5rem}.header-left p{font-size:.85rem}.header-filters{gap:.75rem}.card-transportista{padding:.75rem}.card-content h3{font-size:1rem}.modal{margin:.25rem;max-height:calc(100vh - 4.5rem)}.modal-content,.modal-footer{padding:.75rem}.btn-volver,.btn-crear{padding:.5rem .75rem;font-size:.8rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.recibir-productos-container{min-height:100vh;padding-bottom:4rem!important}.recibir-productos-container>div{margin-bottom:2rem}.lista-recepciones{margin-bottom:3rem}.boton-guardar{margin-bottom:2rem}.recibir-productos-container{display:grid;grid-template-columns:1fr 1fr 300px;gap:1.5rem;min-height:100vh;padding-bottom:4rem;width:100%;max-width:none;overflow:visible;position:relative}.panel-busqueda,.panel-recepcion,.panel-resumen{display:flex;flex-direction:column}.panel-busqueda{min-height:600px;height:600px;display:flex;flex-direction:column}.panel-busqueda .card{min-height:550px;height:550px;display:flex;flex-direction:column}.panel-recepcion{min-height:600px;height:600px;display:flex;flex-direction:column}.panel-recepcion .card{min-height:550px;height:550px;display:flex;flex-direction:column}.panel-resumen{min-height:400px;height:400px;display:flex;flex-direction:column}.panel-resumen .card{min-height:350px;height:350px;display:flex;flex-direction:column;padding:1.5rem}.buscador-avanzado{min-height:500px;height:500px;display:flex;flex-direction:column;flex:1}.lista-productos{min-height:200px;max-height:300px;overflow-y:auto;flex:1}.lista-ubicaciones{min-height:150px;max-height:250px;overflow-y:auto}.contenido-recepcion{min-height:500px;height:500px;display:flex;flex-direction:column;flex:1}.lista-recepciones{flex:1;overflow-y:auto;min-height:300px}@media (max-width: 1200px){.recibir-productos-container{grid-template-columns:1fr 1fr;gap:1rem}.panel-resumen{grid-column:1 / -1;min-height:300px;height:300px}.panel-resumen .card{min-height:250px;height:250px}}@media (max-width: 768px){.recibir-productos-container{grid-template-columns:1fr;gap:1rem;padding:1rem}.panel-busqueda,.panel-recepcion,.panel-resumen{min-height:auto;height:auto}.panel-busqueda .card,.panel-recepcion .card,.panel-resumen .card{min-height:auto;height:auto;padding:1rem}.buscador-avanzado,.contenido-recepcion{min-height:auto;height:auto}.lista-productos,.lista-ubicaciones,.lista-recepciones{min-height:200px;max-height:300px}}@media (max-width: 480px){.recibir-productos-container{padding:.5rem;gap:.75rem}.panel-busqueda .card,.panel-recepcion .card,.panel-resumen .card{padding:.75rem}}
