:root{
  --navy:#1A2E3B; --navy-deep:#142430;
  --aqua:#2E9CB7; --aqua-light:#5BBFD4; --teal:#1A7A96; --ice:#CFE1E6;
  --cream:#FAF7F3; --sand:#F5F0E8; --sand2:#EDE4D4; --coral:#D4845A;
  --fg:#21333f; --fg-soft:#5d6f78;
  --line:rgba(26,46,59,.12);
  --shadow:0 24px 60px -28px rgba(20,36,48,.45);
  --maxw:1240px; --pad:clamp(1.4rem,5vw,5rem); --promoH:38px;
  --ease:cubic-bezier(.22,.7,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:'Raleway',system-ui,sans-serif;color:var(--fg);background:var(--cream);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:clip}
h1,h2,h3,h4,.serif{font-family:'Playfair Display',Georgia,serif;font-weight:500;line-height:1.1;color:var(--navy)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--aqua-light);color:var(--navy)}
:focus-visible{outline:2.5px solid var(--teal);outline-offset:3px}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.kicker{font-family:'Raleway';font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--teal);font-weight:600}
.section{padding-block:clamp(4.5rem,10vw,9rem)}
.ornament{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:1.4rem}
.ornament span{height:1px;width:60px;background:currentColor;opacity:.5}
.ornament i{width:9px;height:9px;background:currentColor;transform:rotate(45deg);display:block}

/* botones */
.btn{display:inline-flex;align-items:center;gap:.6rem;justify-content:center;font-family:'Raleway';font-weight:600;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;padding:1.05rem 2rem;border:1.5px solid transparent;cursor:pointer;min-height:50px;transition:transform .18s var(--ease),background .25s,color .25s,border-color .25s,box-shadow .25s}
.btn-primary{background:var(--aqua);color:#fff;box-shadow:0 14px 30px -14px rgba(46,156,183,.8)}
.btn-primary:hover{background:var(--teal)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-outline:hover{background:#fff;color:var(--navy)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--teal)}
.btn:active{transform:scale(.97)}
.link-arrow{font-family:'Raleway';font-weight:600;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:.7rem}
.link-arrow::after{content:"";width:34px;height:1.5px;background:var(--teal);transition:width .3s var(--ease)}
.link-arrow:hover::after{width:54px}

/* reveal */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none}}

/* ---- promo bar ---- */
.promo{position:fixed;top:0;left:0;right:0;z-index:101;min-height:var(--promoH);background:var(--navy);color:#fff;text-align:center;font-size:.8rem;letter-spacing:.08em;padding:.5rem 1rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem}
.promo b{color:var(--aqua-light);font-weight:700}

/* ---- NAV ---- */
.nav{position:fixed;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem var(--pad);transition:background .35s,box-shadow .35s,padding .35s;top:var(--promoH)}
.nav.solid{background:rgba(250,247,243,.92);backdrop-filter:saturate(160%) blur(14px);box-shadow:0 1px 0 var(--line);padding-block:.7rem}
.brand{display:flex;align-items:center}
.brand img{height:46px;width:auto;display:block}
.brand .logo-b{display:none}
.nav.solid .brand .logo-w{display:none}.nav.solid .brand .logo-b{display:block}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;color:#fff;position:relative;padding:.3rem 0}
.nav.solid .nav-links a{color:var(--fg)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1.5px;background:var(--aqua);transition:width .25s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1.1rem}
.lang{font-size:.74rem;letter-spacing:.1em;color:#fff;border:1px solid rgba(255,255,255,.5);padding:.35rem .6rem;font-weight:600}
.nav.solid .lang{color:var(--navy);border-color:var(--line)}
#nt{display:none}.burger{display:none;width:46px;height:46px;align-items:center;justify-content:center;cursor:pointer}
.burger span{display:block;width:24px;height:2px;background:#fff;position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:24px;height:2px;background:#fff}
.burger span::before{top:-7px}.burger span::after{top:7px}
.nav.solid .burger span,.nav.solid .burger span::before,.nav.solid .burger span::after{background:var(--navy)}
@media(max-width:980px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);flex-direction:column;justify-content:center;gap:1.6rem;background:var(--navy);padding:2rem;transform:translateX(110%);transition:transform .4s var(--ease)}
  .nav-links a{color:#fff;font-size:1rem}
  #nt:checked~.nav-links{transform:translateX(0)}
  .burger{display:flex}
  .nav .btn-nav{display:none}
}

/* ---- HERO (home) ---- */
.hero{position:relative;min-height:100svh;min-height:100dvh;display:grid;align-items:center;text-align:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.04)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,36,48,.55),rgba(20,36,48,.30) 40%,rgba(20,36,48,.75))}
.hero-inner{position:relative;z-index:2;width:100%;padding-inline:var(--pad);padding-top:90px}
.hero .ornament{color:var(--aqua-light)}
.hero h1{color:#fff;font-size:clamp(2.8rem,8vw,6.2rem);font-weight:500;letter-spacing:.16em;text-indent:.16em}
.hero .sub{font-family:'Raleway';letter-spacing:.42em;text-transform:uppercase;font-size:clamp(.8rem,2vw,1.1rem);color:var(--ice);margin-top:.8rem}
.hero p.tag{max-width:40rem;margin:1.6rem auto 0;font-size:clamp(1.02rem,2vw,1.25rem);color:rgba(255,255,255,.92);font-weight:300}
.hero-actions{margin-top:2.3rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.scroll-cue{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.8);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-cue::after{content:"";width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.85),transparent);animation:cue 1.9s var(--ease) infinite}
@keyframes cue{0%{opacity:0;transform:scaleY(.3)}50%{opacity:1}100%{opacity:0;transform:translateY(12px) scaleY(.5)}}
@media(prefers-reduced-motion:reduce){.scroll-cue::after{animation:none}}

