/* ===== Variables & Reset ===== */
:root{
  --bg: #f4eee9;
  --ink: #2d2926;
  --muted: #7b6f67;
  --brand: #1c5d53;          /* acento sobrio */
  --brand-2: #b38f6b;        /* acento elegante */
  --card: #ffffffcc;
  --radius-xl: 22px;
  --radius-lg: 16px;
  --shadow-md: 0 10px 25px rgba(0,0,0,.08);
  --transition: 220ms cubic-bezier(.2,.8,.2,1);
}

* { box-sizing: border-box; }
html,body { 
  height: 100%;
  overflow-x: clip;
 }

body{
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.4;
  text-rendering: optimizeLegibility;
}

/* ===== Page Grid Layout ===== */
.page-grid{
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100dvh;
}

/* ===== Header / Nav ===== */
.site-header{
  position: sticky;
  top: 0;
  backdrop-filter: saturate(120%) blur(6px);
  background: color-mix(in oklab, var(--bg) 85%, white 15%);
  border-bottom: 1px solid rgba(0,0,0,.06);
  z-index: 50;
}

.nav-inner{
  display: grid;
  grid-template-columns: 48px 1fr auto; /* toggle | brand | nav */
  align-items: center;
  gap: 12px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 14px 20px;
}

/* Logo elegante */
.brand{
  justify-self: center;
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .5px;
  font-size: clamp(1.3rem, 1.6vw + .9rem, 2rem);
  color: var(--ink);
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: .1em;
}
.brand-mark{ color: var(--brand); }
.brand-rest{ color: var(--brand-2); }

/* Menú principal */
.site-nav{ justify-self: end; }
.menu{
  display: grid;
  grid-auto-flow: column;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-link{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  text-decoration: none;
  color: var(--ink);
  padding: 8px 0;
  cursor: pointer;
  transition: color var(--transition);
}
.nav-link::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  transition: transform var(--transition);
}
.nav-link:hover{ color: var(--brand); }
.nav-link:hover::after{ transform: scaleX(1); }

