.scrollTopBtn {
  position: fixed;
  bottom: 20px;
  right: 20px;
  opacity: 0;
  z-index: 9999;
  border-radius: 5px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}
.scrollTopBtn.visible {
  display: block;
  opacity: 1;
}

/* Scroll horizontal general (para destacados y fin de temporada) */
.scroll-container {
  display: flex;
  overflow-x: auto;
  gap: 1rem;
  scroll-snap-type: x mandatory;
  padding: 8px;
  margin-bottom: 20px;

}
.scroll-container > * {
  flex: 0 0 auto; /* mantener tamaño */
  min-width: 150px; /* ejemplo de ancho mínimo de producto */
}
.scroll-container::-webkit-scrollbar {
  height: 6px;
}

.scroll-container::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 3px;
}

/** ancho extra para siempre permitir scrollear un poco */
/*
.scroll-container::after {
  content: '';
  flex: 0 0 500px; 
}
*/

.scroll-container .product-card {
  flex: 0 0 160px; /* ancho base */
  scroll-snap-align: start;
}

/* Tarjetas generales */
.product-card {
  border: 1px solid #ddd;
  border-radius: 8px;
  height: 310px;
  overflow: hidden;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
  transition: transform 0.3s ease;
  cursor: pointer;
  background: #fff;
  position: relative;
}

.product-card:hover {
  transform: scale(1.05);
}

.product-card img.product-image {
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 8px 8px 0 0;
}

.product-name {
  white-space: nowrap; /* evita saltos de línea */
  overflow: hidden; /* oculta el resto del texto */
  text-overflow: ellipsis; /* añade los ... */
  display: block; /* asegúrate de que se comporte como bloque */
  max-width: 100%; /* o el ancho máximo que quieras */
}

.price-text {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
}

.price-text .old-price {
  font-size: 1rem; /* más pequeño que el precio de descuento */
  text-decoration: line-through;
  color: #6c757d; /* gris */
}

.price-text .discount-price {
  font-size: 1.3rem; /* más grande que el tachado */
  font-weight: 700;
  color: #3aa66d; /* verde destacado */
}

.price-per-kg {
  font-size: 0.9rem;
  display: block;
  margin-top: 2px;
}

/* --- DESTACADOS --- */
.product-card.destacado {
  border: 2px solid #3aa66d;
  background-color: #dff6ef;
  flex: 0 0 160px;
}

.product-card.destacado .product-image {
  height: 110px;
}

/* --- RESTO (grid normal) --- */
.product-card.resto img {
  max-height: 160px;
}

/* --- FIN DE TEMPORADA --- */
.product-card.fin {
  border: 2px solid #d63b3b;
  flex: 0 0 160px;
}

.product-card.fin .product-image {
  height: 110px;
}

/* --- Badges comunes --- */
.product-destacado-badge,
.flash-badge,
.fin-badge,
.product-card.fin.badge {
  position: absolute;
  top: 8px;
  right: 8px;
  border-radius: 4px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
}
