
/* ===================== CATÁLOGO (aislado) ===================== */
/* Todo el catálogo se encapsula en .page-catalogo para no afectar el home */

/* Título/intro */
.page-catalogo .catalogo-title {
  text-align: center;
  margin: 16px 0 6px;
  color: var(--blue);
  font-size: 28px;
}
.page-catalogo .catalogo-intro {
  text-align: center;
  margin-bottom: 18px;
  color: var(--gray-dark);
  opacity: 0.9;
}



/* ===== Filtros ===== */
.page-catalogo .catalogo-filters {
  background: var(--gray-light);
  border-radius: 12px;
  padding: 12px;
  margin-bottom: 16px;
}
.page-catalogo .catalogo-filters .filters-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.page-catalogo .catalogo-filters .filter label {
  font-size: 12px;
  color: var(--gray-dark);
  display: block;
  margin-bottom: 4px;
}
.page-catalogo .catalogo-filters .filter input,
.page-catalogo .catalogo-filters .filter select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #e3e3e3;
  border-radius: 10px;
  font-size: 14px;
  outline: none;
}
.page-catalogo .catalogo-filters .filter.price input::-webkit-outer-spin-button,
.page-catalogo .catalogo-filters .filter.price input::-webkit-inner-spin-button {
  -webkit-appearance: none; margin: 0;
}
.page-catalogo .catalogo-filters .filter.actions { display: flex; align-items: end; }
.page-catalogo .catalogo-filters .btn-secondary {
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid var(--blue);
  background: #fff;
  color: var(--blue);
  cursor: pointer;
}

/* ===== Grilla ===== */
.page-catalogo .catalog-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  outline: none; /* para focus programático en paginación */
}
.page-catalogo .catalog-grid:focus {
  box-shadow: 0 0 0 2px var(--orange);
  border-radius: 8px;
}

/* IMPORTANTE: no tocar la .producto-card global del home */
/* Para catálogo, estilamos solo las tarjetas dentro de la grilla de catálogo */
.page-catalogo .catalog-grid .producto-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 12px;
  overflow: hidden;
  transition: transform .15s ease;
  min-height: 100%;
}
.page-catalogo .catalog-grid .producto-card:hover { transform: translateY(-2px); }

.page-catalogo .catalog-grid .producto-media {
  aspect-ratio: 4 / 3;
  background: #fafafa;
  display: block;
}
.page-catalogo .catalog-grid .producto-media img {
  width: 100%; height: 100%; object-fit: cover;
}

.page-catalogo .catalog-grid .producto-info {
  padding: 10px 12px 12px; display: grid; gap: 6px;
}
.page-catalogo .catalog-grid .producto-title {
  font-size: 16px; color: var(--gray-dark);
}
.page-catalogo .catalog-grid .clamp-2 {
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.page-catalogo .catalog-grid .producto-price {
  font-weight: bold; color: var(--blue);
}
.page-catalogo .catalog-grid .producto-meta {
  display: flex; gap: 8px; flex-wrap: wrap; font-size: 12px;
}
.page-catalogo .catalog-grid .badge {
  display: inline-block; padding: 4px 8px; border-radius: 999px; background: var(--gray-light); color: var(--gray-dark);
}
.page-catalogo .catalog-grid .badge-condition { background: #eef8ff; color: var(--blue); }
.page-catalogo .catalog-grid .badge-category { background: #fff4ec; color: var(--orange); }
.page-catalogo .catalog-grid .producto-actions { margin-top: 6px; }
.page-catalogo .catalog-grid .producto-actions .btn-primary { width: 100%; }

/* ===== Paginación ===== */
.page-catalogo .pagination {
  display: flex; align-items: center; gap: 6px; justify-content: center; margin: 18px 0 24px;
}
.page-catalogo .pagination .page-btn {
  min-width: 36px; height: 36px;
  border-radius: 8px; border: 1px solid #ddd; background: #fff; cursor: pointer;
}
.page-catalogo .pagination .page-btn.active,
.page-catalogo .pagination .page-btn:hover {
  border-color: var(--blue); box-shadow: 0 0 0 2px rgba(32,62,150,0.08);
}
.page-catalogo .pagination .page-btn[disabled] { opacity: .5; cursor: default; }
.page-catalogo .pagination .ellipsis { color: #999; }

/* ===== Estado vacío ===== */
.page-catalogo .catalog-empty { text-align: center; padding: 24px 12px; }
.page-catalogo .catalog-empty .btn-secondary { margin-top: 8px; }

/* ===== Modal del catálogo (IDs para no tocar el modal del home) ===== */
#product-modal[hidden] { display: none !important; }
#product-modal-overlay[hidden] { display: none !important; }

#product-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 1999;
}
#product-modal {
  position: fixed; inset: 0; display: grid; place-items: center; z-index: 2000;
}
#product-modal .modal-content {
  background: #fff; border-radius: 16px; max-width: 960px;
  width: min(96vw, 960px); padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}
#product-modal .btn-close {
  background: transparent; border: none; font-size: 22px; line-height: 1; cursor: pointer; float: right; color: #666;
}
#product-modal .modal-body {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 16px; padding: 8px 4px 12px;
}
#product-modal .modal-figure {
  aspect-ratio: 4/3; background: #fafafa; border-radius: 12px; overflow: hidden;
}
#product-modal .modal-figure img { width: 100%; height: 100%; object-fit: cover; }

#product-modal .modal-title { font-size: 22px; color: var(--gray-dark); margin-bottom: 8px; }
#product-modal .modal-price { font-size: 20px; color: var(--blue); font-weight: bold; margin-bottom: 8px; }
#product-modal .modal-badges .badge { margin-right: 6px; }
#product-modal .modal-description { color: var(--gray-dark); margin: 10px 0 14px; }
#product-modal .modal-cta .btn-primary { width: 100%; }

/* ===== Responsive catálogo ===== */
@media (max-width: 1080px) {
  .page-catalogo .catalogo-filters .filters-row { grid-template-columns: repeat(3, 1fr); }
  .page-catalogo .catalog-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .page-catalogo .catalogo-filters .filters-row { grid-template-columns: 1fr 1fr; }
  .page-catalogo .catalog-grid { grid-template-columns: repeat(2, 1fr); }
  #product-modal .modal-body { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .page-catalogo .catalog-grid { grid-template-columns: 1fr; }
}
/* ===== Breadcrumb ===== */
.page-catalogo .catalogo-breadcrumb {
  background: #f7f8fc;
  border-bottom: 1px solid #eceff6;
  padding: 8px 0;
}
.page-catalogo .catalogo-breadcrumb ol {
  list-style: none; display: flex; gap: 8px; padding: 0; margin: 0; align-items: center;
  font-size: 14px; color: #6b7280;
}
.page-catalogo .catalogo-breadcrumb a { color: var(--blue); font-weight: 700; }
.page-catalogo .catalogo-breadcrumb li+li::before {
  content: "›"; margin-right: 8px; color: #9aa3b2;
}

/* ===== Head compacto ===== */
.page-catalogo .catalogo-head {
  background: #fff;
  padding: 18px 0 10px;
}
.page-catalogo .catalogo-head .catalogo-title {
  text-align: left;
  margin: 0 0 6px;
  color: var(--blue);
  font-size: 28px;
}
.page-catalogo .catalogo-head .catalogo-subtitle {
  margin: 0;
  color: var(--gray-dark);
  opacity: .9;
}

/* ===== Filtros en UNA sola línea (wrapping en mobile) ===== */
.page-catalogo .catalogo-filters {
  background: var(--gray-light);
  border-radius: 12px;
  padding: 10px;
  margin: 12px 0 16px;
}
.page-catalogo .catalogo-filters .filters-row.one-line {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.9fr 0.9fr auto; /* search, cat, cond, sort, limpiar */
  gap: 10px;
  align-items: end;
}
.page-catalogo .catalogo-filters .filter label {
  font-size: 12px; color: var(--gray-dark); display: block; margin-bottom: 4px;
}
.page-catalogo .catalogo-filters .filter input,
.page-catalogo .catalogo-filters .filter select {
  width: 100%; padding: 10px 12px; border: 1px solid #e3e3e3; border-radius: 10px; font-size: 14px; outline: none;
}
.page-catalogo .catalogo-filters .filter.actions { display: flex; align-items: end; }
.page-catalogo .catalogo-filters .btn-secondary {
  padding: 10px 14px; border-radius: 10px; border: 1px solid var(--blue);
  background: #fff; color: var(--blue); cursor: pointer; white-space: nowrap;
}

/* Responsive: que wrapee prolijo */
@media (max-width: 992px) {
  .page-catalogo .catalogo-filters .filters-row.one-line {
    grid-template-columns: 1fr 1fr 1fr; /* search arriba, resto abajo */
  }
  .page-catalogo #search { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .page-catalogo .catalogo-filters .filters-row.one-line {
    grid-template-columns: 1fr 1fr;
  }
  .page-catalogo #search { grid-column: 1 / -1; }
}
/* ===== Tarjetas del catálogo: alto consistente ===== */
.page-catalogo .catalog-grid .producto-card{
  display: flex;
  flex-direction: column;
}

.page-catalogo .catalog-grid .producto-media{
  aspect-ratio: 4 / 3;
  background: #fafafa;
  flex-shrink: 0;
}
.page-catalogo .catalog-grid .producto-media img{
  width: 100%; height: 100%; object-fit: cover;
}

/* Cuerpo en grid para alinear piezas y empujar el botón abajo */
.page-catalogo .catalog-grid .producto-info{
  display: grid;
  grid-template-rows: auto auto auto 1fr auto; /* título, precio, badges, spacer, botón */
  gap: 6px;
  padding: 10px 12px 12px;
}

