/* =========================
   custom.css – Menú estilo JNH (solo primer nivel)
   ========================= */


/* H4 global: mayúsculas, tracking y tamaño */
h4,
.h4 {
  text-transform: uppercase !important;   /* todo en mayúsculas */
  letter-spacing: 0.1em !important;      /* “tracking” (ajustá a gusto) */
  font-size: clamp(16px, 1.4vw, 22px) !important; /* tamaño fluido */
  line-height: 1.2 !important;            /* altura de línea prolija */
}

/* Si algún módulo del theme pisa h4 adentro */
section h4,
section .h4 {
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-size: clamp(16px, 1.4vw, 22px) !important;
  line-height: 1.2 !important;
}



/* 8. Tipografías: Minion en títulos */

/* 8.1) Variable con la familia del kit */
:root{
  --ff-minion: "minion-pro", serif;
}

/* 8.2) Aplicar Minion a H1/H2 y utilitarias */
h1, h2,
.h1, .h2{
  font-family: var(--ff-minion) !important;
  font-feature-settings: "liga" 1, "kern" 1;
}

/* 8.3) Aplicar también a los H3 del banner */
h3.js-banner-title.h1-huge.h3-md,
.js-banner-title.h1-huge.h3-md{
  font-family: var(--ff-minion) !important;
  font-feature-settings: "liga" 1, "kern" 1;
}

/* 8.4) Pesos base (kit trae n4=400 y n5=500) */
h1, .h1 { font-weight: 500; }
h3.js-banner-title.h1-huge.h3-md,
.js-banner-title.h1-huge.h3-md { font-weight: 400; }

/* 8.5) H2 como H3: mismo peso + tracking
   - Re-definimos variables SOLO para h2 para ganar a las reglas del theme */
h2, .h2{
  --heading-font: var(--ff-minion);
  --title-font-weight: 500;
  font-family: var(--heading-font) !important;   /* por si el theme re-aplica */
  font-weight: var(--title-font-weight) !important;
  letter-spacing: 0.2em !important;             /* “mucho” tracking */
  font-synthesis: none;                           /* evita faux bold */
}

/* 8.6) Ajuste fino extra */
.h1, h1,
h3.js-banner-title.h1-huge.h3-md{ letter-spacing: .01em; }


/* 1. Espacio extra entre cada ítem */
.nav-desktop-list {
  display: flex;
  justify-content: center;
  gap: 47px !important;   /* ajustá el valor a tu gusto */
}

/* 2. Estilos base de los enlaces de PRIMER NIVEL */
.nav-desktop-list > li > a.nav-list-link,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link {
  text-transform: uppercase !important;
  font-size: 14px !important;
  font-weight: 300 !important;
  color: #1a1a1a !important;
  letter-spacing: 1.2px !important;
  position: relative;
  padding: 8px 0;
  transition: color 0.3s ease;
}

/* 3. Hover: solo cambio de color */
.nav-desktop-list > li > a.nav-list-link:hover,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link:hover {
  color: #7a7a7a !important;
}

/* 4. Pseudo-elemento: SOLO línea fina inferior en PRIMER NIVEL */

/* 4.1) Asegurar posicionamiento relativo del link */
.nav-desktop-list > li > a.nav-list-link,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link {
  position: relative;
}

/* 4.2) Línea fina inferior (inicialmente oculta) */
.nav-desktop-list > li > a.nav-list-link::after,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -4px;                 /* solo abajo */
  width: 0;
  height: 1px !important;       /* línea delgada */
  background-color: #000;
  transform: translateX(-50%);
  transition: width 0.3s ease, background-color 0.2s ease;
}

/* 4.3) Desactivar la línea superior */
.nav-desktop-list > li > a.nav-list-link::before,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link::before {
  content: none !important;
}

/* 5. Hover: expandir línea inferior en PRIMER NIVEL */
.nav-desktop-list > li > a.nav-list-link:hover::after,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link:hover::after {
  width: 100% !important;
}

/* 6. Estado activo: mantener la línea y color de acento en PRIMER NIVEL */
.nav-desktop-list > li > a.nav-list-link.selected::after,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link.selected::after {
  width: 100% !important;
  background-color: #ab7438 !important;  /* color de acento */
}

/* 6.1) Accesibilidad: mostrar al enfocar con teclado */
.nav-desktop-list > li > a.nav-list-link:focus-visible::after,
.nav-desktop-list > li > div.nav-item-container > a.nav-list-link:focus-visible::after {
  width: 100% !important;
}


/* 7. RESET para sub‑ítems: que no hereden estos estilos */
ul.desktop-list-subitems a.nav-list-link {
  text-transform: none !important;
  font-size: inherit    !important;
  font-weight: normal   !important;
  letter-spacing: normal!important;
  color: inherit        !important;
  padding: 0 !important;
}

ul.desktop-list-subitems a.nav-list-link::before,
ul.desktop-list-subitems a.nav-list-link::after {
  display: none !important;
}

/* tamaño y separación de bullets del banner */
.swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin: 0 6px !important;
  background: #ccc;
  opacity: 1;
  transition: background 0.3s;
}

/* color activo */
.swiper-pagination-bullet-active {
  background: #ab7438;  /* tu color de acento */
}

/* Borrar 1/2 en swiper de categorías del home */
.js-swiper-banners-pagination.swiper-pagination.swiper-pagination-fraction {
  display: none !important;
}


