/* ================================
🎨 ESTILOS – Módulo Contacto
================================ */

#contacto {
  padding: 5rem !important;
  background-color: var(--fondo-activo);
  color: var(--texto-activo);
  transition: background-color var(--transicion), color var(--transicion);
}

body.oscuro .bloque-contacto {
  background-color: var(--fondo-oscuro);
  color: var(--texto-oscuro);
}

.bloque-contacto .contenedor {
  max-width: 800px;
  margin: 0 auto;
}

.titulo-seccion {
  text-align: center;
  font-size: 2.2rem;
  margin-bottom: 1rem;
}

.parrafo-contacto {
  text-align: center;
  font-size: 1rem;
  margin-bottom: 1rem;
  opacity: 0.85;
}

/* ========== CAMPOS ========== */

form#form-contacto {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-top: 2rem;
}

.grupo-campo {
  display: flex;
  flex-direction: column;
  position: relative;
}

.grupo-campo label {
  margin-bottom: 0.3rem;
  font-weight: bold;
}

.grupo-campo input,
.grupo-campo textarea {
  padding: 0.7rem;
  border: 1px solid var(--color-secundario);
  border-radius: 6px;
  font-size: 1rem;
  resize: none;
  transition: border-color 0.3s;
  background-color: var(--fondo-claro);
  color: var(--texto-claro);
}

body.oscuro .grupo-campo input,
body.oscuro .grupo-campo textarea {
  background-color: #2a2a2a;
  color: var(--texto-oscuro);
  border-color: #444;
}

/* Contador */
.contador {
  position: absolute;
  bottom: 0.3rem;
  right: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-secundario);
  font-style: italic;
}

/* Textarea especial */
#contacto_mensaje {
  min-height: 6rem;
  max-height: 100vh;
  overflow-y: auto;
  resize: vertical;
  resize: block;
}

.grupo-campo-doble {
  display: flex;
  flex-direction: row; /* importante: era column */
  gap: 1rem;
}

.grupo-campo-doble .mitad {
  flex: 1;
  min-width: 0;
}

@media (min-width: 600px) {
  .grupo-campo-doble {
    flex-direction: row;
  }
}

/* Botón */
.acciones-form {
  text-align: center;
}

.btn-enviar {
  background-color: var(--color-principal);
  color: white;
  border: none;
  padding: 0.75rem 2rem;
  border-radius: 30px;
  cursor: pointer;
  font-weight: bold;
  font-size: 1rem;
  transition: background-color 0.3s;
  box-shadow: 0px 25px 30px -10px rgba(0, 0, 0, 0.4);
}

.btn-enviar:hover {
  background-color: #e53e4d;
}

/*Validador externo*/
.just-validate-error-label {
  color: var(--color-principal);
  font-size: 0.8rem;
  font-style: italic;
  margin-top: 0.3rem;
}
input.just-validate-error-field,
textarea.just-validate-error-field {
  border-color: var(--color-principal);
}

/* Mensaje de confirmación */
.mensaje-enviado {
  text-align: center;
  margin-top: 2rem;
  font-size: 1rem;
  color: green;
  font-weight: bold;
}

.campo-error {
  border-color: #fd4a5c !important;
  box-shadow: 0 0 4px #fd4a5c44;
}

@media (max-width: 768px) {
  .grupo-campo-doble {
    flex-direction: column;
  }
}

.aviso-disclaimer {
  font-size: 0.75rem;
  font-style: italic;
  margin-top: 1.5rem;
  padding: 1rem;
  border-left: 4px solid var(--resaltado);
  border-radius: 6px;
  line-height: 1.5;
  text-align: left;
  background-color: transparent;
}

/* 🌞 Tema claro */
body:not(.oscuro) .aviso-disclaimer {
  color: #555; /* gris medio */
}

/* 🌙 Tema oscuro */
body.oscuro .aviso-disclaimer {
  color: #ccc; /* gris claro */
}
