/* ══════════════════════════════════════════════
   MOONGLADE — style.css  (PageSpeed Optimised)
   Changes: skip-link added, focus styles, 
   prefers-reduced-motion, colour-contrast fixes,
   touch-target sizes, font-display swap fallback
   ══════════════════════════════════════════════ */

/* ── DESIGN TOKENS ── */
:root{
  --cream:#FAF7F2;--parchment:#F3EDE3;--warm:#EDE4D7;--sand:#D9CDBF;
  --stone:#B8A898;--umber:#6B5B4E;--bark:#3D2F25;--bark-lt:#5C4538;
  --copper:#B87A4A;--copper-lt:#D4975E;--copper-dk:#8A5A30;--white:#FFFFFF;
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'DM Sans',sans-serif;
  --tr:0.3s ease;
  /* Accessible focus ring colour */
  --focus-ring: #005FCC;
}

/* ── FONT DISPLAY SWAP FALLBACK (in case Google Fonts is slow) ── */
@font-face{
  font-family:'Cormorant Garamond';
  font-display:swap;
  src:local('Georgia');
}
@font-face{
  font-family:'DM Sans';
  font-display:swap;
  src:local('Arial');
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:var(--sans);background:var(--cream);color:var(--bark);overflow-x:hidden;font-size:16px;line-height:1.75}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
p{font-size:15px;line-height:1.8;font-weight:300}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--parchment)}
::-webkit-scrollbar-thumb{background:var(--copper);border-radius:2px}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
    scroll-behavior:auto!important;
  }
  .hero-slide img,.club-carousel-track,.fp-track,.amen-gallery-track{transition:none!important}
}

/* ── SKIP LINK (Accessibility) ── */
.skip-link{
  position:absolute;
  top:-100%;
  left:0;
  background:var(--bark);
  color:var(--cream);
  padding:12px 20px;
  font-size:14px;
  font-weight:500;
  letter-spacing:1px;
  z-index:99999;
  transition:top 0.2s;
  text-decoration:underline;
}
.skip-link:focus{top:0}

/* ── GLOBAL FOCUS STYLES (WCAG 2.4.7) ── */
:focus-visible{
  outline:3px solid var(--focus-ring);
  outline-offset:3px;
  border-radius:2px;
}
/* Remove default outline only when :focus-visible is supported */
:focus:not(:focus-visible){outline:none}

/* ── TAG ── */
.tag{display:inline-flex;align-items:center;gap:10px;font-size:10px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--copper);margin-bottom:16px}
.tag::before{content:'';display:block;width:28px;height:1px;background:var(--copper)}

/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:999;height:68px;display:flex;align-items:center;background:transparent;transition:background .4s ease,box-shadow .4s ease;will-change:background}
header.scrolled{background:rgba(250,247,242,.97);box-shadow:0 1px 0 rgba(61,47,37,.08);backdrop-filter:blur(12px)}
.nav-wrap{width:100%;max-width:1400px;margin:0 auto;padding:0 48px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo img{height:28px;width:auto}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{font-size:12px;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;color:var(--bark);opacity:.75;transition:opacity var(--tr);white-space:nowrap;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--copper);transition:width var(--tr)}
.nav-links a:hover{opacity:1}.nav-links a:hover::after{width:100%}

/* Hamburger — min 44×44 touch target */
.hbg{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.hbg span{display:block;width:22px;height:1px;background:var(--bark);transition:all .3s}
.hbg.open span:nth-child(1){transform:translateY(6px)rotate(45deg)}
.hbg.open span:nth-child(2){opacity:0}
.hbg.open span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}
.mob-nav{display:none;position:fixed;inset:68px 0 0;background:var(--cream);flex-direction:column;padding:36px 28px 100px;z-index:998;border-top:1px solid var(--warm);overflow-y:auto}
.mob-nav.open{display:flex}
.mob-nav a{font-family:var(--serif);font-size:26px;font-weight:300;font-style:italic;color:var(--bark);padding:12px 0;border-bottom:1px solid var(--warm);transition:color var(--tr)}
.mob-nav a:hover{color:var(--copper)}
.mob-nav-cta{margin-top:24px;background:var(--bark);color:var(--cream);font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;padding:15px;border:none;cursor:pointer;text-align:center;transition:background var(--tr);min-height:44px}
.mob-nav-cta:hover{background:var(--bark-lt)}

/* ── BUTTONS — min 44px touch targets ── */
.btn-fill{background:var(--bark);color:var(--cream);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:14px 30px;border:none;cursor:pointer;transition:background var(--tr);min-height:44px}
.btn-fill:hover{background:var(--bark-lt)}
.btn-line{background:transparent;color:var(--bark);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:13px 30px;border:1px solid var(--sand);cursor:pointer;transition:border-color var(--tr);min-height:44px}
.btn-line:hover{border-color:var(--bark)}
.btn-copper{background:var(--copper);color:var(--white);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:14px 30px;border:none;cursor:pointer;transition:background var(--tr);min-height:44px}
.btn-copper:hover{background:var(--copper-dk)}

