/* ========================================
   GRUPO CADENA — Custom Theme v3
   Replica exacta de grupocadena.happylemon.io
   ======================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#1D1D1B;
  --red:#FF0004;
  --yellow:#FFE900;
  --green:#61CE70;
  --white:#FFFFFF;
  --black:#000000;
  --font:'Montserrat',sans-serif;
  --futura:'Montserrat',sans-serif;
}
html{scroll-behavior:smooth}
html,body{width:100%!important;max-width:none!important;margin:0!important;padding:0!important}
body>*{max-width:none!important}
body .wp-site-blocks,
body .wp-site-blocks>*,
body .is-layout-constrained,
body .is-layout-constrained>*,
body .is-layout-flow,
body .is-layout-flow>*,
body .is-layout-constrained>.alignwide,
body .is-layout-constrained>.alignfull{max-width:none!important;width:100%!important;margin-left:0!important;margin-right:0!important;padding-left:0!important;padding-right:0!important}
body .has-global-padding{padding:0!important}
body .entry-content,body .entry-content>*{max-width:none!important}
.wp-block-post-content,.wp-block-post-content>*{max-width:none!important}
body{font-family:var(--font);font-size:16px;font-weight:400;color:var(--primary);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:var(--font);cursor:pointer}

/* ======== TOP BAR ======== */
.top-bar{
  background:var(--red);
  display:flex;align-items:center;justify-content:center;
  padding:0;position:relative;z-index:101;
}
.top-bar__inner{
  width:90%;max-width:1200px;
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0;
}
.top-bar__phones{display:flex;gap:32px;align-items:center}
.top-bar__phone{display:flex;align-items:center;gap:8px;color:var(--white);font-size:14px;font-weight:600}
.top-bar__phone i{font-size:14px}
.top-bar__socials{display:flex;gap:5px}
.top-bar__socials a{
  color:var(--white);font-size:18px;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .3s;
}
.top-bar__socials a:hover{opacity:.7}

/* ======== HEADER / NAVBAR ======== */
.header-hero-wrap{position:relative}
.site-header{
  position:absolute;top:0;left:0;width:100%;z-index:100;
  display:flex;align-items:center;justify-content:center;
}
.site-header__inner{
  width:90%;max-width:1200px;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 0;
}
.site-header__logo img{width:10rem;height:auto}
.menu-btn{
  display:flex;align-items:center;gap:10px;
  background:transparent;border:none;
  color:var(--white);font-size:20px;font-weight:600;
  text-transform:uppercase;letter-spacing:2px;
  padding:0;
}
.menu-btn svg{width:32px;height:32px;fill:var(--white)}

/* ======== FULLSCREEN MENU OVERLAY ======== */
.menu-overlay{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:row;visibility:hidden;pointer-events:none;transition:visibility 0s .5s}
.menu-overlay.open{visibility:visible;pointer-events:auto;transition:visibility 0s 0s}
.menu-overlay__left{position:relative;width:50%;height:100vh;overflow:hidden;transform:translateX(-100%);transition:transform .5s cubic-bezier(.4,0,.2,1)}
.menu-overlay.open .menu-overlay__left{transform:translateX(0)}
.menu-overlay__slideshow{position:absolute;inset:0}
.menu-overlay__slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;
  animation:kenBurns 20s ease infinite alternate;
}
.menu-overlay__slide.active{opacity:1}
.menu-overlay__slide:nth-child(1){animation-delay:0s;transform-origin:center center}
.menu-overlay__slide:nth-child(2){animation-delay:-5s;transform-origin:top left}
.menu-overlay__slide:nth-child(3){animation-delay:-10s;transform-origin:bottom right}
.menu-overlay__slide:nth-child(4){animation-delay:-15s;transform-origin:top right}
@keyframes kenBurns{0%{transform:scale(1)}100%{transform:scale(1.15)}}
.menu-overlay__logo{position:absolute;top:24px;left:32px;z-index:2}
.menu-overlay__logo img{width:10rem;height:auto}
.menu-overlay__right{
  width:50%;height:100vh;background:var(--white);
  display:flex;flex-direction:column;justify-content:center;
  padding:60px 80px;position:relative;
  transform:translateX(100%);transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.menu-overlay.open .menu-overlay__right{transform:translateX(0)}
.menu-overlay__close{position:absolute;top:20px;right:32px;background:none;border:none;color:var(--primary);font-size:28px}
.menu-overlay__close:hover{opacity:.6}
.menu-overlay__links{display:flex;flex-direction:column;gap:12px}
.menu-overlay__links a{color:var(--primary);font-size:40px;font-weight:300;letter-spacing:-0.5px;transition:color .3s}
.menu-overlay__links a:hover{color:var(--red)}
.menu-overlay__socials{position:absolute;bottom:32px;right:40px;display:flex;gap:20px}
.menu-overlay__socials a{color:var(--primary);font-size:22px;transition:color .3s}
.menu-overlay__socials a:hover{color:var(--red)}

/* ======== HERO ======== */
.hero{
  position:relative;min-height:85vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
  margin-bottom:-75px;
}
.hero__video{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none}
.hero__video iframe,.hero__video>div{position:absolute;top:50%;left:50%;width:180vw;height:180vh;transform:translate(-50%,-50%);border:0}
.hero__overlay{position:absolute;inset:0;z-index:1;background:rgba(0,0,0,.3)}
.hero__content{position:relative;z-index:2;padding:0 40px;max-width:900px}
.hero__title{font-size:45px;font-weight:700;color:var(--white);line-height:1;margin-bottom:8px;white-space:nowrap}
.hero__subtitle{font-size:32px;font-weight:500;color:var(--white);line-height:1.3;margin-bottom:24px}
.hero__buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:calc(.667em + 2px) calc(1.333em + 2px);
  font-weight:600;font-size:16px;
  border:none;border-radius:3px;
  transition:all .3s;cursor:pointer;
  font-family:var(--font);
}
.btn--red{background:var(--red);color:var(--white)}
.btn--red:hover{opacity:.85}
.btn--black{background:var(--black);color:var(--white)}
.btn--black:hover{opacity:.85}
.btn--green{background:var(--green);color:var(--white)}
.btn--green:hover{opacity:.85}
.btn--white{background:var(--white);color:var(--black);border-radius:15px}
.btn--white:hover{opacity:.85}

/* ======== LOGO CAROUSEL ======== */
.logo-carousel-wrap{
  display:flex;justify-content:center;
  position:relative;z-index:50;
}
.logo-carousel{
  background:var(--white);
  padding:25px;
  border-radius:10px;
  box-shadow:0 0 10px rgba(135,135,135,.5);
  width:90%;max-width:1200px;
}
.logo-carousel .swiper-slide{display:flex;align-items:center;justify-content:center}
.logo-carousel .swiper-slide img{max-height:70px;width:auto}

/* ======== DESARROLLOS ======== */
.desarrollos{
  background:var(--white);
  padding:50px 0;
  display:flex;flex-direction:column;align-items:center;
}
.desarrollos__inner{width:95%;max-width:1200px}
.desarrollos__header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;flex-wrap:wrap;gap:24px;
}
.desarrollos__title{font-size:40px;font-weight:700;color:var(--black);line-height:1.15}
.desarrollos__logo{display:flex;justify-content:flex-end;align-items:flex-end}
.desarrollos__logo img{width:150px;margin-left:auto}

/* Tabs */
.tabs__nav{
  display:flex;gap:8px;margin-bottom:24px;
  justify-content:center;flex-wrap:wrap;
}
.tabs__btn{
  padding:10px 24px;font-size:16px;font-weight:600;
  font-family:var(--font);
  color:var(--white);background:var(--black);
  border:none;border-radius:10px;
  transition:all .3s;cursor:pointer;
}
.tabs__btn.active{background:var(--red)}
.tabs__btn:hover{background:var(--red)}
.tabs__panel{display:none}
.tabs__panel.active{display:block}

/* Development cards grid */
.dev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.dev-card{
  position:relative;min-height:420px;
  border-radius:25px;overflow:hidden;
  background-size:cover;background-position:center;
  display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .3s;
  box-shadow:0 0 10px rgba(157,157,157,.5);
}
.dev-card:hover{transform:translateY(-4px)}
.dev-card__content{
  position:relative;z-index:2;
  padding:20px;
  backdrop-filter:brightness(.9) blur(2.5px);
  -webkit-backdrop-filter:brightness(.9) blur(2.5px);
  border-radius:0 0 25px 25px;
}
.dev-card__name{font-size:28px;font-weight:700;color:var(--white);margin-bottom:6px}
.dev-card__status{
  display:flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;color:var(--white);
  margin-bottom:12px;
}
.dev-card__status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dev-card__status-dot--green{background:#00FF00}
.dev-card__status-dot--yellow{background:#FFFF00}
.dev-card__status-dot--red{background:#FF0000}
.dev-card__btn{
  display:block;text-align:center;padding:10px;
  font-size:16px;font-weight:600;
  color:var(--black);background:var(--white);
  border-radius:15px;transition:all .3s;
}
.dev-card__btn:hover{background:var(--red);color:var(--white)}

/* ======== PRECALIFICATE ======== */
.precalificate{
  position:relative;padding:80px 40px;
  text-align:center;color:var(--white);
  background-size:cover;background-position:center;
  min-height:40vh;
  display:flex;align-items:center;justify-content:center;
  border-radius:10px;
}
.precalificate::before{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,.5);z-index:1;
  border-radius:10px;
}
.precalificate__content{position:relative;z-index:2;max-width:800px;margin:0 auto}
.precalificate__title{font-family:var(--futura);font-size:45px;font-weight:700;margin-bottom:16px;color:var(--white)}
.precalificate__text{font-family:var(--futura);font-size:20px;font-weight:400;line-height:1.2;margin-bottom:28px;color:var(--white)}
.precalificate .btn{font-family:var(--futura);font-size:18px;border-radius:15px;background:var(--white);color:var(--black)}

/* ======== TESTIMONIALS ======== */
.testimonials{background:var(--white);padding:50px 0;display:flex;flex-direction:column;align-items:center}
.testimonials__inner{width:90%;max-width:1200px}
.testimonials__title{font-family:var(--futura);font-size:50px;font-weight:600;color:var(--black);text-align:center;margin-bottom:40px}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testimonials__video{position:relative;padding-bottom:56.25%;height:0;border-radius:0;overflow:hidden;background:var(--primary)}
.testimonials__video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ======== ABOUT / COUNTERS ======== */
.about{background:var(--white);padding:50px 0 0;display:flex;flex-direction:column;align-items:center}
.about__inner{
  width:90%;max-width:900px;
  display:flex;flex-direction:column;
  align-items:center;text-align:center;
}
.about__logo{width:160px;margin-bottom:16px}
.about__title{font-family:var(--futura);font-size:50px;font-weight:600;color:var(--black);margin-bottom:16px}
.about__text{font-family:var(--futura);font-size:20px;font-weight:300;color:var(--black);line-height:1.2;margin-bottom:40px}
.about__counters{display:flex;gap:50px;justify-content:center;flex-wrap:nowrap;margin-bottom:40px}
.counter{text-align:center}
.counter__number{font-family:var(--futura);font-size:52px;font-weight:600;color:var(--black)}
.counter__label{font-family:var(--futura);font-size:22px;font-weight:400;color:var(--primary);margin-top:4px}

/* Full-width image */
.full-image{width:100%}
.full-image img{width:100%;height:auto;display:block}

/* ======== BLOG ======== */
.blog-section{padding:50px 0;background:var(--white);display:flex;flex-direction:column;align-items:center}
.blog-section__inner{width:90%;max-width:1200px}
.blog-section__title{font-family:var(--futura);font-size:50px;font-weight:600;color:var(--black);text-align:center;margin-bottom:40px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.blog-card{border-radius:10px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.15)}
.blog-card__img{width:100%;aspect-ratio:3/2;object-fit:cover}
.blog-card__body{padding:20px}
.blog-card__title{font-size:23px;font-weight:700;margin-bottom:12px;line-height:1.3;font-family:var(--font)}
.blog-card__link{font-size:14px;font-weight:500;color:var(--red)}

/* ======== FOOTER ======== */
.site-footer{background:var(--primary);border-radius:25px 25px 0 0;padding:50px 0;display:flex;justify-content:center}
.footer__inner{width:90%;max-width:1200px;display:grid;grid-template-columns:40% 30% 30%;gap:40px}
.footer__logo{width:40%;margin-bottom:16px}
.footer__desc{font-size:16px;color:var(--white);line-height:1.7;margin-bottom:20px}
.footer__socials{display:flex;gap:12px;margin-bottom:24px}
.footer__socials a{color:var(--white);font-size:20px;transition:color .3s}
.footer__socials a:hover{color:var(--red)}
.footer__back-top{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 24px;border:1px solid rgba(255,255,255,.3);
  border-radius:25px;color:var(--white);font-size:14px;font-weight:500;
  background:var(--primary);transition:all .3s;
}
.footer__back-top:hover{background:rgba(255,255,255,.1)}
.footer__col-title{font-size:22px;font-weight:600;color:var(--white);margin-bottom:16px}
.footer__links{display:flex;flex-direction:column;gap:8px}
.footer__links a{font-size:20px;font-weight:500;color:var(--white);transition:color .3s}
.footer__links a:hover{color:var(--red)}
.footer__links a.is-red{color:var(--red)}
.footer__links--sub{padding-left:16px}
.footer__links--sub a{font-size:16px;font-weight:400}
.footer__bottom{background:var(--red);text-align:center;padding:16px 40px;color:var(--white);font-size:14px;font-weight:500}

/* ======== POPUP / MODAL (Right Side Panel) ======== */
.modal{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.7);display:none;justify-content:flex-end;opacity:0;transition:opacity .3s ease}
.modal.open{display:flex;opacity:1}
.modal__inner{background:var(--white);width:420px;max-width:90vw;height:100vh;overflow-y:auto;position:relative;display:flex;flex-direction:column;align-items:center;transform:translateX(100%);animation:slideInPanel .4s ease forwards}
@keyframes slideInPanel{from{transform:translateX(100%)}to{transform:translateX(0)}}
.modal__close{position:absolute;top:16px;right:16px;background:none;color:var(--primary);border:1px solid rgba(0,0,0,.15);width:32px;height:32px;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center;z-index:2;cursor:pointer;transition:background .3s}
.modal__close:hover{background:rgba(0,0,0,.05)}
.modal__logo{width:100%;padding:48px 40px 8px;text-align:center}
.modal__logo img{max-width:200px;height:auto}
.modal__body{padding:0 40px 40px;text-align:center;width:100%}
.modal__desc{font-size:14px;line-height:1.7;color:rgba(29,29,27,.6);margin-bottom:24px}
.modal__btn{display:block;width:100%;text-align:center;padding:14px;border:1.5px solid var(--primary);color:var(--primary);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:none;border-radius:8px;transition:all .3s;cursor:pointer;text-decoration:none}
.modal__btn:hover{background:var(--primary);color:var(--white)}
.modal__divider{width:calc(100% - 80px);height:1px;background:rgba(0,0,0,.1);margin:8px 0}
.modal__location{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:500;color:var(--primary);padding:16px 40px 12px}
.modal__location i{color:var(--red);font-size:14px}
.modal__map-wrap{padding:0 40px;width:100%}
.modal__map{width:100%;height:220px;border:0;border-radius:8px}
.modal__map-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#2563EB;padding:12px 40px;text-decoration:none;transition:opacity .3s}
.modal__map-link:hover{opacity:.7}
.modal__contact{padding:8px 40px 32px;text-align:center;font-size:13px;color:rgba(29,29,27,.5)}
.modal__contact i{margin-right:6px}

/* ======== PAGE HERO (Inner Pages) ======== */
.page-hero{
  position:relative;min-height:50vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
  background-size:cover;background-position:center;
}
.page-hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:1}
.page-hero__content{position:relative;z-index:2;padding:0 40px;max-width:900px}
.page-hero__title{font-size:50px;font-weight:700;color:var(--white);line-height:1.1;margin-bottom:12px}
.page-hero__subtitle{font-size:20px;font-weight:400;color:rgba(255,255,255,.85);line-height:1.4}

/* ======== BREADCRUMB ======== */
.breadcrumb{display:flex;justify-content:center;background:var(--white);padding:20px 0 0}
.breadcrumb__inner{
  width:95%;max-width:1200px;
  display:flex;align-items:center;gap:10px;
  font-size:14px;font-weight:500;color:rgba(29,29,27,.5);
}
.breadcrumb__inner a{color:var(--red);transition:opacity .3s}
.breadcrumb__inner a:hover{opacity:.7}
.breadcrumb__sep{font-size:10px;color:rgba(29,29,27,.3)}
.breadcrumb__current{color:var(--primary)}

/* ======== DESARROLLOS PAGE ======== */
.desarrollos-page{background:var(--white);padding:40px 0 60px;display:flex;flex-direction:column;align-items:center}
.desarrollos-page__inner{width:95%;max-width:1200px}
.desarrollos-page__intro{
  display:flex;align-items:center;justify-content:space-between;
  gap:40px;margin-bottom:40px;flex-wrap:wrap;
}
.desarrollos-page__intro-text{flex:1;min-width:280px}
.desarrollos-page__heading{font-size:38px;font-weight:700;color:var(--black);line-height:1.15;margin-bottom:16px}
.desarrollos-page__desc{font-size:17px;font-weight:400;color:rgba(29,29,27,.65);line-height:1.6}
.desarrollos-page__intro-logo{flex-shrink:0}
.desarrollos-page__intro-logo img{width:180px}

/* Page-specific card variant */
.dev-grid--page{grid-template-columns:repeat(3,1fr);gap:20px}
.dev-card--page{min-height:420px}
.dev-card__city{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:rgba(255,255,255,.85);
  margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;
}
.dev-card__city i{font-size:11px;color:var(--red)}

/* About compact variant */
.about--compact{padding:50px 0}

/* ======== SOBRE (ABOUT PAGE) ======== */
.sobre{background:var(--white);padding:50px 0;display:flex;flex-direction:column;align-items:center}
.sobre__inner{width:95%;max-width:1200px}
.sobre__row{display:flex;align-items:center;gap:50px}
.sobre__text{flex:1;min-width:280px}
.sobre__label{
  display:inline-block;font-size:13px;font-weight:700;
  text-transform:uppercase;letter-spacing:2px;
  color:var(--red);margin-bottom:12px;
}
.sobre__heading{font-size:36px;font-weight:700;color:var(--black);line-height:1.15;margin-bottom:20px}
.sobre__desc{font-size:16px;color:rgba(29,29,27,.65);line-height:1.7;margin-bottom:16px}
.sobre__desc:last-child{margin-bottom:0}
.sobre__image{flex:1;min-width:280px}
.sobre__image img{width:100%;border-radius:20px;object-fit:cover;aspect-ratio:4/3}

/* Sobre counters */
.sobre-counters{background:var(--black);padding:50px 0;display:flex;justify-content:center}
.sobre-counters__inner{
  width:95%;max-width:1200px;
  display:flex;justify-content:center;gap:60px;flex-wrap:wrap;
}
.sobre-counters .counter__number{color:var(--white)}
.sobre-counters .counter__label{color:rgba(255,255,255,.7)}

/* Mision / Vision / Valores */
.sobre-mvv{background:var(--white);padding:60px 0;display:flex;flex-direction:column;align-items:center}
.sobre-mvv__inner{width:95%;max-width:1200px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sobre-mvv__card{
  background:var(--white);border-radius:20px;padding:40px 32px;
  box-shadow:0 2px 20px rgba(0,0,0,.07);
  transition:transform .3s,box-shadow .3s;
}
.sobre-mvv__card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.12)}
.sobre-mvv__icon{
  width:56px;height:56px;border-radius:14px;
  background:var(--red);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:20px;
}
.sobre-mvv__title{font-size:22px;font-weight:700;color:var(--black);margin-bottom:12px}
.sobre-mvv__desc{font-size:15px;color:rgba(29,29,27,.6);line-height:1.65}

/* Presencia */
.sobre-presencia{background:var(--white);padding:60px 0;display:flex;flex-direction:column;align-items:center}
.sobre-presencia__inner{width:95%;max-width:1200px}
.sobre-presencia__header{text-align:center;margin-bottom:40px}
.sobre-presencia__title{font-size:38px;font-weight:700;color:var(--black);margin-bottom:12px}
.sobre-presencia__subtitle{font-size:17px;color:rgba(29,29,27,.6)}
.sobre-presencia__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.presencia-card{
  position:relative;min-height:320px;border-radius:20px;overflow:hidden;
  background-size:cover;background-position:center;
  display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .3s;
}
.presencia-card:hover{transform:translateY(-4px)}
.presencia-card__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.1) 100%)}
.presencia-card__content{position:relative;z-index:2;padding:28px}
.presencia-card__city{font-size:28px;font-weight:700;color:var(--white);margin-bottom:4px}
.presencia-card__count{font-size:14px;font-weight:500;color:rgba(255,255,255,.75);margin-bottom:14px}
.presencia-card__link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;color:var(--white);
  transition:gap .3s;
}
.presencia-card__link:hover{gap:12px}

