/* Sale page specific styles (scoped class names) */

/* Horizontal scroller wrapper (full-bleed) */
.sale-cards-wrap {
  margin-top: 28px;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  --sale-cards-left-pad: max(20px, calc((100vw - 1240px) / 2 + 20px));
  --sale-cards-right-pad: max(20px, calc((100vw - 1240px) / 2 + 20px));
}

/* Horizontal card list */
.sale-cards {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(280px, 44%);
  gap: 20px;
  overflow-x: auto;
  overflow-y: visible;
  /* extra vertical padding so shadows aren't clipped */
  padding: 24px var(--sale-cards-right-pad) 72px var(--sale-cards-left-pad);
  scroll-snap-type: x mandatory;
  scroll-padding-left: var(--sale-cards-left-pad);
  scroll-padding-right: var(--sale-cards-right-pad);
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.sale__subtitle {
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-top: 10px;
  color: white;
}

.sale-cards::-webkit-scrollbar {
  display: none;
  height: 0;
}

/* Offer card (black translucent) */
.offer-card {
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  /* match button pill radius offset by card padding */
  --card-pad: 32px;
  --cta-font-size: 15px;
  --cta-line-height: 1;
  --cta-vpad: 10px;
  border-radius: calc(((var(--cta-font-size) * var(--cta-line-height)) + (var(--cta-vpad) * 2)) / 2 + var(--card-pad));
  border: none;
  box-shadow: none;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: var(--card-pad);
  text-decoration: none;
}

.offer-card:hover {
  background: rgba(0, 0, 0, 0.62);
  border-color: rgba(255, 255, 255, 0.18);
}

.offer-card__body {
  margin: 0;
}

.offer-card__title {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 0 0 6px 0;
  color: #fff;
}

.offer-card__text {
  font-size: 15px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.85);
  font-weight: 500;
  margin: 0 0 8px 0;
}

/* Keep CTAs tidy inside cards */
.offer-card .hero-cta {
  align-self: flex-start;
  margin-top: 6px;
}

/* Wider cards on larger screens for rhythm */
@media (min-width: 900px) {
  .sale-cards {
    grid-auto-columns: minmax(320px, 36%);
  }
}

/* Vertical layout on narrow screens */
@media (max-width: 640px) {
  .sale-cards-wrap {
    /* full-bleed so cards can use the whole viewport width */
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
  }

  .sale-cards {
    grid-auto-flow: row;
    grid-auto-columns: initial;
    grid-template-columns: 1fr;
    overflow-x: visible;
    scroll-snap-type: none;
    /* 100% width minus 16pt side padding */
    padding: 12px 16pt 20px;
  }

  /* widen inner content by reducing card-side padding on small screens */
  .offer-card {
    width: 100%;
    --card-pad: 20px;
  }
}