/* ═══════════════════════════════════════════════════════════════
   Banners patrocinados do Sondar — carrossel do hero + card na timeline.
   Feature isolada (não depende das vars de styles.css). Dorme até existir
   campanha com addon "Hero do Sondar" (sondar_addon=true).
═══════════════════════════════════════════════════════════════ */

/* ── Carrossel ── */
/* Base é "passthrough": sem clip/borda, pra o hero ficar IDÊNTICO ao original
   quando não há campanhas promovidas. O clipping/arredondamento só entra com
   --active (adicionado pelo JS quando há >1 slide). */
.promo-carousel { position: relative; }
/* Clipping/arredondamento vai no viewport interno (não no carrossel) — assim as
   setas podem ficar POR FORA do card sem serem cortadas pelo overflow. */
.promo-carousel--active .promo-carousel__viewport { overflow: hidden; border-radius: 16px; }
.promo-carousel__track {
  display: flex;
  align-items: stretch;
  transition: transform .45s cubic-bezier(.4, 0, .2, 1);
  will-change: transform;
}
.promo-slide { flex: 0 0 100%; min-width: 100%; }
/* Slide do hero mantém o visual original do banner do app. */
.promo-slide--hero { display: block; }

/* Slide patrocinado (banner de momento) */
.promo-slide--ad {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: 240px;
  text-decoration: none;
  color: #fff;
  overflow: hidden;
}
.promo-slide__bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform .6s ease;
}
.promo-slide--ad:hover .promo-slide__bg { transform: scale(1.04); }
.promo-slide__shade {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 35%, rgba(0, 0, 0, .78) 100%);
}
.promo-slide__badge {
  position: absolute; top: 14px; left: 14px;
  background: #EA580C; color: #fff;
  font-size: 11px; font-weight: 800; letter-spacing: .4px; text-transform: uppercase;
  padding: 4px 9px; border-radius: 6px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .25);
}
.promo-slide__content { position: relative; padding: 18px 20px; max-width: 80%; }
.promo-slide__title {
  margin: 0 0 4px; font-size: 22px; font-weight: 800; line-height: 1.2;
  text-shadow: 0 1px 8px rgba(0, 0, 0, .45);
}
.promo-slide__local {
  margin: 0 0 8px; font-size: 13px; opacity: .92;
  text-shadow: 0 1px 6px rgba(0, 0, 0, .45);
}
.promo-slide__cta {
  display: inline-block; font-size: 13px; font-weight: 700;
  background: rgba(255, 255, 255, .18); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  padding: 6px 12px; border-radius: 999px;
}

/* Setas */
.promo-carousel__arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255, 255, 255, .9); color: #1e1b2e;
  border: none; border-radius: 50%;
  cursor: pointer; z-index: 3;
  box-shadow: 0 2px 10px rgba(0, 0, 0, .18);
  transition: background .2s;
}
.promo-carousel__arrow:hover { background: #fff; }
.promo-carousel__arrow--prev { left: -22px; }
.promo-carousel__arrow--next { right: -22px; }
.promo-carousel__arrow[hidden] { display: none; }

/* Dots */
.promo-carousel__dots {
  position: absolute; bottom: 10px; left: 0; right: 0;
  display: flex; justify-content: center; gap: 6px; z-index: 3;
}
.promo-carousel__dots:empty { display: none; }
.promo-carousel__dot {
  width: 8px; height: 8px; border-radius: 50%; border: none; padding: 0;
  background: rgba(255, 255, 255, .55); cursor: pointer;
  transition: background .2s, width .2s;
}
.promo-carousel__dot.is-active { background: #fff; width: 20px; border-radius: 4px; }

/* ── Card patrocinado no meio da timeline ── */
.promo-timeline-card {
  display: flex; flex-direction: column;
  border-radius: 14px; overflow: hidden;
  background: #fff; text-decoration: none; color: inherit;
  border: 1px solid rgba(0, 0, 0, .08);
  box-shadow: 0 4px 16px rgba(0, 0, 0, .06);
  transition: transform .2s, box-shadow .2s;
}
.promo-timeline-card:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(0, 0, 0, .10); }
.promo-timeline-card__img { position: relative; height: 150px; background-size: cover; background-position: center; }
.promo-timeline-card__badge {
  position: absolute; top: 10px; left: 10px;
  background: #EA580C; color: #fff;
  font-size: 10px; font-weight: 800; letter-spacing: .4px; text-transform: uppercase;
  padding: 3px 8px; border-radius: 5px;
}
.promo-timeline-card__body { padding: 12px 14px; }
.promo-timeline-card__title { margin: 0 0 4px; font-size: 15px; font-weight: 800; color: #1e1b2e; line-height: 1.25; }
.promo-timeline-card__local { margin: 0; font-size: 12px; color: #6b6b7b; }

@media (max-width: 640px) {
  .promo-slide--ad { min-height: 180px; }
  .promo-slide__title { font-size: 18px; }
  .promo-carousel__arrow { width: 32px; height: 32px; }
  /* Gutter pequeno no mobile: setas voltam pra dentro pra não serem cortadas. */
  .promo-carousel__arrow--prev { left: 6px; }
  .promo-carousel__arrow--next { right: 6px; }
}
