/* ============================================================
   CINCO BAÑOS · Landing · estilos de sección
   Reutiliza system.css + logo.css
   ============================================================ */

.lp{overflow-x:hidden}
.container{max-width:1180px;margin:0 auto;padding:0 32px}
.container--narrow{max-width:880px}

/* reveal sutil · NUNCA toca opacity → el contenido es siempre visible (export/PDF/PPTX safe).
   Solo desliza con transform; en render estático el peor caso es un nudge inofensivo. */
.js .reveal{transform:translateY(20px);transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.js .reveal.is-in{transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal,.js .reveal.is-in{transform:none;transition:none}}

.eyebrow.coral{color:var(--coral)}
.sec-pad{padding:104px 0}
.sec-head{max-width:60ch}
.sec-head h2{font-family:var(--f-display);font-weight:700;font-size:clamp(30px,4.4vw,48px);letter-spacing:-.025em;line-height:1.04;margin:14px 0 0}
.sec-head .lead{font-size:var(--t-bodyl);color:var(--ink-2);margin:20px 0 0;max-width:52ch}
.on-sage .sec-head .lead{color:#C9D4C6}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,241,232,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s,padding .3s,background .3s;
}
.site-header.scrolled{border-color:var(--stone-line)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:74px;transition:height .3s}
.site-header.scrolled .bar{height:62px}
.site-header nav{display:flex;align-items:center;gap:30px}
.site-header nav a.lnk{font-family:var(--f-body);font-weight:500;font-size:15px;color:var(--graphite);text-decoration:none;transition:color .2s}
.site-header nav a.lnk:hover{color:var(--sage)}
.site-header .phone{font-family:var(--f-display);font-weight:600;font-size:15px;color:var(--sage);text-decoration:none}
.site-header .btn{padding:13px 20px;font-size:15px}
.nav-collapse{display:flex;align-items:center;gap:30px}
@media (max-width:860px){.nav-collapse .lnk,.nav-collapse .phone{display:none}}

/* ---------- Hero ---------- */
.hero{position:relative;padding:72px 0 96px}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero__badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);background:var(--sage-tint);border:1px solid #cfdac9;padding:8px 14px;border-radius:var(--r-pill)}
.hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,7.4vw,88px);line-height:.98;letter-spacing:-.035em;margin:24px 0 0}
.hero h1 .em{color:var(--sage)}
.hero__sub{font-size:clamp(18px,2.2vw,22px);color:var(--ink-2);margin:24px 0 0;max-width:34ch}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.hero__micro{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;font-size:14px;color:var(--ink-2)}
.hero__micro span{display:flex;align-items:center;gap:8px}
.hero__micro .tick{color:var(--coral);font-weight:700}
.hero__media{position:relative}
.hero__media .ph{height:520px;border-radius:var(--r-lg)}
.hero__five{position:absolute;right:-26px;bottom:-36px;font-family:var(--f-display);font-weight:700;font-size:240px;line-height:.7;color:var(--cream);text-shadow:0 0 0 #000;pointer-events:none;z-index:2}
.hero__chip{position:absolute;left:-22px;top:34px;background:#fff;border:1px solid var(--stone-line);border-radius:var(--r-md);padding:14px 18px;box-shadow:var(--shadow-soft);z-index:3}
.hero__chip b{font-family:var(--f-display);font-weight:700;font-size:30px;color:var(--sage);letter-spacing:-.02em;display:block}
.hero__chip span{font-size:13px;color:var(--ink-2)}

/* ---------- Prueba social ---------- */
.proof{border-top:1px solid var(--stone-line);border-bottom:1px solid var(--stone-line);background:var(--paper)}
.proof__row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 0;flex-wrap:wrap}
.proof__item{display:flex;align-items:center;gap:14px}
.proof__num{font-family:var(--f-display);font-weight:700;font-size:34px;letter-spacing:-.02em;color:var(--sage);line-height:1}
.proof__lab{font-size:13px;color:var(--ink-2);line-height:1.3;max-width:18ch}
.proof__stars{color:var(--coral);font-size:18px;letter-spacing:2px}
.proof__div{width:1px;height:42px;background:var(--stone-line)}

/* ---------- Problema (sage) ---------- */
.problem{background:var(--sage);color:var(--cream)}
.problem__grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.problem h2{font-family:var(--f-display);font-weight:700;font-size:clamp(30px,4.2vw,46px);letter-spacing:-.025em;line-height:1.05;margin:14px 0 0}
.problem__list{list-style:none;margin:32px 0 0;padding:0;display:flex;flex-direction:column;gap:2px}
.problem__list li{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--sage-line);font-size:18px;color:#E6EBE2}
.problem__list .x{color:var(--coral);font-weight:700;flex:none;font-size:20px}
.problem__quote{background:var(--sage-deep);border-radius:var(--r-lg);padding:40px;border-left:4px solid var(--coral)}
.problem__quote p{font-family:var(--f-serif);font-style:italic;font-size:clamp(24px,3vw,32px);line-height:1.35;margin:0;color:var(--cream)}
.problem__quote cite{display:block;font-family:var(--f-body);font-style:normal;font-size:14px;color:#C9D4C6;margin-top:20px;letter-spacing:.02em}
.problem__turn{margin-top:30px;font-family:var(--f-display);font-weight:600;font-size:22px;color:var(--cream)}
.problem__turn b{color:var(--coral)}

/* ---------- Timeline ---------- */
.timeline-sec{background:var(--cream)}
.timeline__strip{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:48px;position:relative}
.timeline__cta{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:48px;padding:32px 36px;background:var(--sage-tint);border:1px solid #cfdac9;border-radius:var(--r-lg)}
.timeline__cta p{margin:0;font-family:var(--f-display);font-weight:600;font-size:22px;color:var(--sage);max-width:36ch}
.note-asterisk{font-size:13px;color:var(--ink-2);margin-top:22px;max-width:60ch}

/* ---------- Galería ---------- */
.gallery{background:var(--paper);border-top:1px solid var(--stone-line)}
.gallery__grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:48px}

/* ---------- Proceso ---------- */
.process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:52px;counter-reset:step}
.pstep{position:relative;padding-top:30px;border-top:2px solid var(--graphite)}
.pstep__n{font-family:var(--f-mono);font-size:13px;font-weight:600;letter-spacing:.1em;color:var(--coral)}
.pstep h3{font-family:var(--f-display);font-weight:600;font-size:var(--t-h4);letter-spacing:-.01em;margin:12px 0 10px}
.pstep p{margin:0;font-size:15px;color:var(--ink-2)}

/* ---------- Pricing ---------- */
.pricing{background:var(--cream)}
.pricing__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;align-items:start}
.pricing__note{text-align:center;margin-top:30px;font-size:14px;color:var(--ink-2)}