/* Título: dos líneas reservadas siempre */
.page-catalogo .catalog-grid .producto-title{
  font-size: 16px; color: var(--gray-dark);
  min-height: 2.6em; /* ≈ 2 líneas */
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* Precio fijo y notorio */
.page-catalogo .catalog-grid .producto-price{
  font-weight: 700; color: var(--blue); line-height: 1.2;
}

/* Badges con altura mínima para que no “salten” */
.page-catalogo .catalog-grid .producto-meta{
  display: flex; gap: 8px; flex-wrap: wrap; font-size: 12px;
  min-height: 28px; /* 1 línea de badges */
}

/* Botón pegado abajo siempre */
.page-catalogo .catalog-grid .producto-actions{
  margin-top: 0;
}
.page-catalogo .catalog-grid .producto-actions .btn-primary{
  width: 100%;
}

/* Pequeños refinamientos visuales */
.page-catalogo .catalog-grid .badge{
  display: inline-block; padding: 4px 8px; border-radius: 999px;
  background: var(--gray-light); color: var(--gray-dark);
}
.page-catalogo .catalog-grid .badge-condition{ background: #eef8ff; color: var(--blue); }
.page-catalogo .catalog-grid .badge-category{ background: #fff4ec; color: var(--orange); }

/* === Alineación interna de tarjetas de catálogo === */
.page-catalogo .catalog-grid .producto-card{
  display: flex;
  flex-direction: column;
}

.page-catalogo .catalog-grid .producto-media{
  aspect-ratio: 4/3;
  background: #fafafa;
  flex-shrink: 0;
}
.page-catalogo .catalog-grid .producto-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Zona info con layout consistente */
.page-catalogo .catalog-grid .producto-info{
  display: flex;
  flex-direction: column;
  gap: 8px;                  /* ritmo vertical parejo */
  padding: 10px 12px 12px;
  flex: 1;                   /* ocupa todo el alto restante */
}

/* Título: exactamente 2 líneas reservadas, sin márgenes raros */
.page-catalogo .catalog-grid .producto-title{
  margin: 0;
  font-size: 16px;
  line-height: 1.25;
  color: var(--gray-dark);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(1.25em * 2);  /* reserva de 2 líneas */
}

/* Precio: sin margen extra y altura estable */
.page-catalogo .catalog-grid .producto-price{
  margin: 0;
  line-height: 1.2;
  font-weight: 700;
  color: var(--blue);
}

/* Badges: altura mínima para 1–2 líneas y wraps controlados */
.page-catalogo .catalog-grid .producto-meta{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  min-height: 32px;             /* ≈ 1 línea de badges */
}
@media (min-width: 768px){
  .page-catalogo .catalog-grid .producto-meta{ min-height: 40px; } /* da margen si hay 2 badges */
}
.page-catalogo .catalog-grid .badge{
  margin: 0;                    /* sin márgenes externos impredecibles */
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--gray-light);
  color: var(--gray-dark);
}
.page-catalogo .catalog-grid .badge-condition{ background:#eef8ff;color:var(--blue); }
.page-catalogo .catalog-grid .badge-category{ background:#fff4ec;color:var(--orange); }

/* Botón siempre abajo */
.page-catalogo .catalog-grid .producto-actions{
  margin-top: auto;             /* empuja el botón al fondo */
}
.page-catalogo .catalog-grid .producto-actions .btn-primary{
  width: 100%;
}
/* === Alineación exacta de piezas internas en tarjetas === */
.page-catalogo .catalog-grid .producto-card{ display:flex; flex-direction:column; }

/* la imagen se mantiene fija 4:3 */
.page-catalogo .catalog-grid .producto-media{ aspect-ratio:4/3; background:#fafafa; flex-shrink:0; }
.page-catalogo .catalog-grid .producto-media img{ width:100%; height:100%; object-fit:cover; display:block; }

/* layout interno con filas fijas: título (2 líneas), precio, badges, spacer, botón */
.page-catalogo .catalog-grid .producto-info{
  display:grid;
  grid-template-rows: 2.6em /* título */  1.2em /* precio */  40px /* badges */  1fr /* spacer */  auto /* botón */;
  gap:8px;
  padding:10px 12px 12px;
  flex:1;
}

/* título: 2 líneas exactamente */
.page-catalogo .catalog-grid .producto-title{
  margin:0; font-size:16px; line-height:1.3; color:var(--gray-dark);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* precio: una línea */
.page-catalogo .catalog-grid .producto-price{ margin:0; line-height:1.2; font-weight:700; color:var(--blue); }

/* badges: 40px asegura 1–2 líneas sin mover el resto */
.page-catalogo .catalog-grid .producto-meta{
  display:flex; flex-wrap:wrap; gap:8px; font-size:12px; align-content:flex-start; overflow:hidden;
}
.page-catalogo .catalog-grid .badge{ padding:4px 8px; border-radius:999px; background:var(--gray-light); color:var(--gray-dark); margin:0; }
.page-catalogo .catalog-grid .badge-condition{ background:#eef8ff; color:var(--blue); }
.page-catalogo .catalog-grid .badge-category{ background:#fff4ec; color:var(--orange); }

/* botón pegado abajo en todas */
.page-catalogo .catalog-grid .producto-actions{ align-self:end; }
.page-catalogo .catalog-grid .producto-actions .btn-primary{ width:100%; }
/* Badges: una sola línea + elipsis para categoría larga */
.page-catalogo .catalog-grid .producto-meta{
  display: flex;
  flex-wrap: nowrap;     /* para que la categoría no salte abajo */
  gap: 8px;
  align-items: center;
  min-height: 28px;      /* altura estable para que todo alinee */
}

.page-catalogo .catalog-grid .badge{
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--gray-light);
  color: var(--gray-dark);
  line-height: 1.2;
  white-space: nowrap;   /* que el badge no haga múltiples líneas */
}

.page-catalogo .catalog-grid .badge-condition{
  background: #eef8ff; color: var(--blue);
  flex: 0 0 auto;       /* tamaño natural */
}

.page-catalogo .catalog-grid .badge-category{
  background: #fff4ec; color: var(--orange);
  flex: 1 1 auto;             /* que ocupe el espacio restante */
  min-width: 0;               /* permite elipsis en contenedores flex */
  overflow: hidden;
  text-overflow: ellipsis;    /* “…” cuando no entra */
}
/* Mantener 4:3 siempre (ya lo tenías, lo reforzamos) */
.page-catalogo .catalog-grid .producto-media {
  aspect-ratio: 4 / 3;
  background: #fafafa;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}

/* Esqueleto (shimmer) mientras carga */
.page-catalogo .catalog-grid .producto-media.skeleton::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, #f2f2f2 0%, #eaeaea 40%, #f2f2f2 80%);
  background-size: 200% 100%;
  animation: shimmer 1.2s infinite linear;
}
@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* La img no causa salto y hace fade-in */
.page-catalogo .catalog-grid .producto-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;

  opacity: 0;
  transition: opacity .25s ease;
}
.page-catalogo .catalog-grid .producto-media img.is-loaded {
  opacity: 1;
}

/* =========================================================
   Te Conviene – Página: ¿Qué es Te Conviene?
   Scope: .qe-page (agregar class="qe-page" al <main> o a un wrapper)
   Depende de variables globales: --blue, --orange, etc.
========================================================= */

.qe-page {
  /* Espaciado base de la página */
  --section-gap: clamp(28px, 5vw, 56px);
  --container-max: 1100px;
}

.qe-page .container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 16px;
}

/* ============ HERO SECUNDARIO ============ */
.qe-page .hero--secondary {
  background: linear-gradient(0deg, rgba(32,62,150,0.04), rgba(32,62,150,0.04));
  padding: clamp(36px, 6vw, 80px) 0;
  border-top: 3px solid var(--orange);
}

.qe-page .hero--secondary .hero-content h1 {
  color: var(--blue);
  margin-bottom: 12px;
  text-wrap: balance;
}

.qe-page .hero--secondary .hero-content p {
  max-width: 760px;
  color: var(--gray-dark);
  margin: 6px 0 18px;
}

.qe-page .btn-primary,
.qe-page .btn-outline {
  display: inline-block;
  padding: 10px 18px;
  border-radius: 8px;
  font-weight: 700;
  text-decoration: none;
  line-height: 1;
  transition: transform .05s ease, box-shadow .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease;
}

.qe-page .btn-primary {
  background: var(--orange);
  color: #fff;
  box-shadow: 0 2px 0 rgba(0,0,0,.1);
}
.qe-page .btn-primary:hover { transform: translateY(-1px); }

.qe-page .btn-outline {
  border: 2px solid var(--orange);
  color: var(--orange);
  background: transparent;
}
.qe-page .btn-outline:hover {
  background: var(--orange);
  color: #fff;
}

/* ============ SECCIONES BASE ============ */
.qe-page .section {
  padding: var(--section-gap) 0;
}
.qe-page .section--alt {
  background: #fafbff;
  border-top: 1px solid rgba(32,62,150,.08);
  border-bottom: 1px solid rgba(32,62,150,.08);
}
.qe-page .cta-center {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

/* ============ GRIDS LOCALES ============ */
.qe-page .grid {
  display: grid;
  gap: 16px;
}

.qe-page .grid--2cols {
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .qe-page .grid--2cols { grid-template-columns: 1.1fr .9fr; }
}

.qe-page .grid--3cols {
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .qe-page .grid--3cols { grid-template-columns: repeat(3, 1fr); }
}

/* ============ LISTA CON CHECK ============ */
.qe-page .list-check {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
}
.qe-page .list-check li {
  position: relative;
  padding-left: 28px;
  margin: 8px 0;
}
.qe-page .list-check li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--orange);
  font-weight: 800;
}

/* ============ BENEFICIOS (REUTILIZA .benefits) ============ */
.qe-page .benefits {
  padding: var(--section-gap) 0;
}
.qe-page .benefits h2 {
  text-align: center;
  color: var(--blue);
  margin-bottom: 12px;
}
.qe-page .benefits .grid {
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .qe-page .benefits .grid { grid-template-columns: repeat(3, 1fr); }
}
.qe-page .benefits .card {
  border: 1px solid rgba(32,62,150,.08);
  border-top: 3px solid var(--orange); /* línea naranja distintiva */
  border-radius: 10px;
  padding: 16px;
  background: #fff;
}
.qe-page .benefits .card h3 {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--blue);
  margin-bottom: 6px;
}
.qe-page .benefits .card.wide {
  grid-column: 1;
}
@media (min-width: 900px) {
  .qe-page .benefits .card.wide { grid-column: span 3; }
}
.qe-page .benefits .card.destacada {
  background: linear-gradient(0deg, rgba(243,111,33,.06), rgba(243,111,33,.06));
  border-color: rgba(243,111,33,.25);
}

/* ============ CÓMO COMPRAR (REUTILIZA .como-comprar) ============ */
.qe-page .como-comprar {
  padding: var(--section-gap) 0;
}
.qe-page .como-comprar h2 {
  text-align: center;
  color: var(--blue);
  margin-bottom: 6px;
}
.qe-page .como-comprar .intro {
  text-align: center;
  max-width: 800px;
  margin: 0 auto 16px;
  color: var(--gray-dark);
}
.qe-page .como-comprar .steps {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
}
@media (min-width: 780px) {
  .qe-page .como-comprar .steps { grid-template-columns: repeat(4, 1fr); }
}
.qe-page .como-comprar .step {
  border: 1px solid rgba(32,62,150,.08);
  border-top: 3px solid var(--orange);
  border-radius: 10px;
  padding: 14px;
  background: #fff;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.qe-page .como-comprar .step-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.qe-page .como-comprar .numero {
  width: 28px; height: 28px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: var(--blue);
  color: #fff;
  font-weight: 800;
  font-size: 14px;
}

/* ============ TIMELINE (MODELO DE NEGOCIO) ============ */
.qe-page .timeline {
  position: relative;
  margin-top: 12px;
  display: grid;
  gap: 18px;
}
.qe-page .timeline::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: rgba(32,62,150,.15);
}
.qe-page .timeline-item {
  position: relative;
  padding-left: 40px;
}
.qe-page .timeline-dot {
  position: absolute;
  left: 8px; top: 4px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(243,111,33,.15);
}
.qe-page .timeline-content h3 {
  margin-bottom: 4px;
  color: var(--blue);
}

/* ============ PLUS: Ganás vos, ganamos todos ============ */
.qe-page .plus h2 {
  text-align: center;
  color: var(--blue);
  margin-bottom: 8px;
}
.qe-page .plus p {
  max-width: 860px;
  margin: 0 auto 16px;
  text-align: center;
  color: var(--gray-dark);
}
.qe-page .mini-card {
  background: #fff;
  border: 1px solid rgba(32,62,150,.08);
  border-top: 3px solid var(--orange);
  border-radius: 10px;
  padding: 14px;
}
.qe-page .mini-card h3 {
  color: var(--blue);
  margin-bottom: 4px;
}

/* ============ CTA FINAL ============ */
.qe-page .cta-final {
  text-align: center;
  background: linear-gradient(180deg, rgba(32,62,150,.04), rgba(32,62,150,0));
  border-top: 1px solid rgba(32,62,150,.08);
}
.qe-page .cta-final h2 {
  color: var(--blue);
  margin-bottom: 12px;
}

/* ============ UTILIDADES LOCALES ============ */
.qe-page .te-conviene .te { color: var(--blue); font-weight: 800; }
.qe-page .te-conviene .conviene { color: var(--orange); font-weight: 800; }


/* ==========================================
   HERO (¿Qué es Te Conviene?) – Encapsulado
   Scope: .qe-page .qe-hero
========================================== */
.qe-page .qe-hero {
  --hero-pad-y: clamp(48px, 8vw, 108px);
  --hero-gap: clamp(18px, 3vw, 28px);
  position: relative;
  isolation: isolate;
  padding: var(--hero-pad-y) 0;
  background:
    linear-gradient(180deg, rgba(32,62,150,0.05) 0%, rgba(32,62,150,0.03) 60%, transparent 100%);
  overflow: clip;
}

/* Onda naranja sutil abajo */
.qe-page .qe-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: clamp(48px, 8vw, 80px);
  background:
    radial-gradient(120% 100% at 50% 0%, rgba(243,111,33,0.18) 0%, rgba(243,111,33,0.00) 65%);
  pointer-events: none;
  z-index: -1;
}

.qe-page .qe-hero .qe-hero__wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--hero-gap);
  align-items: center;
}

