:root{
  --bg-white:#ffffff; --bg-cream:#faf8f3; --bg-soft:#f5f3ee;
  --navy-deep:#0c2340; --navy:#1a3d7c;
  --gold:#c9a449; --gold-light:#e6c878; --gold-deep:#9c7d2e; --gold-bg:#fdf8e7;
  --ink:#0c2340; --ink-soft:#2c3e5a; --ink-mute:#5a6577; --ink-faint:#94a0b3;
  --line:rgba(12,35,64,0.1); --line-strong:rgba(12,35,64,0.18);
  --radius-card:24px; --radius-pill:999px;
  --serif:'Cormorant Garamond',serif;
  --sans:'Inter',system-ui,sans-serif;
  --display:'Archivo Black','Inter',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html{background:var(--navy-deep)}
body{font-family:var(--sans);background:var(--navy-deep);color:var(--ink);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--gold);color:var(--navy-deep)}
.container{max-width:1320px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}

/* TOPBAR */
.topbar{position:sticky;top:0;left:0;right:0;z-index:100;background:rgba(12,35,64,.55);backdrop-filter:blur(8px);transition:background .4s ease}
.topbar.solid{background:var(--navy-deep);box-shadow:0 2px 14px rgba(12,35,64,.2)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:14px clamp(20px,4vw,56px);max-width:1320px;margin:0 auto;gap:24px}
.nav-logo-txt{color:#fff;font-family:var(--serif);font-size:24px;font-weight:600;letter-spacing:.02em}
.nav-logo-txt em{font-style:italic;color:var(--gold-light)}
.nav-logo img{height:54px;width:auto;display:block;transition:transform .25s ease}
.nav-logo:hover img{transform:translateY(-1px)}
.footer-logo img{height:58px;width:auto;display:block}
.nav-cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#c9a449,#a07a35);color:#fffaf0;font-weight:700;font-size:14px;padding:11px 24px;border-radius:999px;transition:transform .2s ease;box-shadow:0 8px 22px -8px rgba(160,122,53,.6)}
.nav-cta:hover{transform:translateY(-2px)}
.nav-menu{display:flex;align-items:center;gap:clamp(20px,3vw,40px);margin:0 auto}
.nav-menu a{position:relative;color:#fff;font-weight:600;font-size:15px;letter-spacing:.02em;padding:4px 0;transition:color .25s ease}
.nav-menu a::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--gold-light);transform:scaleX(0);transform-origin:center;transition:transform .3s ease}
.nav-menu a:hover{color:var(--gold-light)}
.nav-menu a:hover::after{transform:scaleX(1)}
/* Hamburguesa mobile */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;padding:0;background:none;border:none;cursor:pointer;z-index:120}
.nav-burger span{display:block;width:26px;height:2.5px;background:#fff;border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.nav-burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.nav-mobile{display:none;flex-direction:column;background:linear-gradient(135deg,rgba(0,56,102,.88),rgba(0,96,172,.88));backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.12);max-height:0;overflow:hidden;transition:max-height .35s ease}
.nav-mobile.open{max-height:360px}
.nav-mobile a{color:#fff;font-weight:600;font-size:16px;letter-spacing:.02em;padding:16px 36px;border-bottom:1px solid rgba(255,255,255,.08);transition:background .2s ease}
.nav-mobile a:hover,.nav-mobile a:active{background:rgba(255,255,255,.08);color:var(--gold-light)}
@media(max-width:680px){
  .nav-menu{display:none}
  .nav-burger{display:flex}
  .nav-mobile{display:flex}
  .nav-cta{padding:9px 16px;font-size:13px}
}

/* HERO — IMPACTO */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;text-align:center;padding:120px 16px 88px}
.hero-bg{position:absolute;inset:0;z-index:1;overflow:hidden}
.hero-bg .slide{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-bg .s1{background-image:url("images/hero-invierno-desktop.jpg");animation:heroFadeA 16s ease-in-out infinite}
.hero-bg .s2{background-image:url("images/hero-tennis-desktop.jpg");background-position:center 36%;animation:heroFadeB 16s ease-in-out infinite}
@keyframes heroFadeA{0%,40%{opacity:1}50%,90%{opacity:0}100%{opacity:1}}
@keyframes heroFadeB{0%,40%{opacity:0}50%,90%{opacity:1}100%{opacity:0}}
@media(max-width:768px){
  .hero-bg .s1{background-image:url("images/hero-invierno-mobile.jpg")}
  .hero-bg .s2{background-image:url("images/hero-atv-mobile.jpg");background-position:center 28%}
}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,35,64,.55) 0%,rgba(12,35,64,.34) 42%,rgba(12,35,64,.82) 100%)}
.hero-content{position:relative;z-index:3;max-width:1100px}
.hero-badge{display:inline-block;color:var(--gold-light);border:1px solid rgba(201,164,73,.5);background:rgba(12,35,64,.35);font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:700;padding:9px 22px;border-radius:999px;margin-bottom:28px;backdrop-filter:blur(4px)}
.hero-mega{font-family:var(--display);color:#fff;font-size:clamp(34px,9.2vw,116px);line-height:.92;letter-spacing:-.02em;text-transform:uppercase;white-space:nowrap;text-shadow:0 8px 50px rgba(0,0,0,.45)}
.hero-inv{font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(60px,16vw,196px);line-height:.9;margin-top:-.04em;background:linear-gradient(135deg,#f9e9b0 0%,#dcb95c 45%,#a07a35 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 6px 30px rgba(201,164,71,.4));animation:shimmer 4.5s ease-in-out infinite}
@keyframes shimmer{0%,100%{filter:drop-shadow(0 6px 28px rgba(201,164,71,.35))}50%{filter:drop-shadow(0 8px 46px rgba(201,164,71,.62))}}
.hero-place{margin-top:14px;font-family:var(--serif);font-style:italic;font-weight:500;color:#fff;font-size:clamp(20px,3.4vw,42px);letter-spacing:.01em;text-shadow:0 2px 18px rgba(0,0,0,.45)}
.hero-sub{color:rgba(255,255,255,.92);font-size:clamp(15px,1.5vw,19px);max-width:620px;margin:20px auto 36px;text-shadow:0 2px 14px rgba(0,0,0,.3)}
.hero-heads{display:grid}
.hhead{grid-area:1/1;align-self:end;opacity:0;transform:translateY(14px);transition:opacity .8s ease,transform .8s ease;pointer-events:none}
.hhead.in{opacity:1;transform:none;pointer-events:auto}
.hero-alt{font-family:var(--serif);font-weight:600;color:#fff;font-size:clamp(34px,6.4vw,76px);line-height:1.08;letter-spacing:-.01em;text-shadow:0 6px 30px rgba(0,0,0,.5)}
.hero-alt em{font-style:italic;color:var(--gold-light)}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#c9a449 0%,#a07a35 60%,#c9a449 100%);background-size:200% 100%;color:#fffaf0;font-weight:800;font-size:clamp(14px,1.4vw,16px);letter-spacing:.01em;padding:17px 38px;border-radius:999px;box-shadow:0 16px 44px -12px rgba(160,122,53,.65);transition:transform .3s ease,background-position .6s ease}
.btn-primary:hover{transform:translateY(-3px);background-position:100% 50%}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;color:#fff;border:1.5px solid rgba(255,255,255,.6);font-weight:600;font-size:clamp(14px,1.4vw,16px);padding:16px 34px;border-radius:999px;transition:background .2s ease}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.7);font-size:11px;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.hero-scroll span.bar{width:1px;height:36px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:sc 1.8s ease-in-out infinite}
@keyframes sc{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* SECTIONS */
.section{padding:clamp(64px,9vw,118px) 0}
.small-label{display:inline-block;color:var(--gold-deep);font-size:12px;letter-spacing:.3em;text-transform:uppercase;font-weight:700;margin-bottom:14px}
.sec-title{font-weight:800;font-size:clamp(30px,4.6vw,56px);line-height:1.06;letter-spacing:-.02em;color:var(--navy-deep)}
.sec-title em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold-deep)}
.title-block{text-align:center;max-width:840px;margin:0 auto 56px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* INTRO */
.intro{background:var(--bg-cream);text-align:center}
.intro p.lead{font-size:clamp(17px,1.6vw,21px);color:var(--ink-soft);max-width:760px;margin:0 auto 36px;line-height:1.7}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1020px;margin:48px auto 0}
.feat-cell{position:relative;overflow:hidden;background:linear-gradient(160deg,rgba(255,255,255,.92),rgba(236,242,251,.8));backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.65);box-shadow:0 12px 34px -20px rgba(12,35,64,.45),inset 0 1px 0 rgba(255,255,255,.7);border-radius:22px;padding:34px 22px 28px;text-align:center;opacity:0;transform:translateY(30px) scale(.95);filter:blur(8px);clip-path:inset(0 0 12% 0 round 22px);transition:opacity .85s cubic-bezier(.2,.85,.25,1),transform .85s cubic-bezier(.2,.85,.25,1),filter .85s ease,clip-path .85s cubic-bezier(.2,.85,.25,1),box-shadow .45s ease}
.feat-cell.in{opacity:1;transform:none;filter:blur(0);clip-path:inset(0 0 0 0 round 22px)}
.feat-cell::after{content:'';position:absolute;top:0;left:-130%;width:75%;height:100%;background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.6) 50%,transparent 68%);transform:skewX(-18deg);pointer-events:none}
.feat-cell.in::after{animation:sheen 1.15s ease .3s 1}
.feat-cell:hover::after{animation:sheen .9s ease 1}
@keyframes sheen{0%{left:-130%}100%{left:150%}}
.feat-cell:hover{transform:translateY(-8px);box-shadow:0 34px 60px -22px rgba(12,35,64,.5),inset 0 1px 0 rgba(255,255,255,.85)}
.feat-ic{position:relative;width:62px;height:62px;margin:0 auto 18px;border-radius:18px;background:linear-gradient(140deg,#1a3d7c 0%,#0c2340 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 24px -10px rgba(12,35,64,.6);transition:transform .5s cubic-bezier(.2,.85,.25,1),box-shadow .45s ease}
.feat-cell:hover .feat-ic{transform:translateY(-4px) scale(1.09);box-shadow:0 18px 34px -10px rgba(201,164,71,.65)}
.feat-ic svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.feat-cell span{display:block;font-weight:600;font-size:14.5px;color:var(--navy-deep);line-height:1.3}
@media(max-width:980px){.feat-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.feat-grid{grid-template-columns:1fr 1fr;gap:12px}.feat-cell{padding:22px 14px}}

/* ALOJAMIENTO — con galería por sector */
#alojamiento{background:#fff}
.aloj-list{display:flex;flex-direction:column;gap:clamp(20px,3vw,36px)}
.aloj-row{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(28px,4vw,56px);align-items:center;padding:clamp(40px,5vw,70px) clamp(20px,5vw,60px);background:#ede9df;border-radius:18px;margin:0 clamp(10px,3vw,40px)}
.aloj-row.rev .aloj-galwrap{order:2}
.aloj-galwrap{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}
.aloj-galwrap img{width:100%;aspect-ratio:4/3;height:auto;object-fit:cover;display:block;border-radius:14px;cursor:pointer;transition:transform .5s ease,filter .4s ease;filter:saturate(.95)}
.aloj-galwrap img:hover{transform:scale(1.02);filter:saturate(1.12);z-index:2}
.aloj-info .aloj-tag{display:inline-block;background:var(--gold-bg);color:var(--gold-deep);font-size:11.5px;letter-spacing:.06em;font-weight:700;padding:7px 16px;border-radius:999px;margin-bottom:16px}
.aloj-info h3{font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(30px,4vw,46px);color:var(--navy-deep);line-height:1.05;margin-bottom:14px}
.aloj-info p{color:var(--ink-mute);font-size:15.5px;line-height:1.7;margin-bottom:22px}
.aloj-amen{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px 18px;margin-bottom:26px}
.aloj-amen li{position:relative;padding-left:24px;font-size:14px;color:var(--ink-soft)}
.aloj-amen li::before{content:'';position:absolute;left:0;top:7px;width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(201,164,71,.16)}
.btn-gold-inline{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#c9a449,#a07a35);color:#fffaf0;font-weight:700;font-size:14px;padding:13px 30px;border-radius:999px;transition:transform .2s ease}
.btn-gold-inline:hover{transform:translateY(-2px)}

/* GALERIA GENERAL */
.galeria{background:var(--navy-deep)}
.galeria .small-label{color:var(--gold-light)}
.galeria .sec-title{color:#fff}
.galeria .sec-title em{color:var(--gold-light)}
.galeria .title-block p{color:rgba(255,255,255,.7);margin-top:14px}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:130px;gap:14px}
.gal-grid figure{position:relative;overflow:hidden;border-radius:16px;cursor:pointer;margin:0;grid-column:span 1;grid-row:span 1}
.gal-grid figure:nth-of-type(7n+1){grid-column:span 2;grid-row:span 2}
.gal-grid figure:nth-of-type(7n+3){grid-row:span 2}
.gal-grid figure:nth-of-type(7n+6){grid-column:span 2}
.gal-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.2,.8,.2,1),filter .5s ease;filter:saturate(.88)}
.gal-grid figure::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,35,64,0) 55%,rgba(8,20,38,.55) 100%);opacity:0;transition:opacity .4s ease;pointer-events:none}
.gal-grid figure:hover::after{opacity:1}
.gal-grid figure:hover img{transform:scale(1.08);filter:saturate(1.15)}
@media(max-width:920px){
  .gal-grid{grid-auto-rows:110px}
}
@media(max-width:600px){
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .gal-grid figure,
  .gal-grid figure:nth-of-type(7n+1),
  .gal-grid figure:nth-of-type(7n+3),
  .gal-grid figure:nth-of-type(7n+6){grid-column:span 1;grid-row:span 1}
  .gal-grid figure:nth-of-type(5n+1){grid-column:span 2}
}

