/* ===== CONTENT PROTECTION ===== */
img{-webkit-user-drag:none;user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}
a img{pointer-events:auto}
body{-webkit-user-select:none;user-select:none}
input,textarea,select,[contenteditable]{-webkit-user-select:text;user-select:text}
@media print{body,body *{display:none!important;visibility:hidden!important}}

/* ===== RESET and BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#18263a;
  --navy-light:#1e3050;
  --white:#ffffff;
  --off-white:#f8f7f4;
  --teal:#2a9d8f;
  --teal-dark:#238b7e;
  --gold:#c9a96e;
  --gold-light:#d4b97e;
  --gray-100:#f5f5f5;
  --gray-200:#e8e8e8;
  --gray-400:#999;
  --gray-600:#666;
  --gray-800:#333;
  --body-text:#333;
  --text-body:#333;
  --font-heading:'haboro-contrast-extended',sans-serif;
  --font-subheading:'Inder',sans-serif;
  --font-body:'Inter',sans-serif;
  --transition:0.3s ease;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--body-text);line-height:1.7;overflow-x:hidden;background:var(--white)}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition)}
ul{list-style:none}
h1,h2{font-family:var(--font-heading);line-height:1.2;font-weight:700}h3,h4,h5,h6{font-family:var(--font-subheading);line-height:1.2;font-weight:700}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:20px 0;transition:all 0.3s ease;background:linear-gradient(180deg,rgba(24,38,58,0.85) 0%,rgba(24,38,58,0.3) 60%,transparent 100%)}
.header.scrolled{background:rgba(24,38,58,0.97);backdrop-filter:blur(12px);padding:12px 0;box-shadow:0 2px 20px rgba(0,0,0,0.15)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:0 40px}
.header-logo img{height:90px;width:auto;transition:height 0.3s ease}
.header.scrolled .header-logo img{height:65px}
.header-right{display:flex;align-items:center;gap:20px}
.btn-schedule{display:inline-block;font-family:var(--font-body);font-weight:400;font-size:14px;letter-spacing:3px;text-transform:uppercase;padding:22px 26px;border:1px solid var(--white);border-radius:50px;color:var(--white);background:transparent;cursor:pointer;transition:all 0.3s ease}
.btn-schedule:hover{background:var(--white);color:var(--navy)}
/* ===== DESKTOP NAV LINKS ===== */
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{color:var(--white);font-family:var(--font-heading);font-size:0.8125rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--teal);transition:width var(--transition)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--teal);color:var(--white)!important;padding:10px 24px;font-size:0.75rem!important;letter-spacing:0.12em}
.nav-cta:hover{background:var(--teal-dark)}
.nav-cta::after{display:none!important}
@media(max-width:768px){.nav-links{display:none}}

.hamburger{display:flex;flex-direction:column;gap:6px;cursor:pointer;background:none;border:none;padding:8px;z-index:1001}
.hamburger span{display:block;width:28px;height:2px;background:var(--white);transition:all 0.3s ease}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,6px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}

@media(max-width:768px){
  .btn-schedule{display:none}
  .header-inner{padding:0 20px}
}

/* ===== LANGUAGE SWITCHER ===== */
.lang-switcher{display:flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:0.6875rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase}
.lang-switcher a{color:rgba(255,255,255,0.55);transition:color 0.3s ease}
.lang-switcher a:hover,.lang-switcher a.lang-active{color:var(--white)}
.lang-switcher .lang-sep{color:rgba(255,255,255,0.25);font-weight:300}
.lang-switcher-mobile{padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;gap:12px;align-items:center}
.lang-switcher-mobile a{color:rgba(255,255,255,0.55);font-family:var(--font-heading);font-size:1rem;font-weight:500;letter-spacing:0.05em;text-transform:uppercase;transition:color 0.3s ease}
.lang-switcher-mobile a.lang-active,.lang-switcher-mobile a:hover{color:var(--white)}
.lang-switcher-mobile .lang-sep{color:rgba(255,255,255,0.25)}

/* ===== MOBILE NAV + OVERLAY ===== */
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);opacity:0;visibility:hidden;transition:all 0.3s ease;z-index:998}
.mobile-overlay.open{opacity:1;visibility:visible}
.mobile-nav{position:fixed;top:0;right:-100%;width:100%;max-width:400px;height:100vh;background:var(--navy);padding:100px 40px 40px;transition:right 0.4s cubic-bezier(.77,0,.175,1);z-index:999;overflow-y:auto}
.mobile-nav.open{right:0}
.mobile-nav a{display:block;color:var(--white);font-family:var(--font-heading);font-size:1rem;font-weight:500;letter-spacing:0.05em;text-transform:uppercase;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.08)}
.mobile-nav a:hover{color:#2a9d8f}
.mobile-nav .mobile-nav-lang{padding:16px 0;margin-top:8px;display:flex;gap:12px;align-items:center}
.mobile-nav .mobile-nav-lang a{font-size:.875rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;color:rgba(255,255,255,0.55)}
.mobile-nav .mobile-nav-lang a:last-of-type{color:#fff}
.mobile-nav .mobile-nav-lang span{color:rgba(255,255,255,0.25)}

/* ===== FOOTER ===== */
.footer{background:var(--white);padding:60px 24px 40px;min-height:568px}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 20px;margin-bottom:40px;padding-bottom:32px;border-bottom:1px solid #e8e8e8}
.footer-nav a{font-family:var(--font-heading);font-size:0.875rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--navy);transition:color 0.3s ease;white-space:nowrap}
.footer-nav a:hover{color:#2a9d8f}
.footer-social{display:flex;justify-content:center;gap:20px;margin-bottom:40px}
.footer-social a{width:44px;height:44px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;transition:all 0.3s ease}
.footer-social a:hover{background:var(--teal)}
.footer-social svg{width:18px;height:18px;fill:var(--white)}
.footer-partners{display:flex;justify-content:center;align-items:center;gap:28px;margin-bottom:40px;flex-wrap:wrap}
.footer-partners img{height:48px;max-width:180px;width:auto;object-fit:contain;opacity:0.6;transition:opacity 0.3s ease}
.footer-partners img:hover{opacity:1}
.footer-disclaimer{font-size:0.75rem;color:var(--gray-400);text-align:center;line-height:1.8;max-width:800px;margin:0 auto 24px}
.footer-copyright{text-align:center;font-family:var(--font-heading);font-size:0.6875rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-400);margin-bottom:8px}
.footer-powered{text-align:center;font-family:var(--font-heading);font-size:0.625rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-400)}
.footer-legal{text-align:center;font-family:var(--font-heading);font-size:0.6875rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-400);margin-bottom:8px}
.footer-legal a{color:var(--gray-400);text-decoration:underline}
.footer-legal a:hover{color:var(--navy)}
.footer-powered a{color:var(--gray-400);text-decoration:underline}
.footer-powered a:hover{color:var(--navy)}

@media(max-width:900px){
  .footer-nav{gap:6px 14px}
  .footer-nav a{white-space:normal}
}
@media(max-width:768px){
  .footer-nav{gap:6px 12px}
  .footer-partners img{height:44px}
}

/* ===== HERO ===== */
.hero{position:relative;width:100%;height:100vh;overflow:hidden;background:var(--navy)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-gradient{position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.4) 0%,rgba(24,38,58,0.1) 50%,rgba(24,38,58,0.45) 100%);pointer-events:none}
.hero-caption{position:absolute;bottom:52px;left:56px;z-index:2;border-left:3px solid var(--gold);padding-left:22px;max-width:560px}
.hero-caption-title{font-family:var(--font-heading);font-size:clamp(1.5rem,3vw,2.6rem);font-weight:600;color:#fff;line-height:1.2;letter-spacing:0.04em;text-transform:uppercase;text-shadow:0 2px 20px rgba(0,0,0,0.5);margin:0 0 10px}
.hero-caption-sub{font-family:var(--font-heading);font-size:clamp(0.8rem,1.2vw,1rem);font-weight:400;color:var(--gold);line-height:1.5;letter-spacing:0.12em;text-transform:uppercase;text-shadow:0 1px 10px rgba(0,0,0,0.5);margin:0}
@media(max-width:768px){.hero-caption{bottom:28px;left:20px;padding-left:14px}.hero-caption-title{font-size:clamp(1.1rem,5vw,1.6rem)}.hero-caption-sub{font-size:0.75rem}}

/* ===== BEACHFRONT TEXT SECTION ===== */
.beachfront-text{background:var(--white);padding:68px 60px;text-align:center}
.beachfront-text-inner{max-width:1080px;margin:0 auto}
.beachfront-text h2{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--navy);line-height:1.2;margin-bottom:24px;white-space:nowrap}
.beachfront-text p{font-size:clamp(1.1rem,1.5vw,1.3rem);line-height:1.8;color:#444;text-align:center}
@media(max-width:768px){.beachfront-text{padding:48px 24px}.beachfront-text h2{white-space:normal}.beachfront-text p{font-size:1.05rem}}

/* ===== VIDEO SECTION ===== */
.video-section{width:100%;background:#000;line-height:0}
.video-wrapper{position:relative;width:100%;padding-top:56.25%}
.video-wrapper video,.video-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:cover}

/* ===== STATS SECTION ===== */
.stats-section{background:var(--white);padding:82px 40px 40px;text-align:center}
.stats-heading{font-family:var(--font-heading);font-size:1.5rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);margin-bottom:70px;opacity:1}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);max-width:680px;margin:0 auto;gap:0 60px}
.stat-item{padding:40px 20px;text-align:center}
.stat-number{font-family:var(--font-heading);font-size:4.5rem;font-weight:400;color:var(--navy);line-height:1;margin-bottom:14px}
.stat-number--static{font-size:4rem}
.stat-label{font-family:var(--font-heading);font-size:1rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);opacity:0.85;line-height:1.6}
@media(max-width:600px){
  .stats-grid{grid-template-columns:1fr;max-width:320px;gap:0}
  .stat-number{font-size:3rem}
  .stat-number--static{font-size:2.75rem}
}

/* ===== ELEVATED SLIDESHOW ===== */
.video-photo-divider{width:100%;height:6px;background:var(--white)}
.elevated-slideshow{position:relative;width:100%;height:min(56.25vw,820px);overflow:hidden}
.elevated-slideshow img{width:100%;height:100%;object-fit:cover;object-position:center center;filter:brightness(1.12) saturate(1.4) contrast(1.05)}
.elevated-slideshow-overlay{position:absolute;inset:0;background:rgba(24,38,58,0.15)}

