/* =============================================
   PARADISE RESIDENCE — Stylesheet
   Palette: cream / taupe / charcoal / gold
   ============================================= */

:root {
  --cream:      #F8F4EF;
  --warm-white: #FDFCFB;
  --taupe:      #B8A99A;
  --lt-taupe:   #D4C9BE;
  --charcoal:   #2A2A2A;
  --dark:       #1C1C1C;
  --darker:     #111111;
  --gold:       #C9A96E;
  --lt-gold:    #E8D5B0;
  --steel:      #4A5568;
  --green-wa:   #25D366;
  --ease:       cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html  { scroll-behavior:smooth; }
body  { font-family:'Jost',sans-serif; background:var(--dark); color:var(--cream); overflow-x:hidden; }
img   { max-width:100%; display:block; }
a     { text-decoration:none; color:inherit; }
button{ font-family:'Jost',sans-serif; }

.container { max-width:1380px; margin:0 auto; }
.script    { font-family:'Great Vibes',cursive; }

/* ---- TYPOGRAPHY HELPERS ---- */
.eyebrow {
  font-size:.65rem; letter-spacing:.45em; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px; display:block;
}
.section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4vw,3.6rem);
  font-weight:300; line-height:1.12; color:var(--warm-white);
}
.section-title em { font-style:italic; color:var(--gold); }
.divider { width:56px; height:1px; background:var(--gold); margin:22px 0; }
.body-text { font-size:1rem; font-weight:300; line-height:1.85; color:var(--taupe); max-width:600px; }

/* ---- BUTTONS ---- */
.btn-primary {
  display:inline-block; padding:15px 44px;
  background:var(--gold); color:var(--dark);
  font-size:.7rem; font-weight:600; letter-spacing:.25em; text-transform:uppercase;
  border:none; cursor:pointer;
  transition:background .3s var(--ease), transform .3s var(--ease);
}
.btn-primary:hover { background:var(--lt-gold); transform:translateY(-2px); }

.btn-ghost {
  display:inline-block; padding:15px 44px;
  border:1px solid rgba(248,244,239,.45); color:var(--cream);
  font-size:.7rem; letter-spacing:.25em; text-transform:uppercase;
  transition:border-color .3s var(--ease), color .3s var(--ease), transform .3s var(--ease);
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }

/* ===================== NAVIGATION ===================== */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  padding:26px 60px;
  display:flex; align-items:center; justify-content:space-between;
  transition:padding .4s var(--ease), background .4s var(--ease), border-color .4s var(--ease);
}
.nav.scrolled {
  background:rgba(28,28,28,.96);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  padding:16px 60px;
  border-bottom:1px solid rgba(201,169,110,.18);
}
.nav-logo { display:flex; flex-direction:column; line-height:1; }
.nav-logo .script   { font-size:2rem; color:var(--gold); }
.nav-logo .tagline  { font-size:.58rem; letter-spacing:.3em; text-transform:uppercase; color:var(--lt-taupe); margin-top:3px; }
.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a {
  font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cream);
  position:relative; transition:color .3s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:1px; background:var(--gold); transition:width .3s var(--ease);
}
.nav-links a:hover { color:var(--gold); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
  padding:10px 26px; border:1px solid var(--gold); color:var(--gold);
  font-size:.68rem; letter-spacing:.2em; text-transform:uppercase;
  transition:background .3s, color .3s;
}
.nav-cta:hover { background:var(--gold); color:var(--dark); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:24px; height:1.5px; background:var(--cream); transition:.3s; }

/* MOBILE MENU */
.mobile-menu {
  display:none; position:fixed; inset:0; z-index:950;
  background:var(--dark); flex-direction:column; align-items:center; justify-content:center; gap:28px;
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
  font-family:'Cormorant Garamond',serif; font-size:2.2rem; font-weight:300;
  color:var(--cream); letter-spacing:.05em; transition:color .3s;
}
.mobile-menu a:hover { color:var(--gold); }
.mobile-close {
  position:absolute; top:24px; right:32px;
  background:none; border:none; color:var(--cream); font-size:1.4rem; cursor:pointer; transition:color .3s;
}
.mobile-close:hover { color:var(--gold); }

