/* promo-popup.css — timed promotional popup */

/* ── Overlay ──────────────────────────────────────────────────── */

.promo-overlay {
  position: fixed;
  inset: 0;
  z-index: 450; /* above modal (400), below nothing */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-5);
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  /* Hidden state */
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.4s ease,
    visibility 0.4s ease;
}

.promo-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

/* ── Card ─────────────────────────────────────────────────────── */

.promo-card {
  position: relative;
  width: 100%;
  max-width: 480px;

  /* Height: image-driven, capped for every screen */
  min-height: 380px;
  max-height: 85svh;
  max-height: 85vh; /* fallback for browsers without svh */

  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.45),
    0 12px 30px rgba(0, 0, 0, 0.25);

  /* Entry animation */
  transform: scale(0.94) translateY(20px);
  transition:
    transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1),
    opacity   0.45s ease;
  opacity: 0;
}

.promo-overlay.is-visible .promo-card {
  transform: scale(1) translateY(0);
  opacity: 1;
}

/* Exit animation class added by JS */
.promo-overlay.is-closing .promo-card {
  transform: scale(0.96) translateY(10px);
  opacity: 0;
  transition:
    transform 0.25s ease,
    opacity   0.25s ease;
}

/* ── Background image layer ───────────────────────────────────── */

.promo-card__bg {
  position: absolute;
  inset: 0;
  background-image: var(--promo-bg-image);
  background-size: cover;
  background-position: center top;
  z-index: 0;

  /* Subtle Ken Burns feel — optional, very slow */
  animation: promoBgFloat 14s ease-in-out infinite alternate;
}

@keyframes promoBgFloat {
  from { transform: scale(1);    }
  to   { transform: scale(1.04); }
}

/* ── Gradient overlay for text legibility ─────────────────────── */

.promo-card__gradient {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.92)  0%,
    rgba(0, 0, 0, 0.65) 40%,
    rgba(0, 0, 0, 0.15) 75%,
    rgba(0, 0, 0, 0.05) 100%
  );
}

/* ── Close button ─────────────────────────────────────────────── */

.promo-card__close {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  z-index: 3;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: var(--clr-white);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    background var(--transition-fast),
    transform  var(--transition-fast);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.promo-card__close:hover {
  background: rgba(255, 255, 255, 0.26);
  transform: scale(1.1);
}

.promo-card__close svg {
  pointer-events: none;
  flex-shrink: 0;
}

/* ── Content ──────────────────────────────────────────────────── */

.promo-card__content {
  position: relative;
  z-index: 2;

  /* Fill full card height, push text to bottom */
  min-height: inherit;
  max-height: inherit;
  overflow-y: auto;
  scrollbar-width: none;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;

  padding: var(--sp-8);
  padding-top: var(--sp-16); /* top breathing room so it doesn't crowd close btn */
}

.promo-card__content::-webkit-scrollbar {
  display: none;
}

/* ── Chip label ───────────────────────────────────────────────── */

.promo-card__chip {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-family);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-white);
  background: var(--grad-accent);
  background: -webkit-linear-gradient(135deg, #ff4d1a 0%, #e5197a 100%);
  background: linear-gradient(135deg, #ff4d1a 0%, #e5197a 100%);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-4);
  width: fit-content;
}

/* ── Title ────────────────────────────────────────────────────── */

.promo-card__title {
  font-family: var(--font-family);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-3xl);
  line-height: var(--leading-tight);
  color: var(--clr-white);
  margin-bottom: var(--sp-3);
}

@media (max-width: 380px) {
  .promo-card__title { font-size: var(--text-2xl); }
}

/* ── Subtitle ─────────────────────────────────────────────────── */

.promo-card__subtitle {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: var(--sp-7);
  max-width: 36ch;
}

/* ── CTA area ─────────────────────────────────────────────────── */

.promo-card__cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-4);
}

/* Badge override — slightly larger in popup context */
.promo-card__cta .badge-link img {
  height: 3.5rem;
}

.promo-card__cta-note {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.45);
}

/* ── Mobile adjustments ───────────────────────────────────────── */

@media (max-width: 480px) {
  .promo-overlay {
    padding: var(--sp-4);
    align-items: flex-end; /* slide up from bottom on mobile */
    padding-bottom: var(--sp-6);
  }

  .promo-card {
    max-width: 100%;
    min-height: 340px;
    border-radius: var(--radius-2xl);

    /* Bottom-sheet entry on mobile */
    transform: scale(1) translateY(40px);
  }

  .promo-overlay.is-visible .promo-card {
    transform: scale(1) translateY(0);
  }

  .promo-card__content {
    padding: var(--sp-6);
    padding-top: var(--sp-14);
  }

  .promo-card__title {
    font-size: var(--text-2xl);
  }
}

/* ── Landscape + short viewport safety ───────────────────────── */

@media (max-height: 500px) {
  .promo-card {
    min-height: 0;
    max-height: 90svh;
    max-height: 90vh;
  }

  .promo-card__content {
    padding-top: var(--sp-10);
    padding-bottom: var(--sp-5);
  }

  .promo-card__subtitle {
    display: none; /* collapse subtitle on very short screens */
  }
}