/* ===== ELEVATED TEXT SECTION ===== */
.elevated-text-section{background:var(--white);padding:68px 60px;text-align:center}
.elevated-text-inner{max-width:1080px;margin:0 auto}
.elevated-right{display:none}
.elevated-left .section-label{display:none}
.elevated-left h2{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--navy);line-height:1.2;margin-bottom:24px;white-space:nowrap;text-align:center}
.elevated-left p{font-size:clamp(1.1rem,1.5vw,1.3rem);line-height:1.8;color:#444;text-align:center}
@media(max-width:768px){.elevated-text-section{padding:48px 24px}.elevated-left h2{white-space:normal}.elevated-left p{font-size:1.05rem}}

/* ===== ARCHITECTURE SLIDESHOW ===== */
.architecture-slideshow{position:relative;width:100%;height:min(71vw,750px);overflow:hidden}
.architecture-slideshow img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.architecture-slideshow-overlay{position:absolute;inset:0;background:rgba(24,38,58,0.1)}

/* ===== OCEAN VIEW SECTION ===== */
.ocean-view-section{background:var(--white);padding:36px 60px}
.ocean-view-section > div{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;max-width:1100px;margin:0 auto;align-items:center}
.ocean-view-section h2{font-family:var(--font-heading);font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--navy);line-height:1.2;margin-bottom:28px}
.ocean-view-section .btn-dark{display:inline-block}
.unit-list{list-style:none;padding:0;margin:0 0 32px}
.unit-list li{font-size:1.15rem;color:#444;padding:14px 0;border-bottom:1px solid #e8e8e8;line-height:1.5;white-space:nowrap}
.unit-list li::before{content:"• ";color:var(--navy)}
@media(max-width:900px){
  .ocean-view-section > div{grid-template-columns:1fr;gap:40px}
  .ocean-view-section{padding:60px 24px}
}

/* ===== INTERIOR CAROUSEL ===== */
.interior-carousel-section{padding:0;overflow:hidden;background:var(--white)}
.interior-carousel{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;cursor:grab;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.interior-carousel::-webkit-scrollbar{display:none}
.interior-carousel-item{flex:0 0 calc(100%/3);scroll-snap-align:start;min-width:280px}
.interior-carousel-item img{width:100%;height:400px;object-fit:cover;display:block}
@media(max-width:768px){
  .interior-carousel-item{flex:0 0 80vw}
}

/* ===== AMENITIES SECTION ===== */
.amenities-section{background:var(--white);padding:36px 60px}
.amenities-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;max-width:1200px;margin:0 auto;align-items:center}
.amenities-text .section-label{color:var(--navy);display:block;margin-bottom:12px}
.amenities-text h2{font-family:var(--font-heading);font-size:clamp(2rem,3.5vw,2.8rem);color:var(--navy);margin-bottom:20px;line-height:1.2}
.amenities-text p{font-size:1.0625rem;color:#555;line-height:1.8;margin-bottom:28px}
.amenities-image img{width:100%;height:560px;object-fit:cover;border-radius:4px}
@media(max-width:900px){
  .amenities-inner{grid-template-columns:1fr;gap:40px}
  .amenities-section{padding:60px 24px}
  .amenities-image{order:-1}
}

/* ===== COMMUNITY SECTION ===== */
.community-section{background:var(--white);padding:36px 60px}
.community-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;max-width:1200px;margin:0 auto;align-items:center}
.community-text .section-label{color:var(--navy);display:block;margin-bottom:12px}
.community-text h2{font-family:var(--font-heading);font-size:clamp(2rem,3.5vw,2.8rem);color:var(--navy);margin-bottom:20px;line-height:1.2}
.community-text p{font-size:1.0625rem;color:#555;line-height:1.8;margin-bottom:28px}
.community-image img{width:100%;height:560px;object-fit:cover;border-radius:4px}
@media(max-width:900px){
  .community-inner{grid-template-columns:1fr;gap:40px}
  .community-section{padding:60px 24px}
  .community-image{order:-1}
}

/* ===== LIFESTYLE HERO CAROUSEL ===== */
.lch-section{position:relative;overflow:hidden;background:#06111d;line-height:0}
.lch-track{position:relative;height:640px}
.lch-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s cubic-bezier(.4,0,.2,1);z-index:0}
.lch-slide.active{opacity:1;z-index:1}
.lch-slide img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.lch-slide.active img{animation:lchKB 9s ease-out both}
@keyframes lchKB{from{transform:scale(1.06) translateX(6px)}to{transform:scale(1) translateX(0)}}
.lch-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(6,17,29,.55) 100%);z-index:2;pointer-events:none}
.lch-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .3s}
.lch-btn:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.5);transform:translateY(-50%) scale(1.1)}
.lch-prev{left:2rem}.lch-next{right:2rem}
.lch-dots{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:6;display:flex;gap:10px;line-height:1}
.lch-dot{width:32px;height:2px;background:rgba(255,255,255,.3);border:none;padding:0;cursor:pointer;border-radius:1px;transition:background .4s,width .4s}
.lch-dot.active{background:#fff;width:52px}
/* ===== LIFESTYLE ACCENT ROW ===== */
.lifestyle-accent-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:5px;background:var(--navy);padding:5px 5px 0}
.accent-img{overflow:hidden;position:relative}
.accent-img img{width:100%;height:360px;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.accent-img:hover img{transform:scale(1.05)}
@media(max-width:900px){
  .lch-track{height:460px}
  .lifestyle-accent-row{grid-template-columns:1fr 1fr}
  .accent-img--wide{grid-column:1/-1}
  .accent-img img{height:260px}
}
@media(max-width:540px){
  .lch-track{height:320px}
  .lch-btn{width:38px;height:38px}.lch-prev{left:.75rem}.lch-next{right:.75rem}
  .lifestyle-accent-row{grid-template-columns:1fr}
  .accent-img--wide{grid-column:1}
  .accent-img img{height:220px}
}

/* ===== CLOSING STATEMENT ===== */
.closing-statement{background:#06111d;padding:80px 40px 60px;text-align:center}
.closing-statement h2{font-family:var(--font-heading);font-size:clamp(1.4rem,3.5vw,2.4rem);font-weight:300;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,.88);max-width:700px;margin:0 auto;line-height:1.4}

/* ===== LIFESTYLE MOSAIC ===== */
.lifestyle-mosaic-section{background:#06111d;padding:0;line-height:0}

.lifestyle-mosaic{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  grid-auto-rows:400px;
  gap:3px;
}

/* All items fill their grid cell fully — zero black gaps */
.lifestyle-mosaic-item{
  position:relative;
  overflow:hidden;
  background:#06111d;
}

.lifestyle-mosaic-item img,
.lifestyle-mosaic-item canvas{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .9s cubic-bezier(.25,.46,.45,.94);
}
.lifestyle-mosaic-item:hover img{transform:scale(1.08)}

/* Premium hover overlay */
.lm-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,17,29,.95) 0%,rgba(6,17,29,.2) 45%,transparent 72%);
  opacity:0;transition:opacity .5s ease;
  display:flex;align-items:flex-end;padding:24px 22px;
}
.lm-overlay span{
  font-family:var(--font-heading);
  font-size:.8rem;
  font-weight:800;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#fff;
  position:relative;
  padding-bottom:7px;
  transform:translateY(16px);
  transition:transform .48s cubic-bezier(.25,.46,.45,.94);
  text-shadow:0 2px 12px rgba(0,0,0,.4);
}
/* Animated teal underline draws across on hover */
.lm-overlay span::after{
  content:'';
  position:absolute;
  bottom:0;left:0;
  width:0;height:2px;
  background:var(--teal);
  transition:width .42s ease .08s;
}
.lifestyle-mosaic-item:hover .lm-overlay{opacity:1}
.lifestyle-mosaic-item:hover .lm-overlay span{transform:translateY(0)}
.lifestyle-mosaic-item:hover .lm-overlay span::after{width:100%}

@media(max-width:1024px){
  .lifestyle-mosaic{grid-template-columns:repeat(3,1fr);grid-auto-rows:280px}
}
@media(max-width:640px){
  .lifestyle-mosaic{grid-template-columns:repeat(2,1fr);grid-template-rows:none}
  .lifestyle-mosaic-item{aspect-ratio:4/5}
}

