/* Related products slider (best sellers) */
.related-slider { position: relative; }

/* Ensure the dedicated related slider uses the full width without theme padding */
.related-wrapper .related.products {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.related-slider-viewport {
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x proximity; /* avoid over-aggressive snapping that can crop by 1px */
  max-width: 100%;
  padding-bottom: 70px;
  -ms-overflow-style: none;       /* IE/Edge */
  scrollbar-width: none;          /* Firefox */
}
.related-slider-viewport::-webkit-scrollbar { display: none; }

.related-slider .products {
  --slider-gap: 16px;
  --slider-fudge: 12px; /* small per-item subtraction to avoid clipping */
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
  gap: var(--slider-gap);
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
}

/* Item widths per breakpoint: 1 mobile, 2 tablet, 3 desktop */
.related-slider .products > li.product {
  /* 3 items per page: subtract 2 gaps and 3x fudge (per item) */
  --_w: calc((100% - (2 * var(--slider-gap)) - (3 * var(--slider-fudge))) / 3);
  flex: 0 0 var(--_w) !important;
  width: var(--_w) !important;
  max-width: var(--_w) !important;
  margin: 0 !important; /* avoid default Woo spacing breaking stride */
  margin-right: 0 !important;
  margin-left: 0 !important;
  scroll-snap-align: start;
  box-sizing: border-box;
}
@media (max-width: 1023px) {
  /* 2 items per page: subtract 1 gap and 2x fudge (per item) */
  .related-slider .products > li.product { --_w: calc((100% - var(--slider-gap) - (2 * var(--slider-fudge))) / 2); flex-basis: var(--_w) !important; width: var(--_w) !important; max-width: var(--_w) !important; margin-right: 0 !important; }
}
@media (max-width: 639px) {
  .related-slider-viewport {
    padding: 0 16px 20px;
    scroll-snap-type: x mandatory;
    scroll-padding: 0 16px;
  }

  .related-slider .related-nav {
    display: none !important;
  }

  .related-slider .products {
    --slider-gap: 18px;
    --slider-fudge: 6px;
    justify-content: flex-start !important;
  }

  /* Show ~1.4 cards but keep first fully visible */
  .related-slider .products > li.product {
    --_w: calc(85% - var(--slider-gap));
    flex-basis: var(--_w) !important;
    width: var(--_w) !important;
    max-width: var(--_w) !important;
    scroll-snap-align: center;
  }

  .related-slider .products > li.product:first-child {
    margin-left: calc(16px) !important;
  }

  .related-slider .products > li.product:last-child {
    margin-right: calc(16px) !important;
  }
}


/* Nav buttons */
.related-slider {
  position: relative;
}

.related-slider .related-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,0.15);
  background: #fff;
  color: #111;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 5;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

.related-slider .related-prev { left: -45px; }
.related-slider .related-next { right: -45px; }

/* Remove bleeding; keep arrows outside without overlapping cards */

@media (max-width: 1023px) {
  .related-slider .related-prev { left: -30px; }
  .related-slider .related-next { right: -30px; }
}
@media (max-width: 639px) {
  .related-slider .related-prev { left: -20px; }
  .related-slider .related-next { right: -20px; }
}

.related-slider .related-nav:disabled {
  opacity: 0.4;
  cursor: default;
}

/* Ensure product cards don't stretch awkwardly inside flex */
.related-slider .products > li.product > * {
  height: auto;
}

/* Keep add-to-cart button fully visible inside the slide */
.related-slider li.product .button-container {
  bottom: -44px !important;
  left: 50% !important;
  transform: translateX(-50%);
}

@media (max-width: 639px) {
  .related-slider li.product .button-container {
    bottom: -36px !important;
  }
}
