/* ================= CONTACTO NUEVO ================= */

.contacto-top {
  text-align: center;
  margin-top: 20px;
  padding: 25px 15px !important;
}

.contacto-top h2 {
  justify-content: center !important;
  font-size: 34px !important;
  color: var(--primary-2) !important;
}

.contacto-top p {
  font-size: 18px;
  color: var(--text-accent);
  margin-top: 8px;
}

.contacto-layout {
  align-items: stretch;
  gap: 20px;
}

.contacto-form-col,
.contacto-info-col {
  padding: 0 !important;
}

.contacto-form-col {
  width: 42% !important;
}

.contacto-info-col {
  width: 56% !important;
}

.contacto-form-card,
.contacto-info-card {
  border-radius: 18px !important;
  padding: 28px !important;
  box-shadow: 0 6px 18px rgba(0,0,0,0.12) !important;
  height: 100%;
}

.contacto-form-card h2,
.contacto-info-card h2 {
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--primary-2) !important;
  margin-bottom: 10px !important;
}

.contacto-subtexto {
  font-size: 15px !important;
  color: var(--text-dark);
  margin-bottom: 15px !important;
}

.contacto-obligatorio {
  font-size: 14px !important;
  color: var(--text-dark);
  margin-bottom: 18px !important;
}

.contacto-formulario .form-group {
  margin-top: 0 !important;
  margin-bottom: 18px;
  padding: 0 !important;
}

.contacto-formulario .form-group label {
  position: static !important;
  display: block;
  background: transparent !important;
  padding: 0 !important;
  margin-bottom: 6px;
  font-size: 13px !important;
  color: var(--text-muted);
}

.contacto-formulario input,
.contacto-formulario select,
.contacto-formulario textarea {
  width: 100%;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  padding: 12px 14px !important;
  font-size: 15px;
  color: var(--text-dark);
  background: var(--bg-white);
  outline: none;
}

.contacto-formulario textarea {
  resize: vertical;
  min-height: 160px;
}

.contacto-formulario input:focus,
.contacto-formulario select:focus,
.contacto-formulario textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-alpha-25);
}

.contacto-btn-wrap {
  margin-top: 10px;
}

.contacto-btn {
  width: 100%;
  min-height: 54px;
  border-radius: 10px !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  gap: 10px;
}

.contacto-btn i {
  font-size: 24px;
}

.contacto-info-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.contacto-info-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}

.contacto-info-icon {
  width: 58px;
  min-width: 58px;
  height: 58px;
  border-radius: 12px;
  background: var(--bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contacto-info-icon i {
  font-size: 30px;
  color: var(--primary-2);
}

.contacto-info-texto {
  flex: 1;
  text-align: left !important;
}

.contacto-info-texto h3 {
  margin: 0 0 4px 0 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--text-black);
  text-align: left !important;
}

.contacto-info-texto p {
  margin: 0 !important;
  font-size: 15px !important;
  color: var(--text-dark);
  text-align: left !important;
  line-height: 1.45;
}

.contacto-mapa {
  margin-top: 10px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--gray-200);
}

.contacto-mapa iframe {
  width: 100% !important;
  min-height: 300px;
  display: block;
}

@media screen and (max-width: 1000px) {
  .contacto-form-col,
  .contacto-info-col {
    width: 100% !important;
  }

  .contacto-top h2 {
    font-size: 28px !important;
  }

  .contacto-top p {
    font-size: 16px;
  }
}