/* =====================================================================
   SOLUCIONES GASTRONÓMICOS — styles.css (versión sobria)
   Paleta: Neutra · Minimalista · Profesional
   ===================================================================== */

/* ─── VARIABLES ──────────────────────────────────────────────────────── */
:root {
  /* Paleta sobria (grises y un solo acento sutil) */
  --gris-900: #1e1e1e;      /* Texto principal, fondos oscuros */
  --gris-700: #3a3a3a;      /* Títulos, énfasis */
  --gris-500: #6c6c6c;      /* Texto secundario, bordes */
  --gris-300: #b0b0b0;      /* Bordes suaves, divisores */
  --gris-100: #f5f5f5;      /* Fondos claros, hover */
  --blanco:    #ffffff;

  /* Acento único muy sutil (gris azulado) */
  --accento:   #5f7d8c;      /* Solo para enlaces o detalles mínimos */
  --accento-hover: #4a6370;

  /* Layout */
  --max-width:   1280px;
  --radius-card: 4px;        /* Bordes más rectos, más serios */

  /* Sombras casi imperceptibles */
  --shadow-sm:   0 1px 2px rgba(0,0,0,0.03);
  --shadow-md:   0 2px 4px rgba(0,0,0,0.05);
}

/* ─── RESET BASE ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

div[style*="z-index: 99999"] {
  display: none !important; visibility: hidden !important;
  height: 0 !important; padding: 0 !important;
}

html { scroll-behavior: auto; } /* Quitamos smooth scroll para sobriedad */

body {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  color: var(--gris-900);
  background-color: var(--blanco);
  line-height: 1.6;
  font-size: 15px;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

main { min-width: 0; width: 100%; }

h1, h2, h3, h4 {
  font-family: "Inter", system-ui, sans-serif;
  color: var(--gris-700);
  font-weight: 500;          /* Menos peso, más sobrio */
  letter-spacing: normal;    /* Sin expansión */
  line-height: 1.3;
}

/* Eliminamos la clase Poppins */
.hero-title, .section-title, .cat-hero-title {
  font-family: "Inter", sans-serif;
}

a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 2rem;           /* Un poco más de aire */
}

/* ─── TOP BAR — ahora estática, sin animación ────────────────────────── */
.top-bar {
  background: var(--gris-900);
  color: var(--gris-300);
  font-size: 0.75rem;
  border-bottom: none;
  height: 36px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.top-bar-scroll-inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  white-space: nowrap;
  padding-left: 0;            /* Quitamos el padding infinito */
  animation: none;            /* Sin animación */
}
.tb-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--gris-300);
  text-decoration: none;
  padding: 0;
  transition: color 0.1s;
  font-size: 0.75rem;
  font-weight: 400;
}
.tb-item svg { width: 12px; height: 12px; opacity: 0.6; }
.tb-item.tb-sep { color: var(--gris-500); }
a.tb-item:hover { color: var(--blanco); }
.tb-item.tb-wa { color: var(--gris-300); font-weight: 400; }
a.tb-item.tb-wa:hover { color: var(--blanco); }

/* ─── HEADER / NAV (menos pegajoso, sin animaciones) ─────────────────── */
header {
  border-bottom: 1px solid var(--gris-300);
  background: var(--blanco);
  position: relative;         /* Quitamos sticky */
  top: 0;
  z-index: 100;
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 0;
  gap: 1rem;
  flex-wrap: nowrap;
}

.logo { display: flex; align-items: center; gap: 0.5rem; flex-shrink: 0; }
.logo img { width: 140px; object-fit: contain; }

.logo-text {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--gris-900);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

nav { flex: 1; display: flex; justify-content: flex-start; }

.nav-menu {
  list-style: none;
  display: flex;
  gap: 2rem;
  font-size: 0.9rem;
  align-items: center;
}

.nav-menu a {
  color: var(--gris-700);
  font-weight: 400;
  transition: color 0.1s;
}
.nav-menu a:hover { color: var(--gris-900); }
/* Eliminamos el pseudo-elemento ::after con subrayado animado */

.nav-right {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  flex-shrink: 0;
}

.nav-cta {
  padding: 0.45rem 1.2rem;
  border-radius: 3px;
  border: 1px solid var(--gris-500);
  color: var(--gris-700);
  font-size: 0.85rem;
  font-weight: 500;
  background: transparent;
  white-space: nowrap;
  transition: background 0.1s, color 0.1s;
}
.nav-cta:hover {
  background: var(--gris-900);
  color: var(--blanco);
  border-color: var(--gris-900);
}

