/* garante que nada ultrapasse largura */
*,
*::before,
*::after{
  box-sizing: border-box;
}

/* ================= CONTACT WRAPPER ================= */

.contact-wrapper{
  max-width: 1500px;
  margin: 0 auto;
  padding: 3.5rem 1.4rem;

  display: flex;
  justify-content: center;
}

/* ================= CONTACT CARD ================= */

.contact-section{
  width: 100%;
  max-width: 1300px;

  display: grid;
  grid-template-columns: 182px 1fr;
  gap: 2.1rem;

  background: var(--card);
  border-radius: 14px;
  padding: 2.1rem;

  box-shadow: 0 20px 60px rgba(0,0,0,0.08);
}

/* ================= CONTACT INFO ================= */

.contact-info{
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.contact-info h2{
  font-size: 1.4rem;
  margin-bottom: .35rem;
}

.contact-subtitle{
  color: var(--muted);
  line-height: 1.6;
}

/* ================= FORM ================= */

.contact-form{
  display: flex;
  flex-direction: column;
  gap: 0.84rem;
  width: 100%;
}

.form-group{
  display: flex;
  flex-direction: column;
  gap: .28rem;
}

/* INPUTS */

.contact-form input,
.contact-form textarea{
  width: 100%;
  padding: .63rem 0.7rem;

  border-radius: 7px;
  border: 1px solid var(--border);

  background: var(--input-bg);
  color: var(--text);

  font-size: 1rem;
}

.contact-form textarea{
  resize: vertical;
  min-height: 84px;
}

.contact-form input:focus,
.contact-form textarea:focus{
  outline: none;
  border-color: var(--accent);
}

/* BOTÃO */

.btn-primary{
  margin-top: .35rem;
  align-self: flex-start;

  background: var(--accent);
  color: white;

  border: none;
  padding: .56rem 0.98rem;

  border-radius: 999px;

  font-weight: 600;
  cursor: pointer;
}