/* =============================================================
   Formulario "Seguro de Vida"  ·  template-parts/form-vida.php
   Versión compacta: misma estética, escala reducida para que el
   bloque quede proporcionado respecto a la página.
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

.vida-form-wrapper {
  --v-primary:        #0e159c;
  --v-primary-dark:   #0a1078;
  --v-ink:            #20223f;
  --v-label:          #262a48;
  --v-muted:          #9498ad;
  --v-border:         #e6e7f1;
  --v-border-strong:  #c7cadf;
  --v-field-bg:       #ffffff;
  --v-soft:           #f2f3fb;
  --v-soft-hover:     #e9eaf6;
  --v-tint:           rgba(14, 21, 156, .06);
  --v-ring:           rgba(14, 21, 156, .12);
  --v-tp-green:       #00b67a;
  --v-radius:         6px;
  --v-radius-card:    10px;

  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}

.vida-form {
  background: var(--v-field-bg);
  border: 1px solid #eef0f7;
  border-radius: var(--v-radius-card);
  padding: 22px 22px 18px;
  box-shadow: 0 16px 40px -24px rgba(20, 22, 80, .28);
  font-family: 'DM Sans', 'Open Sans', sans-serif;
  -webkit-font-smoothing: antialiased;
}

/* ---------- Cabecera ---------- */
.vida-form__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}
.vida-form__logo { display: inline-flex; align-items: center; }
.vida-form__logo img { max-height: 26px; width: auto; display: block; }
.vida-form__logo--empty { min-height: 26px; }
.vida-steps { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.vida-steps__item { font-size: .95rem; font-weight: 600; color: var(--v-muted); transition: color .18s ease; }
.vida-steps__item.is-current { color: var(--v-primary); }
.vida-steps__sep { font-size: .9rem; color: var(--v-border-strong); }
.vida-form__phone {
  display: inline-flex; align-items: center; gap: 7px;
  font-weight: 700; font-size: 1rem; letter-spacing: .01em;
  color: var(--v-primary); text-decoration: none; white-space: nowrap;
}
.vida-form__phone-icon { display: inline-flex; width: 18px; height: 18px; }
.vida-form__phone-icon svg { width: 100%; height: 100%; }

/* ---------- Pasos ---------- */
.vida-step { display: none; }
.vida-step.is-active { display: block; animation: vidaFade .3s ease; }
@keyframes vidaFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* ---------- Campos ---------- */
.vida-field { margin-bottom: 15px; }
.vida-label {
  display: block;
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--v-ink);
  margin-bottom: 7px;
}

.vida-input {
  width: 100%; height: 48px; padding: 0 14px;
  font-size: .95rem; font-family: inherit; color: var(--v-ink);
  background: var(--v-field-bg);
  border: 1.5px solid var(--v-border); border-radius: var(--v-radius);
  outline: none; transition: border-color .18s ease, box-shadow .18s ease;
}
.vida-input::placeholder { color: var(--v-muted); }
.vida-input:focus { border-color: var(--v-primary); box-shadow: 0 0 0 3px var(--v-ring); }

/* ---------- Fecha de nacimiento ---------- */
.vida-date { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }

/* ---------- Selects ---------- */
.vida-select { position: relative; }
.vida-select select {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  width: 100%; height: 48px; padding: 0 36px 0 14px;
  font-size: .95rem; font-family: inherit; color: var(--v-ink);
  background: var(--v-field-bg);
  border: 1.5px solid var(--v-border); border-radius: var(--v-radius);
  outline: none; cursor: pointer; transition: border-color .18s ease, box-shadow .18s ease;
}
.vida-select select:required:invalid { color: var(--v-muted); }
.vida-select select option[disabled] { color: var(--v-muted); }
.vida-select select option { color: var(--v-ink); }
.vida-select select:focus { border-color: var(--v-primary); box-shadow: 0 0 0 3px var(--v-ring); }
.vida-select::after {
  content: ""; position: absolute; right: 15px; top: 50%;
  width: 8px; height: 8px; margin-top: -6px;
  border-right: 2px solid var(--v-border-strong);
  border-bottom: 2px solid var(--v-border-strong);
  transform: rotate(45deg); pointer-events: none;
}
.vida-date .vida-select select { padding: 0 26px 0 12px; font-size: .92rem; }
.vida-date .vida-select::after { right: 12px; }

/* ---------- Toggle Sí / No ---------- */
.vida-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.vida-toggle__option { position: relative; cursor: pointer; }
.vida-toggle__option input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.vida-toggle__option span {
  display: flex; align-items: center; justify-content: center;
  height: 48px; font-size: .95rem; font-weight: 600;
  color: var(--v-primary); background: var(--v-soft);
  border: 2px solid transparent; border-radius: var(--v-radius);
  transition: background .16s ease, border-color .16s ease;
}
.vida-toggle__option:hover span { background: var(--v-soft-hover); }
.vida-toggle__option input:checked + span { background: var(--v-tint); border-color: var(--v-primary); font-weight: 700; }
.vida-toggle__option input:focus-visible + span { box-shadow: 0 0 0 3px var(--v-ring); }

