/*
 * Карусель промо-баннеров — лендинг и страница меню магазина.
 * Единственный источник правды: дубль из ProductList.css удалён.
 */

.promo-section {
  padding: 0;
  background: var(--bg-muted, #f8fafc);
}

.promo-banners {
  overflow: hidden;
}

.promo-banners .carousel {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 0 16px 4px;
  scrollbar-width: none;
  -ms-overflow-style: none;
  max-width: 1100px;
  margin: 0 auto;
}

.promo-banners .carousel::-webkit-scrollbar {
  display: none;
}

/* Мобилка: один баннер на всю ширину */
.promo-banner {
  flex: 0 0 calc(100% - 32px);
  aspect-ratio: 16 / 9;
  position: relative;
  background: var(--bg-subtle, #f3f4f6);
  border-radius: var(--radius-sm, 8px);
  scroll-snap-align: start;
  overflow: hidden;
  cursor: pointer;
}

/* Desktop: два баннера в видимой зоне */
@media (min-width: 768px) {
  .promo-banner {
    flex: 0 0 calc((100% - 8px) / 2 - 16px);
    aspect-ratio: 16 / 7;
  }
}

.promo-banner .promo-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
  transition: transform 0.3s ease;
}

.promo-banner:hover .promo-image {
  transform: scale(1.02);
}

/* Пустой баннер (нет картинки) */
.promo-banner--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: var(--gray-light, #94a3b8);
  background: var(--bg-muted, #f8fafc);
}
