.elementor-31410 .elementor-element.elementor-element-ead14a3{--display:flex;--margin-top:-38px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-31410 .elementor-element.elementor-element-c96248c{margin:16px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-31410 .elementor-element.elementor-element-c96248c.elementor-element{--align-self:center;}.elementor-31410 .elementor-element.elementor-element-2bb4331{--display:flex;--padding-top:14px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(min-width:769px){.elementor-31410 .elementor-element.elementor-element-2bb4331{--width:60%;}}@media(max-width:768px){.elementor-31410 .elementor-element.elementor-element-c96248c.elementor-element{--align-self:center;}.elementor-31410 .elementor-element.elementor-element-c96248c{text-align:center;}}/* Start custom CSS for heading, class: .elementor-element-c96248c */.eyebrow{
    display:inline-block;
    font: 600 14px/1.2 system-ui,-apple-system,"Segoe UI",Roboto,Poppins,Arial,sans-serif;
    letter-spacing:.08em; text-transform: uppercase;
    color: var(--brand-olive);
    background: rgba(95,127,59,.08);
    border: 1px solid rgba(95,127,59,.15);
    padding: 8px 12px; border-radius: 999px; margin-bottom: 14px;
  }/* End custom CSS */
/* Start custom CSS for shortcode, class: .elementor-element-c7ce546 *//* ===========================
   Ninja Forms — Estilo limpio
   Scope: Form ID = 1
   =========================== */
#nf-form-1-cont{
  --morado:#b385bf;
  --verde:#5f7f3b;
  --borde:#e8e3ea;
  --borde-focus:#c5b2cc;
  --txt:#222;
  --txt-soft:#666;
  --bg:#fff;
  --bg-soft:#faf9fb;
}

/* Card general */
#nf-form-1-cont .nf-form-content{
  background: var(--bg);
  border: 1px solid var(--borde);
  border-radius: 16px;
  padding: clamp(18px,3vw,28px);
  box-shadow: 0 12px 30px rgba(0,0,0,.06);
}

/* Título y descripción */
#nf-form-1-cont .nf-form-title h3{
  font: 800 clamp(20px,2.6vw,28px)/1.2 system-ui,sans-serif;
  margin: 0 0 8px;
  color: var(--txt);
}
#nf-form-1-cont .nf-form-fields-required{
  color: var(--txt-soft);
  font-size: 13px;
  margin-bottom: 14px;
}

/* Etiquetas */
#nf-form-1-cont .nf-field-label label{
  font-weight: 700;
  color: var(--txt);
  font-size: 14.5px;
  margin-bottom: 6px;
  display: inline-block;
}
#nf-form-1-cont .ninja-forms-req-symbol{ color: var(--morado); }

/* Inputs, selects, textarea */
#nf-form-1-cont .nf-field-element input[type="text"],
#nf-form-1-cont .nf-field-element input[type="email"],
#nf-form-1-cont .nf-field-element input[type="tel"],
#nf-form-1-cont .nf-field-element input[type="number"],
#nf-form-1-cont .nf-field-element select,
#nf-form-1-cont .nf-field-element textarea{
  width: 100%;
  background: #fff;
  border: 1.5px solid var(--borde) !important;
  border-radius: 10px !important;
  padding: 12px 14px !important;
  font-size: 15px;
  line-height: 1.4;
  color: var(--txt);
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
  box-shadow: 0 2px 0 rgba(0,0,0,.02) inset;
}
#nf-form-1-cont .nf-field-element textarea{
  min-height: 140px; resize: vertical;
}

/* Placeholder */
#nf-form-1-cont ::placeholder{ color:#999; opacity:1 }

/* Focus */
#nf-form-1-cont .nf-field-element input:focus,
#nf-form-1-cont .nf-field-element select:focus,
#nf-form-1-cont .nf-field-element textarea:focus{
  outline: 0;
  border-color: var(--borde-focus) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--morado) 20%, transparent);
  background: var(--bg-soft);
}

/* Select con flecha */
#nf-form-1-cont .nf-field-element select{
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--morado) 50%),
    linear-gradient(135deg, var(--morado) 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 18px) calc(50% - 4px),
    calc(100% - 12px) calc(50% - 4px),
    100% 0;
  background-size: 6px 6px, 6px 6px, 2.5em 100%;
  background-repeat: no-repeat;
  padding-right: 42px !important;
}

/* Radios / checkboxes */
#nf-form-1-cont .nf-field-element input[type="checkbox"],
#nf-form-1-cont .nf-field-element input[type="radio"]{
  accent-color: var(--verde);
  transform: translateY(1px);
}

/* Filas y columnas */
#nf-form-1-cont .nf-field-container{ margin-bottom: 14px; }
#nf-form-1-cont .nf-row{ gap: 16px; }
#nf-form-1-cont .nf-row .nf-cell{ margin-bottom: 0; }

/* Botón enviar */
#nf-form-1-cont .nf-form-content input[type="button"],
#nf-form-1-cont .submit-wrap .nf-element{
  width: 100%;
  border: 0 !important;
  border-radius: 12px !important;
  padding: 14px 18px !important;
  font-weight: 800 !important;
  letter-spacing: .3px;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--verde), color-mix(in srgb, var(--verde) 80%, #000 20%)) !important;
  color: #fff !important;
  box-shadow: 0 10px 18px rgba(95,127,59,.22);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
  cursor: pointer;
}
#nf-form-1-cont .nf-form-content input[type="button"]:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 26px rgba(95,127,59,.28);
  filter: saturate(1.05);
}

/* Errores */
#nf-form-1-cont .nf-error .nf-field-element input,
#nf-form-1-cont .nf-error .nf-field-element select,
#nf-form-1-cont .nf-error .nf-field-element textarea{
  border-color: #e46b6b !important;
  box-shadow: 0 0 0 3px rgba(228,107,107,.15) !important;
}
#nf-form-1-cont .nf-error-msg,
#nf-form-1-cont .ninja-forms-req-symbol{ color:#c14747; }
#nf-form-1-cont .nf-error-field-errors{
  margin-top:6px; font-size: 13px; color:#c14747;
}

/* Éxito */
#nf-form-1-cont .nf-response-msg{
  margin-top: 14px;
  background: linear-gradient(90deg, rgba(95,127,59,.10), rgba(179,133,191,.10));
  border: 1px solid var(--borde);
  border-radius: 12px;
  padding: 14px 16px;
  color: var(--txt);
  box-shadow: 0 10px 20px rgba(0,0,0,.04);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  #nf-form-1-cont *{ transition:none !important; }
}

/* Responsive */
@media (max-width: 640px){
  #nf-form-1-cont .nf-row{ gap: 10px; }
  #nf-form-1-cont .nf-form-content{ padding: 16px; }
}/* End custom CSS */