/* AMENITIES — iconos SVG + efectos */
.amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.amen-cell{position:relative;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-card);padding:34px 28px;overflow:hidden;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.amen-cell::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 0%,rgba(201,164,71,.10),transparent 60%);opacity:0;transition:opacity .4s ease}
.amen-cell:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(12,35,64,.34);border-color:rgba(201,164,71,.5)}
.amen-cell:hover::before{opacity:1}
.amen-ic{width:60px;height:60px;border-radius:18px;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:transform .4s ease,background .4s ease}
.amen-cell:hover .amen-ic{transform:rotate(-6deg) scale(1.08);background:linear-gradient(135deg,#fdf3d4,#f3e2a8)}
.amen-ic svg{width:30px;height:30px;stroke:var(--gold-deep);fill:none;stroke-width:1.7}
.amen-cell h3{font-size:19px;font-weight:700;color:var(--navy-deep);margin-bottom:8px;position:relative}
.amen-cell p{color:var(--ink-mute);font-size:14.5px;line-height:1.6;position:relative}

/* CTA / FORM */
.cta{background:var(--bg-cream)}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.cta-left p{color:var(--ink-soft);font-size:17px;line-height:1.7;margin:18px 0 28px}
.cta-datos{display:flex;flex-direction:column;gap:16px}
.cta-dato{display:flex;gap:14px;align-items:flex-start}
.cta-dato .ic{font-size:20px}
.cta-dato .lbl{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;margin-bottom:2px}
.cta-dato .val{color:var(--ink-soft);font-size:15px}
.cta-dato .val a{color:var(--gold-deep);font-weight:600}
.form-wrap{background:#fff;border:1.5px solid var(--line);border-top:3px solid var(--gold);border-radius:var(--radius-card);padding:clamp(28px,4vw,44px);box-shadow:0 28px 60px -32px rgba(12,35,64,.3)}
.form-wrap h3{font-weight:800;font-size:clamp(24px,3vw,32px);color:var(--navy-deep);line-height:1.1;margin-bottom:4px}
.form-wrap h3 em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold-deep)}
.form-sub{color:var(--ink-mute);font-size:14px;margin-bottom:24px}
.form-row{margin-bottom:16px}
.form-row.split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:12px 14px;border:1px solid var(--line-strong);border-radius:10px;font-family:inherit;font-size:15px;background:#fff;color:var(--ink)}
.form-row textarea{min-height:90px;resize:vertical}
.form-submit{width:100%;background:linear-gradient(135deg,#c9a449 0%,#a07a35 60%,#c9a449 100%);background-size:200% 100%;color:#fffaf0;font-weight:800;font-size:17px;letter-spacing:.02em;padding:17px;border-radius:999px;margin-top:8px;transition:transform .2s ease,background-position .6s ease}
.form-submit:hover{transform:translateY(-2px);background-position:100% 50%}
.form-disc{text-align:center;font-size:12px;color:var(--ink-faint);margin-top:14px}

/* FOOTER */
footer{background:var(--navy-deep);color:#fff;padding:48px 0 32px;border-top:4px solid var(--gold)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
.footer-logo{font-family:var(--serif);font-size:24px;font-weight:600}
.footer-logo em{font-style:italic;color:var(--gold-light)}
.footer-nav{display:flex;gap:26px;font-size:13px;color:rgba(255,255,255,.6)}
.footer-nav a:hover{color:var(--gold-light)}
.footer-contact{width:100%;display:flex;justify-content:center;gap:clamp(24px,5vw,56px);flex-wrap:wrap;margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12)}
.footer-contact .fc{display:flex;flex-direction:column;gap:4px;text-align:center}
.footer-contact .fc-lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);font-weight:700}
.footer-contact .fc-val{color:rgba(255,255,255,.85);font-size:14.5px;text-decoration:none}
.footer-contact a.fc-val:hover{color:var(--gold-light)}
.footer-meta{width:100%;text-align:center;margin-top:22px;font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.04em}
.footer-dev{width:100%;display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:22px}
.footer-dev span{font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.06em}
.footer-dev img{height:34px;width:auto;display:block;opacity:.7;transition:opacity .25s ease}
.footer-dev a:hover img{opacity:1}

/* WHATSAPP */
.wa{position:fixed;right:22px;bottom:22px;width:62px;height:62px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(0,0,0,.25);z-index:9999;animation:wap 2.5s ease-out infinite}
.wa svg{width:32px;height:32px;fill:#fff}
@keyframes wap{0%{box-shadow:0 6px 22px rgba(0,0,0,.25),0 0 0 0 rgba(37,211,102,.55)}70%{box-shadow:0 6px 22px rgba(0,0,0,.25),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 6px 22px rgba(0,0,0,.25),0 0 0 0 rgba(37,211,102,0)}}

/* LIGHTBOX */
.lb{position:fixed;inset:0;background:rgba(8,20,38,.94);z-index:10000;display:none;align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lb__btn{position:absolute;background:rgba(255,255,255,.12);color:#fff;width:50px;height:50px;border-radius:50%;font-size:26px;display:flex;align-items:center;justify-content:center;transition:background .2s ease}
.lb__btn:hover{background:rgba(255,255,255,.25)}
.lb__close{top:24px;right:24px}
.lb__prev{left:18px;top:50%;transform:translateY(-50%)}
.lb__next{right:18px;top:50%;transform:translateY(-50%)}

/* RESPONSIVE */
@media(max-width:920px){
  .aloj-row,.aloj-row.rev .aloj-galwrap{grid-template-columns:1fr;order:0}
  .aloj-row .aloj-info{order:1}
  .aloj-row .aloj-galwrap{order:2}
  .aloj-row.rev .aloj-info{order:1}
  .aloj-row.rev .aloj-galwrap{order:2}
  .amen-grid{grid-template-columns:1fr 1fr}
  .cta-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .amen-grid{grid-template-columns:1fr}
  .aloj-amen{grid-template-columns:1fr}
  .form-row.split{grid-template-columns:1fr}
}
/* APP BAND */
.app-band{background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 62%,#0a2c5e 100%);position:relative;overflow:hidden}
.app-band::after{content:'';position:absolute;width:520px;height:520px;right:-120px;top:-160px;background:radial-gradient(circle,rgba(201,164,71,.18),transparent 65%);pointer-events:none}
.app-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,64px);align-items:center;position:relative;z-index:2}
.app-copy .small-label{color:var(--gold-light)}
.app-copy h2{color:#fff}
.app-copy h2 em{color:var(--gold-light)}
.app-copy p{color:rgba(255,255,255,.82);font-size:clamp(15px,1.6vw,18px);line-height:1.7;margin:16px 0 22px;max-width:520px}
.app-feats{display:flex;flex-wrap:wrap;gap:10px 12px;margin-bottom:30px}
.app-feats span{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.92);font-size:13.5px;font-weight:600;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);padding:8px 14px;border-radius:999px}
.app-feats svg{width:17px;height:17px;stroke:var(--gold-light);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.app-visual{display:flex;justify-content:center;align-items:center}
.app-screenshot{max-width:320px;width:100%;border-radius:18px;box-shadow:0 44px 84px -30px rgba(0,0,0,.7);display:block}
@media(max-width:760px){.app-grid{grid-template-columns:1fr;text-align:center}.app-copy p{margin-left:auto;margin-right:auto}.app-feats{justify-content:center}.app-visual{margin-top:6px}}

:root{
  /* Paleta oficial Solanas Punta del Este · sampleada del logo */
  --brand-blue:#0060ac;        /* azul cobalto del logo */
  --brand-blue-deep:#004a85;   /* sombra del azul */
  --brand-blue-darker:#003866; /* fondo dramático */
  --brand-cyan:#08bfde;        /* cyan de "Punta del Este" */
  --brand-cyan-soft:#a9e8f3;
  --brand-gold:#c9a449; --brand-gold-light:#e6c878; --brand-gold-deep:#9c7d2e;
  --display-2:'Playfair Display',serif;
}
body{padding-top:0}

/* PROMO STRIP TOP */
.promo-strip{position:relative;z-index:200;background:linear-gradient(90deg,#003866,#0060ac 35%,#08bfde 65%,#0060ac 85%,#003866);background-size:200% 100%;color:#fff;padding:10px 12px;text-align:center;font-size:13.5px;font-weight:600;box-shadow:0 4px 14px rgba(0,96,172,.4);animation:psFlow 8s linear infinite;border-bottom:1.5px solid rgba(8,191,222,.5)}
@keyframes psFlow{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.promo-strip-inner{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;max-width:1200px;margin:0 auto}
.ps-mark{display:inline-flex;align-items:center;justify-content:center;width:8px;height:8px;background:#08bfde;border-radius:50%;box-shadow:0 0 0 4px rgba(8,191,222,.3);animation:psBeat 1.6s ease-in-out infinite}
@keyframes psBeat{0%,100%{box-shadow:0 0 0 4px rgba(8,191,222,.3)}50%{box-shadow:0 0 0 9px rgba(8,191,222,.05)}}
.ps-main{color:#fff;letter-spacing:.02em}
.ps-main b{color:#a9e8f3;font-weight:800;letter-spacing:.05em}
.ps-count{background:rgba(0,0,0,.4);color:#a9e8f3;padding:5px 14px;border-radius:6px;font-family:'SF Mono',Menlo,monospace;font-size:12.5px;font-weight:700;letter-spacing:.05em;border:1px solid rgba(8,191,222,.35)}
.topbar{background:rgba(0,56,102,.65) !important;backdrop-filter:blur(10px)}
.topbar.solid{background:linear-gradient(135deg,#003866,#0060ac) !important}
@media(max-width:600px){
  .promo-strip{font-size:11.5px;padding:8px 10px;gap:8px}
  .ps-count{font-size:11px;padding:3px 8px}
}

/* HERO REDISEÑADO · impactante */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;padding:80px 16px 100px;background:#000}
.hero-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden}
.hero-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:1;opacity:.85;-webkit-transform:translateZ(0);transform:translateZ(0)}
.hero-poster{display:none}
.desktop-only{display:block}
.mobile-only{display:none}
@media(max-width:768px){.desktop-only{display:none}.mobile-only{display:block}}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,56,102,.35) 0%,rgba(0,96,172,.2) 35%,rgba(0,30,60,.7) 100%);z-index:2}


.hero-content{position:relative;z-index:3;max-width:1280px;width:100%}

/* Eslogan principal · tipografía mixta */
.hero-mega-v2{display:block;font-family:'Archivo Black','Inter',sans-serif;color:#fff;font-size:clamp(42px,9vw,140px);line-height:.88;letter-spacing:-.035em;text-transform:uppercase;text-shadow:0 12px 60px rgba(0,0,0,.85)}
.hero-mega-v2 .accent{display:inline-block;color:#f5d060;text-shadow:0 4px 18px rgba(240,200,60,.5)}
@keyframes goldShine{0%{background-position:0% center}100%{background-position:200% center}}
@keyframes flameShimmer{0%,100%{filter:drop-shadow(0 6px 24px rgba(8,191,222,.45))}50%{filter:drop-shadow(0 12px 60px rgba(8,191,222,.9))}}

.hero-script{display:block;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;color:#a9e8f3;font-size:clamp(36px,7vw,98px);line-height:1.0;letter-spacing:-.005em;margin-top:8px;text-shadow:0 6px 32px rgba(0,0,0,.75)}

.hero-pesos{display:inline-block;margin-top:18px;padding:10px 24px;background:rgba(0,56,102,.55);border:1.5px solid rgba(8,191,222,.55);backdrop-filter:blur(8px);border-radius:999px;color:#a9e8f3;font-family:'Inter',sans-serif;font-weight:700;font-size:clamp(12px,1.4vw,15px);letter-spacing:.22em;text-transform:uppercase}

/* COUNTDOWN gigante INTEGRADO en el hero */
.hero-countdown{margin:36px auto 28px;display:flex;justify-content:center;gap:clamp(8px,2vw,18px);max-width:640px}
.cd-cell{flex:1;max-width:130px;background:linear-gradient(160deg,rgba(0,30,60,.7),rgba(0,96,172,.4));border:1.5px solid rgba(8,191,222,.5);backdrop-filter:blur(12px);border-radius:18px;padding:18px 12px;position:relative;overflow:hidden;box-shadow:0 12px 40px rgba(0,96,172,.4)}
.cd-cell::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#08bfde,transparent);animation:cdShine 2.5s ease-in-out infinite}
@keyframes cdShine{0%,100%{opacity:.3}50%{opacity:1}}
.cd-num{font-family:'Archivo Black','Inter',sans-serif;color:#a9e8f3;font-size:clamp(42px,7.5vw,82px);line-height:1;letter-spacing:-.025em;text-shadow:0 4px 24px rgba(8,191,222,.7);font-variant-numeric:tabular-nums}
.cd-lbl{color:rgba(255,255,255,.75);font-size:clamp(10px,1.1vw,12px);font-weight:600;text-transform:uppercase;letter-spacing:.18em;margin-top:8px}
@media(max-width:600px){
  .cd-cell{padding:12px 6px;border-radius:14px}
}

.hero-deadline{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;color:#fff;font-size:clamp(15px,1.8vw,21px);margin-top:-4px;margin-bottom:30px;opacity:.95}
.hero-deadline b{font-weight:700;color:#a9e8f3;font-style:normal;font-family:'Inter',sans-serif;letter-spacing:.04em}

.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#08bfde 0%,#0060ac 60%,#08bfde 100%);background-size:200% 100%;color:#fff;font-weight:800;font-size:clamp(15px,1.5vw,17px);letter-spacing:.04em;padding:18px 38px;border-radius:999px;box-shadow:0 16px 44px -10px rgba(0,96,172,.7);transition:transform .3s ease,background-position .6s ease,box-shadow .3s ease;text-transform:uppercase}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);background-position:100% 50%;box-shadow:0 22px 60px -10px rgba(8,191,222,.85)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;color:#fff;border:1.5px solid rgba(169,232,243,.7);background:rgba(0,56,102,.45);font-weight:700;font-size:clamp(14px,1.4vw,16px);padding:17px 30px;border-radius:999px;transition:background .3s ease,border-color .3s ease;backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(0,56,102,.75);border-color:#08bfde}

.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.7);font-size:11px;letter-spacing:.3em;text-transform:uppercase}

/* SECCIÓN BENEFICIOS EXCLUSIVOS · paleta Solanas */
.beneficios{background:linear-gradient(180deg,#f0f8fc 0%,#dff0f8 100%);padding:clamp(70px,9vw,120px) 0;position:relative;overflow:hidden}
.beneficios::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(8,191,222,.18),transparent 70%);top:-200px;right:-150px;filter:blur(60px);z-index:1}
.beneficios .container{position:relative;z-index:2}
.ben-title-pre{display:inline-block;background:linear-gradient(135deg,#003866,#0060ac);color:#a9e8f3;font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:800;padding:8px 22px;border-radius:999px;margin-bottom:18px;box-shadow:0 8px 22px -8px rgba(0,96,172,.5);border:1px solid rgba(8,191,222,.4)}
.ben-title{font-family:'Archivo Black',sans-serif;font-size:clamp(34px,5.4vw,68px);line-height:1.02;letter-spacing:-.025em;color:#0060ac;text-transform:uppercase;text-align:center;max-width:980px;margin:0 auto 14px}
.ben-title em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;color:#08bfde;text-transform:none}
.ben-sub{text-align:center;color:#2c3e5a;font-size:clamp(16px,1.6vw,19px);max-width:680px;margin:0 auto 60px;line-height:1.6}
.ben-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ben-card{position:relative;background:#fff;border-radius:24px;padding:36px 28px;box-shadow:0 20px 50px -22px rgba(0,96,172,.25);border:1.5px solid rgba(0,96,172,.08);transition:transform .4s cubic-bezier(.2,.85,.25,1),box-shadow .4s ease,border-color .3s ease;overflow:hidden}
.ben-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#0060ac,#08bfde);border-radius:24px 24px 0 0}
.ben-card:hover{transform:translateY(-10px);box-shadow:0 36px 80px -28px rgba(0,96,172,.4);border-color:rgba(8,191,222,.4)}
.ben-ic{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#0060ac,#08bfde);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:transform .5s cubic-bezier(.2,.85,.25,1),background .4s ease;box-shadow:0 12px 28px -10px rgba(0,96,172,.55)}
.ben-ic svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ben-card:hover .ben-ic{transform:translateY(-4px) scale(1.08);background:linear-gradient(135deg,#08bfde,#0060ac)}
.ben-card h3{font-family:'Archivo Black',sans-serif;font-size:22px;color:#0060ac;line-height:1.15;margin-bottom:10px;text-transform:uppercase;letter-spacing:-.01em}
.ben-card h3 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;color:#08bfde;text-transform:none;letter-spacing:0}
.ben-card p{color:#2c3e5a;font-size:15px;line-height:1.65}
@media(max-width:920px){.ben-grid{grid-template-columns:1fr;gap:18px}}

/* CRYSTAL BEACH */
.crystal-beach{padding:0;position:relative;overflow:hidden;background:#001428}
.cb-slider{position:relative;height:clamp(520px,80vh,900px);overflow:hidden}
.cb-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease;transform:scale(1.04);transition:opacity 1.2s ease,transform 7s ease}
.cb-slide.active{opacity:1;transform:scale(1)}
.cb-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,20,40,.15) 0%,rgba(0,10,30,.3) 45%,rgba(0,10,30,.82) 72%,#001428 100%);z-index:2}
.cb-dots{position:absolute;top:20px;right:20px;display:flex;gap:10px;z-index:10}
.cb-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.6);background:transparent;cursor:pointer;transition:background .3s ease,border-color .3s ease,transform .3s ease}
.cb-dot.active{background:#08bfde;border-color:#08bfde;transform:scale(1.25)}

.cb-content{position:relative;z-index:3;margin-top:-260px;padding-bottom:clamp(64px,9vw,110px)}
.cb-text{max-width:860px}
.cb-pre{display:inline-block;background:linear-gradient(135deg,#003866,#0060ac);color:#a9e8f3;font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:800;padding:8px 22px;border-radius:999px;margin-bottom:22px;border:1px solid rgba(8,191,222,.4);box-shadow:0 8px 22px -8px rgba(0,96,172,.5)}
.cb-title{font-family:'Archivo Black',sans-serif;font-size:clamp(28px,4vw,54px);line-height:1;letter-spacing:-.025em;color:#fff;text-transform:uppercase;text-shadow:0 8px 40px rgba(0,0,0,.6);margin-bottom:28px}
.cb-title em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;color:#08bfde;text-transform:none;letter-spacing:0;font-size:1em}
.cb-body{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.cb-body p{color:rgba(255,255,255,.88);font-size:clamp(15px,1.5vw,18px);line-height:1.72;max-width:780px}
.cb-amenities{display:grid;grid-template-columns:repeat(3,auto);justify-content:start;gap:10px 12px;margin-bottom:36px}
.cb-amenities span{display:inline-flex;align-items:center;gap:8px;color:#fff;font-size:13.5px;font-weight:600;background:rgba(8,191,222,.12);border:1px solid rgba(8,191,222,.35);padding:9px 16px;border-radius:999px;backdrop-filter:blur(6px)}
.cb-amenities svg{width:16px;height:16px;stroke:#08bfde;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.cb-btn{background:linear-gradient(135deg,#08bfde 0%,#0060ac 60%,#08bfde 100%) !important}
@media(max-width:768px){
  .cb-slider{height:clamp(380px,65vw,560px)}
  .cb-content{margin-top:-100px}
  .cb-amenities span{font-size:12.5px;padding:7px 12px}
}

/* MOBILE STICKY */
.mobile-sticky{display:none;position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#08bfde,#0060ac);color:#fff;padding:14px 16px;text-align:center;font-weight:800;font-size:14.5px;box-shadow:0 -6px 22px rgba(0,0,0,.3);z-index:150;text-decoration:none;letter-spacing:.04em;text-transform:uppercase;border-top:1.5px solid rgba(255,255,255,.2)}
@media(max-width:768px){
  .mobile-sticky{display:block}
  .wa{bottom:78px !important}
  body{padding-bottom:60px}
}

/* PROMO BADGE en formulario */
.form-promo{background:linear-gradient(90deg,#f0f8fc,#dff0f8);border:2px dashed #0060ac;padding:14px 18px;border-radius:14px;margin-bottom:20px;text-align:center;font-weight:800;color:#0060ac;font-size:14px;text-transform:uppercase;letter-spacing:.04em}
.form-promo b{color:#08bfde}
