#jm-ruta {
  --jm-bg:      #090C14;
  --jm-gold:    #C9973B;
  --jm-gold-lt: rgba(201,151,59,.13);
  --jm-gold-bd: rgba(201,151,59,.28);
  --jm-navy:    #0F2748;
  --jm-navy2:   #1A3F72;
  --jm-teal:    #0B7B6E;
  --jm-green:   #16A34A;
  --jm-red:     #C0392B;
  --jm-card:    #FFFFFF;
  --jm-text:    #0F1E33;
  --jm-muted:   #5B6F85;
  --jm-border:  #DDE6F0;
  --jm-soft:    #F4F8FD;
  --jm-wh:      #FFFFFF;
  --jm-wh2:     rgba(255,255,255,.68);
  --jm-wh3:     rgba(255,255,255,.36);
  --jm-r:       20px;
  --jm-rb:      50px;
  --jm-ease:    cubic-bezier(.4,0,.2,1);
  --jm-spring:  cubic-bezier(.175,.885,.32,1.275);
  --jm-gb:      linear-gradient(135deg,#0F2748 0%,#1A3F72 100%);
  --jm-gg:      linear-gradient(135deg,#C9973B 0%,#E8B84B 100%);
  --jm-shadow:  0 28px 72px rgba(0,0,0,.45);

  /* Sección completa */
  /*padding: 88px 0 96px;*/
  position: relative;
  overflow: hidden;
  /*font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;*/
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}
#jm-ruta *,#jm-ruta *::before,#jm-ruta *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
/* Decoración de fondo */
#jm-ruta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 600px 400px at 0% 0%, rgba(26,63,114,.2) 0%, transparent 70%),
    radial-gradient(ellipse 500px 600px at 100% 100%, rgba(201,151,59,.07) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* ── Pantallas ──────────────────────────────────────────────── */
#jm-ruta .jm-screen { position: relative; z-index: 1; }
#jm-ruta .jm-hidden { display: none !important; }

/* ── Contenedor ─────────────────────────────────────────────── */
#jm-ruta .jm-wrap {
  /*max-width: 1180px;*/
  margin: 0 auto;
  /*padding: 0 24px;*/
}

/* ── Layout de bienvenida — 2 columnas ──────────────────────── */
#jm-ruta .jm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 900px) {
  #jm-ruta .jm-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  #jm-ruta .jm-col-visual {
    order: -1; /* Visual primero en móvil */
  }
}

/* ── Columna izquierda: copy ────────────────────────────────── */
#jm-ruta .jm-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.2px;
  color: var(--jm-gold);
  margin-bottom: 18px;
}
#jm-ruta .jm-eye-ico { font-size: 1rem; }

#jm-ruta .jm-h2 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 700;
  line-height: 1.18;
  color: var(--jm-wh);
  margin-bottom: 18px;
}
#jm-ruta .jm-h2 em {
  font-style: italic;
  color: var(--jm-gold);
}
#jm-ruta .jm-lead {
  font-size: 1rem;
  color: var(--jm-wh2);
  line-height: 1.6;
  margin-bottom: 28px;
  max-width: 480px;
}

/* Features */
#jm-ruta .jm-feats {
  list-style: none;
  margin-bottom: 28px;
}
#jm-ruta .jm-feats li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 7px 0;
  font-size: .93rem;
  font-weight: 500;
  color: var(--jm-wh);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
#jm-ruta .jm-feats li:last-child { border-bottom: none; }
#jm-ruta .jm-fi {
  font-size: 1.05rem;
  width: 32px;
  flex-shrink: 0;
}

/* Stats */
#jm-ruta .jm-stats-row {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 32px;
  flex-wrap: wrap;
  row-gap: 8px;
}
#jm-ruta .jm-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 20px;
}
#jm-ruta .jm-stat:first-child { padding-left: 0; }
#jm-ruta .jm-stat strong {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--jm-gold);
  line-height: 1;
}
#jm-ruta .jm-stat span {
  font-size: .62rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--jm-wh3);
  margin-top: 3px;
}
#jm-ruta .jm-stat-div {
  width: 1px;
  height: 32px;
  background: rgba(255,255,255,.12);
  flex-shrink: 0;
}

