:root{
  --bg:#0d0d0d;
  --card:#151515;
  --muted:#bfbfbf;
  --line:#252525;
  --text:#f5f5f5;
  --accent:#DC143C;
  --accent-2:#e43535;
  --ok:#10b981;
  --warn:#f59e0b;
  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --logo-min:120px;
  --logo-max:240px;
}

*{ box-sizing:border-box }
html,body{ height:100% }
html{ background: var(--bg) }
body{
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Sofia Pro", system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, "Helvetica Neue", Arial, sans-serif;
}
a{ color: inherit }

/* ===== Layout base ===== */
.container{ max-width:1080px; margin:0 auto; padding:56px 20px }
.grid{ display:grid; gap:24px }

/* ===== Head de sección ===== */
.section-head{ text-align:center; margin-bottom:16px }
.section-head .sub{ margin:10px auto 0 }

/* ===== HERO ===== */
.hero{ padding-top:32px; padding-bottom:16px; text-align:center }
.badge{
  display:inline-flex; gap:8px; align-items:center;
  border:1px solid var(--line); background:rgba(220,20,60,.08);
  padding:6px 12px; border-radius:999px; font-size:.9rem; color:#fff
}
.logo{ width:96px; height:96px; object-fit:contain; display:block; margin:0 auto 16px }
h1{ font-size:clamp(32px,4vw,48px); line-height:1.1; margin:12px 0 }
.sub{ color:var(--muted); font-size:1.1rem; max-width:760px; margin:8px auto 24px }
.cta{
  display:inline-block; background:var(--accent); padding:16px 26px;
  border-radius:12px; text-decoration:none; font-weight:700; box-shadow:var(--shadow); transition:.2s;
}
.cta:hover{ background:var(--accent-2); transform: translateY(-1px) }
.note{ font-size:.9rem; color:var(--muted); margin-top:10px }

/* NUEVO: bullets del hero */
.hero-bullets{
  list-style:none;
  padding:0;
  margin: 18px auto 22px;
  max-width: 760px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px 14px;
  text-align:left;
}
.hero-bullets li{
  border: 1px solid var(--line);
  background: #0f0f0f;
  border-radius: 14px;
  padding: 12px 14px;
  color:#eaeaea;
  box-shadow: var(--shadow);
  line-height: 1.25;
}
@media (max-width: 720px){
  .hero-bullets{ grid-template-columns: 1fr }
}

/* ===== Cards / Media ===== */
.benefits{ grid-template-columns:repeat(auto-fit,minmax(240px,1fr)) }
.card{
  background:linear-gradient(180deg,#151515 0%,#111 100%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow)
}
.card i{ color:var(--accent); margin-bottom:8px }
.media{ position:relative; border-radius:18px; overflow:hidden; border:1px solid var(--line) }
.media img{ width:100%; height:100%; object-fit:cover; display:block }
.media .caption{
  position:absolute; left:12px; bottom:12px;
  background:rgba(0,0,0,.5); backdrop-filter:saturate(120%) blur(4px);
  padding:6px 10px; border-radius:10px; font-size:.85rem
}

/* ===== NUEVO: Esto es para ti si... ===== */
.fit-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 18px;
}
.fit-card h3{
  margin: 0 0 10px 0;
  font-size: 1.2rem;
  display:flex;
  align-items:center;
  gap:10px;
}
.fit-card h3 i{ color: var(--accent) }
.fit-card.fit-no h3 i{ color: rgba(255,255,255,.55) }

.fit-list{
  margin: 0;
  padding-left: 18px;
  color:#ddd;
}
.fit-list li{ margin: 10px 0; line-height: 1.35 }

.fit-cta{
  display:flex;
  align-items:center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 16px;
}
@media (max-width: 860px){
  .fit-grid{ grid-template-columns: 1fr }
}

/* ===== NUEVO: El mecanismo ===== */
.mechanism-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 18px;
}
.mechanism-card h3{
  margin: 0 0 10px 0;
  font-size: 1.2rem;
  display:flex;
  align-items:center;
  gap:10px;
}
.mechanism-card h3 i{ color: var(--accent) }

.mechanism-list{
  margin: 0;
  padding-left: 18px;
  color:#ddd;
}
.mechanism-list li{ margin: 10px 0; line-height: 1.35 }