/* Reset del botón "Categorías" para que luzca como los demás enlaces */
.submenu-toggle{
  background: none;
  border: none;
  padding: 8px 0;       /* igual que .nav-link */
  font: inherit;        /* hereda familia y tamaño */
  color: inherit;
  line-height: inherit;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

/* Anillo de enfoque consistente (accesibilidad) */
.nav-link:focus-visible,
.submenu-toggle:focus-visible{
  outline: 2px solid color-mix(in oklab, var(--brand) 70%, white 0%);
  outline-offset: 4px;
  border-radius: 8px;
}


/* Flecha */
.chev{
  width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2;
  transition: transform var(--transition);
}

/* Submenú (desktop hover + mobile click) */
.has-submenu{
  position: relative;
}
.submenu{
  --pad: 10px;
  position: absolute;
  left: 0;
  top: calc(100% + 1px);
  min-width: 240px;
  list-style: none;
  margin: 0;
  padding: var(--pad);
  background: var(--card);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  opacity: 0;
  transform: translateY(8px) scale(.98);
  pointer-events: none;
  transition: opacity var(--transition), transform var(--transition);
  backdrop-filter: blur(6px);
}
.nav-sublink{
  display: block;
  padding: 10px 12px;
  border-radius: 12px;
  color: var(--ink);
  text-decoration: none;
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.nav-sublink:hover{
  background: color-mix(in oklab, var(--brand-2) 20%, white);
  color: var(--brand);
  transform: translateX(4px);
}

/* Mostrar submenú en desktop (hover) */
@media (hover:hover){
  .has-submenu:hover > .submenu{
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
  }
  .has-submenu:hover .chev{ transform: rotate(180deg); }
}

/* ===== Botón hamburguesa (icono) ===== */
.nav-toggle{
  display: none;
  width: 42px; height: 42px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: #fff;
  box-shadow: var(--shadow-md);
  align-items: center;
  justify-content: center;
  padding: 0;
}
.menu-icon{
  width: 28px;
  height: 28px;
  object-fit: contain;
  display: block;
  transition: opacity var(--transition), transform var(--transition);
}
/* Efecto al abrir el menú */
.nav-toggle[aria-expanded="true"] .menu-icon {
  opacity: 0.7;
  transform: scale(1.1);
}

/* ===== Hero con Grid ===== */
.hero{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  align-items: stretch;
  gap: clamp(16px, 4vw, 42px);
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 20px 40px;
}
.hero-copy{
  align-self: center;
}
.hero h1{
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(2rem, 2.5vw + 1.2rem, 3.2rem);
  line-height: 1.1;
  margin: 0 0 12px 0;
}
.hero p{
  color: var(--muted);
  font-size: clamp(1rem, .4vw + .9rem, 1.1rem);
  margin: 0 0 18px 0;
}
.cta{
  display: inline-block;
  text-decoration: none;
  font-weight: 600;
  padding: 12px 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: white;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition), filter var(--transition);
}
.cta:hover{ transform: translateY(-1px); filter: brightness(1.03); }

/* Hero modelo Nisimarket */
/* Hero modelo Nisimarket */
.hero-card{
  margin: 0;
  display: grid;
  place-items: center; /* centrado, evita desplazamientos extraños */
  overflow: hidden;
  position: relative;
}

/* Imagen totalmente fluida */
.hero-card img{
  display: block;
  width: 100%;
  height: auto;
  max-width: 520px;          /* límite en desktop/tablet */
  aspect-ratio: 1 / 1;       /* mantiene proporción cuadrada elegante */
  object-fit: cover;
}




/* ================== LO MÁS VENDIDO ================== */
.best-sellers{
  max-width: 1200px;
  margin: 24px auto 64px;
  padding: 0 20px;
}
.best-sellers .bs-header h2{
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .4px;
  font-size: clamp(1.4rem, 1.2vw + 1.2rem, 2rem);
  margin: 0 0 14px 0;
  color: var(--ink);
}

.carousel{
  position: relative;
}
.carousel-viewport{
  overflow: hidden;
}
.carousel-track{
  --gap: clamp(12px, 2vw, 18px);
  display: grid;
  grid-auto-flow: column;
  gap: var(--gap);
  /* 4 tarjetas visibles en escritorio */
  grid-auto-columns: calc((100% - (var(--gap) * 3)) / 4);
  align-items: stretch;
}

/* Tarjeta */
.product-card{
  background: var(--card);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  box-shadow: var(--shadow-md);
  padding: 16px 16px 14px;
  display: grid;
  align-content: start;
  gap: 8px;
  transition: transform var(--transition), box-shadow var(--transition), filter var(--transition);
  will-change: transform;
}
.product-card:hover{
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 14px 36px rgba(0,0,0,.12);
  filter: saturate(1.02);
}

/*IMAGENES DE PRODUCTOS*/

.product-card img{
  width: 100%;
}

.p-cat{
  display: inline-block;
  font-size: .85rem;
  color: var(--brand);
  background: color-mix(in oklab, var(--brand) 10%, white);
  padding: 6px 10px;
  border-radius: 999px;
  width: fit-content;
}
.p-name{
  margin: 2px 0 0 0;
  font-weight: 700;
  font-size: 1.05rem;

}


.p-desc{
  margin: 0;
  color: var(--muted);
}
.p-price{
  margin: 6px 0 10px 0;
  font-size: 1rem;
}
.p-btn{
  justify-self: start;
  text-decoration: none;
  font-weight: 600;
  padding: 10px 14px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition), filter var(--transition);
}
.p-btn:hover{
  transform: translateY(-2px);
  filter: brightness(1.03);
}

/* Flechas */
.carousel-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px; height: 42px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: #fff;
  box-shadow: var(--shadow-md);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform var(--transition), background var(--transition), color var(--transition);
  color: var(--ink);
  z-index: 2;
}
.carousel-arrow:hover{
  background: color-mix(in oklab, var(--brand-2) 15%, white);
  color: var(--brand);
  transform: translateY(-50%) scale(1.06);
}
.arrow-prev{ left: -6px; }
.arrow-next{ right: -6px; }
.carousel-arrow svg{ width: 22px; height: 22px; }

/*Lo Mas Vendido final*/




/*Catalogo y categoria de productos*/

/* ===== Catálogo / Categorías ===== */
.catalogo{
  max-width: 1200px;
  margin: 32px auto 64px;
  padding: 0 20px;
}
.catalogo h1{
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .3px;
  font-size: clamp(1.6rem, 2vw + 1rem, 2.4rem);
  margin: 0 0 6px 0;
  color: var(--ink);
}
.catalogo h2{
  margin: 0 0 16px 0;
  color: var(--ink);
  font-size: clamp(1.05rem, .5vw + .95rem, 1.2rem);
}