/* Buscador en header */
.header-search { min-width: 200px; max-width: 240px; }

.header-search-input {
  width: 100%;
  padding: 0.4rem 0.8rem;
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  font-size: 0.85rem;
  background: var(--blanco);
  outline: none;
  color: var(--gris-900);
  transition: border-color 0.1s;
}
.header-search-input::placeholder { color: var(--gris-500); }
.header-search-input:focus {
  border-color: var(--gris-700);
  box-shadow: none; /* Eliminamos sombra */
}

/* Botón hamburguesa (sin cambios estructurales) */
.nav-toggle {
  display: none;
  width: 38px; height: 38px;
  border: 1px solid var(--gris-300);
  background: var(--blanco);
  cursor: pointer;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.nav-toggle span {
  display: block; width: 18px; height: 1.5px;
  background: var(--gris-900);
  transition: transform 0.2s, opacity 0.2s;
}
.nav-toggle.nav-toggle--open span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.nav-toggle.nav-toggle--open span:nth-child(2) { opacity: 0; }
.nav-toggle.nav-toggle--open span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

/* ─── HERO (sin gradientes, sin patrones) ────────────────────────────── */
.hero {
  background: var(--gris-100);
  color: var(--gris-700);
  padding: 4rem 0;
  position: relative;
}
.hero::before { display: none; } /* Eliminamos el overlay radial */
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: center;
}
.hero-subtitle {
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  color: var(--gris-500);
  font-weight: 400;
  margin-bottom: 0.5rem;
}
.hero-title {
  font-size: 2.2rem;
  margin-bottom: 0.8rem;
  line-height: 1.2;
  color: var(--gris-900);
  font-weight: 500;
}
.hero-text {
  font-size: 1rem;
  max-width: 540px;
  margin-bottom: 1.5rem;
  color: var(--gris-500);
}
.hero-cta-group { display: flex; gap: 1rem; flex-wrap: wrap; }

.hero-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.5rem; }
.hero-badge {
  padding: 0.2rem 0.8rem;
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  background: transparent;
  color: var(--gris-500);
  font-size: 0.75rem;
}
.hero-image-box {
  background: var(--blanco);
  padding: 0.5rem;
  border: 1px solid var(--gris-300);
  border-radius: 3px;
}
.hero-image-box img { border-radius: 3px; }
.hero-tagline { margin-top: 0.5rem; font-size: 0.85rem; color: var(--gris-500); }

/* ─── BUTTONS (planos, sin bordes llamativos) ────────────────────────── */
.btn {
  display: inline-block;
  padding: 0.6rem 1.5rem;
  border-radius: 3px;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 0.1s, border-color 0.1s;
  white-space: nowrap;
  text-align: center;
}

.btn-primary {
  background: var(--gris-900);
  color: var(--blanco);
  border-color: var(--gris-900);
}
.btn-primary:hover {
  background: var(--gris-700);
  border-color: var(--gris-700);
}

.btn-outline {
  background: transparent;
  border-color: var(--gris-500);
  color: var(--gris-700);
}
.btn-outline:hover {
  background: var(--gris-100);
  border-color: var(--gris-700);
}

/* Eliminamos .btn-cobre (no usado en sobrio) */

/* ─── SECTION BASE ───────────────────────────────────────────────────── */
section { padding: 3rem 0; }

.section-title {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  margin-bottom: 0.5rem;
  color: var(--gris-700);
}

.section-subtitle {
  text-align: center;
  font-size: 1rem;
  color: var(--gris-500);
  max-width: 600px;
  margin: 0 auto 2rem;
  line-height: 1.5;
}

/* ─── TRUST STRIP (simplificado) ─────────────────────────────────────── */
.trust-strip {
  background: var(--gris-100);
  border-bottom: 1px solid var(--gris-300);
}
.trust-strip-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.trust-pill {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1rem 1.5rem;
  border-right: 1px solid var(--gris-300);
  font-size: 0.9rem;
  color: var(--gris-500);
  transition: background 0.1s;
}
.trust-pill:last-child { border-right: none; }
.trust-pill:hover { background: var(--blanco); }
.trust-pill b { color: var(--gris-700); font-weight: 500; }
.trust-icon {
  width: 32px; height: 32px;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--blanco);
  border: 1px solid var(--gris-300);
  font-size: 1rem;
}