/* ---------- Botón principal ---------- */
.vida-btn {
  position: relative; width: 100%; height: 52px;
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  margin-top: 2px;
  font-size: 1rem; font-weight: 700; letter-spacing: .01em; font-family: inherit;
  color: #fff; background: var(--v-primary);
  border: none; border-radius: var(--v-radius); cursor: pointer;
  box-shadow: 0 8px 20px -10px rgba(14, 21, 156, .5);
  transition: background .18s ease, transform .08s ease, box-shadow .18s ease;
}
.vida-btn:hover { background: var(--v-primary-dark); transform: translateY(-1px); box-shadow: 0 12px 24px -12px rgba(14, 21, 156, .55); }
.vida-btn:active { transform: translateY(0); }
.vida-btn__arrow { width: 18px; height: 18px; }
.vida-btn.is-loading { pointer-events: none; }
.vida-btn.is-loading .vida-btn__label { visibility: hidden; }
.vida-btn__spinner { display: none; }
.vida-btn.is-loading .vida-btn__spinner {
  display: block; position: absolute; width: 20px; height: 20px;
  border: 2.5px solid rgba(255, 255, 255, .4); border-top-color: #fff;
  border-radius: 50%; animation: vidaSpin .7s linear infinite;
}
@keyframes vidaSpin { to { transform: rotate(360deg); } }

/* ---------- Paso 2 ---------- */
.vida-back {
  display: inline-flex; align-items: center; gap: 6px;
  margin-bottom: 14px; padding: 0;
  font-size: .88rem; font-weight: 600; font-family: inherit;
  color: var(--v-muted); background: none; border: none; cursor: pointer;
}
.vida-back svg { width: 16px; height: 16px; }
.vida-back:hover { color: var(--v-primary); }
.vida-step__title { margin: 0 0 4px; font-size: 1.25rem; font-weight: 700; letter-spacing: -.02em; color: var(--v-ink); }
.vida-step__subtitle { margin: 0 0 18px; font-size: .9rem; line-height: 1.5; color: var(--v-muted); }

/* ---------- Checkbox ---------- */
.vida-check {
  display: flex; align-items: flex-start; gap: 9px;
  margin: 2px 0 16px; font-size: .82rem; line-height: 1.45;
  color: var(--v-muted); cursor: pointer;
}
.vida-check input { width: 17px; height: 17px; margin-top: 1px; flex: 0 0 auto; accent-color: var(--v-primary); cursor: pointer; }
.vida-check a { color: var(--v-primary); text-decoration: underline; }

/* ---------- Errores ---------- */
.vida-errors {
  display: none; margin-bottom: 12px; padding: 9px 13px;
  font-size: .85rem; color: #b3261e;
  background: #fdeceb; border: 1px solid #f6c6c2; border-radius: 6px;
}
.vida-errors.is-visible { display: block; }
.vida-errors.is-success { display: block; color: #0a7d57; background: #e7f7f0; border-color: #b6e7d4; }
.vida-form .is-error select,
.vida-form .vida-input.is-error,
.vida-form select.is-error { border-color: #e0554b !important; box-shadow: 0 0 0 3px rgba(224, 85, 75, .10) !important; }
.vida-toggle.is-error .vida-toggle__option span { border-color: #e0554b; }

/* ---------- Trustpilot ---------- */
.vida-trust {
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
  gap: 9px; margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--v-border);
}
.vida-trust__stars { display: inline-flex; gap: 3px; padding: 3px; background: var(--v-tp-green); border-radius: 4px; }
.vida-trust__star svg { width: 15px; height: 15px; display: block; }
.vida-trust__text { font-size: .86rem; color: var(--v-ink); }
.vida-trust__text strong { font-weight: 700; }
.vida-trust__brand { display: inline-flex; align-items: center; gap: 4px; font-size: .86rem; font-weight: 700; color: var(--v-ink); }
.vida-trust__brand svg { width: 15px; height: 15px; }

/* =============================================================
   Composición: tarjeta centrada sobre fondo limpio
   ============================================================= */
.presentation:has(.vida-form-wrapper),
.presentation.has-vida-form {
  background: linear-gradient(180deg, #f7f8fc 0%, #edeff8 100%) !important;
  min-height: auto !important;
  padding: 38px 16px 46px !important;
  align-items: center; justify-content: center;
}
.presentation:has(.vida-form-wrapper)::before,
.presentation.has-vida-form::before { display: none !important; }
.presentation:has(.vida-form-wrapper) .presentation__cover,
.presentation.has-vida-form .presentation__cover { display: none !important; }
.presentation:has(.vida-form-wrapper) .presentation__inner,
.presentation.has-vida-form .presentation__inner {
  display: flex !important; flex-direction: column;
  align-items: center; justify-content: center; width: 100%; gap: 0;
}
.presentation:has(.vida-form-wrapper) .presentation__text,
.presentation.has-vida-form .presentation__text {
  flex: none !important; width: 100%; max-width: 480px;
  text-align: center; color: var(--v-ink, #20223f) !important;
}
.presentation:has(.vida-form-wrapper) .presentation__text:empty,
.presentation.has-vida-form .presentation__text:empty,
.presentation:has(.vida-form-wrapper) .presentation__text h1:empty,
.presentation.has-vida-form .presentation__text h1:empty { display: none; }
.presentation:has(.vida-form-wrapper) .presentation__text h1,
.presentation.has-vida-form .presentation__text h1 {
  color: var(--v-ink, #20223f) !important;
  font-family: 'DM Sans', 'Open Sans', sans-serif;
  font-weight: 700; font-size: 1.5rem; margin-bottom: 1rem;
}
.presentation:has(.vida-form-wrapper) .presentation__form,
.presentation.has-vida-form .presentation__form { width: 100%; display: flex; justify-content: center; }

/* ---------- Responsive ---------- */
@media (max-width: 480px) {
  .vida-form { padding: 20px 16px 16px; }
  .vida-date { gap: 8px; }
  .vida-date .vida-select select { padding: 0 22px 0 10px; }
}
@media (min-width: 1024px) {
  .presentation:has(.vida-form-wrapper),
  .presentation.has-vida-form { padding: 56px 16px !important; }
}