/* Grid 4 x 2 en escritorio (8 productos) */
.categories-grid{
  --gap: clamp(12px, 2vw, 18px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Mantén tu tarjeta con hover suave */
.categories .product-card{
  background: var(--card);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  box-shadow: var(--shadow-md);
  padding: 16px 16px 14px;
  display: grid;
  align-content: start;
  gap: 8px;
  transition: transform var(--transition), box-shadow var(--transition), filter var(--transition);
}
.categories .product-card:hover{
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 14px 36px rgba(0,0,0,.12);
  filter: saturate(1.02);
}

/* Imagen fija con encuadre consistente (4:5) */
.pc-media{
  margin: 0;
  padding: 0;
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 5;         /* formato elegante para catálogo */
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
}
.pc-media img{
  
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;            /* cubre sin deformar */
  object-position: center center;
  transform: scale(1);
  transition: transform var(--transition), filter var(--transition);
}
.categories .product-card:hover .pc-media img{
  transform: scale(1.03);
  filter: saturate(1.04);
}

/* Elementos de texto ya definidos en tu sitio:
   .p-cat .p-name .p-desc .p-price .p-btn
   Si quieres pequeñas variaciones para esta sección: */
.categories .p-cat{
  background: color-mix(in oklab, var(--brand) 10%, white);
  color: var(--brand);
  padding: 6px 10px;
  border-radius: 999px;
  width: fit-content;
  font-size: .85rem;
}
.categories .p-name{ font-weight: 700; margin: 2px 0 0 0; }
.categories .p-desc{ color: var(--muted); margin: 0; }
.categories .p-price{ margin: 6px 0 10px 0; }
.categories .p-btn{
  justify-self: start;
  text-decoration: none;
  font-weight: 600;
  padding: 10px 14px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition), filter var(--transition);
}
.categories .p-btn:hover{
  transform: translateY(-2px);
  filter: brightness(1.03);
}


/*Catalogo y categoria de productos final*/





/*Promociones del Mes*/
/* ===== Promociones del Mes ===== */
.promos{
  max-width: 1200px;
  margin: 24px auto 64px;
  padding: 0 20px;
}
.promos-header h2{
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .4px;
  font-size: clamp(1.3rem, 1.1vw + 1.1rem, 1.8rem);
  margin: 0 0 14px 0;
  color: var(--ink);
}

.promos-grid{
  display: grid;
  gap: clamp(12px, 2vw, 18px);
  grid-template-columns: repeat(3, 1fr);  /* Escritorio: 3 */
  width: 1200px;
  list-style: none;
  margin: 0;
  padding: 0;
  justify-items: stretch;
}

.promo-card{
  background: color-mix(in oklab, var(--bg) 85%, white 15%);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: var(--radius-lg, 16px);
  box-shadow: var(--shadow-md);
  padding: 12px 12px 14px;
  display: grid;
  gap: 10px;
  align-content: start;
  transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
}

/* Contenedor de imagen 9:16 con recorte elegante */
.promo-media{
  position: relative;
  margin: 0;
  width: 100%;
  aspect-ratio: 9 / 16;     /* clave: formato vertical 9:16 */
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  contain: paint;
/* Asegura centrado del contenido interno */
  display: flex;
  align-items: center;
  justify-content: center;  
}
.promo-media img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;     /* recorte elegante manteniendo proporción */
  object-position: center center; /* centra la imagen */
  display: block;
  transform: translatez(0);
  transition: transform var(--transition), filter var(--transition), opacity var(--transition);
}

/* Botón coherente con tu branding */
.promo-btn{
  justify-self: stretch;
  text-align: center;
  text-decoration: none;
  font-weight: 600;
  padding: 10px 14px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition), filter var(--transition), opacity var(--transition), background var(--transition);
}

/* Hover en ESCRITORIO: zoom sutil en imagen y botón */
@media (hover:hover){
  .promo-card:hover .promo-media img{
    transform: scale(1.03);
    filter: saturate(1.04);
  }
  .promo-card:hover .promo-btn{
    transform: translateY(-1px);
    filter: brightness(1.04);
    /* leve variación del gradiente para "vida" */
    background: linear-gradient(135deg,
      color-mix(in oklab, var(--brand) 92%, white),
      color-mix(in oklab, var(--brand-2) 92%, white)
    );
  }
}