/* CTA principal */
#jm-ruta .jm-btn-main {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 15px 32px;
  background: var(--jm-gg);
  color: #0F1E33;
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  font-weight: 800;
  border: none;
  border-radius: var(--jm-rb);
  cursor: pointer;
  box-shadow: 0 8px 28px rgba(201,151,59,.38);
  transition: transform .22s var(--jm-ease), box-shadow .22s var(--jm-ease);
  letter-spacing: .1px;
  margin-bottom: 12px;
}
#jm-ruta .jm-btn-main:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 38px rgba(201,151,59,.52);
}
#jm-ruta .jm-disc {
  font-size: .72rem;
  color: var(--jm-wh3);
}

/* ── Columna derecha: visual ────────────────────────────────── */
#jm-ruta .jm-visual-wrap {
  position: relative;
  padding: 16px;
}

/* Tarjetas de preview */
#jm-ruta .jm-pv-card {
  background: var(--jm-card);
  border-radius: 16px;
  padding: 14px 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,.28);
  border: 1.5px solid var(--jm-border);
  position: relative;
  transition: transform .3s var(--jm-ease);
}
#jm-ruta .jm-pv1 {
  border-color: var(--jm-gold-bd);
  box-shadow: 0 12px 40px rgba(201,151,59,.2), 0 4px 16px rgba(0,0,0,.2);
  z-index: 3;
  animation: jm-float1 4s ease-in-out infinite;
}
#jm-ruta .jm-pv2 {
  margin-top: 10px;
  margin-left: 24px;
  margin-right: -12px;
  z-index: 2;
  opacity: .92;
  animation: jm-float2 4.5s ease-in-out infinite;
}
#jm-ruta .jm-pv3 {
  margin-top: 8px;
  margin-left: 48px;
  margin-right: -24px;
  z-index: 1;
  opacity: .72;
  animation: jm-float3 5s ease-in-out infinite;
}
@keyframes jm-float1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes jm-float2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-4px)} }
@keyframes jm-float3 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-2px)} }

#jm-ruta .jm-pv-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--jm-border);
}
#jm-ruta .jm-pv-rank {
  font-size: .66rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--jm-muted);
}
#jm-ruta .jm-pv1 .jm-pv-rank { color: var(--jm-gold); }
#jm-ruta .jm-pv-pct {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--jm-muted);
}
#jm-ruta .jm-pv1 .jm-pv-pct { color: var(--jm-gold); }
#jm-ruta .jm-pv-body {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
#jm-ruta .jm-pv-emo {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: var(--jm-gb);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
#jm-ruta .jm-pv-zona { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--jm-muted); margin-bottom: 2px; }
#jm-ruta .jm-pv-name { font-size: .9rem; font-weight: 800; color: var(--jm-text); }
#jm-ruta .jm-pv-pills {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}
#jm-ruta .jm-pv-pills span {
  font-size: .66rem;
  font-weight: 600;
  color: var(--jm-muted);
  background: var(--jm-soft);
  border: 1px solid var(--jm-border);
  border-radius: 6px;
  padding: 3px 7px;
}

/* Badge legal flotante */
#jm-ruta .jm-legal-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(11,123,110,.15);
  border: 1px solid rgba(11,123,110,.3);
  border-radius: 100px;
  padding: 7px 14px;
  font-size: .72rem;
  font-weight: 700;
  color: #4ADE80;
  margin-top: 14px;
}

/* ── Contenedor del quiz ────────────────────────────────────── */
#jm-ruta .jm-quiz-wrap {
  max-width: 480px;
    margin: 0 auto;
}
#jm-ruta .jm-card {
  background: var(--jm-card);
  border-radius: var(--jm-r);
  box-shadow: var(--jm-shadow);
  overflow: hidden;
}

