/* ==========================================================================
   Ticker — Animated scrolling ribbon
   ========================================================================== */

.ticker {
  width: 100%;
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-blue) 100%);
  border-bottom: 2px solid var(--color-lime);
  overflow: hidden;
  white-space: nowrap;
}

.ticker__track {
  display: inline-flex;
  width: max-content;
  animation: ticker-scroll 30s linear infinite;
}

.ticker__content {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-8);
  font-size: var(--text-sm);
  color: var(--color-white);
  white-space: nowrap;
}

.ticker__content strong {
  color: var(--color-lime);
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
}

.ticker__icon {
  flex-shrink: 0;
  color: var(--color-lime);
}

@keyframes ticker-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* Pause on hover for readability */
.ticker:hover .ticker__track {
  animation-play-state: paused;
}

@media (max-width: 767px) {
  .ticker__content {
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-6);
  }
}

/* ==========================================================================
   Promo Banner — Web banner / seasonal promo
   Tamaño imagen: 2400×600 px (4:1 ratio, retina)
   Para ocultar: agregar .is-hidden al <section>
   Para cambiar imagen: editar <img src> en index.html
   ========================================================================== */

.promo-banner {
  width: 100%;
  background-color: var(--color-navy);
  overflow: hidden;
}

.promo-banner.is-hidden {
  display: none;
}

.promo-banner__link {
  position: relative;
  display: block;
  width: 100%;
  line-height: 0;
  aspect-ratio: 4 / 1;
  max-height: 480px;
  text-decoration: none;
}

.promo-banner__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* ---- Text overlay (sobre el espacio negativo de la imagen) ---- */
.promo-banner__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding-inline: clamp(var(--space-6), 6vw, var(--space-16));
  padding-block: var(--space-6);
  line-height: var(--line-height-normal);
  max-width: 60%;
  pointer-events: none;
}

.promo-banner__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-2xl), 4vw, var(--text-5xl));
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  letter-spacing: var(--letter-spacing-tight);
  line-height: 1.1;
  margin: 0 0 var(--space-3);
  text-shadow: 0 2px 24px rgba(10, 22, 40, 0.6);
}

.promo-banner__subtitle {
  font-family: var(--font-body);
  font-size: clamp(var(--text-sm), 1.4vw, var(--text-lg));
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.92);
  max-width: 38ch;
  margin: 0;
  text-shadow: 0 2px 16px rgba(10, 22, 40, 0.6);
}

/* Sutil acento lime debajo del título */
.promo-banner__title::after {
  content: "";
  display: block;
  width: clamp(40px, 5vw, 64px);
  height: 3px;
  background: var(--color-lime);
  margin-top: var(--space-3);
  border-radius: 2px;
}

/* ---- Responsive: en mobile el banner es más alto (3:1) ---- */
@media (max-width: 767px) {
  .promo-banner__link {
    aspect-ratio: 3 / 1;
    max-height: 280px;
  }

  .promo-banner__overlay {
    max-width: 70%;
    padding-inline: var(--space-5);
  }

  .promo-banner__title {
    font-size: clamp(var(--text-lg), 4.5vw, var(--text-2xl));
  }

  .promo-banner__subtitle {
    font-size: clamp(var(--text-xs), 2.5vw, var(--text-sm));
  }
}