/* Logos grid */
.sobre-logos{background:var(--white);padding:50px 0;display:flex;flex-direction:column;align-items:center}
.sobre-logos__inner{width:95%;max-width:1000px;text-align:center}
.sobre-logos__title{font-size:38px;font-weight:700;color:var(--black);margin-bottom:32px}
.sobre-logos__grid{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:32px;align-items:center;
}
.sobre-logos__item{flex:0 0 auto}
.sobre-logos__item img{max-height:60px;width:auto;opacity:.7;transition:opacity .3s}
.sobre-logos__item img:hover{opacity:1}

/* ======== BLOG ARCHIVE ======== */
.blog-archive{background:var(--white);padding:50px 0 60px;display:flex;flex-direction:column;align-items:center}
.blog-archive__inner{width:95%;max-width:1200px}
.blog-archive__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-archive-card{
  border-radius:16px;overflow:hidden;background:var(--white);
  box-shadow:0 2px 16px rgba(0,0,0,.07);
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;
}
.blog-archive-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.13)}
.blog-archive-card__img-wrap{position:relative;overflow:hidden}
.blog-archive-card__img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .4s}
.blog-archive-card:hover .blog-archive-card__img{transform:scale(1.04)}
.blog-archive-card__cat{
  position:absolute;top:14px;left:14px;
  background:var(--red);color:var(--white);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:5px 12px;border-radius:6px;
}
.blog-archive-card__body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.blog-archive-card__date{font-size:13px;color:rgba(29,29,27,.45);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.blog-archive-card__title{font-size:20px;font-weight:700;color:var(--black);line-height:1.3;margin-bottom:10px}
.blog-archive-card__excerpt{font-size:14px;color:rgba(29,29,27,.55);line-height:1.6;margin-bottom:16px;flex:1}
.blog-archive-card__link{font-size:14px;font-weight:600;color:var(--red);display:inline-flex;align-items:center;gap:6px;transition:gap .3s}
.blog-archive-card:hover .blog-archive-card__link{gap:10px}

/* Blog pagination */
.blog-pagination{display:flex;justify-content:center;gap:6px;padding:40px 0 0}
.blog-pagination__item a,.blog-pagination__item span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:40px;height:40px;padding:0 12px;
  border-radius:10px;font-size:14px;font-weight:600;
  border:1px solid rgba(0,0,0,.1);color:var(--primary);
  transition:all .3s;
}
.blog-pagination__item a:hover{background:var(--red);color:var(--white);border-color:var(--red)}
.blog-pagination__item .current{background:var(--red);color:var(--white);border-color:var(--red)}

/* Blog empty state */
.blog-archive__empty{
  text-align:center;padding:80px 20px;
  color:rgba(29,29,27,.4);
}
.blog-archive__empty i{font-size:48px;margin-bottom:16px}
.blog-archive__empty h2{font-size:28px;font-weight:700;color:var(--black);margin-bottom:8px}
.blog-archive__empty p{font-size:16px;color:rgba(29,29,27,.5)}

/* ======== SINGLE POST ======== */
.page-hero--post{min-height:55vh}
.post-hero__meta{display:flex;align-items:center;gap:16px;justify-content:center;margin-bottom:16px}
.post-hero__cat{
  background:var(--red);color:var(--white);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:5px 14px;border-radius:6px;
}
.post-hero__date{font-size:14px;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:6px}
.single-post{background:var(--white);padding:50px 0;display:flex;flex-direction:column;align-items:center}
.single-post__inner{width:95%;max-width:760px}
.single-post__content{font-size:17px;line-height:1.8;color:rgba(29,29,27,.8)}
.single-post__content h2{font-size:28px;font-weight:700;color:var(--black);margin:32px 0 16px}
.single-post__content h3{font-size:22px;font-weight:700;color:var(--black);margin:24px 0 12px}
.single-post__content p{margin-bottom:20px}
.single-post__content img{border-radius:12px;margin:24px 0}
.single-post__content ul,.single-post__content ol{margin:0 0 20px 24px}
.single-post__content li{margin-bottom:8px}
.single-post__content blockquote{
  border-left:4px solid var(--red);margin:24px 0;padding:16px 24px;
  background:rgba(255,0,4,.03);border-radius:0 8px 8px 0;
  font-style:italic;color:rgba(29,29,27,.7);
}

/* Tags */
.single-post__tags{display:flex;flex-wrap:wrap;gap:8px;padding-top:32px;border-top:1px solid rgba(0,0,0,.08);margin-top:40px}
.single-post__tag{
  font-size:13px;font-weight:500;color:var(--primary);
  padding:6px 14px;border:1px solid rgba(0,0,0,.1);border-radius:8px;
  transition:all .3s;
}
.single-post__tag:hover{background:var(--red);color:var(--white);border-color:var(--red)}

/* Share */
.single-post__share{
  display:flex;align-items:center;gap:16px;margin-top:24px;padding-top:24px;
  border-top:1px solid rgba(0,0,0,.08);
}
.single-post__share-label{font-size:14px;font-weight:600;color:var(--primary)}
.single-post__share-links{display:flex;gap:10px}
.single-post__share-links a{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(29,29,27,.06);color:var(--primary);
  font-size:16px;transition:all .3s;
}
.single-post__share-links a:hover{background:var(--red);color:var(--white)}

/* Post navigation */
.post-nav{background:var(--white);padding:0 0 40px;display:flex;justify-content:center}
.post-nav__inner{width:95%;max-width:760px;display:flex;justify-content:space-between;gap:20px}
.post-nav__link{
  padding:20px 24px;border:1px solid rgba(0,0,0,.08);border-radius:12px;
  transition:all .3s;flex:1;max-width:48%;
}
.post-nav__link:hover{border-color:var(--red);box-shadow:0 4px 16px rgba(255,0,4,.08)}
.post-nav__link--next{text-align:right}
.post-nav__label{font-size:13px;font-weight:500;color:rgba(29,29,27,.45);display:flex;align-items:center;gap:6px;margin-bottom:6px}
.post-nav__link--next .post-nav__label{justify-content:flex-end}
.post-nav__title{font-size:15px;font-weight:600;color:var(--black);line-height:1.3}

/* Related posts */
.related-posts{background:var(--white);padding:20px 0 60px;display:flex;flex-direction:column;align-items:center}
.related-posts__inner{width:95%;max-width:1200px}
.related-posts__title{font-size:32px;font-weight:700;color:var(--black);text-align:center;margin-bottom:32px}

/* ======== CONTACTO PAGE ======== */
.page-hero--short{min-height:40vh}
.contacto{background:var(--white);padding:50px 0 60px;display:flex;flex-direction:column;align-items:center}
.contacto__inner{width:95%;max-width:1200px;display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:start}
.contacto__heading{font-size:32px;font-weight:700;color:var(--black);margin-bottom:8px}
.contacto__desc{font-size:16px;color:rgba(29,29,27,.55);margin-bottom:28px;line-height:1.5}

/* Contact form */
.contacto-form{display:flex;flex-direction:column;gap:20px}
.contacto-form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contacto-form__field{display:flex;flex-direction:column;gap:6px}
.contacto-form__field label{font-size:14px;font-weight:600;color:var(--primary)}
.contacto-form__field input,
.contacto-form__field select,
.contacto-form__field textarea{
  width:100%;padding:13px 16px;
  font-family:var(--font);font-size:15px;color:var(--primary);
  border:1.5px solid rgba(0,0,0,.12);border-radius:10px;
  background:var(--white);transition:border-color .3s;
  outline:none;
}
.contacto-form__field input:focus,
.contacto-form__field select:focus,
.contacto-form__field textarea:focus{border-color:var(--red)}
.contacto-form__field textarea{resize:vertical;min-height:120px}
.contacto-form__field select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231D1D1B' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;
}
.contacto-form__submit{align-self:flex-start;padding:14px 40px;font-size:16px;border-radius:10px}

/* Contact info */
.contacto__info{display:flex;flex-direction:column;gap:20px}
.contacto-info-card{
  background:var(--white);border-radius:16px;padding:28px;
  box-shadow:0 2px 16px rgba(0,0,0,.06);
}
.contacto-info-card__title{font-size:18px;font-weight:700;color:var(--black);margin-bottom:14px}
.contacto-info-card__list{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
.contacto-info-card__list li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:rgba(29,29,27,.7);line-height:1.4}
.contacto-info-card__list li a{color:rgba(29,29,27,.7);transition:color .3s}
.contacto-info-card__list li a:hover{color:var(--red)}
.contacto-info-card__list li i{color:var(--red);font-size:14px;margin-top:3px;flex-shrink:0;width:16px;text-align:center}
.contacto-info-card__hours{font-size:13px;color:rgba(29,29,27,.45);display:flex;align-items:center;gap:8px}
.contacto-info-card__hours i{color:var(--red);font-size:13px}
.contacto-info-card__socials{display:flex;flex-direction:column;gap:10px}
.contacto-info-card__socials a{
  display:flex;align-items:center;gap:10px;
  font-size:15px;font-weight:500;color:var(--primary);transition:color .3s;
}
.contacto-info-card__socials a:hover{color:var(--red)}
.contacto-info-card__socials a i{font-size:18px;width:20px;text-align:center}

/* Contact map */
.contacto-map{width:100%;height:400px}
.contacto-map iframe{width:100%;height:100%;border:0}

/* ======== CREDITOS PAGE ======== */
.creditos-page{background:var(--white);padding:50px 0 60px;display:flex;flex-direction:column;align-items:center}
.creditos-page__inner{width:95%;max-width:1200px}
.creditos-page__intro{text-align:center;max-width:750px;margin:0 auto 50px}
.creditos-page__heading{font-size:38px;font-weight:700;color:var(--black);line-height:1.15;margin-bottom:16px}
.creditos-page__desc{font-size:17px;font-weight:400;color:rgba(29,29,27,.65);line-height:1.6}

/* Credit option cards */
.creditos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px}
.credito-card{
  background:var(--white);border-radius:20px;padding:40px 32px;
  box-shadow:0 2px 20px rgba(0,0,0,.07);
  transition:transform .3s,box-shadow .3s;
}
.credito-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.12)}
.credito-card__icon{
  width:60px;height:60px;border-radius:15px;
  background:var(--red);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:20px;
}
.credito-card__title{font-size:22px;font-weight:700;color:var(--black);margin-bottom:12px}
.credito-card__desc{font-size:15px;color:rgba(29,29,27,.6);line-height:1.6;margin-bottom:20px}
.credito-card__list{display:flex;flex-direction:column;gap:10px}
.credito-card__list li{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:500;color:var(--primary)}
.credito-card__list li i{color:var(--green);font-size:13px;flex-shrink:0}

/* Process steps */
.creditos-process{text-align:center;margin-bottom:20px}
.creditos-process__title{font-size:38px;font-weight:700;color:var(--black);margin-bottom:40px}
.creditos-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.creditos-step{text-align:center;padding:24px 16px}
.creditos-step__number{
  width:56px;height:56px;border-radius:50%;
  background:var(--black);color:var(--white);
  font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.creditos-step__title{font-size:18px;font-weight:700;color:var(--black);margin-bottom:8px}
.creditos-step__desc{font-size:14px;color:rgba(29,29,27,.6);line-height:1.5}

/* FAQ */
.creditos-faq{background:var(--white);padding:60px 0;display:flex;flex-direction:column;align-items:center}
.creditos-faq__inner{width:95%;max-width:800px}
.creditos-faq__title{font-size:38px;font-weight:700;color:var(--black);text-align:center;margin-bottom:32px}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid rgba(0,0,0,.08);border-radius:12px;overflow:hidden;transition:box-shadow .3s}
.faq-item:hover{box-shadow:0 2px 12px rgba(0,0,0,.06)}
.faq-item__question{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;background:none;border:none;
  font-size:16px;font-weight:600;color:var(--primary);
  text-align:left;cursor:pointer;gap:16px;
  font-family:var(--font);
}
.faq-item__question i{font-size:12px;color:rgba(29,29,27,.4);transition:transform .3s}
.faq-item.open .faq-item__question i{transform:rotate(180deg)}
.faq-item__answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-item__answer{max-height:300px}
.faq-item__answer p{padding:0 24px 20px;font-size:15px;color:rgba(29,29,27,.6);line-height:1.6}

/* ======== ANIMATIONS ======== */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.slide-up{opacity:0;transform:translateY(40px);transition:opacity .6s ease,transform .6s ease}
.slide-up.visible{opacity:1;transform:translateY(0)}

/* ======== RESPONSIVE ======== */

/* --- Large tablets / small desktops --- */
@media(max-width:1024px){
  .dev-grid{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr 1fr;gap:24px}
  .footer__col-title{font-size:18px}
  .footer__links a{font-size:16px}
  .footer__desc{font-size:14px}
  .testimonials__grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .hero__title{font-size:36px}
  .hero__subtitle{font-size:24px}
  .desarrollos__title{font-size:35px}
  .precalificate__title,.testimonials__title,.blog-section__title,.about__title{font-size:36px}
  .footer__links a{font-size:18px}
  .dev-card{min-height:360px}
  .page-hero{min-height:55vh}
  .page-hero__title{font-size:38px}
  .desarrollos-page__heading{font-size:32px}
  .dev-grid--page{grid-template-columns:repeat(2,1fr)}
  .dev-card--page{min-height:360px}
  .creditos-grid{grid-template-columns:repeat(2,1fr)}
  .creditos-steps{grid-template-columns:repeat(2,1fr)}
  .creditos-page__heading,.creditos-process__title,.creditos-faq__title{font-size:32px}
  .sobre__row{flex-direction:column;gap:32px}
  .sobre__heading{font-size:30px}
  .sobre-mvv__inner{grid-template-columns:1fr 1fr}
  .sobre-presencia__grid{grid-template-columns:1fr 1fr}
  .sobre-presencia__title,.sobre-logos__title{font-size:32px}
  .sobre-counters__inner{gap:40px}
  .blog-archive__grid{grid-template-columns:repeat(2,1fr)}
  .contacto__inner{grid-template-columns:1fr;gap:40px}
  .post-nav__link{padding:16px 20px}
  .related-posts__title{font-size:28px}
  .about__counters{flex-wrap:wrap;gap:32px}
  .hero__content{padding:0 24px}
  .precalificate{padding:60px 32px}
  .menu-overlay__right{padding:60px 48px}
}

/* --- Tablets / small screens --- */
@media(max-width:768px){
  /* Menu overlay */
  .menu-overlay{flex-direction:column}
  .menu-overlay__left{width:100%;height:40vh;transform:translateY(-100%)}
  .menu-overlay.open .menu-overlay__left{transform:translateY(0)}
  .menu-overlay__right{width:100%;height:60vh;padding:40px 32px;transform:translateY(100%)}
  .menu-overlay.open .menu-overlay__right{transform:translateY(0)}
  .menu-overlay__links a{font-size:28px}
  .menu-overlay__logo img{width:8rem}
  .menu-overlay__socials{bottom:24px;right:32px}

  /* Top bar & header */
  .top-bar__inner{flex-direction:column;gap:8px;padding:8px 0}
  .top-bar__phones{flex-direction:row;gap:16px}
  .top-bar__phone{font-size:11px}
  .site-header__inner{padding:16px 0}
  .site-header__logo img{width:8rem}
  .menu-btn{font-size:16px}

  /* Hero */
  .hero{min-height:70vh;margin-bottom:-40px}
  .hero__content{padding:0 20px}
  .hero__title{font-size:26px;white-space:normal}
  .hero__subtitle{font-size:18px}
  .hero__buttons{flex-direction:column;align-items:center}
  .hero__video iframe,.hero__video>div{width:300vw;height:300vh}

  /* Logo carousel */
  .logo-carousel{width:95%;padding:16px}
  .logo-carousel .swiper-slide img{max-height:45px}

  /* Desarrollos */
  .desarrollos__inner{width:100%;padding:0 20px}
  .desarrollos__header{flex-direction:row;align-items:center}
  .desarrollos__logo img{width:120px}
  .desarrollos__title{font-size:30px}
  .tabs__btn{padding:8px 16px;font-size:13px}
  .dev-grid{grid-template-columns:1fr}
  .dev-card{min-height:300px}
  .dev-card__name{font-size:22px}

  /* Page hero */
  .page-hero{min-height:50vh}
  .page-hero__title{font-size:28px}
  .page-hero__subtitle{font-size:16px}
  .page-hero__content{padding:0 20px}

  /* Desarrollos page */
  .desarrollos-page{padding:30px 0 40px}
  .desarrollos-page__inner{width:100%;padding:0 20px}
  .desarrollos-page__intro{flex-direction:column;gap:20px;align-items:flex-start}
  .desarrollos-page__heading{font-size:26px}
  .desarrollos-page__desc{font-size:15px}
  .desarrollos-page__intro-logo img{width:120px}
  .dev-grid--page{grid-template-columns:1fr}
  .dev-card--page{min-height:300px}

  /* Créditos page */
  .creditos-page{padding:30px 0 40px}
  .creditos-page__inner{width:100%;padding:0 20px}
  .creditos-page__heading,.creditos-process__title,.creditos-faq__title{font-size:26px}
  .creditos-page__desc{font-size:15px}
  .creditos-grid{grid-template-columns:1fr}
  .creditos-steps{grid-template-columns:1fr;gap:16px}
  .credito-card{padding:32px 24px}
  .creditos-faq__inner{width:100%;padding:0 20px}
  .faq-item__question{padding:16px 20px;font-size:15px}
  .faq-item__answer p{padding:0 20px 16px;font-size:14px}

  /* Sobre page */
  .sobre{padding:30px 0}
  .sobre__inner,.sobre-mvv__inner,.sobre-presencia__inner,.sobre-logos__inner{width:100%;padding:0 20px}
  .sobre__heading{font-size:26px}
  .sobre__desc{font-size:15px}
  .sobre-counters{padding:32px 0}
  .sobre-counters__inner{gap:24px;flex-wrap:wrap}
  .sobre-counters .counter__number{font-size:36px}
  .sobre-counters .counter__label{font-size:16px}
  .sobre-mvv{padding:40px 0}
  .sobre-mvv__inner{grid-template-columns:1fr}
  .sobre-mvv__card{padding:32px 24px}
  .sobre-presencia{padding:40px 0}
  .sobre-presencia__title,.sobre-logos__title{font-size:26px}
  .sobre-presencia__grid{grid-template-columns:1fr}
  .presencia-card{min-height:240px}
  .sobre-logos{padding:40px 0}
  .sobre-logos__grid{gap:20px}
  .sobre-logos__item img{max-height:45px}

  /* Blog archive */
  .blog-archive{padding:30px 0 40px}
  .blog-archive__inner{width:100%;padding:0 20px}
  .blog-archive__grid{grid-template-columns:1fr}
  .blog-archive-card__title{font-size:18px}

  /* Single post */
  .single-post{padding:30px 0}
  .single-post__inner{width:100%;padding:0 20px}
  .single-post__content{font-size:16px}
  .single-post__content h2{font-size:22px}
  .post-nav__inner{width:100%;padding:0 20px;flex-direction:column}
  .post-nav__link{max-width:100%}
  .post-nav__link--next{text-align:left}
  .post-nav__link--next .post-nav__label{justify-content:flex-start}
  .related-posts__inner{width:100%;padding:0 20px}
  .related-posts__title{font-size:24px}

  /* Contacto */
  .contacto{padding:30px 0 40px}
  .contacto__inner{width:100%;padding:0 20px;grid-template-columns:1fr}
  .contacto__heading{font-size:26px}
  .contacto-form__row{grid-template-columns:1fr}
  .contacto-form__submit{width:100%}
  .contacto-map{height:280px}

  /* Precalificate */
  .precalificate{padding:40px 20px;min-height:auto}
  .precalificate__title{font-size:28px}
  .precalificate__text{font-size:16px}

  /* Testimonials / About / Blog section */
  .testimonials__inner,.blog-section__inner{width:95%}
  .about__inner{width:95%}
  .about__title,.testimonials__title,.blog-section__title{font-size:30px}
  .about__text{font-size:16px}
  .counter__number{font-size:36px}
  .counter__label{font-size:16px}
  .about__counters{flex-wrap:wrap;gap:24px;justify-content:center}
  .blog-grid{grid-template-columns:1fr}
  .blog-card__title{font-size:18px}

  /* Footer */
  .site-footer{padding:40px 20px}
  .footer__inner{grid-template-columns:1fr 1fr 1fr;gap:20px}
  .footer__logo{width:50%}
  .footer__col-title{font-size:16px}
  .footer__links a{font-size:14px}
  .footer__links--sub a{font-size:12px}
  .footer__desc{font-size:12px}
  .footer__bottom{padding:12px 20px;font-size:12px}

  /* Buttons */
  .btn{font-size:14px}

  /* Modal */
  .modal__inner{width:100%;max-width:100vw}
  .modal__logo{padding:40px 24px 8px}
  .modal__body{padding:0 24px 24px}
  .modal__location{padding:12px 24px}
  .modal__map-wrap{padding:0 24px}
  .modal__map-link{padding:8px 24px}
  .modal__contact{padding:8px 24px 24px}
}