.mechanism-tagline{
  border: 2px solid rgba(220,20,60,.45);
  background: radial-gradient(900px 260px at 20% -10%, rgba(220,20,60,.18), transparent 60%), #101010;
}

.tagline{
  margin: 10px 0 12px 0;
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 800;
  letter-spacing: .2px;
}

.mechanism-cta{ margin-top: 16px }

@media (max-width: 860px){
  .mechanism-grid{ grid-template-columns: 1fr }
}

/* ===== Tabla comparativa ===== */
.table-wrap{ overflow:auto; border:1px solid var(--line); border-radius:14px }
table{ width:100%; border-collapse:collapse; background:#0f0f0f }
th,td{ padding:14px 16px; border-bottom:1px solid var(--line); text-align:left }
th{ position:sticky; top:0; background:#121212 }
tr:hover td{ background:#111 }
.yes{ color:#10b981; font-weight:700 }
.no{ color:#ef4444; font-weight:700 }

/* ===== Testimonios ===== */
.testis{ grid-template-columns:repeat(auto-fit,minmax(260px,1fr)) }
.quote{ display:flex; gap:14px }
.quote img{ width:44px; height:44px; border-radius:999px; object-fit:cover; border:1px solid var(--line) }
.quote p{ margin:0; color:#ddd }
.quote .who{ font-size:.9rem; color:var(--muted) }

/* ===== FAQ ===== */
details{ border:1px solid var(--line); border-radius:12px; padding:14px 18px; background:#111 }
details+details{ margin-top:12px }
summary{ cursor:pointer; font-weight:700 }

/* ===== Pricing ===== */
.pricing{ display:grid; grid-template-columns:1fr; gap:18px }
.price-card{
  border:2px solid var(--accent);
  border-radius:18px;
  padding:24px;
  background:radial-gradient(1200px 400px at 80% -10%, rgba(220,20,60,.14), transparent 60%), #101010
}
.kpis{ display:flex; gap:14px; flex-wrap:wrap; margin-top:10px }
.kpis .pill{ border:1px solid var(--line); padding:6px 10px; border-radius:999px; color:#ddd }
.legal{ font-size:.85rem; color:var(--muted) }

/* ===== Footer ===== */
footer{ border-top:1px solid var(--line); padding:40px 20px; text-align:center; color:#aaa }
.links{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap }
.links a{ color:#ddd; text-decoration:underline }

/* ===== IG Slider base ===== */
.ig-slider{ position:relative; margin-top:12px }
.ig-track{
  display:grid; grid-auto-flow:column; gap:20px;
  overflow-x:auto; scroll-snap-type:x mandatory;
  padding:6px 44px;
}

.slide{
  position:relative; scroll-snap-align:center; flex:0 0 auto;
  width:min(340px,85vw); aspect-ratio:4/5;
  border-radius:20px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  background:#000;
}
.slide img{
  width:100%; height:100%; object-fit:cover; display:block;
  transform:translateZ(0);
}
.ig-label{
  position:absolute; left:50%; bottom:14px; transform:translateX(-50%);
  background:#fff; color:#111; font-weight:800;
  padding:10px 16px; border-radius:16px; box-shadow:0 6px 20px rgba(0,0,0,.25);
  font-size:1rem; line-height:1; white-space:nowrap;
}
.ig-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:999px; border:1px solid var(--line);
  background:rgba(0,0,0,.5); color:#fff; backdrop-filter:blur(3px);
  display:grid; place-items:center; cursor:pointer;
}
.ig-nav:hover{ background:rgba(0,0,0,.7) }
.ig-nav.prev{ left:6px } .ig-nav.next{ right:6px }

.ig-dots{ display:flex; gap:8px; justify-content:center; margin-top:10px }
.ig-dots button{ width:8px; height:8px; border-radius:999px; border:none; background:#555; opacity:.5 }
.ig-dots button[aria-current="true"]{ background:var(--accent); opacity:1; width:20px }

@media (max-width:480px){
  .slide{ width:78vw }
}

/* ===== Qué es Invencible (bloque explicativo) ===== */
.invencible-explain .explain-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:24px;
  align-items:center;
}
.explain-media{
  margin:0; position:relative;
  border-radius:20px; overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow);
}
.explain-media img{
  width:100%; height:100%;
  aspect-ratio:16/9;
  object-fit:cover; object-position:center;
  display:block;
}
.explain-caption{
  position:absolute; left:16px; bottom:14px;
  background:#fff; color:#111; padding: 10px 16px; border-radius: 16px; font-weight: 800;
  font-size: 1rem; line-height: 1; box-shadow:0 6px 20px rgba(0,0,0,.25);
}
.explain-copy h2{ margin:0 0 8px 0; font-size:clamp(22px,3vw,28px) }
.explain-copy p{ color:var(--muted); margin:0 0 10px 0 }

.explain-bullets{
  list-style: none; padding: 0; margin: 14px auto 16px; max-width: 760px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; text-align: left;
  color:#ddd;
}
.explain-bullets li{
  border: 1px solid var(--line); background: #0f0f0f; color: #ddd;
  border-radius: 999px; padding: 10px 14px; font-size: .98rem;
  display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow);
}
.explain-bullets li::before{
  content: "\f058"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--accent); opacity: .95;
}
@media (max-width: 680px){ .explain-bullets{ grid-template-columns: 1fr } }

@media (max-width: 860px){
  .invencible-explain .explain-grid{ grid-template-columns: 1fr; }
}

/* ===== Cómo funciona ===== */
.howitworks{ margin-top:30px }
.how-row{
  display:grid; grid-template-columns:80px 140px 1fr; align-items:center;
  gap:22px; padding:26px 0; border-top:1px solid var(--line);
}
.how-row:last-child{ border-bottom:1px solid var(--line) }
.how-num{ font-size:2.2rem; font-weight:800; color:#fff; opacity:.9; letter-spacing:.02em }
.how-illu{
  width:140px; height:140px; border-radius:22px;
  display:grid; place-items:center;
  background:linear-gradient(180deg,#151515 0%,#111 100%);
  border:1px solid var(--line); box-shadow:var(--shadow);
}
.how-illu i{ font-size:48px; color:var(--accent) }
.how-copy h3{ margin:0 0 8px 0; font-size:1.25rem }
.how-copy p{ color:var(--muted); margin:0 0 10px 0 }

.areas{
  display:flex; flex-wrap:wrap; gap:8px; margin:8px 0 6px 0; padding:0; list-style:none
}
.areas li{
  border:1px solid var(--line); background:#0f0f0f; color:#ddd;
  border-radius:999px; padding:6px 10px; font-size:.95rem
}

.howitworks .areas.areas-2col{
  display: block !important;
  column-count: 2; column-gap: 20px;
  -webkit-column-count: 2; -webkit-column-gap: 20px;
  margin: 12px 0 6px 0;
  padding: 0; list-style: none;
}
.howitworks .areas.areas-2col li{
  display: block; width: 100%;
  break-inside: avoid; -webkit-column-break-inside: avoid;
  border: 1px solid var(--line);
  background: #0f0f0f; color: #ddd;
  border-radius: 999px; padding: 8px 14px; font-size: .95rem;
  margin: 0 0 10px 0;
}
@media (max-width: 560px){
  .howitworks .areas.areas-2col{ column-count: 1; -webkit-column-count: 1; }
}

@media (max-width:840px){
  .how-row{ grid-template-columns:64px 96px 1fr; gap:16px }
  .how-illu{ width:96px; height:96px; border-radius:16px }
  .how-illu i{ font-size:34px }
  .how-num{ font-size:1.8rem }
}
@media (max-width:560px){
  .how-row{ grid-template-columns:56px 72px 1fr }
  .how-illu{ width:72px; height:72px }
  .how-illu i{ font-size:28px }
}

/* ===== Valor + CTA ===== */
.value-cta{ text-align:center }
.value-cards{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
  margin:18px 0 10px 0;
}
.vcard{
  background:#0f0f0f; border:1px solid var(--line); border-radius:20px;
  padding:20px 18px; box-shadow:var(--shadow); text-align:left; color:#eee;
}
.vcard h3{ margin:0 0 6px 0; font-size:1.2rem }
.vcard p{ margin:0; color:var(--muted) }
.tilt-1{ transform:rotate(-3deg) } .tilt-2{ transform:rotate(-1deg) }
.tilt-3{ transform:rotate(2deg) }  .tilt-4{ transform:rotate(-2deg) }
.vcard:hover{ transform:rotate(0deg) translateY(-4px); transition:.2s }

.value-subtitle{ margin:24px 0 10px 0; color:#ddd; font-size:1.1rem }
.value-cta-buttons{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:6px }
.pill-cta{
  display:inline-block; background:var(--accent); color:#fff; text-decoration:none;
  padding:12px 18px; border-radius:999px; font-weight:700; border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 24px rgba(220,20,60,.25);
}
.pill-cta:hover{ background:#e43535 }
.value-note{ margin-top:12px; color:var(--muted); font-size:.95rem }

@media (max-width:1024px){ .value-cards{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:560px){
  .value-cards{ grid-template-columns:1fr }
  .vcard{ transform:rotate(0) }
}

/* ===== Testimonios: layout 2x2 centrado ===== */
#pruebas-sociales .testis{
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 22px;
  justify-items: center;
}
#pruebas-sociales .card{
  width: 100%;
  max-width: 460px;
  text-align: center;
}
#pruebas-sociales h2{
  text-align: center;
  margin-bottom: 14px;
}
@media (max-width: 720px){
  #pruebas-sociales .testis{ grid-template-columns: 1fr }
}
#pruebas-sociales .quote { justify-content: center }

/* ===== FAQ en 2 columnas ===== */
.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px 24px;
}
.faq-grid details{
  background:#111; border:1px solid var(--line); border-radius:12px; padding:14px 18px;
}
.faq-grid summary{ font-weight:700; cursor:pointer }
@media (max-width:720px){
  .faq-grid{ grid-template-columns:1fr; }
}

/* ===== Ajustes de logo y títulos ===== */
.hero .logo{
  width: clamp(120px, 18vw, 240px);
  height: auto;
  margin-bottom: 18px;
}

/* ===== Slider combinado: media arriba + texto abajo ===== */
.slide--area{
  aspect-ratio: auto;
  padding: 0;
  display: flex; flex-direction: column;
}
.slide--area .slide-media{
  position: relative;
  width: 100%;
  aspect-ratio: 4/5;
  overflow: hidden;
}
.slide--area .slide-media img{
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.slide--area .ig-label{
  left: 50%; transform: translateX(-50%);
  bottom: 12px;
}
.slide--area .slide-copy{
  padding: 14px 14px 16px;
  background: linear-gradient(180deg,#151515 0%, #111 100%);
  border-top: 1px solid var(--line);
}
.slide--area .slide-copy p{ margin: 0; color: var(--muted) }
.slide--area .area-icon{ color: var(--accent); opacity: .95 }

/* ===== Título bloque de áreas ===== */
#areas .section-title { text-align: center }
.section-title .brand { color: var(--accent) }

/* Logos secundarios con el mismo tamaño que el del hero */
.logo--hero-size{
  width: clamp(120px, 18vw, 240px);
  height: auto;
  display: block;
  margin: 0 auto 18px;
  object-fit: contain;
}

/* Ocultar scrollbar pero mantener el scroll interno */
.ig-track{
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.ig-track::-webkit-scrollbar{
  display: none !important;
}

.area-title{
  display:flex;
  align-items:center;
  gap:12px;
  margin:0 0 8px 0;
  font-size:1.15rem;
  color:#fff;
}
.area-title .area-icon{
  margin-left:auto;
  color: var(--accent);
  opacity:.95;
  line-height:1;
}

/* ==========================================
   Sticky CTA (aparece al hacer scroll)
   ========================================== */
/* .sticky-cta{
  position: fixed;
  right: 16px;
  top: 16px;
  z-index: 9999;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  background: var(--accent);
  color: #fff;
  text-decoration: none;
  font-weight: 800;

  padding: 12px 14px;
  border-radius: 999px;
  box-shadow: 0 12px 28px rgba(0,0,0,.35);

  transform: translateY(-12px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease, background .2s ease;
}

.sticky-cta:hover{
  background: var(--accent-2);
  transform: translateY(0);
}

.sticky-cta.is-visible{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.sticky-cta .rocket{
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.22);
}

.sticky-cta .label{
  white-space: nowrap;
  font-size: .95rem;
  letter-spacing: .2px;
}

@media (max-width: 520px){
  .sticky-cta .label{
    display: none;
  }
  .sticky-cta{
    padding: 10px;
  }
} */

/* ===== Fuentes: @font-face (todas las variantes) ===== */
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-UltraLight.woff2") format("woff2");
  font-weight: 200; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-ExtraLight.woff2") format("woff2");
  font-weight: 250; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-Light.woff2") format("woff2");
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-Regular.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-RegularItalic.woff2") format("woff2");
  font-weight: 400; font-style: italic; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-Medium.woff2") format("woff2");
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-SemiBold.woff2") format("woff2");
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-Bold.woff2") format("woff2");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-BoldItalic.woff2") format("woff2");
  font-weight: 700; font-style: italic; font-display: swap;
}
@font-face{
  font-family: "Sofia Pro";
  src: url("/fonts/sofia-pro/SofiaPro-Black.woff2") format("woff2");
  font-weight: 900; font-style: normal; font-display: swap;
}
@font-face{
  font-family:"Sofia Pro";
  src: url("/fonts/sofia-pro/Sofia Pro Regular Az.otf") format("opentype");
  font-weight:400; font-style:normal; font-display:swap;
}

/* ===== Pesos tipográficos ===== */
h1, h2, .section-title{ font-weight: 700 }
h3{ font-weight: 600 }
.sub, p{ font-weight: 400 }
.cta, .pill-cta{ font-weight: 700 }
.badge, .ig-label, .explain-caption{ font-weight: 700 }


.hero-target{
  max-width: 900px;
  margin: 10px auto 18px;
  text-align: center;
}

.hero-target__headline{
  font-size: clamp(22px, 2.3vw, 30px);
  font-weight: 800;
  color: #fff;
  margin-bottom: 8px;
}

.hero-target__sub{
  font-size: clamp(16px, 1.6vw, 20px);
  color: var(--muted);
  line-height: 1.35;
}


.hero-bullets{
  list-style:none;
  padding:0;
  margin: 18px auto 22px;
  max-width: 760px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px 14px;
  text-align:left;
}

.hero-bullets--onecol{
  grid-template-columns: 1fr;
  max-width: 820px;
}

.hero-bullets li{
  border: 1px solid var(--line);
  background: #0f0f0f;
  border-radius: 14px;
  padding: 12px 14px 12px 46px;
  color:#eaeaea;
  box-shadow: var(--shadow);
  line-height: 1.25;
  position: relative;
}

.hero-bullets li::before{
  content: "\f058";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: var(--accent);
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
}

.yes{
  color: var(--accent);
  font-weight: 800;
}

.no{
  color: rgba(255,255,255,.72);
  font-weight: 600;
}

#comparativa td.yes{
  background: rgba(220,20,60,.08);
  border: 1px solid var(--line);
  border-radius: 8px;
}

#comparativa td.no::before{
  content: "\f00d";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  margin-right: 8px;
  color: rgba(255,255,255,.35);
}


/* =========================================================
   HERO: menos “aire” arriba, más legibilidad y bullets centrados
   ========================================================= */

/* Reduce un poco el aire general del hero */
.hero{
  padding-top: 22px;
  padding-bottom: 10px;
}

/* Título principal: un pelín más compacto */
.hero h1{
  margin: 10px 0 12px;
  line-height: 1.08;
}

/* Público objetivo: más aire entre líneas (mejor lectura) */
.hero-target{
  margin: 12px auto 14px;
}

.hero-target__headline{
  line-height: 1.18;
  margin-bottom: 10px;
}

.hero-target__sub{
  line-height: 1.65;   /* <- más aire entre líneas */
}

/* Bullets:
   - centrados
   - todas las cajas mismo ancho (igual al “ancho del bloque”, basado en la más larga)
   - sin ocupar todo el viewport
*/
.hero-bullets--onecol{
  width: fit-content;
  max-width: min(820px, 92vw);
  margin: 14px auto 18px;
  gap: 12px;
}

.hero-bullets--onecol li{
  width: 100%;
  line-height: 1.45;      /* <- más aire dentro de cada frase */
  padding-top: 14px;
  padding-bottom: 14px;
}

/* Ajuste fino del icono para que quede “más centrado” verticalmente */
.hero-bullets li::before{
  top: 50%;
  transform: translateY(-50%);
}

/* CTA y nota: un poco más de aire y limpieza visual */
.hero .cta{
  margin-top: 6px;
}

.hero .note{
  margin-top: 12px;
  line-height: 1.5;
}


/* =========================================================
   MECANISMO: “No motiva. Entrena.” más potente (como antes)
   ========================================================= */

/* Recupera el “peso” visual del titular del mecanismo */
.mechanism-tagline h3{
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.12;
  margin: 0 0 10px 0;
}


/* =========================================================
   COMPARATIVA: volver a dibujar la línea vertical separadora
   (entre Apps genéricas e Invencible)
   ========================================================= */

/* Línea vertical en cabecera y filas */
#comparativa thead th:nth-child(2),
#comparativa tbody td:nth-child(2){
  border-right: 1px solid var(--line);
}

#comparativa thead th:nth-child(3),
#comparativa tbody td:nth-child(3){
  border-left: 1px solid var(--line);
}

/* =========================
   FAQ: evitar que la columna de al lado se estire
   ========================= */

.faq-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;                 /* conserva tu separación si ya la tenías */
  align-items: start;        /* CLAVE: en vez de stretch */
}

/* Asegura que cada card conserve su altura real (no se estira) */
.faq-grid > details{
  align-self: start;         /* refuerzo por si hay estilos heredados */
  height: auto;
}

@media (max-width: 900px){
  .faq-grid{
    grid-template-columns: 1fr;
  }
}

/* =========================
   Logo tamaño fijo (logo--hero-size)
   ========================= */

.logo.logo--hero-size{
  width: 96px;
  height: 96px;
  object-fit: contain;
  display: block;
}

@media (max-width: 640px){
  .logo.logo--hero-size{
    width: 72px;
    height: 72px;
  }
}


/* Alternativa sin :has() */
#precio .price-card .cta{
  display: inline-flex;
}

#precio .price-card p{
  text-align: center;
}

/* =========================
   PRECIO: centrar CTA (y el bloque) de forma consistente
   ========================= */

#precio .price-card{
  text-align: center;
}