/* ── Progreso (segmentos) ───────────────────────────────────── */
#jm-ruta .jm-prog { padding: 14px 20px 0; }
#jm-ruta .jm-segs { display: flex; gap: 3px; margin-bottom: 8px; }
#jm-ruta .jm-seg {
  flex: 1;
  height: 3px;
  border-radius: 100px;
  background: var(--jm-border);
  overflow: hidden;
  position: relative;
}
#jm-ruta .jm-sf {
  position: absolute;
  inset: 0;
  background: var(--jm-gg);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .42s var(--jm-ease);
}
#jm-ruta .jm-seg.jm-done .jm-sf { transform: scaleX(1); }
#jm-ruta .jm-seg.jm-cur .jm-sf  { transform: scaleX(1); opacity: .45; }
#jm-ruta .jm-prow { display: flex; justify-content: space-between; }
#jm-ruta .jm-plbl { font-size: .62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--jm-muted); }
#jm-ruta .jm-pnum { font-size: .62rem; font-weight: 800; color: var(--jm-gold); }

/* ── Pregunta ───────────────────────────────────────────────── */
#jm-ruta .jm-qh { padding: 17px 22px 13px; border-bottom: 1px solid var(--jm-border); }
#jm-ruta .jm-qi {
  width: 42px; height: 42px; border-radius: 11px;
  background: var(--jm-gb);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; margin-bottom: 9px;
}
#jm-ruta .jm-qt { font-size: 1.08rem; font-weight: 800; color: var(--jm-text); line-height: 1.24; margin-bottom: 2px; }
#jm-ruta .jm-qs { font-size: .79rem; color: var(--jm-muted); }
#jm-ruta .jm-qb { padding: 13px 22px 12px; }
#jm-ruta .jm-qf { padding: 0 22px 20px; }

/* Inputs */
#jm-ruta .jm-inp {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--jm-border);
  border-radius: 11px;
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem;
  color: var(--jm-text);
  font-weight: 500;
  background: var(--jm-soft);
  outline: none;
  transition: border-color .16s, box-shadow .16s;
}
#jm-ruta .jm-inp:focus { border-color: var(--jm-navy2); background: #fff; box-shadow: 0 0 0 3px rgba(26,63,114,.09); }
#jm-ruta .jm-inp::placeholder { color: #B8C4CF; font-weight: 400; }
#jm-ruta .jm-inp.jm-ok  { border-color: var(--jm-teal); }
#jm-ruta .jm-inp.jm-err { border-color: var(--jm-red); }
#jm-ruta .jm-inp.jm-ta  { min-height: 82px; resize: none; line-height: 1.5; }
#jm-ruta .jm-fm { font-size: .68rem; margin-top: 4px; padding-left: 3px; font-weight: 600; }
#jm-ruta .jm-fm.jm-ok  { color: var(--jm-teal); }
#jm-ruta .jm-fm.jm-err { color: var(--jm-red); }

/* Teléfono */
#jm-ruta .jm-ph-row { display: flex; gap: 7px; }
#jm-ruta .jm-lw { position: relative; flex-shrink: 0; }
#jm-ruta .jm-ls {
  appearance: none;
  padding: 11px 25px 11px 11px;
  border: 1.5px solid var(--jm-border);
  border-radius: 11px;
  font-family: 'DM Sans', sans-serif;
  font-size: .82rem; font-weight: 600;
  color: var(--jm-text); background: var(--jm-soft);
  cursor: pointer; outline: none;
  min-width: 83px; transition: border-color .16s;
}
#jm-ruta .jm-ls:focus { border-color: var(--jm-navy2); }
#jm-ruta .jm-lw::after { content:'▾'; position:absolute; right:8px; top:50%; transform:translateY(-50%); color:var(--jm-muted); pointer-events:none; font-size:.68rem; }