/* 1) La card es columna y ocupa todo el alto del “col” */
.js-item-product {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
}

/* 2) La parte de descripción crece y empuja el final */
.js-item-product > .item-description {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
}

/* 3) El botón como HERMANO de .item-description: al fondo */
.js-item-product > .item-actions {
  margin-top: auto !important;
  display: flex !important;
  justify-content: center !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* 4) NORMALIZAR ALTOS: que el título siempre “valga” 2 líneas */
.js-item-product .item-description .js-item-name {
  line-height: 1.3em !important;
  -webkit-line-clamp: 2 !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  /* CLAVE: mismo alto para todas las cards */
  max-height: 2.6em !important;  /* 2 líneas */
  min-height: 2.6em !important;  /* reserva cuando hay 1 línea */

  margin-bottom: .5rem !important;
}

/* 5) NORMALIZAR el bloque de precio (1 línea de alto mínimo) */
.js-item-product .item-description .item-price-container {
  line-height: 1.2em !important;
  min-height: 1.2em !important;  /* asegura slot fijo */
  margin-bottom: .75rem !important;
}

/* 6) Quitar pozos inferiores accidentales */
.js-item-product,
.js-item-product .item-description,
.js-item-product .item-actions {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

.js-item-product .item-actions {
  margin-top: .5rem !important; /* leve separación del precio */
  padding-top: 0 !important;
}

/* 4) Ocultar el SVG del carrito */
.item-actions .js-quickshop-bag,
.item-actions .js-item-submit-container svg {
  display: none !important;
}

/* 5) Estilo del botón “Agregar al carrito” */
.item-actions .js-item-submit-container > input.js-addtocart {
  all: unset !important;
  display: inline-flex !important;
  align-items: center !important;
  font: inherit !important;
  color: var(--button-foreground) !important;
  background-color: var(--button-background) !important;
  padding: 0.5em 1em !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  transition: filter 0.2s ease, background-color 0.2s ease !important;
}

/* 6) Hover botón AGREGAR AL CARRITO */
.item-actions .js-item-submit-container > input.js-addtocart:hover {
  filter: brightness(0.9) !important;
  background-color: #a85e47 !important;
}

/* 7) Tipografía del precio */
.js-item-product .item-description .item-price-container,
.js-item-product .item-description .js-item-price,
.js-item-product .item-description .price {
  font-size: 17px !important;
  line-height: 1.2em !important;
  margin-top: 2em !important;
  font-weight: 600;
  letter-spacing: 0.1em;
}

/* 8) Tipografía del título */
.js-item-product .item-description .js-item-name {
  font-size: 15px !important;
  color: #000000 !important;
  line-height: 1.3em !important;
  max-height: 2.6em !important;
  letter-spacing: 0.05em !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  text-transform: uppercase !important;
}

/* Transición suave para título y precio */
.js-item-product .item-description .js-item-name,
.js-item-product .item-description .item-price-container {
  transition: opacity 0.2s ease, transform 0.2s ease !important;
}

/* Hover muy sutil: bajar opacidad y elevar ligeramente */
.js-item-product .item-description .js-item-name:hover,
.js-item-product .item-description .item-price-container:hover {
  opacity: 0.85 !important;
  transform: translateY(-2px) !important;
}

/* 1) Separar verticalmente las cards */
.col-grid {
  margin-bottom: 1.5rem !important;
}

/* 2) Reducir espacio entre título y precio */
.js-item-product .item-description .js-item-name {
  margin-bottom: 0.5rem !important;
}

/* 3) Reducir espacio entre precio y botón */
.js-item-product .item-description .item-price-container {
  margin-bottom: 1rem !important;
}

/* Elevar el botón unos pixeles sin romper el flex auto */
.js-item-product > .item-actions {
  transform: translateY(-26px) !important;
}

.js-swiper-banners-mobile-pagination { display: none !important; }


/* Barra superior: más peso tipográfico */
.swiper-slide.slide-container {
  font-weight: 700 !important; 
  letter-spacing: .07em !important; 
}

/* Quickshop estilado como botón real (full width, padding, fondo) */
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open {
  display: flex !important;              /* NO inline-flex */
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 1em 1em !important;
  border: none !important;
  text-decoration: none !important;
  cursor: pointer !important;
  font: inherit !important;
  background-color:#000000 !important;
  color: var(--button-foreground, #ffffff) !important;
  transition: filter .2s ease, background-color .2s ease !important;
}

/* Hover unificado (por si el hover cae en el <a>) */
.js-item-product .item-description a.item-link:hover .item-actions .js-quickshop-modal-open,
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open:hover {
  filter: brightness(0.9) !important;
  background-color: #a85e47 !important;
}

/* Ocultar el ícono del bolso con especificidad alta */
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open .js-open-quickshop-icon {
  display: none !important;
}

/* ---------- Ajustes globales (tuneables) ---------- */
:root{
  --gs-btn-font-size: 12px;   /* tipografía del botón */
  --gs-btn-font-weight: 300;  /* 400/500/600 según gusto */
  --gs-btn-height: 30px;      /* alto visual buscado */
  --gs-btn-px: 12px;          /* padding horizontal */
  --gs-btn-bg: var(--button-background, #000000);
  --gs-btn-fg: var(--button-foreground, #ffffff);
}

/* Unificamos botón nativo y trigger de quickshop */
.js-item-product .item-actions .js-quickshop-modal-open,
.js-item-product .item-actions .js-item-submit-container input.js-addtocart,
.js-item-product .item-actions .js-item-submit-container button {
  /* Layout y caja */
  display: flex !important;                 /* full-width real */
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  letter-spacing: 0.08em !important;
  min-height: var(--gs-btn-height) !important;
  box-sizing: border-box !important;
  padding: 1m 1em !important;            /* base para fallback */
  padding-left: var(--gs-btn-px) !important;
  padding-right: var(--gs-btn-px) !important;

  /* Tipografía */
  font: inherit !important;
  font-size: var(--gs-btn-font-size) !important;
  font-weight: var(--gs-btn-font-weight) !important;
  line-height: 1 !important;
  text-align: center !important;
  text-decoration: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;

  /* Apariencia */
  -webkit-appearance: none !important;
  appearance: none !important;
  border: none !important;
  box-shadow: none !important;
  background-color: var(--gs-btn-bg) !important;
  color: var(--gs-btn-fg) !important;
  cursor: pointer !important;
  transition: filter .2s ease, background-color .2s ease !important;
}

/* Hover idéntico en ambos casos (y también si el hover cae en el <a>) */
.js-item-product .item-description a.item-link:hover .item-actions .js-quickshop-modal-open,
.js-item-product .item-actions .js-quickshop-modal-open:hover,
.js-item-product .item-actions .js-item-submit-container input.js-addtocart:hover,
.js-item-product .item-actions .js-item-submit-container button:hover {
  filter: brightness(0.9) !important;
  background-color: #a85e47 !important;
}

/* Ocultar iconito del quickshop para que quede “botón botón” */
.js-item-product .item-actions .js-quickshop-modal-open .js-open-quickshop-icon {
  display: none !important;
}

/* Por si el tema le deja clase de link/botón que ensucia */
.js-item-product .item-actions .js-quickshop-modal-open.btn,
.js-item-product .item-actions .js-quickshop-modal-open.btn-link {
  text-decoration: none !important;
  box-shadow: none !important;
}

/* Igualar tipografía del quickshop al botón "normal" */
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open,
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open .js-open-quickshop-wording {
  font-family: inherit !important;
  font-size: var(--gs-btn-font-size) !important;
  font-weight: var(--gs-btn-font-weight) !important;
  line-height: 1 !important;
}

/* Por si el tema vuelve a inyectar estilos de link/botón en el trigger */
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open.btn,
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open.btn-link {
  text-decoration: none !important;
  box-shadow: none !important;
}

/* Ocultar el ícono con más especificidad (por si reaparece) */
.js-item-product .item-description a.item-link .item-actions .js-quickshop-modal-open .js-open-quickshop-icon {
  display: none !important;
}

/* BUSCADOR */

/* Desktop */
@media (min-width: 768px) {
  /* 1) Input en formato píldora */
  .js-search-form .search-input {
    height: 44px !important;
    border-radius: 999px !important;
    border: 1px solid var(--main-foreground-opacity-20) !important;
    background: #fff !important;
    padding: 0 44px 0 14px !important; /* lugar para la lupa a la derecha */
    color: var(--main-foreground) !important;
    font-size: 14px !important;        /* tamaño del texto “Buscar” */
    font-weight: 500 !important;
    transition: border-color .2s, box-shadow .2s !important;
  }
  .js-search-form .search-input::placeholder {
    color: var(--main-foreground-opacity-40) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    opacity: 1 !important;
  }

  /* 2) Color al seleccionar (focus) */
  .js-search-form .search-input:focus {
    outline: none !important;
    border-color: var(--accent-color) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-color) 24%, transparent) !important;
  }

  /* 3) Lupa dentro del buscador (a la derecha) */
  .js-search-form .form-group {
    position: relative !important;
  }
  .js-search-form .form-group::after {
    content: "" !important;
    position: absolute !important;
    right: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 18px !important;
    height: 18px !important;
    background-image: var(--icon-search) !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 18px 18px !important;
    opacity: .6 !important;            /* misma “intensidad” que el placeholder */
    pointer-events: none !important;
  }

  /* 4) El botón submit queda transparente y encima (sin su propio ícono) */
  .js-search-form .search-submit-btn {
    position: absolute !important;
    right: 0 !important;
    top: 0 !important;
    width: 44px !important;
    height: 44px !important;
    border: 0 !important;
    background: transparent !important;
    padding: 0 !important;
    cursor: pointer !important;
    z-index: 2 !important;
  }
  .js-search-form .search-submit-btn::before,
  .js-search-form .search-submit-btn::after,
  .js-search-form .search-submit-btn svg {
    display: none !important;
    content: none !important;
    background: none !important;
  }
}


/* NEWSLETTER HOME */

/* INPUT newsletter: pill + texto negro */
.js-newsletter-home .js-newsletter input.form-control {
  height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid var(--main-foreground-opacity-20) !important;
  background: #fff !important;
  padding: 0 14px !important;
  color: #000 !important;              /* texto negro */
  /* sin cambios de font-size / weight */
}

/* Placeholder bien visible */
.js-newsletter-home .js-newsletter input.form-control::placeholder {
  color: #666 !important;              /* gris oscuro sobre fondo blanco */
  opacity: 1 !important;
}

/* Glow más chico pero más “chillón” en foco */
.js-newsletter-home .js-newsletter input.form-control:focus {
  outline: none !important;
  border-color: var(--accent-color) !important;
  /* glow reducido (4px) y más intenso (60% del accent) */
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent-color) 60%, transparent) !important;
}

