/* ========================================
   Banner — Condição Especial Disney
   ======================================== */

.disney {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: stretch;
  padding: 0;
  margin-bottom: clamp(3rem, 6vw, 5rem);
  background:
    radial-gradient(circle at 85% 15%, rgba(217, 117, 72, 0.35), transparent 55%),
    radial-gradient(circle at 10% 100%, rgba(201, 163, 91, 0.18), transparent 50%),
    linear-gradient(135deg, #0a1e2e 0%, #143850 100%);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  isolation: isolate;
  color: #fff;
}

/* ---- Faísca decorativa ---- */
.disney::before,
.disney::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.disney::before {
  top: -120px; right: -80px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(255, 220, 170, 0.25), transparent 70%);
  filter: blur(20px);
}
.disney::after {
  bottom: -100px; left: 30%;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(217, 117, 72, 0.25), transparent 70%);
  filter: blur(30px);
}

/* ---- Mídia ---- */
.disney__media {
  position: relative;
  min-height: 360px;
  overflow: hidden;
}
.disney__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.02);
  transition: transform var(--t-slow);
}
.disney:hover .disney__media img {
  transform: scale(1.04);
}
.disney__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 50%, #0a1e2e 100%);
  pointer-events: none;
}

.disney__badge {
  position: absolute;
  top: 22px;
  left: 22px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-ink);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.18);
  z-index: 2;
}
.disney__badge::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 0 4px rgba(217, 117, 72, 0.22);
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(217, 117, 72, 0.22); }
  50%      { box-shadow: 0 0 0 8px rgba(217, 117, 72, 0.05); }
}

/* ---- Body ---- */
.disney__body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding: clamp(2rem, 4vw, 3rem) clamp(2rem, 4vw, 3.5rem) clamp(2rem, 4vw, 3rem) 0;
}

.disney__body .eyebrow {
  color: var(--color-accent-2);
  margin-bottom: 0;
}
.disney__body .eyebrow::before {
  background: var(--color-accent-2);
}

.disney__title {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 3.4vw, 2.75rem);
  font-weight: 600;
  line-height: 1.05;
  color: #fff;
  letter-spacing: -0.02em;
}
.disney__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-accent-2);
}

.disney__lead {
  font-size: var(--fs-md);
  color: rgba(255, 255, 255, 0.78);
  max-width: 46ch;
  margin-top: -4px;
}

/* ---- Features ---- */
.disney__features {
  display: grid;
  gap: 10px;
  margin-block: var(--space-2);
}
.disney__features li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.92);
}
.disney__features li svg {
  flex-shrink: 0;
  width: 20px; height: 20px;
  padding: 4px;
  border-radius: 50%;
  background: rgba(217, 117, 72, 0.18);
  color: var(--color-accent-2);
}

/* ---- CTA strip ---- */
.disney__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  flex-wrap: wrap;
  padding-top: var(--space-5);
  margin-top: auto;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.disney__price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.disney__from {
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
.disney__value {
  font-family: var(--font-serif);
  font-size: 2.25rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1;
}
.disney__parcel {
  font-size: var(--fs-sm);
  color: rgba(255, 255, 255, 0.7);
  margin-top: 2px;
}
.disney__parcel strong {
  color: #fff;
  font-weight: 600;
}

.disney .btn--primary {
  padding: 16px 28px;
  font-size: 0.95rem;
}

/* ---- Countdown ---- */
.disney__timer {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
}
.disney__timer-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-2);
}
.disney__timer-label::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(217, 117, 72, 0.25);
  animation: pulse 1.8s ease-in-out infinite;
}
.disney__timer-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.disney__timer-grid > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 6px;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.disney__timer-grid strong {
  font-family: var(--font-serif);
  font-size: 1.65rem;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.disney__timer-grid span {
  margin-top: 4px;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}

/* ---- Selo Parceiro ---- */
.disney__partner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(201, 163, 91, 0.08);
  border: 1px solid rgba(201, 163, 91, 0.22);
}
.disney__partner svg {
  flex-shrink: 0;
  color: var(--color-gold);
  fill: rgba(201, 163, 91, 0.18);
}
.disney__partner div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.disney__partner strong {
  font-size: 0.82rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.01em;
}
.disney__partner span {
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.6);
}

/* ========================================
   Faixa de companhias aéreas parceiras
   ======================================== */
.partners {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 3vw, 2.5rem);
  padding: var(--space-5) clamp(1.5rem, 3vw, 2rem);
  margin-bottom: clamp(3rem, 6vw, 5rem);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
}
.partners__label {
  flex-shrink: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
  padding-right: clamp(1rem, 3vw, 2rem);
  border-right: 1px solid var(--color-line);
}
.partners__list {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-around;
  gap: clamp(1rem, 3vw, 2rem);
}
.partners__logo {
  display: inline-block;
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: 0.04em;
  color: var(--color-ink-soft);
  opacity: 0.6;
  transition: opacity var(--t-base), color var(--t-base), transform var(--t-base);
  white-space: nowrap;
}
.partners__list li:hover .partners__logo {
  opacity: 1;
  color: var(--color-ink);
  transform: translateY(-1px);
}
/* Microestilo distintivo por marca (sem usar logos oficiais) */
.partners__logo--latam   { font-style: italic; letter-spacing: 0.18em; }
.partners__logo--american{ font-weight: 600; letter-spacing: 0.01em; font-family: var(--font-serif); }
.partners__logo--azul    { color: #1f6fbf; letter-spacing: 0.12em; }
.partners__logo--gol     { color: #d97548; letter-spacing: 0.16em; }
.partners__logo--copa    { font-weight: 700; letter-spacing: 0.2em; }
.partners__list li:hover .partners__logo--azul,
.partners__list li:hover .partners__logo--gol  { color: inherit; opacity: 1; }

@media (max-width: 768px) {
  .partners {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-4);
  }
  .partners__label {
    padding-right: 0;
    border-right: 0;
    text-align: center;
  }
  .partners__list { justify-content: center; }
}

@media (max-width: 480px) {
  .disney__timer-grid strong { font-size: 1.3rem; }
  .disney__timer-grid > div { padding: 8px 4px; }
}

/* ---- Responsivo ---- */
@media (max-width: 860px) {
  .disney {
    grid-template-columns: 1fr;
  }
  .disney__media {
    min-height: 220px;
    aspect-ratio: 16 / 9;
  }
  .disney__media::after {
    background: linear-gradient(180deg, transparent 40%, #0a1e2e 100%);
  }
  .disney__body {
    padding: 0 clamp(1.5rem, 5vw, 2.5rem) clamp(2rem, 5vw, 2.5rem);
    margin-top: -40px;
  }
}

@media (max-width: 480px) {
  .disney__cta { flex-direction: column; align-items: stretch; }
  .disney .btn--primary { width: 100%; }
}