/* Opciones */
#jm-ruta .jm-opts { display: flex; flex-direction: column; gap: 6px; }
#jm-ruta .jm-opt {
  width: 100%; padding: 10px 13px;
  border: 1.5px solid var(--jm-border); border-radius: 11px;
  background: #fff; font-family: 'DM Sans', sans-serif;
  font-size: .85rem; font-weight: 600; color: var(--jm-text);
  cursor: pointer; display: flex; align-items: center; gap: 9px; text-align: left;
  transition: border-color .13s, background .13s, transform .12s;
}
#jm-ruta .jm-opt:hover { border-color: var(--jm-navy2); background: rgba(26,63,114,.03); transform: translateX(3px); }
#jm-ruta .jm-opt.jm-sel {
  border-color: var(--jm-navy);
  background: linear-gradient(135deg, rgba(15,39,72,.06), rgba(26,63,114,.06));
  color: var(--jm-navy); transform: translateX(3px);
}
#jm-ruta .jm-opt.jm-sel .jm-chk { display: flex; }
#jm-ruta .jm-oe { font-size: .96rem; width: 20px; text-align: center; flex-shrink: 0; }
#jm-ruta .jm-chk {
  margin-left: auto; width: 18px; height: 18px; border-radius: 50%;
  background: var(--jm-navy); display: none;
  align-items: center; justify-content: center;
  flex-shrink: 0; font-size: .65rem; color: #fff; font-weight: 700;
}

/* Botones de navegación */
#jm-ruta .jm-bn {
  width: 100%; padding: 12px 20px;
  background: var(--jm-gb); color: #fff;
  font-family: 'DM Sans', sans-serif; font-size: .9rem; font-weight: 700;
  border: none; border-radius: var(--jm-rb); cursor: pointer;
  box-shadow: 0 8px 24px rgba(15,39,72,.32);
  display: flex; align-items: center; justify-content: center; gap: 7px;
  opacity: .33; pointer-events: none;
  transition: opacity .2s, transform .2s, box-shadow .2s;
}
#jm-ruta .jm-bn.jm-on { opacity: 1; pointer-events: all; }
#jm-ruta .jm-bn.jm-on:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(15,39,72,.46); }
#jm-ruta .jm-bbk {
  background: none; border: none; cursor: pointer;
  color: var(--jm-muted); font-family: 'DM Sans', sans-serif;
  font-size: .76rem; font-weight: 600; padding: 3px 0;
  display: flex; align-items: center; gap: 4px;
  margin-bottom: 7px; transition: color .12s;
}
#jm-ruta .jm-bbk:hover { color: var(--jm-navy); }
#jm-ruta .jm-bsk {
  background: none; border: none; cursor: pointer;
  color: var(--jm-muted); font-family: 'DM Sans', sans-serif;
  font-size: .72rem; font-weight: 600; padding: 7px 0 0;
  display: flex; align-items: center; justify-content: center; width: 100%;
  transition: color .12s;
}
#jm-ruta .jm-bsk:hover { color: var(--jm-navy); }

/* Animaciones de swipe */
@keyframes jm-sIR { from { opacity:0; transform:translateX(60px) scale(.97) } to { opacity:1; transform:none } }
@keyframes jm-sIL { from { opacity:0; transform:translateX(-60px) scale(.97) } to { opacity:1; transform:none } }
@keyframes jm-sOL { from { opacity:1 } to { opacity:0; transform:translateX(-50px) } }
@keyframes jm-sOR { from { opacity:1 } to { opacity:0; transform:translateX(50px) } }
#jm-ruta .jm-aIR { animation: jm-sIR .3s var(--jm-ease) forwards; }
#jm-ruta .jm-aIL { animation: jm-sIL .3s var(--jm-ease) forwards; }
#jm-ruta .jm-aOL { animation: jm-sOL .18s var(--jm-ease) forwards; }
#jm-ruta .jm-aOR { animation: jm-sOR .18s var(--jm-ease) forwards; }

