/* ============================================================
   Página de Eventos (e contato) — extensões
   ============================================================ */

.page-hero {
  background: var(--bg-dark-deep);
  color: var(--color-text);
  padding-top: clamp(8rem, 14vh, 11rem);
  padding-bottom: clamp(4rem, 8vw, 7rem);
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--line-dark);
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 80% 30%, rgba(245,143,39,0.10) 0%, transparent 60%),
    radial-gradient(40% 40% at 20% 80%, rgba(245,143,39,0.06) 0%, transparent 60%);
}
.page-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--s-8);
  max-width: 56rem;
}
.page-hero h1 {
  font-size: clamp(2.5rem, 1.8rem + 3vw, 4.5rem);
  line-height: 1.02;
  letter-spacing: -0.035em;
  font-weight: 300;
  max-width: 18ch;
}
.page-hero h1 em {
  font-style: italic;
  color: var(--color-accent);
  font-weight: 300;
}
.page-hero p {
  font-size: clamp(1.05rem, 0.95rem + 0.4vw, 1.3rem);
  color: var(--color-text-muted);
  line-height: 1.55;
  max-width: 46rem;
  font-weight: 300;
}

/* ─── Lista completa de eventos (grid de categorias) ─── */
.events-full {
  background: var(--bg-light);
}
.events-full__grid {
  display: grid;
  gap: var(--s-16);
}
.events-full__group {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--s-10);
  padding-bottom: var(--s-12);
  border-bottom: 1px solid var(--line-light);
}
.events-full__group:last-child { border-bottom: 0; }
.events-full__group header {
  position: sticky;
  top: 120px;
  align-self: start;
}
.events-full__group h2 {
  font-size: clamp(1.75rem, 1.3rem + 1.8vw, 2.5rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  font-weight: 500;
  margin-top: 0.75rem;
}
.events-full__group h2 em {
  font-style: normal;
  color: var(--color-accent);
  font-weight: 600;
}

/* Content column = placeholder + list */
.events-full__content {
  display: grid;
  gap: var(--s-6);
}
.events-full__placeholder {
  aspect-ratio: 16 / 7;
  background: linear-gradient(135deg, var(--bg-light-warm) 0%, var(--bg-light-elevated) 100%);
  border: 1px dashed var(--line-light-strong);
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.75rem;
  padding: 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.events-full__placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 25% 35%, rgba(245,143,39,0.08) 0%, transparent 70%),
    radial-gradient(50% 60% at 75% 65%, rgba(13,13,13,0.04) 0%, transparent 70%);
  pointer-events: none;
}
.events-full__placeholder-icon {
  width: 40px;
  height: 40px;
  color: var(--color-accent);
  opacity: 0.7;
  position: relative;
}
.events-full__placeholder-label {
  font-family: var(--font-sans);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-accent);
  position: relative;
}
.events-full__placeholder-hint {
  font-family: var(--font-sans);
  font-size: var(--fs-micro);
  color: var(--color-ink-soft);
  position: relative;
  max-width: 28ch;
  text-wrap: balance;
}

/* Imagem real da categoria (substitui placeholder) */
.events-full__image {
  position: relative;
  aspect-ratio: 16 / 7;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--bg-dark);
  box-shadow: 0 12px 36px -18px rgba(13, 13, 13, 0.32);
}
.events-full__image img {
  width: 100%;
  object-fit: cover;
  transition: transform 1000ms var(--ease-out);
}
.events-full__image:hover img { transform: scale(1.04); }
.events-full__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.4) 100%);
  pointer-events: none;
}
.events-full__image-caption {
  position: absolute;
  bottom: 1.25rem;
  left: 1.5rem;
  z-index: 2;
  color: var(--color-text);
  font-family: var(--font-sans);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.events-full__image-caption::before {
  content: "";
  width: 24px; height: 1px;
  background: var(--color-accent);
}
@media (max-width: 720px) {
  .events-full__image { aspect-ratio: 16 / 10; }
}

.events-full__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: var(--s-4);
}
.events-full__list li {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 1rem;
  padding: 1.125rem 0;
  border-bottom: 1px solid var(--line-light);
  color: var(--color-ink);
  font-size: var(--fs-body);
  line-height: 1.4;
}
.events-full__list .num {
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-accent);
  padding-top: 5px;
  font-feature-settings: "tnum";
  letter-spacing: 0.04em;
}
.events-full__list strong { font-weight: 500; }
@media (max-width: 980px) {
  .events-full__group { grid-template-columns: 1fr; gap: var(--s-6); }
  .events-full__group header { position: static; }
  .events-full__placeholder { aspect-ratio: 16 / 9; }
  .events-full__list { grid-template-columns: 1fr; }
}