/* ─── CATEGORIES GRID (menos énfasis) ────────────────────────────────── */
.categories-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.category-card {
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  background: var(--blanco);
  display: flex;
  flex-direction: column;
  transition: border-color 0.1s;
}
.category-card:hover { border-color: var(--gris-500); }

.category-image {
  height: 140px;
  background: var(--gris-100);
  background-size: cover;
  background-position: center;
}

.category-body {
  padding: 0.8rem 1rem 1rem;
}

.category-title {
  font-size: 0.9rem;
  font-weight: 500;
  margin-bottom: 0.3rem;
  color: var(--gris-700);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.category-text {
  font-size: 0.8rem;
  color: var(--gris-500);
  margin-bottom: 0.5rem;
  line-height: 1.5;
}

.category-link {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--accento);
  display: inline-flex;
  align-items: center;
  gap: 0.1rem;
  transition: color 0.1s;
}
.category-link:hover { color: var(--accento-hover); }
.category-link::after { content: "›"; font-size: 1rem; }

/* ─── CARRUSEL DE PRODUCTOS (sin sombras, sin flechas exageradas) ────── */
.products-carousel-section { background: var(--blanco); }

.products-carousel { position: relative; margin-top: 1rem; }
.carousel-track-wrapper { overflow: hidden; }
.carousel-track { display: flex; gap: 1.5rem; }
.carousel-track .product-card { flex: 0 0 calc(25% - 1.125rem); }

.carousel-arrow {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px;
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  background: var(--blanco);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: 1rem;
  color: var(--gris-700);
  transition: background 0.1s, color 0.1s;
  z-index: 2;
}
.carousel-arrow--prev { left: -1rem; }
.carousel-arrow--next { right: -1rem; }
.carousel-arrow:hover {
  background: var(--gris-900);
  color: var(--blanco);
  border-color: var(--gris-900);
}

/* ─── PRODUCTS GRID (card minimal) ───────────────────────────────────── */
.products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.product-card {
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  background: var(--blanco);
  display: flex;
  flex-direction: column;
  position: relative;
  transition: border-color 0.1s;
}
.product-card:hover { border-color: var(--gris-500); }

.product-img {
  width: 100%;
  aspect-ratio: 1;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: var(--gris-100);
}

.product-body {
  padding: 0.75rem 0.8rem 0.8rem;
  border-top: 1px solid var(--gris-200);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.product-title {
  font-size: 0.85rem;
  font-weight: 500;
  margin-bottom: 0.2rem;
  color: var(--gris-700);
  text-transform: uppercase;
  letter-spacing: 0.01em;
}

.product-meta {
  font-size: 0.75rem;
  color: var(--gris-500);
  margin-bottom: 0.4rem;
}

.product-price {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--gris-700);
  margin-bottom: 0.5rem;
}

.product-actions {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: auto;
}

.product-badge {
  position: absolute;
  top: 6px; left: 6px;
  padding: 2px 6px;
  background: var(--gris-100);
  border: 1px solid var(--gris-300);
  font-size: 0.6rem;
  font-weight: 500;
  color: var(--gris-500);
}

.btn-xs {
  padding: 0.3rem 0.8rem;
  font-size: 0.75rem;
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  background: var(--blanco);
  cursor: pointer;
  font-weight: 400;
  color: var(--gris-700);
  transition: background 0.1s, border-color 0.1s;
}
.btn-xs:hover { background: var(--gris-100); }

.btn-xs-primary {
  background: var(--gris-900);
  border-color: var(--gris-900);
  color: var(--blanco);
}
.btn-xs-primary:hover { background: var(--gris-700); }

/* ─── FEATURES (sin transformaciones) ────────────────────────────────── */
.features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.feature-card {
  background: var(--blanco);
  border-radius: 3px;
  padding: 1.5rem;
  border: 1px solid var(--gris-300);
  font-size: 0.9rem;
  transition: border-color 0.1s;
}
.feature-card:hover { border-color: var(--gris-500); }

.feature-icon { font-size: 1.5rem; margin-bottom: 0.8rem; }