/* --- Small phones --- */
@media(max-width:480px){
  /* Hero */
  .hero{min-height:60vh}
  .hero__title{font-size:22px}
  .hero__subtitle{font-size:16px}
  .hero__content{padding:0 16px}

  /* Top bar */
  .top-bar__socials a{width:30px;height:30px;font-size:15px}

  /* Menu */
  .menu-overlay__left{height:30vh}
  .menu-overlay__right{height:70vh;padding:32px 24px}
  .menu-overlay__links a{font-size:22px}
  .menu-overlay__links{gap:8px}
  .menu-overlay__socials{bottom:20px;right:24px;gap:16px}
  .menu-overlay__socials a{font-size:18px}
  .menu-overlay__logo img{width:6rem}

  /* Desarrollos */
  .dev-card{min-height:260px;border-radius:18px}
  .dev-card__name{font-size:20px}
  .dev-card__status{font-size:12px}
  .dev-card__btn{font-size:14px;padding:8px}
  .dev-card__content{padding:16px}
  .desarrollos__title{font-size:26px}
  .tabs__nav{gap:6px}
  .tabs__btn{padding:7px 12px;font-size:12px}

  /* Page hero */
  .page-hero{min-height:45vh}
  .page-hero__title{font-size:24px}
  .page-hero__subtitle{font-size:14px}

  /* Precalificate */
  .precalificate{padding:32px 16px}
  .precalificate__title{font-size:24px}
  .precalificate__text{font-size:14px}

  /* About / Counters */
  .about__title,.testimonials__title,.blog-section__title{font-size:24px}
  .about__text{font-size:14px}
  .about__counters{gap:16px}
  .counter__number{font-size:28px}
  .counter__label{font-size:13px}
  .about__logo{width:120px}

  /* Footer */
  .site-footer{padding:32px 16px;border-radius:18px 18px 0 0}
  .footer__inner{grid-template-columns:1fr;gap:20px}
  .footer__logo{width:30%}
  .footer__desc{font-size:14px}
  .footer__col-title{font-size:18px}
  .footer__links a{font-size:14px}
  .footer__links--sub a{font-size:13px}
  .footer__back-top{font-size:13px;padding:8px 20px}
  .footer__bottom{font-size:11px;padding:10px 16px}

  /* Blog cards */
  .blog-card__body{padding:16px}
  .blog-card__title{font-size:16px}

  /* Créditos */
  .creditos-page__heading,.creditos-process__title,.creditos-faq__title{font-size:22px}
  .credito-card{padding:24px 20px}

  /* Sobre */
  .sobre__heading{font-size:22px}
  .sobre-presencia__title,.sobre-logos__title{font-size:22px}
  .sobre-counters .counter__number{font-size:28px}
  .sobre-counters .counter__label{font-size:13px}

  /* Contacto */
  .contacto__heading{font-size:22px}

  /* Modal */
  .modal__logo{padding:32px 20px 8px}
  .modal__body{padding:0 20px 20px}
  .modal__desc{font-size:13px}
  .modal__btn{font-size:12px;padding:12px}
  .modal__location{padding:10px 20px;font-size:12px}
  .modal__map-wrap{padding:0 20px}
  .modal__map{height:180px}
  .modal__map-link{padding:8px 20px;font-size:12px}
  .modal__contact{padding:8px 20px 20px;font-size:12px}

  /* Single post */
  .single-post__content h2{font-size:20px}
  .single-post__content{font-size:15px}
  .related-posts__title{font-size:20px}

  /* Blog archive */
  .blog-archive-card__title{font-size:16px}
}

/* --- Extra small phones (iPhone SE, etc.) --- */
@media(max-width:360px){
  .hero__title{font-size:20px}
  .hero__subtitle{font-size:14px}
  .hero{min-height:55vh}
  .dev-card{min-height:220px;border-radius:14px}
  .dev-card__name{font-size:18px}
  .desarrollos__title{font-size:22px}
  .menu-overlay__links a{font-size:20px}
  .menu-overlay__right{padding:28px 20px}
  .about__counters{flex-direction:column;align-items:center}
  .tabs__btn{padding:6px 10px;font-size:11px}
  .precalificate__title{font-size:22px}
  .footer__logo{width:70%}
  .page-hero__title{font-size:22px}
}

/* ========================================================================
   AGORA HIGH LIFE — Modern Development Page
   Brand: Black + white, rounded, glassmorphism, modern UI
   ======================================================================== */

/* Shared label */
.agora-label{
  display:inline-block;font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:3px;
  color:rgba(26,26,26,.35);margin-bottom:14px;
}
.agora-label--light{color:rgba(255,255,255,.5)}

