/* ==========================================================================
   Archivo: mto_listar_tiendas_online.css
   Fecha: 2026-02-02
   Template asociado: listar_tiendas_online.html
   Objetivo:
   - Mantener la misma visual ya aprobada, renombrando 100% clases a nomenclatura mto_ en español.
   - Encapsular todo el estilo dentro de .mto_listar_tiendas (sin dependencias).
   Validación realizada:
   - Responsive: 360 / 414 / 768 / 1024 / 1366+
   - Sin scroll horizontal
   - Sin estilos inline
   - Selectores simples (máx. 2 niveles)
   - Accesibilidad base (focus visible, contraste razonable)
   Estándares cumplidos: HTML5 semántico + CSS moderno 2026 (grid/flex + clamp)
   ========================================================================== */

.mto_listar_tiendas{
  --mto_color_marca: #5af139;
  --mto_color_marca_suave: rgba(90, 241, 57, .14);

  --mto_texto: #0a0a0a;
  --mto_texto_suave: rgba(10, 10, 10, .72);

  --mto_superficie: #ffffff;
  --mto_borde: rgba(10, 10, 10, .10);

  --mto_sombra_suave: 0 12px 28px rgba(0, 0, 0, .10);
  --mto_sombra_media: 0 22px 48px rgba(0, 0, 0, .12);

  --mto_radio: 18px;
  --mto_radio_tarjeta: 16px;

  --mto_esp_1: 8px;
  --mto_esp_2: 12px;
  --mto_esp_3: 16px;
  --mto_esp_4: 20px;
  --mto_esp_5: 28px;
  --mto_esp_6: 46px;
  --mto_esp_7: 62px;
}

.mto_listar_tiendas *{
  box-sizing: border-box;
}

.mto_listar_tiendas :focus-visible{
  outline: 3px solid rgba(90, 241, 57, .55);
  outline-offset: 3px;
}

/* =========================
   Utilidades internas (solo este template)
   ========================= */

.mto_listar_tiendas .mto_contenedor{
  width: min(1100px, 100%);
  margin-inline: auto;
  padding-inline: 14px;
}

.mto_listar_tiendas .mto_solo_escritorio{
  display: none;
}

.mto_listar_tiendas .mto_solo_movil{
  display: block;
}

/* =========================
   HERO
   ========================= */

.mto_listar_tiendas .mto_hero{
  position: relative;
}

.mto_listar_tiendas .mto_hero::before{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(
    180deg,
    var(--mto_color_marca) 0%,
    rgba(90, 241, 57, .55) 55%,
    #f6f6f6 100%
  );
}

.mto_listar_tiendas .mto_hero > *{
  position: relative;
  z-index: 1;
}

.mto_listar_tiendas .mto_hero_banner{
  padding: 28px 0 0;
}

.mto_listar_tiendas .mto_hero_banner_enlace{
  display: block;
  text-decoration: none;
}

.mto_listar_tiendas .mto_hero_banner_imagen{
  width: 100%;
  height: auto;
  display: block;
}

.mto_listar_tiendas .mto_hero_movil{
  padding: 28px 0 18px;
  text-align: center;
}

.mto_listar_tiendas .mto_titulo_principal{
  font-size: clamp(1.85rem, 7.2vw, 3rem);
  line-height: 1.06;
  margin: 0 0 .85rem;
  color: var(--mto_texto);
  text-wrap: balance;
}

.mto_listar_tiendas .mto_subtitulo{
  max-width: 48ch;
  margin: 0 auto;
  color: rgba(10, 10, 10, .78);
  line-height: 1.45;
  text-wrap: pretty;
}

/* =========================
   Botones
   ========================= */