/* ── HERO ── */
.hero{position:relative;width:100%;padding-top:68px;background:var(--parchment);overflow:hidden}
.hero-slides{position:relative;width:100%;line-height:0}
.hero-slide{display:none;width:100%}
.hero-slide.active{display:block}
.hero-slide img{
  width:100%;
  display:block;
  object-fit:cover;
  height:calc(100svh - 68px);
}
.hero-nav{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.hero-dot{width:44px;height:44px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.hero-dot::after{content:'';display:block;width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);transition:background .3s,transform .3s}
.hero-dot.active::after{background:var(--copper);transform:scale(1.3)}
.hero-prev,.hero-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:rgba(250,247,242,.15);backdrop-filter:blur(6px);border:1px solid rgba(250,247,242,.25);color:var(--cream);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--tr);font-size:18px;line-height:1}
.hero-prev{left:20px}.hero-next{right:20px}
.hero-prev:hover,.hero-next:hover{background:rgba(184,122,74,.5)}

/* ── MARQUEE ── */
.marquee-strip{background:var(--bark);padding:13px 0;overflow:hidden}
.marquee-inner{display:flex;white-space:nowrap;animation:marquee 32s linear infinite}
.marquee-inner span{font-family:var(--serif);font-size:15px;font-weight:300;font-style:italic;color:rgba(250,247,242,.6);padding:0 44px}
.marquee-inner .dot{color:var(--copper);padding:0 6px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── VIDEO SECTION ── */
.video-section{background:var(--bark);padding:72px 48px}
.video-section-inner{max-width:1100px;margin:0 auto}
.video-section-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;gap:24px}
.video-section-h{font-family:var(--serif);font-size:clamp(28px,4vw,56px);font-weight:300;color:var(--cream);line-height:1.1}
.video-section-h em{font-style:italic;color:var(--copper-lt)}
.video-section-sub{font-size:14px;color:rgba(250,247,242,.65);max-width:280px;line-height:1.75;text-align:right}
.video-embed-wrap{position:relative;width:100%;padding-bottom:56.25%;height:0;background:#111;overflow:hidden}
.video-embed-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:pointer;background:rgba(61,47,37,.4);transition:background var(--tr);z-index:2}
.video-play-overlay:hover{background:rgba(61,47,37,.2)}
.play-circle{width:72px;height:72px;border:2px solid var(--copper-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);background:rgba(184,122,74,.2);transition:transform var(--tr)}
.video-play-overlay:hover .play-circle{transform:scale(1.08)}
.play-label{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(250,247,242,.65);white-space:nowrap}
.video-thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}

/* Delay below-the-fold render work to improve first paint and LCP */
.club-section,
.video-section,
.amen-section,
.masterplan-section,
.fp-section,
.mf-banner,
.loc-section,
.specs-section,
.contact-section,
.footer{
  content-visibility:auto;
  contain-intrinsic-size:900px;
}

/* ── CLUBHOUSE ── */
.club-section{background:var(--cream)}
.club-section-inner{max-width:1200px;margin:0 auto;padding:88px 48px}
.club-top{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-bottom:56px}
.club-left-sticky{position:sticky;top:88px;align-self:start}
.club-right-scroll{max-height:560px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--sand) transparent;padding-right:6px}
.club-right-scroll::-webkit-scrollbar{width:3px}
.club-right-scroll::-webkit-scrollbar-track{background:transparent}
.club-right-scroll::-webkit-scrollbar-thumb{background:var(--sand);border-radius:2px}
.club-h{font-family:var(--serif);font-size:clamp(36px,5vw,72px);font-weight:300;color:var(--bark);line-height:1;margin-bottom:14px}
.club-h em{font-style:italic;color:var(--copper);display:block}
.club-tagline{font-size:15px;color:var(--umber);line-height:1.8;font-weight:300;margin-bottom:28px}
.club-rera-badge{background:var(--parchment);border:1px solid var(--warm);padding:16px 20px;margin-bottom:28px}
.club-rera-label{font-size:9px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--copper);margin-bottom:6px}
.club-rera-val{font-size:12.5px;color:var(--umber);font-weight:300;line-height:1.65}
.club-rera-val a{color:var(--copper);text-decoration:underline;text-underline-offset:3px}
.club-floors-list{display:flex;flex-direction:column}
.club-floor-row{display:grid;grid-template-columns:80px 1fr;gap:16px;align-items:start;padding:16px 0;border-bottom:1px solid var(--warm)}
.club-floor-row:last-child{border-bottom:none}
.cf-num{font-family:var(--serif);font-size:22px;color:var(--copper);font-weight:400;line-height:1}
.cf-lbl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--stone);margin-top:2px}
.cf-items{font-size:14px;color:var(--umber);line-height:1.75;font-weight:300;padding-top:4px}