/* ===================== HERO ===================== */
.hero {
  position:relative; height:100vh; min-height:680px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background:url('../../images/Yard.jpg') center/cover no-repeat;
  transform:scale(1.06); transition:transform 8s ease;
}
.hero-bg.loaded { transform:scale(1); }
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(28,28,28,.72) 0%, rgba(28,28,28,.38) 50%, rgba(28,28,28,.62) 100%);
}
.hero-content {
  position:relative; z-index:2; text-align:center;
  max-width:860px; padding:0 24px;
  animation:fadeUp 1.2s .3s both;
}
.hero-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.6rem,9vw,7.5rem); font-weight:300; line-height:.95;
  color:var(--warm-white); margin-bottom:18px;
}
.hero-title em { font-style:italic; color:var(--gold); display:block; }
.hero-sub {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.1rem,2.2vw,1.6rem); font-weight:300; letter-spacing:.12em;
  color:var(--lt-taupe); margin-bottom:20px;
}
.hero-price-tag {
  display:inline-block; padding:8px 24px;
  border:1px solid rgba(201,169,110,.4);
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--lt-taupe);
  margin-bottom:36px;
}
.hero-price-tag strong { color:var(--gold); font-weight:600; }
.hero-actions { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }
.scroll-indicator {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:var(--taupe); font-size:.58rem; letter-spacing:.35em; text-transform:uppercase;
  animation:pulse 2.5s infinite;
}
.scroll-indicator::before {
  content:''; display:block; width:1px; height:48px;
  background:linear-gradient(to bottom,transparent,var(--gold));
}

/* ===================== STATS BAR ===================== */
.stats-bar {
  background:var(--charcoal); padding:36px 60px;
  display:flex; justify-content:center; align-items:center;
  border-top:1px solid rgba(201,169,110,.25); border-bottom:1px solid rgba(201,169,110,.25);
  flex-wrap:wrap;
}
.stat { text-align:center; padding:12px 52px; }
.stat-num {
  font-family:'Cormorant Garamond',serif; font-size:3rem; font-weight:300;
  color:var(--gold); line-height:1;
}
.stat-num sup { font-size:1.1rem; }
.stat-label { font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--taupe); margin-top:6px; }
.stat-divider { width:1px; height:56px; background:rgba(201,169,110,.25); align-self:center; }

/* ===================== ABOUT ===================== */
.about { padding:130px 60px; background:var(--dark); }
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:100px; align-items:center; }
.about-images { position:relative; height:600px; }
.img-main     { position:absolute; top:0; left:0; width:70%; height:78%; object-fit:cover; }
.img-secondary{ position:absolute; bottom:0; right:0; width:54%; height:52%; object-fit:cover; border:6px solid var(--dark); }
.about-badge {
  position:absolute; top:50%; right:-24px; transform:translateY(-50%);
  width:96px; height:96px; background:var(--gold); border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  z-index:2; text-align:center; gap:1px;
}
.badge-no  { font-size:.5rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--dark); }
.badge-val { font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:600; color:var(--dark); line-height:1; }
.badge-loc { font-size:.48rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--dark); }
.price-block { margin-top:36px; border-left:2px solid var(--gold); padding-left:20px; }
.price-label { display:block; font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:var(--taupe); margin-bottom:4px; }
.price-value { display:block; font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:300; color:var(--gold); }