/* Tap en MÓVIL: opacidad ligera y elegante (se añade clase via JS) */
.promo-card.tapped .promo-media img,
.promo-card.tapped .promo-btn{
  opacity: .86;
}


/*Promociones del Mes final*/





/* ===== Por qué elegirnos ===== */
.why-choose{
  max-width: 1200px;
  margin: 32px auto 56px;
  padding: 0 20px;
}

.wc-header h2{
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .4px;
  font-size: clamp(1.3rem, 1.1vw + 1.1rem, 1.8rem);
  margin: 0 0 14px 0;
  color: var(--ink);
}

/* Contenedor con fondo claro y bordes suaves */
.wc-grid{
  --tile-bg: color-mix(in oklab, var(--bg) 85%, white 15%);
  display: grid;
  grid-template-columns: repeat(4, 1fr);   /* escritorio: 4 horizontales */
  gap: clamp(10px, 2vw, 16px);
  list-style: none;
  margin: 0;
  padding: 0;
}

.wc-item{
  background: var(--tile-bg);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: var(--radius-lg, 16px);
  box-shadow: var(--shadow-md);
  padding: clamp(16px, 2.4vw, 22px);
  text-align: center;
  transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
}

.wc-item:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 36px rgba(0,0,0,.12);
  background: color-mix(in oklab, var(--brand-2) 8%, var(--tile-bg));
}

/* Icono con color de marca y ligera gradación */
.material-symbols-outlined{
  font-variation-settings: "OPSZ" 48, "wght" 400, "FILL" 0;
}

.wc-icon{
  display: inline-block;
  font-size: clamp(42px, 4vw, 56px);
  line-height: 1;
  color: var(--brand);
  /* Sutil efecto bicolor usando text-shadow con el segundo tono */
  text-shadow: 0 0 0 var(--brand-2);
  margin-bottom: 8px;
}

.wc-text{
  margin: 6px 0 0 0;
  font-weight: 600;
  color: var(--ink);
}

/* Accesibilidad: respeta reducir movimiento */
@media (prefers-reduced-motion: reduce){
  .wc-item{ transition: none; }
}

/* ===== Por qué elegirnos Final ===== */



/* ===== Testimonios ===== */
.testimonials{
  max-width: 1200px;
  margin: 32px auto 64px;
  padding: 0 20px;
}

.t-header h2{
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .4px;
  font-size: clamp(1.3rem, 1.1vw + 1.1rem, 1.8rem);
  margin: 0 0 14px 0;
  color: var(--ink);
}

.t-carousel{ position: relative; }
.t-viewport{
  overflow: hidden;
  position: relative;
  width: 100%;
}

.t-track{
  --gap: clamp(12px, 2vw, 18px);
  display: grid;
  grid-auto-flow: column;
  gap: var(--gap);
  /* 3 visibles en escritorio */
  grid-auto-columns: calc((100% - (var(--gap) * 2)) / 3);
  align-items: stretch;
  will-change: transform;
  transition: transform var(--transition);
}

/* Tarjeta */
.t-card{
  background: color-mix(in oklab, var(--bg) 85%, white 15%);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: var(--radius-lg, 16px);
  box-shadow: var(--shadow-md);
  padding: clamp(16px, 2.4vw, 22px);
  display: grid;
  align-content: start;
  gap: 10px;
  text-align: center;
}

/* Avatar circular */
.t-avatar{
  width: 76px;
  height: 76px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center;
  border: 3px solid color-mix(in oklab, var(--brand) 35%, var(--brand-2) 65%);
  margin: 0 auto 4px;
}

/* Texto y nombre */
.t-quote{
  margin: 0;
  color: var(--muted);
  font-size: .98rem;
}
.t-name{
  margin: 2px 0 0 0;
  font-weight: 700;
  color: var(--ink);
}