/* ---- PAGE HERO (interiores) ---- */
.page-hero{position:relative;min-height:54vh;display:grid;align-items:center;text-align:center;color:#fff;overflow:hidden;padding-top:calc(var(--promoH) + 86px)}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,36,48,.5),rgba(20,36,48,.72))}
.page-hero .ornament{color:var(--aqua-light)}
.page-hero h1{color:#fff;font-size:clamp(2.4rem,6vw,4.2rem);letter-spacing:.08em}
.page-hero .crumb{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:1rem}
.page-hero .crumb a{color:var(--aqua-light)}

/* ---- trust bar ---- */
.trust{background:var(--navy-deep);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding-block:1.1rem;text-align:center}
.trust div{font-size:.82rem;letter-spacing:.04em;color:rgba(255,255,255,.9)}
.trust b{color:var(--aqua-light)}
@media(max-width:680px){.trust .wrap{grid-template-columns:1fr;gap:.6rem;font-size:.8rem}}

/* ---- split ---- */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,6vw,5.5rem)}
.split.rev .txt{order:2}
.split .media{position:relative}
.split .media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;box-shadow:var(--shadow)}
.split .media .frame{position:absolute;inset:18px -18px -18px 18px;border:1px solid var(--aqua);z-index:-1}
.split h2{font-size:clamp(2.1rem,5vw,3.6rem);margin-top:.7rem}
.split p{color:var(--fg-soft);margin:1.2rem 0;font-size:1.06rem}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:2.2rem}.split.rev .txt{order:0}.split .media{order:-1}.split .media img{aspect-ratio:16/10}.split .media .frame{inset:12px -12px -12px 12px}}

/* ---- stats ---- */
.stats{background:var(--sand)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat b{font-family:'Playfair Display';font-size:clamp(2.2rem,4vw,3rem);color:var(--teal);display:block;line-height:1}
.stat span{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-soft);margin-top:.4rem;display:block}
@media(max-width:680px){.stats .wrap{grid-template-columns:1fr 1fr;gap:2rem 1rem}}