@media (min-width: 960px) {
  .qe-page .qe-hero .qe-hero__wrap {
    grid-template-columns: 1.05fr .95fr; /* leve ventaja al texto */
  }
}

/* Texto */
.qe-page .qe-hero__copy h1 {
  color: var(--blue);
  font-size: clamp(28px, 4.2vw, 46px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 10px;
  text-wrap: balance;
}
.qe-page .qe-hero__copy .hl { color: var(--orange); font-weight: 800; }

.qe-page .qe-hero__sub {
  max-width: 60ch;
  color: var(--gray-dark);
  font-size: clamp(16px, 1.6vw, 18px);
  margin: 8px 0 16px;
}

.qe-page .qe-hero__cta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* Botones, reutilizando estilos globales pero con tweaks locales */
.qe-page .qe-hero .btn-primary {
  display: inline-block;
  padding: 12px 20px;
  border-radius: 10px;
  font-weight: 800;
  background: var(--orange);
  color: #fff;
  text-decoration: none;
  box-shadow: 0 3px 0 rgba(0,0,0,.12);
  transition: transform .06s ease, box-shadow .2s ease, background-color .2s ease;
}
.qe-page .qe-hero .btn-primary:hover { transform: translateY(-1px); }

.qe-page .qe-hero .btn-link {
  display: inline-block;
  font-weight: 700;
  text-decoration: none;
  border-bottom: 2px solid rgba(32,62,150,.2);
  color: var(--blue);
}
.qe-page .qe-hero .btn-link:hover { border-color: var(--blue); }

/* Media (imagen/mockup) */
.qe-page .qe-hero__media {
  justify-self: center;
  width: min(520px, 100%);
  aspect-ratio: 4 / 3;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(32,62,150,.08), rgba(32,62,150,.02));
  border: 1px solid rgba(32,62,150,.08);
  box-shadow:
    0 20px 40px rgba(0,0,0,.06),
    0 2px 0 rgba(0,0,0,.03);
  overflow: hidden;
}

.qe-page .qe-hero__media picture,
.qe-page .qe-hero__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Marca dentro del copy */
.qe-page .qe-hero .te-conviene .te { color: var(--blue); font-weight: 800; }
.qe-page .qe-hero .te-conviene .conviene { color: var(--orange); font-weight: 800; }

/* Accesibilidad */
.qe-page .sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

.qe-page .qe-hero__media {
  justify-self: center;
  width: min(380px, 100%);
  aspect-ratio: auto;      /* Permite que el logo use su proporción natural */
  border-radius: 0;        /* Quitar borde redondeado */
  border: none;            /* Quitar borde gris */
  background: transparent; /* Sin fondo */
  box-shadow: none;        /* Sin sombra */
}
.qe-page .qe-hero__media img {
  width: 100%;
  height: auto;
  object-fit: contain;
}
/* =========================================================
   ¿Qué es Te Conviene? – Secciones intermedias
   Scope: .qe-page  (dejar <main class="qe-page">)
   Bloques cubiertos:
   - "Nuestra esencia" + "¿Por qué existimos?"
   - "Lo que nos hace distintos" (benefits + trust-strip + cards)
========================================================= */

/* ---------- Contenedores y spacing ---------- */
.qe-page .section { padding: clamp(28px, 5vw, 56px) 0; }
.qe-page .container { max-width: 1100px; margin: 0 auto; padding: 0 16px; }

/* ---------- Grid utilitario ---------- */
.qe-page .grid { display: grid; gap: 16px; }
.qe-page .grid--2cols { grid-template-columns: 1fr; }
@media (min-width: 900px){
  .qe-page .grid--2cols { grid-template-columns: 1.1fr .9fr; }
}

/* ---------- Tipografía de títulos ---------- */
.qe-page h2 { color: var(--blue); margin: 0 0 12px; text-wrap: balance; }
.qe-page h3 { color: var(--blue); margin: 0 0 8px; }

/* ---------- "Nuestra esencia" ---------- */
.qe-page .list-check { list-style: none; padding: 0; margin: 6px 0 0; }
.qe-page .list-check li {
  position: relative; padding-left: 26px; margin: 8px 0;
}
.qe-page .list-check li::before {
  content: "✔"; position: absolute; left: 0; top: 0;
  color: var(--orange); font-weight: 800;
}

/* =========================================================
   Lo que nos hace distintos (benefits + trust strip)
========================================================= */
.qe-page .benefits { padding: clamp(28px,5vw,52px) 0; }
.qe-page .benefits h2 { text-align: center; margin-bottom: 8px; }

/* Micro-confianza debajo del título */
.qe-page .trust-strip{
  display:flex; flex-wrap:wrap; gap:10px 18px;
  justify-content:center;
  margin: 6px 0 16px;
  font-size: 14px; color: var(--blue);
}
.qe-page .trust-strip span{
  background:#fff;
  border:1px solid rgba(32,62,150,.10);
  border-radius:999px;
  padding:6px 10px;
}

/* Grid de cards */
.qe-page .benefits .grid {
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
}
@media (min-width: 860px) {
  .qe-page .benefits .grid { grid-template-columns: repeat(3,1fr); }
  .qe-page .benefits .card.wide { grid-column: 1 / -1; }
}



/* =========================================================
   ¿Cómo funciona hoy? – Bloque encapsulado
   Scope: .qe-steps
========================================================= */

/* Título + intro */
.qe-steps h2{
  text-align:center;
  margin-bottom:12px;
}
.qe-steps .intro{
  text-align:center;
  max-width: 820px;
  margin: 0 auto 18px;
  color: var(--gray-dark);
}

/* Grid de pasos */
.qe-steps .steps{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 980px){
  .qe-steps .steps{ grid-template-columns: repeat(4,1fr); }
}

/* Card de paso */
.qe-steps .step-card{
  background: #fff;
  border: 1px solid rgba(32,62,150,.10);
  border-top: 4px solid var(--orange);
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  min-height: 160px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.qe-steps .step-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.10);
  border-color: rgba(32,62,150,.18);
}

/* Cabecera de paso: badge + título */
.qe-steps .step-head{
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: center;
}
.qe-steps .step-badge{
  width: 34px; height: 34px;
  display: grid; place-items: center;
  border-radius: 999px;
  border: 2px solid var(--blue);
  color: var(--blue);
  font-weight: 800;
  line-height: 1;
  background: #fff;
}
.qe-steps .step-title{
  margin: 0;
  color: var(--blue);
  line-height: 1.2;
  min-height: 2.4em; /* reserva aprox. 2 líneas para alinear */
}

/* Texto del paso */
.qe-steps .step-text{
  margin: 0;
  color: var(--gray-dark);
  line-height: 1.45;
}

/* CTA row */
.qe-steps .steps-cta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 18px;
}

/* Botón primario (naranja) */
.qe-steps .btn-primary{
  display: inline-block;
  padding: 12px 18px;
  border-radius: 12px;
  background: var(--orange);
  color: #fff;
  text-decoration: none;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
  transition: transform .06s ease, box-shadow .2s ease, background-color .2s ease;
}
.qe-steps .btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
}

/* Link WhatsApp solo en mobile (no competimos con el flotante en desktop) */
.qe-steps .wa-link{
  text-decoration: none;
  font-weight: 700;
  color: var(--blue);
  border: 2px solid rgba(32,62,150,.18);
  padding: 10px 14px;
  border-radius: 10px;
  background: #fff;
}
.qe-steps .only-mobile{ display: inline-block; }
@media (min-width: 980px){
  .qe-steps .only-mobile{ display: none; }
}