/* Estrellas */
.t-stars{
  display: inline-flex;
  gap: 2px;
  align-items: center;
  justify-content: center;
}
.t-stars .material-symbols-outlined{
  font-variation-settings: "OPSZ" 24, "wght" 400, "FILL" 1;
  font-size: 20px;
  line-height: 1;
  color: var(--brand);
  opacity: .95;
}
.t-stars .off{ color: color-mix(in oklab, var(--brand) 20%, var(--ink) 80%); opacity: .35; }

/* Flechas, misma estética que el carrusel existente */
.t-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px; height: 42px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: #fff;
  box-shadow: var(--shadow-md);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform var(--transition), background var(--transition), color var(--transition);
  color: var(--ink);
  z-index: 2;
}
.t-arrow:hover{
  background: color-mix(in oklab, var(--brand-2) 15%, white);
  color: var(--brand);
  transform: translateY(-50%) scale(1.06);
}
.t-prev{ left: -6px; }
.t-next{ right: -6px; }
.t-arrow svg{ width: 22px; height: 22px; }

/*testimonios de clientes final*/










/* ===== Footer ===== */
/* ===== Footer ===== */
.site-footer{
  border-top: 1px solid rgba(0,0,0,.06);
  background: color-mix(in oklab, var(--bg) 88%, white 12%);
  color: var(--ink);
  margin-top: 40px;
}

.footer-inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 26px 20px;
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr 1.1fr; /* 4 columnas escritorio */
  gap: clamp(16px, 3vw, 28px);
}

/* Marca y contacto */
.f-logo{
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 700;
  letter-spacing: .5px;
  font-size: clamp(1.2rem, 1.2vw + 1rem, 1.8rem);
  color: var(--ink);
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: .1em;
  margin-bottom: 8px;
}
.f-logo .brand-mark{ color: var(--brand); }
.f-logo .brand-rest{ color: var(--brand-2); }

.f-mail{
  display: inline-block;
  margin-top: 4px;
  color: var(--brand);
  text-decoration: none;
  font-weight: 600;
  transition: color var(--transition), transform var(--transition);
}
.f-mail:hover{ color: var(--brand-2); transform: translateY(-1px); }

/* Social */
.f-social{ margin-top: 12px; }
.f-social-btn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 12px;
  color: var(--brand);
  box-shadow: var(--shadow-md);
  text-decoration: none;
  font-weight: 600;
  transition: transform var(--transition), background var(--transition), color var(--transition);
}
.f-social-btn:hover{
  transform: translateY(-1px);
  background: color-mix(in oklab, var(--brand-2) 12%, white);
  color: var(--brand);
}
.f-ico{ width: 20px; height: 20px; display: block; }

/* Listas de enlaces */
.f-title{
  margin: 0 0 8px 0;
  font-weight: 700;
  font-size: 1rem;
  color: var(--ink);
}
.f-list{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}
.f-link{
  text-decoration: none;
  color: var(--ink);
  padding: 6px 0;
  border-radius: 10px;
  transition: color var(--transition), background var(--transition), transform var(--transition);
}
.f-link:hover{
  color: var(--brand);
  background: color-mix(in oklab, var(--brand) 10%, white);
  transform: translateX(2px);
}

/* CTA */
.f-cta-text{
  margin: 0 0 10px 0;
  color: var(--muted);
}
.f-cta-btn{
  display: inline-block;
  text-decoration: none;
  font-weight: 600;
  padding: 10px 14px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition), filter var(--transition);
}
.f-cta-btn:hover{ transform: translateY(-2px); filter: brightness(1.03); }

/* Línea legal inferior */
.footer-legal{
  border-top: 1px solid rgba(0,0,0,.06);
  text-align: center;
  color: var(--muted);
  padding: 14px 20px 18px;
}




/*Footer final*/





/* ===== Responsivo ===== */



@media (max-width: 1020px){
  /* (Opcional) 3 visibles en pantallas medianas */
  .carousel-track{
    grid-auto-columns: calc((100% - (var(--gap) * 2)) / 3);
  }

  .t-track{
    grid-auto-columns: calc((100% - var(--gap)) / 2);
  }
  /*Categorias y catalogo*/
  .categories-grid{
    grid-template-columns: repeat(2, 1fr);
  }

  /*Promociones del mes*/
  .promos-grid{
    grid-template-columns: repeat(2, 1fr);
  }

  /*footer*/
  .footer-inner{
    grid-template-columns: 1fr 1fr; /* 2 columnas */
  }
}
@media (max-width: 820px){
  /* (Opcional) 2 visibles en tablet */
  .carousel-track{
    grid-auto-columns: calc((100% - var(--gap)) / 2);
  }
}
/* Tablet */
@media (max-width: 980px){
  .hero{
    grid-template-columns: 1fr;
  }
/*seccion por que elegirnos*/
  .wc-grid{
    grid-template-columns: repeat(2, 1fr);
  }
}