/* ===================== INTERIORS ===================== */
.interiors { background:#161616; }
.interior-row {
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center;
}
.interior-row.reverse { direction:rtl; }
.interior-row.reverse > * { direction:ltr; }

.interior-img { overflow:hidden; max-height:620px; }
.interior-img img { width:100%; height:100%; object-fit:cover; object-position:center; transition:transform .6s var(--ease); }
.interior-img:hover img { transform:scale(1.04); }

.interior-text { padding:80px 72px; }
.interior-text .body-text { max-width:480px; }

/* KITCHEN */
.kitchen-row { }
.kitchen-text { padding:80px 72px; }
.kitchen-text .body-text { max-width:480px; margin-bottom:36px; }
.spec-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:32px; }
.spec-item { display:flex; align-items:flex-start; gap:14px; }
.spec-icon {
  width:36px; height:36px; min-width:36px;
  border:1px solid rgba(201,169,110,.3);
  display:flex; align-items:center; justify-content:center; margin-top:2px;
}
.spec-icon svg { width:16px; height:16px; stroke:var(--gold); fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.spec-title { font-size:.82rem; font-weight:500; color:var(--warm-white); margin-bottom:3px; }
.spec-desc  { font-size:.78rem; font-weight:300; color:var(--taupe); line-height:1.5; }

.kitchen-views {
  width:100%; overflow:hidden;
  border-top:4px solid #161616;
}
.kitchen-views img { width:100%; object-fit:cover; }

/* BEDROOMS */
.bed-features { display:flex; flex-direction:column; gap:12px; margin-top:28px; }
.bed-feat { display:flex; align-items:center; gap:12px; font-size:.9rem; font-weight:300; color:var(--taupe); }
.bf-dot { width:4px; height:4px; min-width:4px; background:var(--gold); border-radius:50%; }

.bedroom-renders {
  display:grid; grid-template-columns:1fr 1fr;
  gap:4px; border-top:4px solid #161616;
}
.brender-item { overflow:hidden; }
.brender-item img { width:100%; object-fit:cover; transition:transform .6s var(--ease); }
.brender-item:hover img { transform:scale(1.03); }

/* ===================== AMENITIES ===================== */
.amenities { background:var(--dark); padding:130px 60px; }
.amenities-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.amenity-list { display:flex; flex-direction:column; gap:0; margin-top:36px; }
.amenity-item {
  display:flex; align-items:flex-start; gap:20px;
  padding:20px 0; border-bottom:1px solid rgba(255,255,255,.06);
}
.amenity-item:first-child { border-top:1px solid rgba(255,255,255,.06); }
.amenity-icon {
  width:44px; height:44px; min-width:44px;
  border:1px solid rgba(201,169,110,.3);
  display:flex; align-items:center; justify-content:center;
}
.amenity-icon svg { width:20px; height:20px; stroke:var(--gold); }
.amenity-title { font-size:.9rem; font-weight:500; color:var(--warm-white); margin-bottom:3px; }
.amenity-desc  { font-size:.82rem; font-weight:300; color:var(--taupe); line-height:1.55; }
.amenities-img { overflow:hidden; border-radius:0; }
.amenities-img img { width:100%; object-fit:cover; }

/* ===================== FLOOR PLANS ===================== */
.floor-plans { background:var(--charcoal); padding:120px 60px; }
.fp-header { text-align:center; max-width:700px; margin:0 auto 52px; }
.fp-tabs {
  display:flex; justify-content:center; gap:4px; margin-bottom:52px; flex-wrap:wrap;
}
.fp-tab {
  padding:14px 36px; background:transparent;
  border:1px solid rgba(201,169,110,.25); color:var(--taupe);
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
  cursor:pointer; transition:.3s; display:flex; flex-direction:column; align-items:center; gap:4px;
}
.fp-tab span { font-size:.6rem; color:inherit; opacity:.7; }
.fp-tab:hover { border-color:var(--gold); color:var(--gold); }
.fp-tab.active { background:var(--gold); border-color:var(--gold); color:var(--dark); }
.fp-tab.active span { opacity:.8; }

.fp-panels { position:relative; }
.fp-panel  { display:none; }
.fp-panel.active { display:block; }
.fp-layout { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.fp-plan-img { overflow:hidden; background:rgba(255,255,255,.03); }
.fp-plan-img img { width:100%; object-fit:contain; padding:8px; }

.fp-details { padding-top:8px; }
.fp-floor-tag {
  display:inline-block; padding:5px 16px;
  background:rgba(201,169,110,.15); border:1px solid rgba(201,169,110,.3);
  font-size:.62rem; letter-spacing:.25em; text-transform:uppercase; color:var(--gold);
  margin-bottom:12px;
}
.fp-sqm {
  font-family:'Cormorant Garamond',serif; font-size:3.2rem; font-weight:300;
  color:var(--warm-white); line-height:1; margin-bottom:16px;
}
.fp-sqm::after { content:' sqm'; font-size:1.2rem; color:var(--taupe); }
.fp-desc { font-size:.9rem; font-weight:300; color:var(--taupe); line-height:1.7; margin-bottom:28px; }
.fp-rooms { list-style:none; display:flex; flex-direction:column; gap:10px; }
.fp-rooms li {
  display:flex; align-items:center; gap:12px;
  font-size:.88rem; font-weight:300; color:var(--lt-taupe);
  padding-bottom:10px; border-bottom:1px solid rgba(255,255,255,.05);
}
.fp-rooms li::before { content:''; width:20px; height:1px; background:var(--gold); flex-shrink:0; }

/* ===================== MASTER PLAN ===================== */
.master-plan { background:#161616; padding:120px 60px; }
.mp-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.mp-facts { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:40px; }
.mp-fact { text-align:center; padding:20px 16px; background:var(--charcoal); }
.mp-fact-num { font-family:'Cormorant Garamond',serif; font-size:2.4rem; font-weight:300; color:var(--gold); line-height:1; }
.mp-fact-label { font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--taupe); margin-top:6px; }
.mp-img { overflow:hidden; }
.mp-img img { width:100%; object-fit:cover; }

/* ===================== GALLERY ===================== */
.gallery { background:var(--dark); padding:120px 0; }
.gallery-header { padding:0 60px; text-align:center; margin-bottom:48px; }
.gallery-filter {
  display:flex; justify-content:center; gap:8px; margin-bottom:40px;
  padding:0 60px; flex-wrap:wrap;
}
.filter-btn {
  padding:9px 26px; border:1px solid rgba(201,169,110,.3);
  background:transparent; color:var(--taupe);
  font-size:.68rem; letter-spacing:.2em; text-transform:uppercase;
  cursor:pointer; transition:background .3s, border-color .3s, color .3s;
}
.filter-btn:hover, .filter-btn.active { background:var(--gold); border-color:var(--gold); color:var(--dark); }

.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:260px; gap:4px; }
.g-item { position:relative; overflow:hidden; cursor:zoom-in; }
.g-item.wide  { grid-column:span 2; }
.g-item.tall  { grid-row:span 2; }
.g-item img   { width:100%; height:100%; object-fit:cover; transition:transform .65s var(--ease); }
.g-item:hover img { transform:scale(1.07); }
.g-overlay {
  position:absolute; inset:0; background:rgba(28,28,28,0);
  display:flex; align-items:flex-end; padding:20px 24px; transition:background .35s;
}
.g-item:hover .g-overlay { background:rgba(28,28,28,.48); }
.g-label {
  font-size:.65rem; letter-spacing:.22em; text-transform:uppercase; color:var(--cream);
  opacity:0; transform:translateY(8px); transition:opacity .35s, transform .35s;
  border-bottom:1px solid var(--gold); padding-bottom:4px;
}
.g-item:hover .g-label { opacity:1; transform:translateY(0); }

/* ---- LIGHTBOX ---- */
.lightbox {
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.94);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.lightbox.active { opacity:1; pointer-events:all; }
.lb-img-wrap { display:flex; flex-direction:column; align-items:center; gap:14px; max-width:88vw; }
.lightbox img { max-width:88vw; max-height:82vh; object-fit:contain; display:block; }
.lb-caption { font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--taupe); }
.lb-close,.lb-prev,.lb-next {
  position:absolute; background:none;
  border:1px solid rgba(255,255,255,.25); color:var(--cream);
  width:44px; height:44px; display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; cursor:pointer; transition:border-color .3s, color .3s;
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover { border-color:var(--gold); color:var(--gold); }
.lb-close { top:24px; right:28px; }
.lb-prev  { left:20px;  top:50%; transform:translateY(-50%); }
.lb-next  { right:20px; top:50%; transform:translateY(-50%); }

/* ===================== LOCATION ===================== */
.location { background:var(--charcoal); padding:130px 60px; }
.location-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.loc-category { margin-top:32px; }
.loc-cat-title {
  display:flex; align-items:center; gap:10px;
  font-size:.68rem; letter-spacing:.25em; text-transform:uppercase; color:var(--gold);
  margin-bottom:12px;
}
.loc-cat-title svg { width:15px; height:15px; stroke:var(--gold); flex-shrink:0; }
.loc-items { display:flex; flex-wrap:wrap; gap:8px; }
.loc-items span {
  padding:6px 14px; border:1px solid rgba(201,169,110,.25);
  font-size:.78rem; font-weight:300; color:var(--lt-taupe);
}
.loc-coords {
  display:flex; align-items:center; gap:8px; margin-top:32px;
  font-size:.7rem; color:var(--steel); letter-spacing:.08em;
}
.loc-coords svg { width:14px; height:14px; stroke:var(--steel); }
.map-wrap { aspect-ratio:4/3; overflow:hidden; position:sticky; top:100px; }
.map-wrap iframe { width:100%; height:100%; border:none; filter:grayscale(25%) contrast(1.1) brightness(.95); }

/* ===================== CONTACT ===================== */
.contact { background:var(--dark); padding:130px 60px; }
.contact-inner { display:grid; grid-template-columns:1fr 1fr; gap:100px; }
.info-items { display:flex; flex-direction:column; gap:36px; margin-top:40px; }
.info-item  { display:flex; flex-direction:column; gap:4px; }
.info-label { font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.info-val   { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:300; color:var(--warm-white); }
.info-sub   { font-size:.83rem; color:var(--taupe); font-weight:300; }
.whatsapp-btn {
  display:inline-flex; align-items:center; gap:12px; padding:15px 32px;
  background:var(--green-wa); color:#fff;
  font-size:.78rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase;
  transition:background .3s, transform .3s; margin-top:40px; width:fit-content;
}
.whatsapp-btn svg { width:20px; height:20px; fill:#fff; flex-shrink:0; }
.whatsapp-btn:hover { background:#1fba58; transform:translateY(-2px); }

.contact-form { display:flex; flex-direction:column; gap:20px; }
.form-row     { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group   { display:flex; flex-direction:column; gap:7px; }
.form-group label { font-size:.62rem; letter-spacing:.25em; text-transform:uppercase; color:var(--taupe); }
.form-group input,
.form-group select,
.form-group textarea {
  background:transparent; border:1px solid rgba(184,169,154,.28);
  padding:13px 18px; color:var(--cream);
  font-family:'Jost',sans-serif; font-size:.9rem; font-weight:300;
  outline:none; transition:border-color .3s; -webkit-appearance:none; appearance:none;
}
.form-group select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A96E' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center; cursor:pointer;
}
.form-group select option { background:var(--charcoal); color:var(--cream); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--gold); }
.form-group textarea { resize:none; height:130px; }
.form-group input::placeholder,
.form-group textarea::placeholder { color:rgba(184,169,154,.45); }
.submit-btn { align-self:flex-start; margin-top:8px; }

/* ===================== FOOTER ===================== */
footer { background:var(--darker); border-top:1px solid rgba(201,169,110,.18); }
.footer-top {
  padding:60px; display:flex; align-items:flex-start;
  justify-content:space-between; flex-wrap:wrap; gap:40px;
}
.footer-brand   { display:flex; flex-direction:column; gap:8px; }
.footer-script  { font-size:2.2rem; color:var(--gold); }
.footer-brand p { font-size:.68rem; letter-spacing:.28em; text-transform:uppercase; color:var(--taupe); }
.footer-links   { display:flex; gap:32px; list-style:none; flex-wrap:wrap; align-items:center; }
.footer-links a { font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--taupe); transition:color .3s; }
.footer-links a:hover { color:var(--gold); }
.footer-bottom  { padding:24px 60px; border-top:1px solid rgba(255,255,255,.06); text-align:center; }
.footer-bottom p{ font-size:.72rem; color:var(--steel); line-height:1.8; }

/* ===================== SCROLL REVEAL ===================== */
.reveal { opacity:0; transform:translateY(36px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.r1 { transition-delay:.12s; }
.r2 { transition-delay:.24s; }
.r3 { transition-delay:.36s; }
.r4 { transition-delay:.48s; }

/* ===================== ANIMATIONS ===================== */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes pulse {
  0%,100% { opacity:1; }
  50%      { opacity:.45; }
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1280px) {
  .interior-text  { padding:60px 48px; }
  .kitchen-text   { padding:60px 48px; }
  .spec-grid      { grid-template-columns:1fr; }
  .fp-layout      { gap:48px; }
}

@media (max-width:1100px) {
  .about-inner     { gap:56px; }
  .amenities-inner { gap:56px; }
  .about  { padding:100px 40px; }
  .amenities, .floor-plans, .master-plan, .location, .contact { padding-left:40px; padding-right:40px; }
  .gallery { padding-left:0; padding-right:0; }
}

@media (max-width:960px) {
  .about-inner,
  .amenities-inner,
  .location-inner,
  .contact-inner,
  .mp-inner { grid-template-columns:1fr; }

  .interior-row,
  .interior-row.reverse { grid-template-columns:1fr; direction:ltr; }
  .interior-row.reverse { direction:ltr; }
  .interior-img { max-height:460px; }
  .interior-text, .kitchen-text { padding:48px 40px; }

  .fp-layout { grid-template-columns:1fr; gap:36px; }
  .bedroom-renders { grid-template-columns:1fr; }
  .about-images { height:480px; margin-bottom:20px; }
  .about-badge  { right:10px; }
  .map-wrap     { position:static; aspect-ratio:16/9; }

  .gallery-grid { grid-template-columns:repeat(3,1fr); grid-auto-rows:220px; }
  .g-item.wide  { grid-column:span 2; }
  .g-item.tall  { grid-row:span 1; }

  .nav { padding:20px 40px; }
  .nav.scrolled { padding:14px 40px; }
  .stats-bar    { padding:24px 40px; }
}

@media (max-width:768px) {
  .nav-links,.nav-cta { display:none; }
  .hamburger  { display:flex; }
  .nav        { padding:16px 24px; }
  .nav.scrolled { padding:12px 24px; }

  .about, .amenities, .floor-plans, .master-plan, .location, .contact { padding:72px 24px; }
  .gallery-header,.gallery-filter { padding-left:24px; padding-right:24px; }
  .gallery { padding:72px 0; }

  .stats-bar    { padding:20px 16px; }
  .stat         { padding:10px 20px; flex:1; }
  .stat-divider { height:40px; }

  .kitchen-views img { object-fit:contain; background:#111; }

  .gallery-grid { grid-template-columns:repeat(2,1fr); grid-auto-rows:200px; }
  .g-item.wide  { grid-column:span 2; }
  .g-item.tall  { grid-row:span 1; }

  .form-row { grid-template-columns:1fr; }
  .mp-facts { grid-template-columns:repeat(3,1fr); }
  .loc-category { margin-top:24px; }

  .footer-top    { padding:44px 24px; flex-direction:column; }
  .footer-bottom { padding:20px 24px; }
  .footer-links  { gap:18px; }
  .fp-tabs { gap:4px; }
  .fp-tab  { padding:10px 18px; font-size:.62rem; }
}

@media (max-width:520px) {
  .hero-title  { font-size:3.2rem; }
  .gallery-grid { grid-template-columns:1fr; grid-auto-rows:240px; }
  .g-item.wide  { grid-column:span 1; }
  .stat-divider { display:none; }
  .stats-bar    { flex-wrap:wrap; }
  .stat         { min-width:100px; }
  .mp-facts     { grid-template-columns:1fr; gap:8px; }
  .spec-grid    { grid-template-columns:1fr; }
  .fp-tabs      { flex-direction:column; align-items:center; }
  .fp-tab       { width:100%; max-width:320px; }
}