/* Club image carousel */
.club-carousel{position:relative;overflow:hidden;background:var(--bark);margin-top:4px}
.club-carousel-track-wrap{overflow:hidden}
.club-carousel-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.club-carousel-slide{flex:0 0 33.333%;padding:3px}
.club-carousel-slide img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;filter:saturate(.85);transition:filter .35s}
.club-carousel-slide img:hover{filter:saturate(1)}
.club-carousel-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:rgba(61,47,37,.55)}
.club-carousel-counter{font-size:11px;color:rgba(250,247,242,.5);letter-spacing:1.5px}
.club-carousel-btns{display:flex;gap:8px}
.club-carousel-btn{background:transparent;border:1px solid rgba(212,151,94,.35);color:var(--copper-lt);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--tr),border-color var(--tr);font-size:16px}
.club-carousel-btn:hover{background:rgba(212,151,94,.15);border-color:var(--copper-lt)}
.club-carousel-dots{display:flex;gap:7px;align-items:center}
.club-carousel-dot{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:0}
.club-carousel-dot::after{content:'';display:block;width:6px;height:6px;border-radius:50%;background:rgba(250,247,242,.25);transition:background .3s,transform .3s}
.club-carousel-dot.active::after{background:var(--copper-lt);transform:scale(1.4)}

/* ── AMENITIES ── */
.amen-section{background:var(--parchment)}
.amen-block{position:relative}
.amen-img-wrap{position:relative;aspect-ratio:16/7;overflow:hidden}
.amen-img{width:100%;height:100%;object-fit:cover;filter:brightness(.48) saturate(.85)}
.amen-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(61,47,37,.95) 0%,rgba(61,47,37,.55) 45%,rgba(61,47,37,.15) 100%)}
.amen-content{position:absolute;bottom:0;left:0;right:0;padding:0 72px 48px;z-index:2}
.amen-title{font-family:var(--serif);font-size:clamp(26px,4.8vw,68px);color:var(--cream);font-weight:300;line-height:1;margin-bottom:20px}
.amen-title em{color:var(--copper-lt);font-style:italic}
.amen-list{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:5px 10px;margin-bottom:24px}
.amen-list li{font-size:13px;color:rgba(250,247,242,.85);padding-left:12px;position:relative;line-height:1.6;font-weight:300}
.amen-list li::before{content:'—';position:absolute;left:0;color:var(--copper-lt);font-size:9px;top:3px}
.amen-gallery{background:var(--bark);overflow:hidden}
.amen-gallery-track-wrap{overflow:hidden;width:100%}
.amen-gallery-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1);width:100%}
.amen-gallery-slide{flex:0 0 33.333%;min-width:0;padding:2px}
.amen-gallery-slide img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;filter:saturate(.85);transition:filter .3s}
.amen-gallery-slide img:hover{filter:saturate(1)}
.gallery-nav-row{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:rgba(61,47,37,.6)}
.gallery-nav-btn{background:transparent;border:1px solid rgba(212,151,94,.3);color:var(--copper-lt);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--tr);font-size:16px}
.gallery-nav-btn:hover{background:rgba(212,151,94,.15)}
.gallery-counter{font-size:11px;color:rgba(250,247,242,.5);letter-spacing:1px}

/* ── EDITORIAL SEO PARAGRAPHS ── */
.editorial-para{max-width:860px;margin:0 auto;padding:44px 48px 0}
.editorial-para p{font-family:var(--serif);font-size:17px;font-weight:300;color:var(--umber);line-height:1.95;font-style:italic;text-align:center;position:relative}
.editorial-para p::before{content:'';display:block;width:40px;height:1px;background:var(--copper);margin:0 auto 24px}
/* Masterplan variant */
.masterplan-section .editorial-para{padding:0 48px 52px;max-width:1200px}
.masterplan-section .editorial-para p{text-align:left;font-size:16px}
.masterplan-section .editorial-para p::before{margin:0 0 22px}
/* Video variant */
.video-section .editorial-para{padding:40px 0 0;max-width:1100px;margin:0 auto}
.video-section .editorial-para p{text-align:left;color:rgba(250,247,242,.75);font-size:15px;line-height:1.9}
.video-section .editorial-para p::before{background:rgba(212,151,94,.5);margin:0 0 22px}
/* Waterfront wrapper */
.amen-mid-bar-wrap{background:var(--cream)}
.amen-mid-bar-wrap .editorial-para{padding:40px 72px 8px;max-width:100%}
.amen-mid-bar-wrap .editorial-para p{text-align:left;font-size:15px;font-style:normal;color:var(--umber);line-height:1.85}
.amen-mid-bar-wrap .editorial-para p::before{margin:0 0 20px;background:var(--copper)}

.amen-mid-bar{display:flex;align-items:center;justify-content:space-between;padding:20px 72px;background:var(--cream);flex-wrap:wrap;gap:14px;border-top:1px solid var(--warm);border-bottom:1px solid var(--warm)}
.amen-mid-text{font-family:var(--serif);font-size:clamp(14px,1.7vw,21px);color:var(--umber);font-style:italic}
.amen-mid-btn{background:transparent;border:1px solid var(--bark);color:var(--bark);font-size:10.5px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:11px 24px;cursor:pointer;transition:background var(--tr),color var(--tr);min-height:44px}
.amen-mid-btn:hover{background:var(--bark);color:var(--cream)}