/* Móvil */
@media (max-width: 700px){
  .nav-inner{
    grid-template-columns: 42px 1fr 42px; /* toggle | brand center | (espacio) */
  }
  .brand{ justify-self: center; }
  .nav-toggle{ display: inline-flex; }

  /* Menú móvil: alineado a la izquierda, más ancho, con fade + slide */
  .site-nav{
    position: fixed;
    top: 70px;
    left: 12px;         /* alineado a la izquierda */
    right: auto;
    width: 80%;         /* un poco más ancho */
    border-radius: 18px;
    background: var(--card);
    border: 1px solid rgba(0,0,0,.06);
    box-shadow: 0 20px 40px rgba(0,0,0,.12);
    padding: 12px;

    /* Animación de entrada/salida */
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transform: translateX(-10px);     /* slide desde la izquierda */
    transition:
      opacity var(--transition),
      transform var(--transition),
      max-height var(--transition);
    will-change: transform, opacity;
    backdrop-filter: blur(8px);
  }
  .site-nav.open{
    max-height: 80dvh;
    opacity: 1;
    transform: translateX(0);
  }

  .menu{
    grid-auto-flow: row;
    gap: 6px;
  }
  .nav-link{
    padding: 12px 10px;
    border-radius: 12px;
  }
  .nav-link:hover{
    background: color-mix(in oklab, var(--brand) 10%, white);
    color: var(--brand);
  }

  /* Submenú en móvil: acordeón con transición */
  .submenu{
    position: static;
    border: 0;
    box-shadow: none;
    padding: 0 6px 6px 6px;
    margin-top: 4px;
    border-radius: 12px;
    background: transparent;
    opacity: 1; /* gestionado por altura */
    transform: none;
    pointer-events: auto;
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition);
  }
  .submenu.open{
    max-height: 260px; /* suficiente para 3 ítems */
  }

  .submenu-toggle .chev{
    margin-left: 2px;
    transition: transform var(--transition);
  }
  .submenu-toggle[aria-expanded="true"] .chev{
    transform: rotate(180deg);
  }

  /*HERO CARD*/
  .hero{ 
    padding: 0 16px 28px;
   }                 /* un poco menos de padding lateral */

  

  .hero-card img{ 
    
    max-width: min(420px, 88vw); } /* se adapta sin desbordar */




  /* ================= / LO MÁS VENDIDO ================= */

/* ===== MÓVIL: 1 tarjeta fija, deslizamiento interno, sin fila horizontal ===== */

  /* Contenedor sin empujar el layout */
  .best-sellers{ 
    padding: 0 1px;
    max-width: 380px;
   }

  /*titulo H2*/ 
  .bs-header{
    text-align: center;
  }


  .best-sellers .carousel{
    max-width: 100%;

  }


  /* El viewport actúa como "marco" */
  .best-sellers .carousel-viewport{
    position: relative;
    width: 100%;
    overflow: hidden;   /* oculta tarjetas contiguas */
    padding: 0;
    margin: 0;
    isolation: isolate; /* evita que flechas creen stacking raro */
  }

  /* El track se mueve por transform dentro del marco */
  .best-sellers .carousel-track{
    display: flex;      /* NO usar display:block aquí */
    gap: 0;             /* sin separación horizontal */
    width: 100%;
    transform: translateX(0);
    transition: transform var(--transition);
    will-change: transform;

    /* Anula cualquier grid heredado */
    grid-auto-flow: initial;
    grid-auto-columns: initial;
  }

  /* Cada tarjeta ocupa exactamente el ancho del marco */
  .best-sellers .product-card{
    flex: 0 0 100%;     /* <- clave: 1 slide = 100% del viewport del carrusel */
    max-width: 100%;
    width: auto;        /* evita sumar padding al 100% */
    box-sizing: border-box;
    border-radius: 16px;
    padding: 16px 16px 14px;
  }

  /* Flechas totalmente dentro del marco */
  .best-sellers .arrow-prev{ left: 8px; }
  .best-sellers .arrow-next{ right: 8px; }