/* ===== INQUIRE SECTION ===== */
.inquire-section{background:var(--navy);padding:90px 40px}
.inquire-inner{max-width:900px;margin:0 auto;text-align:center}
.inquire-eyebrow{display:block;font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);margin-bottom:20px}
.inquire-inner > div > h2{display:none}
.inquire-inner > p,.inquire-inner > div > p{font-family:var(--font-heading);font-size:1rem;letter-spacing:0.15em;text-transform:uppercase;color:#fff;margin-bottom:50px}
.inquire-benefits{display:none}
.inquire-trust{display:none}
.inquire-right-label{display:none}
.inquire-left h2{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);margin-bottom:16px}
.inquire-left p{font-family:var(--font-heading);font-size:1rem;letter-spacing:0.15em;text-transform:uppercase;color:#fff;margin-bottom:50px}
.inquire-form{text-align:left;width:100%}
.inquire-form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.inquire-form-group{display:flex;flex-direction:column;margin-bottom:20px}
.inquire-form-group label{font-size:0.8rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.55);font-weight:300;margin-bottom:8px}
.inquire-optional{font-size:0.7rem;opacity:0.6;text-transform:none;letter-spacing:0}
.inquire-form input[type="text"],
.inquire-form input[type="email"],
.inquire-form input[type="tel"],
.inquire-form textarea{font-size:1rem;color:#fff;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.25);border-radius:4px;padding:12px 16px;width:100%;box-sizing:border-box;outline:none;transition:border-color .2s}
.inquire-form input:focus,
.inquire-form textarea:focus{border-color:var(--gold)}
.inquire-form input::placeholder,
.inquire-form textarea::placeholder{color:rgba(255,255,255,0.3)}
.inquire-form textarea{resize:vertical;min-height:110px}
.inquire-radio-group{display:flex;gap:28px;margin-top:4px}
.inquire-radio{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,0.7);font-size:0.9rem;font-weight:300;letter-spacing:0.05em;cursor:pointer}
.inquire-radio input[type="radio"]{width:auto;accent-color:var(--gold)}
.inquire-submit{margin-top:12px;font-family:var(--font-heading);font-size:0.8rem;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;color:var(--navy);background:var(--gold);border:none;padding:14px 40px;cursor:pointer;transition:background .2s}
.inquire-submit:hover{background:#b8924f}
@media(max-width:768px){.inquire-form-row{grid-template-columns:1fr}}

/* ===== UTILITY: SECTION LABEL ===== */
.section-label{font-family:var(--font-heading);font-size:0.6875rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:12px;opacity:0.5}
.section-title{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;color:var(--navy);margin-bottom:20px}

/* ===== UTILITY: PAGE-LEVEL TEXT ===== */
.page-label{display:block;font-family:var(--font-heading);font-size:0.75rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:0.75rem}
.page-title{font-family:var(--font-heading);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:300;color:var(--navy);line-height:1.3;margin-bottom:1.25rem}
.page-text{font-size:1rem;color:#555;line-height:1.8}

/* ===== UTILITY: BUTTONS ===== */
.btn{display:inline-block;font-family:var(--font-heading);font-weight:600;font-size:0.8125rem;letter-spacing:0.15em;text-transform:uppercase;padding:16px 40px;border:none;cursor:pointer;transition:all var(--transition);text-align:center}
.btn-primary{background:var(--teal);color:var(--white)}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(42,157,143,0.3)}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 25px rgba(201,169,110,0.3)}
.btn-outline{background:transparent;color:var(--white);border:2px solid var(--white)}
.btn-outline:hover{background:var(--white);color:var(--navy)}
.btn-dark{display:inline-block;font-family:var(--font-body);font-weight:400;font-size:16px;letter-spacing:5px;text-transform:uppercase;padding:0 0 9px;background:transparent;color:#000;border:none;border-bottom:2px solid #000;cursor:pointer;transition:all 0.3s ease}
.btn-dark:hover{opacity:0.7}
.btn-outline-dark{display:inline-block;font-family:var(--font-heading);font-weight:600;font-size:0.6875rem;letter-spacing:0.18em;text-transform:uppercase;padding:14px 32px;border:1.5px solid var(--navy);color:var(--navy);background:transparent;cursor:pointer;transition:all 0.3s ease}
.btn-outline-dark:hover{background:var(--navy);color:var(--white)}

/* ===== SCROLL ANIMATIONS ===== */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity 0.8s ease,transform 0.8s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.slide-up{opacity:0;transform:translateY(70px);transition:opacity 0.9s ease,transform 0.9s ease}
.slide-up.visible{opacity:1;transform:translateY(0)}

/* ===== UTILITY: TRANSITION DELAYS ===== */
.delay-0{transition-delay:0s}
.delay-1{transition-delay:0.1s}
.delay-2{transition-delay:0.2s}
.delay-3{transition-delay:0.3s}
.delay-4{transition-delay:0.4s}
.delay-08{transition-delay:.08s}
.delay-16{transition-delay:.16s}
.delay-24{transition-delay:.24s}

/* ===== PAGE: BLOG INDEX ===== */
.blog-hero{
  position:relative;height:65vh;min-height:440px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;
}
.blog-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,.35) 0%,rgba(24,38,58,.72) 100%)}
.blog-hero .hero-content{position:relative;z-index:2;text-align:center;padding:0 24px;max-width:780px}
.blog-hero .hero-eyebrow{display:block;font-family:var(--font-heading);font-size:1.75rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;opacity:0;animation:fadeUp .7s .2s ease both}
.blog-hero h1{color:var(--white);font-size:clamp(1.8rem,4vw,3rem);font-weight:700;margin-bottom:16px;opacity:0;animation:fadeUp .7s .38s ease both}
.blog-hero p{color:rgba(255,255,255,.88);font-size:1rem;line-height:1.8;max-width:620px;margin:0 auto;opacity:0;animation:fadeUp .7s .56s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

.blog-section{padding:100px 0;background:var(--off-white)}

/* Featured first post */
.blog-featured{
  display:grid;grid-template-columns:1.4fr 1fr;gap:0;
  background:var(--white);border-radius:6px;overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.09);margin-bottom:48px;
  opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;
}
.blog-featured.visible{opacity:1;transform:translateY(0)}
.blog-featured-img{position:relative;overflow:hidden;min-height:380px}
.blog-featured-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.blog-featured:hover .blog-featured-img img{transform:scale(1.04)}
.blog-featured-badge{
  position:absolute;top:20px;left:20px;
  background:var(--gold);color:var(--white);
  font-family:var(--font-heading);font-size:.65rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;padding:6px 14px;border-radius:3px;
}
.blog-featured-body{padding:48px;display:flex;flex-direction:column;justify-content:center}
.blog-featured-body .blog-card-date{font-size:.8rem;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;font-weight:500}
.blog-featured-body h2{font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:700;color:var(--navy);margin-bottom:16px;line-height:1.3}
.blog-featured-body h2 a{color:var(--navy)}
.blog-featured-body h2 a:hover{color:var(--teal)}
.blog-featured-body p{font-size:.9375rem;color:var(--gray-600);line-height:1.75;margin-bottom:28px}
.blog-card-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-heading);font-size:.78rem;font-weight:600;
  color:var(--teal);text-transform:uppercase;letter-spacing:.1em;
  border-bottom:2px solid var(--teal);padding-bottom:4px;
  transition:all var(--transition);
}
.blog-card-link:hover{color:var(--navy);border-color:var(--navy)}

/* Standard grid */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

/* Card */
.blog-card{
  background:var(--white);border-radius:6px;overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  opacity:0;transform:translateY(30px);
  transition:opacity .6s ease,transform .6s ease,box-shadow .35s ease;
}
.blog-card.visible{opacity:1;transform:translateY(0)}
.blog-card:hover{transform:translateY(-6px)!important;box-shadow:0 20px 48px rgba(0,0,0,.12)}
.blog-card-img{position:relative;overflow:hidden;aspect-ratio:16/10}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .65s cubic-bezier(.25,.46,.45,.94)}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(24,38,58,.65) 100%);
  opacity:0;transition:opacity .4s ease;
}
.blog-card:hover .blog-card-img-overlay{opacity:1}
.blog-card-body{padding:26px 28px 28px}
.blog-card-date{font-size:.78rem;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;font-weight:500}
.blog-card-body h3{font-size:1.05rem;font-weight:600;color:var(--navy);margin-bottom:10px;line-height:1.4}
.blog-card-body h3 a{color:var(--navy);transition:color var(--transition)}
.blog-card-body h3 a:hover{color:var(--teal)}
.blog-card-body p{font-size:.9rem;color:var(--gray-600);line-height:1.7;margin-bottom:18px}
.blog-card-tag{
  display:inline-block;font-family:var(--font-heading);font-size:.65rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  background:rgba(42,157,143,.1);color:var(--teal);
  padding:3px 10px;border-radius:3px;margin-bottom:10px;
}
@media(max-width:960px){
  .blog-featured{grid-template-columns:1fr}
  .blog-featured-img{min-height:260px}
  .blog-featured-body{padding:32px}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:580px){
  .blog-grid{grid-template-columns:1fr}
  .blog-featured-body{padding:24px}
}

/* ===== TEMPLATE: BLOG ARTICLE ===== */
.article-hero{
  position:relative;height:50vh;min-height:350px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;
}
.article-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,.3) 0%,rgba(24,38,58,.7) 100%)}
.article-hero .hero-content{position:relative;z-index:2;text-align:center;padding:0 24px;max-width:800px}
.article-hero h1{color:var(--white);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;margin-bottom:12px}
.article-hero .hero-meta{color:rgba(255,255,255,.8);font-size:0.875rem;text-transform:uppercase;letter-spacing:.1em}

.article{padding:80px 0 100px}
.article-container{max-width:800px;margin:0 auto;padding:0 24px}
.article-container p{font-size:1rem;color:var(--gray-800);line-height:1.9;margin-bottom:24px}
.article-container h2{font-size:clamp(1.25rem,3vw,1.75rem);color:var(--navy);margin:48px 0 20px;font-weight:700}
.article-container h3{font-size:clamp(1rem,2vw,1.25rem);color:var(--navy);margin:32px 0 12px;font-weight:600}
.article-container ul,.article-container ol{margin:0 0 24px 24px;color:var(--gray-800)}
.article-container li{margin-bottom:8px;line-height:1.8}
.article-container img{border-radius:4px;margin:32px 0}
.article-container .back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-heading);font-size:.8125rem;font-weight:600;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:32px;transition:color var(--transition)}
.article-container .back-link:hover{color:var(--navy)}
.article-container .back-link svg{width:16px;height:16px;fill:currentColor}

/* Stats row used in some articles */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:40px 0;text-align:center}
.stat-box{background:var(--off-white);padding:28px 20px;border-radius:4px}
.stat-box .number{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.stat-box .label{font-size:.875rem;color:var(--gray-600)}
@media(max-width:600px){.stats-row{grid-template-columns:1fr}}

/* ===== SHARED: CONTACT SECTION (content pages) ===== */
.contact{padding:120px 0;background:var(--navy);position:relative}
.contact::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,.4),transparent)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-text h2{color:var(--white);font-size:clamp(1.75rem,3.5vw,2.5rem);margin-bottom:20px}
.contact-text .section-label{color:var(--gold);opacity:1}
.contact-text p{color:rgba(255,255,255,.75);font-size:1rem;line-height:1.8;margin-bottom:32px}
.contact-details{display:flex;flex-direction:column;gap:20px}
.contact-detail{display:flex;align-items:flex-start;gap:16px;color:rgba(255,255,255,.8)}
.contact-detail svg{width:20px;height:20px;fill:var(--teal);flex-shrink:0;margin-top:3px}
.contact-detail strong{color:var(--white)}
.contact-form-wrapper{background:rgba(255,255,255,.05);padding:40px;border-radius:4px;border:1px solid rgba(255,255,255,.08);min-height:400px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:48px}}

