/* IngSoft V81.12 — Contacto: parte derecha corregida sin herencias conflictivas
   Corrección total del formulario derecho mediante arquitectura limpia.
   No usa: contact-card, form-static, field, btn, panel ni clases heredadas problemáticas. */
:root{
  --c12-ink:#071832;
  --c12-ink2:#17395a;
  --c12-white:#ffffff;
  --c12-soft:#eef6fc;
  --c12-border:#b7dcf5;
  --c12-cyan:#4dc2f3;
  --c12-cyan2:#8bdcff;
  --c12-red:#e41e2b;
  --c12-dark:#06152a;
  --c12-dark2:#0b2b55;
  --c12-shadow:0 24px 68px rgba(6,21,42,.12);
}
html body.page-contacto,
html body.contacto-page,
html body.contact-clean-page{
  background:linear-gradient(180deg,#edf5fb 0%,#f8fbff 100%) !important;
  color:var(--c12-ink) !important;
  -webkit-text-fill-color:initial !important;
}
html body.contact-clean-page .contact-clean-section{
  background:transparent !important;
  padding:clamp(42px,6vw,82px) 0 !important;
}
html body.contact-clean-page .contact-clean-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(420px,.82fr) !important;
  gap:32px !important;
  align-items:start !important;
}
html body.contact-clean-page .contact-clean-info,
html body.contact-clean-page .contact-clean-form-card{
  border-radius:30px !important;
  box-shadow:var(--c12-shadow) !important;
  overflow:visible !important;
  opacity:1 !important;
  visibility:visible !important;
  filter:none !important;
  text-shadow:none !important;
}
html body.contact-clean-page .contact-clean-info{
  background:#ffffff !important;
  border:2px solid var(--c12-border) !important;
  padding:30px !important;
  color:var(--c12-ink) !important;
  -webkit-text-fill-color:initial !important;
}
html body.contact-clean-page .contact-clean-kicker{
  display:inline-flex !important;
  align-items:center !important;
  gap:1rem !important;
  width:max-content !important;
  background:#ffffff !important;
  color:var(--c12-ink) !important;
  -webkit-text-fill-color:var(--c12-ink) !important;
  border:2px solid var(--c12-cyan) !important;
  border-radius:999px !important;
  padding:.85rem 1.45rem !important;
  font-weight:950 !important;
  letter-spacing:.16em !important;
  text-transform:uppercase !important;
}
html body.contact-clean-page .contact-clean-kicker::before{
  content:"" !important;
  display:block !important;
  width:52px !important;
  height:6px !important;
  border-radius:999px !important;
  background:var(--c12-red) !important;
}
html body.contact-clean-page .contact-clean-info h2{
  margin:24px 0 12px !important;
  color:var(--c12-ink) !important;
  -webkit-text-fill-color:var(--c12-ink) !important;
  font-size:clamp(2.1rem,4vw,3.3rem) !important;
  line-height:1.05 !important;
  font-weight:950 !important;
}
html body.contact-clean-page .contact-clean-intro{
  margin:0 0 26px !important;
  color:var(--c12-ink2) !important;
  -webkit-text-fill-color:var(--c12-ink2) !important;
  font-size:1.08rem !important;
  font-weight:760 !important;
  line-height:1.58 !important;
}
html body.contact-clean-page .contact-clean-facts{display:grid !important;gap:16px !important;}
html body.contact-clean-page .contact-clean-fact{
  display:grid !important;
  grid-template-columns:190px minmax(0,1fr) !important;
  gap:1rem !important;
  align-items:center !important;
  background:var(--c12-soft) !important;
  border:1.5px solid var(--c12-border) !important;
  border-radius:20px !important;
  padding:18px 20px !important;
}
html body.contact-clean-page .contact-clean-fact b{color:var(--c12-ink) !important;-webkit-text-fill-color:var(--c12-ink) !important;font-weight:900 !important;}
html body.contact-clean-page .contact-clean-fact span,
html body.contact-clean-page .contact-clean-fact a{color:var(--c12-ink2) !important;-webkit-text-fill-color:var(--c12-ink2) !important;font-weight:760 !important;opacity:1 !important;text-shadow:none !important;}
html body.contact-clean-page .contact-clean-fact a{color:#075fae !important;-webkit-text-fill-color:#075fae !important;text-decoration:underline !important;text-underline-offset:3px !important;}

/* Parte derecha: sin clases heredadas; contraste absoluto sobre fondo oscuro. */
html body.contact-clean-page .contact-clean-form-card{
  background:linear-gradient(180deg,var(--c12-dark) 0%,var(--c12-dark2) 100%) !important;
  border:2px solid rgba(184,236,255,.62) !important;
  padding:34px !important;
  color:#ffffff !important;
  -webkit-text-fill-color:initial !important;
}
html body.contact-clean-page .contact-clean-form-card,
html body.contact-clean-page .contact-clean-form-card *{
  opacity:1 !important;
  visibility:visible !important;
  filter:none !important;
  text-shadow:none !important;
}
html body.contact-clean-page .contact-clean-form-card h3,
html body.contact-clean-page #contact-form-title{
  display:block !important;
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  font-size:clamp(1.8rem,3vw,2.65rem) !important;
  line-height:1.1 !important;
  font-weight:950 !important;
  margin:0 0 14px !important;
  letter-spacing:-.025em !important;
}
html body.contact-clean-page .contact-clean-form-intro{
  display:block !important;
  color:#e8f7ff !important;
  -webkit-text-fill-color:#e8f7ff !important;
  font-size:1.03rem !important;
  line-height:1.58 !important;
  font-weight:780 !important;
  margin:0 0 22px !important;
}
html body.contact-clean-page .ingsoft-contact-form-clean{
  display:grid !important;
  gap:18px !important;
  margin:0 !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}