/* Agora Buttons */
.agora-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 36px;font-size:15px;font-weight:600;
  font-family:var(--font);letter-spacing:.3px;
  border:none;border-radius:60px;cursor:pointer;
  transition:all .35s cubic-bezier(.4,0,.2,1);text-decoration:none;
}
.agora-btn--dark{background:#1a1a1a;color:#fff}
.agora-btn--dark:hover{background:#333;transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.2)}
.agora-btn--white{background:#fff;color:#1a1a1a}
.agora-btn--white:hover{background:#f5f5f5;transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.15)}
.agora-btn--glass{
  background:rgba(255,255,255,.12);color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.agora-btn--glass:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.agora-btn--full{width:100%}

/* ===== HERO ===== */
.agora-hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
  background-size:cover;background-position:center;
}
.agora-hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.6) 100%);
}
.agora-hero__content{
  position:relative;z-index:2;
  max-width:800px;padding:0 40px;
  display:flex;flex-direction:column;align-items:center;
}
.agora-hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 24px;border-radius:50px;
  font-size:13px;font-weight:600;color:#fff;
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.15);
  margin-bottom:28px;
}
.agora-hero__badge-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px rgba(74,222,128,.6)}
.agora-hero__title{
  font-size:60px;font-weight:600;color:#fff;
  line-height:1.05;margin-bottom:20px;
  letter-spacing:-2px;
}
.agora-hero__subtitle{
  font-size:18px;font-weight:400;color:rgba(255,255,255,.75);
  line-height:1.7;max-width:520px;margin-bottom:40px;
}
.agora-hero__ctas{display:flex;gap:14px}
.agora-hero__scroll{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;
}
.agora-hero__scroll span{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.agora-hero__scroll-line{width:1px;height:40px;background:rgba(255,255,255,.25);position:relative;overflow:hidden}
.agora-hero__scroll-line::after{
  content:'';position:absolute;top:-100%;left:0;width:100%;height:50%;
  background:#fff;animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{0%{top:-50%}100%{top:150%}}

/* ===== BRAND SECTION ===== */
.agora-brand{background:#fafafa;padding:110px 0;display:flex;justify-content:center}
.agora-brand__inner{
  width:95%;max-width:800px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.agora-brand__logo{width:340px;height:auto;margin-bottom:28px}
.agora-brand__divider{width:48px;height:2px;background:#1a1a1a;margin-bottom:28px}
.agora-brand__tagline{
  font-size:40px;font-weight:600;color:#1a1a1a;
  line-height:1.15;margin-bottom:14px;
  letter-spacing:-1px;
}
.agora-brand__subtitle{
  font-size:17px;font-weight:400;color:rgba(26,26,26,.45);
  letter-spacing:.3px;
}

/* ===== VALUE PROPOSITION ===== */
.agora-value{background:#fff;padding:100px 0;display:flex;justify-content:center}
.agora-value__inner{
  width:95%;max-width:1200px;
  display:flex;align-items:center;gap:70px;
}
.agora-value__text{flex:1;min-width:280px}
.agora-value__heading{
  font-size:44px;font-weight:600;color:#1a1a1a;
  line-height:1.1;margin-bottom:24px;
  letter-spacing:-1px;
}
.agora-value__desc{
  font-size:17px;font-weight:400;color:rgba(26,26,26,.55);
  line-height:1.75;margin-bottom:16px;
}
.agora-value__desc:last-of-type{margin-bottom:36px}
.agora-value__image{flex:1;min-width:280px}
.agora-value__image img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.1)}

/* ===== BENTO GALLERY ===== */
.agora-gallery{background:#fff;padding:0 0 100px;display:flex;justify-content:center}
.agora-gallery__inner{width:95%;max-width:1200px}
.agora-gallery__header{margin-bottom:40px}
.agora-gallery__title{font-size:40px;font-weight:600;color:#1a1a1a;letter-spacing:-1px}
.agora-bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:220px;
  gap:16px;
}
.agora-bento__item{
  position:relative;border-radius:20px;overflow:hidden;cursor:pointer;
}
.agora-bento__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.agora-bento__item:hover img{transform:scale(1.06)}
.agora-bento__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%);
  display:flex;align-items:flex-end;padding:20px;
  opacity:0;transition:opacity .35s ease;
}
.agora-bento__item:hover .agora-bento__overlay{opacity:1}
.agora-bento__overlay span{
  font-size:14px;font-weight:600;color:#fff;letter-spacing:.5px;
  background:rgba(0,0,0,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:8px 18px;border-radius:50px;
}
.agora-bento__item--tall{grid-row:span 2}
.agora-bento__item--wide{grid-column:span 2}

/* ===== CLAIM ===== */
.agora-claim{
  position:relative;min-height:55vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  background-size:cover;background-position:center;
  background-attachment:fixed;
}
.agora-claim__overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);z-index:1}
.agora-claim__content{position:relative;z-index:2;max-width:700px;padding:80px 40px}
.agora-claim__title{
  font-size:48px;font-weight:600;color:#fff;
  line-height:1.1;margin-bottom:20px;
  letter-spacing:-1.5px;
}
.agora-claim__text{font-size:18px;font-weight:400;color:rgba(255,255,255,.65);line-height:1.7}

/* ===== MODELS / FLOOR PLANS ===== */
.agora-models{background:#fafafa;padding:100px 0;display:flex;flex-direction:column;align-items:center}
.agora-models__inner{width:95%;max-width:1100px}
.agora-models__header{text-align:center;margin-bottom:48px}
.agora-models__title{
  font-size:40px;font-weight:600;color:#1a1a1a;
  letter-spacing:-1px;
}

/* Agora Tabs */
.agora-tabs__nav{
  display:flex;gap:8px;margin-bottom:40px;
  justify-content:center;flex-wrap:wrap;
}
.agora-tabs__btn{
  padding:12px 24px;font-size:13px;font-weight:600;
  font-family:var(--font);letter-spacing:.5px;
  color:rgba(26,26,26,.5);background:#fff;
  border:1.5px solid rgba(0,0,0,.08);border-radius:50px;
  transition:all .3s;cursor:pointer;
}
.agora-tabs__btn:hover{color:#1a1a1a;border-color:rgba(0,0,0,.2)}
.agora-tabs__btn.active{color:#fff;background:#1a1a1a;border-color:#1a1a1a}
.agora-tabs__panel{display:none}
.agora-tabs__panel.active{display:block}

/* Model card */
.agora-model{
  display:flex;align-items:center;gap:60px;
  background:#fff;border-radius:28px;padding:48px;
  box-shadow:0 4px 30px rgba(0,0,0,.06);
}
.agora-model__plan{flex:1;display:flex;align-items:center;justify-content:center}
.agora-model__plan img{max-width:100%;max-height:400px;object-fit:contain}
.agora-model__info{flex:1;min-width:280px}
.agora-model__type{
  display:inline-block;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:2.5px;
  color:#fff;background:#1a1a1a;
  padding:6px 16px;border-radius:50px;
  margin-bottom:16px;
}
.agora-model__name{font-size:38px;font-weight:600;color:#1a1a1a;margin-bottom:4px;letter-spacing:-1px}
.agora-model__size{
  font-size:26px;font-weight:700;color:#1a1a1a;
  margin-bottom:28px;
}
.agora-model__features{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.agora-model__features li{
  display:flex;align-items:center;gap:12px;
  font-size:15px;color:rgba(26,26,26,.65);
}
.agora-model__features li i{color:#4ade80;font-size:14px;flex-shrink:0}

/* ===== DEVELOPER ===== */
.agora-developer{background:#fff;padding:90px 0;display:flex;justify-content:center}
.agora-developer__inner{
  width:95%;max-width:700px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.agora-developer__logo{width:150px;height:auto;margin-bottom:24px;opacity:.7}
.agora-developer__title{
  font-size:30px;font-weight:400;color:#1a1a1a;
  margin-bottom:12px;letter-spacing:-.5px;
}
.agora-developer__title strong{font-weight:700}
.agora-developer__text{font-size:16px;color:rgba(26,26,26,.45);line-height:1.6}

/* ===== CTA ===== */
.agora-cta{
  position:relative;min-height:60vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  background-size:cover;background-position:center;
}
.agora-cta__overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);z-index:1}
.agora-cta__content{position:relative;z-index:2;max-width:650px;padding:80px 40px}
.agora-cta__title{
  font-size:48px;font-weight:600;color:#fff;
  line-height:1.1;margin-bottom:20px;
  letter-spacing:-1.5px;
}
.agora-cta__text{font-size:18px;font-weight:400;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:40px}
.agora-cta__buttons{display:flex;gap:14px;justify-content:center}

/* ===== LOCATION ===== */
.agora-location{background:#fafafa;padding:100px 0;display:flex;flex-direction:column;align-items:center}
.agora-location__inner{width:95%;max-width:1100px}
.agora-location__header{text-align:center;margin-bottom:48px}
.agora-location__title{
  font-size:40px;font-weight:600;color:#1a1a1a;
  margin-bottom:12px;letter-spacing:-1px;
}
.agora-location__desc{font-size:17px;color:rgba(26,26,26,.5);line-height:1.6;max-width:550px;margin:0 auto}
.agora-location__map{border-radius:24px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.08);margin-bottom:32px}
.agora-location__map iframe{width:100%;height:420px;border:0}
.agora-location__info{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.agora-location__card{
  display:flex;align-items:flex-start;gap:16px;
  background:#fff;padding:24px;border-radius:20px;
  box-shadow:0 2px 16px rgba(0,0,0,.04);
  transition:transform .3s,box-shadow .3s;
}
.agora-location__card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.08)}
.agora-location__card i{
  font-size:18px;color:#1a1a1a;
  width:44px;height:44px;border-radius:14px;
  background:#f0f0f0;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.agora-location__card strong{font-size:14px;font-weight:700;color:#1a1a1a;display:block;margin-bottom:4px}
.agora-location__card p{font-size:14px;color:rgba(26,26,26,.5);margin:0;line-height:1.4}
.agora-location__card a{color:rgba(26,26,26,.5);transition:color .3s}
.agora-location__card a:hover{color:#1a1a1a}

/* ===== FORM SECTION ===== */
.agora-form-section{background:#1a1a1a;padding:100px 0;display:flex;justify-content:center}
.agora-form-section__inner{
  width:95%;max-width:1100px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.agora-form-section__title{
  font-size:40px;font-weight:600;color:#fff;
  margin-bottom:16px;letter-spacing:-1px;line-height:1.1;
}
.agora-form-section__desc{
  font-size:16px;color:rgba(255,255,255,.45);line-height:1.7;
  margin-bottom:32px;
}
.agora-form-section__logo{width:200px;height:auto;opacity:.3}
.agora-form{display:flex;flex-direction:column;gap:16px}
.agora-form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.agora-form__field label{
  display:block;font-size:12px;font-weight:600;
  color:rgba(255,255,255,.4);text-transform:uppercase;
  letter-spacing:1px;margin-bottom:8px;
}
.agora-form__field input,
.agora-form__field select,
.agora-form__field textarea{
  width:100%;padding:16px 20px;
  font-family:var(--font);font-size:15px;color:#fff;
  border:1.5px solid rgba(255,255,255,.1);border-radius:14px;
  background:rgba(255,255,255,.06);outline:none;
  transition:all .3s;
}
.agora-form__field input::placeholder,
.agora-form__field textarea::placeholder{color:rgba(255,255,255,.25)}
.agora-form__field input:focus,
.agora-form__field select:focus,
.agora-form__field textarea:focus{
  border-color:rgba(255,255,255,.35);
  background:rgba(255,255,255,.1);
}
.agora-form__field select{
  cursor:pointer;appearance:none;color:rgba(255,255,255,.6);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,.4)' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 20px center;padding-right:44px;
}
.agora-form__field textarea{resize:vertical;min-height:110px}

/* ===== AGORA RESPONSIVE ===== */
@media(max-width:1024px){
  .agora-hero{min-height:85vh}
  .agora-hero__title{font-size:44px}
  .agora-brand{padding:80px 0}
  .agora-brand__logo{width:260px}
  .agora-brand__tagline{font-size:32px}
  .agora-value{padding:80px 0}
  .agora-value__inner{flex-direction:column;gap:48px}
  .agora-value__heading{font-size:36px}
  .agora-bento{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .agora-bento__item--tall{grid-row:span 2}
  .agora-claim__title{font-size:38px}
  .agora-models{padding:80px 0}
  .agora-models__title{font-size:34px}
  .agora-model{flex-direction:column;gap:40px;padding:36px}
  .agora-model__plan img{max-height:320px}
  .agora-location{padding:80px 0}
  .agora-location__title{font-size:34px}
  .agora-location__info{grid-template-columns:1fr}
  .agora-cta__title{font-size:38px}
  .agora-form-section__inner{grid-template-columns:1fr;gap:40px}
}
@media(max-width:768px){
  .agora-hero{min-height:85vh}
  .agora-hero__content{padding:0 20px}
  .agora-hero__title{font-size:34px;letter-spacing:-1px}
  .agora-hero__subtitle{font-size:15px}
  .agora-hero__ctas{flex-direction:column;width:100%}
  .agora-hero__ctas .agora-btn{text-align:center}
  .agora-hero__scroll{display:none}
  .agora-brand{padding:60px 0}
  .agora-brand__inner{width:100%;padding:0 20px}
  .agora-brand__logo{width:180px}
  .agora-brand__tagline{font-size:26px}
  .agora-value{padding:60px 0}
  .agora-value__inner{width:100%;padding:0 20px;flex-direction:column;gap:32px}
  .agora-value__heading{font-size:30px}
  .agora-value__desc{font-size:15px}
  .agora-gallery{padding:0 0 60px}
  .agora-gallery__inner{width:100%;padding:0 20px}
  .agora-gallery__title{font-size:30px}
  .agora-bento{grid-template-columns:1fr;grid-auto-rows:200px}
  .agora-bento__item--tall{grid-row:span 1}
  .agora-bento__item--wide{grid-column:span 1}
  .agora-claim__content{padding:60px 20px}
  .agora-claim__title{font-size:30px}
  .agora-claim{background-attachment:scroll}
  .agora-models{padding:60px 0}
  .agora-models__inner{width:100%;padding:0 20px}
  .agora-models__title{font-size:28px}
  .agora-tabs__nav{gap:6px;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .agora-tabs__nav::-webkit-scrollbar{display:none}
  .agora-tabs__btn{padding:10px 16px;font-size:12px;white-space:nowrap;flex-shrink:0}
  .agora-model{flex-direction:column;gap:28px;padding:28px 24px;border-radius:20px}
  .agora-model__plan img{max-height:250px}
  .agora-model__name{font-size:28px}
  .agora-model__size{font-size:22px;margin-bottom:20px}
  .agora-developer{padding:60px 0}
  .agora-developer__inner{width:100%;padding:0 20px}
  .agora-developer__title{font-size:24px}
  .agora-cta__content{padding:60px 20px}
  .agora-cta__title{font-size:30px}
  .agora-cta__buttons{flex-direction:column;width:100%}
  .agora-cta__buttons .agora-btn{text-align:center}
  .agora-location{padding:60px 0}
  .agora-location__inner{width:100%;padding:0 20px}
  .agora-location__title{font-size:28px}
  .agora-location__map{border-radius:16px}
  .agora-location__map iframe{height:280px}
  .agora-form-section{padding:60px 0}
  .agora-form-section__inner{width:100%;padding:0 20px;grid-template-columns:1fr;gap:32px}
  .agora-form-section__title{font-size:28px}
  .agora-form-section__logo{width:140px}
  .agora-form__row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .agora-hero{min-height:80vh}
  .agora-hero__title{font-size:28px}
  .agora-hero__subtitle{font-size:14px}
  .agora-hero__content{padding:0 16px}
  .agora-brand__tagline{font-size:22px}
  .agora-brand__logo{width:140px}
  .agora-brand__inner{padding:0 16px}
  .agora-value__inner{padding:0 16px}
  .agora-value__heading{font-size:24px}
  .agora-gallery__inner{padding:0 16px}
  .agora-gallery__title{font-size:24px}
  .agora-bento{gap:10px;grid-auto-rows:180px}
  .agora-claim__content{padding:50px 16px}
  .agora-claim__title{font-size:24px}
  .agora-claim__text{font-size:15px}
  .agora-models__inner{padding:0 16px}
  .agora-models__title{font-size:24px}
  .agora-tabs__btn{padding:8px 14px;font-size:11px}
  .agora-model{padding:24px 20px}
  .agora-model__name{font-size:24px}
  .agora-model__features li{font-size:14px}
  .agora-location__inner{padding:0 16px}
  .agora-location__title{font-size:24px}
  .agora-location__map iframe{height:220px}
  .agora-cta__content{padding:50px 16px}
  .agora-cta__title{font-size:24px}
  .agora-cta__text{font-size:15px}
  .agora-form-section__inner{padding:0 16px}
  .agora-form-section__title{font-size:24px}
  .agora-form-section__desc{font-size:14px}
  .agora-btn{padding:14px 28px;font-size:14px}
}

/* ========================================================================
   ALBORADA RESIDENCIAL — Basalto-style Design
   Brand: Navy (#1e2a5e) + Gold (#c8872e), off-white, charcoal, modern rounded
   ======================================================================== */

/* --- Alborada Design Tokens --- */
.alb-hero,.alb-stats,.alb-about,.alb-amenidades,.alb-gal,.alb-modelo,.alb-ubicacion,.alb-contacto{
  --a-dark:#141e47;--a-mid:#1e2a5e;--a-acc:#c8872e;--a-light:#f5efe6;
  --charcoal:#1a1a1a;--gray-d:#2d2d2d;--gray-m:#595959;--gray-l:#8a8a8a;
  --off-white:#f6f6f1;--border:#e5e5e0;
  --r-xs:8px;--r-sm:14px;--r-md:20px;--r-lg:28px;--r-xl:40px;--r-pill:999px;
  --shadow-xs:0 2px 12px rgba(0,0,0,.06);--shadow-sm:0 4px 24px rgba(0,0,0,.08);
  --shadow-md:0 8px 40px rgba(0,0,0,.12);--shadow-lg:0 20px 64px rgba(0,0,0,.16);
  --ease:cubic-bezier(.4,0,.2,1);--dur:.35s;
}

/* --- Typography --- */
.alb-eyebrow{display:block;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--a-acc);margin-bottom:14px}
.alb-eyebrow--light{color:rgba(255,255,255,.5)}
.alb-section-title{font-size:clamp(30px,4vw,50px);font-weight:800;letter-spacing:-.025em;line-height:1.1;color:var(--charcoal)}
.alb-section-title--light{color:#fff}
.alb-divider{width:44px;height:3px;background:var(--a-acc);border-radius:var(--r-pill);margin:18px 0 28px}
.alb-divider.center{margin-inline:auto}
.alb-divider--light{background:var(--a-acc)}

/* --- Buttons --- */
.alb-btn-p,.alb-btn-o,.alb-btn-wa{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 34px;border-radius:var(--r-pill);
  font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  border:none;cursor:pointer;transition:transform var(--dur) var(--ease),background var(--dur),box-shadow var(--dur);text-decoration:none;
}
.alb-btn-p{background:var(--a-acc);color:#fff}
.alb-btn-p:hover{background:var(--a-mid);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.alb-btn-p--full{width:100%}
.alb-btn-o{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.alb-btn-o:hover{background:rgba(255,255,255,.1);border-color:#fff;transform:translateY(-2px)}
.alb-btn-wa{background:#22c55e;color:#fff}
.alb-btn-wa:hover{background:#16a34a;transform:translateY(-2px);box-shadow:var(--shadow-sm)}

/* --- Animations --- */
@keyframes albFadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.alb-hero .anim{opacity:0;animation:albFadeUp .7s var(--ease) forwards;animation-delay:var(--d,0s)}
.alb-hero .reveal,.alb-stats .reveal,.alb-about .reveal,.alb-amenidades .reveal,
.alb-gal .reveal,.alb-ubicacion .reveal,.alb-contacto .reveal{
  opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s!important}.d2{transition-delay:.2s!important}.d3{transition-delay:.3s!important}

/* ===== HERO ===== */
.alb-hero{
  position:relative;min-height:100vh;overflow:hidden;
  display:flex;align-items:center;
  background-size:cover;background-position:center;
}
.alb-hero__ov{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(115deg,rgba(20,30,71,.9) 0%,rgba(14,14,14,.55) 52%,rgba(0,0,0,.18) 100%);
}
.alb-hero__content{position:relative;z-index:2;padding:0 64px;max-width:720px}
.alb-hero__logo{width:260px;height:auto;margin-bottom:20px;filter:brightness(0) invert(1)}
.alb-hero h1{font-size:clamp(36px,5vw,64px);font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1.05;margin-bottom:20px}
.alb-hero h1 em{font-style:normal;color:var(--a-acc)}
.alb-hero__tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}
.alb-hero__tag{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 18px;border-radius:var(--r-pill);
  font-size:12px;font-weight:600;color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.alb-hero__tag i{font-size:13px;color:var(--a-acc)}
.alb-hero__btns{display:flex;gap:12px;flex-wrap:wrap}
.alb-hero__stat{
  position:absolute;bottom:48px;right:64px;z-index:2;
  display:flex;gap:2px;
}
.alb-hero__stat-item{
  padding:20px 28px;text-align:center;
  background:rgba(255,255,255,.08);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.14);
}
.alb-hero__stat-item:first-child{border-radius:var(--r-lg) 0 0 var(--r-lg)}
.alb-hero__stat-item:last-child{border-radius:0 var(--r-lg) var(--r-lg) 0}
.alb-hero__stat-num{display:block;font-size:28px;font-weight:800;color:#fff;letter-spacing:-.02em}
.alb-hero__stat-lbl{font-size:11px;font-weight:500;color:rgba(255,255,255,.55);letter-spacing:1px;text-transform:uppercase;margin-top:4px}

/* ===== STATS BAR ===== */
.alb-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--a-dark);padding:56px 20px;
}
.alb-stats__item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.alb-stats__icon{font-size:22px;color:var(--a-acc)}
.alb-stats__num{font-size:36px;font-weight:800;color:#fff;letter-spacing:-.02em}
.alb-stats__lbl{font-size:12px;font-weight:500;color:var(--gray-l);text-transform:uppercase;letter-spacing:1.5px}

/* ===== ABOUT ===== */
.alb-about{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:580px;background:var(--off-white);
}
.alb-about__media{overflow:hidden}
.alb-about__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.alb-about__media:hover img{transform:scale(1.04)}
.alb-about__text{padding:80px 64px;display:flex;flex-direction:column;justify-content:center}
.alb-about__text p{font-size:16px;color:var(--gray-m);line-height:1.75;margin-bottom:16px}

/* ===== AMENIDADES ===== */
.alb-amenidades{background:#fff;padding:100px 64px;display:flex;flex-direction:column;align-items:center}
.alb-amenidades__header{text-align:center;max-width:600px;margin-bottom:56px}
.alb-amenidades__header p{font-size:16px;color:var(--gray-m);line-height:1.6}
.alb-amenidades__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;width:100%;max-width:1200px}
.alb-amenity-card{
  position:relative;background:var(--off-white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:36px 28px;text-align:center;overflow:hidden;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur),border-color var(--dur);
}
.alb-amenity-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--a-mid),var(--a-dark));
  opacity:0;transition:opacity var(--dur);border-radius:inherit;z-index:0;
}
.alb-amenity-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.alb-amenity-card:hover::before{opacity:1}
.alb-amenity-card>*{position:relative;z-index:1}
.alb-amenity-card__icon{
  width:52px;height:52px;border-radius:var(--r-md);
  background:var(--a-light);color:var(--a-mid);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:16px;
  transition:background var(--dur),color var(--dur);
}
.alb-amenity-card:hover .alb-amenity-card__icon{background:rgba(255,255,255,.15);color:#fff}
.alb-amenity-card h4{font-size:16px;font-weight:700;color:var(--charcoal);margin-bottom:6px;transition:color var(--dur)}
.alb-amenity-card p{font-size:13px;color:var(--gray-l);line-height:1.5;transition:color var(--dur)}
.alb-amenity-card:hover h4,.alb-amenity-card:hover p{color:#fff}

/* ===== GALERIA ===== */
.alb-gal{padding:80px 60px;background:#fff}
.alb-gal__grid{
  display:grid;grid-template-columns:3fr 2fr 2fr;gap:12px;
}
.alb-gal__main,.alb-gal__item{border-radius:var(--r-xl);overflow:hidden}
.alb-gal__main img,.alb-gal__item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.alb-gal__main:hover img,.alb-gal__item:hover img{transform:scale(1.06)}
.alb-gal__main{min-height:500px}
.alb-gal__col{display:flex;flex-direction:column;gap:12px}
.alb-gal__item{min-height:240px}

/* ===== MODELOS ===== */
.alb-modelo{background:var(--a-mid);padding:100px 64px;display:flex;flex-direction:column;align-items:center}
.alb-modelo__header{text-align:center;margin-bottom:48px}
.alb-modelo__tabs{width:100%;max-width:1100px}
.alb-tabs-nav{justify-content:center;margin-bottom:40px;gap:8px;border:none;border-bottom:none}
.alb-tab-btn{background:rgba(255,255,255,.06)!important;color:rgba(255,255,255,.5)!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:var(--r-pill)!important}
.alb-tab-btn:hover{color:#fff!important;border-color:rgba(255,255,255,.25)!important}
.alb-tab-btn.active{background:var(--a-acc)!important;color:#fff!important;border-color:var(--a-acc)!important}
.alb-modelo__card{
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--a-dark);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.alb-modelo__img{overflow:hidden}
.alb-modelo__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.alb-modelo__img:hover img{transform:scale(1.04)}
.alb-modelo__info{padding:56px 48px;display:flex;flex-direction:column;justify-content:center}
.alb-modelo__badge{
  display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2px;
  color:#fff;background:var(--a-acc);padding:5px 14px;border-radius:var(--r-pill);margin-bottom:16px;width:fit-content;
}
.alb-modelo__name{font-size:36px;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:4px}
.alb-modelo__size{font-size:26px;font-weight:700;color:var(--a-acc);margin-bottom:24px}
.alb-modelo__specs{display:flex;gap:20px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08)}
.alb-modelo__specs span{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:rgba(255,255,255,.6)}
.alb-modelo__specs i{color:var(--a-acc);font-size:14px}
.alb-modelo__features{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.alb-modelo__features li{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.6)}
.alb-modelo__features i{color:var(--a-acc);font-size:12px;flex-shrink:0}

/* ===== UBICACION ===== */
.alb-ubicacion{background:var(--off-white);padding:100px 64px;display:flex;justify-content:center}
.alb-ubicacion__inner{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;max-width:1200px;width:100%;align-items:start}
.alb-ubicacion__text p{font-size:16px;color:var(--gray-m);line-height:1.75;margin-bottom:24px}
.alb-poi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
.alb-poi{
  display:flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:var(--r-pill);
  background:#fff;border:1px solid var(--border);
  font-size:13px;font-weight:500;color:var(--charcoal);
  transition:all var(--dur) var(--ease);
}
.alb-poi:hover{background:var(--a-light);color:var(--a-dark);border-color:var(--a-acc);transform:translateY(-2px)}
.alb-poi i{color:var(--a-acc);font-size:14px}
.alb-address{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border-radius:var(--r-pill);
  background:var(--a-mid);color:#fff;font-size:13px;font-weight:500;
}
.alb-address i{color:var(--a-acc)}
.alb-ubicacion__map{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md)}
.alb-ubicacion__map iframe{width:100%;height:100%;min-height:480px;border:0}

/* ===== CONTACTO ===== */
.alb-contacto{background:#fff;padding:100px 64px;display:flex;justify-content:center}
.alb-contacto__inner{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;max-width:1200px;width:100%;align-items:start}
.alb-contacto__info p{font-size:16px;color:var(--gray-m);line-height:1.75;margin-bottom:24px}
.alb-contacto__details{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}
.alb-contacto__detail{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--gray-m)}
.alb-contacto__detail i{color:var(--a-acc);font-size:16px;width:20px;text-align:center}
.alb-contacto__detail a{color:var(--gray-m);transition:color .3s}
.alb-contacto__detail a:hover{color:var(--a-mid)}
.alb-contacto__form-wrap{
  background:var(--off-white);border-radius:var(--r-xl);padding:48px;
  border:1px solid var(--border);
}
.alb-contacto__form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.alb-fg{display:flex;flex-direction:column;gap:6px}
.alb-fg--full{grid-column:span 2}
.alb-fg label{font-size:12px;font-weight:600;color:var(--gray-m);text-transform:uppercase;letter-spacing:1px}
.alb-fg input,.alb-fg select,.alb-fg textarea{
  width:100%;padding:14px 18px;font-family:var(--font);font-size:14px;
  border:1.5px solid var(--border);border-radius:var(--r-pill);
  background:#fff;color:var(--charcoal);outline:none;transition:border-color .3s,box-shadow .3s;
}
.alb-fg textarea{border-radius:var(--r-lg);min-height:100px;resize:vertical}
.alb-fg input:focus,.alb-fg select:focus,.alb-fg textarea:focus{border-color:var(--a-acc);box-shadow:0 0 0 3px rgba(200,135,46,.1)}
.alb-fg select{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23595959' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 18px center;padding-right:40px;
}
.alb-contacto__form .alb-btn-p{grid-column:span 2}

/* ===== WA FLOAT ===== */
.alb-wa-float{
  position:fixed;bottom:28px;right:28px;z-index:999;
  width:60px;height:60px;border-radius:50%;
  background:#22c55e;color:#fff;font-size:28px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(34,197,94,.4);
  transition:transform .35s,box-shadow .35s;
}
.alb-wa-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(34,197,94,.5)}

/* ===== ALBORADA RESPONSIVE ===== */
@media(max-width:1200px){
  .alb-hero__content{padding:0 40px}
  .alb-hero__stat{display:none}
  .alb-amenidades,.alb-modelo,.alb-ubicacion,.alb-contacto{padding-left:40px;padding-right:40px}
  .alb-gal{padding:60px 40px}
  .alb-modelo__specs{gap:14px}
  .alb-modelo__specs span{font-size:12px;white-space:nowrap}
  .alb-modelo__info{padding:40px 28px}
}
@media(max-width:960px){
  .alb-hero{justify-content:center}
  .alb-hero__content{text-align:center;display:flex;flex-direction:column;align-items:center;padding:0 40px;max-width:none}
  .alb-hero__tags{justify-content:center}
  .alb-hero__btns{justify-content:center}
  .alb-about{grid-template-columns:1fr}
  .alb-about__media{max-height:400px}
  .alb-about__text{padding:48px 40px}
  .alb-amenidades__grid{grid-template-columns:repeat(2,1fr)}
  .alb-gal__grid{grid-template-columns:1fr 1fr}
  .alb-gal__main{grid-column:span 2;min-height:350px}
  .alb-modelo__card{grid-template-columns:1fr}
  .alb-modelo__img{max-height:350px}
  .alb-modelo__info{padding:40px 36px}
  .alb-ubicacion__inner{grid-template-columns:1fr;gap:40px}
  .alb-ubicacion__map iframe{min-height:350px}
  .alb-contacto__inner{grid-template-columns:1fr;gap:40px}
  .alb-stats{grid-template-columns:repeat(2,1fr);gap:24px}
}
@media(max-width:640px){
  .alb-hero__content{padding:0 20px;text-align:center;display:flex;flex-direction:column;align-items:center}
  .alb-hero__logo{width:160px}
  .alb-hero h1{font-size:26px}
  .alb-hero__tags{justify-content:center}
  .alb-hero__btns{flex-direction:column;width:100%;align-items:center}
  .alb-hero__btns .alb-btn-p,.alb-hero__btns .alb-btn-o{width:100%;justify-content:center}
  .alb-stats{padding:36px 20px}
  .alb-stats__num{font-size:28px}
  .alb-about__text{padding:32px 20px}
  .alb-amenidades,.alb-modelo,.alb-ubicacion,.alb-contacto{padding-left:20px;padding-right:20px}
  .alb-tabs-nav{flex-wrap:nowrap;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;padding-bottom:8px;scrollbar-width:none}
  .alb-tabs-nav::-webkit-scrollbar{display:none}
  .alb-tab-btn{font-size:13px;padding:10px 18px;white-space:nowrap;flex-shrink:0}
  .alb-modelo__card{grid-template-columns:1fr}
  .alb-modelo__info{padding:28px 20px}
  .alb-modelo__info .alb-btn-p{padding:12px 24px;font-size:11px}
  .alb-modelo__specs{flex-wrap:wrap;gap:12px;font-size:13px}
  .alb-modelo__features{font-size:13px}
  .alb-modelo__features li{white-space:normal;word-break:break-word;font-size:13px}
  .alb-amenidades__grid{grid-template-columns:1fr}
  .alb-gal{padding:48px 20px}
  .alb-gal__grid{grid-template-columns:1fr}
  .alb-gal__main{grid-column:span 1;min-height:250px}
  .alb-gal__item{min-height:180px}
  .alb-poi-grid{grid-template-columns:1fr}
  .alb-contacto__form{grid-template-columns:1fr}
  .alb-fg--full,.alb-contacto__form .alb-btn-p{grid-column:span 1}
  .alb-contacto__form-wrap{padding:32px 24px}
  .alb-wa-float{width:52px;height:52px;font-size:24px;bottom:20px;right:20px}
}

/* ========================================
   BASALTO CONDOMINIOS
   ======================================== */

/* --- Variables --- */
:root{
  --bsl-g-dark:#0b4530;
  --bsl-g-mid:#1a7a52;
  --bsl-g-acc:#2d9e6e;
  --bsl-g-light:#e6f4ee;
  --bsl-charcoal:#1a1a1a;
  --bsl-gray-d:#2d2d2d;
  --bsl-gray-m:#595959;
  --bsl-gray-l:#8a8a8a;
  --bsl-off-white:#f6f6f1;
  --bsl-white:#ffffff;
  --bsl-border:#e5e5e0;
  --bsl-r-xs:8px;--bsl-r-sm:14px;--bsl-r-md:20px;--bsl-r-lg:28px;--bsl-r-xl:40px;--bsl-r-pill:999px;
  --bsl-shadow-xs:0 2px 12px rgba(0,0,0,.06);
  --bsl-shadow-sm:0 4px 24px rgba(0,0,0,.08);
  --bsl-shadow-md:0 8px 40px rgba(0,0,0,.12);
  --bsl-shadow-lg:0 20px 64px rgba(0,0,0,.16);
  --bsl-font-display:'Plus Jakarta Sans',system-ui,sans-serif;
  --bsl-font-body:'Barlow',system-ui,sans-serif;
  --bsl-ease:cubic-bezier(.4,0,.2,1);
  --bsl-dur:.35s;
}

/* --- Typography --- */
.bsl-eyebrow{
  display:block;font-family:var(--bsl-font-body);font-size:11px;font-weight:600;
  letter-spacing:3px;text-transform:uppercase;color:var(--bsl-g-acc);margin-bottom:14px;
}
.bsl-section-title{
  font-family:var(--bsl-font-display);font-weight:800;
  font-size:clamp(28px,3.5vw,50px);color:var(--bsl-charcoal);
  line-height:1.1;letter-spacing:-.03em;margin-bottom:16px;
}
.bsl-section-title em{font-style:italic;color:var(--bsl-g-acc)}
.bsl-divider{
  width:48px;height:3px;border-radius:2px;
  background:linear-gradient(90deg,var(--bsl-g-acc),var(--bsl-g-mid));margin-bottom:28px;
}
.bsl-divider--center{margin-left:auto;margin-right:auto}

/* --- Buttons --- */
.bsl-btn-p{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bsl-g-dark);color:var(--bsl-white);
  font-family:var(--bsl-font-body);font-size:12px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:16px 34px;border-radius:var(--bsl-r-pill);border:none;cursor:pointer;
  transition:all var(--bsl-dur) var(--bsl-ease);
}
.bsl-btn-p:hover{background:var(--bsl-g-mid);transform:translateY(-2px);box-shadow:var(--bsl-shadow-sm)}
.bsl-btn-o{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:var(--bsl-white);
  font-family:var(--bsl-font-body);font-size:12px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:15px 33px;border-radius:var(--bsl-r-pill);border:1px solid rgba(255,255,255,.25);cursor:pointer;
  transition:all var(--bsl-dur) var(--bsl-ease);backdrop-filter:blur(6px);
}
.bsl-btn-o:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.bsl-btn-d{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bsl-charcoal);color:var(--bsl-white);
  font-family:var(--bsl-font-body);font-size:12px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:16px 34px;border-radius:var(--bsl-r-pill);border:none;cursor:pointer;
  transition:all var(--bsl-dur) var(--bsl-ease);
}
.bsl-btn-d:hover{background:var(--bsl-g-dark);transform:translateY(-2px);box-shadow:var(--bsl-shadow-sm)}
.bsl-btn-wa{
  display:inline-flex;align-items:center;gap:10px;
  background:#25d366;color:var(--bsl-white);
  font-family:var(--bsl-font-body);font-size:12px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:16px 34px;border-radius:var(--bsl-r-pill);border:none;cursor:pointer;
  transition:all var(--bsl-dur) var(--bsl-ease);margin-top:32px;
}
.bsl-btn-wa:hover{background:#1fba59;transform:translateY(-2px);box-shadow:var(--bsl-shadow-sm)}
.bsl-btn-wa i{font-size:16px}

/* --- Reveal animations --- */
.bsl-stats .reveal,
.bsl-about .reveal,
.bsl-amenidades .reveal,
.bsl-gallery .reveal,
.bsl-modelo .reveal,
.bsl-ubicacion .reveal,
.bsl-proceso .reveal,
.bsl-contacto .reveal{
  opacity:0;transform:translateY(30px);transition:opacity .7s var(--bsl-ease),transform .7s var(--bsl-ease);
}
.bsl-stats .reveal.d1,.bsl-about .reveal.d1,.bsl-amenidades .reveal.d1,.bsl-gallery .reveal.d1,
.bsl-modelo .reveal.d1,.bsl-ubicacion .reveal.d1,.bsl-proceso .reveal.d1,.bsl-contacto .reveal.d1{transition-delay:.15s}
.bsl-stats .reveal.d2,.bsl-about .reveal.d2,.bsl-amenidades .reveal.d2,.bsl-gallery .reveal.d2,
.bsl-modelo .reveal.d2,.bsl-ubicacion .reveal.d2,.bsl-proceso .reveal.d2,.bsl-contacto .reveal.d2{transition-delay:.3s}
.bsl-stats .reveal.d3,.bsl-about .reveal.d3,.bsl-amenidades .reveal.d3,.bsl-gallery .reveal.d3,
.bsl-modelo .reveal.d3,.bsl-ubicacion .reveal.d3,.bsl-proceso .reveal.d3,.bsl-contacto .reveal.d3{transition-delay:.45s}
.bsl-stats .reveal.visible,
.bsl-about .reveal.visible,
.bsl-amenidades .reveal.visible,
.bsl-gallery .reveal.visible,
.bsl-modelo .reveal.visible,
.bsl-ubicacion .reveal.visible,
.bsl-proceso .reveal.visible,
.bsl-contacto .reveal.visible{opacity:1;transform:translateY(0)}

/* --- HERO --- */
.bsl-hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  background-color:var(--bsl-charcoal);
}
.bsl-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,69,48,.7) 0%,rgba(26,26,26,.85) 100%);
}
.bsl-hero__content{
  position:relative;z-index:2;text-align:center;max-width:720px;padding:0 32px;
}
.bsl-hero__logo{
  display:block;width:220px;margin:0 auto 32px;
  filter:drop-shadow(0 4px 20px rgba(0,0,0,.3));
}
.bsl-hero__title{
  font-family:var(--bsl-font-display);font-weight:800;
  font-size:clamp(44px,6vw,80px);color:var(--bsl-white);
  line-height:1.05;letter-spacing:-.04em;margin-bottom:28px;
}
.bsl-hero__title em{font-style:italic;color:var(--bsl-g-acc)}
.bsl-hero__tagline{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:36px}
.bsl-hero__tag{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--bsl-r-pill);
  padding:8px 18px;font-family:var(--bsl-font-body);font-size:12px;
  font-weight:500;color:rgba(255,255,255,.75);
}
.bsl-hero__tag i{color:var(--bsl-g-acc);font-size:12px}
.bsl-hero__btns{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.bsl-hero__stat{
  position:absolute;bottom:0;right:48px;z-index:2;
  display:flex;flex-direction:column;
  background:rgba(255,255,255,.06);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--bsl-r-xl) var(--bsl-r-xl) 0 0;overflow:hidden;
}
.bsl-hero__stat-item{
  padding:22px 36px;text-align:center;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.bsl-hero__stat-item:last-child{border-bottom:none}
.bsl-hero__stat-num{
  display:block;font-family:var(--bsl-font-display);font-size:28px;font-weight:800;
  color:var(--bsl-white);letter-spacing:-.02em;
}
.bsl-hero__stat-lbl{
  font-family:var(--bsl-font-body);font-size:11px;font-weight:500;
  color:rgba(255,255,255,.45);letter-spacing:1px;text-transform:uppercase;
}

/* --- STATS --- */
.bsl-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--bsl-g-dark);
}
.bsl-stats__item{
  padding:52px 24px;text-align:center;
  border-right:1px solid rgba(255,255,255,.07);
  transition:background var(--bsl-dur) var(--bsl-ease);
}
.bsl-stats__item:last-child{border-right:none}
.bsl-stats__item:hover{background:rgba(255,255,255,.04)}
.bsl-stats__icon{
  display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:var(--bsl-r-md);
  background:rgba(45,158,110,.15);margin:0 auto 18px;font-size:20px;color:var(--bsl-g-acc);
}
.bsl-stats__num{
  display:block;font-family:var(--bsl-font-display);font-size:clamp(36px,4vw,52px);
  font-weight:800;color:var(--bsl-white);letter-spacing:-.03em;line-height:1.1;margin-bottom:6px;
}
.bsl-stats__lbl{
  font-family:var(--bsl-font-body);font-size:13px;font-weight:500;
  color:rgba(255,255,255,.5);letter-spacing:.5px;
}

/* --- ABOUT --- */
.bsl-about{
  display:grid;grid-template-columns:1.1fr 1fr;
  background:var(--bsl-white);
}
.bsl-about__media{position:relative;overflow:hidden;min-height:540px}
.bsl-about__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--bsl-ease)}
.bsl-about__media:hover img{transform:scale(1.04)}
.bsl-about__text{
  padding:80px 80px 80px 64px;display:flex;flex-direction:column;justify-content:center;
}
.bsl-about__text p{
  font-family:var(--bsl-font-body);font-size:16px;color:var(--bsl-gray-m);
  line-height:1.8;font-weight:400;margin-bottom:32px;
}
.bsl-about__badge{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bsl-white);border-radius:var(--bsl-r-pill);
  padding:10px 20px;font-family:var(--bsl-font-body);font-size:13px;
  font-weight:500;box-shadow:var(--bsl-shadow-xs);color:var(--bsl-gray-m);
  margin-bottom:28px;border:1px solid var(--bsl-border);width:fit-content;
}
.bsl-about__badge i{color:var(--bsl-g-acc);font-size:14px}
.bsl-about__badge strong{color:var(--bsl-g-dark);font-family:var(--bsl-font-display);font-weight:700}
.bsl-about__badge-sub{color:var(--bsl-gray-l);font-weight:400}

/* --- AMENIDADES --- */
.bsl-amenidades{background:var(--bsl-white);padding:100px 64px}
.bsl-amenidades__header{text-align:center;max-width:560px;margin:0 auto 64px}
.bsl-amenidades__header p{
  font-family:var(--bsl-font-body);font-size:16px;color:var(--bsl-gray-m);
  line-height:1.75;font-weight:400;margin-top:12px;
}
.bsl-amenidades__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.bsl-amenity{
  background:var(--bsl-off-white);border-radius:var(--bsl-r-xl);
  padding:34px 26px;border:1px solid var(--bsl-border);
  transition:transform var(--bsl-dur) var(--bsl-ease),box-shadow var(--bsl-dur) var(--bsl-ease),border-color var(--bsl-dur) var(--bsl-ease);
  position:relative;overflow:hidden;cursor:default;
}
.bsl-amenity::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(140deg,var(--bsl-g-dark) 0%,var(--bsl-g-mid) 100%);
  opacity:0;transition:opacity var(--bsl-dur) var(--bsl-ease);border-radius:var(--bsl-r-xl);
}
.bsl-amenity>*{position:relative;z-index:1}
.bsl-amenity:hover{transform:translateY(-6px);box-shadow:var(--bsl-shadow-lg);border-color:transparent}
.bsl-amenity:hover::before{opacity:1}
.bsl-amenity:hover .bsl-amenity__icon{background:rgba(255,255,255,.15);color:var(--bsl-white)}
.bsl-amenity:hover .bsl-amenity__title{color:var(--bsl-white)}
.bsl-amenity:hover .bsl-amenity__desc{color:rgba(255,255,255,.7)}
.bsl-amenity__icon{
  width:52px;height:52px;border-radius:var(--bsl-r-md);
  background:var(--bsl-g-light);display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;transition:background var(--bsl-dur) var(--bsl-ease),color var(--bsl-dur) var(--bsl-ease);
  font-size:21px;color:var(--bsl-g-acc);
}
.bsl-amenity__title{
  font-family:var(--bsl-font-display);font-weight:700;font-size:14.5px;
  color:var(--bsl-charcoal);margin-bottom:8px;
  transition:color var(--bsl-dur) var(--bsl-ease);letter-spacing:-.01em;
}
.bsl-amenity__desc{
  font-family:var(--bsl-font-body);font-size:13px;color:var(--bsl-gray-m);
  line-height:1.65;transition:color var(--bsl-dur) var(--bsl-ease);font-weight:400;
}

/* --- GALLERY --- */
.bsl-gallery{
  background:var(--bsl-white);padding:0 60px 80px;
  display:grid;grid-template-columns:3fr 2fr 2fr;gap:14px;
}
.bsl-gallery__main,.bsl-gallery__sm{border-radius:var(--bsl-r-xl);overflow:hidden}
.bsl-gallery__main img,.bsl-gallery__sm img{
  width:100%;height:100%;object-fit:cover;transition:transform .7s var(--bsl-ease);
}
.bsl-gallery__main:hover img,.bsl-gallery__sm:hover img{transform:scale(1.06)}
.bsl-gallery__main{min-height:500px}
.bsl-gallery__sm{min-height:240px}
.bsl-gallery__col{display:grid;grid-template-rows:1fr 1fr;gap:14px}

/* --- MODELO --- */
.bsl-modelo{
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--bsl-gray-d);
}
.bsl-modelo__text{
  padding:80px 60px 80px 80px;display:flex;flex-direction:column;justify-content:center;
}
.bsl-modelo__text .bsl-section-title{color:var(--bsl-white)}
.bsl-modelo__text .bsl-divider{margin-bottom:20px}
.bsl-modelo__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--bsl-g-acc);color:var(--bsl-white);
  font-family:var(--bsl-font-body);font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:7px 18px;border-radius:var(--bsl-r-pill);margin-bottom:18px;width:fit-content;
}
.bsl-modelo__size{
  font-family:var(--bsl-font-body);font-size:16px;font-weight:400;
  color:rgba(255,255,255,.5);margin-bottom:32px;display:flex;align-items:center;gap:10px;
}
.bsl-modelo__size i{font-size:14px;color:var(--bsl-g-acc)}
.bsl-modelo__features{list-style:none;margin-bottom:44px}
.bsl-modelo__features li{
  padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);
  font-family:var(--bsl-font-body);font-size:15px;color:rgba(255,255,255,.8);
  font-weight:400;display:flex;align-items:center;gap:14px;
}
.bsl-modelo__features li:last-child{border-bottom:none}
.bsl-modelo__features li i{color:var(--bsl-g-acc);font-size:13px;width:16px;flex-shrink:0}
.bsl-modelo__media{position:relative;overflow:hidden;margin:40px 0;border-radius:var(--bsl-r-xl) 0 0 var(--bsl-r-xl)}
.bsl-modelo__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--bsl-ease)}
.bsl-modelo__media:hover img{transform:scale(1.04)}

