/* Shared hero styles for feature / persona landing pages */
.eventos-hero,
.convites-hero,
.convidados-hero,
.lista-presentes-hero,
.presentes-hero,
.marketplace-hero,
.tarefas-hero,
.portaria-hero,
.sobre-hero,
.organizadores-hero,
.fornecedores-hero,
.convidados-page-hero,
.aplicativo-hero,
.contato-hero,
.suporte-hero {
  position: relative;
  overflow: hidden;
  background: var(--gradient-hero);
  color: var(--color-text-primary);
  padding: var(--spacing-3xl) 0;
  text-align: center;
  border-bottom: 1px solid var(--color-border-light);
}

/* Keep hero content above the decorative glows */
.eventos-hero > .container,
.convites-hero > .container,
.convidados-hero > .container,
.lista-presentes-hero > .container,
.presentes-hero > .container,
.marketplace-hero > .container,
.tarefas-hero > .container,
.portaria-hero > .container,
.sobre-hero > .container,
.organizadores-hero > .container,
.fornecedores-hero > .container,
.convidados-page-hero > .container,
.aplicativo-hero > .container,
.contato-hero > .container,
.suporte-hero > .container {
  position: relative;
  z-index: 1;
}

/* Decorative soft glow orbs — pure CSS, no per-page markup needed */
.eventos-hero::before,
.convites-hero::before,
.convidados-hero::before,
.lista-presentes-hero::before,
.presentes-hero::before,
.marketplace-hero::before,
.tarefas-hero::before,
.portaria-hero::before,
.sobre-hero::before,
.organizadores-hero::before,
.fornecedores-hero::before,
.convidados-page-hero::before,
.aplicativo-hero::before,
.contato-hero::before,
.suporte-hero::before {
  content: '';
  position: absolute;
  top: -160px;
  right: -120px;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--color-brand-coral) 0%, transparent 70%);
  filter: blur(70px);
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
  animation: float 18s ease-in-out infinite;
}

.eventos-hero::after,
.convites-hero::after,
.convidados-hero::after,
.lista-presentes-hero::after,
.presentes-hero::after,
.marketplace-hero::after,
.tarefas-hero::after,
.portaria-hero::after,
.sobre-hero::after,
.organizadores-hero::after,
.fornecedores-hero::after,
.convidados-page-hero::after,
.aplicativo-hero::after,
.contato-hero::after,
.suporte-hero::after {
  content: '';
  position: absolute;
  bottom: -180px;
  left: -120px;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--color-brand-purple-mid) 0%, transparent 70%);
  filter: blur(70px);
  opacity: 0.18;
  pointer-events: none;
  z-index: 0;
  animation: float 22s ease-in-out infinite;
  animation-delay: -6s;
}

.eventos-hero-title,
.convites-hero-title,
.convidados-hero-title,
.lista-presentes-hero-title,
.marketplace-hero-title,
.sobre-hero-title,
.organizadores-hero-title,
.fornecedores-hero-title,
.convidados-page-hero-title,
.aplicativo-hero-title,
.contato-hero-title,
.suporte-hero-title,
[class$="-hero-title"] {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
  text-shadow: none;
  letter-spacing: -0.02em;
}

[class$="-hero-title"] .highlight {
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: none;
}

[class$="-hero-description"] {
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  text-shadow: none;
  max-width: 720px;
  margin: 0 auto;
}

/* ============================================
   Persona heros — two-column (text + photo)
   ============================================ */
.persona-hero {
  text-align: left;
  padding: var(--spacing-4xl) 0;
}

.persona-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-3xl);
  align-items: center;
}

.persona-hero__content {
  max-width: 560px;
}

/* Override the centered description default for the two-column layout */
.persona-hero .persona-hero__content [class$="-hero-description"] {
  margin: 0;
  max-width: none;
}

.persona-hero__visual {
  position: relative;
}

.persona-hero__img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--color-border);
}

@media (max-width: 1024px) {
  .persona-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-2xl);
  }

  .persona-hero__content {
    max-width: none;
  }

  .persona-hero__img {
    aspect-ratio: 16 / 9;
  }
}

/* ============================================
   Universal card hover elevation for internal pages.
   feature-pages.css loads last, so these win the cascade
   over per-page card rules. Transform/shadow only —
   safe regardless of each card's own colours.
   ============================================ */
.feature-card,
.evento-card,
.diferencial-card,
.compromisso-card,
.missao-card,
.quick-action-card,
.status-card,
.plano-card {
  transition: transform var(--transition-base) var(--ease-out),
    border-color var(--transition-fast), box-shadow var(--transition-base);
}

.feature-card:hover,
.evento-card:hover,
.diferencial-card:hover,
.compromisso-card:hover,
.missao-card:hover,
.quick-action-card:hover,
.status-card:hover,
.plano-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lift);
}

/* Subtle icon pop on card hover where a feature-icon exists */
.feature-card:hover .feature-icon {
  transform: scale(1.06);
}

/* Featured plan: keep its emphasis but add the lift on hover */
.plano-card.featured:hover {
  box-shadow: var(--shadow-glow-purple);
}