.feature-title {
  font-weight: 500;
  margin-bottom: 0.3rem;
  color: var(--gris-700);
  font-size: 1rem;
}

/* ─── SERVICIOS ──────────────────────────────────────────────────────── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.service-card {
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  padding: 1.5rem;
  background: var(--blanco);
  transition: border-color 0.1s;
}
.service-card:hover { border-color: var(--gris-500); }

.service-title {
  font-weight: 500;
  margin-bottom: 0.3rem;
  color: var(--gris-700);
  font-size: 1rem;
}

/* ─── MARCAS (más sutiles) ───────────────────────────────────────────── */
.brands-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  align-items: center;
}

.brand-logo {
  width: 140px; height: 60px;
  background: var(--blanco);
  border: 1px solid var(--gris-300);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  padding: 0.5rem;
  transition: border-color 0.1s;
}
.brand-logo img {
  max-width: 100%; max-height: 100%; object-fit: contain;
  filter: grayscale(100%);
  opacity: 0.7;
  transition: filter 0.1s, opacity 0.1s;
}
.brand-logo:hover { border-color: var(--gris-500); }
.brand-logo:hover img { filter: grayscale(0%); opacity: 1; }

/* Brands featured (sección oscura home) — ahora no tan oscura */
.brands-featured {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}
.brand-featured-card {
  background: var(--gris-100);
  padding: 1.5rem;
  border-radius: 3px;
  text-align: center;
  border: 1px solid var(--gris-300);
}
.brand-featured-logo { margin-bottom: 1rem; }
.brand-tag { display: block; font-size: 0.75rem; color: var(--gris-500); margin-top: 4px; }

/* ─── CTA FINAL (sin gradientes) ─────────────────────────────────────── */
.cta-final {
  background: var(--gris-100);
  color: var(--gris-700);
  padding: 3rem 0;
}
.cta-final::before { display: none; }
.cta-final-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.5rem;
  align-items: center;
}
.cta-final-title { font-size: 1.8rem; margin-bottom: 0.3rem; color: var(--gris-900); }
.cta-final-text  { font-size: 1rem; color: var(--gris-500); max-width: 480px; }

.cta-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; }
.cta-badge {
  background: var(--blanco);
  border: 1px solid var(--gris-300);
  padding: 0.2rem 0.8rem;
  border-radius: 3px;
  font-size: 0.75rem;
  color: var(--gris-500);
}

/* ─── CONTACTO ───────────────────────────────────────────────────────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 2rem;
}

.contact-card {
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  padding: 1.5rem;
  background: var(--blanco);
  font-size: 0.9rem;
}
.contact-card h3 { margin-bottom: 0.8rem; color: var(--gris-700); font-size: 1rem; }
.contact-row { margin-bottom: 0.6rem; color: var(--gris-500); }
.whatsapp-link { color: var(--accento); font-weight: 500; }

.map-placeholder {
  width: 100%; height: 260px;
  background: var(--gris-100);
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gris-500);
  font-size: 0.9rem;
}

.field-label {
  display: block;
  font-size: 0.85rem;
  margin-bottom: 0.2rem;
  color: var(--gris-500);
  font-weight: 400;
}

.field-input,
.field-textarea {
  width: 100%;
  padding: 0.5rem 0.8rem;
  border-radius: 3px;
  border: 1px solid var(--gris-300);
  font-size: 0.9rem;
  outline: none;
  background: var(--blanco);
  color: var(--gris-900);
  transition: border-color 0.1s;
}
.field-textarea { resize: vertical; min-height: 120px; }
.field-input:focus,
.field-textarea:focus {
  border-color: var(--gris-500);
  box-shadow: none;
}

/* ─── FOOTER ─────────────────────────────────────────────────────────── */
footer {
  background: var(--gris-900);
  color: var(--gris-300);
  padding: 0;
  font-size: 0.85rem;
  border-top: none;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 2rem;
  margin-bottom: 2rem;
}