/* ---------- Financiación ---------- */
.finance{background:var(--graphite);color:var(--cream)}
.finance__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.finance h2{font-family:var(--f-display);font-weight:700;font-size:clamp(30px,4.2vw,46px);letter-spacing:-.025em;line-height:1.05;margin:14px 0 0}
.finance__sub{color:#C9C3B7;font-size:18px;margin:20px 0 0;max-width:40ch}
.finance__badge{display:inline-flex;align-items:center;gap:10px;margin-top:24px;background:var(--coral);color:#231310;font-family:var(--f-display);font-weight:600;font-size:16px;padding:11px 18px;border-radius:var(--r-pill)}
.sim{background:#232220;border:1px solid #3a3a37;border-radius:var(--r-lg);padding:38px}
.sim__row{margin-bottom:30px}
.sim__row label{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;color:#C9C3B7;margin-bottom:14px}
.sim__row label b{font-family:var(--f-display);font-weight:700;font-size:22px;color:var(--cream);letter-spacing:-.01em}
.sim input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:#3a3a37;outline:none;accent-color:var(--coral)}
.sim input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--coral);cursor:pointer;border:3px solid #232220}
.sim input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--coral);cursor:pointer;border:3px solid #232220}
.sim input[type=range]:focus-visible{outline:3px solid var(--coral);outline-offset:4px}
.sim__terms{display:flex;gap:10px;flex-wrap:wrap}
.sim__term{flex:1;min-width:64px;text-align:center;font-family:var(--f-display);font-weight:600;font-size:15px;padding:12px 6px;border-radius:var(--r-sm);background:#2c2b29;border:1.5px solid #3a3a37;color:#C9C3B7;cursor:pointer;transition:all .18s}
.sim__term[aria-pressed=true]{background:var(--cream);color:var(--graphite);border-color:var(--cream)}
.sim__term:focus-visible{outline:3px solid var(--coral);outline-offset:3px}
.sim__out{margin-top:34px;padding-top:28px;border-top:1px solid #3a3a37;display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.sim__pay{font-family:var(--f-display);font-weight:700;font-size:64px;line-height:.9;letter-spacing:-.03em;color:var(--cream);display:flex;align-items:baseline;gap:4px}
.sim__pay small{font-size:24px;font-weight:600}
.sim__meta{font-size:13px;color:#9b968d;max-width:30ch;text-align:right}
.sim__tae{font-family:var(--f-mono);font-size:12px;color:var(--coral);letter-spacing:.04em;margin-top:6px}

/* ---------- Garantías ---------- */
.guarantees{background:var(--cream)}
.guar__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:52px}
.guar{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.seal{width:84px;height:84px;border-radius:50%;border:1.5px solid var(--sage);display:grid;place-items:center;color:var(--sage);font-family:var(--f-display);font-weight:700;font-size:30px;position:relative;flex:none}
.seal::before{content:"";position:absolute;inset:6px;border-radius:50%;border:1px solid var(--sage);opacity:.4}
.guar h3{font-family:var(--f-display);font-weight:600;font-size:var(--t-h4);letter-spacing:-.01em;margin:0}
.guar p{margin:0;font-size:15px;color:var(--ink-2);max-width:34ch}
.guar__hero{margin-top:36px;background:var(--coral);color:#231310;border-radius:var(--r-lg);padding:40px 44px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.guar__hero p{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,3.2vw,36px);letter-spacing:-.02em;margin:0;max-width:22ch;line-height:1.08;color:#231310}
.guar__hero .big5{font-family:var(--f-display);font-weight:700;font-size:120px;line-height:.7;color:#231310;opacity:.9}

/* ---------- Testimonios ---------- */
.testimonials{background:var(--paper);border-top:1px solid var(--stone-line)}
.test__grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:52px}

/* ---------- FAQ ---------- */
.faq-sec{background:var(--cream)}
.faq-sec .faq{margin-top:44px}

/* ---------- CTA final ---------- */
.final{background:var(--sage);color:var(--cream);position:relative;overflow:hidden}
.final__ghost{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--f-display);font-weight:700;font-size:880px;line-height:.7;color:rgba(245,241,232,.05);pointer-events:none}
.final__grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.final h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,6vw,72px);letter-spacing:-.03em;line-height:.98;margin:18px 0 0}
.final__sub{font-size:20px;color:#DDE3D8;margin:22px 0 0;max-width:34ch}
.final__micro{margin-top:26px;display:flex;gap:20px;flex-wrap:wrap;font-size:14px;color:#C9D4C6}
.final__micro span{display:flex;gap:8px;align-items:center}
.form{background:var(--paper);border-radius:var(--r-lg);padding:38px}
.form .fld{margin-bottom:18px}
.form label{display:block;font-family:var(--f-display);font-weight:600;font-size:14px;color:var(--graphite);margin-bottom:8px}
.form input,.form select{width:100%;font-family:var(--f-body);font-size:16px;padding:14px 16px;border:1.5px solid var(--stone-line);border-radius:var(--r-sm);background:#fff;color:var(--graphite);transition:border-color .2s}
.form input:focus,.form select:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 3px rgba(58,90,64,.15)}
.form input.err{border-color:var(--coral-deep)}
.form .err-msg{color:var(--coral-deep);font-size:13px;margin-top:6px;display:none}
.form input.err + .err-msg{display:block}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .btn{width:100%;justify-content:center;margin-top:8px}
.form .legal{font-size:12px;color:var(--ink-2);margin:16px 0 0;line-height:1.5}
.form .legal a{color:var(--sage)}
.form__ok{display:none;text-align:center;padding:30px 10px}
.form__ok .seal{margin:0 auto 20px}
.form__ok h3{font-family:var(--f-display);font-size:26px;margin:0 0 10px;letter-spacing:-.01em}
.form__ok p{color:var(--ink-2);margin:0}

/* ---------- Footer ---------- */
.site-footer{background:var(--graphite);color:#C9C3B7;padding:72px 0 36px}
.foot__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.site-footer h4{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#8a857c;margin:0 0 18px}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.site-footer a{color:#C9C3B7;text-decoration:none;font-size:15px}
.site-footer a:hover{color:var(--cream)}
.site-footer .blurb{font-size:14px;max-width:30ch;margin:18px 0 0;color:#9b968d}
.foot__bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:54px;padding-top:26px;border-top:1px solid #2f2e2b;font-size:13px;color:#8a857c}

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .hero__grid,.problem__grid,.finance__grid,.final__grid{grid-template-columns:1fr;gap:40px}
  .hero__media{order:-1}
  .hero__five{font-size:160px;right:0;bottom:-20px}
  .process__grid{grid-template-columns:1fr 1fr}
  .timeline__strip{grid-template-columns:1fr 1fr}
  .pricing__grid,.guar__grid{grid-template-columns:1fr}
  .gallery__grid,.test__grid{grid-template-columns:1fr}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .sec-pad{padding:72px 0}
  .container{padding:0 22px}
  .timeline__strip,.process__grid,.foot__grid{grid-template-columns:1fr}
  .proof__row{justify-content:flex-start;gap:18px}
  .proof__div{display:none}
  .form .row2{grid-template-columns:1fr}
  .hero__chip{display:none}
}

/* ---------- Caso real (banda intercalada entre secciones) ---------- */
.caso{background:var(--paper);border-top:1px solid var(--stone-line);border-bottom:1px solid var(--stone-line)}
.caso--sage{background:var(--sage);border-color:var(--sage);color:var(--cream)}
.caso__grid{display:grid;grid-template-columns:minmax(0,440px) 1fr;gap:52px;align-items:center;padding:40px 0}
.caso--rev .caso__grid{grid-template-columns:1fr minmax(0,440px)}
.caso--rev .caso__media{order:2}
.caso__media{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/10}
.caso__media img{width:100%;height:100%;object-fit:cover;display:block}
.caso__tag{position:absolute;top:14px;left:14px;background:var(--coral);color:#231310;font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px 13px;border-radius:var(--r-pill)}
.caso__eyebrow{font-family:var(--f-mono);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);margin-bottom:14px}
.caso--sage .caso__eyebrow{color:var(--coral-tint)}
.caso__quote{font-family:var(--f-display);font-weight:600;font-size:clamp(22px,2.6vw,30px);line-height:1.28;letter-spacing:-.01em;color:var(--graphite);margin:0}
.caso--sage .caso__quote{color:#fff}
.caso__who{display:flex;align-items:center;gap:14px;margin-top:24px}
.caso__avatar{width:56px;height:56px;border-radius:var(--r-pill);overflow:hidden;flex:none}
.caso__avatar img{width:100%;height:100%;object-fit:cover;display:block}
.caso__name{font-family:var(--f-display);font-weight:600;font-size:16px}
.caso__meta{font-size:13px;color:var(--ink-2);margin-top:2px}
.caso--sage .caso__meta{color:#C9D4C6}
@media (max-width:760px){
  .caso__grid,.caso--rev .caso__grid{grid-template-columns:1fr;gap:24px;padding:32px 0}
  .caso--rev .caso__media{order:0}
}

/* ---------- Botón flotante de WhatsApp ---------- */
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:90;display:inline-flex;align-items:center;gap:11px;background:#25D366;color:#fff;text-decoration:none;font-family:var(--f-display);font-weight:600;font-size:16px;padding:13px 20px 13px 16px;border-radius:var(--r-pill);box-shadow:0 8px 24px rgba(0,0,0,.22);transition:transform .18s ease,box-shadow .18s ease}
.wa-fab:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.28)}
.wa-fab svg{width:26px;height:26px;flex:none}
.wa-fab__txt{white-space:nowrap}
@media (max-width:560px){
  .wa-fab{right:16px;bottom:16px;padding:14px}
  .wa-fab__txt{display:none}
  .wa-fab svg{width:28px;height:28px}
}