/* ── Procesando ─────────────────────────────────────────────── */
#jm-ruta .jm-proc { padding: 44px 26px; text-align: center; }
#jm-ruta .jm-proc-ico { width: 58px; height: 58px; border-radius: 16px; background: var(--jm-gb); display: inline-flex; align-items: center; justify-content: center; font-size: 1.65rem; margin-bottom: 18px; box-shadow: 0 12px 28px rgba(15,39,72,.26); }
#jm-ruta .jm-proc-t { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700; color: var(--jm-text); margin-bottom: 4px; }
#jm-ruta .jm-proc-s { font-size: .82rem; color: var(--jm-muted); margin-bottom: 22px; }
#jm-ruta .jm-proc-steps { text-align: left; }
#jm-ruta .jm-ps { display: flex; align-items: center; gap: 10px; padding: 5px 0; font-size: .82rem; font-weight: 500; color: var(--jm-muted); opacity: 0; transform: translateY(7px); transition: opacity .3s, transform .3s, color .28s; }
#jm-ruta .jm-ps.jm-show { opacity: 1; transform: none; }
#jm-ruta .jm-ps.jm-done { color: var(--jm-teal); }
#jm-ruta .jm-pd { width: 7px; height: 7px; border-radius: 50%; background: var(--jm-border); flex-shrink: 0; transition: background .28s; }
#jm-ruta .jm-ps.jm-done .jm-pd { background: var(--jm-teal); }

/* ── Resultados ─────────────────────────────────────────────── */
#jm-ruta .jm-res-hero { background: var(--jm-gb); padding: 28px 22px 20px; text-align: center; position: relative; overflow: hidden; }
#jm-ruta .jm-res-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% -10%, rgba(201,151,59,.15) 0%, transparent 55%); pointer-events:none; }
#jm-ruta .jm-res-seal { width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.12); border: 1.5px solid rgba(201,151,59,.4); display: inline-flex; align-items: center; justify-content: center; font-size: 1.35rem; margin-bottom: 9px; }
#jm-ruta .jm-res-ey { font-size: .63rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--jm-gold); margin-bottom: 5px; }
#jm-ruta .jm-res-t { font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 700; color: #fff; margin-bottom: 3px; line-height: 1.22; }
#jm-ruta .jm-res-t em { font-style: italic; color: var(--jm-gold); }
#jm-ruta .jm-res-s { font-size: .8rem; color: rgba(255,255,255,.68); }