/* Utilidad accesible local */
.qe-steps .sr-only{
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}
/* =========================================================
   Nuestros inicios / Respaldo – bloque encapsulado
   Scope: .qe-origins
========================================================= */
.qe-origins { background: #f7f9ff1a; } /* sutil, opcional */
.qe-origins .origins-head{ text-align:left; max-width: 900px; margin: 0 auto 14px; }
.qe-origins h2{ color: var(--blue); margin-bottom: 6px; }
.qe-origins .origins-intro{
  color: var(--gray-dark);
  margin: 0 0 8px;
}

/* Badge “Respaldado por La Plata” */
.qe-origins .brand-badge{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  margin: 6px 0 6px;
}
.qe-origins .badge-dot{
  width:10px; height:10px; border-radius:999px;
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(243,111,33,.15);
}
.qe-origins .badge-text{
  display:inline-block;
  border:1px solid rgba(32,62,150,.18);
  border-radius:999px;
  padding:6px 10px;
  background:#fff;
  color: var(--blue);
  font-weight:700;
}
.qe-origins .badge-link{
  color: var(--blue); text-decoration:none; font-weight:700;
  border-bottom: 2px solid rgba(32,62,150,.25);
}
.qe-origins .badge-link:hover{ border-bottom-color: var(--blue); }

/* Timeline vertical */
.qe-origins .origins-timeline{
  list-style:none; margin: 10px auto 0; padding:0;
  max-width: 920px;
  position: relative;
}
.qe-origins .origins-timeline::before{
  content:""; position:absolute; left:20px; top:0; bottom:0;
  width:2px; background: rgba(32,62,150,.18);
}
.qe-origins .tl-item{
  position: relative; padding-left: 50px; margin: 12px 0 18px;
}
.qe-origins .tl-marker{
  position:absolute; left:12px; top:4px;
  width:16px; height:16px; border-radius:999px;
  background:#fff; border:3px solid var(--orange);
  box-shadow: 0 1px 6px rgba(0,0,0,.08);
}
.qe-origins .tl-title{
  margin:0 0 4px; color: var(--blue);
}
.qe-origins .tl-text{
  margin:0; color: var(--gray-dark); line-height:1.45;
}

/* Responsive */
@media (min-width: 900px){
  .qe-origins .origins-head{ text-align:left; }
}
@media (max-width: 520px){
  .qe-origins .origins-timeline::before{ left:18px; }
  .qe-origins .tl-item{ padding-left: 46px; }
  .qe-origins .tl-marker{ left:10px; }
}
/* ===== Nuestros inicios – mejoras de badge y timeline ===== */

/* Head y badge */
.qe-origins .origins-head{ max-width: 900px; margin: 0 auto 14px; }
.qe-origins .brand-badge{
  display:flex; align-items:center; justify-content:flex-start; gap:10px; flex-wrap:wrap;
  margin: 6px 0 10px;
}
.qe-origins .badge-dot{
  width:12px; height:12px; border-radius:999px;
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(243,111,33,.15);
}
.qe-origins .badge-text{
  display:inline-block;
  border:1.5px solid var(--blue);     /* más presencia en azul TC */
  border-radius:999px;
  padding:6px 12px;
  background:#fff; color: var(--blue); font-weight:700;
}

/* Intro */
.qe-origins .origins-intro{ color: var(--gray-dark); margin: 6px 0 0; }

/* Timeline más marcado y con mejor respiración */
.qe-origins .origins-timeline{
  list-style:none; margin: 14px auto 0; padding:0; max-width: 920px; position: relative;
}
.qe-origins .origins-timeline::before{
  content:""; position:absolute; left:28px; top:0; bottom:0;
  width:3px; background: rgba(32,62,150,.20);   /* línea un poco más gruesa */
}
.qe-origins .tl-item{
  position: relative; padding-left: 72px; margin: 14px 0 22px;
}
.qe-origins .tl-marker{
  position:absolute; left:18px; top:6px;
  width:18px; height:18px; border-radius:999px;
  background:#fff; border:4px solid var(--orange);  /* marcador más visible */
  box-shadow: 0 1px 6px rgba(0,0,0,.08);
}
.qe-origins .tl-title{ margin:0 0 4px; color: var(--blue); font-weight:800; }
.qe-origins .tl-text{ margin:0; color: var(--gray-dark); line-height:1.5; }

/* Responsive fino */
@media (max-width: 520px){
  .qe-origins .origins-timeline::before{ left:24px; }
  .qe-origins .tl-item{ padding-left: 62px; }
  .qe-origins .tl-marker{ left:14px; }
}

/* Título y badge en una fila */
.qe-origins .origins-title-row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;               /* si no entra, baja prolijo */
  margin-bottom:6px;
}
.qe-origins .origins-title-row h2{ margin:0; }

/* Badge compacto para convivir con el h2 */
.qe-origins .brand-badge{ margin:0; }
.qe-origins .badge-text{ padding:4px 10px; font-size:.92rem; }

/* Títulos de cada etapa: bajar tamaño y mantener peso */
.qe-origins .tl-title{
  font-size: 1.06rem;           /* antes heredaba muy grande */
  font-weight: 800;
  line-height: 1.25;
  margin: 0 0 4px;
}

/* Pequeño ajuste de separación del timeline */
.qe-origins .tl-item{ margin: 12px 0 18px; }


/* ===== Nuestros inicios – versión centrada, con más aire ===== */
.qe-origins .origins-head{
  max-width: 960px;
  margin: 0 auto 16px;
  text-align: center;                 /* título + badge + intro centrados */
}
.qe-origins h2{ margin: 0 0 8px; }

.qe-origins .brand-badge{
  display: inline-flex;               /* centrado junto al texto */
  align-items: center;
  gap: 10px;
  margin: 4px 0 8px;
}
.qe-origins .badge-dot{
  width: 12px; height: 12px; border-radius: 999px;
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(243,111,33,.15);
}
.qe-origins .badge-text{
  display:inline-block;
  border: 1.5px solid var(--blue);
  border-radius: 999px;
  padding: 6px 12px;
  color: var(--blue); background:#fff; font-weight: 700;
}

.qe-origins .origins-intro{
  color: var(--gray-dark);
  margin: 6px auto 0;
  max-width: 900px;
}

/* Timeline con más aire */
.qe-origins .origins-timeline{
  list-style: none; padding: 0; margin: 18px auto 0;
  max-width: 960px; position: relative;
}
.qe-origins .origins-timeline::before{
  content:""; position: absolute; left: 28px; top: 0; bottom: 0;
  width: 3px; background: rgba(32,62,150,.20);
}
.qe-origins .tl-item{
  position: relative;
  padding-left: 76px;                 /* más espacio entre marcador y texto */
  margin: 18px 0 26px;                /* MÁS AIRE entre mini secciones */
}
.qe-origins .tl-marker{
  position: absolute; left: 18px; top: 6px;
  width: 18px; height: 18px; border-radius: 999px;
  background: #fff; border: 4px solid var(--orange);
  box-shadow: 0 1px 6px rgba(0,0,0,.08);
}
.qe-origins .tl-title{
  margin: 0 0 6px;
  color: var(--blue);
  font-weight: 800;
  font-size: 1.05rem;                 /* tamaño cómodo */
  line-height: 1.25;
}
.qe-origins .tl-text{
  margin: 0;
  color: var(--gray-dark);
  line-height: 1.5;
}

@media (max-width: 520px){
  .qe-origins .origins-timeline::before{ left: 24px; }
  .qe-origins .tl-item{ padding-left: 64px; }
  .qe-origins .tl-marker{ left: 14px; }
}
.respaldado-por{
  display: inline-flex;           /* se ajusta al contenido */
  align-items: center;
  gap: 12px;
  margin: 12px auto 22px;
  padding: 8px 16px;
  border: 2px solid var(--blue);  /* borde azul institucional */
  border-radius: 10px;
  background: #fff;               /* fondo blanco limpio */
}

.respaldado-por .tag{
  font-weight: 700;
  font-size: 1rem;
  color: var(--blue);
  text-transform: uppercase;
  letter-spacing: .5px;
}

.respaldado-por .logo-lp{
  height: 42px; 
  width: auto;
  transition: transform .2s ease;
}

.respaldado-por a:hover .logo-lp{
  transform: scale(1.05);        /* efecto hover sutil */
}

/* ===== CTA final ===== */
.qe-final-cta{
  background: linear-gradient(180deg, rgba(32,62,150,.05), rgba(32,62,150,.1));
  padding: clamp(36px,5vw,60px) 0;
  text-align:center;
}

.qe-final-cta h2{ margin-bottom:6px; }
.qe-final-cta .cta-sub{ margin-bottom:18px; color:var(--gray-dark); font-size:1.1rem; }

.qe-final-cta .cta-row{
  display:flex; gap:12px; flex-wrap:wrap; justify-content:center;
  margin-bottom:20px;
}
.qe-final-cta .btn-primary{
  display:inline-block; padding:14px 22px;
  border-radius:12px; background:var(--orange); color:#fff; font-weight:800;
  text-decoration:none; font-size:1.05rem;
  transition:transform .06s ease, box-shadow .2s ease;
  box-shadow:0 2px 6px rgba(0,0,0,.08);
}
.qe-final-cta .btn-primary:hover{
  transform:translateY(-1px); box-shadow:0 8px 18px rgba(0,0,0,.12);
}

.qe-final-cta .btn-outline{
  display:inline-block; padding:12px 16px; border-radius:12px; border:2px solid var(--orange);
  color:var(--orange); font-weight:800; text-decoration:none; background:#fff;
  transition:background-color .2s ease, color .2s ease, transform .06s ease;
}
.qe-final-cta .btn-outline:hover{ background:var(--orange); color:#fff; transform:translateY(-1px); }

.qe-final-cta .only-mobile{ display:inline-block; }
@media (min-width:980px){ .qe-final-cta .only-mobile{ display:none; } }

.qe-final-cta .cta-micro{
  list-style:none; padding:0; margin:0;
  display:flex; flex-wrap:wrap; gap:14px; justify-content:center;
  color:var(--gray-dark); font-size:.95rem;
}
.qe-final-cta .cta-micro li{ display:flex; align-items:center; gap:6px; }
/* =========================================================
   MOBILE HARDENING – Te Conviene (<= 980 / 680 / 480 / 360)
   Solo layout/espaciados/tap targets. No toca tipografías base.
========================================================= */

/* ---------- Utilidades globales ---------- */
@media (prefers-reduced-motion: reduce){
  * { animation: none !important; transition: none !important; }
}



/* WhatsApp flotante: evita solapar CTAs al fondo */
@media (max-width: 480px){
  .section:last-of-type { padding-bottom: max(56px, 10vh); } /* respiración final */
}



/* ---------- Bloque: ¿Cómo funciona hoy? (.qe-steps) ---------- */
@media (max-width: 980px){
  .qe-steps .steps{ grid-template-columns: 1fr; }
  .qe-steps .steps-cta{ gap: 10px; }
  .qe-steps .btn-primary,
  .qe-steps .wa-link.only-mobile{ width: 100%; text-align: center; }
}

@media (max-width: 480px){
  .qe-steps .step-card{ padding: 14px; min-height: unset; }
  .qe-steps .step-head{ grid-template-columns: 32px 1fr; gap: 8px; }
  .qe-steps .step-badge{ width: 32px; height: 32px; }
  .qe-steps .step-title{ min-height: unset; }
}

/* ---------- Bloque: Nuestros inicios (.qe-origins) ---------- */
@media (max-width: 680px){
  .qe-origins .origins-head{ padding: 0 2px; }
  .qe-origins .respaldado-por{
    display: inline-flex; flex-wrap: nowrap; gap: 10px; padding: 6px 12px;
  }
  .qe-origins .respaldado-por .logo-lp{ height: 36px; }
  .qe-origins .origins-timeline{ margin-top: 14px; }
  .qe-origins .origins-timeline::before{ left: 22px; width: 3px; }
  .qe-origins .tl-item{ padding-left: 58px; margin: 16px 0 22px; }
  .qe-origins .tl-marker{ left: 10px; top: 6px; width: 16px; height: 16px; border-width: 3px; }
}

@media (max-width: 360px){
  .qe-origins .respaldado-por .tag{ font-size: .9rem; }
  .qe-origins .respaldado-por .logo-lp{ height: 32px; }
}

/* ---------- Bloque: Ganás vos… (.qe-value) ---------- */
@media (max-width: 980px){
  .qe-value .value-cards{ grid-template-columns: 1fr; }
}
@media (max-width: 480px){
  .qe-value .vcard{
    grid-template-columns: 34px 1fr; gap: 8px; padding: 14px;
  }
  .qe-value .v-ico{ width: 34px; height: 34px; }
}

/* ---------- CTA final (.qe-final-cta) ---------- */
@media (max-width: 680px){
  .qe-final-cta .cta-row{ gap: 10px; }
  .qe-final-cta .btn-primary,
  .qe-final-cta .btn-outline.only-mobile{
    width: 100%; text-align: center;
  }
  .qe-final-cta .cta-micro{ gap: 10px; }
}

/* ---------- Navegación fija / hero ajustes de respiro ---------- */
@media (max-width: 480px){
  .qe-page .section{ padding-top: clamp(22px, 5vw, 30px); padding-bottom: clamp(22px, 5vw, 30px); }
  .qe-page .container{ padding-left: 14px; padding-right: 14px; }
}

.btn-outline{
  display:inline-block;
  padding: 12px 20px;
  border: 2px solid var(--orange);
  border-radius: 12px;
  background: #fff;
  color: var(--orange);
  font-weight: 700;
  text-decoration: none;
  transition: background-color .2s ease, color .2s ease, transform .06s ease;
}
.btn-outline:hover{
  background: var(--orange);
  color: #fff;
  transform: translateY(-1px);
}

/* Base común para todos los botones */
.btn{
  display:inline-block;
  padding: 14px 22px;            /* mismo alto */
  border-radius: 12px;
  font-weight: 800;
  font-size: 1.05rem;
  text-decoration: none;
  line-height: 1.2;              /* consistente */
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
  transition: transform .06s ease, box-shadow .2s ease, background-color .2s ease;
}

/* Botón primario (naranja) */
.btn-primary{
  background: var(--orange);
  color: #fff;
}
.btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
  background: var(--orange-light);
}