#precio .price-card .kpis{
  justify-content: center;
}

#precio .price-card .cta{
  display: inline-flex;   /* mantiene el look del botón */
  margin-left: auto;
  margin-right: auto;
}

/* =========================
   Sticky CTA: siempre visible
   ========================= */

.sticky-cta{
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
}

/* ===== FAQ en grid: que el espaciado lo gestione el gap, no details+details ===== */
.faq-grid details{
  margin-top: 0 !important;
}


/* ============================
   HEADER (siempre visible)
   ============================ */

:root{
  --header-h: 92px; /* altura del header con logo grande */
}

.main-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10000;
  background: rgba(13, 13, 13, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.header-inner{
  max-width: 1200px;
  margin: 0 auto;
  height: var(--header-h);
  padding: 0 20px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}


/* Izquierda */
.header-left {
  justify-self: start;
}

.header-link {
  color: #e5e7eb;
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  opacity: 0.85;
}

.header-link:hover {
  opacity: 1;
}

/* Centro */
.header-center {
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-logo {
  display: block;
  width: 64px;
  height: 64px;
}

.header-brand {
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 0.2px;
  line-height: 1;
}

.header-cta {
  padding: 12px 18px;
  border-radius: 999px;
  background: var(--accent);
  color: #0d0d0d;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  white-space: nowrap;
}

/* Derecha */
.header-right {
  justify-self: end;
}


.header-cta:hover {
  opacity: 0.9;
}

/* Mobile */
@media (max-width: 640px) {
  .header-link {
    font-size: 13px;
  }

  .header-logo {
    width: 44px;
    height: 44px;
  }

  .header-brand {
    font-size: 20px;
  }

  .header-cta {
    padding: 7px 12px;
    font-size: 12px;
  }
}



/* Empuja todo el contenido hacia abajo para que no quede debajo del header */
body{
  padding-top: var(--header-h);
}

/* Mobile: header un poco más bajo */
@media (max-width: 640px){
  :root{ --header-h: 72px; }
  body{ padding-top: var(--header-h); }
}