/* Fila del input + botón en una línea */
.js-newsletter-home .newsletter .input-append {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

/* El contenedor del input ocupa todo el ancho disponible */
.js-newsletter-home .newsletter .form-group {
  flex: 1 1 auto !important;
  margin: 0 !important;
}

/* Botón “Enviar” visible y con pill (izquierda recta) */
.js-newsletter-home .newsletter .newsletter-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 44px !important;
  padding: 0 16px !important;
  border: 0 !important;
  background: var(--accent-color) !important;
  color: #fff !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  cursor: pointer !important;

  /* borde izquierdo recto, derecho redondeado */
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-top-right-radius: 999px !important;
  border-bottom-right-radius: 999px !important;
}


/* Hover suave */
.js-newsletter-home .newsletter .newsletter-btn:hover {
  filter: brightness(0.9) !important;
}


/* Evitar que “Agregar al carrito” parta en 2 líneas */
.item-actions .js-item-submit-container > input.js-addtocart,
.item-actions .js-quickshop-modal-open.btn-link {
  white-space: nowrap !important;
}

/* Tamaño fluido para móviles (baja levemente en pantallas chicas) */
.item-actions .js-item-submit-container > input.js-addtocart,
.item-actions .js-quickshop-modal-open.btn-link {
  font-size: clamp(13px, 3.6vw, 16px) !important;
  padding: .55em 1em !important; /* un pelín menos ayuda a que no corte */
}