/* --- UBICACIÓN --- */
.bsl-ubicacion{
  background:var(--bsl-off-white);padding:100px 64px;
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;
}
.bsl-ubicacion .bsl-section-title{margin-bottom:16px}
.bsl-ubicacion__desc{
  font-family:var(--bsl-font-body);font-size:16px;color:var(--bsl-gray-m);
  line-height:1.8;font-weight:400;margin-bottom:28px;
}
.bsl-ubicacion__poi-label{
  font-family:var(--bsl-font-body);font-size:11px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--bsl-charcoal);
  margin-bottom:14px;display:flex;align-items:center;gap:12px;
}
.bsl-ubicacion__poi-label::after{content:'';flex:1;height:1px;background:var(--bsl-border)}
.bsl-ubicacion__poi-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:36px}
.bsl-ubicacion__poi{
  background:var(--bsl-white);border-radius:var(--bsl-r-pill);
  padding:10px 16px;font-family:var(--bsl-font-body);font-size:13px;
  font-weight:500;color:var(--bsl-gray-m);border:1px solid var(--bsl-border);
  box-shadow:var(--bsl-shadow-xs);display:flex;align-items:center;gap:9px;
  transition:all var(--bsl-dur) var(--bsl-ease);
}
.bsl-ubicacion__poi i{color:var(--bsl-g-acc);font-size:12px;width:14px;flex-shrink:0}
.bsl-ubicacion__poi:hover{
  background:var(--bsl-g-light);color:var(--bsl-g-dark);
  border-color:var(--bsl-g-acc);transform:translateY(-2px);
}
.bsl-ubicacion__address{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bsl-g-dark);color:var(--bsl-white);
  padding:12px 24px;border-radius:var(--bsl-r-pill);
  font-family:var(--bsl-font-body);font-size:13px;font-weight:600;
}
.bsl-ubicacion__address i{color:var(--bsl-g-acc)}
.bsl-ubicacion__map{border-radius:var(--bsl-r-xl);overflow:hidden;box-shadow:var(--bsl-shadow-lg);height:500px}
.bsl-ubicacion__map iframe{width:100%;height:100%;border:none;display:block}

/* --- PROCESO --- */
.bsl-proceso{background:var(--bsl-charcoal);padding:100px 64px;text-align:center}
.bsl-proceso .bsl-section-title{color:var(--bsl-white)}
.bsl-proceso__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  margin-top:64px;position:relative;
}
.bsl-proceso__grid::before{
  content:'';position:absolute;top:50px;
  left:calc(12.5% + 8px);right:calc(12.5% + 8px);
  height:1px;background:rgba(255,255,255,.08);pointer-events:none;
}
.bsl-proceso__card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--bsl-r-xl);padding:42px 24px 36px;
  transition:transform var(--bsl-dur) var(--bsl-ease),background var(--bsl-dur) var(--bsl-ease),border-color var(--bsl-dur) var(--bsl-ease);
}
.bsl-proceso__card:hover{
  background:rgba(255,255,255,.08);transform:translateY(-6px);
  border-color:rgba(45,158,110,.3);
}
.bsl-proceso__dot{
  width:12px;height:12px;border-radius:50%;background:var(--bsl-g-acc);
  margin:0 auto 28px;box-shadow:0 0 0 4px rgba(45,158,110,.2);
}
.bsl-proceso__num{
  font-family:var(--bsl-font-display);font-size:60px;font-weight:800;
  color:var(--bsl-g-acc);line-height:1;display:block;margin-bottom:16px;letter-spacing:-.04em;
}
.bsl-proceso__title{
  font-family:var(--bsl-font-display);font-weight:700;font-size:15px;
  color:var(--bsl-white);margin-bottom:12px;letter-spacing:-.01em;
}
.bsl-proceso__desc{
  font-family:var(--bsl-font-body);font-size:13.5px;
  color:rgba(255,255,255,.45);line-height:1.65;font-weight:400;
}

/* --- CONTACTO --- */
.bsl-contacto{
  background:var(--bsl-white);padding:100px 64px;
  display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;
}
.bsl-contacto .bsl-section-title{font-size:clamp(28px,3.5vw,46px)}
.bsl-contacto__desc{
  font-family:var(--bsl-font-body);font-size:16px;color:var(--bsl-gray-m);
  line-height:1.8;font-weight:400;margin-bottom:28px;
}
.bsl-contacto__list{display:flex;flex-direction:column;gap:18px;margin-bottom:8px}
.bsl-contacto__row{
  display:flex;align-items:center;gap:16px;
  font-family:var(--bsl-font-body);font-size:14px;color:var(--bsl-gray-m);
}
.bsl-contacto__row i{
  width:40px;height:40px;border-radius:var(--bsl-r-sm);
  background:var(--bsl-g-light);display:flex;align-items:center;justify-content:center;
  color:var(--bsl-g-acc);font-size:15px;flex-shrink:0;
}
.bsl-contacto__row strong{
  font-family:var(--bsl-font-display);font-weight:700;
  font-size:16px;color:var(--bsl-charcoal);
}
.bsl-contacto__sub{font-size:12px;color:var(--bsl-gray-l)}
.bsl-contacto__form{
  background:var(--bsl-off-white);border-radius:var(--bsl-r-xl);
  padding:48px 40px;border:1px solid var(--bsl-border);
}
.bsl-contacto__form-title{
  font-family:var(--bsl-font-display);font-weight:700;font-size:20px;
  color:var(--bsl-charcoal);margin-bottom:4px;
}
.bsl-contacto__form-sub{
  font-family:var(--bsl-font-body);font-size:13px;color:var(--bsl-gray-l);
  margin-bottom:28px;
}
.bsl-form-group{margin-bottom:18px}
.bsl-form-group label{
  display:block;font-family:var(--bsl-font-body);font-size:12px;
  font-weight:600;color:var(--bsl-charcoal);margin-bottom:7px;
  letter-spacing:.5px;
}
.bsl-form-group label i{color:var(--bsl-g-acc);margin-right:4px;font-size:11px}
.bsl-form-group input,.bsl-form-group textarea{
  width:100%;padding:13px 16px;border-radius:var(--bsl-r-sm);
  border:1px solid var(--bsl-border);background:var(--bsl-white);
  font-family:var(--bsl-font-body);font-size:14px;color:var(--bsl-charcoal);
  transition:border-color var(--bsl-dur) var(--bsl-ease),box-shadow var(--bsl-dur) var(--bsl-ease);
  outline:none;
}
.bsl-form-group input:focus,.bsl-form-group textarea:focus{
  border-color:var(--bsl-g-acc);box-shadow:0 0 0 3px rgba(45,158,110,.1);
}
.bsl-form-group textarea{resize:vertical;min-height:90px}
.bsl-contacto__submit{width:100%;justify-content:center;margin-top:8px}

/* --- WA FLOAT --- */
.bsl-wa-float{
  position:fixed;bottom:28px;right:28px;z-index:90;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;color:var(--bsl-white);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;box-shadow:0 6px 24px rgba(37,211,102,.4);
  transition:transform var(--bsl-dur) var(--bsl-ease),box-shadow var(--bsl-dur) var(--bsl-ease);
}
.bsl-wa-float:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(37,211,102,.5)}

/* --- RESPONSIVE 1200px --- */
@media(max-width:1200px){
  .bsl-amenidades,.bsl-proceso,.bsl-contacto,.bsl-ubicacion{padding-inline:40px}
  .bsl-gallery{padding-inline:40px}
  .bsl-about__text{padding:60px 48px 60px 40px}
  .bsl-modelo__text{padding:60px 40px 60px 60px}
}

/* --- RESPONSIVE 960px --- */
@media(max-width:960px){
  .bsl-hero__content{padding:0 24px;max-width:100%}
  .bsl-hero__stat{display:none}
  .bsl-hero__title{font-size:clamp(40px,8vw,64px)}
  .bsl-stats{grid-template-columns:repeat(2,1fr)}
  .bsl-stats__item{padding:44px 16px}
  .bsl-stats__item:nth-child(2){border-right:none}
  .bsl-stats__item:nth-child(1),.bsl-stats__item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.07)}
  .bsl-about{grid-template-columns:1fr}
  .bsl-about__media{border-radius:0 0 var(--bsl-r-xl) var(--bsl-r-xl);order:2;min-height:320px}
  .bsl-about__text{padding:52px 28px 40px;order:1}
  .bsl-amenidades{padding:72px 24px}
  .bsl-amenidades__grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .bsl-gallery{padding:0 24px 56px;grid-template-columns:1fr 1fr}
  .bsl-gallery__main{min-height:340px;grid-column:1/-1}
  .bsl-gallery__col{display:contents}
  .bsl-gallery__sm{min-height:200px}
  .bsl-modelo{grid-template-columns:1fr;padding-top:24px}
  .bsl-modelo__media{border-radius:var(--bsl-r-xl);margin:0 24px;min-height:280px;order:-1}
  .bsl-modelo__text{padding:52px 24px}
  .bsl-ubicacion{grid-template-columns:1fr;padding:72px 24px;gap:44px}
  .bsl-ubicacion__map{height:360px}
  .bsl-proceso{padding:72px 24px}
  .bsl-proceso__grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .bsl-proceso__grid::before{display:none}
  .bsl-contacto{grid-template-columns:1fr;padding:72px 24px;gap:48px}
  .bsl-contacto__form{padding:36px 24px}
}

/* --- RESPONSIVE 640px --- */
@media(max-width:640px){
  .bsl-hero{min-height:100svh}
  .bsl-hero__content{padding:0 20px}
  .bsl-hero__logo{width:140px;margin-bottom:20px}
  .bsl-hero__title{font-size:clamp(36px,10vw,52px)}
  .bsl-hero__tag{font-size:10px;padding:6px 13px}
  .bsl-hero__btns{flex-direction:column;gap:10px}
  .bsl-hero__btns .bsl-btn-p,.bsl-hero__btns .bsl-btn-o{width:100%;justify-content:center}
  .bsl-stats{grid-template-columns:1fr 1fr}
  .bsl-stats__item{padding:36px 12px}
  .bsl-stats__item:nth-child(odd){border-right:1px solid rgba(255,255,255,.07)}
  .bsl-stats__item:nth-child(2),.bsl-stats__item:nth-child(4){border-right:none}
  .bsl-amenidades__grid{grid-template-columns:1fr;gap:12px}
  .bsl-gallery{grid-template-columns:1fr;padding:0 16px 48px;gap:12px}
  .bsl-gallery__main{grid-column:1;min-height:260px}
  .bsl-gallery__sm{min-height:200px}
  .bsl-proceso__grid{grid-template-columns:1fr;gap:12px}
  .bsl-ubicacion__poi-grid{grid-template-columns:1fr}
  .bsl-ubicacion__map{height:300px}
  .bsl-contacto__form{padding:28px 20px}
  .bsl-wa-float{bottom:20px;right:20px;width:50px;height:50px;font-size:20px}
}

