/* ================================================================
   DMB Product Carousel — CSS scroll-snap
   Converts .featured-products, .new-products, .viewed-products
   grids into horizontally scrollable carousels
   ================================================================ */

/* ---- Carousel wrapper (applied by JS) ---- */
.dmb-carousel {
  position: relative;
}

/* ---- Track: the scrollable row ---- */
.dmb-carousel .dmb-carousel__track {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  gap: var(--grid-gap-tight, 1rem);
  padding: 0 0 var(--sp-4) 0;

  /* Hide scrollbar */
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.dmb-carousel .dmb-carousel__track::-webkit-scrollbar {
  display: none;
}

/* ---- Slides ---- */
.dmb-carousel .dmb-carousel__track > * {
  flex: 0 0 var(--dmb-slide-width, 280px) !important;
  width: var(--dmb-slide-width, 280px) !important;
  min-width: 0 !important;
  max-width: var(--dmb-slide-width, 280px) !important;
  scroll-snap-align: start;
  box-sizing: border-box !important;
}

/* Responsive slide widths
   Formula: (container - (N-1)*gap) / N
   gap = 1rem (track gap), container ≈ 100vw - 2*1.25rem page padding */
@media (max-width: 575px) {
  .dmb-carousel .dmb-carousel__track > * {
    --dmb-slide-width: calc((100vw - 2.5rem - 1rem) / 1.5);
  }
}

@media (min-width: 576px) and (max-width: 767px) {
  .dmb-carousel .dmb-carousel__track > * {
    --dmb-slide-width: calc((100vw - 2.5rem - 1rem) / 2);
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .dmb-carousel .dmb-carousel__track > * {
    --dmb-slide-width: calc((100vw - 2.5rem - 2rem) / 3);
  }
}

@media (min-width: 992px) and (max-width: 1399px) {
  .dmb-carousel .dmb-carousel__track > * {
    --dmb-slide-width: calc((100vw - 2.5rem - 3rem) / 4);
  }
}

@media (min-width: 1400px) {
  .dmb-carousel .dmb-carousel__track > * {
    --dmb-slide-width: calc((min(100vw, 1320px) - 3rem) / 4);
  }
}

/* ---- Navigation arrows ---- */
.dmb-carousel__nav {
  position: absolute;
  top: 0;
  bottom: var(--sp-4);
  width: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  cursor: pointer;
  background: transparent;
  border: none;
  padding: 0;
  opacity: 0;
  transition: opacity 200ms ease;
  pointer-events: none;
}

.dmb-carousel:hover .dmb-carousel__nav {
  opacity: 1;
  pointer-events: auto;
}

.dmb-carousel__nav--prev {
  left: -24px;
}

.dmb-carousel__nav--next {
  right: -24px;
}

/* Arrow icon */
.dmb-carousel__nav-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-bg, #f5f0ea);
  border: 2px solid var(--c-text, #101820);
  color: var(--c-text, #101820);
  transition: background 150ms ease, color 150ms ease;
}

.dmb-carousel__nav:hover .dmb-carousel__nav-icon {
  background: var(--c-text, #101820);
  color: var(--c-bg, #f5f0ea);
}

.dmb-carousel__nav-icon svg {
  width: 18px;
  height: 18px;
}

/* Hide arrow when at boundary */
.dmb-carousel__nav--hidden {
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ---- Progress dots (optional, mobile) ---- */
.dmb-carousel__dots {
  display: flex;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-2) 0 0;
}

.dmb-carousel__dot {
  width: 6px;
  height: 6px;
  border: 1.5px solid var(--c-text, #101820);
  background: transparent;
  padding: 0;
  cursor: pointer;
  transition: background 200ms ease;
}

.dmb-carousel__dot.-active {
  background: var(--c-text, #101820);
}

/* Show dots only on mobile */
@media (min-width: 768px) {
  .dmb-carousel__dots {
    display: none;
  }
}

/* ---- Section header with arrows inline ---- */
.dmb-carousel .dmb-carousel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-4);
}

.dmb-carousel .dmb-carousel__header .section-title,
.dmb-carousel .dmb-carousel__header h2 {
  margin: 0 !important;
}

.dmb-carousel__header-nav {
  display: flex;
  gap: var(--sp-2);
}

.dmb-carousel__header-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 2px solid rgba(16, 24, 32, 0.15);
  color: var(--c-text, #101820);
  cursor: pointer;
  padding: 0;
  transition: border-color 200ms ease, background 200ms ease, color 200ms ease;
}

.dmb-carousel__header-btn:hover {
  border-color: var(--c-text, #101820);
  background: var(--c-text, #101820);
  color: var(--c-bg, #f5f0ea);
}

.dmb-carousel__header-btn:disabled {
  opacity: 0.2;
  cursor: default;
  pointer-events: none;
}

.dmb-carousel__header-btn svg {
  width: 16px;
  height: 16px;
}

/* ---- Footer links ---- */
.dmb-carousel .featured-products-footer,
.dmb-carousel .new-products-footer {
  margin-top: var(--sp-4);
}
