/* === Página de Contacto === */
.contacto {
  background-color: var(--azulOscuro);
  color: var(--blanco);
  padding: 8rem 0;
  min-height: calc(100vh - 20rem); /* asegura buena altura visual */
}

.contacto h2 {
  font-size: 3.6rem;
  margin-bottom: 2rem;
}

.intro-contacto {
  max-width: 70rem;
  margin: 0 auto 4rem auto;
  font-size: 1.6rem;
  line-height: 1.6;
}

.formulario-contacto {
  max-width: 60rem;
  margin: 0 auto;
  background-color: var(--blanco);
  color: var(--negro);
  padding: 3rem;
  border-radius: 1rem;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

.campo {
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
}

.campo label {
  font-weight: bold;
  margin-bottom: 0.5rem;
  color: var(--azulOscuro);
}

.campo input,
.campo textarea {
  border: 1px solid var(--grisClaro);
  border-radius: 0.5rem;
  padding: 1rem;
  font-size: 1.5rem;
  font-family: var(--fuenteParrafos);
}

.campo input:focus,
.campo textarea:focus {
  outline: none;
  border-color: var(--azul);
  box-shadow: 0 0 6px rgba(0, 165, 226, 0.4);
}

.campo button {
  cursor: pointer;
  font-size: 1.6rem;
  transition: background-color 0.3s ease;
  width: 50%;
}

.campo button:hover {
  background-color: var(--azulHover);
}

@media (max-width: 768px) {
  .campo button {
    width: 100%;
  }
}