/* --- RESPONSIVE 480px --- */
@media(max-width:480px){
  .bsl-hero__title{font-size:clamp(32px,10vw,44px)}
  .bsl-btn-p,.bsl-btn-o,.bsl-btn-d{padding:13px 26px;font-size:11px}
  .bsl-about,.bsl-amenidades,.bsl-ubicacion,.bsl-proceso,.bsl-contacto{padding-top:60px;padding-bottom:60px}
  .bsl-amenidades,.bsl-ubicacion,.bsl-proceso,.bsl-contacto{padding-inline:16px}
  .bsl-about__text{padding:40px 16px 36px}
  .bsl-modelo__text{padding:40px 16px}
}

@supports(padding-bottom:env(safe-area-inset-bottom)){
  .bsl-wa-float{bottom:calc(28px + env(safe-area-inset-bottom));right:calc(28px + env(safe-area-inset-right))}
}

/* ========================================
   CENTAURUS RESIDENCIAL
   ======================================== */
:root{
  --ctr-teal:#0FB5A2;
  --ctr-teal-dark:#0A9486;
  --ctr-teal-light:#E8F8F6;
  --ctr-charcoal:#2C2C2C;
  --ctr-graphite:#4A4A4A;
  --ctr-smoke:#6B6B6B;
  --ctr-silver:#A0A0A0;
  --ctr-cloud:#F5F5F3;
  --ctr-white:#FFFFFF;
  --ctr-dark-bg:#1A1A1A;
  --ctr-font-display:'Urbanist','Helvetica Neue',sans-serif;
  --ctr-font-body:'DM Sans','Helvetica Neue',sans-serif;
  --ctr-section-pad:clamp(80px,10vw,140px);
  --ctr-container:1200px;
  --ctr-radius-sm:3px;
  --ctr-radius-md:6px;
  --ctr-ease-out:cubic-bezier(0.22,1,0.36,1);
  --ctr-ease-smooth:cubic-bezier(0.4,0,0.2,1);
}
.ctr-about .container,.ctr-amenities .container,.ctr-gallery .container,
.ctr-models .container,.ctr-location .container,.ctr-process .container,
.ctr-contact .container,.ctr-stats .container,.ctr-hero .container{
  width:100%;max-width:1200px;margin:0 auto;padding:0 24px;
}
.ctr-label{
  font-family:var(--ctr-font-body);font-size:11px;font-weight:500;
  letter-spacing:3px;text-transform:uppercase;color:var(--ctr-teal);margin-bottom:16px;display:block;
}

/* Reveal */
.ctr-stats .reveal,.ctr-about .reveal,.ctr-amenities .reveal,.ctr-gallery .reveal,
.ctr-models .reveal,.ctr-location .reveal,.ctr-process .reveal,.ctr-contact .reveal{
  opacity:0;transform:translateY(40px);transition:opacity .9s var(--ctr-ease-out),transform .9s var(--ctr-ease-out);
}
.ctr-stats .reveal.visible,.ctr-about .reveal.visible,.ctr-amenities .reveal.visible,
.ctr-gallery .reveal.visible,.ctr-models .reveal.visible,.ctr-location .reveal.visible,
.ctr-process .reveal.visible,.ctr-contact .reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}

/* --- HERO --- */
.ctr-hero{position:relative;width:100%;height:100vh;min-height:700px;overflow:hidden}
.ctr-hero__bg{position:absolute;inset:0;z-index:0}
.ctr-hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.ctr-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,26,.45) 0%,rgba(26,26,26,.4) 40%,rgba(26,26,26,.7) 100%);z-index:1}
.ctr-hero__content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.ctr-hero__logo{margin-bottom:24px}
.ctr-hero__logo img{height:85px;width:auto;filter:brightness(0) invert(1)}
.ctr-hero__tag{
  font-family:var(--ctr-font-body);font-size:11px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;color:var(--ctr-teal);margin-bottom:16px;display:block;
  opacity:0;animation:ctrFadeUp 1s var(--ctr-ease-out) .5s forwards;
}
.ctr-hero__title{
  font-family:var(--ctr-font-display);font-size:clamp(36px,5vw,60px);font-weight:600;
  line-height:1.1;letter-spacing:-.5px;color:var(--ctr-white);max-width:700px;
  opacity:0;animation:ctrFadeUp 1s var(--ctr-ease-out) .7s forwards;
}
.ctr-hero__title em{font-style:normal;font-weight:400;color:var(--ctr-teal)}
.ctr-hero__subtitle{
  font-family:var(--ctr-font-body);font-size:16px;font-weight:300;
  color:rgba(255,255,255,.75);margin-top:20px;max-width:500px;line-height:1.7;
  opacity:0;animation:ctrFadeUp 1s var(--ctr-ease-out) .9s forwards;
}
.ctr-hero__cards{
  position:absolute;z-index:3;right:24px;bottom:80px;
  display:flex;flex-direction:column;gap:12px;
}
.ctr-hero__card{
  background:rgba(255,255,255,.1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.15);border-radius:var(--ctr-radius-md);
  padding:20px 28px;min-width:200px;
  opacity:0;animation:ctrFadeLeft .8s var(--ctr-ease-out) forwards;
}
.ctr-hero__card:nth-child(1){animation-delay:1.1s}
.ctr-hero__card:nth-child(2){animation-delay:1.3s}
.ctr-hero__card:nth-child(3){animation-delay:1.5s}
.ctr-hero__card-value{font-family:var(--ctr-font-display);font-size:32px;font-weight:600;color:var(--ctr-white);line-height:1}
.ctr-hero__card-label{font-family:var(--ctr-font-body);font-size:11px;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:6px}
.ctr-hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:ctrFadeUp 1s var(--ctr-ease-out) 1.8s forwards}
.ctr-hero__scroll-line{width:1px;height:40px;background:rgba(255,255,255,.4);position:relative;overflow:hidden}
.ctr-hero__scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--ctr-teal);animation:ctrScrollLine 2s ease-in-out infinite}
@keyframes ctrScrollLine{0%{top:-100%}50%{top:100%}100%{top:100%}}
@keyframes ctrFadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes ctrFadeLeft{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* --- STATS --- */
.ctr-stats{background:var(--ctr-dark-bg);padding:48px 0}
.ctr-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.ctr-stats__item{position:relative}
.ctr-stats__item::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:40px;background:rgba(255,255,255,.1)}
.ctr-stats__item:last-child::after{display:none}
.ctr-stats__number{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-teal);line-height:1}
.ctr-stats__label{font-family:var(--ctr-font-body);font-size:12px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:10px}

/* --- ABOUT --- */
.ctr-about{padding:var(--ctr-section-pad) 0;background:var(--ctr-white)}
.ctr-about__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.ctr-about__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,50px);font-weight:600;line-height:1.15;color:var(--ctr-charcoal);margin-bottom:28px}
.ctr-about__title em{font-style:normal;font-weight:400;color:var(--ctr-teal-dark)}
.ctr-about__text{font-family:var(--ctr-font-body);font-size:15px;font-weight:300;color:var(--ctr-smoke);line-height:1.8;margin-bottom:20px}
.ctr-about__features{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:36px}
.ctr-about__feature{display:flex;align-items:center;gap:12px;font-family:var(--ctr-font-body);font-size:14px;font-weight:400;color:var(--ctr-graphite)}
.ctr-about__feature-icon{width:36px;height:36px;border-radius:50%;background:var(--ctr-teal-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ctr-about__feature-icon svg{width:16px;height:16px;stroke:var(--ctr-teal);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ctr-about__image{position:relative;border-radius:var(--ctr-radius-md);overflow:hidden}
.ctr-about__image img{width:100%;height:500px;object-fit:cover}
.ctr-about__image-accent{position:absolute;bottom:-20px;right:-20px;width:180px;height:180px;border:1px solid var(--ctr-teal);border-radius:var(--ctr-radius-md);opacity:.3;z-index:-1}

/* --- AMENITIES --- */
.ctr-amenities{padding:var(--ctr-section-pad) 0;background:var(--ctr-cloud);position:relative}
.ctr-amenities__header{text-align:center;max-width:600px;margin:0 auto 64px}
.ctr-amenities__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-charcoal);line-height:1.15}
.ctr-amenities__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ctr-amenity-card{
  background:var(--ctr-white);border-radius:var(--ctr-radius-md);padding:40px 32px;text-align:center;
  transition:transform .4s var(--ctr-ease-smooth),box-shadow .4s var(--ctr-ease-smooth);border:1px solid transparent;
}
.ctr-amenity-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.06);border-color:rgba(15,181,162,.15)}
.ctr-amenity-card__icon{width:52px;height:52px;margin:0 auto 20px;background:var(--ctr-teal-light);border-radius:50%;display:flex;align-items:center;justify-content:center}
.ctr-amenity-card__icon svg{width:24px;height:24px;stroke:var(--ctr-teal);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ctr-amenity-card__title{font-family:var(--ctr-font-display);font-size:22px;font-weight:600;color:var(--ctr-charcoal);margin-bottom:10px}
.ctr-amenity-card__desc{font-family:var(--ctr-font-body);font-size:13px;font-weight:300;color:var(--ctr-smoke);line-height:1.7}

/* --- GALLERY --- */
.ctr-gallery{padding:var(--ctr-section-pad) 0;background:var(--ctr-white)}
.ctr-gallery__header{text-align:center;max-width:600px;margin:0 auto 56px}
.ctr-gallery__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-charcoal)}
.ctr-gallery__mosaic{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:280px 280px;gap:16px}
.ctr-gallery__item{border-radius:var(--ctr-radius-md);overflow:hidden;position:relative}
.ctr-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ctr-ease-out)}
.ctr-gallery__item:hover img{transform:scale(1.05)}
.ctr-gallery__item--wide{grid-column:span 2}
.ctr-gallery__item-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px 24px;background:linear-gradient(transparent,rgba(0,0,0,.5));opacity:0;transition:opacity .4s ease}
.ctr-gallery__item:hover .ctr-gallery__item-overlay{opacity:1}
.ctr-gallery__item-overlay span{font-family:var(--ctr-font-body);font-size:12px;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;color:var(--ctr-white)}

/* --- MODELS --- */
.ctr-models{padding:var(--ctr-section-pad) 0;background:var(--ctr-cloud)}
.ctr-models__header{text-align:center;max-width:600px;margin:0 auto 56px}
.ctr-models__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-charcoal)}
.ctr-models__tabs{display:flex;justify-content:center;gap:8px;margin-bottom:48px}
.ctr-models__tab{
  font-family:var(--ctr-font-body);font-size:13px;font-weight:500;letter-spacing:1px;
  text-transform:uppercase;padding:14px 36px;border-radius:var(--ctr-radius-sm);
  color:var(--ctr-smoke);background:var(--ctr-white);border:1px solid #E0E0E0;
  transition:all .35s var(--ctr-ease-smooth);cursor:pointer;
}
.ctr-models__tab:hover{color:var(--ctr-teal);border-color:var(--ctr-teal)}
.ctr-models__tab.active{background:var(--ctr-teal);color:var(--ctr-white);border-color:var(--ctr-teal)}
.ctr-models__panel{display:none;opacity:0;transform:translateY(16px);transition:opacity .5s var(--ctr-ease-out),transform .5s var(--ctr-ease-out)}
.ctr-models__panel.active{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;opacity:1;transform:translateY(0)}
.ctr-models__name{font-family:var(--ctr-font-display);font-size:clamp(36px,5vw,56px);font-weight:600;color:var(--ctr-charcoal);line-height:1.1}
.ctr-models__size{display:inline-flex;align-items:baseline;gap:4px;margin-top:12px;margin-bottom:28px}
.ctr-models__size-number{font-family:var(--ctr-font-display);font-size:48px;font-weight:600;color:var(--ctr-teal);line-height:1}
.ctr-models__size-unit{font-family:var(--ctr-font-body);font-size:16px;color:var(--ctr-smoke)}
.ctr-models__specs{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.ctr-models__spec{display:flex;align-items:center;gap:14px;font-family:var(--ctr-font-body);font-size:15px;font-weight:400;color:var(--ctr-graphite)}
.ctr-models__spec-dot{width:6px;height:6px;border-radius:50%;background:var(--ctr-teal);flex-shrink:0}
.ctr-models__cta{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ctr-font-body);font-size:13px;font-weight:500;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ctr-teal);padding:16px 0;border-bottom:1px solid var(--ctr-teal);
  transition:gap .3s ease;
}
.ctr-models__cta:hover{gap:16px}
.ctr-models__cta svg{width:18px;height:18px;stroke:var(--ctr-teal);fill:none;stroke-width:2}
.ctr-models__visual{position:relative}
.ctr-models__floorplan{width:100%;border-radius:var(--ctr-radius-md);background:var(--ctr-white);padding:32px;box-shadow:0 8px 40px rgba(0,0,0,.06)}
.ctr-models__floorplan img{width:100%;height:auto}
.ctr-models__badge{
  position:absolute;top:-12px;right:-12px;background:var(--ctr-teal);color:var(--ctr-white);
  font-family:var(--ctr-font-body);font-size:11px;font-weight:600;letter-spacing:1px;
  text-transform:uppercase;padding:10px 20px;border-radius:var(--ctr-radius-sm);
}

/* --- LOCATION --- */
.ctr-location{padding:var(--ctr-section-pad) 0;background:var(--ctr-white)}
.ctr-location__grid{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:start}
.ctr-location__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-charcoal);line-height:1.15;margin-bottom:28px}
.ctr-location__address{font-family:var(--ctr-font-body);font-size:15px;font-weight:300;color:var(--ctr-smoke);line-height:1.8;margin-bottom:36px}
.ctr-location__pois{display:flex;flex-direction:column;gap:20px}
.ctr-location__poi{display:flex;align-items:flex-start;gap:16px}
.ctr-location__poi-icon{width:40px;height:40px;border-radius:50%;background:var(--ctr-teal-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ctr-location__poi-icon svg{width:18px;height:18px;stroke:var(--ctr-teal);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ctr-location__poi-title{font-family:var(--ctr-font-body);font-size:14px;font-weight:500;color:var(--ctr-charcoal);margin-bottom:2px}
.ctr-location__poi-desc{font-family:var(--ctr-font-body);font-size:13px;font-weight:300;color:var(--ctr-smoke)}
.ctr-location__map{border-radius:var(--ctr-radius-md);overflow:hidden;height:480px;position:relative}
.ctr-location__map iframe{width:100%;height:100%;border:0;filter:grayscale(100%) contrast(1.05);transition:filter .5s ease}
.ctr-location__map:hover iframe{filter:grayscale(0%) contrast(1)}
.ctr-location__map-label{
  position:absolute;bottom:16px;left:16px;background:var(--ctr-white);padding:10px 18px;
  border-radius:var(--ctr-radius-sm);font-family:var(--ctr-font-body);font-size:12px;font-weight:500;
  color:var(--ctr-charcoal);box-shadow:0 4px 20px rgba(0,0,0,.1);z-index:2;pointer-events:none;
}

/* --- PROCESS --- */
.ctr-process{padding:var(--ctr-section-pad) 0;background:var(--ctr-dark-bg);position:relative;overflow:hidden}
.ctr-process__bg-accent{
  position:absolute;top:-200px;right:-200px;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(15,181,162,.06) 0%,transparent 70%);pointer-events:none;
}
.ctr-process__header{text-align:center;max-width:600px;margin:0 auto 72px}
.ctr-process__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-white)}
.ctr-process__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative}
.ctr-process__steps::before{content:'';position:absolute;top:30px;left:60px;right:60px;height:1px;background:rgba(255,255,255,.1)}
.ctr-process__step{text-align:center;position:relative}
.ctr-process__step-number{
  width:60px;height:60px;margin:0 auto 24px;border-radius:50%;
  border:1px solid rgba(255,255,255,.15);background:var(--ctr-dark-bg);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ctr-font-display);font-size:24px;font-weight:500;color:var(--ctr-teal);position:relative;z-index:1;
}
.ctr-process__step-title{font-family:var(--ctr-font-display);font-size:20px;font-weight:600;color:var(--ctr-white);margin-bottom:10px}
.ctr-process__step-desc{font-family:var(--ctr-font-body);font-size:13px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.7}