/* Cards de resultado */
#jm-ruta .jm-res-body { padding: 16px 15px 10px; }
#jm-ruta .jm-rl { font-size: .6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--jm-muted); margin-bottom: 10px; }
#jm-ruta .jm-dc { border-radius: 13px; overflow: hidden; border: 1.5px solid var(--jm-border); margin-bottom: 8px; transition: box-shadow .16s; }
#jm-ruta .jm-dc.jm-r1 { border-color: var(--jm-gold-bd); box-shadow: 0 4px 16px rgba(201,151,59,.12); }
#jm-ruta .jm-dc.jm-r1:hover { box-shadow: 0 7px 24px rgba(201,151,59,.2); }
#jm-ruta .jm-dc.jm-r2:hover, #jm-ruta .jm-dc.jm-r3:hover { box-shadow: 0 4px 12px rgba(0,0,0,.06); }
#jm-ruta .jm-dt { display: flex; align-items: center; justify-content: space-between; padding: 9px 12px 8px; border-bottom: 1px solid var(--jm-border); }
#jm-ruta .jm-drr { display: flex; align-items: center; gap: 7px; }
#jm-ruta .jm-drk { font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; color: var(--jm-muted); }
#jm-ruta .jm-r1 .jm-drk { color: var(--jm-gold); }
#jm-ruta .jm-dbd { font-size: .58rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; padding: 2px 6px; border-radius: 100px; }
#jm-ruta .jm-bg { background: var(--jm-gold-lt); color: var(--jm-gold); border: 1px solid var(--jm-gold-bd); }
#jm-ruta .jm-bn2 { background: rgba(15,39,72,.08); color: var(--jm-navy2); border: 1px solid rgba(26,63,114,.17); }
#jm-ruta .jm-dp { display: flex; flex-direction: column; align-items: flex-end; }
#jm-ruta .jm-dpn { font-size: 1.06rem; font-weight: 800; color: var(--jm-muted); }
#jm-ruta .jm-r1 .jm-dpn { color: var(--jm-gold); }
#jm-ruta .jm-dpl { font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--jm-muted); margin-top: 1px; }
#jm-ruta .jm-dm { display: flex; align-items: flex-start; gap: 9px; padding: 10px 12px 8px; }
#jm-ruta .jm-de { width: 35px; height: 35px; border-radius: 9px; flex-shrink: 0; background: var(--jm-gb); display: flex; align-items: center; justify-content: center; font-size: 1rem; }
#jm-ruta .jm-r1 .jm-de { width: 39px; height: 39px; border-radius: 11px; font-size: 1.15rem; }
#jm-ruta .jm-dz { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--jm-muted); margin-bottom: 2px; }
#jm-ruta .jm-dn { font-size: .91rem; font-weight: 800; color: var(--jm-text); line-height: 1.2; }
#jm-ruta .jm-r1 .jm-dn { font-size: 1rem; }
#jm-ruta .jm-dd { font-size: .75rem; color: var(--jm-muted); line-height: 1.52; padding: 0 12px 8px; display: none; }
#jm-ruta .jm-r1 .jm-dd { display: block; }
#jm-ruta .jm-dmet { display: flex; gap: 5px; flex-wrap: wrap; padding: 0 12px 9px; align-items: center; }
#jm-ruta .jm-dm-pill { font-size: .7rem; font-weight: 600; border-radius: 7px; padding: 3px 7px; border: 1px solid var(--jm-border); color: var(--jm-text); background: var(--jm-soft); }
#jm-ruta .jm-dm-mens { font-size: .77rem; font-weight: 800; color: var(--jm-navy); background: var(--jm-gold-lt); border-color: var(--jm-gold-bd); padding: 4px 9px; }
#jm-ruta .jm-r1 .jm-dm-mens { font-size: .82rem; }
#jm-ruta .jm-dm-green { background: rgba(22,163,74,.08); color: var(--jm-green); border-color: rgba(22,163,74,.2); }
#jm-ruta .jm-dm-navy { background: rgba(15,39,72,.07); color: var(--jm-navy2); border-color: rgba(26,63,114,.17); }
#jm-ruta .jm-dlg { display: flex; align-items: center; gap: 5px; margin: 0 12px 10px; font-size: .68rem; font-weight: 600; color: var(--jm-teal); background: rgba(11,123,110,.07); border-radius: 7px; padding: 5px 8px; }
#jm-ruta .jm-dcta { padding: 0 12px 12px; }
#jm-ruta .jm-dcb { display: flex; align-items: center; justify-content: center; gap: 6px; width: 100%; padding: 9px 14px; border: none; border-radius: var(--jm-rb); cursor: pointer; font-family: 'DM Sans', sans-serif; font-size: .81rem; font-weight: 700; text-decoration: none; transition: transform .15s, box-shadow .15s; color: #fff; }
#jm-ruta .jm-r1 .jm-dcb { background: var(--jm-gb); box-shadow: 0 6px 16px rgba(15,39,72,.28); padding: 11px 14px; font-size: .85rem; }
#jm-ruta .jm-r1 .jm-dcb:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(15,39,72,.4); }
#jm-ruta .jm-r2 .jm-dcb, #jm-ruta .jm-r3 .jm-dcb { background: var(--jm-soft); color: var(--jm-navy); border: 1.5px solid rgba(26,63,114,.17); }
#jm-ruta .jm-r2 .jm-dcb:hover, #jm-ruta .jm-r3 .jm-dcb:hover { background: rgba(26,63,114,.05); }

/* Perfil resumen */
#jm-ruta .jm-pb { background: var(--jm-soft); border-radius: 12px; border: 1px solid var(--jm-border); padding: 12px 14px; margin-bottom: 13px; }
#jm-ruta .jm-pbh { font-size: .59rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--jm-muted); margin-bottom: 8px; }
#jm-ruta .jm-pbg { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
#jm-ruta .jm-pbi { font-size: .74rem; }
#jm-ruta .jm-pbk { color: var(--jm-muted); font-weight: 500; }
#jm-ruta .jm-pbv { color: var(--jm-text); font-weight: 700; }