/* Badge "Envío gratis" */
.js-shipping-label-private,
.js-shipping-label {
  background-color: #747A63 !important;
  border-color: #747A63 !important;
  color: #fff !important; /* para buen contraste */
}

/* Línea fina arriba y abajo del bloque institucional */
.section-institutional-home .col-md-8{
  border-top: 1px solid var(--decero-brown, #ab7438);
  border-bottom: 1px solid var(--decero-brown, #ab7438);
  padding: 20px 0;   /* aire interno para que no “pegue” */
  margin: 24px auto; /* separarlo de lo de arriba/abajo */
}

/* líneas más sutiles */
.section-institutional-home .col-md-8{
  border-color: #ab7438;
}

:root{
  --decero-brown: #ab7438;
}

/* Envío gratis en producto destacado home */
.js-free-shipping-minimum-message > .text-accent {
  font-size: 16px !important;   
  font-weight: 600 !important;
  line-height: 1.2 !important;
}

/* Banner categorías a 100vw */
.category-banner {
  position: relative !important;
  left: 50% !important;
  right: 50% !important;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  width: 100vw !important;
}

.category-banner .category-banner-image{
  display: block !important;
  width: 100vw !important;
  height: auto !important;
  max-width: none !important;
}

/* Menú mobile (limpio y consistente) */

/* 1) Footer del menú (hamburger): fondo #ab7438 + tipografía blanca */
.modal-nav-hamburger .hamburger-footer{
  background:#ab7438 !important;
  color:#fff !important;
}
.modal-nav-hamburger .hamburger-footer a{ color:#fff !important; }
.modal-nav-hamburger .hamburger-footer svg{ fill:#fff !important; }

/* 2) "Ver todos los productos" en verde */
.modal-nav-hamburger .list-subitems .nav-item.py-1 .nav-list-link{
  color:#4f6b01 !important;
}

/* 3) Header de cada submenú: fondo #ab7438 + tipografía blanca */
.modal-nav-hamburger .list-subitems .modal-header{
  background:#ab7438 !important;
  color:#fff !important;
  border-bottom:0 !important; /* evitamos línea adicional */
}
.modal-nav-hamburger .list-subitems .modal-header a{ color:#fff !important; }
.modal-nav-hamburger .list-subitems .modal-header svg{ fill:#fff !important; }
.modal-nav-hamburger .list-subitems .modal-header .modal-back{
  background:transparent !important;
}

/* 4) Divisores UNIFORMES dibujados en el <a>, no en el <li> */

/* 4a. Reset total de bordes / pseudo-líneas previas (evita líneas dobles) */
.modal-nav-hamburger .nav-primary .nav-item,
.modal-nav-hamburger .nav-primary .list-subitems .nav-item{
  border:0 !important;
}
.modal-nav-hamburger .nav-primary .nav-item::before,
.modal-nav-hamburger .nav-primary .nav-item::after,
.modal-nav-hamburger .nav-primary .list-subitems .nav-item::before,
.modal-nav-hamburger .nav-primary .list-subitems .nav-item::after,
.modal-nav-hamburger .nav-primary .nav-item > .nav-list-link::before,
.modal-nav-hamburger .nav-primary .nav-item > .nav-list-link::after,
.modal-nav-hamburger .nav-primary .list-subitems .nav-item > .nav-list-link::before,
.modal-nav-hamburger .nav-primary .list-subitems .nav-item > .nav-list-link::after{
  content:none !important;
}
.modal-nav-hamburger .nav-primary .nav-item > .nav-list-link,
.modal-nav-hamburger .nav-primary .list-subitems .nav-item > .nav-list-link{
  border:0 !important;
  box-shadow:none !important;
  position:relative;
  display:block;
  padding-left:16px;  /* margen interno para que el divisor no sea full width */
  padding-right:16px;
}

/* 4b. Divisor con background (siempre 1px y mismo color), no full width */
.modal-nav-hamburger .nav-primary .nav-item:not(:last-child) > .nav-list-link{
  background-image:linear-gradient(#ab7438, #ab7438);
  background-repeat:no-repeat;
  background-position:left bottom;
  background-size:calc(100% - 32px) 1px; /* 16px de cada lado */
}
.modal-nav-hamburger .nav-primary .list-subitems .nav-item:not(:last-child) > .nav-list-link{
  background-image:linear-gradient(#ab7438, #ab7438);
  background-repeat:no-repeat;
  background-position:left bottom;
  background-size:calc(100% - 32px) 1px;
}

/* ===== Filtros (modal #nav-filters) ===== */

/* 1) Header del modal: fondo #ab7438 + tipografía/ícono blancos */
#nav-filters .modal-header{
  background:#ab7438 !important;
  color:#fff !important;
}
#nav-filters .modal-header a,
#nav-filters .modal-header .modal-close{ color:#fff !important; }
#nav-filters .modal-header svg{ fill:#fff !important; }

/* 2) Títulos dentro del modal (presentes y futuros) */
#nav-filters .font-weight-bold,
#nav-filters .font-small.font-weight-bold,
#nav-filters .modal-body .font-weight-bold{
  color:#ab7438 !important;
}

/* 3) RADIOS (Ordenar): aro más delgado y punto activo #ab7438 */
#nav-filters .radio-button-icons .radio-button-icon{
  border:1.5px solid #ab7438 !important;    /* aro fino */
  background:transparent !important;
  border-radius:50% !important;
  box-shadow:none !important;
}
#nav-filters .radio-button-icons .radio-button-icon.unchecked{
  background:transparent !important;
}
#nav-filters .radio-button-item.selected .radio-button-icons .radio-button-icon.checked{
  background:#ab7438 !important;            /* punto activo */
  border:none !important;
  border-radius:50% !important;
  transform:scale(.6);
  transform-origin:center;
}
#nav-filters .radio-button-item.selected .radio-button-label{
  color:#ab7438 !important;
}

/* 4) CHECKBOXES (filtros): FIX de alineación + borde fino + tick blanco */
#nav-filters label.js-filter-checkbox{
  display:block;                              /* cada opción ocupa su fila */
}
#nav-filters label.js-filter-checkbox .checkbox{
  display:inline-flex !important;             /* ícono a la IZQUIERDA del texto */
  align-items:center !important;
  gap:8px !important;                         /* separación icono–texto */
  vertical-align:middle;
}

