/* Formularios — wrapper genérico .contact-form y compatibilidad con Contact Form 7.
   Extraído de HOME.html .contact-form / .contact-form__group y adaptado para CF7. */

/* Card blanca solo para el formulario completo de la página /contacto/.
   NO aplicar a la regla global .wpcf7 .wpcf7-form porque entonces el
   newsletter del footer y los lead-magnet también pintarían card. */
.contact-form,
.contacto-form-wrap .wpcf7-form,
.contacto-form-wrap .wpcf7 .wpcf7-form {
  background-color: var(--color-white);
  padding: var(--space-lg);
  border-radius: var(--radius-md);
  border: 1px solid rgba(42, 41, 98, 0.08);
  box-shadow: var(--shadow-sm);
}

.contact-form__group,
.wpcf7 .form-row {
  margin-bottom: var(--space-md);
}

/* wpautop mete <p> dentro de .form-row y un <br /> entre label e input.
   Reset del <p> para que no añada margins propios y oculto el <br />
   (el label ya separa con su margin-bottom). */
.wpcf7 .form-row > p,
.wpcf7 .form-row-2 .form-row > p {
  margin: 0;
}
.wpcf7 .form-row > p > br,
.wpcf7 .form-row-2 .form-row > p > br {
  display: none;
}

.contact-form__group label,
.wpcf7 label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 0.375rem;
}
.contact-form__group label .required,
.wpcf7 label .required { color: var(--color-orange); }

/* Inputs nativos + CF7 (CF7 envuelve los inputs en span.wpcf7-form-control-wrap) */
.contact-form__group input,
.contact-form__group textarea,
.contact-form__group select,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 input[type="number"],
.wpcf7 textarea,
.wpcf7 select {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid rgba(42, 41, 98, 0.2);
  border-radius: var(--radius-sm);
  background-color: var(--color-white);
  color: var(--color-dark);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.5;
  transition: var(--transition);
}

.contact-form__group input:focus,
.contact-form__group textarea:focus,
.contact-form__group select:focus,
.wpcf7 input:focus,
.wpcf7 textarea:focus,
.wpcf7 select:focus {
  outline: none;
  border-color: var(--color-orange);
  box-shadow: 0 0 0 3px rgba(235, 90, 44, 0.10);
}

.contact-form__group textarea,
.wpcf7 textarea { min-height: 140px; resize: vertical; }

.contact-form__row,
.wpcf7 .form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
}

.contact-form__checkbox,
.wpcf7 .form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-xs);
  font-size: var(--text-sm);
  color: var(--color-gray);
  margin-bottom: var(--space-md);
  cursor: pointer;
}
.contact-form__checkbox input,
.wpcf7 .wpcf7-acceptance input {
  width: auto;
  margin-top: 0.25rem;
  accent-color: var(--color-orange);
}
.contact-form__checkbox a { color: var(--color-orange); text-decoration: underline; }

.contact-form__submit,
.wpcf7 input[type="submit"],
.wpcf7-submit {
  width: 100%;
  background-color: var(--color-orange);
  color: var(--color-white);
  padding: 1rem;
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
  border: none;
  font-family: var(--font-body);
}
.contact-form__submit:hover,
.wpcf7 input[type="submit"]:hover,
.wpcf7-submit:hover {
  background-color: var(--color-orange-hover);
  transform: translateY(-2px);
}

/* CF7 — mensajes de validación y respuesta */
.wpcf7-not-valid-tip {
  color: #b32424;
  font-size: var(--text-xs);
  margin-top: 0.25rem;
}
.wpcf7-response-output {
  margin: var(--space-md) 0 0;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  background: var(--color-beige);
  border: 1px solid rgba(42, 41, 98, 0.12);
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
  background: #fde6e1;
  border-color: var(--color-orange);
  color: var(--color-dark);
}
.wpcf7 form.sent .wpcf7-response-output {
  background: #e3f6ee;
  border-color: #1d8d5a;
  color: #1d8d5a;
}

@media (max-width: 600px) {
  .contact-form__row,
  .wpcf7 .form-row-2 { grid-template-columns: 1fr; }
}