/* ---- head center ---- */
.head-center{text-align:center;max-width:46rem;margin:0 auto clamp(2.4rem,5vw,3.6rem)}
.head-center h2{font-size:clamp(2.1rem,5vw,3.4rem);margin-top:.7rem}
.head-center p{color:var(--fg-soft);margin-top:1rem}

/* ---- experiencias (cards home) ---- */
.exp{background:var(--cream)}
.exp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
@media(max-width:760px){.exp-grid{grid-template-columns:1fr}}
.xcard{position:relative;min-height:440px;display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;color:#fff;overflow:hidden;isolation:isolate}
.xcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .9s var(--ease)}
.xcard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,36,48,.05),rgba(20,36,48,.35) 45%,rgba(20,36,48,.9))}
.xcard:hover img{transform:scale(1.06)}
.xcard .px{position:absolute;top:1.3rem;right:1.3rem;background:rgba(255,255,255,.95);color:var(--navy);font-weight:700;font-size:.82rem;padding:.45rem .8rem;letter-spacing:.02em}
.xcard .kx{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--aqua-light);font-weight:600}
.xcard h3{color:#fff;font-size:1.9rem;margin:.5rem 0 .6rem}
.xcard p{color:rgba(255,255,255,.88);font-size:.96rem;max-width:34ch}
.xcard .row{margin-top:1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.xcard .meta{font-size:.78rem;letter-spacing:.06em;color:rgba(255,255,255,.85)}
.xcard .link-arrow{color:#fff}.xcard .link-arrow::after{background:#fff}

/* ---- experiencia detalle (rows) ---- */
.exp-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.exp-row + .exp-row{margin-top:clamp(3.5rem,7vw,6rem)}
.exp-row.rev .exp-txt{order:2}
.exp-row .exp-media{position:relative}
.exp-row .exp-media img{width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow)}
.exp-row .exp-media .frame{position:absolute;inset:16px -16px -16px 16px;border:1px solid var(--aqua);z-index:-1}
.exp-row .price-tag{display:inline-block;background:var(--aqua);color:#fff;font-weight:700;padding:.4rem .9rem;font-size:.9rem;margin-bottom:1rem;letter-spacing:.03em}
.exp-row h2{font-size:clamp(1.9rem,4vw,2.8rem)}
.exp-row .ksm{margin-bottom:.5rem}
.exp-row p{color:var(--fg-soft);margin:1rem 0}
.exp-row .incl{list-style:none;display:grid;gap:.55rem;margin:1.3rem 0}
.exp-row .incl li{padding-left:1.7rem;position:relative;color:var(--fg)}
.exp-row .incl li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}
@media(max-width:820px){.exp-row{grid-template-columns:1fr;gap:1.8rem}.exp-row.rev .exp-txt{order:0}.exp-row .exp-media{order:-1}.exp-row .exp-media .frame{inset:10px -10px -10px 10px}}

/* ---- reserva / widget ---- */
.reserve{background:var(--navy);color:#fff;text-align:center}
.reserve h2{color:#fff;font-size:clamp(2rem,5vw,3.2rem)}
.reserve p{color:rgba(255,255,255,.75);max-width:42rem;margin:1rem auto 0}
.widget-slot{margin-top:2.5rem;border:2px dashed rgba(91,191,212,.5);min-height:300px;display:grid;place-items:center;padding:2.5rem 1.5rem;background:rgba(255,255,255,.04)}
.widget-slot .tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--aqua-light);font-weight:700}
.widget-slot h3{color:#fff;margin:.7rem 0;font-size:1.5rem}
.widget-slot code{display:block;margin-top:1.2rem;font-family:ui-monospace,Menlo,monospace;font-size:.72rem;color:var(--ice);background:rgba(0,0,0,.3);padding:.9rem 1rem;text-align:left;overflow-x:auto;border:1px solid rgba(255,255,255,.1)}

/* ---- galería ---- */
.gallery{background:var(--sand)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.gal-grid a{overflow:hidden;aspect-ratio:1}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal-grid a:hover img{transform:scale(1.08)}
@media(max-width:760px){.gal-grid{grid-template-columns:repeat(2,1fr)}}
.gal-full{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.gal-full a{overflow:hidden;aspect-ratio:1}
.gal-full img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal-full a:hover img{transform:scale(1.08)}
@media(max-width:760px){.gal-full{grid-template-columns:repeat(2,1fr)}}

/* ---- testimonios ---- */
.testi{position:relative;color:#fff;text-align:center;background:linear-gradient(rgba(20,36,48,.78),rgba(20,36,48,.78)),url('https://www.bajatherapycabo.com/assets/images/testimonial/testimonial-1.jpg') center/cover fixed}
.testi h2{color:#fff;font-size:clamp(2rem,5vw,3.2rem)}
.testi-grid{margin-top:2.6rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote{background:rgba(255,255,255,.07);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.18);padding:2rem}
.quote .stars{color:var(--coral);letter-spacing:3px}
.quote p{font-family:'Playfair Display';font-style:italic;font-size:1.12rem;color:#fff;margin:.9rem 0 1.1rem;line-height:1.5}
.quote .who{font-size:.82rem;letter-spacing:.08em;color:var(--ice);font-weight:600}
@media(max-width:820px){.testi{background-attachment:scroll}.testi-grid{grid-template-columns:1fr;gap:1rem}}

/* ---- cta final ---- */
.cta{position:relative;color:#fff;text-align:center;background:linear-gradient(rgba(20,36,48,.6),rgba(20,36,48,.78)),url('https://www.bajatherapycabo.com/assets/images/bg/cta-bg.jpg') center/cover}
.cta h2{color:#fff;font-size:clamp(2.3rem,6vw,4rem);max-width:18ch;margin-inline:auto}
.cta p{color:rgba(255,255,255,.9);margin:1.1rem auto 2rem;max-width:36rem}

/* ---- contacto ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-info ul{list-style:none;display:grid;gap:1.3rem;margin-top:1.5rem}
.contact-info li{display:flex;gap:.9rem;align-items:flex-start}
.contact-info .ic{color:var(--teal);font-weight:700;min-width:1.4rem;font-size:1.1rem}
.contact-info b{color:var(--navy)}
.contact-info span{color:var(--fg-soft);display:block;font-size:.95rem}
.form{display:grid;gap:1rem;background:#fff;padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow);border:1px solid var(--line)}
.form label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-soft);font-weight:600;margin-bottom:.35rem;display:block}
.form input,.form textarea,.form select{width:100%;padding:.9rem 1rem;border:1px solid var(--line);font-family:inherit;font-size:1rem;background:var(--cream);color:var(--fg)}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.map{border:0;width:100%;height:360px;filter:grayscale(.15)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}.form .two{grid-template-columns:1fr}}

/* ---- footer ---- */
footer{background:var(--navy-deep);color:rgba(255,255,255,.75);font-size:.92rem}
footer .wrap{padding-block:4rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem}
footer h4{color:#fff;font-family:'Raleway';font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:1.1rem;font-weight:600}
footer ul{list-style:none;display:grid;gap:.7rem}
footer a:hover{color:var(--aqua-light)}
.f-brand img{height:52px;width:auto;margin-bottom:1rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding:1.5rem var(--pad);text-align:center;font-size:.78rem;color:rgba(255,255,255,.5)}
@media(max-width:820px){footer .wrap{grid-template-columns:1fr 1fr}.f-brand{grid-column:1/-1}}

/* floating */
.wa{position:fixed;right:1.1rem;bottom:1.1rem;z-index:90;width:56px;height:56px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(0,0,0,.45)}
.wa svg{width:30px;height:30px;fill:#fff}
.book-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:90;background:var(--coral);color:#fff;writing-mode:vertical-rl;padding:1rem .5rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;border-radius:8px 0 0 8px}