/* Testimonios */
#jm-ruta .jm-test-section { padding: 0 15px 14px; }
#jm-ruta .jm-th { font-size: .6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--jm-muted); margin-bottom: 9px; padding-top: 4px; border-top: 1px solid var(--jm-border); display: flex; align-items: center; justify-content: space-between; }
#jm-ruta .jm-th-g { font-size: .6rem; color: var(--jm-gold); font-weight: 600; }
#jm-ruta .jm-tg { display: flex; flex-direction: column; gap: 7px; }
#jm-ruta .jm-tc { background: var(--jm-soft); border: 1px solid var(--jm-border); border-radius: 11px; padding: 11px 13px; }
#jm-ruta .jm-tst { font-size: .76rem; color: #B8860B; margin-bottom: 4px; letter-spacing: .5px; }
#jm-ruta .jm-tt { font-size: .77rem; color: var(--jm-text); line-height: 1.54; margin-bottom: 6px; font-style: italic; }
#jm-ruta .jm-ta2 { display: flex; align-items: center; gap: 7px; }
#jm-ruta .jm-tav { width: 24px; height: 24px; border-radius: 50%; background: var(--jm-gb); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: .7rem; color: #fff; font-weight: 700; }
#jm-ruta .jm-tn { font-size: .73rem; font-weight: 700; color: var(--jm-text); }
#jm-ruta .jm-tf { font-size: .65rem; color: var(--jm-muted); }

/* CTAs finales */
#jm-ruta .jm-res-cta { padding: 0 15px 20px; }
#jm-ruta .jm-rch { font-size: .6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--jm-muted); text-align: center; margin-bottom: 10px; }
#jm-ruta .jm-rcg { display: flex; flex-direction: column; gap: 7px; }
#jm-ruta .jm-btn-wa { width: 100%; padding: 13px 20px; background: linear-gradient(135deg,#1EBE65,#128C7E); color: #fff; font-family: 'DM Sans', sans-serif; font-size: .9rem; font-weight: 700; border: none; border-radius: var(--jm-rb); cursor: pointer; box-shadow: 0 8px 20px rgba(30,190,101,.28); display: flex; align-items: center; justify-content: center; gap: 7px; transition: transform .2s, box-shadow .2s; }
#jm-ruta .jm-btn-wa:hover { transform: translateY(-2px); }
#jm-ruta .jm-btn-ghost { width: 100%; padding: 12px 20px; background: transparent; border: 1.5px solid rgba(255,255,255,.15); color: rgba(255,255,255,.6); font-family: 'DM Sans', sans-serif; font-size: .88rem; font-weight: 600; border-radius: var(--jm-rb); cursor: pointer; transition: border-color .2s, color .2s; }
#jm-ruta .jm-btn-ghost:hover { border-color: rgba(255,255,255,.35); color: #fff; }
#jm-ruta .jm-nok { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 8px; background: rgba(11,123,110,.09); border-radius: 9px; font-size: .73rem; color: var(--jm-teal); font-weight: 600; margin-top: 7px; }

/* Reveal animation */
@keyframes jm-revUp { 0%{opacity:0;transform:translateY(24px) scale(.95)} 70%{transform:translateY(-3px) scale(1.01)} 100%{opacity:1;transform:none} }
#jm-ruta .jm-reveal { animation: jm-revUp .58s var(--jm-spring) forwards; }

/* Responsive quiz */
@media (max-width: 560px) {
  #jm-ruta { padding: 60px 0 72px; }
  #jm-ruta .jm-wrap { padding: 0 16px; }
  #jm-ruta .jm-qh { padding: 13px 16px 11px; }
  #jm-ruta .jm-qb { padding: 11px 16px 11px; }
  #jm-ruta .jm-qf { padding: 0 16px 17px; }
  #jm-ruta .jm-prog { padding: 11px 16px 0; }
  #jm-ruta .jm-res-body { padding: 13px 11px 8px; }
  #jm-ruta .jm-test-section, #jm-ruta .jm-res-cta { padding-left: 11px; padding-right: 11px; }
}