@charset "UTF-8";

/* ========== Variables ========== */
:root{
  --color-primario:#DECE9A;
  --color-secundario:#0A3033;
  --color-gris-texto:#3C4043;
  --color-neutro:#575756;
  --brand-strip-width:220px;
}

/* ========== Base tipográfica ========== */
html{font-size:16px;}
@media (min-width:1200px){html{font-size:17px;}}
body{font-family:'Ubuntu',sans-serif;color:var(--color-gris-texto);background:#fff;line-height:1.55;-webkit-text-size-adjust:100%;}
p,.lead,.section-intro{max-width:70ch;}
h1,h2{font-family:'Cormorant Garamond',serif;font-weight:700;color:var(--color-secundario);}
h3,h4,h5{font-family:'Ubuntu',sans-serif;font-weight:700;color:var(--color-secundario);}
h1{font-size:clamp(2.2rem,4.2vw,3.6rem);line-height:1.08;letter-spacing:-.01em;}
h2{font-size:clamp(1.8rem,3.2vw,2.6rem);line-height:1.15;}
h3{font-size:clamp(1.25rem,1.6vw,1.5rem);line-height:1.3;}

/* ========== Header ========== */
.navbar-sunsuites{background:linear-gradient(to right,var(--color-primario) 25% var(--brand-strip-width),var(--color-secundario) var(--brand-strip-width) 100%);transition:box-shadow .2s ease,transform .3s ease-in-out;}
.navbar-sunsuites.is-scrolled{box-shadow:0 4px 20px rgba(0,0,0,.15);}
.navbar-hidden{transform:translateY(-100%);}
.brand-text{color:var(--color-secundario);font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:clamp(.9rem,1vw,1rem);}
.main-menu .nav-link{color:rgba(255,255,255,.92);text-transform:uppercase;letter-spacing:.045em;font-weight:600;font-size:clamp(.9rem,1vw,1.05rem);padding:0 1rem;}
.main-menu .nav-link:hover,.main-menu .nav-link:focus{color:var(--color-primario);}
.nav-icon{color:rgba(255,255,255,.92)!important;padding:0 .6rem!important;font-size:1.05rem;}
.nav-icon:hover{color:var(--color-primario)!important;}
.vr.vr-light{width:1px;height:24px;background:rgba(255,255,255,.2);display:inline-block;}
.md-btn-contained{background:var(--color-primario);color:var(--color-secundario);border:none;border-radius:8px;padding:.68rem 1.05rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:.95rem;box-shadow:0 2px 6px rgba(0,0,0,.12);transition:transform .05s,box-shadow .15s,background-color .15s,color .15s;}
.md-btn-contained:hover{background:var(--color-secundario);color:#fff;box-shadow:0 6px 20px rgba(0,0,0,.22);}
.md-btn-contained:active{transform:translateY(1px);}

/* ========== Hero ========== */
.hero-sunsuites{position:relative;min-height:92vh;}
.min-vh-92{min-height:92vh;}
.hero-images{position:absolute;inset:0;z-index:0;}
.hero-img{height:92vh;object-fit:cover;object-position:center;filter:saturate(1.05) contrast(1.02);}
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(to right,rgba(10,48,51,.75) 0%,rgba(10,48,51,.5) 80%,rgba(10,48,51,.15) 100%),
  linear-gradient(to top,rgba(0,0,0,.35) 0%,rgba(0,0,0,0) 60%);}
.hero-content{position:relative;z-index:2;}
.hero-kicker{background:rgba(222,206,154,.15);color:#fff;border:1px solid rgba(222,206,154,.35);font:600 .82rem/1 'Ubuntu',sans-serif;letter-spacing:.06em;}
.hero-title-modern{color:#fff;font-family:'Ubuntu',sans-serif;font-weight:900;line-height:1.04;letter-spacing:-.01em;font-size:clamp(2.2rem,4.4vw,4.2rem);margin:0;}
.hero-title-modern .hero-emph{color:var(--color-primario);}
.hero-sub{color:rgba(255,255,255,.94);font-weight:400;font-size:clamp(1.05rem,1.2vw,1.3rem);margin:.85rem 0 0;}
.hero-stats{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:1.2rem 1.5rem;border-radius:1rem;background:rgba(255,255,255,.08);backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);border:1px solid rgba(255,255,255,.25);color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.2);}
.hero-stats .divider{width:1px;height:28px;background:rgba(255,255,255,.45);justify-self:center;}
.stat-item{display:flex;align-items:center;justify-content:center;gap:.65rem;}
.stat-ico{font-size:1.2rem;opacity:.95;color:var(--color-primario);}
.stat-text{font-size:clamp(1.05rem,1.1vw,1.28rem);letter-spacing:.01em;}
.stat-strong{font-weight:800;color:#fff;}

/* ========== Overview ========== */
.py-6{padding-top:4.8rem;padding-bottom:4.8rem;}
.overview-section{position:relative;}
.viz-wrap{max-width:720px;margin-inline:auto;}
.viz-tag{position:absolute;left:-2rem;top:1rem;writing-mode:vertical-rl;transform:rotate(180deg);font-size:.95rem;letter-spacing:.4rem;color:rgba(10,48,51,.18);}
.shape{position:absolute;border-radius:.5rem;}
.shape-a{width:64%;height:62%;background:var(--color-primario);left:-8%;top:-6%;}
.shape-b{width:36%;height:28%;background:rgba(87,87,86,.25);left:12%;bottom:-6%;backdrop-filter:blur(1px);}
.viz-main{position:relative;border-radius:.75rem;overflow:hidden;}
.viz-secondary{position:absolute;right:-8%;bottom:-8%;width:52%;border-radius:.6rem;overflow:hidden;}
.kicker{display:inline-block;font:600 .85rem/1 'Ubuntu',sans-serif;letter-spacing:.18em;text-transform:uppercase;color:var(--color-secundario);border-left:3px solid var(--color-primario);padding-left:.6rem;margin-bottom:.6rem;}
.overview-bullets li{display:flex;align-items:center;gap:.6rem;margin:.45rem 0;color:var(--color-secundario);font-size:clamp(1rem,1vw,1.1rem);}
.overview-bullets i{color:var(--color-primario);}
.overview-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;background:rgba(222,206,154,.25);border-radius:.75rem;padding:1.1rem 1.3rem;}
.overview-stats .stat{display:flex;align-items:center;gap:1rem;justify-content:center;padding:.8rem .6rem;}
.overview-stats .stat i{font-size:1.5rem;color:var(--color-secundario);}
.overview-stats .stat strong{font-weight:800;color:var(--color-secundario);font-size:1.08rem;margin-right:.15rem;}
.overview-stats .stat span{font:600 .75rem/1 'Ubuntu',sans-serif;letter-spacing:.18em;color:rgba(10,48,51,.7);}
.overview-stats .stat:hover{background:rgba(255,255,255,.6);border-radius:.5rem;transition:.2s;}
.overview-stats .stat div{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap;}

/* ========== Planos ========== */
.plans-section{position:relative;overflow:hidden;}
.plans-bg{position:absolute;inset:0;z-index:0;background:#0A3033;}
.plans-section .container{position:relative;z-index:1;}
.plans-section .section-pretitle,.plans-section .section-intro{color:#d3d3d3!important;}
.plans-tabs .nav-link{color:#fff;border:1px solid rgba(255,255,255,.25);background:transparent;margin:0 .25rem;border-radius:0;font-size:clamp(1rem,1.15vw,1.15rem);padding:.75rem 1.15rem;}
.plans-tabs .nav-link.active{background:var(--color-primario);color:var(--color-secundario);border-color:var(--color-primario);}
.plans-panel{color:#fff;align-items:center;}
.plans-panel .col-lg-5,.plans-panel .col-lg-7{display:flex;flex-direction:column;justify-content:center;}
.plans-panel .col-lg-5{padding-left:3rem;padding-right:1.5rem;max-width:500px;margin-left:auto;}
.plans-panel .col-lg-7{padding-right:3rem;padding-left:1.5rem;max-width:600px;margin-right:auto;align-items:center;}
.plan-frame{width:100%;max-height:620px;border-radius:.6rem;overflow:hidden;display:flex;align-items:center;justify-content:center;background:transparent;}
.plan-frame .plan-img{width:100%;height:auto;object-fit:contain;object-position:center;}
.specs-list{max-width:42ch;padding:1rem 1.2rem;}
.specs-list li{display:flex;align-items:center;gap:.6rem;margin:.45rem 0;font-size:1.06rem;line-height:1.45;color:#fff;}
.specs-list i{color:var(--color-primario);font-size:1.15rem;}
.price-tag{font:600 .95rem/1 'Ubuntu',sans-serif;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.9);}
.price-tag span{background:var(--color-primario);color:var(--color-secundario);padding:.28rem .6rem;border-radius:.3rem;font-weight:800;font-size:1.05em;}
.plan-frame a{cursor:zoom-in;}

/* ========== Cierre de venta ========== */
.closing-section{background:#fff;}
.badge-pill{background:rgba(10,48,51,.05);border:1px solid rgba(10,48,51,.12);color:var(--color-secundario);font:600 .8rem/1 'Ubuntu',sans-serif;letter-spacing:.06em;padding:.55rem .8rem;border-radius:999px;}
.testimonial{color:var(--color-secundario);max-width:56ch;}
.testimonial i{color:var(--color-primario);margin-right:.5rem;}
.testimonial .t-meta{color:var(--color-neutro);font-size:.9rem;}
.closing-card{background:#fdfdfd;border-radius:.75rem;padding:1.25rem;box-shadow:0 8px 28px rgba(0,0,0,.08);}
.closing-card .label{color:var(--color-secundario);}
.closing-card .value{color:var(--color-neutro);font-weight:800;}
.closing-progress{height:.6rem;background:rgba(10,48,51,.08);}
.closing-progress .progress-bar{background:var(--color-primario);}
.closing-facts li{display:grid;grid-template-columns:1.4rem 1fr auto;align-items:center;gap:.6rem;padding:.55rem 0;border-bottom:1px solid rgba(10,48,51,.08);color:var(--color-secundario);font-size:1rem;}
.closing-facts li:last-child{border-bottom:0;}
.closing-facts i{color:var(--color-secundario);opacity:.9;}
.closing-facts strong{color:var(--color-neutro);font-weight:800;}

/* ========== Contacto / Modal ========== */
.contact-modal{--field-pad-y:.75rem;--ico-left:.85rem;}
.contact-modal .modal-content{border:0;border-radius:16px;overflow:hidden;box-shadow:0 22px 70px rgba(0,0,0,.35);}
.contact-modal .modal-header{background:var(--color-secundario);color:#fff;}
.contact-modal .modal-title{font-family:'Cormorant Garamond',serif;font-weight:700;letter-spacing:.02em;display:flex;align-items:center;gap:.6rem;}
.contact-modal .modal-title i{color:var(--color-primario);}
.contact-modal .btn-close{filter:invert(1) grayscale(1);opacity:.9;}
.contact-modal .modal-body{padding:1.25rem;background:#fff;}
.input-icon{position:relative;}
.input-icon .fa-field-ico{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--color-neutro);}
.input-icon .custom-input{padding-left:2.5rem;}
.custom-input{border-radius:.5rem;border:1px solid rgba(0,0,0,.08);padding:.75rem 1rem;font-size:1rem;background:#fff;color:var(--color-secundario);}
.custom-input:focus{outline:none;box-shadow:0 0 0 .2rem rgba(10,48,51,.18);border-color:transparent;}
.btn-send{background:var(--color-secundario);color:#fff;border-radius:8px;font-weight:700;padding:.75rem 1.25rem;border:0;}
.btn-send:hover{background:#062122;}
.input-icon.icon-top .fa-field-ico{top:.95rem;transform:none;}
.input-icon.icon-top textarea.custom-input{padding-top:.75rem;padding-left:2.5rem;}

/* ========== Footer ========== */
.site-footer{background:var(--color-secundario);color:rgba(255,255,255,.85);font-size:.9rem;padding:1.2rem 0;border-top:3px solid var(--color-primario);}
.site-footer a{color:var(--color-primario);text-decoration:none;font-weight:600;}
.site-footer a:hover{text-decoration:underline;}
.site-footer strong{color:#fff;font-weight:700;}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;white-space:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.footer-left,.footer-right{margin:0;line-height:1.2;}

/* ========== Amenities (marquee) ========== */

.amenidades { position: relative; }

.amen-wrap{
  position:relative;
  overflow:hidden;
  width:100%;
  margin-top:1.25rem;
  min-height:64px; 
}

.amen-track{
  position:absolute;
  top:0;
  display:flex;
  gap:2.25rem;
  padding:0 .5rem;
  white-space:nowrap;
  will-change:transform;
}

.amen-track.t1{ left:0; }
.amen-track.t2{ left:100%; }

.amen-item{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:.85rem;
  min-width:220px;
  color:var(--color-secundario);
}

.amen-ico{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:10px;
  background:#0A3033;
  color:#fff;
  box-shadow:0 6px 16px rgba(0,0,0,.10);
}

.amen-ico i{ font-size:22px; line-height:1; }

.amen-text{ line-height:1.15; text-align:left; }
.amen-text .amen-k{ 
  font:700 .8rem/1 'Ubuntu',sans-serif; 
  letter-spacing:.05em; 
  text-transform:uppercase; 
  color:rgba(10,48,51,.55);
}
.amen-text .amen-v{ 
  display:block; 
  font-weight:800; 
  color:var(--color-secundario);
  font-size:1.05rem;
}

.amen-wrap:hover .amen-item .amen-ico{ transform:translateY(-1px); }

@media (max-width:575.98px){
  .amen-item{ min-width:180px; gap:.75rem; }
  .amen-ico{ width:40px; height:40px; }
  .amen-ico i{ font-size:20px; }
  .amen-text .amen-v{ font-size:1rem; }
}

#amenidades .amen-wrap{ padding-top:.25rem; }

#amenidades .amen-item{
  gap:.85rem;
  padding:.25rem .4rem;
  min-width:240px;
}

#amenidades .amen-item i{
  font-size:28px;
  color:var(--color-secundario);
  opacity:1;
  line-height:1;
}

#amenidades .amen-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  line-height:1.15;
}

#amenidades .amen-text span:first-child{
  font:700 .9rem/1 'Ubuntu',sans-serif;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#9aa0a6;
  margin-bottom:.1rem;
  white-space:nowrap;
}

#amenidades .amen-text span:last-child{
  font-weight:800;
  font-size:1.15rem;
  color:#111;
  white-space:nowrap;
}

@media (max-width: 767.98px){
  #amenidades .amen-item{ min-width:200px; }
  #amenidades .amen-item i{ font-size:26px; }
  #amenidades .amen-text span:last-child{ font-size:1.05rem; }
}

/* ========== Mapa ========== */
.map-fullbleed{position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;width:100vw;background:#f6f8f7;}
.map-outer{position:relative;width:100vw;aspect-ratio:21/9;max-height:560px;min-height:320px;overflow:hidden;}
.map-outer iframe{position:absolute;inset:0;width:100%;height:100%;border:0;pointer-events:none;filter:saturate(1.02) contrast(1.02);}
@supports not (aspect-ratio:1/1){.map-outer{height:48vw;}}

/* ========== Video / Presentación ========== */
.video-section{background:linear-gradient(180deg,#fff 0%,#f9faf9 100%);}
.video-card{border-radius:18px;overflow:hidden;background:#fff;}
.video-copy{background:#fff;}
.video-copy .kicker{border-left-color:var(--color-primario);}
.video-wrapper{position:relative;max-width:90%;margin:0 auto;border-radius:.6rem;overflow:hidden;}
.video-el{width:100%;height:100%;object-fit:cover;display:block;border-radius:0;}
.video-media{display:flex;justify-content:center;padding-right:1.5rem;}
.play-btn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:68px;height:68px;border-radius:999px;border:none;display:grid;place-items:center;background:var(--color-primario);color:var(--color-secundario);box-shadow:0 10px 28px rgba(0,0,0,.18);transition:transform .15s,box-shadow .2s,background-color .2s;}
.play-btn i{font-size:1.15rem;margin-left:2px;}
.play-btn:hover{transform:translate(-50%,-50%) scale(1.06);box-shadow:0 14px 36px rgba(0,0,0,.22);background:#e6d8a9;}
@media (max-width:991.98px){.video-card{border-radius:0}.video-copy{padding:1.25rem!important}}

/* ========== Launch countdown (único) ========== */
.launch-countdown{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.2rem;border-radius:.75rem;background:#fdfbf5;border:1px solid rgba(222,206,154,.55);box-shadow:0 3px 12px rgba(0,0,0,.05);margin:1rem 0 1.5rem;max-width:420px;}
.launch-countdown::after{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(120deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.6) 50%,rgba(255,255,255,0) 100%);transform:skewX(-20deg);animation:shine 8s infinite;}
@keyframes shine{0%{left:-75%}8%,100%{left:120%}}
.launch-countdown .lc-left{display:flex;align-items:center;gap:.75rem;}
.launch-countdown i{color:var(--color-secundario);font-size:1.15rem;opacity:.9;}
.launch-countdown .lc-kicker{display:block;font:700 .8rem/1 'Ubuntu',sans-serif;text-transform:uppercase;letter-spacing:.05em;color:var(--color-secundario);opacity:.8;}
.launch-countdown .lc-deadline{font-size:.95rem;color:var(--color-secundario);}
.launch-countdown .lc-right{display:flex;flex-direction:column;align-items:flex-end;}
.launch-countdown .lc-number{font-family:'Ubuntu',sans-serif;font-weight:900;font-size:1.6rem;line-height:1;color:var(--color-secundario);}
.launch-countdown .lc-label{font:600 .8rem/1 'Ubuntu',sans-serif;color:rgba(10,48,51,.75);margin-top:.15rem;}
@media (max-width:575.98px){.launch-countdown{flex-direction:column;align-items:flex-start;gap:.6rem}.launch-countdown .lc-right{align-items:flex-start}}

/* ========== Botón WhatsApp flotante ========== */
.btn-whatsapp{border:1px solid rgba(10,48,51,.18);color:var(--color-secundario);background:#fff;border-radius:8px;font-weight:700;padding:.75rem 1.25rem;display:inline-flex;align-items:center;gap:.5rem;}
.btn-whatsapp i{font-size:1.1em;}
.wa-float{position:fixed;bottom:20px;right:20px;width:58px;height:58px;background-color:#25D366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 6px 16px rgba(0,0,0,.25);z-index:9999;text-decoration:none;transition:transform .25s,box-shadow .25s;overflow:hidden;}
.wa-float i{position:relative;z-index:2;}         /* icono arriba del pulso */
.wa-float .wa-pulse{position:absolute;inset:0;border-radius:50%;background-color:rgba(37,211,102,.45);z-index:1;animation:none;}
.wa-float:hover{transform:scale(1.08);box-shadow:0 8px 20px rgba(0,0,0,.35);}
.wa-float:hover .wa-pulse{animation:wa-pulse 1.2s infinite;}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.6}70%,100%{transform:scale(1.7);opacity:0}}

/* ========== Galería ========== */
#lg-gallery .gal-thumb{border-radius:12px;box-shadow:0 6px 18px rgba(0,0,0,.10);transition:transform .22s,box-shadow .22s;}
#lg-gallery a:hover .gal-thumb{transform:translateY(-2px) scale(1.01);box-shadow:0 14px 30px rgba(0,0,0,.16);}
.lg-sub-html h4{margin:0 0 .25rem;font-family:'Cormorant Garamond',serif;color:var(--color-secundario);}
.lg-sub-html p{margin:0;color:var(--color-neutro);}
.brand-inline{list-style:none;margin:1.25rem 0 0;padding:0;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;}
.brand-inline li{opacity:.85;filter:grayscale(100%);transition:opacity .2s,filter .2s;}
.brand-inline li:hover{opacity:1;filter:none;}
.brand-inline img{display:block;height:44px;width:auto;}

/* ========== Testimonios ========== */
.testi-section{position:relative;background:linear-gradient(180deg,#fff 0%,#f9faf9 100%);}
.testi-section .testi-carousel{position:relative;}
.testi-section .testi-card{margin:0 auto;max-width:980px;text-align:center;color:var(--color-secundario);padding:2.5rem 1rem 0;position:relative;}
.testi-section .testi-quote{font-size:clamp(1.25rem,2.2vw,2rem);line-height:1.35;color:rgba(10,48,51,.85);margin:0 0 1.5rem;position:relative;padding:0 1rem;}
.testi-section .testi-quote::before{content:"“";position:absolute;left:50%;top:-1rem;transform:translate(-50%,-40%);font-family:'Cormorant Garamond',serif;font-weight:700;font-size:clamp(4rem,10vw,8rem);line-height:.8;color:rgba(222,206,154,.35);pointer-events:none;}
.testi-section .testi-meta{display:grid;gap:.25rem;justify-items:center;}
.testi-section .testi-meta strong{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:clamp(1.05rem,1.3vw,1.25rem);color:var(--color-secundario);}
.testi-section .testi-meta span{font:500 .95rem/1 'Ubuntu',sans-serif;color:rgba(10,48,51,.65);}
.testi-section .testi-indicators{position:static;display:flex;justify-content:center;gap:1rem;margin:1.75rem 0 0;}
.testi-section .testi-indicators button[data-bs-target]{width:72px!important;height:72px!important;display:inline-flex;align-items:center;justify-content:center;padding:0!important;margin:0!important;border:0!important;background:transparent!important;text-indent:0!important;box-sizing:border-box;border-radius:50%;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.12);opacity:.75;outline:3px solid transparent;outline-offset:3px;transition:transform .2s,box-shadow .2s,opacity .2s,outline-color .2s;}
.testi-section .testi-indicators button[data-bs-target] img{width:100%;height:100%;object-fit:cover;display:block;}
.testi-section .testi-indicators button.active,
.testi-section .testi-indicators button:hover,
.testi-section .testi-indicators button:focus{opacity:1;transform:translateY(-2px) scale(1.03);box-shadow:0 12px 28px rgba(0,0,0,.18);outline-color:var(--color-primario);}
.testi-section .testi-control{width:48px;height:48px;top:42%;background:rgba(255,255,255,.7);border-radius:50%;box-shadow:0 6px 16px rgba(0,0,0,.12);opacity:.95;}
.testi-section .testi-control i{color:var(--color-secundario);font-size:1rem;}
.testi-section .testi-control:hover{background:#fff;}
@media (max-width:575.98px){
  .testi-section .testi-indicators button[data-bs-target]{width:56px!important;height:56px!important;}
  .testi-section .testi-quote{padding:0;}
}

/* ========== Utilidades / AOS ========== */
html:not(.aos-enabled) [data-aos]{opacity:1!important;transform:none!important;}
.viz-main.fade-stack{position:relative;overflow:hidden;aspect-ratio:9/11;width:100%;background:#0A3033;}
@supports not (aspect-ratio:1){.viz-main.fade-stack{min-height:520px;}}
.fade-stack .fade-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;animation:xfade 15s linear infinite;animation-delay:calc(var(--i)*5s);will-change:opacity;}
.fade-stack .fade-slide[style*="--i:0"]{opacity:1;}
@keyframes xfade{0%,26%{opacity:1}33%,94%{opacity:0}100%{opacity:1}}

/* ========== Responsive global ========== */
@media (max-width:991.98px){
  .hero-stats{grid-template-columns:1fr;text-align:center;}
  .hero-stats .divider{display:none;}
  .hero-title-modern{font-size:clamp(1.9rem,6vw,2.8rem);}
  .hero-sunsuites{min-height:82vh;}
  .hero-img{height:82vh;}
  .viz-tag{display:none;}
  .overview-stats{grid-template-columns:1fr 1fr;}
  .plans-panel .col-lg-5,.plans-panel .col-lg-7{padding-left:1rem;padding-right:1rem;}
  .plans-panel .plan-frame{max-height:340px;}
}
@media (max-width:767.98px){
  .hero-stats{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:1rem;}
  .hero-stats .stat-item{justify-content:center;}
  #overview{margin-top:2.5rem;}
  .plans-section .tab-pane .col-12.col-lg-5{display:flex;flex-direction:column;align-items:center;text-align:center;}
  .plans-section .price-tag{display:inline-block;margin:.5rem auto 1rem!important;text-align:center;}
  .plans-section .col-12.col-lg-5 .d-flex{justify-content:center;}
}

.plan-frame + p {
  width: 100%;
  text-align: center;
}

.btn-brochure {
  background: rgba(255, 255, 255, 0.12); 
  color: #fff;
  font-weight: 600;
  padding: .65rem 1.25rem;
  border-radius: .75rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  backdrop-filter: blur(10px);     
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.25);
  transition: all .3s ease;
}

.btn-brochure:hover {
  background: rgba(255, 255, 255, 0.25);
  color: var(--color-primario);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
}

:root{
  --color-primario:#DECE9A;     /* oro suave (ya lo tienes) */
  --color-secundario:#0A3033;   /* verde petróleo (ya lo tienes) */
  --pl-bg:#ffffff;              /* fondo blanco */
  --pl-fade: .55s;              /* velocidad de fade */
}

/* Overlay */
#preloader{
  position:fixed; inset:0; z-index:9999;
  background: var(--pl-bg);
  display:grid; place-items:center;
  transition: opacity var(--pl-fade) ease, visibility var(--pl-fade) ease;
}


#preloader .pl-canvas{
  position:relative;
  width:min(420px, 72vw);
  height:min(420px, 72vw);
  filter: drop-shadow(0 10px 30px rgba(0,0,0,.08));
}

#preloader .blob{
  position:absolute; inset:auto;
  width:44%; aspect-ratio:1/1; border-radius:40% 60% 60% 40% / 40% 40% 60% 60%;
  opacity:.85;
  mix-blend-mode:normal; 
  will-change:transform, border-radius;
  animation: float 4.6s ease-in-out infinite alternate,
             morph 9s ease-in-out infinite;
}


#preloader .b1{ background:rgba(10,48,51,.10); left:6%;  top:16%; animation-delay: .0s; }
#preloader .b2{ background:rgba(222,206,154,.60); right:8%; top:22%; animation-delay:-.6s; }
#preloader .b3{ background:rgba(10,48,51,.18); left:22%; bottom:8%; animation-delay:-1.2s; }


#preloader .slice{
  position:absolute; inset:auto;
  background: conic-gradient(from 180deg at 50% 50%, transparent 0 65%, rgba(10,48,51,.09) 65% 100%);
  border-radius:24px;
  filter: blur(.3px);
  will-change:transform;
  animation: spin 7.5s linear infinite;
}
#preloader .s1{ width:65%; height:12%; left:17%; top:12%; }
#preloader .s2{ width:55%; height:12%; right:14%; bottom:14%; animation-direction: reverse; }


body.is-loaded #preloader{ opacity:0; visibility:hidden; }


@media (prefers-reduced-motion: reduce){
  #preloader .blob, #preloader .slice{ animation:none }
  #preloader{ transition:none }
}


@keyframes float{
  from{ transform: translate3d(0,0,0) rotate(0.001deg) }
  to  { transform: translate3d(0,-14%,0) rotate(2deg) }
}
@keyframes morph{
  0%  { border-radius:40% 60% 60% 40% / 40% 40% 60% 60% }
  50% { border-radius:55% 45% 60% 40% / 50% 35% 65% 50% }
  100%{ border-radius:60% 40% 45% 55% / 45% 60% 40% 55% }
}
@keyframes spin{ to{ transform: rotate(360deg) } }