/* Botón secundario (azul) */
.btn-secondary{
  background: var(--blue);
  color: #fff;
}
.btn-secondary:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
  background: var(--blue-light);
}
/* ===== Hero: mobile only ===== */
@media (max-width: 480px){
  /* Orden: 1) título/texto, 2) CTAs, 3) media */
  .qe-hero__cta { order: 2; }
  .qe-hero__media { order: 3; }

  /* Botones iguales y full-width */
  .qe-hero__cta .btn,
  .qe-hero__cta .btn-primary,
  .qe-hero__cta .btn-secondary{
    width: 100%;
    padding: 14px 22px;
    border-radius: 12px;
    font-weight: 800;
    font-size: 1.05rem;
    line-height: 1.2;
    text-align: center;
  }

  /* Mostrar primero "Ver Catálogo" (azul) y luego "Conocé…" (naranja) 
     Si tu href cambia, poneles clases en el HTML y usá esas clases. */
  .qe-hero__cta a[href*="catalogo"]{ order: 1; }
  .qe-hero__cta a[href*="#como-comprar"]{ order: 2; }

  /* Título un poco más compacto */
  .qe-hero h1{
    font-size: clamp(24px, 6vw, 30px);
    line-height: 1.18;
    margin-bottom: 4px;
  }

  /* Ilustración más chica y centrada */
  .qe-hero__media picture,
  .qe-hero__media img{
    display: block;
    max-width: 60vw;          /* ~60% del ancho del viewport */
    max-height: 280px;
    height: auto;
    margin: 8px auto 0;
  }

  /* Respiro inferior para no chocar con el FAB de WhatsApp */
  .qe-hero.section{
    padding-bottom: max(72px, 10vh);
  }
}

@media (max-width: 360px){
  .qe-hero__cta{ gap: 8px; }
  .qe-hero__media img{ max-width: 64vw; }
}
/* ===== Hero: fix botones mobile ===== */
@media (max-width: 480px){
  /* Pila y espacio más corto entre botones */
  .qe-hero__cta{
    display: flex;
    flex-direction: column;
    gap: 8px;                 /* antes era mayor */
    margin-top: 6px;
  }

  /* Ambos botones: mismo ancho real, sin márgenes laterales */
  .qe-hero__cta a,
  .qe-hero__cta .btn,
  .qe-hero__cta .btn-primary,
  .qe-hero__cta .btn-secondary{
    display: block;
    width: 100%;
    align-self: stretch;      /* ocupa todo el ancho del contenedor */
    box-sizing: border-box;
    margin: 0;                /* elimina márgenes que achican uno de los dos */
    text-align: center;
    padding: 14px 22px;       /* misma altura en ambos */
    border-width: 0;          /* evita diferencias por borde */
  }

  /* Por si alguna clase global les pone un max-width */
  .qe-hero__cta .btn,
  .qe-hero__cta .btn-primary,
  .qe-hero__cta .btn-secondary{
    max-width: none !important;
  }
}

/* ===== Breadcrumb (scoped) ===== */
.qe-breadcrumb{
  background: linear-gradient(180deg, rgba(32,62,150,.03), rgba(32,62,150,.02));
  border-bottom: 1px solid rgba(32,62,150,.08);
  /* si tenés header fijo, el :target ya está gestionado; no tocamos scroll */
}

.qe-breadcrumb .container{
  max-width: 1100px; margin: 0 auto; padding: 10px 16px;
}

.qe-breadcrumb ol{
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center; flex-wrap: nowrap; gap: 8px;
  overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none;
  white-space: nowrap;
}
.qe-breadcrumb ol::-webkit-scrollbar{ display: none; }

.qe-breadcrumb li{
  display: inline-flex; align-items: center; gap: 8px; color: #556;
  font-size: .95rem;
}

/* Separador */
.qe-breadcrumb li + li::before{
  content: "›"; color: rgba(32,62,150,.55);
  display: inline-block;
}

/* Links y estado actual */
.qe-breadcrumb a{
  color: var(--blue); text-decoration: none; font-weight: 600;
}
.qe-breadcrumb a:hover{ text-decoration: underline; }

.qe-breadcrumb .is-current{
  color: var(--gray-dark); font-weight: 700;
}
.qe-breadcrumb .is-current span{
  text-decoration: none;
}

/* Mobile: un poco más compacto */
@media (max-width: 480px){
  .qe-breadcrumb .container{ padding: 8px 14px; }
  .qe-breadcrumb li{ font-size: .92rem; }
}
/* Altura del header fijo (ajustá si tu header mide otra cosa) */
:root { --header-h: 64px; }          /* desktop */
@media (max-width: 980px){
  :root { --header-h: 56px; }        /* mobile, si es un poco más bajo */
}

/* Altura del header fijo (ajustá si hace falta) */
:root { --header-h: 56px; }              /* mobile típico */
@media (min-width: 981px){
  :root { --header-h: 64px; }            /* desktop típico */
}

/* Breadcrumb en flujo normal, con offset más corto */
.qe-breadcrumb{
  position: static;                       /* <- vuelve a flujo normal */
  top: auto;                              /* limpia valores previos */
  margin-top: calc(var(--header-h) - 38px);/* offset reducido; ajustá 8–16px a gusto */
  z-index: 1;                             /* no necesita ser alto */
}

/* Compacto */
.qe-breadcrumb .container{
  padding: 6px 16px;
}
@media (max-width: 480px){
  .qe-breadcrumb .container{ padding: 4px 14px; }
}
/* === Ajuste fino QE: menos aire entre breadcrumb y HERO === */


/* 1) Reducir SOLO el padding superior del hero (no el inferior) */
.qe-page .qe-hero{
  /* top mucho más corto; bottom se mantiene amplio para “respirar” */
  padding-top: clamp(18px, 3vw, 40px);
  padding-bottom: clamp(48px, 8vw, 108px);
}
/* 1) Microajuste mobile: un poquito menos arriba en pantallas chicas */
@media (max-width: 640px){
  .qe-page .qe-hero{ padding-top: clamp(14px, 3.5vw, 28px); }
}

/* 2) Suavizar transición si el header tiene sombra al hacer scroll */
.qe-breadcrumb{ transition: margin-top 160ms ease; }

/* 3) iOS notch safe-area (por si el header es fixed y hay notch) */
@supports (padding: max(0px)){
  body{ padding-top: calc(65px + env(safe-area-inset-top)); }
}
/* === Menos aire entre el HERO y "Nuestra esencia" === */

/* 1) Hero: recortar un poco el padding inferior y la onda */
.qe-page .qe-hero{
  padding-bottom: clamp(24px, 4vw, 48px); /* antes var(--hero-pad-y) simétrico */
}
.qe-page .qe-hero::after{
  height: clamp(24px, 5vw, 48px); /* antes: clamp(48px, 8vw, 80px) */
}

/* 2) Solo la PRIMERA sección después del hero: menos padding arriba (y un poco abajo) */
.qe-page .qe-hero + .section{
  padding-top: clamp(12px, 2.5vw, 24px);
  padding-bottom: clamp(20px, 3vw, 32px);
}

/* 3) Detalles tipográficos de ese bloque para compactar sin “aplastar” */
.qe-page .qe-hero + .section h2{ margin-bottom: 8px; }
.qe-page .qe-hero + .section .list-check{ margin-top: 4px; }



/* (Opcional) Si querés subirlo todavía ~8–12px extra, descomentar: */
/*
.qe-steps.section{ margin-top: -10px; } 
*/

/* 2) Título más cercano al borde superior y más separado de las píldoras de arriba */
.qe-steps h2{
  margin-top: -6px;    /* sube solo el texto del h2 */
  margin-bottom: 10px; /* compacta espacio con la intro */
  line-height: 1.15;
}

/* 3) Intro un poco más compacta */
.qe-steps .intro{
  margin: 0 auto 14px; /* antes 18px */
}

/* 4) En mobile, aún un pelín más compacto */
@media (max-width: 768px){
  .qe-steps.section{ padding-top: 12px; }     /* o 8px si querés más arriba */
  .qe-steps h2{ margin-top: -4px; margin-bottom: 8px; }
  .qe-steps .intro{ margin: 0 auto 12px; }
}

/* Divisor suave al pie de una sección */
.section--divider-bottom{
  position: relative;
}
.section--divider-bottom::after{
  content:"";
  position: absolute;
  left: 0; right: 0; bottom: -10px;
  height: 28px;
  pointer-events: none;
  /* banda suave con tono naranja de marca */
  background: radial-gradient(120% 18px at 50% 0,
              rgba(243,111,33,.18) 0%,
              rgba(243,111,33,.08) 35%,
              rgba(243,111,33,0) 70%);
}
/* Sube el bloque siguiente sin afectar el resto */
.section--pull-up{
  margin-top: -16px;                 /* súbelo (ajustá -10 a -24 según gusto) */
  padding-top: clamp(8px, 1.2vw, 16px); /* mantiene un poco de respiro interno */
}

/* Compactar el cierre del bloque anterior para que se acerquen más */
.qe-origins.section{
  padding-bottom: clamp(12px, 1.8vw, 20px);
}

/* Subir el bloque "Ganás vos, ganamos todos" */
.section.plus{
  margin-top: 10px;                 /* ajustá: -12 a -24 según gusto */
  padding-top: 32px;                 /* mantiene un poco de respiro interno */
}

/* Compactar título e intro de este bloque */
.section.plus h2{
  margin-top: -4px;                  /* sube solo el texto del h2 */
  margin-bottom: 12px;               /* separa del párrafo */
  line-height: 1.18;
}
.section.plus .value-intro{
  margin: 0 0 14px;                  /* menos aire debajo del párrafo */
}

/* Un pelín menos de separación antes de las mini-cards */
.section.plus .grid{
  margin-top: 12px;
  row-gap: 12px;
}

@media (max-width: 768px){
  .section.plus{ margin-top: -12px; padding-top: 10px; }
  .section.plus h2{ margin-top: -2px; margin-bottom: 10px; }
  .section.plus .value-intro{ margin-bottom: 12px; }
}
/* ===============================================
   Parche aislado: Página ¿Cómo comprar?
   Scope: body[data-page="como-comprar"] ...
   No toca otras vistas. Carga después de style.css
================================================= */