/* --- CONTACT --- */
.ctr-contact{padding:var(--ctr-section-pad) 0;background:var(--ctr-white)}
.ctr-contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.ctr-contact__title{font-family:var(--ctr-font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--ctr-charcoal);line-height:1.15;margin-bottom:24px}
.ctr-contact__text{font-family:var(--ctr-font-body);font-size:15px;font-weight:300;color:var(--ctr-smoke);line-height:1.8;margin-bottom:36px}
.ctr-contact__info-item{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.ctr-contact__info-icon{width:44px;height:44px;border-radius:50%;background:var(--ctr-teal-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ctr-contact__info-icon svg{width:18px;height:18px;stroke:var(--ctr-teal);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ctr-contact__info-label{font-family:var(--ctr-font-body);font-size:12px;font-weight:400;letter-spacing:1px;text-transform:uppercase;color:var(--ctr-silver);margin-bottom:2px}
.ctr-contact__info-value{font-family:var(--ctr-font-body);font-size:15px;font-weight:500;color:var(--ctr-charcoal)}
.ctr-contact__form{display:flex;flex-direction:column;gap:20px}
.ctr-contact__form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ctr-contact__input-group{display:flex;flex-direction:column}
.ctr-contact__input-group label{font-family:var(--ctr-font-body);font-size:12px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--ctr-smoke);margin-bottom:8px}
.ctr-contact__input-group input,.ctr-contact__input-group select,.ctr-contact__input-group textarea{
  font-family:var(--ctr-font-body);font-size:14px;padding:14px 18px;
  border:1px solid #E0E0E0;border-radius:var(--ctr-radius-sm);
  background:var(--ctr-cloud);color:var(--ctr-charcoal);outline:none;transition:border-color .3s ease;
}
.ctr-contact__input-group input:focus,.ctr-contact__input-group select:focus,.ctr-contact__input-group textarea:focus{border-color:var(--ctr-teal)}
.ctr-contact__input-group textarea{resize:vertical;min-height:100px}
.ctr-contact__submit{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--ctr-font-body);font-size:13px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;background:var(--ctr-teal);color:var(--ctr-white);border:none;
  border-radius:var(--ctr-radius-sm);padding:18px 40px;cursor:pointer;
  transition:background .3s ease,transform .2s ease;
}
.ctr-contact__submit:hover{background:var(--ctr-teal-dark);transform:translateY(-2px)}
.ctr-contact__submit svg{width:18px;height:18px;fill:var(--ctr-white)}

/* --- WA FLOAT --- */
.ctr-whatsapp{
  position:fixed;bottom:28px;right:28px;z-index:90;width:56px;height:56px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 24px rgba(37,211,102,.35);
  transition:transform .3s ease,box-shadow .3s ease;
  animation:ctrFadeUp .8s var(--ctr-ease-out) 2s forwards;opacity:0;
}
.ctr-whatsapp:hover{transform:scale(1.1);box-shadow:0 6px 32px rgba(37,211,102,.5)}
.ctr-whatsapp svg{width:28px;height:28px;fill:#fff}

/* --- RESPONSIVE 960px --- */
@media(max-width:960px){
  .ctr-hero__cards{position:relative;right:auto;bottom:auto;flex-direction:row;flex-wrap:wrap;margin-top:32px}
  .ctr-hero__card{min-width:140px;flex:1}
  .ctr-hero__content{padding-bottom:40px}
  .ctr-stats__grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .ctr-stats__item:nth-child(2)::after{display:none}
  .ctr-about__grid{grid-template-columns:1fr;gap:48px}
  .ctr-about__image{order:-1}
  .ctr-about__image img{height:360px}
  .ctr-amenities__grid{grid-template-columns:repeat(2,1fr)}
  .ctr-gallery__mosaic{grid-template-columns:1fr 1fr;grid-template-rows:240px 240px 240px}
  .ctr-gallery__item--wide{grid-column:span 2}
  .ctr-models__panel.active{grid-template-columns:1fr;gap:40px}
  .ctr-location__grid{grid-template-columns:1fr;gap:40px}
  .ctr-location__map{height:360px}
  .ctr-process__steps{grid-template-columns:repeat(2,1fr);gap:40px}
  .ctr-process__steps::before{display:none}
  .ctr-contact__grid{grid-template-columns:1fr;gap:48px}
}
@media(max-width:600px){
  --ctr-section-pad:60px;
  .ctr-hero{min-height:100svh;min-height:100dvh}
  .ctr-hero__title{font-size:36px}
  .ctr-hero__subtitle{font-size:14px}
  .ctr-hero__logo img{height:60px}
  .ctr-hero__cards{flex-direction:column;gap:10px}
  .ctr-hero__card{padding:14px 20px;display:flex;align-items:center;gap:12px}
  .ctr-hero__card-value{font-size:24px}
  .ctr-hero__scroll{display:none}
  .ctr-stats__grid{grid-template-columns:1fr 1fr}
  .ctr-stats__item::after{display:none}
  .ctr-about__features{grid-template-columns:1fr}
  .ctr-about__image img{height:280px}
  .ctr-amenities__grid{grid-template-columns:1fr}
  .ctr-gallery__mosaic{grid-template-columns:1fr;grid-template-rows:auto;grid-auto-rows:220px}
  .ctr-gallery__item--wide{grid-column:span 1}
  .ctr-models__tabs{display:flex;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-direction:row}
  .ctr-models__tabs::-webkit-scrollbar{display:none}
  .ctr-models__tab{white-space:nowrap;flex-shrink:0;text-align:center}
  .ctr-process__steps{grid-template-columns:1fr}
  .ctr-contact__form-row{grid-template-columns:1fr}
  .ctr-location__map{height:280px}
}
@media(max-width:480px){
  --ctr-section-pad:44px;
  .ctr-hero__title{font-size:26px}
  .ctr-hero__subtitle{font-size:13px}
  .ctr-hero__content{padding-bottom:40px}
  .ctr-hero__logo img{height:48px}
  .ctr-hero__card-value{font-size:20px}
  .ctr-hero__card{padding:12px 16px;min-width:auto}
  .ctr-stats__grid{grid-template-columns:1fr}
  .ctr-gallery__mosaic{grid-auto-rows:180px}
  .ctr-hero{min-height:85svh}
  .ctr-about__image img{height:220px}
  .ctr-location__map{height:220px}
  .ctr-models__tab{padding:10px 18px;font-size:12px}
}

/* ========================================
   RÍO DE PLATA RESIDENCIAL
   ======================================== */
:root{
  --rdp-sand:#F5EDE4;--rdp-sand-light:#FAF6F1;--rdp-sky:#2B8FC2;--rdp-sky-deep:#1B6E9C;
  --rdp-sky-soft:#E3F1F8;--rdp-sky-pale:#F0F8FC;--rdp-charcoal:#2A2D2E;--rdp-dark:#1C1E1F;
  --rdp-white:#FFFFFF;--rdp-g50:#FAFAF9;--rdp-g100:#F3F3F1;--rdp-g200:#E5E5E3;
  --rdp-g400:#A8A8A5;--rdp-g600:#6B6B68;--rdp-g800:#3A3A38;
  --rdp-r:16px;--rdp-rm:22px;--rdp-rl:30px;--rdp-rx:40px;
}
@keyframes rdpRise{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}
@keyframes rdpSlideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes rdpFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes rdpMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.rdp-rv{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rdp-rv.rdp-vis{opacity:1;transform:translateY(0)}
.rdp-stag{font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--rdp-sky);margin-bottom:12px}

/* --- HERO --- */
.rdp-hero{min-height:100vh;background:var(--rdp-sand-light);display:flex;align-items:center;position:relative;overflow:hidden;padding:48px 0}
.rdp-hero-grain{position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
.rdp-hero-in{max-width:1300px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center;position:relative;z-index:2}
.rdp-hero-l{animation:rdpRise 1s cubic-bezier(.16,1,.3,1) .2s both}
.rdp-hero-logo{margin-bottom:20px}
.rdp-hero-logo img{height:90px;display:block}
.rdp-hero-pill{display:inline-block;background:var(--rdp-sky-soft);color:var(--rdp-sky-deep);font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:8px 18px;border-radius:100px;margin-bottom:24px}
.rdp-hero-l h1{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(36px,5vw,56px);font-weight:800;line-height:1.06;color:var(--rdp-dark);letter-spacing:-1.5px;margin-bottom:18px}
.rdp-hero-l h1 span{color:var(--rdp-sky);display:block}
.rdp-hero-l>p{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;line-height:1.75;color:var(--rdp-g600);max-width:440px;margin-bottom:32px}
.rdp-hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.rdp-btn1{display:inline-flex;align-items:center;gap:10px;background:var(--rdp-sky);color:white;padding:16px 30px;border-radius:var(--rdp-rm);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1);box-shadow:0 6px 24px rgba(43,143,194,.25)}
.rdp-btn1:hover{background:var(--rdp-sky-deep);transform:translateY(-3px);box-shadow:0 12px 36px rgba(43,143,194,.3)}
.rdp-btn2{display:inline-flex;align-items:center;gap:10px;background:var(--rdp-white);color:var(--rdp-charcoal);padding:16px 26px;border-radius:var(--rdp-rm);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;text-decoration:none;border:1.5px solid var(--rdp-g200);transition:all .4s cubic-bezier(.16,1,.3,1)}
.rdp-btn2:hover{border-color:var(--rdp-sky);color:var(--rdp-sky)}
.rdp-hero-nums{display:flex;gap:32px}
.rdp-hn .rdp-hn-v{font-family:'Plus Jakarta Sans',sans-serif;font-size:32px;font-weight:800;color:var(--rdp-dark);letter-spacing:-1px}
.rdp-hn .rdp-hn-v small{font-size:16px;color:var(--rdp-g400);font-weight:500}
.rdp-hn .rdp-hn-l{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:var(--rdp-g400);margin-top:2px;font-weight:500}
.rdp-hero-r{animation:rdpSlideIn 1.1s cubic-bezier(.16,1,.3,1) .4s both}
.rdp-mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:240px 200px;gap:14px}
.rdp-mos{border-radius:var(--rdp-rl);overflow:hidden;position:relative}
.rdp-mos img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.rdp-mos:hover img{transform:scale(1.05)}
.rdp-mos-big{grid-column:1/3}
.rdp-mos-lab{position:absolute;bottom:14px;left:16px;background:rgba(0,0,0,.5);backdrop-filter:blur(10px);color:white;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:6px 14px;border-radius:100px}

/* --- MARQUEE --- */
.rdp-mq{background:var(--rdp-dark);padding:16px 0;overflow:hidden;white-space:nowrap}
.rdp-mq-track{display:inline-flex;animation:rdpMarquee 30s linear infinite}
.rdp-mq-i{display:inline-flex;align-items:center;gap:12px;padding:0 32px;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:1px;text-transform:uppercase}
.rdp-dot{width:5px;height:5px;border-radius:50%;background:var(--rdp-sky)}

/* --- ABOUT --- */
.rdp-about{padding:110px 0;background:var(--rdp-white)}
.rdp-about-w{max-width:1200px;margin:0 auto;padding:0 48px}
.rdp-about-top{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:end;margin-bottom:56px}
.rdp-about-top h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,4vw,42px);font-weight:800;color:var(--rdp-dark);line-height:1.1;letter-spacing:-.5px}
.rdp-about-top p{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.75;color:var(--rdp-g600);max-width:480px;align-self:end}
.rdp-about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rdp-ac{background:var(--rdp-g50);border:1px solid var(--rdp-g200);border-radius:var(--rdp-rl);padding:36px 28px;transition:all .5s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}
.rdp-ac::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--rdp-sky);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.rdp-ac:hover{border-color:var(--rdp-sky);box-shadow:0 16px 48px rgba(43,143,194,.08);transform:translateY(-6px)}
.rdp-ac:hover::before{transform:scaleX(1)}
.rdp-ac-ic{width:52px;height:52px;background:var(--rdp-sky-soft);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:background .4s}
.rdp-ac:hover .rdp-ac-ic{background:var(--rdp-sky)}
.rdp-ac-ic svg{width:24px;height:24px;stroke:var(--rdp-sky);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;transition:stroke .4s}
.rdp-ac:hover .rdp-ac-ic svg{stroke:white}
.rdp-ac h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;color:var(--rdp-dark);margin-bottom:8px}
.rdp-ac p{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--rdp-g600);line-height:1.6}

/* --- BENTO AMENITIES --- */
.rdp-amen{padding:110px 0;background:var(--rdp-sand-light)}
.rdp-amen-w{max-width:1200px;margin:0 auto;padding:0 48px}
.rdp-amen-h{margin-bottom:48px}
.rdp-amen-h h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,4vw,42px);font-weight:800;color:var(--rdp-dark);line-height:1.1;letter-spacing:-.5px;margin-bottom:14px}
.rdp-amen-h p{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.75;color:var(--rdp-g600);max-width:520px}
.rdp-bento{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rdp-bi{background:var(--rdp-white);border:1px solid var(--rdp-g200);border-radius:var(--rdp-rm);padding:26px 22px;display:flex;align-items:flex-start;gap:14px;transition:all .4s cubic-bezier(.16,1,.3,1)}
.rdp-bi:hover{border-color:rgba(43,143,194,.2);box-shadow:0 12px 40px rgba(43,143,194,.06);transform:translateY(-4px)}
.rdp-w2{grid-column:span 2}
.rdp-feat{background:var(--rdp-sky);border-color:var(--rdp-sky);grid-column:span 2;grid-row:span 2;flex-direction:column;padding:36px 32px;gap:18px}
.rdp-feat h4{color:white;font-size:20px}
.rdp-feat p{color:rgba(255,255,255,.7)}
.rdp-feat .rdp-bic{background:rgba(255,255,255,.15)}
.rdp-feat .rdp-bic svg{stroke:white}
.rdp-bic{width:44px;height:44px;min-width:44px;background:var(--rdp-sky-soft);border-radius:14px;display:flex;align-items:center;justify-content:center}
.rdp-bic svg{width:22px;height:22px;stroke:var(--rdp-sky);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.rdp-bi h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;color:var(--rdp-dark);margin-bottom:4px}
.rdp-bi p{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:var(--rdp-g600);line-height:1.5}

/* --- PHOTOS --- */
.rdp-photos{padding:24px 0;overflow-x:auto;background:var(--rdp-white)}
.rdp-photos-row{display:flex;gap:16px;padding:0 48px}
.rdp-ph-item{flex:0 0 380px;height:260px;border-radius:var(--rdp-rl);overflow:hidden}
.rdp-ph-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.rdp-ph-item:hover img{transform:scale(1.06)}

/* --- MODELS --- */
.rdp-models{padding:110px 0;background:var(--rdp-white)}
.rdp-mod-w{max-width:1200px;margin:0 auto;padding:0 48px}
.rdp-mod-h{text-align:center;margin-bottom:48px}
.rdp-mod-h h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,4vw,42px);font-weight:800;color:var(--rdp-dark);line-height:1.1;letter-spacing:-.5px;margin-bottom:12px}
.rdp-mod-h p{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.75;color:var(--rdp-g600);max-width:520px;margin:0 auto}
.rdp-mod-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.rdp-mc{background:var(--rdp-g50);border:1px solid var(--rdp-g200);border-radius:var(--rdp-rx);overflow:hidden;transition:all .5s cubic-bezier(.16,1,.3,1)}
.rdp-mc:hover{border-color:var(--rdp-sky);box-shadow:0 24px 64px rgba(43,143,194,.1);transform:translateY(-8px)}
.rdp-mc-top{position:relative;height:260px;background:linear-gradient(135deg,var(--rdp-sky-pale),#D0E8F2);display:flex;align-items:center;justify-content:center}
.rdp-badge{position:absolute;top:20px;left:20px;background:var(--rdp-sky);color:white;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:7px 16px;border-radius:100px}
.rdp-bg-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:56px;font-weight:800;color:var(--rdp-dark);letter-spacing:-2px;opacity:.1;position:absolute;bottom:16px;right:24px}
.rdp-ic-wrap{width:90px;height:90px;background:rgba(43,143,194,.1);border-radius:26px;display:flex;align-items:center;justify-content:center}
.rdp-ic-wrap svg{width:44px;height:44px;stroke:var(--rdp-sky);fill:none;stroke-width:1}
.rdp-mc-body{padding:32px 28px 36px}
.rdp-mc-body h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:24px;font-weight:800;color:var(--rdp-dark);letter-spacing:-.5px;margin-bottom:4px}
.rdp-mt{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:var(--rdp-sky);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:22px}
.rdp-mc-specs{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.rdp-ms{display:flex;align-items:center;gap:12px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--rdp-g800);font-weight:500}
.rdp-ck{width:24px;height:24px;min-width:24px;background:var(--rdp-sky-soft);border-radius:8px;display:flex;align-items:center;justify-content:center}
.rdp-ck svg{width:14px;height:14px;stroke:var(--rdp-sky);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.rdp-mc-div{height:1px;background:var(--rdp-g200);margin:22px 0}
.rdp-mc-area{display:flex;align-items:baseline;gap:6px;margin-bottom:24px}
.rdp-big{font-family:'Plus Jakarta Sans',sans-serif;font-size:38px;font-weight:800;color:var(--rdp-dark);letter-spacing:-1px}
.rdp-unit{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;color:var(--rdp-g400);font-weight:500}
.rdp-desc{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--rdp-g400);margin-left:8px}
.rdp-mc-cta{display:block;text-align:center;background:var(--rdp-dark);color:white;padding:16px;border-radius:var(--rdp-r);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1)}
.rdp-mc-cta:hover{background:var(--rdp-sky);box-shadow:0 8px 24px rgba(43,143,194,.3)}

/* --- LOCATION --- */
.rdp-loc{padding:110px 0;background:var(--rdp-sand-light)}
.rdp-loc-w{max-width:1200px;margin:0 auto;padding:0 48px}
.rdp-loc-top{display:flex;justify-content:space-between;align-items:end;margin-bottom:44px;gap:40px;flex-wrap:wrap}
.rdp-loc-top h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,4vw,42px);font-weight:800;color:var(--rdp-dark);line-height:1.1;letter-spacing:-.5px}
.rdp-loc-top p{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.75;color:var(--rdp-g600);max-width:420px}
.rdp-loc-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:24px;align-items:stretch}
.rdp-loc-pois{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}
.rdp-lp{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--rdp-white);border:1px solid var(--rdp-g200);border-radius:var(--rdp-r);font-family:'Plus Jakarta Sans',sans-serif;transition:all .3s}
.rdp-lp:hover{border-color:var(--rdp-sky);background:var(--rdp-sky-pale)}
.rdp-pd{width:8px;height:8px;min-width:8px;border-radius:50%;background:var(--rdp-sky)}
.rdp-lp span{font-size:14px;color:var(--rdp-g800);font-weight:500}
.rdp-loc-map{border-radius:var(--rdp-rx);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.08);border:1px solid var(--rdp-g200);min-height:440px}
.rdp-loc-map iframe{width:100%;height:100%;min-height:440px;display:block;filter:saturate(.6);transition:filter .5s;border:0}
.rdp-loc-map:hover iframe{filter:saturate(1)}

/* --- PROCESS --- */
.rdp-proc{padding:110px 0;background:var(--rdp-white)}
.rdp-proc-w{max-width:1200px;margin:0 auto;padding:0 48px}
.rdp-proc-h{text-align:center;margin-bottom:56px}
.rdp-proc-h h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,4vw,42px);font-weight:800;color:var(--rdp-dark);line-height:1.1;letter-spacing:-.5px}
.rdp-proc-row{display:flex;gap:0;position:relative}
.rdp-proc-row::before{content:'';position:absolute;top:36px;left:48px;right:48px;height:2px;background:var(--rdp-g200)}
.rdp-ps{flex:1;text-align:center;position:relative;padding:0 16px}
.rdp-ps-n{width:72px;height:72px;margin:0 auto 24px;background:var(--rdp-white);border:2px solid var(--rdp-g200);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;font-size:24px;font-weight:800;color:var(--rdp-g400);position:relative;z-index:2;transition:all .4s}
.rdp-ps:hover .rdp-ps-n{background:var(--rdp-sky);border-color:var(--rdp-sky);color:white;transform:scale(1.1)}
.rdp-ps h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;color:var(--rdp-dark);margin-bottom:8px}
.rdp-ps p{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--rdp-g600);line-height:1.6}

/* --- CONTACT --- */
.rdp-contact{padding:110px 0;background:var(--rdp-sand-light)}
.rdp-con-w{max-width:1200px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.rdp-con-l h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(26px,4vw,38px);font-weight:800;color:var(--rdp-dark);line-height:1.1;letter-spacing:-.5px;margin-bottom:14px}
.rdp-con-l>p{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.75;color:var(--rdp-g600);margin-bottom:32px;max-width:440px}
.rdp-ci{display:flex;flex-direction:column;gap:18px;margin-bottom:36px}
.rdp-cr{display:flex;align-items:flex-start;gap:14px}
.rdp-cr-ic{width:46px;height:46px;min-width:46px;background:var(--rdp-sky-soft);border-radius:14px;display:flex;align-items:center;justify-content:center}
.rdp-cr-ic svg{width:20px;height:20px;stroke:var(--rdp-sky);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.rdp-cr h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;color:var(--rdp-dark);margin-bottom:2px}
.rdp-cr p{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--rdp-g600);line-height:1.5}
.rdp-wab{display:inline-flex;align-items:center;gap:12px;background:#25D366;color:white;padding:17px 34px;border-radius:var(--rdp-rm);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1);box-shadow:0 6px 24px rgba(37,211,102,.25)}
.rdp-wab:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(37,211,102,.35)}
.rdp-wab svg{width:22px;height:22px;fill:white}
.rdp-cf{background:var(--rdp-white);border-radius:var(--rdp-rx);padding:40px;border:1px solid var(--rdp-g200);box-shadow:0 8px 32px rgba(0,0,0,.04)}
.rdp-cf h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:22px;font-weight:800;color:var(--rdp-dark);margin-bottom:6px;letter-spacing:-.3px}
.rdp-fsub{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--rdp-g600);margin-bottom:24px}
.rdp-fg{margin-bottom:16px}
.rdp-fg label{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;color:var(--rdp-dark);margin-bottom:6px}
.rdp-fg input,.rdp-fg select,.rdp-fg textarea{width:100%;padding:13px 16px;border:1.5px solid var(--rdp-g200);border-radius:var(--rdp-r);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--rdp-charcoal);background:var(--rdp-g50);transition:all .3s;outline:none}
.rdp-fg input:focus,.rdp-fg select:focus,.rdp-fg textarea:focus{border-color:var(--rdp-sky);background:var(--rdp-white);box-shadow:0 0 0 4px rgba(43,143,194,.08)}
.rdp-fg textarea{height:80px;resize:vertical}
.rdp-frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rdp-bsend{width:100%;padding:16px;background:var(--rdp-dark);color:white;border:none;border-radius:var(--rdp-rm);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .4s cubic-bezier(.16,1,.3,1);margin-top:8px}
.rdp-bsend:hover{background:var(--rdp-sky);box-shadow:0 8px 24px rgba(43,143,194,.25)}

/* --- FLOAT WA --- */
.rdp-fwa{position:fixed;bottom:28px;right:28px;z-index:90;width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.35);text-decoration:none;transition:all .3s;animation:rdpFloat 3s ease-in-out infinite}
.rdp-fwa:hover{transform:scale(1.12)}
.rdp-fwa svg{width:28px;height:28px;fill:white}

/* --- RESPONSIVE --- */
@media(max-width:960px){
  .rdp-hero-in{grid-template-columns:1fr;padding:0 24px;gap:36px}
  .rdp-mosaic{grid-template-rows:200px 160px}
  .rdp-about-w,.rdp-amen-w,.rdp-mod-w,.rdp-loc-w,.rdp-proc-w,.rdp-con-w{padding:0 24px}
  .rdp-about-top{grid-template-columns:1fr;gap:16px}
  .rdp-about-cards{grid-template-columns:1fr}
  .rdp-bento{grid-template-columns:1fr 1fr}
  .rdp-w2,.rdp-feat{grid-column:span 2}
  .rdp-mod-row{grid-template-columns:1fr}
  .rdp-loc-grid{grid-template-columns:1fr}
  .rdp-proc-row{flex-direction:column;gap:28px}
  .rdp-proc-row::before{display:none}
  .rdp-ps{text-align:left;display:flex;align-items:flex-start;gap:20px;padding:0}
  .rdp-ps-n{margin:0;min-width:56px;width:56px;height:56px;font-size:20px}
  .rdp-con-w{grid-template-columns:1fr;gap:36px}
  .rdp-photos-row .rdp-ph-item{flex:0 0 280px;height:200px}
}
@media(max-width:600px){
  .rdp-mosaic{grid-template-columns:1fr;grid-template-rows:220px 160px 160px}
  .rdp-mos-big{grid-column:1/2}
  .rdp-hero-nums{flex-wrap:wrap;gap:20px}
  .rdp-hero-btns{flex-direction:column;width:100%}
  .rdp-btn1,.rdp-btn2{width:100%;justify-content:center}
  .rdp-bento{grid-template-columns:1fr}
  .rdp-w2,.rdp-feat{grid-column:span 1}
  .rdp-loc-pois{grid-template-columns:1fr}
  .rdp-frow{grid-template-columns:1fr}
  .rdp-photos-row{padding:0 24px}
  .rdp-photos-row .rdp-ph-item{flex:0 0 260px;height:180px}
}
@media(max-width:480px){
  .rdp-hero{padding:32px 0}
  .rdp-hero-in{padding:0 16px;gap:32px}
  .rdp-hero-l h1{font-size:clamp(28px,8vw,40px)}
  .rdp-hero-l>p{font-size:15px}
  .rdp-hero-logo img{height:60px}
  .rdp-hero-nums{gap:16px}
  .rdp-photos-row .rdp-ph-item{flex:0 0 220px;height:160px}
}

/* ========================================
   VALLE ORIENTE RESIDENCIAL
   ======================================== */