/* Opcional (recomendado): previene cualquier barra horizontal global */
html, body { overflow-x: clip; }

@media (prefers-reduced-motion: reduce){
  :root{ --transition: 1ms linear; }
  .best-sellers .carousel-track{
    transition: none !important;
  }
}



/*Categorias y productos*/

.catalogo{ padding: 0 16px; }
  .categories-grid{
    grid-template-columns: 1fr;
  }
  .categories .product-card{
    padding: 14px 14px 12px;   /* un poco menos de padding */
  }



/* Móvil: 1 por fila, full width y sin desbordes */  

/*Promociones del mes*/  
.promos{ padding: 0 16px; }

  .promos-grid{
    grid-template-columns: 1fr;
    width: 365px;
  }
  .promo-card{
    padding: 1px 1px 1px;
  }
  .promo-media{
    aspect-ratio: 9 / 16; /* mantiene formato 9:16 */
    width: 100%;
  }
  .promo-media img{
    width: 100%;
    height: 100%;
  }

  /* OPCIÓN: mostrar SOLO 1 imagen en móvil */
  .promos.mobile-single .promos-grid .promo-card:nth-child(n+2){
    display: none;
  }

  /* Respeta reducir movimiento */
@media (prefers-reduced-motion: reduce){
  .promo-media img, .promo-btn, .promo-card{ transition: none; }
}

/*Promociones del mes final*/

/*por que elegirnos*/

  .why-choose{ padding: 0 16px; }
  .wc-grid{ grid-template-columns: 1fr; }

/*por que elegirnos final*/  



/* 1 por vista movil con desplazamiento exacto*/
/*testimonios de clientes*/

.testimonials{ 
  padding: 0 6px;
  max-width: 390px;

}

  .t-header h2{
    text-align: center;

  }

  .t-viewport{
    isolation: isolate; /* evita stacking raro con flechas */
  }

  .t-track{
    display: flex;
    gap: 0;
    grid-auto-flow: initial;
    grid-auto-columns: initial;
    width: 100%;
    transform: translateX(0);
  }

  .t-card{
    flex: 0 0 100%;
    max-width: 100%;
    width: auto;
    box-sizing: border-box;
  }

  

  .t-prev{ left: 8px; }
  .t-next{ right: 8px; }

/* Respeta reducir movimiento */
@media (prefers-reduced-motion: reduce){
  .t-track{ transition: none; }
}  

/*Footer*/
.footer-inner{
    grid-template-columns: 1fr; /* 1 columna móvil */
    padding: 22px 16px;
  }
  .f-col{ padding: 6px 0; }

  /* Centrado suave en móvil */
  .f-brand, .f-links, .f-cta{
    text-align: left; /* cámbialo a center si prefieres */
  }

  .f-social-btn{ padding: 10px 12px; }

  /* Accesibilidad: reducir movimiento */
@media (prefers-reduced-motion: reduce){
  .f-link, .f-social-btn, .f-cta-btn{ transition: none; }

}



/* ---------- Fix puntual para móviles ~360px de ancho (Galaxy S8/S8+/S9) ---------- */
@media screen and (max-width: 360px){
  /* Da un pelín más de espacio lateral y evita que el padding “robe” ancho útil */
  .mobile-single{
    /*padding-left: 12px;
    padding-right: 12px;*/
    margin: 0;
    padding: 0;
    padding-left: 5px;
    width: 355px;
  }

  .promos-grid{
    grid-template-columns: 1fr;
    width: 100%;
    
  }

  /* Aísla el layout y evita artefactos de subpíxel */
  .promo-card{
    contain: layout paint;
  }

  /* Centrado y encuadre exacto dentro del marco 9:16 SIN corrimiento */
  .promo-media{
    position: relative;
    margin: 0;                  /* por si <figure> trae margen del user agent */
    display: block;
  }
  .promo-media img{
    position: absolute;         /* elimina cualquier “empuje” por flex */
    inset: 0;                   /* top/right/bottom/left = 0 */
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;   /* centrado perfecto */
    transform: translate3d(0,0,0); /* suaviza rounding en algunos navegadores */
    backface-visibility: hidden;
  }
}





}