/* ===== TEMPLATE: RESIDENCE UNIT ===== */
.unit-hero{position:relative;height:70vh;min-height:500px;overflow:hidden;display:flex;align-items:flex-end;background-size:cover;background-position:center}
.unit-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,.3) 0%,rgba(24,38,58,.7) 100%)}
.unit-hero-content{position:relative;z-index:2;padding:60px 0;width:100%}
.unit-hero h1{color:var(--white);font-size:clamp(1.5rem,3.2vw,2.6rem);font-weight:600;margin-bottom:8px}
.unit-hero .unit-subtitle{color:var(--gold);font-family:var(--font-heading);font-size:1rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500}
@media(max-width:768px){.unit-hero{height:55vh;min-height:360px}.unit-hero-content{padding:40px 0}}

.unit-back-link{display:inline-flex;align-items:center;gap:8px;color:var(--teal);font-family:var(--font-heading);font-size:.8125rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:24px 0;transition:all var(--transition)}
.unit-back-link:hover{color:var(--gold);gap:12px}
.unit-back-link svg{width:18px;height:18px;fill:currentColor}

.specs-bar{background:var(--navy);padding:40px 0}
.specs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:32px;text-align:center}
.spec-item{color:var(--white)}
.spec-value{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--gold);margin-bottom:4px}
.spec-label{font-size:.8125rem;letter-spacing:.1em;text-transform:uppercase;opacity:0.7}
@media(max-width:600px){.specs-grid{gap:20px}.spec-value{font-size:1.4rem}}

.unit-description{padding:80px 0}
.unit-description-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.unit-description h2{font-size:clamp(1.5rem,3vw,2.25rem);color:var(--navy);margin-bottom:24px}
.unit-description p{font-size:1.0625rem;color:var(--gray-600);line-height:1.9;margin-bottom:24px}
.unit-description-grid img{border-radius:4px;width:100%;height:auto;display:block}
.unit-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:32px}
@media(max-width:768px){.unit-description-grid{grid-template-columns:1fr}.unit-description{padding:60px 0}}

.unit-floorplan{padding:96px 0;background:var(--off-white)}
.unit-floorplan .section-label{color:var(--teal)!important;opacity:1}
.unit-floorplan .fp-header{text-align:center;margin-bottom:52px}
.unit-floorplan .fp-header h2{font-size:clamp(1.5rem,3vw,2.25rem);color:var(--navy);margin-bottom:0}
.unit-floorplan .fp-header h2::after{content:'';display:block;width:40px;height:2px;background:var(--gold);margin:18px auto 0}
.floorplan-display{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:40px}
.floorplan-display>img{flex:1;min-width:0;height:auto;display:block;mix-blend-mode:multiply}
.fp-measures{width:220px;flex-shrink:0;background:#fff;border:1px solid rgba(201,169,110,.55);border-radius:3px;padding:12px 12px 10px;box-shadow:0 4px 24px rgba(24,38,58,.14);transition:transform .3s ease,box-shadow .3s ease;z-index:10;cursor:pointer}
.fp-measures--sm{width:180px}
.fp-measures:hover{transform:scale(1.05);box-shadow:0 10px 40px rgba(24,38,58,.22)}
.fp-measures-label{display:block;font-family:var(--font-heading);font-size:.57rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:8px}
.fp-measures img{width:100%;height:auto;display:block}
.fp-measures-click{display:block;font-family:var(--font-heading);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--white);background:var(--teal);text-align:center;margin-top:10px;padding:8px 6px 7px;border-radius:2px;font-weight:600}
.fp-lightbox{position:fixed;inset:0;background:rgba(10,16,26,.92);z-index:9999;display:flex;align-items:center;justify-content:center;padding:32px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;cursor:pointer}
.fp-lightbox.open{opacity:1;visibility:visible}
.fp-lightbox img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:3px;cursor:default;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.fp-lightbox-close{position:absolute;top:18px;right:22px;background:none;border:none;color:#fff;font-size:2.2rem;line-height:1;cursor:pointer;opacity:.65;transition:opacity .2s;font-weight:300}
.fp-lightbox-close:hover{opacity:1}
@media(max-width:768px){
  .unit-floorplan{padding:60px 0}
  .floorplan-display{flex-direction:column;align-items:flex-start;gap:24px}
  .fp-measures,.fp-measures--sm{width:100%;max-width:320px}
}

.other-residences{padding:100px 0}
.other-residences h2{text-align:center;font-size:clamp(1.5rem,3vw,2.25rem);color:var(--navy);margin-bottom:48px}
.other-residences .section-label{text-align:center}
.other-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.other-card{background:var(--white);border-radius:4px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:all var(--transition)}
.other-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.12)}
.other-card-img{aspect-ratio:16/9;overflow:hidden}
.other-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.other-card:hover .other-card-img img{transform:scale(1.05)}
.other-card-body{padding:20px}
.other-card-body h3{font-size:1rem;color:var(--navy);margin-bottom:6px}
.other-card-body p{font-size:.8125rem;color:var(--gray-600)}
@media(max-width:900px){.other-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.other-grid{grid-template-columns:1fr}}