.footer-title {
  font-weight: 400;
  margin-bottom: 0.8rem;
  color: var(--blanco);
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.footer-links { list-style: none; }
.footer-links li { margin-bottom: 0.3rem; }
.footer-links a { color: var(--gris-300); transition: color 0.1s; }
.footer-links a:hover { color: var(--blanco); }

.footer-bottom {
  border-top: 1px solid var(--gris-500);
  padding-top: 1rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  color: var(--gris-500);
  font-size: 0.8rem;
  padding-bottom: 20px;
}
.footer-bottom a { color: var(--gris-500); transition: color 0.1s; }
.footer-bottom a:hover { color: var(--gris-300); }

/* ─── FLOATING BUTTONS (menos llamativos) ────────────────────────────── */
.floating-buttons {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  z-index: 150;
}

.floating-btn {
  width: 44px; height: 44px;
  border-radius: 4px;
  border: 1px solid var(--gris-300);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--blanco);
  color: var(--gris-700);
  box-shadow: var(--shadow-sm);
  transition: background 0.1s, border-color 0.1s;
}
.floating-btn:hover { background: var(--gris-100); border-color: var(--gris-500); }

.whatsapp-btn { background: var(--blanco); color: var(--gris-700); }
.to-top-btn { display: flex; }
.to-top-btn--visible { opacity: 1; }

/* ─── PAGINACIÓN ─────────────────────────────────────────────────────── */
.pagination { margin-top: 2rem; display: flex; justify-content: center; gap: 0.5rem; }
.pagination span { color: var(--gris-500); align-self: center; font-size: 0.85rem; }

/* ─── BREADCRUMBS ────────────────────────────────────────────────────── */
.breadcrumb-wrapper {
  background: var(--gris-100);
  border-bottom: 1px solid var(--gris-300);
  font-size: 0.85rem;
}
.breadcrumb {
  list-style: none; display: flex;
  padding: 0.7rem 0; color: var(--gris-500);
  flex-wrap: wrap; gap: 0.3rem;
}
.breadcrumb li:not(:last-child)::after { content: "/"; margin: 0 6px; color: var(--gris-300); }
.breadcrumb a { color: var(--gris-700); transition: color 0.1s; }
.breadcrumb a:hover { color: var(--gris-900); }
.breadcrumb .active { color: var(--gris-500); }
.breadcrumb-current { color: var(--accento); font-weight: 500; }

/* ─── CATEGORY PAGE (más sobrio) ─────────────────────────────────────── */
#category-hero {
  background-size: cover;
  background-position: center 30%;
  position: relative;
  padding: 3rem 0;
  color: var(--gris-900);
  text-align: center;
}
#category-hero::before { display: none; }
#category-hero h1 {
  font-size: 2.2rem; color: var(--gris-900);
  margin-bottom: 0.5rem;
}
.category-hero-inner .breadcrumb { justify-content: center; font-size: 0.9rem; }
.category-hero-inner .breadcrumb li,
.category-hero-inner .breadcrumb li:not(:last-child)::after { color: var(--gris-500); }
.category-hero-inner .breadcrumb a { color: var(--accento); }

.category-content-grid { padding-top: 2rem; padding-bottom: 4rem; }
.category-grid-inner {
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: 2rem;
}

.category-sidebar {
  padding: 1.5rem;
  border: 1px solid var(--gris-300);
  border-radius: 3px;
  background: var(--blanco);
  height: fit-content;
  position: sticky;
  top: 1rem;
}
.category-sidebar h2 { font-size: 1rem; margin-bottom: 1rem; color: var(--gris-700); font-weight: 500; }

.filter-group { margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--gris-200); }
.filter-title { font-size: 0.8rem; font-weight: 500; color: var(--gris-500); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.5rem; }
.filter-list { list-style: none; }
.filter-list li a { display: block; font-size: 0.9rem; padding: 0.2rem 0; color: var(--gris-500); transition: color 0.1s; }
.filter-list li a:hover,
.filter-list li a.active { color: var(--gris-700); font-weight: 500; }

.category-grid-products {
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
}

.no-results-message {
  padding: 2.5rem;
  text-align: center;
  border: 1px dashed var(--gris-300);
  border-radius: 3px;
  margin-top: 2rem;
  color: var(--gris-500);
}

/* ─── MEGA MENÚ (simplificado, sin hover effect) ─────────────────────── */
.nav-menu > li { position: relative; }

.mega-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 600px;
  background-color: var(--blanco);
  border: 1px solid var(--gris-300);
  box-shadow: var(--shadow-sm);
  z-index: 1000;
  padding: 1.5rem;
  border-top: 2px solid var(--gris-700);
}
.nav-menu > li.has-mega-menu:hover > .mega-menu { display: flex; }

.mega-menu-content { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }

.mega-menu-product {
  text-decoration: none; color: var(--gris-700);
  display: block;
  border-radius: 3px;
  overflow: hidden;
  transition: background 0.1s;
}
.mega-menu-product:hover { background: var(--gris-100); }
.mega-menu-product img { width: 100%; height: 100px; object-fit: cover; }
.mega-menu-product-title { font-size: 0.8rem; font-weight: 400; padding: 0.5rem 0.3rem; }

/* ─── LINEAS / BANNERS (sin transformaciones) ────────────────────────── */
.secciones-lineas { padding: 4rem 0; background: var(--blanco); }

.lineas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.5rem;
}

.linea-banner {
  height: 260px;
  border-radius: 3px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: flex-end;
  text-decoration: none;
  overflow: hidden;
  border: 1px solid var(--gris-300);
  transition: border-color 0.1s;
}
.linea-banner:hover { border-color: var(--gris-500); }

.linea-info {
  padding: 1.5rem;
  width: 100%;
  background: var(--blanco);
  color: var(--gris-700);
  border-top: 1px solid var(--gris-300);
}
.btn-linea {
  font-size: 0.75rem;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--accento);
  letter-spacing: 0.05em;
}

/* ─── SPECS / TAGS ───────────────────────────────────────────────────── */
.product-specs { display: flex; gap: 0.5rem; margin-top: 0.5rem; flex-wrap: wrap; }
.spec-tag {
  background: var(--gris-100);
  border: 1px solid var(--gris-300);
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.7rem;
  color: var(--gris-500);
}

/* ─── LINKS ÚTILES ───────────────────────────────────────────────────── */
.btn-link {
  color: var(--accento);
  font-weight: 500;
  transition: color 0.1s;
}
.btn-link:hover { color: var(--accento-hover); text-decoration: underline; }

/* ─── GRACIAS / THANKS ───────────────────────────────────────────────── */
.thanks-section { padding: 5rem 0; }
.thanks-inner {
  min-height: 50vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center;
}
.thanks-title { font-size: 2.2rem; margin-bottom: 0.5rem; color: var(--gris-900); }
.thanks-text { font-size: 1rem; max-width: 540px; margin: 0 auto 2rem; color: var(--gris-500); }
.thanks-actions { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }

/* ─── HERO SLIDER (simplificado) ─────────────────────────────────────── */
.hero-slider-container { position: relative; overflow: hidden; height: 500px; }
.hero-slider-wrapper   { position: relative; height: 100%; }
.hero-slide            { position: absolute; inset: 0; opacity: 0; transition: opacity 0.5s; }
.hero-slide.active     { opacity: 1; z-index: 10; }
.hero-slider-container .hero { height: 100%; display: flex; align-items: center; }

.slider-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 20;
  background: var(--blanco);
  color: var(--gris-700);
  border: 1px solid var(--gris-300);
  padding: 0.6rem 1rem;
  cursor: pointer;
  border-radius: 3px;
  transition: background 0.1s;
}
.slider-arrow.next { right: 20px; }
.slider-arrow.prev { left: 20px; }
.slider-arrow:hover { background: var(--gris-100); }

/* ─── MISC ───────────────────────────────────────────────────────────── */
.product-card { position: relative; }

/* Focus accesible */
.nav-menu a:focus-visible,
.nav-cta:focus-visible,
.header-search-input:focus-visible,
.btn:focus-visible,
.btn-xs:focus-visible {
  outline: 2px solid var(--accento);
  outline-offset: 2px;
}

/* ─── RESPONSIVE (ajustes mínimos) ───────────────────────────────────── */

@media (max-width: 1024px) {
  .hero-inner          { grid-template-columns: 1fr; }
  .hero                { padding: 3rem 0; }
  .hero-title          { font-size: 2rem; }
  .categories-grid,
  .products-grid,
  .features            { grid-template-columns: repeat(2, 1fr); }
  .services-grid       { grid-template-columns: repeat(2, 1fr); }
  .footer-grid         { grid-template-columns: 1.8fr 1.2fr 1.2fr; }
  .carousel-track .product-card { flex: 0 0 calc(33.333% - 1rem); }
  .trust-strip-inner   { grid-template-columns: repeat(2, 1fr); }
  .trust-pill          { border-right: none; border-bottom: 1px solid var(--gris-300); }
}