/* ── MASTER PLAN ── */
.masterplan-section{background:var(--parchment);padding:80px 48px}
.masterplan-inner{max-width:1200px;margin:0 auto}
.masterplan-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;gap:24px}
.masterplan-h{font-family:var(--serif);font-size:clamp(26px,3.5vw,52px);font-weight:300;color:var(--bark);line-height:1.1}
.masterplan-h em{font-style:italic;color:var(--copper)}
.siteplan-img{width:100%;display:block;border:1px solid var(--warm);max-height:82vh;object-fit:cover;aspect-ratio:16/9}

/* ── FLOOR PLANS ── */
.fp-section{background:var(--white);padding:80px 48px 88px}
.fp-inner{max-width:1200px;margin:0 auto}
.fp-head{font-family:var(--serif);font-size:clamp(24px,2.8vw,42px);font-weight:300;color:var(--bark);margin-bottom:44px}
.fp-head em{color:var(--copper);font-style:italic}
.fp-carousel-wrap{overflow:hidden;width:100%}
.fp-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.fp-slide{flex:0 0 33.333%;min-width:0;padding:0 8px}
.fp-card{background:var(--parchment);cursor:pointer}
.fp-img-wrap{overflow:hidden;aspect-ratio:4/3;position:relative;background:var(--warm)}
.fp-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.fp-card:hover .fp-img{transform:scale(1.04)}
.fp-info{padding:15px 18px 18px;border-top:1px solid var(--warm)}
.fp-name{font-family:var(--serif);font-size:16px;font-weight:400;color:var(--bark);margin-bottom:3px}
.fp-unit{font-size:11px;color:var(--copper);letter-spacing:1px}
.fp-locked{position:relative}
.fp-img-blur{filter:blur(7px)brightness(.55)!important}
.fp-lock-panel{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;padding:18px;text-align:center;background:rgba(250,247,242,.88);backdrop-filter:blur(4px)}
.fp-lock-ico{width:40px;height:40px;border:1px solid rgba(184,122,74,.4);display:flex;align-items:center;justify-content:center}
.fp-lock-txt{font-size:13px;color:var(--umber);line-height:1.5;font-weight:300}
.fp-lock-cta{background:transparent;border:1px solid var(--copper);color:var(--copper);font-size:10px;font-family:var(--sans);font-weight:500;letter-spacing:1.5px;text-transform:uppercase;padding:8px 16px;cursor:pointer;transition:background var(--tr),color var(--tr);min-height:44px}
.fp-lock-cta:hover{background:var(--copper);color:var(--white)}
.fp-carousel-nav{display:flex;align-items:center;gap:12px;margin-top:24px;justify-content:center}
.fp-carousel-btn{background:transparent;border:1px solid var(--sand);color:var(--umber);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color var(--tr),background var(--tr);font-size:16px}
.fp-carousel-btn:hover{border-color:var(--copper);background:rgba(184,122,74,.08)}
.fp-carousel-dots{display:flex;gap:6px;align-items:center}
.fp-dot{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:0}
.fp-dot::after{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--sand);transition:background .3s,transform .3s}
.fp-dot.active::after{background:var(--copper);transform:scale(1.4)}
.mf-banner{display:flex;align-items:center;justify-content:space-between;padding:28px 72px;background:var(--parchment);flex-wrap:wrap;gap:18px;border-top:1px solid var(--warm);border-bottom:1px solid var(--warm)}
.mf-text{font-family:var(--serif);font-size:clamp(18px,3vw,40px);font-weight:300;color:var(--bark)}
.mf-cta{background:var(--copper);color:var(--white);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:13px 28px;border:none;cursor:pointer;transition:background var(--tr);min-height:44px}
.mf-cta:hover{background:var(--copper-dk)}

/* ── LOCATION ── */
.loc-section{background:var(--parchment);padding:88px 48px}
.loc-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.loc-left-sticky{position:sticky;top:88px;align-self:start}
.loc-right-scroll{max-height:560px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--sand) transparent;padding-right:6px}
.loc-right-scroll::-webkit-scrollbar{width:3px}
.loc-right-scroll::-webkit-scrollbar-track{background:transparent}
.loc-right-scroll::-webkit-scrollbar-thumb{background:var(--sand);border-radius:2px}
.loc-h{font-family:var(--serif);font-size:clamp(26px,3.8vw,54px);font-weight:300;color:var(--bark);line-height:1.18;margin-bottom:36px}
.loc-h em{color:var(--copper);font-style:italic;display:block}
.loc-list{list-style:none;margin-bottom:0}
.loc-list li{padding:13px 0;border-bottom:1px solid var(--warm);display:grid;grid-template-columns:120px 1fr;gap:10px}
.loc-list li:last-child{border-bottom:none}
.loc-label{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--copper);padding-top:2px}
.loc-val{font-size:14px;color:var(--umber);line-height:1.6;font-weight:300}
.loc-map-wrap iframe{width:100%;height:360px;border:1px solid var(--warm);display:block}