/* ===== PAGE: ABOUT US ===== */
.about-hero{position:relative;height:80vh;min-height:520px;overflow:hidden}
.about-hero-bg{position:absolute;inset:0;background:#1a0f2e url('../images/brasilito-beach-sunset-hero.webp') center bottom/100% auto no-repeat;filter:saturate(1.2) brightness(1.05) contrast(1.05)}
.about-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.25) 0%,transparent 45%,rgba(24,38,58,0.72) 100%)}
.about-hero-content{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:2;text-align:left;width:90%;max-width:1200px}
.about-hero-title{font-family:var(--font-heading);font-size:clamp(1.5rem,3.5vw,2.8rem);font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,0.65);line-height:1.2;margin:0}
.gtu-section{background:#fff;padding:80px 2rem;text-align:center}
.gtu-inner{max-width:1100px;margin:0 auto}
.gtu-label{font-family:var(--font-heading);font-size:0.6875rem;letter-spacing:.25em;text-transform:uppercase;color:var(--navy);font-weight:600;opacity:0.5;display:block;margin-bottom:1.4rem}
.gtu-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;color:#0f1e2d;line-height:1.2;margin:0 auto;max-width:900px;letter-spacing:0.05em;text-transform:uppercase}
.gtu-rule{width:40px;height:2px;background:#c9a96e;margin:1.5rem auto 2.75rem}
.gtu-body{max-width:1000px;margin:0 auto}
.gtu-body p{font-size:clamp(1.1rem,1.5vw,1.3rem);color:#444;line-height:1.8;margin-bottom:1.3rem;text-align:center}
.gtu-body p:last-child{margin-bottom:0}
.team-section{background:#0f1e2d;padding:7rem 2rem}
.team-inner{max-width:1200px;margin:0 auto;text-align:center}
.team-heading{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;font-style:italic;color:#fff;letter-spacing:.01em;line-height:1.15;margin-bottom:0}
.team-rule{width:40px;height:1px;background:#c9a96e;margin:1.5rem auto 4rem}
.team-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem 2rem;text-align:left}
.team-card{display:flex;flex-direction:column;flex:0 0 calc(25% - 1.5rem);max-width:calc(25% - 1.5rem)}
.team-photo-wrap{width:100%;aspect-ratio:1/1;overflow:hidden;margin-bottom:1.1rem}
.team-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.team-initials-wrap{width:100%;aspect-ratio:1/1;background:#172b3a;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.team-initials-wrap span{font-family:var(--font-heading);font-size:2.2rem;font-weight:300;color:#c9a96e;letter-spacing:.06em}
.team-name{font-family:var(--font-heading);font-size:1.15rem;font-weight:600;color:#fff;margin:0 0 .3rem;line-height:1.3}
.team-role{font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#2a9d8f;margin:0}
.team-email{display:inline-block;font-size:.72rem;color:#c9a96e;text-decoration:none;margin-top:.45rem;opacity:.85}
.team-email:hover{opacity:1;text-decoration:underline}
@media(max-width:900px){.team-card{flex:0 0 calc(50% - 1rem);max-width:calc(50% - 1rem)}}
@media(max-width:480px){.team-card{flex:0 0 100%;max-width:100%}}
.partners-section{background:#fff;padding:7rem 0}
.partners-inner{max-width:1100px;margin:0 auto;padding:0 40px}
.partners-heading{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;color:#0f1e2d;text-align:center;margin-bottom:0;letter-spacing:0.05em;text-transform:uppercase}
.partners-rule{width:40px;height:2px;background:#c9a96e;margin:1.5rem auto 4.5rem}
.partner-row{display:grid;grid-template-columns:1fr 1fr;gap:0 80px;padding:60px 0;border-bottom:1px solid #e8e8e8}
.partner-row:first-of-type{padding-top:0}
.partner-row:last-child{border-bottom:none;padding-bottom:0}
.partner-card{display:flex;flex-direction:column;align-items:flex-start}
.partner-logo-img{max-height:90px;max-width:220px;width:auto;height:auto;object-fit:contain;margin-bottom:16px;mix-blend-mode:multiply}
.partner-logo-img.tall{max-height:110px}
.brasilito-impact-logo{display:inline-flex;flex-direction:column;align-items:center;margin-bottom:16px;line-height:1}
.brasilito-impact-logo .bi-name{font-family:var(--font-heading);font-size:2.1rem;font-weight:700;color:#0f1e2d;letter-spacing:0.05em;text-transform:uppercase}
.brasilito-impact-logo .bi-sub{font-family:var(--font-heading);font-size:.58rem;font-weight:400;color:#0f1e2d;letter-spacing:.38em;text-transform:uppercase;margin-top:4px}
.partner-text-logo{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:#18263a;letter-spacing:.1em;text-transform:uppercase;line-height:1.2;margin:0 0 16px}
.partner-role{font-family:var(--font-heading);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#2a9d8f;margin:0 0 16px}
.partner-desc{font-size:15px;color:#4a4a4a;line-height:1.7;margin:0 0 20px}
.partner-link{font-family:var(--font-heading);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#2a9d8f;text-decoration:none;transition:text-decoration .2s}
.partner-link:hover{text-decoration:underline}
.inquire-section{background:#0f1e2d;padding:7rem 2rem;text-align:center}
.inquire-inner{max-width:860px;margin:0 auto}
.inquire-title{font-family:var(--font-heading);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:300;color:#fff;letter-spacing:.25em;text-transform:uppercase;margin:0 0 1.1rem}
.inquire-sub{font-family:var(--font-heading);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(200,214,229,.45);margin:0 0 3.5rem;line-height:1.9}
.minimal-form{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;text-align:left}
.form-field{display:flex;flex-direction:column;gap:.5rem}
.form-field.full{grid-column:1/-1}
.form-field label{font-family:var(--font-heading);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(200,214,229,.4);font-weight:500}
.form-field input,.form-field select,.form-field textarea{background:transparent;border:none;border-bottom:1px solid rgba(200,214,229,.22);color:#fff;padding:.65rem 0;font-size:.9rem;font-family:var(--font-heading);font-weight:300;outline:none;transition:border-color .3s;width:100%;border-radius:0;-webkit-appearance:none}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-bottom-color:rgba(201,169,110,.6)}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(200,214,229,.15)}
.form-field select option{background:#0f1e2d;color:#fff}
.form-field textarea{resize:vertical;min-height:80px}
.form-submit{grid-column:1/-1;text-align:center;margin-top:.75rem}
.form-submit button{background:transparent;border:1px solid rgba(201,169,110,.55);color:#c9a96e;font-family:var(--font-heading);font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;padding:15px 52px;cursor:pointer;transition:all .3s}
.form-submit button:hover{background:#c9a96e;color:#0f1e2d}
.slim-footer{background:#111b2a;color:rgba(200,214,229,.5);padding:2.5rem 2rem}
.slim-footer-inner{max-width:1100px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem}
.slim-footer-logo img{height:32px}
.slim-footer-links{display:flex;gap:2rem;flex-wrap:wrap}
.slim-footer-links a{font-size:.72rem;color:rgba(200,214,229,.45);letter-spacing:.07em;text-transform:uppercase;transition:color .3s;text-decoration:none}
.slim-footer-links a:hover{color:#2a9d8f}
.slim-footer-copy{font-size:.7rem;color:#3a4d5e;width:100%;text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.06)}
.sister-section{background:#0f1e2d;padding:4.5rem 2rem 5rem;text-align:center}
.sister-inner{max-width:1100px;margin:0 auto}
.sister-label{font-family:var(--font-heading);font-size:0.625rem;letter-spacing:.28em;text-transform:uppercase;color:#c9a96e;font-weight:600;display:block;margin-bottom:1.25rem}
.sister-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;color:#fff;line-height:1.2;margin:0 auto 1.5rem;letter-spacing:0.05em;text-transform:uppercase}
.sister-rule{width:40px;height:1px;background:#c9a96e;margin:0 auto 1.75rem;opacity:.7}
.sister-desc{font-family:var(--font-body);font-size:clamp(1rem,1.4vw,1.125rem);color:rgba(200,214,229,.72);line-height:1.85;margin:0 auto 2.25rem;max-width:880px}
.sister-btn{display:inline-block;font-family:var(--font-heading);font-size:.62rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;padding:14px 48px;border:1px solid rgba(201,169,110,.45);color:#c9a96e;transition:all .3s}
.sister-btn:hover{background:#c9a96e;color:#0f1e2d}
.sister-media{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:3rem;max-width:1100px;margin-left:auto;margin-right:auto;border:1px solid rgba(201,169,110,.18)}
.sister-media video,.sister-media img{width:100%;height:400px;object-fit:cover;display:block;filter:brightness(.92)}
.sister-media video:hover,.sister-media img:hover{filter:brightness(1);transition:filter .4s}
.findus-section{background:#f8f7f4;padding:6rem 2rem}
.findus-inner{max-width:1200px;margin:0 auto}
.findus-header{text-align:center;margin-bottom:3rem}
.findus-label{font-family:var(--font-heading);font-size:1.1rem;letter-spacing:0.2em;text-transform:uppercase;color:#2a9d8f;font-weight:600;display:block;margin-bottom:0.75rem}
.findus-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;color:#0f1e2d;margin:0;letter-spacing:0.05em;text-transform:uppercase}
.findus-rule{width:40px;height:2px;background:#c9a96e;margin:1.25rem auto}
.findus-address{font-family:var(--font-heading);font-size:0.9rem;color:#666;letter-spacing:0.04em}
.findus-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:480px;gap:12px}
.findus-photo-main,.findus-photo-secondary,.findus-map{border-radius:4px;overflow:hidden}
.findus-photo-main img,.findus-photo-secondary img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.4) brightness(1.06) contrast(1.05);transition:transform 0.6s ease}
.findus-photo-main:hover img,.findus-photo-secondary:hover img{transform:scale(1.04)}
.findus-map{box-shadow:0 4px 24px rgba(0,0,0,0.1)}
.findus-map iframe{width:100%;height:100%;display:block;border:0}

/* ===== PAGE: BEACHFRONT COMMUNITY LIVING ===== */
.beachfront-hero{position:relative;height:60vh;min-height:400px;overflow:hidden;background-size:cover;background-position:center}
.beachfront-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.25) 0%,transparent 45%,rgba(24,38,58,0.72) 100%)}
.beachfront-hero .hero-content{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:2;text-align:left;width:90%;max-width:1200px}
.beachfront-hero h1{color:var(--white);font-family:var(--font-heading);font-size:clamp(1.5rem,3.2vw,2.6rem);font-weight:600;letter-spacing:0.08em;text-transform:uppercase;text-shadow:0 2px 20px rgba(0,0,0,0.65);line-height:1.2;margin:0}
.intro{padding:72px 0 56px;text-align:center}
.intro h3{margin-bottom:12px}
.intro h2{font-size:clamp(1.7rem,3.2vw,2.6rem);color:var(--navy);margin-bottom:20px;font-family:var(--font-heading)}
.intro p{max-width:1100px;margin:0 auto;color:var(--gray-600);font-size:1.2rem;line-height:1.85}
.map-section{padding:0 0 72px;text-align:center}
.map-section img{max-width:100%;border-radius:4px;margin:0 auto}
.content-section{padding:28px 0}
.content-section:nth-child(even){background:var(--off-white)}
.content-text .section-label{font-size:1.35rem;color:var(--teal);letter-spacing:0.1em;font-weight:700}
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.content-grid.reverse{direction:rtl}
.content-grid.reverse > *{direction:ltr}
.content-text h3{font-size:0.6875rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:10px}
.content-text h2{font-size:clamp(1.7rem,3.2vw,2.6rem);color:var(--navy);margin-bottom:16px}
.content-text h2::after{content:'';display:block;width:36px;height:2px;background:var(--gold);margin-top:14px}
.content-text p{color:var(--gray-600);line-height:1.9;font-size:0.9875rem}
.content-img img{border-radius:4px;width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.cta-banner{padding:56px 0;background:var(--navy);position:relative;text-align:center}
.cta-banner::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.4),transparent)}
.cta-banner h2{color:var(--white);font-size:clamp(2.4rem,5.5vw,4rem);margin-bottom:20px;font-family:var(--font-heading)}
.cta-banner p{color:rgba(255,255,255,0.85);font-size:1.35rem;margin:0 auto;line-height:1.8;width:max-content;max-width:100%}
.lifestyle-carousel-section{background:#0a0a0a;position:relative;padding:0}
.lc-track-wrap{overflow:hidden;width:100%}
.lc-track{display:flex;gap:6px;transition:transform 0.7s cubic-bezier(.77,0,.175,1)}
.lc-slide{flex:0 0 calc(33.333% - 4px);position:relative;overflow:hidden}
.lc-slide img{width:100%;height:62vh;min-height:360px;object-fit:cover;display:block;transition:transform 0.6s ease;opacity:0.88}
.lc-slide:hover img{transform:scale(1.04);opacity:1}
.lc-controls{display:flex;align-items:center;justify-content:center;gap:20px;padding:18px 0 20px;background:#0a0a0a}
.lc-btn{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.2);color:#fff;width:42px;height:42px;border-radius:50%;font-size:1rem;cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center}
.lc-btn:hover{background:rgba(201,169,110,0.35);border-color:var(--gold)}
.lc-dots{display:flex;gap:8px}
.lc-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,0.25);border:none;cursor:pointer;transition:all 0.3s;padding:0}
.lc-dot.active{background:var(--gold);width:24px;border-radius:4px}

/* ===== PAGE: BRASILITO IMPACT ===== */
.brasilito-impact-hero{position:relative;height:100vh;min-height:600px;overflow:hidden;background-size:cover;background-position:center}
.brasilito-impact-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.25) 0%,transparent 45%,rgba(24,38,58,0.72) 100%)}
.brasilito-impact-hero .hero-content{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:2;text-align:left;width:90%;max-width:1200px}
.brasilito-impact-hero h1{color:var(--white);font-family:var(--font-heading);font-size:clamp(1.5rem,3.2vw,2.6rem);font-weight:700;letter-spacing:0.08em;text-transform:uppercase;text-shadow:0 2px 20px rgba(0,0,0,0.65);line-height:1.2;margin:0}
.section-header{text-align:center;margin-bottom:48px}
.impact-logo-block{display:flex;align-items:center;justify-content:center;margin-bottom:44px;padding-bottom:44px;border-bottom:1px solid rgba(42,157,143,0.18)}
.impact-logo-block img{height:120px;width:auto}
.commitment-block{padding:56px 0;background:var(--navy);position:relative;text-align:center}
.commitment-block::before,.commitment-block::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.4),transparent)}
.commitment-block::before{top:0}
.commitment-block::after{bottom:0}
.commitment-block h2{color:var(--white);font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);margin-bottom:20px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;line-height:1.15}
.commitment-block p{max-width:860px;margin:0 auto;color:rgba(255,255,255,0.82);font-size:clamp(1.05rem,1.5vw,1.2rem);line-height:1.88}
.fundraiser-section{padding:60px 0;background:var(--off-white)}
.gallery-mosaic{display:grid;grid-template-columns:1fr 1.7fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:760px}
.gallery-mosaic > img{width:100%;height:100%;object-fit:cover;border-radius:4px;display:block;min-height:0}
.gallery-center{grid-column:2;grid-row:1/3;position:relative;border-radius:4px;overflow:hidden;background:var(--navy);user-select:none;min-height:0}
.carousel-track-container{overflow:hidden;height:100%}
.carousel-track{display:flex;height:100%;transition:transform 0.5s cubic-bezier(0.4,0,0.2,1)}
.carousel-slide{flex:0 0 100%;height:100%}
.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(24,38,58,0.55);border:none;color:var(--white);width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background 0.2s;backdrop-filter:blur(4px);line-height:1}
.carousel-btn:hover{background:rgba(24,38,58,0.9)}
.carousel-prev{left:14px}
.carousel-next{right:14px}
.carousel-footer{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 0 2px}
.carousel-dots{display:flex;gap:7px}
.carousel-dot{width:7px;height:7px;border-radius:50%;background:rgba(24,38,58,0.2);border:none;cursor:pointer;transition:all 0.2s;padding:0}
.carousel-dot.active{background:var(--teal);transform:scale(1.3)}
.carousel-counter{font-family:var(--font-heading);font-size:0.62rem;letter-spacing:0.15em;color:var(--gray-600)}
.save-the-date-section{padding:0}
.std-inner{background:var(--navy);position:relative;overflow:hidden;padding:65px 40px}
.std-inner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 90% 70% at 50% -5%,rgba(201,169,110,0.13) 0%,transparent 65%),radial-gradient(ellipse 60% 40% at 50% 110%,rgba(42,157,143,0.08) 0%,transparent 65%)}
.std-inner::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.55),transparent)}
.std-bottom-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.3),transparent)}
.std-content{position:relative;z-index:1;text-align:center;max-width:860px;margin:0 auto}
.std-badge{display:inline-block;font-family:var(--font-heading);font-size:clamp(1.2rem,2.75vw,1.98rem);font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--white);background:none;padding:0;margin-bottom:28px}
.std-event-name{font-family:var(--font-subheading);font-size:clamp(0.875rem,1.3vw,1.05rem);letter-spacing:0.2em;text-transform:uppercase;color:rgba(201,169,110,0.75);margin-bottom:32px}
.std-date-block{display:flex;flex-direction:column;align-items:center;gap:0;margin-bottom:28px}
.std-month{font-family:var(--font-heading);font-size:clamp(1.1rem,2.5vw,1.8rem);font-weight:700;color:rgba(255,255,255,0.55);letter-spacing:0.28em;text-transform:uppercase;line-height:1}
.std-day{font-family:var(--font-heading);font-size:clamp(7rem,18vw,14rem);font-weight:700;color:var(--white);letter-spacing:-0.02em;line-height:0.85}
.std-year{font-family:var(--font-heading);font-size:clamp(1.2rem,2.5vw,1.9rem);font-weight:700;color:var(--gold);letter-spacing:0.22em}
.std-divider{width:56px;height:1px;background:rgba(201,169,110,0.35);margin:28px auto}
.std-location{font-family:var(--font-subheading);font-size:clamp(0.875rem,1.1vw,0.975rem);color:rgba(255,255,255,0.6);letter-spacing:0.06em;line-height:1.75;margin-bottom:40px}
.std-cta{display:inline-block;font-family:var(--font-heading);font-size:0.85rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--navy);background:var(--gold);padding:20px 64px;border-radius:2px;transition:background 0.2s,transform 0.15s}
.std-cta:hover{background:#b8925a;transform:translateY(-2px)}
.projects-section{padding:28px 0 60px;background:var(--white);position:relative;z-index:2}
.projects-intro{max-width:800px;margin:0 auto 56px;text-align:center}
.projects-intro p{color:var(--gray-600);font-size:1.0625rem;line-height:1.85}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.project-card{background:var(--off-white);border-radius:4px;overflow:hidden}
.project-card-img{aspect-ratio:4/3;overflow:hidden}
.project-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.45s ease;display:block}
.project-card:hover .project-card-img img{transform:scale(1.05)}
.project-card-body{padding:22px 20px}
.project-card-label{font-family:var(--font-heading);font-size:0.62rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--teal);margin-bottom:5px}
.project-card-body h3{font-family:var(--font-heading);font-size:0.88rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--navy);margin-bottom:9px;line-height:1.3}
.project-card-body p{color:var(--gray-600);font-size:0.9375rem;line-height:1.75}
.raised-banner{display:flex;align-items:center;justify-content:center;gap:48px;background:var(--navy);border-radius:4px;padding:36px 40px;margin-bottom:48px;flex-wrap:wrap}
.raised-stat{text-align:center}
.raised-stat-num{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--white);line-height:1}
.raised-stat-label{font-family:var(--font-subheading);font-size:0.875rem;color:rgba(255,255,255,0.65);margin-top:6px;line-height:1.4}
.raised-divider{width:1px;height:60px;background:rgba(201,169,110,0.3)}
.orgs-section{padding:60px 0;background:var(--off-white)}
.org-row-main{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;margin-bottom:24px}
.org-row-secondary{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.org-card{background:var(--white);border-radius:4px;overflow:hidden;display:flex;flex-direction:column}
.org-card.featured{flex-direction:row;align-items:stretch}
.org-card.featured .org-card-header{flex:0 0 150px;min-height:unset}
.org-card.featured .org-card-body{padding:28px;flex:1}
.org-card-header{background:var(--navy);padding:24px 20px;display:flex;align-items:center;justify-content:center;min-height:110px}
.org-card-header img{height:76px;width:auto;object-fit:contain}
.org-card-header-text{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--white);letter-spacing:0.1em;text-transform:uppercase;text-align:center;line-height:1.35}
.org-card-header.teal{background:var(--teal)}
.org-card-body{padding:24px}
.org-card-name{font-family:var(--font-heading);font-size:0.62rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--teal);margin-bottom:4px}
.org-card-fullname{font-family:var(--font-subheading);font-size:0.9rem;color:var(--navy);font-weight:600;margin-bottom:12px;line-height:1.4}
.org-card-body p{font-size:0.9375rem;color:var(--gray-600);line-height:1.78;margin:0}
.org-link{display:inline-flex;align-items:center;gap:4px;margin-top:14px;font-family:var(--font-heading);font-size:0.62rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--teal);border-bottom:1px solid rgba(42,157,143,0.3);padding-bottom:2px;transition:color var(--transition)}
.org-link:hover{color:var(--teal-dark)}
.env-section{padding:60px 0;background:var(--white)}
.env-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:40px}
.env-card{padding:28px;background:var(--off-white);border-radius:4px;border-left:3px solid var(--teal)}
.env-card h3{font-family:var(--font-heading);font-size:0.78rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--navy);margin-bottom:10px}
.env-card p{color:var(--gray-600);font-size:1rem;line-height:1.78}

/* ===== PAGE: CONCIERGE ===== */
.concierge-hero{position:relative;height:70vh;min-height:420px;overflow:hidden;display:flex;align-items:flex-end}
.concierge-hero-bg{position:absolute;inset:0;background:url('../images/arcadia-brasilito-beach-lifestyle-sunset-dining.webp') center center/cover no-repeat}
.concierge-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.18) 0%,transparent 40%,rgba(24,38,58,0.68) 100%)}
.concierge-hero-content{position:relative;z-index:2;padding:0 32px 72px;max-width:1200px;margin:0 auto;width:100%}
.concierge-hero-content h1{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3.6rem);font-weight:700;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,0.5);line-height:1.15;max-width:680px}
.concierge-intro{background:var(--off-white);padding:48px 32px 36px;text-align:center}
.concierge-intro .section-label{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);letter-spacing:0.01em;text-transform:none;color:var(--teal);font-weight:700;display:block;margin-bottom:24px}
.concierge-intro p{font-family:var(--font-body);font-size:clamp(1.1rem,2.2vw,1.5rem);color:#555;line-height:1.7;max-width:700px;margin:0 auto}
.concierge-services{background:var(--off-white);padding:0 0 48px}
.concierge-cards-wrapper{max-width:1200px;margin:0 auto;padding:0 32px}
.concierge-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.concierge-card{background:#fff;border-radius:16px;padding:0 0 40px;box-shadow:0 4px 24px rgba(24,38,58,0.08);overflow:hidden}
.concierge-card-stripe{height:5px;width:100%;margin-bottom:32px;background:var(--teal)}
.concierge-card-body{padding:0 28px}
.concierge-card h2{font-family:var(--font-heading);font-size:1.375rem;font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:20px}
.concierge-card p{font-family:var(--font-body);font-size:1rem;color:#777;line-height:1.75}
.concierge-cta{background:var(--off-white);padding:48px 32px 64px;text-align:center;border-top:1px solid rgba(24,38,58,0.07)}
.concierge-cta h2{font-family:var(--font-heading);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;color:var(--navy);margin-bottom:16px;line-height:1.2}
.concierge-cta p{font-family:var(--font-body);font-size:1.0625rem;color:#666;line-height:1.7;max-width:520px;margin:0 auto 36px}
.btn-concierge{display:inline-block;background:#a0885a;color:#fff;font-family:var(--font-body);font-size:1rem;font-weight:500;letter-spacing:0.04em;padding:16px 44px;border-radius:999px;transition:background 0.25s ease,transform 0.2s ease;text-decoration:none}
.btn-concierge:hover{background:#8a7149;transform:translateY(-1px)}

/* ===== PAGE: CONTACT ===== */
.contact-hero{background:var(--navy);padding:160px 40px 80px;min-height:400px;display:flex;align-items:flex-end}
.contact-hero-inner{max-width:1400px;margin:0 auto;width:100%}
.contact-hero-eyebrow{font-family:var(--font-heading);font-size:1.5rem;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:16px}
.contact-hero-heading{font-family:var(--font-heading);font-size:clamp(1.75rem,4vw,3rem);font-weight:700;color:var(--white);line-height:1.2;max-width:700px}
.contact-content{background:var(--white);padding:80px 40px}
.contact-content-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-form-consent-note{font-family:var(--font-body);font-size:0.75rem;color:#999;line-height:1.6;margin-top:16px}
.contact-form-consent-note a{color:var(--navy);text-decoration:underline}
/* Light-theme overrides: inquire-form on white contact page */
.contact-form-col .inquire-form-group label{color:var(--navy)}
.contact-form-col .inquire-form input[type="text"],
.contact-form-col .inquire-form input[type="email"],
.contact-form-col .inquire-form input[type="tel"],
.contact-form-col .inquire-form textarea{color:var(--navy);background:#fff;border-color:#ddd}
.contact-form-col .inquire-form input::placeholder,
.contact-form-col .inquire-form textarea::placeholder{color:#aaa}
.contact-form-col .inquire-radio{color:var(--navy)}
.contact-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid #e8e8e8;border-left:1px solid #e8e8e8}
.contact-info-cell{padding:32px 28px;border-right:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8}
.contact-info-cell-label{font-family:var(--font-heading);font-size:0.6875rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--navy);opacity:0.5;display:block;margin-bottom:10px}
.contact-info-cell-value{font-family:var(--font-body);font-size:0.9375rem;color:var(--navy);line-height:1.5}
.contact-info-cell-value a{color:var(--navy);transition:color 0.3s ease}
.contact-info-cell-value a:hover{color:var(--teal)}
.contact-info-social{display:flex;gap:12px;margin-top:4px;flex-wrap:wrap}
.contact-info-social a{width:36px;height:36px;border-radius:50%;border:1px solid #ddd;display:flex;align-items:center;justify-content:center;transition:all 0.3s ease}
.contact-info-social a:hover{border-color:var(--navy);background:var(--navy)}
.contact-info-social svg{width:16px;height:16px;fill:var(--navy)}
.contact-info-social a:hover svg{fill:var(--white)}

/* ===== PAGE: DOWNLOADS ===== */
.page-hero{height:65vh;min-height:420px}
.hero-page-content{position:absolute;bottom:2.5rem;left:0;right:0;text-align:center;color:#fff;padding:0 2rem;z-index:2}
.hero-page-content h1{font-family:var(--font-heading);font-size:clamp(1.8rem,4vw,3rem);font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-shadow:0 2px 10px rgba(0,0,0,.4);margin-bottom:.5rem}
.hero-page-content p{font-size:1rem;color:rgba(255,255,255,.8);font-weight:300;max-width:540px;margin:0 auto}
.hero-line{width:50px;height:2px;background:var(--teal);margin:1rem auto 0}
.dl-intro{padding:5rem 2rem;background:#fff;text-align:center}
.dl-intro-inner{max-width:720px;margin:0 auto}
.docs-section{background:#f4f1eb;padding:4rem 2rem}
.docs-inner{max-width:1000px;margin:0 auto}
.docs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2.5rem}
.doc-item{background:#fff;border-radius:10px;padding:1.75rem 1.5rem;text-align:center;box-shadow:0 4px 18px rgba(0,0,0,.05);opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease,box-shadow .3s}
.doc-item.visible{opacity:1;transform:translateY(0)}
.doc-item:hover{box-shadow:0 8px 28px rgba(0,0,0,.1)}
.doc-icon{width:52px;height:52px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.doc-icon svg{width:26px;height:26px;fill:var(--teal)}
.doc-item h3{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--navy);letter-spacing:.04em;text-transform:uppercase;line-height:1.4}
.form-section{background:var(--navy);padding:5rem 2rem;text-align:center;color:#fff}
.form-section .page-label{color:var(--gold)}
.form-section .page-title{color:#fff}
.form-section .page-text{color:rgba(200,214,229,.85);max-width:580px;margin:0 auto 2.5rem}

/* ===== PAGE: FAQ ===== */
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.45) 0%,rgba(24,38,58,0.82) 100%)}
.faq-page{padding:80px 0 60px;background:var(--white)}
.faq-inner{max-width:860px;margin:0 auto;padding:0 24px}
.faq-category{margin-bottom:56px;opacity:0;transform:translateY(24px);transition:opacity 0.6s ease,transform 0.6s ease}
.faq-category.visible{opacity:1;transform:translateY(0)}
.category-header{display:flex;align-items:baseline;gap:20px;margin-bottom:28px;padding-bottom:16px;border-bottom:2px solid var(--off-white)}
.category-number{font-family:var(--font-heading);font-size:2.25rem;font-weight:200;color:var(--teal);line-height:1;flex-shrink:0}
.category-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:0.12em}
.accordion-item{border-bottom:1px solid #ebebeb}
.accordion-item:first-of-type{border-top:1px solid #ebebeb}
.accordion-btn{width:100%;background:none;border:none;padding:18px 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--font-body);font-size:1.0625rem;font-weight:500;color:var(--navy);text-align:left;line-height:1.5;gap:16px;transition:color var(--transition)}
.accordion-btn:hover{color:var(--teal)}
.accordion-icon{width:20px;height:20px;min-width:20px;position:relative;flex-shrink:0}
.accordion-icon::before,.accordion-icon::after{content:'';position:absolute;background:var(--teal);border-radius:1px;transition:transform 0.3s ease,opacity 0.3s ease}
.accordion-icon::before{width:14px;height:1.5px;top:9px;left:3px}
.accordion-icon::after{width:1.5px;height:14px;top:3px;left:9px}
.accordion-item.open .accordion-icon::after{transform:rotate(90deg);opacity:0}
.accordion-body{max-height:0;overflow:hidden;transition:max-height 0.38s ease}
.accordion-body-inner{padding:0 32px 20px 0;font-size:1.0625rem;color:var(--gray-600);line-height:1.85}
.cta-section{background:var(--navy);padding:100px 0;text-align:center;position:relative}
.cta-section::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.4),transparent)}
.cta-eyebrow{font-family:var(--font-heading);font-size:0.75rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.cta-section h2{font-family:var(--font-heading);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:300;color:var(--white);margin-bottom:14px}
.cta-section p{color:rgba(255,255,255,0.72);font-size:1rem;max-width:560px;margin:0 auto 40px}

/* ===== PAGE: LIFESTYLE AMENITIES ===== */
.amenities-hero{position:relative;height:calc(100vh - 18cm);min-height:300px;overflow:hidden}
.amenities-hero-bg{position:absolute;inset:0;background:url('../images/arcadia-brasilito-beach-condos-pool-amenitie-exterior.webp') center top/cover no-repeat;filter:brightness(1.12) saturate(1.15)}
.amenities-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,38,58,0.25) 0%,transparent 45%,rgba(24,38,58,0.72) 100%)}
.amenities-hero-content{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:2;text-align:left;width:90%;max-width:1200px}
.amenities-hero h1{font-family:var(--font-heading);font-size:clamp(1.5rem,3.5vw,2.8rem);font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,0.65);line-height:1.2;margin:0}
.amenity-section{padding:32px 0}
.amenity-section:nth-child(even){background:var(--off-white)}
.amenity-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.amenity-grid.reverse{direction:rtl}
.amenity-grid.reverse > *{direction:ltr}
.amenity-text h2{font-size:clamp(2rem,3.5vw,2.8rem);color:var(--navy);margin-bottom:8px}
.amenity-text h3{font-size:0.6875rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:12px}
.amenity-text p{color:var(--gray-600);line-height:1.9;font-size:1.0625rem}
.amenity-img img{border-radius:4px;width:100%;aspect-ratio:4/3;object-fit:cover}
.pool-banner{width:100%;height:640px;overflow:hidden;display:block;line-height:0;margin-top:48px}
.pool-banner img{width:100%;height:100%;object-fit:cover;object-position:center 60%;display:block}
.mp-section{padding:16px 0 0;background:#f5f4f0}
.mp-header{text-align:center;margin-bottom:10px;padding:0 24px}
.mp-header .section-label{display:block;margin-bottom:4px}
.mp-header .section-title{font-size:clamp(1.6rem,2.8vw,2.4rem);margin-bottom:0}
.mp-body{position:relative;width:100%;overflow:hidden}
.mp-body img{width:100%;height:auto;display:block}
.mp-legend{position:absolute;background:transparent;padding:18px;z-index:2;max-width:340px}
.mp-legend-commercial{bottom:2%;left:20%;max-width:none;white-space:nowrap}
.mp-legend-residential{top:12%;right:14%}
.mp-col-title{font-family:var(--font-heading);font-size:15px;letter-spacing:0.12em;text-transform:uppercase;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,0.9);padding-bottom:5px;margin-bottom:7px;border-bottom:1px solid rgba(255,255,255,0.4)}
.mp-items{list-style:none;padding:0;margin:0}
.mp-items li{display:flex;align-items:center;gap:9px;padding:2px 0;font-size:17px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,0.9);line-height:1.3;font-family:var(--font-body)}
.mp-num{background:#000;color:#fff;border-radius:50%;width:24px;height:24px;min-width:24px;font-size:0.74rem;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;text-shadow:none}

/* ===== PAGE: REALESTATE THE RESIDENCES ===== */
.hero-gradient{background:linear-gradient(180deg,rgba(24,38,58,0.25) 0%,transparent 45%,rgba(24,38,58,0.72) 100%) !important}
.hero-page-content .hero-title{font-family:var(--font-heading);font-size:clamp(1.5rem,3.5vw,2.8rem);font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,0.65);line-height:1.2}
.intro-section{padding:3rem 2rem;background:#fff;text-align:center}
.intro-section .section-inner{max-width:1100px;margin:0 auto}
.seo-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;font-style:normal;color:var(--navy);line-height:1.2;margin-bottom:1.5rem;letter-spacing:0.05em;text-transform:uppercase}
.units-section{padding:5rem 2rem;background:#f4f1eb}
.units-inner{max-width:1200px;margin:0 auto}
.units-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-top:3rem}
.unit-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.06);opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease,box-shadow .4s}
.unit-card.visible{opacity:1;transform:translateY(0)}
.unit-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,.12)}
.unit-card-image{position:relative;height:220px;overflow:hidden}
.unit-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.unit-card:hover .unit-card-image img{transform:scale(1.05)}
.unit-badge{position:absolute;top:1rem;left:1rem;background:var(--teal);color:#fff;font-family:var(--font-heading);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .9rem;border-radius:4px}
.unit-card-body{padding:1.75rem}
.unit-card-body h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--navy);margin-bottom:.75rem}
.unit-specs{display:flex;gap:1.25rem;flex-wrap:wrap;margin-bottom:1rem}
.unit-spec{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:#666}
.unit-spec svg{width:16px;height:16px;fill:var(--teal)}
.unit-card-body p{font-size:.9rem;color:#777;line-height:1.6;margin-bottom:1.25rem}
.unit-btn{display:inline-block;font-family:var(--font-heading);font-size:.8rem;font-weight:600;color:var(--teal);letter-spacing:.08em;text-transform:uppercase;padding:.5rem 0;border-bottom:2px solid var(--teal);transition:all .3s}
.unit-btn:hover{color:var(--navy);border-color:var(--navy)}
.res-stats{padding:4rem 2rem;background:var(--navy);color:#fff}
.res-stats-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.res-benefits-grid{max-width:1200px;grid-template-columns:repeat(6,1fr);gap:1.5rem}
.res-benefit{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.res-benefit-icon{width:32px;height:32px;fill:var(--gold);flex-shrink:0}
.res-stat{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.res-stat.visible{opacity:1;transform:translateY(0)}
.res-stat-number{font-family:var(--font-heading);font-size:clamp(3rem,6vw,5rem);font-weight:300;color:var(--teal);margin-bottom:.25rem}
.res-stat-label{font-size:1rem;color:rgba(200,214,229,.8);letter-spacing:.15em;text-transform:uppercase}
.features-section{padding:5rem 2rem;background:#fff}
.features-inner{max-width:1100px;margin:0 auto}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;align-items:stretch;max-width:900px;margin-left:auto;margin-right:auto}
.feature-item{padding:1.5rem;border:1px solid #eee;border-radius:8px;transition:all .3s;opacity:0;transform:translateY(20px);display:flex;flex-direction:column}
.feature-item.visible{opacity:1;transform:translateY(0)}
.feature-item:hover{border-color:var(--teal);box-shadow:0 4px 16px rgba(42,157,143,.1)}
.feature-item h3{font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--navy);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.feature-item h3 svg{width:20px;height:20px;fill:var(--teal);min-width:20px}
.feature-item p{font-size:.9rem;color:#666;line-height:1.6}
.compare-section{padding:4rem 2rem;background:#f4f1eb}
.compare-inner{max-width:1000px;margin:0 auto}
.compare-table{width:100%;border-collapse:collapse;font-family:var(--font-body);font-size:14px;margin-top:2rem}
.compare-table thead tr{background:var(--navy);color:#fff}
.compare-table th{padding:12px;text-align:left;font-family:var(--font-heading);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase}
.compare-table th:not(:first-child){text-align:center}
.compare-table td{padding:12px;border-bottom:1px solid #e0dbd1}
.compare-table td:not(:first-child){text-align:center}
.compare-table tbody tr:nth-child(even){background:#ece9e1}
.floorplan-section{padding:1.5rem 0.5rem;background:var(--navy)}
.floorplan-inner{max-width:1600px;margin:0 auto}
.floorplan-tabs{display:flex;justify-content:center;gap:0;margin:1rem 0 0;border-bottom:1px solid rgba(255,255,255,.15);flex-wrap:wrap}
.floorplan-tab{font-family:var(--font-heading);font-size:1rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(200,214,229,.45);padding:.6rem 2rem;cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;background:none;transition:color .3s,border-color .3s}
.floorplan-tab:hover{color:rgba(200,214,229,.8)}
.floorplan-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.floorplan-panels{margin-top:0.75rem}
.floorplan-panel{display:none}
.floorplan-panel.active{display:block}
.floorplan-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
svg.floorplan{width:100%;max-width:1287px;height:auto;display:block;margin:0 auto}
svg.floorplan .st1{fill:rgba(255,255,255,.06);stroke:rgba(255,255,255,.2);stroke-width:1.5;transition:fill .3s,stroke .3s;cursor:pointer}
svg.floorplan .unit-3bed{fill:rgba(233,196,106,.18);stroke:rgba(233,196,106,.6)}
svg.floorplan a:hover .unit-3bed{fill:rgba(233,196,106,.62);stroke:var(--gold);stroke-width:2.5}
svg.floorplan .unit-2bed{fill:rgba(42,157,143,.18);stroke:rgba(42,157,143,.6)}
svg.floorplan a:hover .unit-2bed{fill:rgba(42,157,143,.62);stroke:var(--teal);stroke-width:2.5}
svg.floorplan .unit-2plus{fill:rgba(90,195,175,.16);stroke:rgba(90,195,175,.55)}
svg.floorplan a:hover .unit-2plus{fill:rgba(90,195,175,.58);stroke:#5ac3af;stroke-width:2.5}
svg.floorplan .unit-15flex{fill:rgba(255,255,255,.10);stroke:rgba(255,255,255,.38)}
svg.floorplan a:hover .unit-15flex{fill:rgba(255,255,255,.50);stroke:rgba(255,255,255,.9);stroke-width:2.5}
svg.floorplan .unit-common{fill:rgba(255,255,255,.03);stroke:rgba(255,255,255,.1);pointer-events:none}
svg.floorplan .label{fill:rgba(255,255,255,.72);font-family:var(--font-heading);font-size:13px;font-weight:500;letter-spacing:.06em;pointer-events:none;text-anchor:middle}
.floorplan-legend{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-top:0.75rem}
.legend-item{display:flex;align-items:center;gap:.6rem;font-family:var(--font-heading);font-size:1rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(200,214,229,.65)}
.legend-swatch{width:22px;height:22px;border-radius:3px;border:1.5px solid;flex-shrink:0}
.legend-swatch.s-3bed{background:rgba(233,196,106,.2);border-color:rgba(233,196,106,.6)}
.legend-swatch.s-2plus{background:rgba(90,195,175,.18);border-color:rgba(90,195,175,.5)}
.legend-swatch.s-2bed{background:rgba(42,157,143,.18);border-color:rgba(42,157,143,.55)}
.legend-swatch.s-flex{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.28)}
.res-cta{background:linear-gradient(135deg,var(--navy) 0%,#1e3048 100%);padding:5rem 2rem;text-align:center;color:#fff}
.res-cta .page-label{color:var(--gold)}
.res-cta .page-title{color:#fff}
.res-cta .page-text{color:rgba(200,214,229,.85);max-width:600px;margin:0 auto 2rem}

/* ===== PAGE: THANKS ===== */
.thanks-check{width:72px;height:72px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1) forwards}
.thanks-check svg{width:36px;height:36px;fill:#fff}
@keyframes scaleIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.thanks-intro{padding:5rem 2rem;background:#fff;text-align:center}
.thanks-intro-inner{max-width:720px;margin:0 auto}
.next-section{background:#f4f1eb;padding:4rem 2rem}
.next-inner{max-width:900px;margin:0 auto;text-align:center}
.next-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;margin-top:2.5rem;text-align:left}
.next-item{background:#fff;border-radius:10px;padding:2rem 1.5rem;text-align:center;box-shadow:0 4px 18px rgba(0,0,0,.05)}
.next-step-num{width:44px;height:44px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--gold);letter-spacing:.05em}
.next-item h3{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--navy);letter-spacing:.04em;text-transform:uppercase;line-height:1.4;margin-bottom:.5rem}
.next-item p{font-size:.9rem;color:#666;line-height:1.6}
.countdown-section{background:var(--navy);padding:5rem 2rem;text-align:center;color:#fff}
.countdown-section .page-label{color:var(--gold)}
.countdown-section .page-title{color:#fff;font-size:clamp(1.2rem,2.5vw,1.75rem);margin-bottom:1rem}
.countdown-text{color:rgba(200,214,229,.75);max-width:500px;margin:0 auto 2.5rem;font-size:.95rem;line-height:1.7}
.countdown-number{font-family:var(--font-heading);font-size:5rem;font-weight:700;color:var(--gold);line-height:1;margin-bottom:.25rem}
.countdown-label{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(200,214,229,.45);margin-bottom:2.5rem}
.btn-home-now{display:inline-block;font-family:var(--font-heading);font-weight:500;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;padding:14px 40px;background:var(--teal);color:#fff;border-radius:4px;transition:background .3s;text-decoration:none}
.btn-home-now:hover{background:var(--teal-dark)}

/* ===== PAGE: LEGAL / PRIVACY POLICY ===== */
.privacy-main{padding-top:120px;padding-bottom:80px;max-width:880px;margin:0 auto;padding-left:24px;padding-right:24px}
.privacy-h1{font-family:var(--font-heading);font-size:2.25rem;font-weight:700;color:var(--navy);margin-bottom:32px}
.privacy-section{margin-bottom:48px}
.privacy-h2{font-family:var(--font-heading);font-size:1.375rem;font-weight:600;color:var(--navy);margin-bottom:16px}
.privacy-h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--navy);margin-bottom:10px;margin-top:24px}
.privacy-p{color:var(--text-body);line-height:1.8;margin-bottom:16px}
.privacy-a{color:var(--teal)}

/* ===== PAGE: 404 ===== */
.error-page-body{display:flex;flex-direction:column;min-height:100vh}
.error-section{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--navy);padding:160px 24px 80px}
.error-content{max-width:600px}
.error-code{font-family:var(--font-heading);font-size:8rem;font-weight:700;color:var(--gold);line-height:1;margin-bottom:16px}
.error-title{font-family:var(--font-heading);font-size:2rem;font-weight:600;color:var(--white);margin-bottom:16px}
.error-text{color:rgba(255,255,255,0.72);font-size:1.1rem;margin-bottom:40px}
.btn-home{display:inline-block;font-family:var(--font-heading);font-weight:500;font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;padding:16px 40px;background:var(--teal);color:var(--white)!important;border-radius:4px;transition:background .3s}
.btn-home:hover{background:var(--teal-dark)!important}
@media(max-width:768px){.error-code{font-size:5rem}.error-title{font-size:1.5rem}}

/* ===== PAGE: HOME =====*/
.interior-carousel .interior-carousel-item:nth-child(2){transition-delay:.1s}
.interior-carousel .interior-carousel-item:nth-child(3){transition-delay:.2s}
.interior-carousel .interior-carousel-item:nth-child(4){transition-delay:.3s}
.interior-carousel .interior-carousel-item:nth-child(5){transition-delay:.4s}
.lifestyle-accent-row .accent-img:nth-child(2){transition-delay:.08s}
.lifestyle-accent-row .accent-img:nth-child(3){transition-delay:.16s}
.lifestyle-accent-row .accent-img:nth-child(4){transition-delay:.24s}

/* ===== COMPONENT: INLINE LANG SWITCHER (residencias / descargas mobile nav) ===== */
.inline-lang-switcher{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.15);text-align:center;font-size:.8rem;letter-spacing:.1em}
.inline-lang-switcher a{color:rgba(255,255,255,.55);text-decoration:none}
.inline-lang-switcher a:last-of-type{color:#fff;font-weight:600}