@media (max-width: 900px) {
  .nav    { align-items: center; flex-wrap: wrap; }
  nav     { order: 3; width: 100%; }
  .nav-right { order: 2; margin-left: auto; }
  .header-search { max-width: 260px; }
  .nav-toggle { order: 2; display: flex; }

  .nav-menu {
    position: absolute;
    left: 1.5rem; right: 1.5rem;
    top: 100%;
    margin-top: 0.5rem;
    background: var(--blanco);
    border-radius: 3px;
    border: 1px solid var(--gris-300);
    box-shadow: var(--shadow-sm);
    padding: 0.8rem 1rem;
    flex-direction: column;
    gap: 0.3rem;
    display: none;
  }
  .nav-menu.nav-menu--open { display: flex; }
  .nav-menu li a { display: block; padding: 0.3rem 0; }

  .carousel-track .product-card { flex: 0 0 calc(50% - 0.75rem); }
  .carousel-arrow--prev { left: 0.2rem; }
  .carousel-arrow--next { right: 0.2rem; }

  .mega-menu         { position: static; width: 100%; border: none; box-shadow: none; padding: 0.5rem 0; border-top: none; display: none; }
  .nav-menu--open .mega-menu { display: block; }
  .mega-menu-content { grid-template-columns: repeat(2, 1fr); }
  .nav-menu > li.has-mega-menu:hover > .mega-menu { display: none; }

  .contact-grid      { grid-template-columns: 1fr; }
  .brands-featured   { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .top-bar-inner        { flex-direction: column; align-items: flex-start; gap: 0.2rem; }
  .logo-text            { font-size: 0.85rem; }
  .nav                  { gap: 0.5rem; }
  .nav-right            { width: 100%; justify-content: flex-start; gap: 0.5rem; }
  .header-search        { flex: 1; max-width: 100%; }
  .nav-cta              { padding: 0.4rem 0.8rem; font-size: 0.8rem; }
  .hero                 { padding-top: 2.5rem; }
  .hero-title           { font-size: 1.6rem; }
  .hero-text            { font-size: 0.9rem; }
  .categories-grid,
  .products-grid,
  .features,
  .services-grid        { grid-template-columns: 1fr; }
  .footer-grid          { grid-template-columns: 1fr; }
  section               { padding: 2.5rem 0; }
  .section-title        { font-size: 1.5rem; }
  .section-subtitle     { font-size: 0.9rem; }
  .floating-buttons     { right: 1rem; bottom: 1rem; }
  .carousel-track .product-card { flex: 0 0 100%; }
  .carousel-arrow       { display: none; }
  .trust-strip-inner    { grid-template-columns: 1fr; }
  .mega-menu-content    { grid-template-columns: 1fr; }
  .linea-banner         { height: 200px; }
  .hero-slider-wrapper  { min-height: 400px; }
}

@media (max-width: 1200px) {
  .mega-menu { width: min(750px, calc(100vw - 2rem)); left: 0; }
}

@media (min-width: 901px) {
  .nav-toggle { display: none; }
}

.cto-d-ico i {
  font-size: 1.1rem; /* Ajusta según prefieras */
  width: 1.2rem;
  text-align: center;
  color: #1b1e22;
}

.bg-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}

.hs-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.35); /* ajusta intensidad */
}

/* MIDBANNER — FIX COMPOSICIÓN */
.midbanner-in { padding: 1.8rem 0; }              /* menos alto */
.midbanner-in .container{
  display:flex;
  align-items:center;
  justify-content:flex-start;                      /* ya no “space-between” */
  gap: 2rem;                                       /* separación controlada */
}

.midbanner-txt{ max-width: 620px; }               /* ancho del texto */
.midbanner-txt h2{ margin:0 0 .35rem; }
.midbanner-txt p{ margin:0; max-width: 520px; }

.midbanner-btn{
  margin-left:auto;                               /* empuja el botón, pero sin exagerar */
  min-width: 280px;
  text-align:center;
}

/* RESPONSIVE */
@media (max-width: 900px){
  .midbanner-in .container{
    flex-direction:column;
    align-items:flex-start;
  }
  .midbanner-btn{
    margin-left:0;
    width:100%;
    max-width: 420px;
  }
}

.brands-sec{
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 1.2rem;     /* baja un poco la marca */
  margin-top: 0;           /* evita “saltos” raros */
}
.brands-lbl{ margin-top: .4rem; }