/* ── SPECIFICATIONS ── */
.specs-section{background:var(--white);padding:80px 48px}
.specs-section-inner{max-width:860px;margin:0 auto}
.specs-heading{font-family:var(--serif);font-size:clamp(24px,3vw,44px);font-weight:300;color:var(--bark);margin-bottom:48px;text-align:center}
.specs-heading em{color:var(--copper);font-style:italic}
.specs-accordion{border:1px solid var(--warm)}
.sacc-item{border-bottom:1px solid var(--warm)}
.sacc-item:last-child{border-bottom:none}
.sacc-trigger{width:100%;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:16px;padding:20px 28px;text-align:left;transition:background var(--tr);min-height:44px}
.sacc-trigger:hover{background:var(--parchment)}
.sacc-item.open .sacc-trigger{background:var(--parchment)}
.sacc-icon{font-size:20px;flex-shrink:0;opacity:.7;width:28px;text-align:center}
.sacc-name{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--bark);flex:1}
.sacc-item.open .sacc-name{color:var(--copper)}
.sacc-chevron{width:28px;height:28px;border:1px solid var(--sand);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--copper);font-size:16px;font-weight:300;line-height:1;transition:background var(--tr),border-color var(--tr),transform var(--tr)}
.sacc-item.open .sacc-chevron{background:var(--copper);color:var(--white);border-color:var(--copper);transform:rotate(180deg)}
.sacc-body{display:none;padding:0 28px 24px 72px}
.sacc-item.open .sacc-body{display:block}
.sacc-list{list-style:none}
.sacc-list li{font-size:14px;color:var(--umber);padding:8px 0;padding-left:16px;position:relative;font-weight:300;line-height:1.7;border-bottom:1px solid var(--warm)}
.sacc-list li:last-child{border-bottom:none}
.sacc-list li::before{content:'–';position:absolute;left:0;color:var(--copper)}