/* --- clave: sacar posicionamiento absoluto del icono del tema --- */
#nav-filters .checkbox .checkbox-icon{
  position:static !important;                 /* <--- evita que se monte sobre el texto */
  display:inline-block !important;
  width:18px; height:18px;
  flex:0 0 18px !important;
  margin:0 !important;
  border:1.5px solid #ab7438 !important;      /* borde fino */
  border-radius:4px !important;               /* cuadrados */
  background:transparent !important;
  box-shadow:none !important;
  left:auto !important; top:auto !important;  /* por si el tema los forzó */
}

#nav-filters label.js-filter-checkbox input:checked + .checkbox .checkbox-icon{
  background:#ab7438 !important;              /* fondo activo */
  border-color:#ab7438 !important;
}

/* ocultar cualquier tick del tema y dibujar el nuestro en blanco */
#nav-filters .checkbox .checkbox-icon svg{ display:none !important; }
#nav-filters label.js-filter-checkbox input:checked + .checkbox .checkbox-icon::before,
#nav-filters label.js-filter-checkbox input:checked + .checkbox .checkbox-icon::after{
  content:none !important;
}
#nav-filters label.js-filter-checkbox input:checked + .checkbox .checkbox-icon::after{
  content:"";
  position:relative;                           /* relativo al flujo, no absoluto */
  display:block;
  width:6px; height:10px;
  margin:1px auto 0;                           /* centrado óptico dentro del cuadrado */
  border:2px solid #fff;                       /* tick blanco */
  border-top:0; border-left:0;
  transform:rotate(45deg);
}

/* 5) Botón "Aplicar" del rango de precio: activo en #ab7438 */
#nav-filters .js-price-filter-btn{
  background:var(--main-foreground-opacity-10) !important; /* inactivo */
  color:var(--main-foreground) !important;
  border:none !important;
}
#nav-filters .js-price-filter-btn:not(.disabled):not([disabled]){
  background:#ab7438 !important; color:#fff !important; border:none !important;
}
#nav-filters .js-price-filter-btn:not(.disabled):not([disabled]):hover{
  filter:brightness(.92) !important;
}

/* Chips de filtros activos: fondo #ab7438, texto blanco, misma forma del tema */
.js-remove-filter.chip,
.js-remove-filter-chip.chip,
.chip[data-component^="filter.pill"]{
  background:#ab7438 !important;
  color:#fff !important;
  border-color:#ab7438 !important; /* no tocamos el border-radius/padding original */
  position:relative;                /* para posicionar la X */
  display:inline-block;             /* evita “gaps” Flex */
  padding-right:22px;               /* lugar para la X */
}