.midbanner{ overflow:hidden; }
.midbanner-bg{ will-change: transform; transform: translate3d(0,0,0); }

.hs-ov {
    position:absolute;
    inset:0;
    background: linear-gradient(
        90deg,
        rgba(0,0,0,0.25) 0%,
        rgba(0,0,0,0.25) 45%,
        rgba(0,0,0,0.2) 100%
    );
    z-index:2;
}

.hs-ci-ico {
  width: 36px;
  height: 36px;
  background: #A0693A;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-size: 14px;
  color: #fff;
  transition: all .2s ease;
}

.hs-ci:hover .hs-ci-ico {
  background: #C48858;
  transform: translateY(-2px);
}

.hs-ci {
  gap: .9rem;
}

/* ===========================
   PRODUCTOS DESTACADOS (PG4)
   =========================== */

.prod-sec{
  padding: 3rem 0;
}

.sec-hdr{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
  margin-bottom: 1.25rem;
}

.sec-hdr h2{
  font-size: 1.2rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gris-900);
}

.sec-hdr a{
  font-size:.85rem;
  border:1px solid rgba(0,0,0,.18);
  padding:.45rem .75rem;
  border-radius:6px;
  background:#fff;
}
.sec-hdr a:hover{ border-color: rgba(0,0,0,.35); }

/* Grid */
.pg4{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

@media (max-width: 1100px){ .pg4{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 576px){ .pg4{ grid-template-columns: 1fr; } }

/* Card */
.pi{
  position:relative;
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:14px;
  overflow:hidden;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.pi:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
  border-color: rgba(0,0,0,.18);
}

/* Badge más fino */
.pi-badge{
  position:absolute;
  top:10px;
  left:10px;
  padding: 6px 8px;
  border-radius: 8px;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color:#fff;
  box-shadow: 0 6px 14px rgba(0,0,0,.18);
  z-index:2;
}

/* Imagen: caja consistente */
.pi-img{
  height: 220px;                 /* clave: todas iguales */
  background-color: #fbfbfb;     /* limpia el “blanco feo” */
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;      /* importante para productos */
  border-bottom: 1px solid rgba(0,0,0,.08);
}

/* Cuerpo */
.pi-body{
  padding: 12px 12px 14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* Nombre: 2 líneas máximo */
.pi-name{
  font-size: .85rem;
  font-weight: 600;
  color: #1f1f1f;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(1.25em * 2);
}

/* CTA: más elegante tipo “botón suave” */
.pi-cta{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  width: 100%;
  padding: .55rem .8rem;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.14);
  background: #fff;
  color: #1f1f1f;
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
  transition: background .15s ease, border-color .15s ease;
}

.pi:hover .pi-cta{
  background: #1e1e1e;
  color:#fff;
  border-color:#1e1e1e;
}

.pi-img-wrap{ height:220px; background:#fbfbfb; display:flex; align-items:center; justify-content:center; border-bottom:1px solid rgba(0,0,0,.08); }
.pi-img-wrap img{ max-height: 190px; max-width: 90%; object-fit: contain; }


span.cat-breadcrumb-current {
    color: white !important;
}

.cat-banner-eyebrow{
  color:white !important;
}

.top-bar {
    background: #000 !important;
     border-bottom: none !important;
}

header#siteHeader {
    border-bottom: none !important;
}

.to-top-btn {
  width: 42px;
  height: 42px;
  border-radius: 8px;          /* cuadrado con esquinas suaves */
  background: #fff;
  border: 1px solid #D8DCDE;
  color: #4A5C66;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: opacity .3s, transform .2s, box-shadow .2s;
  
  /* Centrado en pantalla */
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 999;
}

.cat-hero-overlay {
    position: absolute !important;
    inset: 0;
    background: linear-gradient(90deg, rgba(26, 29, 32, .90) 0%, rgba(26, 29, 32, .55) 55%, rgba(26, 29, 32, .30) 100%) !important;
}

.det-main-img {
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #D8DCDE;
    background: #ffffff !important;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: .5rem;
    cursor: zoom-in;
}

.det-thumb {
    width: 70px;
    height: 70px;
    border-radius: 8px;
    border: 2px solid #D8DCDE;
    background: #ECEEF0;
    overflow: hidden;
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
    transition: border-color .15s, box-shadow .15s;
}