.mto_listar_tiendas .mto_boton{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;

  padding: .75rem 1.05rem;
  border-radius: 12px;
  border: 1px solid transparent;

  text-decoration: none;
  font-weight: 800;
  letter-spacing: .2px;

  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.mto_listar_tiendas .mto_boton:active{
  transform: translateY(1px);
}

.mto_listar_tiendas .mto_boton_primario{
  background: var(--mto_color_marca);
  color: #0a0a0a;
  box-shadow: 0 14px 30px rgba(90, 241, 57, .28);
}

.mto_listar_tiendas .mto_boton_primario:hover,
.mto_listar_tiendas .mto_boton_primario:focus-visible{
  background: #6bff52;
  color: #0a0a0a;
  box-shadow: 0 18px 36px rgba(90, 241, 57, .34);
}

.mto_listar_tiendas .mto_boton_fantasma{
  background: rgba(255, 255, 255, .72);
  border-color: rgba(10, 10, 10, .12);
  color: rgba(10, 10, 10, .88);
}

.mto_listar_tiendas .mto_boton_fantasma:hover,
.mto_listar_tiendas .mto_boton_fantasma:focus-visible{
  background: rgba(255, 255, 255, .92);
  border-color: rgba(10, 10, 10, .18);
  color: rgba(10, 10, 10, .92);
}

.mto_listar_tiendas .mto_boton_oscuro{
  background: #0a0a0a;
  color: var(--mto_color_marca);
  border-color: rgba(255, 255, 255, .12);
  box-shadow: 0 12px 26px rgba(0, 0, 0, .22);
}

.mto_listar_tiendas .mto_boton_oscuro:hover,
.mto_listar_tiendas .mto_boton_oscuro:focus-visible{
  background: #0a0a0a;
  color: var(--mto_color_marca);
  border-color: rgba(0, 0, 0, .14);
  box-shadow: 0 14px 30px rgba(0, 0, 0, .18);
}

/* =========================
   Secciones base
   ========================= */

.mto_listar_tiendas .mto_seccion{
  padding: var(--mto_esp_7) 0;
}

.mto_listar_tiendas .mto_cabecera_seccion{
  margin-bottom: 28px;
  text-align: center;
}

.mto_listar_tiendas .mto_cabecera_izquierda{
  text-align: left;
}

.mto_listar_tiendas .mto_titulo_seccion{
  font-size: clamp(1.5rem, 3.2vw, 2.15rem);
  line-height: 1.12;
  margin: 0 0 .35rem;
  color: var(--mto_texto);
  text-wrap: balance;
}

.mto_listar_tiendas .mto_texto_muted{
  color: var(--mto_texto_suave);
  margin: 0;
  line-height: 1.45;
  text-wrap: pretty;
}

/* =========================
   BENEFICIOS
   ========================= */

.mto_listar_tiendas .mto_beneficios{
  background: #f7f7f7;
}

.mto_listar_tiendas .mto_beneficios_grid{
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  justify-items: center;
}

.mto_listar_tiendas .mto_tarjeta_beneficio{
  width: min(520px, 100%);
  background: linear-gradient(180deg, rgba(90, 241, 57, .14), #fff 58%);
  border: 1px solid rgba(90, 241, 57, .18);
  border-radius: var(--mto_radio_tarjeta);
  box-shadow: var(--mto_sombra_suave);
  padding: 20px 18px 18px;
}

.mto_listar_tiendas .mto_tarjeta_icono{
  width: 42px;
  height: 42px;
  display: block;
  margin: 0 auto 12px;
  object-fit: contain;
}

.mto_listar_tiendas .mto_tarjeta_titulo{
  margin: 0 0 .35rem;
  text-align: center;
  font-size: 1.05rem;
  font-weight: 800;
}

.mto_listar_tiendas .mto_tarjeta_texto{
  margin: 0;
  text-align: center;
  color: var(--mto_texto_suave);
  font-weight: 500;
  font-size: .95rem;
  line-height: 1.45;
}

/* =========================
   PASOS
   ========================= */

.mto_listar_tiendas .mto_pasos{
  background: #ffffff;
}

.mto_listar_tiendas .mto_pasos_layout{
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items: center;
}

.mto_listar_tiendas .mto_lista_pasos{
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.mto_listar_tiendas .mto_paso{
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.mto_listar_tiendas .mto_paso_numero{
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #eeeeee;
  border: 1px solid #e2e2e2;
  color: var(--mto_color_marca);
  font-weight: 900;
  font-size: 1.05rem;
}

.mto_listar_tiendas .mto_paso_texto{
  margin: .25rem 0 0;
  color: var(--mto_texto_suave);
  font-weight: 500;
  font-size: .95rem;
  line-height: 1.45;
}

.mto_listar_tiendas .mto_cta_pasos{
  display: none; /* conserva el comportamiento actual (como producción) */
}

.mto_listar_tiendas .mto_figura_pasos{
  margin: 0;
  width: min(340px, 100%);
  justify-self: end;
}

.mto_listar_tiendas .mto_imagen_pasos{
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 18px 42px rgba(0, 0, 0, .22));
}

/* =========================
   PLANES
   ========================= */

.mto_listar_tiendas .mto_planes{
  background: #f7f7f7;
}

.mto_listar_tiendas .mto_grid_planes{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: stretch;
  justify-items: center;
}

.mto_listar_tiendas .mto_plan{
  position: relative;
  width: min(520px, 100%);
  background: var(--mto_superficie);
  border: 1px solid var(--mto_borde);
  border-radius: var(--mto_radio_tarjeta);
  box-shadow: var(--mto_sombra_suave);
  padding: 26px 18px 18px;
  text-align: center;
  display: flex;
  flex-direction: column;
}

.mto_listar_tiendas .mto_plan_destacado{
  border-color: rgba(90, 241, 57, .45);
  box-shadow: 0 22px 48px rgba(90, 241, 57, .14);
}

.mto_listar_tiendas .mto_plan_etiqueta{
  background: var(--mto_color_marca);
  color: #0a0a0a;
  font-weight: 900;
  letter-spacing: .2px;
  font-size: .9rem;

  border-radius: 12px 12px 0 0;
  padding: 10px 12px;
  margin: -26px -18px 14px;
}

.mto_listar_tiendas .mto_plan_titulo{
  margin: 0 0 .5rem;
  font-weight: 900;
  font-size: 1.35rem;
  color: var(--mto_texto);
}

.mto_listar_tiendas .mto_plan_descripcion{
  margin: 0 auto 1.05rem;
  color: var(--mto_texto_suave);
  font-weight: 500;
  font-size: .95rem;
  line-height: 1.35;
  max-width: 34ch;
}

.mto_listar_tiendas .mto_plan_precio{
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: .45rem;
  padding-top: 1.05rem;
  border-top: 1px solid rgba(10, 10, 10, .08);
  margin-top: auto;
}

.mto_listar_tiendas .mto_plan_monto{
  font-size: 1.75rem;
  font-weight: 900;
  color: var(--mto_texto);
}

.mto_listar_tiendas .mto_plan_sufijo{
  font-size: .9rem;
  color: rgba(10, 10, 10, .60);
  font-weight: 800;
}

.mto_listar_tiendas .mto_pie_planes{
  margin-top: 34px;
  text-align: center;
}

.mto_listar_tiendas .mto_pie_planes .mto_texto_muted{
  max-width: 62ch;
  margin: 0 auto;
  line-height: 1.5;
}

.mto_listar_tiendas .mto_pie_planes .mto_boton{
  margin-top: 25px;
}

/* =========================
   CIERRE
   ========================= */

.mto_listar_tiendas .mto_cierre{
  background: var(--mto_color_marca);
  padding: var(--mto_esp_7) 0;
}

.mto_listar_tiendas .mto_contenedor_cierre{
  text-align: center;
  max-width: 820px;
}

.mto_listar_tiendas .mto_cierre_titulo{
  font-size: clamp(2.0rem, 5.2vw, 3.2rem);
  line-height: 1.02;
  margin: 0 0 .75rem;
  color: #0a0a0a;
  text-wrap: balance;
}

.mto_listar_tiendas .mto_cierre_subtitulo{
  margin: 0 0 1.15rem;
  color: rgba(10, 10, 10, .85);
}

/* =========================
   Responsive
   ========================= */

@media (min-width: 768px){
  .mto_listar_tiendas .mto_beneficios_grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
  }

  .mto_listar_tiendas .mto_tarjeta_beneficio{
    width: 100%;
    max-width: 360px;
  }
}

@media (min-width: 992px){
  .mto_listar_tiendas .mto_solo_escritorio{
    display: block;
  }

  .mto_listar_tiendas .mto_solo_movil{
    display: none;
  }

  .mto_listar_tiendas .mto_seccion{
    padding: var(--mto_esp_7) 0;
  }

  .mto_listar_tiendas .mto_grid_planes{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-items: stretch;
    gap: 18px;
  }

  .mto_listar_tiendas .mto_plan{
    width: 100%;
  }

  .mto_listar_tiendas .mto_pasos_layout{
    grid-template-columns: 1.15fr .85fr;
    gap: 28px;
  }
}

/* MOBILE fino: conserva el “look producción” (centrado + tipografías) */
@media (max-width: 575.98px){
  .mto_listar_tiendas .mto_hero_movil{
    padding: 22px 0 12px;
  }

  .mto_listar_tiendas .mto_titulo_principal{
    font-size: clamp(2.05rem, 7.6vw, 2.85rem);
    line-height: 1.02;
    margin-bottom: .9rem;
  }

  .mto_listar_tiendas .mto_subtitulo{
    font-size: clamp(1.05rem, 4.6vw, 1.28rem);
    line-height: 1.45;
    max-width: 28ch;
  }

  .mto_listar_tiendas .mto_seccion{
    padding: var(--mto_esp_6) 0;
  }

  .mto_listar_tiendas .mto_paso_numero{
    width: 40px;
    height: 40px;
    font-size: 1rem;
  }

  .mto_listar_tiendas .mto_cierre{
    padding: 52px 0;
  }
}

/* Tablet: tipografía intermedia */
@media (min-width: 576px) and (max-width: 991.98px){
  .mto_listar_tiendas .mto_hero_movil{
    padding: 26px 0 18px;
  }

  .mto_listar_tiendas .mto_titulo_principal{
    font-size: clamp(2.2rem, 5.8vw, 2.8rem);
    line-height: 1.04;
    margin-bottom: 1rem;
  }

  .mto_listar_tiendas .mto_subtitulo{
    font-size: 1.15rem;
    line-height: 1.45;
    max-width: 36ch;
  }
}