html body.contact-clean-page .ingsoft-contact-field-clean{
  display:grid !important;
  gap:9px !important;
  margin:0 !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
}
html body.contact-clean-page .ingsoft-contact-field-clean label{
  display:block !important;
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  font-size:1.04rem !important;
  line-height:1.2 !important;
  font-weight:950 !important;
  letter-spacing:.01em !important;
  margin:0 !important;
}
html body.contact-clean-page .ingsoft-contact-field-clean input,
html body.contact-clean-page .ingsoft-contact-field-clean textarea{
  display:block !important;
  width:100% !important;
  box-sizing:border-box !important;
  background:#ffffff !important;
  color:var(--c12-ink) !important;
  -webkit-text-fill-color:var(--c12-ink) !important;
  border:2px solid var(--c12-cyan2) !important;
  border-radius:22px !important;
  padding:16px 18px !important;
  font-size:1rem !important;
  line-height:1.35 !important;
  font-weight:760 !important;
  font-family:inherit !important;
  caret-color:var(--c12-ink) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 8px 22px rgba(10,42,75,.20) !important;
}
html body.contact-clean-page .ingsoft-contact-field-clean textarea{
  min-height:160px !important;
  resize:vertical !important;
}
html body.contact-clean-page .ingsoft-contact-field-clean input::placeholder,
html body.contact-clean-page .ingsoft-contact-field-clean textarea::placeholder{
  color:#5f7d98 !important;
  -webkit-text-fill-color:#5f7d98 !important;
  opacity:1 !important;
}
html body.contact-clean-page .ingsoft-contact-field-clean input:focus,
html body.contact-clean-page .ingsoft-contact-field-clean textarea:focus{
  outline:none !important;
  border-color:#bdeeff !important;
  box-shadow:0 0 0 4px rgba(139,220,255,.25),0 10px 26px rgba(10,42,75,.24) !important;
}
html body.contact-clean-page .ingsoft-contact-submit-clean{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:max-content !important;
  min-height:50px !important;
  padding:.95rem 1.3rem !important;
  border-radius:18px !important;
  border:1px solid rgba(255,255,255,.36) !important;
  background:linear-gradient(135deg,#23aae7,#48cbf5) !important;
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  font:950 1rem/1 inherit !important;
  cursor:pointer !important;
  box-shadow:0 14px 30px rgba(35,170,231,.24) !important;
}
@media(max-width:980px){
  html body.contact-clean-page .contact-clean-grid{grid-template-columns:1fr !important;}
  html body.contact-clean-page .contact-clean-fact{grid-template-columns:1fr !important;gap:.45rem !important;}
}