body[data-page="como-comprar"] {
  /* Si tu header es fijo, esto evita solapes del breadcrumb */
  padding-top: var(--header-h, 65px);
}

/* ---------- Breadcrumb ---------- */
body[data-page="como-comprar"] .qe-breadcrumb {
  background: var(--gray-150, #f7f8fc);
  border-bottom: 1px solid var(--gray-300, #eceff6);
}
body[data-page="como-comprar"] .qe-breadcrumb .container { padding: 8px 0; }
body[data-page="como-comprar"] .qe-breadcrumb ol {
  list-style: none; display: flex; gap: 8px; align-items: center;
  font-size: 14px; color: var(--gray-700, #6b7280);
}
body[data-page="como-comprar"] .qe-breadcrumb a {
  color: var(--blue, #203E96); font-weight: 700; text-decoration: none;
}
body[data-page="como-comprar"] .qe-breadcrumb li + li::before {
  content: "›"; color: var(--gray-500, #9aa3b2); margin-right: 8px;
}

/* ---------- H1 + Intro ---------- */
body[data-page="como-comprar"] #cc-title {
  color: var(--blue, #203E96);
  margin-bottom: 6px;
  line-height: 1.2;
}
body[data-page="como-comprar"] .section .intro {
  max-width: 800px; color: #333; opacity: .95;
}

/* ---------- Pasos (qe-steps) ---------- */
body[data-page="como-comprar"] .qe-steps h2 {
  text-align: center; color: var(--blue, #203E96); margin-bottom: 12px;
}
body[data-page="como-comprar"] .qe-steps .intro {
  text-align: center; max-width: 820px; margin: 0 auto 18px;
}

body[data-page="como-comprar"] .qe-steps .steps {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: 16px; grid-template-columns: 1fr;
}
@media (min-width: 980px) {
  body[data-page="como-comprar"] .qe-steps .steps {
    grid-template-columns: repeat(4, 1fr);
  }
}

body[data-page="como-comprar"] .qe-steps .step-card {
  background: #fff;
  border: 1px solid rgba(32,62,150,.1);
  border-top: 4px solid var(--orange, #F36F21);
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
  min-height: 160px;
  display: flex; flex-direction: column; gap: 8px;
}
body[data-page="como-comprar"] .qe-steps .step-head {
  display: grid; grid-template-columns: 34px 1fr; gap: 10px; align-items: center;
}
body[data-page="como-comprar"] .qe-steps .step-badge {
  width: 34px; height: 34px; display: grid; place-items: center;
  border-radius: 999px; border: 2px solid var(--blue, #203E96);
  color: var(--blue, #203E96); font-weight: 800; background: #fff; line-height: 1;
}
body[data-page="como-comprar"] .qe-steps .step-title {
  margin: 0; color: var(--blue, #203E96); line-height: 1.2; min-height: 2.4em;
}
body[data-page="como-comprar"] .qe-steps .step-text { margin: 0; color: #333; }

/* CTA de pasos */
body[data-page="como-comprar"] .qe-steps .steps-cta {
  display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 18px;
}
@media (max-width: 768px) {
  body[data-page="como-comprar"] .qe-steps .btn,
  body[data-page="como-comprar"] .qe-steps .wa-link { width: 100%; max-width: 320px; }
}

/* ---------- Pago y envíos (3 cards) ---------- */
body[data-page="como-comprar"] .benefits h2 {
  color: var(--blue, #203E96); margin-bottom: 12px; text-align: center;
}
body[data-page="como-comprar"] .benefits .grid {
  display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
body[data-page="como-comprar"] .benefits .card {
  background: #fff; border: 1px solid rgba(32,62,150,.1);
  border-radius: 12px; padding: 16px; box-shadow: 0 2px 6px rgba(0,0,0,.08);
  border-top: 4px solid var(--orange, #F36F21);
  text-align: left;
}
body[data-page="como-comprar"] .benefits .card h3 {
  color: var(--blue, #203E96); font-size: 1.1rem; margin-bottom: 6px;
}



/* ---------- FAQ ---------- */
body[data-page="como-comprar"] .faq h2 {
  text-align: center; color: var(--blue, #203E96); margin-bottom: 12px;
}
body[data-page="como-comprar"] .faq-list {
  max-width: 900px; margin: 0 auto; display: grid; gap: 10px;
}
body[data-page="como-comprar"] .faq-list details {
  border: 1px solid rgba(32,62,150,.1);
  border-radius: 10px; padding: 10px 14px; background: #fff;
}
body[data-page="como-comprar"] .faq-list summary {
  cursor: pointer; font-weight: 700; color: var(--blue, #203E96); list-style: none;
}
body[data-page="como-comprar"] .faq-list summary::-webkit-details-marker { display: none; }
body[data-page="como-comprar"] .faq-list details[open] { border-color: rgba(32,62,150,.18); }
body[data-page="como-comprar"] .faq-list details > div { margin-top: 8px; color: #333; }

/* ---------- CTA final ---------- */
body[data-page="como-comprar"] .cta-final {
  text-align: center;
  background: linear-gradient(180deg, rgba(32,62,150,.04), rgba(32,62,150,0));
  border-top: 1px solid rgba(32,62,150,.08);
}
body[data-page="como-comprar"] .cta-final h2 { color: var(--blue, #203E96); margin-bottom: 8px; }
body[data-page="como-comprar"] .cta-final .cta-sub { color: #333; opacity: .9; margin-bottom: 10px; }
body[data-page="como-comprar"] .cta-final .cta-row {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}

/* ---------- Utilidades ---------- */
@media (min-width: 769px){ body[data-page="como-comprar"] .only-mobile { display: none !important; } }

/* Hero nuevo diseño */
.hero-title {
  font-size: 1.4rem; /* un poco más pequeño que antes */
  font-weight: 500;
  text-align: center;
  margin-bottom: 1rem;
  line-height: 1.3;
}

.hero-logo-big {
  max-width: 220px;   /* más grande que el actual */
  margin: 0 auto 1.5rem auto;
  display: block;
}

@media (min-width: 768px) {
  .hero-title {
    font-size: 1.8rem;
  }
  .hero-logo-big {
    max-width: 280px;
  }
}
/* No desplaces el body: el header es sticky */
@supports (padding: max(0px)){
  body{ padding-top: 0 !important; }
}

/* Si necesitás offset, aplicalo al contenido, no al body */
body[data-page="como-comprar"] { padding-top: 0 !important; }
.qe-page main,
body[data-page="como-comprar"] main { padding-top: var(--header-h, 64px); }

/* (Opcional) Ajuste del breadcrumb para que no abra hueco extra */
.qe-breadcrumb{ margin-top: 0; }




/* ============================================================================
   A PARTIR DE ACA PARA ABAJO ESTA LIMPIO Y VALIDADO
============================================================================= */
/* ==========================
   VARIABLES GLOBALES
========================== */
:root{
  --blue:#203E96;
  --blue-light:#4C6CD6;
  --orange:#F36F21;
  --orange-light:#FF914D;
  --white:#FFFFFF;
  --gray-light:#F4F4F4;
  --gray-dark:#333333;

  --font-main:'Arial',sans-serif;
}

/* ==========================
   RESET BÁSICO
========================== */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font-main);color:var(--gray-dark);background:var(--white);line-height:1.5}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.container{width:90%;max-width:1200px;margin:0 auto}

/* ==========================
   BREADCRUMB
========================== */
.breadcrumb{font-size:14px;margin:16px 0 24px;color:var(--gray-dark)}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0}
.breadcrumb li{display:flex;align-items:center}
.breadcrumb li+li::before{content:"›";margin:0 6px;color:var(--orange)}
.breadcrumb a{color:var(--blue);font-weight:500;transition:color .2s}
.breadcrumb a:hover{color:var(--orange-light)}

/* Marca Te Conviene */
.te-conviene{display:inline-flex;align-items:baseline;gap:4px;white-space:nowrap;font-weight:750}
.te-conviene .te{color:var(--orange)}
.te-conviene .conviene{color:var(--blue)}

/* ==========================
   BOTONES (GLOBALES)
========================== */
.btn{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;border-radius:8px;padding:12px 28px;font-weight:700;font-size:16px;border:2px solid transparent;transition:background .2s,border-color .2s,box-shadow .2s}
.btn-primary{background:var(--orange);border-color:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-light);border-color:var(--orange-light)}
.btn-secondary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn-secondary:hover{background:var(--blue-light);border-color:var(--blue-light)}
.btn--lg{min-width:260px;padding:14px 30px;border-radius:12px;font-weight:800;font-size:17px;box-shadow:0 8px 20px rgba(0,0,0,.08)}
.btn--lg:hover{box-shadow:0 12px 26px rgba(0,0,0,.12)}
@media (max-width:768px){.btn--lg{width:100%;max-width:340px}}

/* ==========================
   HEADER
========================== */
.site-header{background:var(--blue);padding:10px 0;position:sticky;top:0;z-index:1000}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px}
.site-header .logo img{max-height:42px}
.site-header .cta .btn{padding:9px 20px;border-radius:6px;font-weight:700;font-size:16px;white-space:nowrap}
/* === Fix CTA del header (tamaño y centrado) === */
.site-header .cta .btn-primary{
  display: inline-flex;           /* asegura alto correcto */
  align-items: center;
  justify-content: center;
  padding: 9px 20px;              /* tamaño compacto del header */
  border-radius: 6px;
  line-height: 1.1;               /* evita recorte vertical */
  height: auto;
  background: var(--orange);
  border: 2px solid var(--orange);
  color: #fff;
  font-weight: 700;
  font-size: 16px;
}

/* hover consistente */
.site-header .cta .btn-primary:hover{
  background: var(--orange-light);
  border-color: var(--orange-light);
}

.site-header .nav ul{list-style:none;display:flex;gap:28px}
.site-header .nav ul li a{color:#fff;font-weight:550;font-size:18px;transition:color .3s}
.site-header .nav ul li a:hover{color:var(--orange-light)}
.site-header .menu-toggle{display:none;background:none;border:none;font-size:28px;color:#fff;cursor:pointer}
@media (max-width:768px){
  .site-header .container{justify-content:flex-start}
  .site-header .logo{order:0;margin-right:auto}
  .site-header .cta{order:1;margin-right:8px}
  .site-header .menu-toggle{order:2;display:block}
  .site-header .nav{display:none;position:absolute;top:100%;right:0;left:0;background:var(--blue);padding:20px;text-align:center}
  .site-header .nav ul{flex-direction:column;gap:16px}
  .site-header .nav.active{display:block;animation:fadeIn .3s}
  body.no-scroll{overflow:hidden}
}
@keyframes fadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ==========================
   FOOTER + WhatsApp FAB
========================== */
.site-footer{background:var(--blue);color:#fff;padding:28px 20px}
.site-footer a{color:#fff;opacity:.95}
.site-footer a:hover{opacity:1;text-decoration:underline}
.site-footer .container{display:flex;gap:24px;justify-content:space-between;flex-wrap:wrap}
.site-footer small{opacity:.8}

.floating-wa{position:fixed;right:clamp(12px,3vw,20px);bottom:max(14px,env(safe-area-inset-bottom));z-index:1200;display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;border:0;border-radius:999px;padding:12px 16px;font-weight:700;box-shadow:0 10px 24px rgba(0,0,0,.18);transition:transform .15s,box-shadow .15s,background .15s}
.floating-wa:hover{background:#1ebe57;transform:translateY(-2px);box-shadow:0 14px 28px rgba(0,0,0,.22)}
.floating-wa:active{transform:translateY(0)}
.floating-wa:focus-visible{outline:3px solid #fff;outline-offset:2px;box-shadow:0 0 0 4px rgba(37,211,102,.45)}
@media (max-width:480px){.floating-wa{width:56px;height:56px;padding:0;justify-content:center;border-radius:50%}.floating-wa span{display:none}}
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.45)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.floating-wa{animation:wa-pulse 2.8s ease-out infinite}
@media (prefers-reduced-motion:reduce){.floating-wa{animation:none}}

/* ==========================
   HOME – HERO
========================== */
.hero{background:var(--white);padding:48px 20px}
.hero .hero-content{text-align:center}
.hero .hero-title{font-size:1.8rem;font-weight:700;line-height:1.3;color:var(--blue);margin-bottom:16px}
.hero p{font-size:1.1rem;color:var(--gray-dark);margin-bottom:20px}
.hero .btn-primary{display:inline-flex;align-items:center;justify-content:center;background:var(--orange);border:2px solid var(--orange);color:#fff;padding:12px 28px;border-radius:8px;font-weight:600;font-size:16px;transition:all .3s;min-width:220px}
.hero .btn-primary:hover{background:var(--orange-light);border-color:var(--orange-light)}
.hero .highlight{color:var(--blue);font-weight:700}
.hero-title-desktop{display:block}
.hero-title-mobile{display:none}
.hero-logo-desktop{display:block}
.hero-logo-mobile{display:none}
.hero .hero-cta-desktop.btn-primary{display:inline-flex}
.hero .hero-cta-mobile.btn-primary{display:none}

@media (min-width:992px){
  .hero .hero-content{display:flex;align-items:center;justify-content:space-between;gap:60px;text-align:left}
  .hero .hero-text{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}
  .hero .hero-title{font-size:2.8rem;margin-bottom:20px}
  .hero p{font-size:1.5rem;margin-bottom:2px}
  .hero .hero-cta-desktop.btn-primary{min-width:240px;align-self:center;margin-top:40px}
  .hero .hero-image{flex:1;display:flex;justify-content:center}
  .hero .hero-logo-big{max-width:600px;margin:0}
}

@media (max-width:768px){
  .hero .hero-content{display:flex;flex-direction:column;align-items:center;text-align:center}
  .hero-title-desktop,.hero-title-mobile{display:none!important}
  .hero-logo-desktop{display:none}
  .hero-logo-mobile{display:block;width:min(90vw,340px);max-width:100%;margin:0 auto 20px;order:1}
  .hero .hero-text{order:2;width:100%;display:flex;flex-direction:column;align-items:center}
  .hero .hero-text p{order:1;font-size:1.2rem;line-height:1.5;margin:0 0 18px}
  .hero .hero-text .btn-primary{order:2;display:inline-flex;width:100%;max-width:320px;margin:0 auto;padding:12px 24px;margin-top:0!important}
  .hero{padding-top:clamp(28px,7vw,40px)}
  .hero .hero-text p{letter-spacing:.1px;margin-bottom:20px}
  .hero .hero-text .btn-primary{min-height:44px;line-height:1.1}
  @supports(padding:max(0px)){.hero{padding-bottom:max(32px,env(safe-area-inset-bottom))}}
}

/* ==========================
   CATEGORÍAS (Swiper)
========================== */
.categories{background:var(--gray-light);padding:48px 20px}
.categories .container{text-align:center}
.categories h2{color:var(--blue);font-size:2rem;line-height:1.2;margin-bottom:22px}

.categories .categories-swiper{position:relative;padding-bottom:40px;max-width:1100px;margin:0 auto;overflow:visible} /* ← clave */
.categories .swiper-slide.category-card{background:#fff;border-radius:12px;border-top:4px solid var(--orange);padding:18px 16px;text-align:center;display:flex;flex-direction:column;justify-content:flex-start;gap:10px;min-height:260px;transition:transform .18s,box-shadow .18s,border-color .18s}
.categories .swiper-slide.category-card:hover{transform:translateY(-4px);box-shadow:0 8px 18px rgba(0,0,0,.10);border-top-color:var(--orange-light)}
.categories .category-card picture{display:block}
.categories .category-card img{height:100px;width:auto;object-fit:contain;margin:0 auto 8px;display:block}
.categories .category-card h3{color:var(--blue);font-size:1.1rem;line-height:1.25;margin:0;min-height:2.5em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.categories .category-card p{color:var(--gray-dark);font-size:.95rem;line-height:1.4;margin:0;flex:1}

/* Flechas — centradas y fuera sin empujar tarjetas */
.categories .swiper-button-next,
.categories .swiper-button-prev{position:absolute;top:50%!important;transform:translateY(-50%)!important;margin-top:0!important;width:48px;height:48px;border-radius:999px;background:#fff;color:var(--blue);box-shadow:0 6px 20px rgba(0,0,0,.12);z-index:5}
.categories .swiper-button-next::after,
.categories .swiper-button-prev::after{font-size:18px}
@media (min-width:769px){
  .categories .swiper-button-prev{left:-28px}
  .categories .swiper-button-next{right:-28px}
}
@media (min-width:1200px){
  .categories .swiper-button-prev{left:-36px}
  .categories .swiper-button-next{right:-36px}
}
@media (max-width:768px){
  .categories h2{font-size:1.6rem;margin-bottom:16px}
  .categories .swiper-slide.category-card{min-height:240px}
  .categories .swiper-button-prev{left:6px}
  .categories .swiper-button-next{right:6px}
}

.categories .swiper-pagination-bullet{opacity:.5}
.categories .swiper-pagination-bullet-active{background:var(--orange);opacity:1}

/* CTA inferior */
.categories .cta-center{margin-top:8px}
.categories .cta-center .btn-primary{display:inline-block;min-width:220px}

/* CTA estilos forzados (opcional) */
.categories .cta-center{text-align:center;margin-top:18px}
.categories .cta-center .btn-primary{display:inline-flex!important;align-items:center;justify-content:center;background:var(--orange)!important;border:2px solid var(--orange)!important;color:#fff!important;padding:14px 30px!important;border-radius:12px!important;font-weight:800!important;font-size:17px!important;min-width:260px;box-shadow:0 8px 20px rgba(0,0,0,.08);text-decoration:none}
.categories .cta-center .btn-primary:hover{background:var(--orange-light)!important;border-color:var(--orange-light)!important;box-shadow:0 12px 26px rgba(0,0,0,.12)}
.categories .cta-center .btn-primary::after,
.categories .cta-center .btn-primary>svg{content:none!important;display:none!important;background:none!important}
.categories .cta-center .btn-primary.is-blue{background:var(--blue)!important;border-color:var(--blue)!important;color:#fff!important}
.categories .cta-center .btn-primary.is-blue:hover{background:var(--blue-light)!important;border-color:var(--blue-light)!important}

/* ==========================
   CÓMO COMPRAR
========================== */
.como-comprar{background:var(--white);padding:48px 20px}
.como-comprar .container{max-width:1200px;margin:0 auto}
.como-comprar h2{text-align:center;color:var(--blue);font-size:2rem;line-height:1.2;margin:0 0 10px}
.como-comprar .intro{max-width:720px;margin:0 auto 22px;text-align:center;color:var(--gray-dark);font-size:1.1rem;opacity:.95}
.como-comprar .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.como-comprar .step{background:#fff;border-radius:12px;border:1px solid rgba(0,0,0,.06);border-top:4px solid var(--orange);padding:16px 14px;box-shadow:0 2px 6px rgba(0,0,0,.08);transition:transform .2s,box-shadow .2s,border-color .2s;min-height:160px;display:flex;flex-direction:column;gap:8px}
.como-comprar .step:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(0,0,0,.12);border-color:rgba(0,0,0,.12)}
.como-comprar .step-header{display:grid;grid-template-columns:32px 1fr;gap:10px;align-items:center;margin-bottom:2px}
.como-comprar .numero{width:32px;height:32px;border-radius:999px;display:grid;place-items:center;background:var(--orange);color:#fff;font-weight:800;font-size:.95rem;line-height:1}
.como-comprar h3{margin:0;color:var(--blue);font-size:1.1rem;line-height:1.2;min-height:2.2em;display:flex;align-items:center}
.como-comprar .step p{margin:0;color:var(--gray-dark);font-size:.98rem;line-height:1.45}
.como-comprar .step:focus-within{outline:2px solid var(--orange);outline-offset:2px}
.como-comprar .cta-center{text-align:center;margin-top:24px}
@media (max-width:1080px){.como-comprar .steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){
  .como-comprar{padding:40px 16px}
  .como-comprar h2{font-size:1.7rem;margin-bottom:8px}
  .como-comprar .intro{font-size:1rem;margin-bottom:16px}
  .como-comprar .steps{grid-template-columns:1fr;gap:14px}
  .como-comprar .step{padding:14px 12px;min-height:unset}
  .como-comprar .step-header{grid-template-columns:30px 1fr;gap:8px}
  .como-comprar .numero{width:30px;height:30px;font-size:.9rem}
  .como-comprar .cta-center .btn--lg{width:100%;max-width:320px}
}

/* ==========================
   OFERTAS
========================== */
.ofertas{background:var(--gray-light);padding:48px 20px;text-align:center}
.ofertas h2{color:var(--blue);font-size:2rem;line-height:1.2;margin:0 0 10px}
.ofertas .intro{max-width:720px;margin:0 auto 24px;color:var(--gray-dark);font-size:1.1rem;opacity:.95}
.ofertas-carousel{max-width:1100px;margin:0 auto;padding-bottom:36px;position:relative;overflow:visible} /* ← overflow visible */
.ofertas-carousel .swiper-wrapper{display:flex;align-items:stretch}
.ofertas-carousel .swiper-slide{width:280px;height:auto;display:flex}
.producto-card{background:#fff;border:1px solid #eee;border-top:4px solid var(--orange);border-radius:12px;box-shadow:0 2px 6px rgba(0,0,0,.08);padding:14px;display:grid;grid-template-rows:auto auto auto auto;gap:10px;width:100%;transition:transform .2s,box-shadow .2s,border-color .2s}
.producto-card:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(0,0,0,.12);border-color:#e9e9e9}
.producto-card:focus-within{outline:2px solid var(--orange);outline-offset:2px}
.producto-card img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px}
.producto-card h3{margin:0;color:var(--blue);font-size:1rem;line-height:1.25;min-height:2.5em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.producto-card .precio{margin:0;color:var(--orange);font-weight:800;font-size:1.1rem}
.btn-detalle{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:10px 14px;border-radius:8px;border:2px solid var(--orange);background:var(--orange);color:#fff;font-weight:700;cursor:pointer;transition:background .2s,border-color .2s,transform .06s}
.btn-detalle:hover{background:var(--orange-light);border-color:var(--orange-light);transform:translateY(-1px)}

/* Flechas Ofertas */
.ofertas .swiper-button-next,.ofertas .swiper-button-prev{
  position:absolute;top:50%!important;transform:translateY(-50%)!important;margin-top:0!important;
  width:48px;height:48px;border-radius:999px;background:#fff;color:var(--blue);box-shadow:0 6px 20px rgba(0,0,0,.12);z-index:5
}
.ofertas .swiper-button-next::after,.ofertas .swiper-button-prev::after{font-size:18px}
@media (min-width:769px){.ofertas .swiper-button-prev{left:-28px}.ofertas .swiper-button-next{right:-28px}}
@media (min-width:1200px){.ofertas .swiper-button-prev{left:-36px}.ofertas .swiper-button-next{right:-36px}}
@media (max-width:768px){
  .ofertas{padding:40px 16px}
  .ofertas h2{font-size:1.7rem}
  .ofertas .intro{font-size:1rem;margin-bottom:16px}
  .ofertas-carousel .swiper-slide{width:75vw}
  .producto-card{padding:12px}
  .btn-detalle{padding:10px 12px}
  .ofertas .swiper-button-prev{left:6px}
  .ofertas .swiper-button-next{right:6px}
}
.ofertas .swiper-pagination-bullet{opacity:.5}
.ofertas .swiper-pagination-bullet-active{background:var(--orange);opacity:1}
.ofertas .cta-center{margin-top:8px}
.ofertas .cta-center .btn-primary{display:inline-flex;min-width:240px}

/* ==========================
   MODALES (Ofertas)
========================== */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);z-index:2000}
.modal .modal-contenido{position:relative;width:min(720px,92vw);max-height:90vh;overflow:auto;overscroll-behavior:contain;background:#fff;border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.25);padding:18px 18px 22px;animation:modalIn .18s ease-out;outline:none}
.modal .modal-contenido img{width:100%;height:auto;max-height:48vh;object-fit:contain;border-radius:12px;margin-bottom:12px;display:block}
.modal .modal-contenido h2{font-size:1.4rem;line-height:1.25;color:var(--blue);margin:0 0 6px}
.modal .modal-contenido .precio{color:var(--orange);font-weight:800;font-size:1.2rem;margin:0 0 8px}
.modal .modal-contenido .descripcion{color:var(--gray-dark);font-size:1rem;line-height:1.5;margin:0 0 14px}
.modal .btn-whatsapp{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 18px;border-radius:12px;font-weight:800;font-size:16px;background:#25D366;border:2px solid #25D366;color:#fff;transition:transform .06s,box-shadow .15s,background-color .15s,border-color .15s;text-decoration:none;box-shadow:0 8px 18px rgba(37,211,102,.28)}
.modal .btn-whatsapp:hover{background:#1ebe57;border-color:#1ebe57;box-shadow:0 12px 26px rgba(37,211,102,.35)}
.modal .btn-whatsapp:active{transform:translateY(1px)}
.modal .cerrar{position:absolute;top:10px;right:12px;width:36px;height:36px;display:grid;place-items:center;border:none;border-radius:999px;background:rgba(0,0,0,.05);color:var(--gray-dark);font-size:26px;line-height:1;cursor:pointer;transition:background-color .15s,transform .06s}
.modal .cerrar:hover{background:rgba(0,0,0,.10)}
.modal .cerrar:active{transform:scale(.98)}
.modal .cerrar:focus-visible,.modal .btn-whatsapp:focus-visible{outline:2px solid var(--orange);outline-offset:2px;border-radius:12px}
@keyframes modalIn{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@media (prefers-reduced-motion:reduce){.modal .modal-contenido{animation:none}.modal .btn-whatsapp,.modal .cerrar{transition:none}}
@media (max-width:768px){
  .modal{padding:16px}
  .modal .modal-contenido{width:min(640px,94vw);padding:16px 14px 18px;border-radius:14px}
  .modal .modal-contenido h2{font-size:1.25rem}
  .modal .modal-contenido .precio{font-size:1.1rem}
  .modal .cerrar{top:8px;right:8px;width:34px;height:34px;font-size:24px}
}
@supports(padding:max(0px)){.modal{padding-bottom:max(16px,env(safe-area-inset-bottom))}}

/* ==========================
   BENEFICIOS
========================== */
.benefits{background:var(--white);padding:48px 20px}
.benefits .container{text-align:center}
.benefits h2{color:var(--blue);font-size:2.2rem;line-height:1.2;margin:0 0 22px}
.br-mobile{display:none}
@media (max-width:768px){.br-mobile{display:block}}
.benefits .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;align-items:stretch}
.benefits .card{background:#fff;border-radius:12px;border:1px solid rgba(0,0,0,.06);border-top:4px solid var(--orange);padding:20px 16px;text-align:left;box-shadow:0 2px 6px rgba(0,0,0,.08);transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;flex-direction:column;gap:8px;min-height:160px}
.benefits .card:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(0,0,0,.12);border-top-color:var(--orange-light)}
.benefits .card h3{display:flex;align-items:center;gap:8px;min-height:2.2em;margin:0;color:var(--blue);font-size:1.15rem;line-height:1.25}
.benefits .card h3 [aria-hidden="true"]{font-size:1.4rem;line-height:1}
.benefits .card p{margin:16px 0 0;color:var(--gray-dark);font-size:.98rem;line-height:1.55}
.benefits .card.destacada{background:linear-gradient(180deg,#fff 0%,#f7f9ff 100%);border-top-color:var(--blue)}
.benefits .card.destacada h3{color:var(--blue)}
.benefits .card.destacada p{opacity:.95}
.benefits .card.wide{grid-column:1/-1}
@media (max-width:992px){.benefits{padding:40px 16px}.benefits h2{font-size:1.7rem;margin-bottom:16px}}
@media (max-width:768px){.benefits .grid{gap:14px}.benefits .card{padding:16px 14px}}
@media (prefers-reduced-motion:reduce){.benefits .card{transition:none}}
@media (min-width:992px){
  .benefits .grid{grid-template-columns:repeat(5,1fr);gap:18px}
  .benefits .card.wide{grid-column:auto}
}
@media (max-width:991.98px){
  .benefits .grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
  .benefits .card.wide{grid-column:1/-1}
}

/* ----- Footer simple (si usás #footer viejo) ----- */
.footer{background:var(--blue);color:#fff;text-align:center;padding:20px}
.footer a{color:var(--orange-light);font-weight:500}


/* ==== HOTFIX SWIPER: flechas centradas y DENTRO del carrusel ==== */

/* El carrusel vuelve a recortar contenido: */
.categories .categories-swiper,
.ofertas .ofertas-carousel{
  position: relative;
  overflow: hidden;                /* <- importante */
}

/* Reseteo total de offsets para que no “estiren” el layout */
.categories .swiper-button-prev,
.categories .swiper-button-next,
.ofertas .swiper-button-prev,
.ofertas .swiper-button-next{
  position: absolute;
  inset: auto !important;          /* resetea top/right/bottom/left previos */
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 44px !important;
  height: 44px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: var(--blue) !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.12) !important;
  z-index: 5;
}

/* Posiciones: adentro del carrusel */
.categories .swiper-button-prev,
.ofertas .swiper-button-prev{ left: 10px !important; }

.categories .swiper-button-next,
.ofertas .swiper-button-next{ right: 10px !important; }

/* Icono */
.categories .swiper-button-prev::after,
.categories .swiper-button-next::after,
.ofertas .swiper-button-prev::after,
.ofertas .swiper-button-next::after{
  font-size: 18px !important;
  font-weight: 700 !important;
}

/* Ajustes por tamaño de pantalla */
@media (min-width: 1200px){
  .categories .swiper-button-prev,
  .ofertas .swiper-button-prev{ left: 14px !important; }
  .categories .swiper-button-next,
  .ofertas .swiper-button-next{ right: 14px !important; }
}

@media (max-width: 768px){
  .categories .swiper-button-prev,
  .categories .swiper-button-next,
  .ofertas .swiper-button-prev,
  .ofertas .swiper-button-next{
    width: 40px !important;
    height: 40px !important;
  }
}


/* ==========================
   AJUSTES HERO + CATEGORÍAS MOBILE
========================== */
@media (max-width:768px){
  /* Hero más compacto */
  .hero {
    padding: 24px 16px 28px;   /* menos espacio arriba/abajo */
  }

  .hero .hero-logo-mobile {
    max-width: 260px;          /* logo un poco más chico */
    margin-bottom: 12px;
  }

  .hero .hero-text p {
    font-size: 1rem;
    margin-bottom: 12px;       /* menos espacio */
  }

  .hero .hero-text .btn-primary {
    padding: 10px 20px;
    font-size: 15px;
    min-width: auto;
    max-width: 260px;
  }

  /* Categorías pegadas al hero */
  .categories {
    padding-top: 28px;         /* menos margen superior */
    padding-bottom: 36px;
  }

  .categories h2 {
    margin-bottom: 12px;
  }
}
.hero-text-desktop { display:block; }
.hero-text-mobile { display:none; }

@media (max-width:768px){
  .hero-text-desktop { display:none; }
  .hero-text-mobile { display:block; font-size:1.1rem; margin-bottom:14px; }
}
@media (min-width: 992px) {
  /* Hero más compacto */
  .hero {
    padding: 32px 20px 36px;   /* menos alto que los 48px */
  }

  .hero .hero-content {
    gap: 40px;                 /* menos espacio entre texto y logo */
    align-items: center;
  }

  /* Texto */
  .hero .hero-title {
    font-size: 2.4rem;         /* antes 2.8rem */
    margin-bottom: 16px;
  }
  .hero .hero-text p {
    font-size: 1.3rem;         /* un poco más compacto */
    margin-bottom: 12px;
  }
  .hero .hero-cta-desktop.btn-primary {
    margin-top: 24px;          /* menos aire */
    min-width: 220px;
  }

  /* Logo */
  .hero .hero-image .hero-logo-big {
    max-width: 380px;          /* antes 600px */
  }

  /* Bloque categorías más pegado */
  .categories {
    padding-top: 36px;         /* en vez de 48px */
  }
}

/* ===== Compactar hero en desktop ===== */
@media (min-width: 992px) {
  .hero .hero-text p.hero-text-desktop {
    margin-bottom: 2px !important; /* fuerza el cambio */
    line-height: 1.4;
  }

  
}

/* ==========================
   COMPONENTE – BREADCRUMB
========================== */
.breadcrumb {
  font-size: 0.85rem;
  color: var(--gray-dark);
  margin: 0;
  padding: 6px 0;
  background: #f9f9f9;
  border-bottom: 1px solid #eee;
}

.breadcrumb .container {
  display: flex;
  align-items: center;
}

.breadcrumb a {
  color: var(--blue);
  text-decoration: none;
  font-weight: 600;
}

.breadcrumb a:hover {
  color: var(--orange);
  text-decoration: underline;
}

.breadcrumb .separator {
  margin: 0 6px;
  color: #999;
}

.breadcrumb .current {
  color: var(--gray-dark);
  font-weight: 500;
}

.page-que-es .qe-benefits ul.benefit-stats > li {
  flex: 0 0 auto;   /* evita el "1 1 100%" heredado */
  width: auto;      /* evita que ocupen 100% */
  display: inline-flex;
  align-items: center;
}