/* El SVG del tema: fuera del layout sí o sí */
.js-remove-filter.chip svg.chip-remove-icon,
.js-remove-filter-chip.chip svg.chip-remove-icon,
.chip[data-component^="filter.pill"] svg.chip-remove-icon{
  display:none !important;
  width:0 !important; height:0 !important;
  margin:0 !important; padding:0 !important;
  position:absolute !important; left:-9999px !important;
}

/* Nuestra X blanca, sin modificar el shape del chip */
.js-remove-filter.chip::after,
.js-remove-filter-chip.chip::after,
.chip[data-component^="filter.pill"]::after{
  content:"×";                      /* U+00D7, nítida */
  position:absolute; right:8px; top:50%;
  transform:translateY(-52%);       /* ajuste óptico */
  font-size:14px; line-height:1; font-weight:700;
  color:#fff;
  pointer-events:none;              /* no tapa el click */
}

/* Interacciones */
.js-remove-filter.chip:hover,
.js-remove-filter-chip.chip:hover,
.chip[data-component^="filter.pill"]:hover{
  filter:brightness(.92);
}
.js-remove-filter.chip:focus,
.js-remove-filter-chip.chip:focus,
.chip[data-component^="filter.pill"]:focus{
  outline:2px solid rgba(171,116,56,.3);
  outline-offset:2px;
}


/* Ocultar opciones de orden que no querés (en el modal de filtros) */
#nav-filters .js-apply-sort[data-sort-value="alpha-ascending"],
#nav-filters .js-apply-sort[data-sort-value="alpha-descending"],
#nav-filters .js-apply-sort[data-sort-value="created-descending"],
#nav-filters .js-apply-sort[data-sort-value="created-ascending"]{
  display:none !important;
}

/* (opcional) si en otro lugar del tema aparecen estas mismas opciones */
.radio-button-container .js-apply-sort[data-sort-value="alpha-ascending"],
.radio-button-container .js-apply-sort[data-sort-value="alpha-descending"],
.radio-button-container .js-apply-sort[data-sort-value="created-descending"],
.radio-button-container .js-apply-sort[data-sort-value="created-ascending"]{
  display:none !important;
}

/* H2 de COLECCIONES & EDICIONES ÚNICAS a todo el ancho + fondo blanco */
.js-banners-section-title.js-banners-title.section-title {
  display: block;
  background: #fff !important;

  /* full width (sale del contenedor) */
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;

  /* mas jerarquía tipográfica */
    font-size: 25px !important;

  /* anulamos márgenes utilitarios del theme y los pasamos a padding */
  margin-top: 0 !important;       /* reemplaza .mt-3 */
  margin-bottom: 0 !important;    /* reemplaza .mb-4 */

  /* aire interno (incluye mt-3=1rem y mb-4=1.5rem + pb-2=.5rem) */
  padding-top: calc(45px + 1.5rem + .5rem) !important;
  padding-bottom: calc(45px + 1.5rem + .5rem) !important;

  /* por si el theme cambia el centrado */
  text-align: center;
  position: relative;
  z-index: 9;
}

/* 1) Controles dentro del banner */
.js-home-slider-row .col-12 { position: relative; }