:root{
  --vo-navy:#1B3A4B;--vo-blue:#1A7FB5;--vo-blue-light:#2A9BD6;--vo-blue-soft:#E8F4FA;
  --vo-cream:#FAFAF8;--vo-white:#FFFFFF;--vo-g100:#F5F5F3;--vo-g200:#EBEBEA;
  --vo-g300:#D4D4D2;--vo-g500:#8A8A88;--vo-g700:#4A4A48;--vo-g900:#1A1A18;
  --vo-warm-bg:#F7F6F3;
  --vo-shadow-sm:0 2px 8px rgba(27,58,75,.06);--vo-shadow-md:0 8px 30px rgba(27,58,75,.10);
  --vo-shadow-lg:0 20px 60px rgba(27,58,75,.12);
  --vo-radius-sm:12px;--vo-radius-md:20px;--vo-radius-lg:28px;--vo-radius-xl:36px;
}
.vo-container{max-width:1200px;margin:0 auto;padding:0 24px}
.vo-section-label{font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--vo-blue);margin-bottom:16px}
.vo-section-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(32px,5vw,48px);font-weight:700;color:var(--vo-navy);line-height:1.15;letter-spacing:-.5px;margin-bottom:20px}
.vo-section-desc{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.7;color:var(--vo-g700);max-width:540px}

@keyframes voFadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes voFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes voPulse{0%,100%{box-shadow:0 0 0 0 rgba(26,127,181,.3)}50%{box-shadow:0 0 0 12px rgba(26,127,181,0)}}
.vo-anim{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.vo-anim.vo-visible{opacity:1;transform:translateY(0)}

/* --- HERO --- */
.vo-hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--vo-navy);padding-top:120px;padding-bottom:60px}
.vo-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;filter:brightness(.55) saturate(.9);transition:transform 8s ease-out}
.vo-hero:hover .vo-hero-bg{transform:scale(1.03)}
.vo-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(15,30,40,.95) 0%,rgba(15,30,40,.6) 35%,rgba(15,30,40,.2) 60%,rgba(15,30,40,.15) 100%);z-index:1}
.vo-hero-content{position:relative;z-index:2;width:100%;padding:0 24px 80px;max-width:1200px;margin:0 auto}
.vo-hero-top-bar{position:absolute;top:0;left:0;right:0;z-index:3;padding:32px 48px;display:flex;justify-content:space-between;align-items:center}
.vo-hero-logo-mark{display:flex;align-items:center;gap:14px}
.vo-hero-logo-mark svg{width:40px;height:auto}
.vo-logo-text{display:flex;flex-direction:column}
.vo-valle-text{font-family:'Plus Jakarta Sans',sans-serif;font-size:9px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:rgba(255,255,255,.5);line-height:1}
.vo-oriente-text{font-family:'Plus Jakarta Sans',sans-serif;font-size:20px;font-weight:800;color:white;line-height:1.1;letter-spacing:-.5px}
.vo-residencial-text{font-family:'Plus Jakarta Sans',sans-serif;font-size:8px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.4);line-height:1;margin-top:1px}
.vo-hero-dev-logo{height:180px;width:auto;margin-bottom:1.5rem}
.vo-hero-text{animation:voFadeUp 1s cubic-bezier(.22,1,.36,1) .3s both;max-width:680px}
.vo-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(26,127,181,.2);backdrop-filter:blur(12px);border:1px solid rgba(26,127,181,.3);border-radius:100px;padding:8px 20px;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--vo-blue-light);margin-bottom:28px}
.vo-hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--vo-blue-light);animation:voPulse 2s infinite}
.vo-hero h1{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(38px,5.5vw,62px);font-weight:800;line-height:1.08;color:var(--vo-white);margin-bottom:20px;letter-spacing:-1px}
.vo-accent{color:var(--vo-blue-light);font-weight:800}
.vo-hero-subtitle{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;line-height:1.7;color:rgba(255,255,255,.65);max-width:500px;margin-bottom:36px;font-weight:400}
.vo-hero-cta-group{display:flex;gap:16px;align-items:center;margin-bottom:48px}
.vo-hero-data-row{display:flex;gap:12px;flex-wrap:wrap}
.vo-hero-data-card{background:rgba(255,255,255,.08);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:var(--vo-radius-md);padding:20px 28px;min-width:140px;transition:all .4s}
.vo-hero-data-card:hover{background:rgba(255,255,255,.12);transform:translateY(-4px)}
.vo-data-value{font-family:'Plus Jakarta Sans',sans-serif;font-size:26px;font-weight:800;color:white;letter-spacing:-.5px}
.vo-data-label{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:rgba(255,255,255,.5);margin-top:2px;font-weight:500}
.vo-btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--vo-blue);color:white;padding:16px 32px;border-radius:var(--vo-radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .4s cubic-bezier(.22,1,.36,1);box-shadow:0 4px 20px rgba(26,127,181,.3)}
.vo-btn-primary:hover{background:var(--vo-blue-light);transform:translateY(-2px);box-shadow:0 8px 30px rgba(26,127,181,.4)}
.vo-btn-outline{display:inline-flex;align-items:center;gap:10px;background:transparent;color:rgba(255,255,255,.8);padding:16px 28px;border-radius:var(--vo-radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:500;text-decoration:none;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:all .4s cubic-bezier(.22,1,.36,1)}
.vo-btn-outline:hover{border-color:rgba(255,255,255,.5);color:white;background:rgba(255,255,255,.05)}

/* --- STATS --- */
.vo-stats-strip{background:var(--vo-navy);padding:40px 0 0;position:relative;z-index:5}
.vo-stats-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.vo-stat-item{padding:36px 24px;text-align:center;position:relative;transition:background .3s}
.vo-stat-item:not(:last-child)::after{content:'';position:absolute;right:0;top:25%;height:50%;width:1px;background:rgba(255,255,255,.08)}
.vo-stat-item:hover{background:rgba(26,127,181,.08)}
.vo-stat-icon{width:40px;height:40px;margin:0 auto 12px;background:rgba(26,127,181,.12);border-radius:12px;display:flex;align-items:center;justify-content:center}
.vo-stat-icon svg{width:20px;height:20px;stroke:var(--vo-blue-light);fill:none;stroke-width:1.5}
.vo-stat-value{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;color:var(--vo-white);letter-spacing:.5px}
.vo-stat-label{font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;color:rgba(255,255,255,.45);margin-top:4px;letter-spacing:.5px}

/* --- ABOUT --- */
.vo-about{padding:120px 0;background:var(--vo-cream)}
.vo-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.vo-about-image{position:relative;border-radius:var(--vo-radius-xl);overflow:hidden;aspect-ratio:4/5;background:none}
.vo-about-image-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;text-align:center;border-radius:var(--vo-radius-xl);overflow:hidden}
.vo-about-image-inner svg{width:100px;height:auto;margin-bottom:24px}
.vo-img-text{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;color:rgba(255,255,255,.8);font-weight:600;line-height:1.3}
.vo-about-image-accent{position:absolute;bottom:-20px;right:-20px;width:160px;height:160px;border-radius:var(--vo-radius-lg);background:var(--vo-blue);opacity:.1}
.vo-about-content{padding:20px 0}
.vo-about-content .vo-section-desc{margin-bottom:40px}
.vo-about-features{display:flex;flex-direction:column;gap:20px}
.vo-about-feature{display:flex;align-items:flex-start;gap:16px;padding:20px 24px;background:var(--vo-white);border-radius:var(--vo-radius-md);border:1px solid var(--vo-g200);transition:all .4s cubic-bezier(.22,1,.36,1)}
.vo-about-feature:hover{border-color:rgba(26,127,181,.2);box-shadow:var(--vo-shadow-md);transform:translateX(8px)}
.vo-about-feature-icon{width:44px;height:44px;min-width:44px;border-radius:14px;background:var(--vo-blue-soft);display:flex;align-items:center;justify-content:center}
.vo-about-feature-icon svg{width:22px;height:22px;stroke:var(--vo-blue);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.vo-about-feature h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;color:var(--vo-navy);margin-bottom:4px}
.vo-about-feature p{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--vo-g500);line-height:1.5}

/* --- AMENITIES --- */
.vo-amenities{padding:120px 0;background:var(--vo-white)}
.vo-amenities-header{text-align:center;margin-bottom:64px}
.vo-amenities-header .vo-section-desc{margin:0 auto}
.vo-amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.vo-amenity-card{background:var(--vo-g100);border-radius:var(--vo-radius-md);padding:36px 28px;text-align:center;border:1px solid transparent;transition:all .5s cubic-bezier(.22,1,.36,1);cursor:default}
.vo-amenity-card:hover{background:var(--vo-white);border-color:rgba(26,127,181,.15);box-shadow:var(--vo-shadow-lg);transform:translateY(-8px)}
.vo-amenity-icon{width:56px;height:56px;margin:0 auto 20px;background:var(--vo-blue-soft);border-radius:18px;display:flex;align-items:center;justify-content:center;transition:all .4s}
.vo-amenity-card:hover .vo-amenity-icon{background:var(--vo-blue)}
.vo-amenity-icon svg{width:26px;height:26px;stroke:var(--vo-blue);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;transition:stroke .4s}
.vo-amenity-card:hover .vo-amenity-icon svg{stroke:white}
.vo-amenity-card h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;color:var(--vo-navy);margin-bottom:6px}
.vo-amenity-card p{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--vo-g500);line-height:1.5}

/* --- MODELS --- */
.vo-models{padding:120px 0;background:var(--vo-cream)}
.vo-models-header{text-align:center;margin-bottom:48px}
.vo-models-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:48px}
.vo-model-tab{padding:14px 32px;border-radius:var(--vo-radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;color:var(--vo-g500);background:var(--vo-white);border:1px solid var(--vo-g200);cursor:pointer;transition:all .4s cubic-bezier(.22,1,.36,1)}
.vo-model-tab:hover{color:var(--vo-navy);border-color:var(--vo-g300)}
.vo-model-tab.active{background:var(--vo-navy);color:white;border-color:var(--vo-navy);box-shadow:0 4px 20px rgba(27,58,75,.25)}
.vo-model-panel{display:none;animation:voFadeUp .6s cubic-bezier(.22,1,.36,1)}
.vo-model-panel.active{display:block}
.vo-model-content{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;background:var(--vo-white);border-radius:var(--vo-radius-xl);overflow:hidden;border:1px solid var(--vo-g200);box-shadow:var(--vo-shadow-md)}
.vo-model-visual{position:relative;min-height:480px;background:linear-gradient(135deg,#E8F0F5,#D5E4ED);display:flex;align-items:center;justify-content:center;padding:0;border-radius:var(--vo-radius-xl) 0 0 var(--vo-radius-xl);overflow:hidden}
.vo-model-visual-placeholder{text-align:center}
.vo-model-icon-large{width:120px;height:120px;margin:0 auto 24px;background:rgba(26,127,181,.1);border-radius:32px;display:flex;align-items:center;justify-content:center}
.vo-model-icon-large svg{width:56px;height:56px;stroke:var(--vo-blue);fill:none;stroke-width:1}
.vo-model-name-display{font-family:'Plus Jakarta Sans',sans-serif;font-size:48px;font-weight:800;color:var(--vo-navy);letter-spacing:-1px}
.vo-model-level{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--vo-g500);letter-spacing:2px;text-transform:uppercase;margin-top:4px}
.vo-model-badge{position:absolute;top:24px;left:24px;background:var(--vo-blue);color:white;font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:8px 18px;border-radius:100px}
.vo-model-info{padding:48px 48px 48px 24px}
.vo-model-info h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:32px;font-weight:700;color:var(--vo-navy);margin-bottom:8px;letter-spacing:-.5px}
.vo-model-type{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--vo-blue);font-weight:600;letter-spacing:2px;text-transform:uppercase;margin-bottom:28px}
.vo-model-specs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
.vo-model-spec{display:flex;align-items:center;gap:12px;padding:16px;background:var(--vo-g100);border-radius:var(--vo-radius-sm)}
.vo-model-spec-icon{width:36px;height:36px;min-width:36px;background:var(--vo-blue-soft);border-radius:10px;display:flex;align-items:center;justify-content:center}
.vo-model-spec-icon svg{width:18px;height:18px;stroke:var(--vo-blue);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.vo-model-spec-text{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--vo-g700);font-weight:500}
.vo-model-areas{display:flex;gap:24px;padding:24px 0;border-top:1px solid var(--vo-g200);margin-bottom:28px}
.vo-model-area{flex:1}
.vo-area-value{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:700;color:var(--vo-navy)}
.vo-area-value span{font-size:16px;font-weight:400;color:var(--vo-g500)}
.vo-area-label{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:var(--vo-g500);margin-top:2px}
.vo-btn-model-cta{display:inline-flex;align-items:center;gap:10px;background:var(--vo-navy);color:white;padding:16px 32px;border-radius:var(--vo-radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:all .4s cubic-bezier(.22,1,.36,1)}
.vo-btn-model-cta:hover{background:var(--vo-blue);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,127,181,.3)}

/* --- LOCATION --- */
.vo-location{padding:120px 0;background:var(--vo-white)}
.vo-location-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.vo-location-content{padding-top:20px}
.vo-location-content .vo-section-desc{margin-bottom:40px}
.vo-poi-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vo-poi-item{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--vo-g100);border-radius:var(--vo-radius-sm);font-family:'Plus Jakarta Sans',sans-serif;transition:all .3s}
.vo-poi-item:hover{background:var(--vo-blue-soft)}
.vo-poi-dot{width:8px;height:8px;min-width:8px;border-radius:50%;background:var(--vo-blue)}
.vo-poi-item span{font-size:14px;color:var(--vo-g700);font-weight:500}
.vo-location-map{border-radius:var(--vo-radius-xl);overflow:hidden;box-shadow:var(--vo-shadow-lg);border:1px solid var(--vo-g200)}
.vo-location-map iframe{width:100%;height:520px;display:block;border:0;filter:saturate(.7) contrast(1.05);transition:filter .5s}
.vo-location-map:hover iframe{filter:saturate(1) contrast(1)}

/* --- PROCESS --- */
.vo-process{padding:120px 0;background:var(--vo-navy);position:relative;overflow:hidden}
.vo-process::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 600px 400px at 80% 20%,rgba(26,127,181,.1),transparent)}
.vo-process .vo-container{position:relative;z-index:2}
.vo-process .vo-section-label{color:var(--vo-blue-light)}
.vo-process .vo-section-title{color:var(--vo-white)}
.vo-process .vo-section-desc{color:rgba(255,255,255,.5)}
.vo-process-header{text-align:center;margin-bottom:64px}
.vo-process-header .vo-section-desc{margin:0 auto}
.vo-process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.vo-process-step{position:relative;padding:36px 28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--vo-radius-lg);transition:all .4s}
.vo-process-step:hover{background:rgba(255,255,255,.07);transform:translateY(-6px);border-color:rgba(26,127,181,.2)}
.vo-step-number{font-family:'Plus Jakarta Sans',sans-serif;font-size:48px;font-weight:800;color:rgba(26,127,181,.2);line-height:1;margin-bottom:20px;letter-spacing:-1px}
.vo-process-step h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:600;color:var(--vo-white);margin-bottom:10px}
.vo-process-step p{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:rgba(255,255,255,.45);line-height:1.6}

/* --- CONTACT --- */
.vo-contact{padding:120px 0;background:var(--vo-cream)}
.vo-contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.vo-contact-info{padding-top:20px}
.vo-contact-info .vo-section-desc{margin-bottom:40px}
.vo-contact-details{display:flex;flex-direction:column;gap:20px;margin-bottom:40px}
.vo-contact-detail{display:flex;align-items:flex-start;gap:16px}
.vo-contact-detail-icon{width:48px;height:48px;min-width:48px;background:var(--vo-blue-soft);border-radius:16px;display:flex;align-items:center;justify-content:center}
.vo-contact-detail-icon svg{width:22px;height:22px;stroke:var(--vo-blue);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.vo-contact-detail h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;color:var(--vo-navy);margin-bottom:4px}
.vo-contact-detail p{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--vo-g500);line-height:1.5}
.vo-whatsapp-btn{display:inline-flex;align-items:center;gap:12px;background:#25D366;color:white;padding:18px 36px;border-radius:var(--vo-radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;text-decoration:none;transition:all .4s cubic-bezier(.22,1,.36,1);box-shadow:0 4px 20px rgba(37,211,102,.3)}
.vo-whatsapp-btn:hover{background:#22c55e;transform:translateY(-2px);box-shadow:0 8px 30px rgba(37,211,102,.4)}
.vo-whatsapp-btn svg{fill:white}
.vo-contact-form-card{background:var(--vo-white);border-radius:var(--vo-radius-xl);padding:48px;border:1px solid var(--vo-g200);box-shadow:var(--vo-shadow-md)}
.vo-contact-form-card h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:26px;font-weight:700;color:var(--vo-navy);margin-bottom:8px;letter-spacing:-.3px}
.vo-form-sub{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--vo-g500);margin-bottom:32px}
.vo-form-group{margin-bottom:20px}
.vo-form-group label{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;color:var(--vo-navy);margin-bottom:8px}
.vo-form-group input,.vo-form-group select,.vo-form-group textarea{width:100%;padding:14px 18px;border:1px solid var(--vo-g200);border-radius:var(--vo-radius-sm);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--vo-g900);background:var(--vo-g100);transition:all .3s;outline:none}
.vo-form-group input:focus,.vo-form-group select:focus,.vo-form-group textarea:focus{border-color:var(--vo-blue);background:var(--vo-white);box-shadow:0 0 0 3px rgba(26,127,181,.1)}
.vo-form-group textarea{height:100px;resize:vertical}
.vo-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.vo-btn-submit{width:100%;padding:16px;background:var(--vo-navy);color:white;border:none;border-radius:var(--vo-radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.22,1,.36,1)}
.vo-btn-submit:hover{background:var(--vo-blue);box-shadow:0 8px 24px rgba(26,127,181,.3)}

/* --- FLOAT WA --- */
.vo-floating-wa{position:fixed;bottom:28px;right:28px;z-index:90;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(37,211,102,.4);text-decoration:none;transition:all .3s;animation:voFloat 3s ease-in-out infinite}
.vo-floating-wa:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(37,211,102,.5)}
.vo-floating-wa svg{fill:white}

/* --- RESPONSIVE --- */
@media(max-width:960px){
  .vo-hero-top-bar{padding:24px}
  .vo-hero-content{padding:0 24px 60px}
  .vo-hero-dev-logo{height:120px;margin-bottom:1rem}
  .vo-hero-cta-group{flex-wrap:wrap}
  .vo-hero-data-row{gap:10px}
  .vo-hero-data-card{padding:16px 20px;min-width:120px}
  .vo-data-value{font-size:22px}
  .vo-stats-inner{grid-template-columns:repeat(2,1fr)}
  .vo-about-grid,.vo-location-grid,.vo-contact-wrapper{grid-template-columns:1fr;gap:40px}
  .vo-about-image{aspect-ratio:16/9}
  .vo-amenities-grid{grid-template-columns:repeat(2,1fr)}
  .vo-model-content{grid-template-columns:1fr}
  .vo-model-visual{min-height:auto;height:300px;border-radius:var(--vo-radius-xl) var(--vo-radius-xl) 0 0}
  .vo-model-info{padding:24px;display:flex;flex-direction:column;justify-content:center}
  .vo-model-info h3{font-size:24px;margin-bottom:4px}
  .vo-model-type{font-size:11px;margin-bottom:16px}
  .vo-model-specs{gap:10px;margin-bottom:20px}
  .vo-model-spec{padding:10px}
  .vo-model-spec-text{font-size:11px;line-height:1.3}
  .vo-model-areas{padding:16px 0;margin-bottom:16px;gap:16px}
  .vo-model-spec-icon{width:30px;height:30px;min-width:30px}
  .vo-model-info{padding:36px}
  .vo-process-steps{grid-template-columns:repeat(2,1fr)}
  .vo-poi-grid{grid-template-columns:1fr 1fr}
  .vo-models-tabs{flex-wrap:nowrap}
}
@media(max-width:600px){
  .vo-stats-inner{grid-template-columns:repeat(2,1fr)}
  .vo-amenities-grid{grid-template-columns:1fr}
  .vo-model-specs{grid-template-columns:1fr}
  .vo-model-areas{flex-direction:column;gap:16px}
  .vo-process-steps{grid-template-columns:1fr}
  .vo-hero-data-row{flex-direction:column}
  .vo-hero-data-card{min-width:unset}
  .vo-form-row{grid-template-columns:1fr}
  .vo-poi-grid{grid-template-columns:1fr}
  .vo-hero-cta-group{flex-direction:column;width:100%}
  .vo-btn-primary,.vo-btn-outline{width:100%;justify-content:center}
  .vo-hero-top-bar{display:none}
  .vo-hero{align-items:center}
  .vo-hero-content{padding:160px 20px 80px}
  .vo-hero-dev-logo{height:120px;margin-bottom:1rem}
  .vo-hero-badge{font-size:10px;padding:6px 16px;margin-bottom:20px}
  .vo-hero-subtitle{font-size:14px;margin-bottom:24px}
  .vo-hero-cta-group{margin-bottom:32px}
  .vo-oriente-text{font-size:16px}
}
@media(max-width:480px){
  .vo-hero-content{padding:150px 16px 32px}
  .vo-hero-dev-logo{height:100px}
  .vo-hero h1{font-size:clamp(28px,8vw,38px)}
  .vo-hero-subtitle{font-size:13px}
  .vo-hero-data-card{padding:12px 16px}
  .vo-data-value{font-size:20px}
  .vo-stats-inner{grid-template-columns:1fr 1fr}
  .vo-container{padding:0 16px}
  .vo-section-title{font-size:clamp(24px,6vw,36px)}
}