/* ─── Página de contato dedicada ─── */
.contact-page {
  background: var(--bg-light);
}
.contact-page .contact__inner { background: transparent; }
.contact-page .contact__form {
  background: var(--bg-light-elevated);
  border: 1px solid var(--line-light);
}
.contact-page .contact__form-toggle {
  background: var(--bg-light-warm);
}
.contact-page .contact__form-toggle button { color: var(--color-ink-soft); }
.contact-page .contact__form-toggle button.is-active { color: var(--bg-dark); }
.contact-page .field input,
.contact-page .field textarea {
  background: var(--bg-light);
  border-color: var(--line-light-strong);
  color: var(--color-ink);
}
.contact-page .field input:focus,
.contact-page .field textarea:focus {
  background: var(--bg-light-elevated);
  border-color: var(--color-accent);
}
.contact-page .field input::placeholder,
.contact-page .field textarea::placeholder { color: var(--color-ink-soft); }
.contact-page .field label { color: var(--color-ink-muted); }
.contact-page .contact__copy h2 { color: var(--color-ink); }
.contact-page .contact__copy h2 em { color: var(--color-accent); }
.contact-page .contact__copy p { color: var(--color-ink-muted); }
.contact-page .contact__channel { border-color: var(--line-light); }
.contact-page .contact__channel a { color: var(--color-ink); }
.contact-page .contact__channel a:hover { color: var(--color-accent); }
.contact-page .contact__channel-label { color: var(--color-accent); }

/* ============================================================
   ░░ RESPONSIVO · página de Eventos & Contato ░░
   ============================================================ */

@media (max-width: 880px) {
  .page-hero {
    padding-top: 7rem;
    padding-bottom: 3rem;
  }
  .page-hero h1 { font-size: clamp(2rem, 1.6rem + 2vw, 2.75rem); max-width: 100%; }
  .page-hero p { font-size: 1rem; }
}

@media (max-width: 720px) {
  .page-hero { padding-top: 6.5rem; padding-bottom: 2.5rem; }
  .page-hero__inner { gap: 1rem; }

  .events-full__grid { gap: 3.5rem; }
  .events-full__group {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding-bottom: 3rem;
  }
  .events-full__group header { position: static; }
  .events-full__group h2 { margin-top: 0.25rem; }
  .events-full__content { gap: 1.25rem; }
  .events-full__placeholder { aspect-ratio: 16 / 10; padding: 1.5rem; }
  .events-full__placeholder-icon { width: 32px; height: 32px; }
  .events-full__list { grid-template-columns: 1fr; }
  .events-full__list li { padding: 0.875rem 0; font-size: 0.9375rem; }

  /* Contato como página */
  .contact-page .contact__inner { gap: 2rem; }
  .contact-page .contact__form { padding: 1.5rem; border-radius: var(--r-lg); }
}
/* =========================================================
   AJUSTES RESPONSIVOS - CARDS, BOTÕES E HEADLINES
========================================================= */

/* Imagens dos cards sem cortar no responsivo */
@media (max-width: 768px) {
  .authority__card,
  .authority__card--wide,
  .portfolio-item__visual,
  .events-full__image,
  .mc__carousel-card,
  .stats__loop-frame {
    min-height: auto !important;
    height: auto !important;
  }

  .authority__card-inner,
  .portfolio-item__visual,
  .events-full__image,
  .mc__carousel-card,
  .stats__loop-frame {
    aspect-ratio: auto !important;
    overflow: hidden !important;
    background: #1e1e1e !important;
    border-radius: inherit;
  }

  .authority__card-inner img,
  .portfolio-item__visual img,
  .events-full__image img,
  .mc__carousel-card img,
  .stats__loop-frame img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
    object-position: center !important;
    transform: none !important;
  }

  .authority__card-meta {
    position: relative !important;
    inset: auto !important;
    padding: 1rem !important;
    background: #1e1e1e !important;
  }
}

/* Ajuste específico para cards da seção Authority no mobile */
@media (max-width: 768px) {
  .authority__grid {
    gap: 1rem !important;
  }

  .authority__card {
    border-radius: 1.25rem !important;
    overflow: hidden !important;
  }

  .authority__card-inner {
    display: flex !important;
    flex-direction: column !important;
  }

  .authority__card-inner img {
    max-height: none !important;
  }
}

/* Botões principais mais equilibrados no responsivo */
@media (max-width: 768px) {
  .btn.btn-primary {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 0.9rem 1rem !important;
    font-size: 0.82rem !important;
    line-height: 1.25 !important;
    letter-spacing: 0.01em !important;
    white-space: normal !important;
    gap: 0.5rem !important;
  }

  .btn.btn-primary .arrow {
    flex: 0 0 auto !important;
    width: 18px !important;
    height: 18px !important;
  }
}

/* Headlines h2 no mobile */
@media (max-width: 768px) {
  h2,
  .section-head h2,
  .authority__head h2,
  .mc__copy h2,
  .diff__head h2,
  .stats__copy h2,
  .strategic__copy h2,
  .events__head h2,
  .versatility__head h2,
  .thematic__copy h2,
  .voice__copy h2,
  .testimonials__head h2,
  .clients__head h2,
  .contact__copy h2,
  .portfolio__cta h3 {
    font-size: 32px !important;
    line-height: 1.12 !important;
    letter-spacing: -0.03em !important;
  }
}

/* Ajuste extra para telas muito pequenas */
@media (max-width: 420px) {
  .btn.btn-primary {
    padding: 0.85rem 0.85rem !important;
    font-size: 0.78rem !important;
    letter-spacing: 0 !important;
  }

  h2,
  .section-head h2,
  .authority__head h2,
  .mc__copy h2,
  .diff__head h2,
  .stats__copy h2,
  .strategic__copy h2,
  .events__head h2,
  .versatility__head h2,
  .thematic__copy h2,
  .voice__copy h2,
  .testimonials__head h2,
  .clients__head h2,
  .contact__copy h2,
  .portfolio__cta h3 {
    font-size: 30px !important;
  }
}