.js-home-slider-row .col-12 > .mt-2.text-center {
  position: absolute;
  left: 0; right: 0;
  bottom: 8px;                 /* un toque más abajo */
  margin: 0 !important;
  z-index: 25;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

/* 2) Ocultar flechas prev/next (incluye variantes del theme/Swiper) */
.js-home-slider-row .js-swiper-home-prev,
.js-home-slider-row .js-swiper-home-next,
.js-home-slider-row .swiper-button-prev,
.js-home-slider-row .swiper-button-next {
  display: none !important;
  visibility: hidden !important;
}
.js-home-slider-row .swiper-button-prev::before,
.js-home-slider-row .swiper-button-prev::after,
.js-home-slider-row .swiper-button-next::before,
.js-home-slider-row .swiper-button-next::after {
  content: none !important;
  display: none !important;
}

/* 3) Bullets más chicas y activa en blanco */
.js-home-slider-row .js-swiper-home-pagination.swiper-pagination-bullets .swiper-pagination-bullet {
  width: 8px; height: 8px;
  margin: 0 5px !important;
  opacity: 1 !important;
  background: rgba(255,255,255,.45) !important; /* inactivas */
}
.js-home-slider-row .js-swiper-home-pagination.swiper-pagination-bullets .swiper-pagination-bullet-active {
  background: #fff !important;                  /* activa en blanco */
}

/* 4) Kill switch de flechas/adorno alrededor de las bullets */
.js-home-slider-row .js-swiper-home-pagination::before,
.js-home-slider-row .js-swiper-home-pagination::after,
.js-home-slider-row .swiper-pagination::before,
.js-home-slider-row .swiper-pagination::after,
.js-home-slider-row .swiper-pagination-bullets::before,
.js-home-slider-row .swiper-pagination-bullets::after,
.js-home-slider-row .swiper-pagination-bullet::before,
.js-home-slider-row .swiper-pagination-bullet::after {
  content: "" !important;
  display: none !important;
  background: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* Sin padding a la section de categorías HOME */
.section-banners-home, .section-modules-home {
    padding: 0px 0 !important;
}


/* Contenedor full-bleed sin paddings seccion banners categorías */
.section-banners-home .js-banners .js-banner-container.container,
.section-banners-home .js-banners .js-swiper-banners {
  width: 100vw; max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0 !important; padding-right: 0 !important;
}



/* ===== Institutional (v2) – prolijo, sello fijo y full-bleed ===== */
.section-institutional-home--v2{
  --seal-size: 140px;
  --seal-x: 0px;
  --seal-y: -250px;                 /* posición vertical del sello (independiente) */
  --text-pad-top: 52px;             /* ALTURA DEL TEXTO (independiente del sello) */
  --text-nudge-left: 8px;
  --section-pad-top: 2rem;

  --pop-top: calc(var(--seal-size)/2);
  --hero-pop: var(--pop-top);

  background:#fff;
  position:relative;
  overflow:visible;
  margin-top: var(--pop-top);
  padding-top: var(--section-pad-top);
  padding-bottom: 2.5rem;
}

.section-institutional-home--v2 .container,
.section-institutional-home--v2 .row{
  position:relative;
  overflow:visible;
}

.section-institutional-home--v2 .col-left{
  position:relative;
  padding-left: 0 !important;
  margin-left: calc(-1 * var(--text-nudge-left));
  padding-top: var(--text-pad-top); /* ya NO depende del sello */
}

.section-institutional-home--v2 h2,
.section-institutional-home--v2 p{
  text-align:left;
}

.section-institutional-home--v2 .institutional-seal{
  position:absolute;
  left: calc(-1 * var(--text-nudge-left) + var(--seal-x));
  top: var(--seal-y) !important;    /* sello fijo por perilla */
  width: var(--seal-size);
  height:auto;
  transform:none !important;
  z-index:2;
  pointer-events:none;
  user-select:none;
}

.section-institutional-home--v2 .institutional-hero-wrap{
  position:relative;
  padding-right:0 !important;
  margin-left:auto;
}
.section-institutional-home--v2 .institutional-hero{
  display:block;
  width:100%;
  height:auto;
  margin-top: calc(-1 * var(--hero-pop)); /* perilla independiente del sello */
}

@media (min-width: 992px){
  .section-institutional-home--v2 .institutional-hero-wrap{
    margin-right: calc(-0.5 * (100vw - 100%));
  }
  .section-institutional-home--v2 .institutional-hero{
    width: calc(100% + 0.5 * (100vw - 100%));
  }
}

/* ===== Mobile (<= 767.98px) ===== */
@media (max-width: 767.98px){
  .section-institutional-home--v2{
    /* sin sobresalto en mobile */
    --hero-pop: 0px;

    /* sello más chico en mobile si querés ajustarlo */
    --seal-size: 96px;

    /* cuánto sube el sello en mobile (negativo = sube) */
    --seal-mobile-shift-y: -20px;

    /* mismo margen del párrafo arriba/abajo */
    --para-gap: 16px;

    /* micro-fix para full-bleed (cubre redondeos de 1px) */
    --bleed-fix: 2px;

    margin-top: 0;
    padding-top: 1.25rem;
  }

  /* sello arriba y centrado, con subida adicional */
  .section-institutional-home--v2 .institutional-seal{
    position: static !important;
    display: block !important;
    width: var(--seal-size);
    height: auto;
    margin: var(--seal-mobile-shift-y) auto 12px auto; /* sube con margin-top negativo */
    left: auto !important;
    top: auto !important;
    transform: none !important;
  }

  /* texto debajo del sello, sin corrimientos laterales ni altura extra */
  .section-institutional-home--v2 .col-left{
    margin-left: 0;
    padding-top: 0;
  }
  /* quitamos gap del título y unificamos el del párrafo */
  .section-institutional-home--v2 h2{ margin-bottom: 0 !important; }
  .section-institutional-home--v2 .js-institutional-message-title{
    margin: var(--para-gap) 0 !important;  /* mismo margen arriba y abajo */
  }

  /* imagen full-width REAL y sin gap a la izquierda (overbleed de 2px) */
  .section-institutional-home--v2 .institutional-hero-wrap{
    margin-right: 0;
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .section-institutional-home--v2 .institutional-hero{
    display: block;
    position: relative;
    height: auto;

    /* full viewport width, con micro-bleed para tapar subpíxeles */
    width: calc(100vw + var(--bleed-fix));
    max-width: none;

    /* alinear al viewport (no al container) y eliminar “gap” izquierdo */
    margin-left: calc(-50vw - var(--bleed-fix)/2);
    margin-right: calc(-50vw - var(--bleed-fix)/2);

    /* separación respecto del párrafo */
    margin-top: var(--para-gap);

    /* aseguramos que no haya traslaciones heredadas */
    transform: none !important;
    left: 50%;
  }
}




/* ===== Mobile tweaks: títulos ===== */
@media (max-width: 767.98px){

  /* COLECCIONES & EDICIONES ÚNICAS: solo darle más margen-top en mobile */
  .js-banners-section-title.js-banners-mobile-title.section-title{
    margin-top: 80px !important; /* subí/bajá este valor a gusto */
  }
  /* fallback por si en tu DOM no aparece la clase .js-banners-mobile-title */
  .js-banner-container .js-banners-section-title.section-title:not(.js-banners-title){
    margin-top: 80px !important;
  }

  /* DESTACADOS DEL MES: le bajamos apenas el tamaño y evitamos el salto de línea */
  .js-products-featured-container > .row > .col-12 > h2.js-products-featured-title.section-title{
    /* centrado real y ancho controlado */
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;

    /* tipografía un toque más chica para que entre en una línea */
    font-size: clamp(18px, 5.2vw, 20px) !important; /* ajustá 19–21 si querés */
    letter-spacing: 0.2em !important;
    line-height: 1.2 !important;

    /* evitamos el problema que lo pegaba a la derecha */
    white-space: normal !important;   /* dejamos que pueda ajustar si hace falta */
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}


























@supports (width: 100dvw) {
  .section-banners-home .js-banners .js-banner-container.container,
  .section-banners-home .js-banners .js-swiper-banners {
    width: 100dvw; max-width: 100dvw;
    margin-left: calc(50% - 50dvw);
    margin-right: calc(50% - 50dvw);
  }
}

/* Sin separación entre slides */
.section-banners-home .js-banners .swiper-wrapper { gap: 0 !important; }
.section-banners-home .js-banners .swiper-slide {
  margin-right: 0 !important;
  width: 25% !important;          /* 4 por vista exacto */
  flex: 0 0 25% !important;
}

/* Limpiar rellenos/márgenes internos */
.section-banners-home .js-banners .js-banner,
.section-banners-home .js-banners .js-textbanner,
.section-banners-home .js-banners .js-textbanner-image-container {
  margin: 0 !important; padding: 0 !important;
}

/* La imagen llena su slide exactamente */
.section-banners-home .js-banners .js-banner img {
  display: block; width: 100%; height: auto;
}

/* Swiper no agregue padding lateral */
.section-banners-home .js-banners .swiper-container { padding: 0 !important; }

/* Evitar “hueco” por barra de scroll */
html, body { overflow-x: hidden; }

/* --- Títulos dentro de la imagen (overlay) --- */
.section-banners-home .js-banners .textbanner-link {
  position: relative;              /* contenedor para el overlay */
  display: block;
}

.section-banners-home .js-banners .js-textbanner-text {
  position: absolute;              /* ponemos el h3 sobre la imagen */
  inset: 0;                        /* ocupa todo el slide */
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  pointer-events: none;            /* que siga siendo clickeable el banner */
  padding: 8px;
}

.section-banners-home .js-banners .js-banner-title {
  color: #fff !important;          /* tipografía blanca */
  letter-spacing: 0.13em !important;
  margin: 0 !important;
  line-height: 1.1;
  text-transform: uppercase;
  /* opcional para legibilidad sobre fondos claros: */
  /* text-shadow: 0 1px 2px rgba(0,0,0,.35); */
}

/* quitamos espacios por si el theme agrega algo extra */
.section-banners-home .js-banners .js-textbanner,
.section-banners-home .js-banners .js-textbanner-image-container {
  margin: 0 !important;
  padding: 0 !important;
}

/* baja/sube el título dentro de la imagen */
.section-banners-home .js-banners .js-banner-title {
  transform: translateY(360%);
}

/* DESTACADOS DEL MES */
.js-products-featured-title.section-title {
  font-size: 25px !important;
  letter-spacing: 0.2em !important;
  margin-top: 70px !important;
  margin-bottom: 70px !important;
}

/* Footer: mismo tamaño que en Home (≈149 × 80 px) */
footer.js-footer .footer-logo-img {
  height: 80px !important;       
  max-height: 80px !important;    
  width: auto !important;         
  max-width: none !important;
  display: inline-block;
}

/* (Opcional) En mobile, si lo querés un toque más chico */
@media (max-width: 576px) {
  footer.js-footer .footer-logo-img {
    height: 70px !important;
    max-height: 70px !important;
  }
}






@media (max-width: 340px) {
  .item-actions .js-item-submit-container > input.js-addtocart,
  .item-actions .js-quickshop-modal-open.btn-link {
    font-size: 12px !important;
    padding: .5em .85em !important;
    min-height: 38px !important; /* opcional: un poco más bajo en xs */
  }
}

@media (max-width: 430px) {
  /* Título */
  .js-item-product .item-description .js-item-name {
    font-size: 14px !important;
    line-height: 1.25em !important;
  }
  /* Precio */
  .js-item-product .item-description .item-price-container,
  .js-item-product .item-description .js-item-price,
  .js-item-product .item-description .price {
    font-size: 14px !important;
    line-height: 1.2em !important;
  }
}

@media (max-width: 375px) {
  .js-item-product .item-description .js-item-name {
    font-size: 13px !important;
    line-height: 1.25em !important;
  }
  .js-item-product .item-description .item-price-container,
  .js-item-product .item-description .js-item-price,
  .js-item-product .item-description .price {
    font-size: 13px !important;
    line-height: 1.2em !important;
  }
}


/* Carrusel secciones del home */
@media (max-width: 767px) {
  .js-textbanner-text .js-banner-title,
  .js-textbanner-text .h1-huge,
  .js-textbanner-text .h3-md {
    font-size: clamp(16px, 4.6vw, 20px) !important;
    line-height: 1.15 !important;
  }
}

/* Sección Corporativos */


/* Corporativos – ajustes mínimos */
.page-header { text-transform: none; }
#solicitar-acceso .btn,
#contacto-b2b .btn { border-radius: 999px; }
.ratio { position: relative; width: 100%; }
.ratio-16x9 { padding-top: 56.25%; }
.ratio > * { position: absolute; inset: 0; }

/* Iniciar sesion */
.btn-pill { border-radius: 999px !important; padding: 0.6rem 1.25rem !important; }