/* ── CONTACT ── */
.contact-section{background:var(--bark);padding:88px 48px;position:relative;overflow:hidden}
.contact-section::before{content:'MOONGLADE';position:absolute;left:-20px;bottom:-30px;font-family:var(--serif);font-size:140px;font-weight:300;color:rgba(250,247,242,.03);white-space:nowrap;pointer-events:none;letter-spacing:-4px;user-select:none;aria-hidden:true}
.contact-inner{max-width:1100px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:start}
.contact-h{font-family:var(--serif);font-size:clamp(26px,3.8vw,52px);font-weight:300;color:var(--cream);line-height:1.15;margin-bottom:16px}
.contact-h em{color:var(--copper-lt);font-style:italic}
.contact-p{font-size:15px;color:rgba(250,247,242,.8);line-height:1.8;font-weight:300}
.contact-divider{width:36px;height:1px;background:rgba(184,122,74,.5);margin:24px 0}
.contact-links a{font-size:14px;color:rgba(250,247,242,.82);display:flex;align-items:center;gap:10px;margin-bottom:10px;transition:color var(--tr);padding:4px 0;min-height:44px}
.contact-links a:hover{color:var(--cream)}
.form-field{margin-bottom:22px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.f-lbl-text{display:block;font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:rgba(184,122,74,.9);margin-bottom:9px}
.f-inp{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(250,247,242,.2);padding:9px 0;font-size:15px;font-family:var(--sans);color:var(--cream);outline:none;transition:border-color var(--tr);font-weight:300}
.f-inp::placeholder{color:rgba(250,247,242,.3)}.f-inp:focus{border-bottom-color:var(--copper-lt)}
.f-inp.error{border-bottom-color:#c0392b}.f-inp.success{border-bottom-color:#27ae60}
.f-inp-wrap{display:flex;flex-direction:column}
.f-phone-wrap{display:flex;align-items:flex-end}
.f-phone-prefix{font-size:15px;color:var(--cream);padding:9px 7px 9px 0;border-bottom:1px solid rgba(250,247,242,.2);line-height:1;font-weight:300;flex-shrink:0;transition:border-color var(--tr)}
.f-phone-wrap.focused .f-phone-prefix{border-bottom-color:var(--copper-lt)}
.f-phone-wrap .f-inp{flex:1}
.f-field-err{font-size:11px;color:#e87;margin-top:4px;display:none;font-weight:300}
.f-field-err.show{display:block}
.f-consent{display:flex;gap:10px;align-items:flex-start;margin-bottom:24px}
.f-check{width:16px;height:16px;flex-shrink:0;margin-top:3px;accent-color:var(--copper-lt);cursor:pointer}
.f-consent-text{font-size:11px;color:rgba(250,247,242,.55);line-height:1.6;font-weight:300}
.form-success-msg{text-align:center;padding:28px 18px;display:none;flex-direction:column;align-items:center;gap:11px}
.form-success-msg.show{display:flex}
.success-ico{width:50px;height:50px;background:#f0faf4;border:1px solid #27ae60;border-radius:50%;display:flex;align-items:center;justify-content:center}
.success-ico svg{color:#27ae60}
.success-title{font-family:var(--serif);font-size:28px;font-weight:300;color:var(--bark)}
.success-sub{font-size:14px;color:var(--umber);font-weight:300;line-height:1.6}
.contact-section .success-title{color:var(--cream)}
.contact-section .success-sub{color:rgba(250,247,242,.75)}
.contact-section .success-ico{background:rgba(39,174,96,.12);border-color:#27ae60}
.btn-submit{width:100%;background:var(--copper-lt);color:var(--bark);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;padding:15px;border:none;cursor:pointer;transition:background var(--tr);min-height:44px}
.btn-submit:hover{background:var(--copper);color:var(--white)}
.btn-submit:disabled{opacity:.6;cursor:not-allowed}

/* ── FOOTER ── */
.footer{background:var(--white)}
.footer-top-strip{height:4px;background:linear-gradient(to right,var(--copper-dk),var(--copper-lt),var(--copper))}
.footer-body{padding:68px 72px 52px;border-bottom:1px solid var(--warm)}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1.2fr;gap:20px}
.footer-logo-img{height:36px;width:auto;margin-bottom:16px}
.footer-tagline{font-size:14px;color:var(--umber);line-height:1.8;max-width:280px;margin-bottom:20px;font-weight:300}
.footer-col-h{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--bark);margin-bottom:18px}
.footer-nav{list-style:none}
.footer-nav li{margin-bottom:10px}
.footer-nav li a{font-size:14px;color:var(--umber);transition:color var(--tr);font-weight:300;padding:4px 0;display:inline-block;min-height:44px;line-height:44px}
.footer-nav li a:hover{color:var(--copper)}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.footer-contact-item svg{flex-shrink:0;margin-top:3px}
.footer-contact-item a,.footer-contact-item span{font-size:14px;color:var(--umber);font-weight:300;line-height:1.5;transition:color var(--tr)}
.footer-contact-item a:hover{color:var(--copper)}
.footer-socials{display:flex;gap:10px;margin-top:20px}
.footer-social-link{width:44px;height:44px;border:1px solid var(--sand);display:flex;align-items:center;justify-content:center;color:var(--umber);transition:border-color var(--tr),color var(--tr)}
.footer-social-link:hover{border-color:var(--copper);color:var(--copper)}
.footer-rera-badge{background:var(--parchment);border:1px solid var(--warm);padding:12px 16px;margin-top:20px}
.footer-rera-badge p{font-size:11px;color:var(--copper);font-weight:500;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.footer-rera-badge span{font-size:12px;color:var(--umber);font-weight:300}
.footer-rera-badge a{color:var(--copper);text-decoration:underline;text-underline-offset:3px}
.footer-bottom{padding:16px 72px;background:var(--parchment);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-copy{font-size:12px;color:var(--stone)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:12px;color:var(--stone);transition:color var(--tr);min-height:44px;line-height:44px;display:inline-block}
.footer-bottom-links a:hover{color:var(--copper)}

/* ── STICKY TAB ── */
.sticky-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:900;background:var(--copper);color:var(--white);border:none;cursor:pointer;width:34px;min-height:80px;border-radius:2px 0 0 2px;box-shadow:-3px 0 12px rgba(184,122,74,.3);transition:width .25s,background var(--tr);display:flex;align-items:center;justify-content:center}
.sticky-tab:hover{width:40px;background:var(--copper-dk)}
.sst{display:block;writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:18px 0;white-space:nowrap}

/* ── MODALS ── */
.modal-bg{display:none;position:fixed;inset:0;z-index:5000;align-items:center;justify-content:center;padding:20px}
.modal-bg::before{content:'';position:absolute;inset:0;background:rgba(61,47,37,.6);backdrop-filter:blur(16px)}
.modal-bg.open{display:flex}
.modal-box{position:relative;z-index:1;width:100%;max-width:460px;background:var(--cream);padding:48px 42px 42px;box-shadow:0 32px 80px rgba(61,47,37,.25);animation:mIn .4s cubic-bezier(.22,1,.36,1) both;max-height:94vh;overflow-y:auto}
@keyframes mIn{from{opacity:0;transform:scale(.92)translateY(28px)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:14px;right:16px;background:var(--warm);border:1px solid var(--sand);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--tr);color:var(--umber)}
.modal-close:hover{background:var(--sand)}
.modal-accent-line{height:2px;background:linear-gradient(to right,var(--copper-dk),var(--copper-lt));margin-bottom:28px}
.modal-eye{font-size:9px;font-weight:500;letter-spacing:3.5px;color:var(--copper);text-transform:uppercase;margin-bottom:5px}
.modal-title{font-family:var(--serif);font-size:clamp(28px,5vw,44px);color:var(--bark);line-height:1.1;margin-bottom:28px}
.modal-title em{font-style:italic;color:var(--copper)}
.modal-rera{font-size:10px;color:rgba(184,122,74,.6);text-align:center;letter-spacing:.5px;margin-top:12px}
.modal-box .f-lbl-text{color:var(--copper)}
.modal-box .f-inp{color:var(--bark);border-bottom-color:var(--sand)}
.modal-box .f-inp::placeholder{color:var(--sand)}
.modal-box .f-inp:focus{border-bottom-color:var(--copper)}
.modal-box .f-phone-prefix{color:var(--bark);border-bottom-color:var(--sand)}
.modal-box .f-phone-wrap.focused .f-phone-prefix{border-bottom-color:var(--copper)}
.modal-box .f-field-err{color:#c0392b}
.modal-box .f-consent-text{color:var(--stone)}
.modal-box .f-check{accent-color:var(--copper)}
.modal-submit{width:100%;background:var(--bark);color:var(--cream);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;padding:15px;border:none;cursor:pointer;transition:background var(--tr);margin-bottom:10px;min-height:44px}
.modal-submit:hover{background:var(--bark-lt)}
.modal-submit:disabled{opacity:.6;cursor:not-allowed}

/* ONLOAD MODAL */
.onload-modal .modal-box{max-width:520px;background:var(--bark);padding:0;overflow:hidden}
.onload-modal .modal-accent-line{display:none}
.onload-header{background:linear-gradient(135deg,var(--copper-dk),var(--copper));padding:28px 40px 24px;text-align:center}
.onload-header-tag{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(250,247,242,.8);margin-bottom:8px}
.onload-header-h{font-family:var(--serif);font-size:28px;color:var(--cream);font-weight:300;font-style:italic}
.onload-body{padding:32px 40px 36px}
.onload-modal .f-lbl-text{color:rgba(212,151,94,.9)}
.onload-modal .f-inp{color:var(--cream);border-bottom-color:rgba(250,247,242,.2)}
.onload-modal .f-inp::placeholder{color:rgba(250,247,242,.3)}
.onload-modal .f-inp:focus{border-bottom-color:var(--copper-lt)}
.onload-modal .f-inp.error{border-bottom-color:#c0392b}
.onload-modal .f-inp.success{border-bottom-color:#27ae60}
.onload-modal .f-phone-prefix{color:var(--cream);border-bottom-color:rgba(250,247,242,.2)}
.onload-modal .f-phone-wrap.focused .f-phone-prefix{border-bottom-color:var(--copper-lt)}
.onload-modal .f-field-err{color:#e87}
.onload-modal .f-consent-text{color:rgba(250,247,242,.55)}
.onload-modal .f-check{accent-color:var(--copper-lt)}
.onload-modal .modal-close{top:12px;right:14px;background:rgba(250,247,242,.1);border-color:rgba(250,247,242,.2);color:rgba(250,247,242,.8)}
.onload-modal .modal-close:hover{background:rgba(250,247,242,.2)}
.onload-modal .modal-submit{background:var(--copper-lt);color:var(--bark)}
.onload-modal .modal-submit:hover{background:var(--copper-lt);filter:brightness(1.1)}
.onload-modal .modal-rera{color:rgba(212,151,94,.5)}
.onload-modal .success-title{color:var(--cream)}
.onload-modal .success-sub{color:rgba(250,247,242,.75)}
.onload-modal .success-ico{background:rgba(39,174,96,.12);border-color:#27ae60}

/* VISIT MODAL */
.visit-modal .modal-box{background:var(--bark);padding:0;overflow:hidden;max-width:520px}
.visit-modal .modal-accent-line{display:none}
.visit-modal .modal-close{background:rgba(250,247,242,.1);border-color:rgba(250,247,242,.2);color:rgba(250,247,242,.8)}
.visit-modal .modal-close:hover{background:rgba(250,247,242,.2)}
.visit-header{background:var(--bark-lt);padding:28px 40px 24px;text-align:center;border-bottom:1px solid rgba(250,247,242,.08)}
.visit-header-tag{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(212,151,94,.8);margin-bottom:8px}
.visit-header-h{font-family:var(--serif);font-size:30px;color:var(--cream);font-weight:300;font-style:italic}
.visit-body{padding:32px 40px 36px}
.visit-modal .f-lbl-text{color:rgba(212,151,94,.9)}
.visit-modal .f-inp{color:var(--cream);border-bottom-color:rgba(250,247,242,.2)}
.visit-modal .f-inp::placeholder{color:rgba(250,247,242,.3)}
.visit-modal .f-inp:focus{border-bottom-color:var(--copper-lt)}
.visit-modal .f-inp.error{border-bottom-color:#c0392b}
.visit-modal .f-inp.success{border-bottom-color:#27ae60}
.visit-modal .f-phone-prefix{color:var(--cream);border-bottom-color:rgba(250,247,242,.2)}
.visit-modal .f-phone-wrap.focused .f-phone-prefix{border-bottom-color:var(--copper-lt)}
.visit-modal .f-field-err{color:#e87}
.visit-modal .f-consent-text{color:rgba(250,247,242,.55)}
.visit-modal .f-check{accent-color:var(--copper-lt)}
.visit-modal .modal-submit{background:var(--copper-lt);color:var(--bark)}
.visit-modal .modal-submit:hover{background:var(--copper);color:var(--white)}
.visit-modal .modal-rera{color:rgba(212,151,94,.5)}
.visit-modal .success-title{color:var(--cream)}
.visit-modal .success-sub{color:rgba(250,247,242,.75)}
.visit-modal .success-ico{background:rgba(39,174,96,.12);border-color:#27ae60}

/* Mobile CTA bar */
.mob-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:850;background:var(--cream);border-top:1px solid var(--warm);padding:11px 14px 13px;box-shadow:0 -4px 24px rgba(61,47,37,.1)}
.mob-cta-bar .btn-fill{width:100%;padding:14px 10px;font-size:11px;text-align:center;display:block}

/* VIDEO FULL MODAL */
.video-modal{display:none;position:fixed;inset:0;z-index:6000;align-items:center;justify-content:center;padding:20px}
.video-modal::before{content:'';position:absolute;inset:0;background:rgba(8,8,12,.88);backdrop-filter:blur(20px)}
.video-modal.open{display:flex}
.video-wrap{position:relative;z-index:1;width:100%;max-width:960px;background:#000;aspect-ratio:16/9}
.video-wrap iframe{width:100%;height:100%;border:none}
.video-close{position:absolute;top:-52px;right:0;background:none;border:1px solid rgba(250,247,242,.3);color:var(--cream);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;line-height:1;transition:background var(--tr)}
.video-close:hover{background:rgba(250,247,242,.1)}

/* ── RESPONSIVE ── */
@media(max-width:1200px){
  .nav-wrap{padding:0 28px}
  .nav-links{gap:24px}
  .footer-body{padding:52px 32px 44px}
  .footer-bottom{padding:16px 32px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:960px){
  .nav-links{display:none}.hbg{display:flex}.nav-wrap{padding:0 20px}
  .hero-slide img{height:55vw;min-height:260px}
  .club-top{grid-template-columns:1fr;gap:36px}
  .club-left-sticky{position:static;top:auto}
  .club-right-scroll{max-height:none;overflow-y:visible;padding-right:0}
  .loc-inner{grid-template-columns:1fr;gap:36px}
  .loc-left-sticky{position:static;top:auto}
  .loc-right-scroll{max-height:none;overflow-y:visible;padding-right:0}
  .contact-inner{grid-template-columns:1fr;gap:36px}
  .amen-img-wrap{aspect-ratio:unset;min-height:auto;display:flex;flex-direction:column}
  .amen-img{position:relative;width:100%;height:220px;object-fit:cover;filter:brightness(.55) saturate(.85);flex-shrink:0}
  .amen-grad{display:none}
  .amen-content{position:static;background:var(--bark);padding:28px 24px 32px}
  .amen-title{font-size:clamp(32px,8vw,48px);color:var(--cream);margin-bottom:20px}
  .amen-list{grid-template-columns:repeat(2,1fr);gap:4px 8px}
  .amen-list li{font-size:12.5px;color:rgba(250,247,242,.85)}
  .amen-mid-bar,.mf-banner{padding:18px 24px}
  .amen-gallery-slide{flex:0 0 50%}
  .fp-slide{flex:0 0 50%}
  .club-carousel-slide{flex:0 0 50%}
  .footer-grid{grid-template-columns:1fr 1fr}
  .loc-section,.masterplan-section,.fp-section,.contact-section,.specs-section{padding-left:24px;padding-right:24px}
  .club-section-inner{padding:52px 24px}
  .video-section{padding:52px 24px}
  .amen-section{padding:0}
  .sticky-tab{display:none!important}
  .mob-cta-bar{display:block}
  body{padding-bottom:60px}
  .editorial-para{padding:28px 24px 0}
  .masterplan-section .editorial-para{padding:0 24px 36px}
  .amen-mid-bar-wrap .editorial-para{padding:28px 24px 12px}
  .video-section .editorial-para{padding:32px 0 0}
}
@media(max-width:640px){
  .fp-slide{flex:0 0 100%}
  .amen-gallery-slide{flex:0 0 100%}
  .club-carousel-slide{flex:0 0 100%}
  .hero-slide img{height:70vw;min-height:280px}
  .mf-banner{flex-direction:column;text-align:center}
  .modal-box{padding:36px 20px 32px}
  .f-row{grid-template-columns:1fr;gap:0}
  .onload-header,.visit-header{padding:22px 24px 18px}
  .onload-body,.visit-body{padding:24px 24px 28px}
  .footer-body{padding:44px 20px 32px}
  .footer-bottom{padding:14px 20px;flex-direction:column;text-align:center}
  .footer-grid{grid-template-columns:1fr}
  .video-section-top{flex-direction:column;align-items:flex-start}
  .video-section-sub{text-align:left}
  .amen-list{grid-template-columns:1fr 1fr}
  .sacc-body{padding:0 16px 20px 44px}
  .amen-img{height:180px}
  .amen-content{padding:24px 20px 28px}
  .amen-title{font-size:clamp(28px,9vw,40px)}
  .editorial-para p{font-size:15px;line-height:1.8}
}

/* ── HIGH CONTRAST MODE SUPPORT ── */
@media(forced-colors:active){
  .btn-fill,.btn-copper,.btn-submit,.modal-submit,.mf-cta{border:2px solid ButtonText}
  .sacc-chevron{border:2px solid ButtonText}
}
