/*
 * Fale Conosco Page — Estilos específicos
 * Não recria tokens. Não duplica estilos globais.
 */

/* =========================================================
 * HERO
 * ========================================================= */

.fc-hero {
  min-height: 60svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: clamp(100px, 12vw, 140px) clamp(64px, 7vw, 96px);
}

.fc-hero-eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-blue-300);
  margin-bottom: var(--space-5);
}

.fc-hero-h1 {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 3.5vw, 2.875rem);
  font-weight: var(--font-weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text-inverse);
  margin-bottom: var(--space-6);
  max-width: 22em;
  text-wrap: balance;
}

.fc-hero-desc {
  font-size: clamp(var(--text-base), 1.8vw, var(--text-lg));
  color: var(--text-inverse-muted);
  line-height: var(--leading-relaxed);
  max-width: 52ch;
  margin-bottom: var(--space-8);
}

/* =========================================================
 * SEÇÃO 2 — FORMULÁRIO
 * ========================================================= */

.fc-form-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(var(--space-10), 5vw, 72px);
  align-items: start;
}

/* Coluna de contexto */
.fc-form-context {
  max-width: 440px;
}

.fc-form-context-eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-navy-500);
  background: rgba(33, 56, 100, 0.07);
  border: 1px solid rgba(33, 56, 100, 0.18);
  border-radius: 100px;
  padding: 3px 12px;
  margin-bottom: var(--space-5);
}

.fc-form-context-title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-xl), 2.5vw, var(--text-3xl));
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-5);
  text-wrap: balance;
}

.fc-form-context-desc {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-7);
}

/* Mini contatos rápidos abaixo da desc */
.fc-quick-contacts {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.fc-quick-contact {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.2s;
}

.fc-quick-contact:hover {
  color: var(--color-navy-500);
}

.fc-quick-contact-icon {
  width: 36px;
  height: 36px;
  background: var(--bg-light);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-navy-700);
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s;
}

.fc-quick-contact:hover .fc-quick-contact-icon {
  background: rgba(33, 56, 100, 0.06);
  border-color: rgba(33, 56, 100, 0.20);
}

/* Card do formulário */
.fc-form-card {
  background: var(--bg-white);
  border: 1px solid var(--color-gray-200);
  border-radius: 20px;
  padding: clamp(var(--space-7), 4vw, 48px);
  box-shadow: var(--shadow-medium);
}

.fc-form-heading {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-xl), 2vw, var(--text-2xl));
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

.fc-form-subheading {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-7);
  line-height: var(--leading-relaxed);
}

.fc-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

.fc-form-grid--2col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

.fc-form-submit {
  width: 100%;
}

.fc-form-privacy {
  margin-top: var(--space-4);
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-align: center;
  line-height: var(--leading-relaxed);
}

/* =========================================================
 * SEÇÃO 3 — CANAIS DE ATENDIMENTO
 * ========================================================= */

.fc-channels-intro {
  text-align: center;
  margin-bottom: clamp(var(--space-10), 5vw, 56px);
}

.fc-channels-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

.fc-channel-card {
  padding: clamp(var(--space-6), 2.5vw, var(--space-8));
  background: var(--bg-white);
  border: 1px solid var(--color-gray-200);
  border-radius: 16px;
  transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
}

.fc-channel-card:hover {
  border-color: rgba(33, 56, 100, 0.22);
  box-shadow: var(--shadow-soft);
  transform: translateY(-2px);
}

.fc-channel-icon {
  width: 48px;
  height: 48px;
  background: rgba(33, 56, 100, 0.07);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-navy-700);
  margin-bottom: var(--space-5);
}

.fc-channel-title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

.fc-channel-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-5);
}

.fc-channel-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.fc-channel-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-navy-500);
  text-decoration: none;
  transition: color 0.2s;
}

.fc-channel-link:hover {
  color: var(--color-navy-800);
}

.fc-channel-link svg {
  flex-shrink: 0;
  opacity: 0.65;
}

/* =========================================================
 * SEÇÃO 4 — CONTATOS INSTITUCIONAIS (faixa compacta)
 * ========================================================= */

.fc-contacts-strip {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(var(--space-6), 4vw, 56px);
  justify-content: center;
  align-items: flex-start;
}

.fc-contact-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  text-align: center;
}

.fc-contact-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
}

.fc-contact-value {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-inverse);
  text-decoration: none;
  transition: color 0.2s;
}

a.fc-contact-value:hover {
  color: var(--color-blue-300);
}

/* =========================================================
 * SEÇÃO 5 — CTA FINAL
 * ========================================================= */

.fc-cta-inner {
  max-width: 640px;
  margin-inline: auto;
  text-align: center;
}

.fc-cta-slogan {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-2xl), 3.5vw, var(--text-4xl));
  font-weight: var(--font-weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text-inverse);
  margin-bottom: var(--space-5);
}

.fc-cta-text {
  font-size: clamp(var(--text-base), 1.8vw, var(--text-lg));
  color: var(--text-inverse-muted);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-8);
  text-wrap: balance;
}

/* =========================================================
 * RESPONSIVIDADE
 * ========================================================= */

@media (min-width: 640px) {
  .fc-channels-grid {
    grid-template-columns: 1fr 1fr;
  }

  .fc-form-grid--2col {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1024px) {
  .fc-form-inner {
    grid-template-columns: 1fr 1.5fr;
    align-items: start;
  }

  .fc-channels-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
