/* ─── RESET & TOKENS ─────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --ink:   #0d0d0d;
  --stone: #f5f2ee;
  --gold:  #b89353;
  --mist:  #eeebe6;
  --muted: #6b6b6b;
  --white: #ffffff;
  --wa:    #25d366;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;
  --ease:  cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  background: var(--white);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { display:block; width:100%; }

/* ═══════════════════════════════════════════════
   ANIMATION KEYFRAMES
═══════════════════════════════════════════════ */

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-50px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes slideInRight {
  from { opacity: 0; transform: translateX(50px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.9); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes linePulse {
  0%,100% { width: 30px; }
  50%      { width: 60px; }
}

/* ─── Scroll Reveal Base State ─────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(35px);
  transition: opacity 0.75s var(--ease), transform 0.75s var(--ease);
}
.reveal.reveal-left {
  transform: translateX(-40px);
}
.reveal.reveal-right {
  transform: translateX(40px);
}
.reveal.reveal-scale {
  transform: scale(0.92);
}
.reveal.visible {
  opacity: 1;
  transform: translate(0) scale(1);
}

/* Stagger children inside a reveal parent */
.reveal-stagger > * {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}
.reveal-stagger.visible > *:nth-child(1) { opacity:1; transform:none; transition-delay:0s; }
.reveal-stagger.visible > *:nth-child(2) { opacity:1; transform:none; transition-delay:0.12s; }
.reveal-stagger.visible > *:nth-child(3) { opacity:1; transform:none; transition-delay:0.24s; }
.reveal-stagger.visible > *:nth-child(4) { opacity:1; transform:none; transition-delay:0.36s; }

/* ─── TOPBAR ─────────────────────────────────── */
.topbar {
  background: var(--ink);
  color: #aaa;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .55rem 6%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .4rem;
}
.topbar a { color: #aaa; text-decoration: none; transition: color .25s; }
.topbar a:hover { color: var(--gold); }
.topbar i { color: var(--gold); margin-right:5px; }

/* ─── NAV ────────────────────────────────────── */
header {
  background: var(--white);
  border-bottom: 1px solid #e8e3dc;
  position: sticky;
  top: 0;
  z-index: 900;
  transition: box-shadow 0.4s var(--ease), padding 0.3s;
}
header.scrolled {
  box-shadow: 0 4px 30px rgba(13,13,13,.1);
}
nav {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem 6%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.brand { display:flex; align-items:center; gap:12px; text-decoration:none; }
.brand img {
  width:42px; height:42px; border-radius:50%; object-fit:cover;
  border:2px solid var(--mist);
  transition: transform 0.4s var(--ease);
}
.brand:hover img { transform: rotate(6deg) scale(1.05); }
.brand-name { font-family:var(--serif); font-size:1.35rem; font-weight:600; color:var(--ink); line-height:1; }
.brand-name small { display:block; font-family:var(--sans); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); font-weight:400; margin-top:2px; }
.nav-links { display:flex; align-items:center; gap:2rem; list-style:none; }
.nav-links a {
  font-size:.82rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--muted); text-decoration:none; transition:color .25s;
  position: relative; padding-bottom: 2px;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 1px; background: var(--gold);
  transition: width 0.3s var(--ease);
}
.nav-links a:hover { color:var(--ink); }
.nav-links a:hover::after { width: 100%; }
.nav-cta {
  background:var(--ink); color:var(--white);
  text-decoration:none; font-size:.78rem; letter-spacing:.12em;
  text-transform:uppercase; padding:.65rem 1.4rem;
  transition: background 0.3s, transform 0.2s;
}
.nav-cta:hover { background:var(--gold); color:var(--ink); transform: translateY(-1px); }

.menu-toggle { display: none; font-size: 1.5rem; color: var(--ink); cursor: pointer; transition: color 0.3s; }
.menu-toggle:hover { color: var(--gold); }

.hero {
  position: relative;
  height: calc(100vh - 90px); /* Exactly full screen minus header */
  min-height: 650px; /* Prevent vertical squishing on small laptops */
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.hero-bg {
  position: absolute; inset: 0;
  background: url('images/luxury_hero_bg.png') center/cover no-repeat;
  /* Subtle parallax handled via JS */
  will-change: transform;
}
.hero-overlay {
  position: absolute; inset: 0;
  background: 
    linear-gradient(to right, rgba(13,13,13,0.5) 0%, rgba(13,13,13,0) 60%),
    linear-gradient(to top, rgba(13,13,13,0.95) 0%, rgba(13,13,13,0.3) 60%, rgba(13,13,13,0) 100%);
}
.hero-content {
  position: relative;
  padding: 0 6% 8%; /* Added extra bottom padding */
  color: var(--white);
  max-width: 600px; /* Safe width to avoid overlapping the glass box */
}
.hero-eyebrow {
  font-size:.85rem; letter-spacing:.25em; text-transform:uppercase;
  font-weight: 600; color:var(--gold); margin-bottom:1.4rem;
  text-shadow: 0 2px 10px rgba(0,0,0,0.5);
  display:flex; align-items:center; gap:.8rem;
  animation: fadeIn 1s var(--ease) 0.2s both;
}
.hero-eyebrow::before {
  content:''; display:block; height:1px; background:var(--gold);
  animation: linePulse 3s ease-in-out infinite;
}
.hero-content h1 {
  font-family:var(--serif); font-size:clamp(2.8rem, 5vw, 4.6rem);
  font-weight:400; line-height:1.15; margin-bottom:1.2rem;
  color:var(--white);
  text-shadow: 0 4px 15px rgba(0,0,0,0.8), 0 2px 5px rgba(0,0,0,0.5);
  animation: fadeUp 1s var(--ease) 0.35s both;
}
.hero-content h1 em { font-style:italic; color:var(--gold); font-weight:500; }
.hero-content > p {
  font-size:1.15rem; color:var(--white); font-weight:400;
  margin-bottom:2rem; max-width: 580px; line-height: 1.7;
  text-shadow: 0 2px 10px rgba(0,0,0,0.8);
  animation: fadeUp 1s var(--ease) 0.5s both;
}
.hero-btns {
  display:flex; gap:1rem; flex-wrap:wrap;
  animation: fadeUp 1s var(--ease) 0.65s both;
}
.btn-primary {
  background: var(--gold); color: var(--ink);
  padding: .9rem 2rem; text-decoration:none;
  font-size:.82rem; letter-spacing:.12em; text-transform:uppercase;
  font-weight:500; transition: all 0.3s var(--ease);
  position: relative; overflow: hidden;
}
.btn-primary::before {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background: rgba(255,255,255,0.2);
  transition: left 0.4s var(--ease);
}
.btn-primary:hover::before { left: 100%; }
.btn-primary:hover { background:var(--white); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,.2); }
.btn-ghost {
  border:1px solid rgba(255,255,255,.4); color:var(--white);
  padding:.9rem 2rem; text-decoration:none;
  font-size:.82rem; letter-spacing:.12em; text-transform:uppercase;
  font-weight:400; transition:all .3s var(--ease);
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); transform: translateY(-2px); }

/* ─── SEARCH BAR ─────────────────────────────── */
.search-strip {
  background: var(--white);
  border-bottom: 1px solid #e8e3dc;
  padding: 1.5rem 6%;
  animation: fadeIn 0.8s var(--ease) 0.8s both;
}
.search-inner {
  max-width: 1200px; margin:0 auto;
  display: flex; gap:1px; flex-wrap:wrap;
}
.s-field {
  flex:1; min-width:150px; background:var(--stone);
  display:flex; flex-direction:column; padding:.9rem 1.2rem;
  transition: background 0.25s;
}
.s-field:focus-within { background: var(--mist); }
.s-field label { font-size:.6rem; text-transform:uppercase; letter-spacing:.18em; color:var(--gold); margin-bottom:.4rem; }
.s-field select, .s-field input {
  background:transparent; border:none; outline:none;
  font-family:var(--sans); font-size:.92rem; color:var(--ink);
  cursor:pointer;
}
.s-field select option { background:var(--white); }
.s-search-btn {
  background:var(--ink); color:var(--white); border:none;
  padding:0 2rem; font-size:.78rem; letter-spacing:.14em;
  text-transform:uppercase; cursor:pointer; min-width:130px;
  transition: background 0.3s, transform 0.2s;
}
.s-search-btn:hover { background:var(--gold); color:var(--ink); transform: scale(1.02); }

/* ─── SECTION WRAPPER ────────────────────────── */
.section { padding: 6rem 6%; }
.section-inner { max-width:1200px; margin:0 auto; }
.section-tag { font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:.8rem; display:block; }
.section-title { font-family:var(--serif); font-size:clamp(2rem,4vw,3rem); font-weight:300; color:var(--ink); line-height:1.15; }
.section-title em { font-style:italic; }
.divider { width:40px; height:1px; background:var(--gold); margin: 1.2rem 0 2.5rem; transition: width 0.5s var(--ease); }

/* ─── ABOUT ──────────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-wrap img { aspect-ratio:4/5; object-fit:cover; }
.about-accent {
  position:absolute; bottom:-20px; right:-20px;
  width:140px; height:140px; border:1px solid var(--gold);
  z-index:-1;
  transition: transform 0.5s var(--ease);
}
.about-img-wrap:hover .about-accent { transform: translate(-6px, -6px); }
.about-text p { color:var(--muted); font-size:.97rem; line-height:1.8; margin-bottom:1.2rem; font-weight:300; }
.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:2.5rem; }
.stat { border-top:1px solid #e8e3dc; padding-top:1rem; }
.stat-num { font-family:var(--serif); font-size:2.2rem; font-weight:300; color:var(--ink); transition: color 0.3s; }
.stat:hover .stat-num { color: var(--gold); }
.stat-label { font-size:.72rem; text-transform:uppercase; letter-spacing:.15em; color:var(--muted); margin-top:.2rem; }

/* ─── PROPERTIES ─────────────────────────────── */
.bg-stone { background:var(--stone); }
.props-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:3rem; gap:1rem; flex-wrap:wrap; }
.view-all { font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink); text-decoration:none; border-bottom:1px solid var(--ink); padding-bottom:2px; transition: color .25s, border-color .25s; }
.view-all:hover { color:var(--gold); border-color:var(--gold); }
.props-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(320px,1fr)); gap:2px; }

.prop-card {
  background:var(--white); overflow:hidden; position:relative;
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.prop-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(13,13,13,.12);
  z-index: 2;
}
.prop-img { height:260px; overflow:hidden; position:relative; }
.prop-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s var(--ease); }
.prop-card:hover .prop-img img { transform:scale(1.07); }

/* Image overlay on hover */
.prop-img::after {
  content: ''; position:absolute; inset:0;
  background: linear-gradient(to top, rgba(13,13,13,.5) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.4s var(--ease);
}
.prop-card:hover .prop-img::after { opacity: 1; }

/* Quick action buttons reveal on hover */
.prop-hover-actions {
  position: absolute; bottom: 1rem; left: 0; right: 0;
  display: flex; justify-content: center; gap: .5rem;
  z-index: 5;
  opacity: 0; transform: translateY(10px);
  transition: opacity 0.3s var(--ease), transform 0.3s var(--ease);
}
.prop-card:hover .prop-hover-actions { opacity: 1; transform: translateY(0); }
.quick-btn {
  background: rgba(255,255,255,.9); color: var(--ink);
  border: none; padding: .4rem 1rem; font-size:.7rem;
  text-transform: uppercase; letter-spacing:.1em; cursor: pointer;
  text-decoration: none; font-weight: 600;
  transition: background 0.2s;
}
.quick-btn:hover { background: var(--gold); color: var(--ink); }

.prop-badge {
  position:absolute; top:1rem; left:1rem;
  background:var(--white); color:var(--ink);
  font-size:.65rem; text-transform:uppercase; letter-spacing:.14em;
  padding:.3rem .8rem; font-weight:500;
  z-index: 3;
}
.prop-badge.sale { background:var(--ink); color:var(--white); }
.prop-body { padding:1.6rem 1.8rem 2rem; }
.prop-price { font-family:var(--serif); font-size:1.7rem; font-weight:300; color:var(--ink); }
.prop-price span { font-family:var(--sans); font-size:.82rem; color:var(--muted); font-weight:300; }
.prop-title { font-size:.95rem; font-weight:500; margin:.3rem 0 .3rem; color:var(--ink); }
.prop-loc { font-size:.82rem; color:var(--muted); display:flex; align-items:center; gap:5px; margin-bottom:1.2rem; }
.prop-loc i { color:var(--gold); font-size:.7rem; }
.prop-meta { display:flex; gap:1.2rem; flex-wrap:wrap; padding:1rem 0; border-top:1px solid #ece8e2; border-bottom:1px solid #ece8e2; margin-bottom:1.4rem; }
.prop-meta span { font-size:.8rem; color:var(--muted); display:flex; align-items:center; gap:6px; }
.prop-meta i { color:var(--gold); }
.prop-desc { font-size:.87rem; color:var(--muted); line-height:1.7; margin-bottom:1.6rem; }
.prop-actions { display:flex; gap:.6rem; }
.pa-wa {
  flex:1; background:var(--wa); color:var(--white); text-decoration:none;
  text-align:center; padding:.75rem; font-size:.78rem; letter-spacing:.1em;
  text-transform:uppercase; font-weight:500; display:flex; align-items:center; justify-content:center; gap:7px;
  transition: opacity .2s, transform .2s;
}
.pa-wa:hover { opacity:.88; transform: scale(1.02); }
.pa-call {
  flex:1; border:1px solid var(--ink); color:var(--ink); text-decoration:none;
  text-align:center; padding:.75rem; font-size:.78rem; letter-spacing:.1em;
  text-transform:uppercase; font-weight:500; display:flex; align-items:center; justify-content:center; gap:7px;
  transition:all .2s;
}
.pa-call:hover { background:var(--ink); color:var(--white); transform: scale(1.02); }

/* ─── SERVICES ───────────────────────────────── */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:2rem; margin-top:3rem; }
.service {
  border-top:1px solid #e8e3dc; padding-top:1.5rem;
  transition: border-color 0.3s;
}
.service:hover { border-color: var(--gold); }
.service-icon {
  font-size:1.4rem; color:var(--gold); margin-bottom:1rem;
  display: inline-block;
  transition: transform 0.4s var(--ease);
}
.service:hover .service-icon { transform: scale(1.2) rotate(-5deg); }
.service h3 { font-family:var(--serif); font-size:1.3rem; font-weight:400; color:var(--ink); margin-bottom:.6rem; }
.service p { font-size:.85rem; color:var(--muted); line-height:1.7; font-weight:300; }

/* ─── TESTIMONIAL ────────────────────────────── */
.testimonial-wrap { max-width:780px; }
.testimonial-quote {
  font-family:var(--serif); font-size:clamp(1.3rem,3vw,1.9rem);
  font-weight:300; font-style:italic; line-height:1.5; color:var(--ink); margin-bottom:2rem;
  position: relative; padding-left: 1.5rem;
}
.testimonial-quote::before {
  content: '"'; position: absolute; left: 0; top: -.2rem;
  font-size: 4rem; color: var(--gold); line-height: 1; font-family: var(--serif);
  opacity: 0.4;
}
.testimonial-author { display:flex; align-items:center; gap:1rem; }
.t-avatar {
  width:44px; height:44px; border-radius:50%; background:var(--mist);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:1.2rem; color:var(--gold);
  border: 1px solid var(--gold);
}
.t-name { font-size:.88rem; font-weight:500; color:var(--ink); }
.t-role { font-size:.75rem; color:var(--muted); }
.t-stars { color:var(--gold); font-size:.85rem; letter-spacing:2px; }

/* ─── CONTACT ────────────────────────────────── */
.contact-split { display:grid; grid-template-columns:1fr 1.5fr; gap:0; border:1px solid #e8e3dc; }
.contact-left { background:var(--ink); color:var(--white); padding:3.5rem; }
.contact-left h2 { font-family:var(--serif); font-size:2rem; font-weight:300; color:var(--white); margin-bottom:.5rem; }
.contact-left p { font-size:.9rem; color:#aaa; margin-bottom:2.5rem; font-weight:300; }
.c-item { margin-bottom:2rem; }
.c-item-label { font-size:.65rem; text-transform:uppercase; letter-spacing:.2em; color:var(--gold); margin-bottom:.4rem; }
.c-item-val { font-size:1rem; color:var(--white); }
.c-item-val a { color:var(--white); text-decoration:none; transition: color .25s; }
.c-item-val a:hover { color: var(--gold); }
.social-row { display:flex; gap:.8rem; margin-top:2.5rem; }
.social-row a {
  width:36px; height:36px; border:1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  color:#aaa; text-decoration:none; font-size:.85rem;
  transition: all .3s var(--ease);
}
.social-row a:hover {
  border-color:var(--gold); color:var(--gold);
  transform: translateY(-3px);
}

.contact-right { padding:3.5rem; }
.contact-right h3 { font-family:var(--serif); font-size:1.5rem; font-weight:400; margin-bottom:.3rem; }
.contact-right p.sub { font-size:.85rem; color:var(--muted); margin-bottom:2.5rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.form-field { display:flex; flex-direction:column; margin-bottom:1.8rem; }
.form-field label { font-size:.65rem; text-transform:uppercase; letter-spacing:.18em; color:var(--gold); margin-bottom:.5rem; }
.form-field input, .form-field select, .form-field textarea {
  border:none; border-bottom:1px solid #ddd; padding:.6rem 0;
  font-family:var(--sans); font-size:.95rem; color:var(--ink);
  background:transparent; outline:none; resize:none; transition:border-color .25s;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color:var(--gold); }
.btn-submit {
  background:var(--ink); color:var(--white); border:none;
  padding:1rem 2.5rem; font-size:.78rem; text-transform:uppercase;
  letter-spacing:.14em; font-weight:500; cursor:pointer;
  transition: background 0.3s, transform 0.2s;
  font-family:var(--sans);
  position: relative; overflow: hidden;
}
.btn-submit::before {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background: var(--gold); transition: left 0.4s var(--ease);
  z-index: 0;
}
.btn-submit:hover::before { left: 0; }
.btn-submit span { position: relative; z-index: 1; }
.btn-submit:hover { color: var(--ink); transform: translateY(-1px); }

/* ─── FOOTER ─────────────────────────────────── */
footer {
  background:var(--stone); border-top:1px solid #e8e3dc;
  padding:3rem 6%; display:flex; flex-wrap:wrap;
  justify-content:space-between; align-items:center; gap:1.5rem;
}
.footer-brand { font-family:var(--serif); font-size:1.1rem; color:var(--ink); }
.footer-brand small { display:block; font-family:var(--sans); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-top:2px; }
.footer-links { display:flex; gap:1.5rem; flex-wrap:wrap; }
.footer-links a { font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); text-decoration:none; transition: color .25s; }
.footer-links a:hover { color:var(--ink); }
.footer-copy { font-size:.72rem; color:var(--muted); }

/* ─── FLOATING WA ────────────────────────────── */
.float-wa {
  position:fixed; bottom:24px; right:24px; z-index:999;
  width:52px; height:52px; border-radius:50%; background:var(--wa); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1.5rem;
  text-decoration:none; box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition: transform .3s var(--ease), box-shadow .3s;
  animation: fadeIn 1.5s var(--ease) both;
}
.float-wa:hover {
  transform:scale(1.12) translateY(-3px);
  box-shadow: 0 10px 30px rgba(37,211,102,.5);
}

/* ─── HERO TRUST BAR ────────────────────────── */
.hero-trust {
  display: flex; flex-wrap: wrap; gap:1.2rem;
  margin-top: 1.8rem;
  animation: fadeUp 1s var(--ease) 0.8s both;
}
.trust-item {
  font-size: .65rem; text-transform: uppercase; letter-spacing: .08em;
  color: rgba(255,255,255,.55); display: flex; align-items: center; gap: 6px;
}
.trust-item i { color: var(--gold); }

/* ─── HERO ENQUIRY BOX ──────────────────────── */
.hero-enquiry {
  position: absolute; right: 6%; bottom: 6%;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 16px;
  width: 360px;
  box-shadow: 0 30px 60px rgba(0,0,0,0.4);
  animation: slideInRight 0.9s var(--ease) 0.7s both;
  z-index: 10;
  overflow: hidden;
}
.enquiry-tabs {
  display: flex; background: rgba(0, 0, 0, 0.25);
}
.eq-tab {
  flex: 1; padding: .6rem; font-family: var(--sans);
  font-size: .7rem; text-transform: uppercase; letter-spacing: .1em;
  border: none; background: transparent; cursor: pointer; color: rgba(255,255,255,0.6);
  transition: all .25s;
}
.eq-tab.active { background: rgba(255, 255, 255, 0.15); color: #fff; font-weight: 500; }
.enquiry-form { padding: 1.5rem; display: flex; flex-direction: column; gap: .8rem; }
.eq-field { display: flex; flex-direction: column; gap: .3rem; }
.eq-field label { font-size: .6rem; text-transform: uppercase; letter-spacing: .15em; color: var(--gold); display:flex; align-items:center; gap:5px; }
.eq-field select, .eq-field input {
  background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255,255,255,0.15); padding: .65rem .8rem;
  font-family: var(--sans); font-size: .85rem; color: #fff; outline: none; cursor: pointer;
  border-radius: 6px; transition: all .25s;
}
.eq-field select option { background: var(--ink); color: #fff; }
.eq-field select:focus, .eq-field input:focus { background: rgba(255, 255, 255, 0.15); border-color: var(--gold); }
.eq-search-btn {
  background: var(--gold); color: var(--ink); border: none; border-radius: 8px;
  padding: 1rem; font-family: var(--sans); font-size: .8rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .12em; cursor: pointer;
  transition: all .3s; margin-top: .5rem;
}
.eq-search-btn:hover { background: #fff; color: var(--ink); transform: translateY(-2px); box-shadow: 0 10px 20px rgba(0,0,0,0.2); }

/* ─── STATS STRIP ───────────────────────────── */
.stats-strip {
  background: var(--ink);
  padding: 2rem 6%;
  animation: fadeIn 0.8s var(--ease) both;
}
.stats-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 0;
}
.s-stat {
  display: flex; flex-direction: column; align-items: center;
  padding: 0 2.5rem; gap: .3rem;
}
.s-num { font-family: var(--serif); font-size: 1.8rem; font-weight: 300; color: var(--white); }
.s-lbl { font-size: .62rem; text-transform: uppercase; letter-spacing: .15em; color: #888; }
.s-sep { width: 1px; height: 40px; background: rgba(255,255,255,.12); }

/* ─── SECTION SUB TEXT ───────────────────────── */
.section-sub { font-size:.88rem; color:var(--muted); margin-top:.5rem; font-weight:300; }

/* ─── PROP AMENITIES ─────────────────────────── */
.prop-amenities {
  display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem;
}
.amen {
  font-size: .72rem; background: var(--stone); color: var(--muted);
  padding: .3rem .7rem; border-radius: 2px; display: flex; align-items: center; gap: 5px;
}
.amen i { color: var(--gold); font-size: .65rem; }

/* ─── WHY CHOOSE US ──────────────────────────── */
.why-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: 2rem;
}
.why-card {
  padding: 2rem; border: 1px solid #e8e3dc;
  transition: border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s;
}
.why-card:hover {
  border-color: var(--gold); transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(184,147,83,.1);
}
.why-icon {
  font-size: 1.5rem; color: var(--gold); margin-bottom: 1rem;
  transition: transform .4s var(--ease);
  display: inline-block;
}
.why-card:hover .why-icon { transform: scale(1.15) rotate(-6deg); }

/* ─── GALLERY ────────────────────────────────── */
.gallery-filters {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    margin-bottom: 3rem;
    flex-wrap: wrap;
}

.g-filter {
    background: transparent;
    border: none;
    font-family: var(--sans);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .15em;
    color: var(--muted);
    cursor: pointer;
    padding: .5rem 1rem;
    position: relative;
    transition: color 0.3s;
}

.g-filter::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 1px;
    background: var(--gold);
    transition: all 0.3s;
    transform: translateX(-50%);
}

.g-filter.active { color: var(--ink); font-weight: 500; }
.g-filter.active::after { width: 40px; }
.g-filter:hover { color: var(--ink); }

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.gallery-item {
    position: relative;
    aspect-ratio: 1/1;
    overflow: hidden;
    cursor: pointer;
    background: var(--mist);
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--ease);
}

.gallery-item:hover img {
    transform: scale(1.1);
}

.gi-overlay {
    position: absolute;
    inset: 0;
    background: rgba(26, 26, 26, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s;
    color: var(--white);
    font-size: 1.5rem;
}

.gallery-item:hover .gi-overlay {
    opacity: 1;
}

/* Lightbox */
.g-lightbox {
    display: none;
    position: fixed;
    z-index: 2000;
    inset: 0;
    background: rgba(0, 0, 0, 0.95);
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.glb-close {
    position: absolute;
    top: 2rem;
    right: 2.5rem;
    color: var(--white);
    font-size: 3rem;
    cursor: pointer;
    line-height: 1;
    transition: color 0.3s;
}

.glb-close:hover { color: var(--gold); }

#glbImg {
    max-width: 90%;
    max-height: 85vh;
    object-fit: contain;
    box-shadow: 0 0 50px rgba(0,0,0,0.5);
    animation: zoomIn 0.4s var(--ease);
}

@keyframes zoomIn {
    from { transform: scale(0.9); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}
.why-card h3 { font-family: var(--serif); font-size: 1.2rem; font-weight: 400; color: var(--ink); margin-bottom: .6rem; }
.why-card p { font-size: .85rem; color: var(--muted); line-height: 1.75; font-weight: 300; }


/* ─── REVIEWS SECTION ────────────────────────── */
.reviews-section { background: var(--stone); }

/* Stat Bar */
.reviews-stats-bar {
  display: flex; align-items: center; justify-content: center;
  gap: 0; background: var(--white); border-radius: 60px;
  padding: 1.1rem 2.5rem; width: fit-content; margin: 2rem auto 3rem;
  box-shadow: 0 4px 24px rgba(13,13,13,.07);
  border: 1px solid #e8e3dc;
}
.rsb-item {
  display: flex; align-items: center; gap: .6rem;
  padding: 0 2rem;
}
.rsb-icon { font-size: 1.1rem; color: var(--gold); }
.rsb-icon.gold { color: #f5a623; }
.rsb-val { font-family: var(--serif); font-size: 1.5rem; font-weight: 300; color: var(--ink); }
.rsb-lbl { font-size: .65rem; text-transform: uppercase; letter-spacing: .15em; color: var(--muted); }
.rsb-sep { width: 1px; height: 36px; background: #e8e3dc; }

/* Carousel Wrapper */
.reviews-carousel-wrap {
  display: flex; align-items: center; gap: 1rem;
  position: relative;
  max-width: 780px; margin: 0 auto;
}
.rc-track-outer {
  flex: 1; overflow: hidden;
}
.rc-track {
  display: flex; gap: 0;
  transition: transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Review Card — width set via JS based on outer container */
.rcard {
  background: var(--white);
  border-radius: 24px;
  padding: 2.5rem 2.2rem;
  flex: 0 0 auto; /* width is injected by JS */
  box-sizing: border-box;
  box-shadow: 0 8px 40px rgba(13,13,13,.07);
  border: 1px solid rgba(232,227,220,.8);
  transition: transform .4s var(--ease), box-shadow .4s;
  position: relative;
  overflow: hidden;
}
.rcard:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 55px rgba(13,13,13,.12);
}
.rcard-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 1.2rem;
}
.rcard-quote {
  font-family: var(--serif); font-size: 5rem; line-height: .8;
  color: var(--gold); opacity: .35; font-style: italic;
  user-select: none;
}
.rcard-stars { color: #f5a623; font-size: 1rem; letter-spacing: 2px; }
.rcard-text {
  font-family: var(--serif); font-style: italic; font-size: 1.05rem;
  font-weight: 300; color: var(--ink); line-height: 1.75;
  margin-bottom: 1.8rem;
  overflow-wrap: break-word;
  word-break: break-word;
  white-space: normal;
}
.rcard-footer {
  display: flex; align-items: center; gap: 1rem;
  padding-top: 1.2rem; border-top: 1px solid #ede9e3;
}
.rcard-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
  border: 2px solid var(--mist);
}
.rcard-avatar-initial {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 1.4rem; color: var(--white);
  flex-shrink: 0;
}
.rcard-name { font-size: .92rem; font-weight: 600; color: var(--ink); margin-bottom: .2rem; }
.rcard-meta { font-size: .72rem; color: var(--muted); display: flex; align-items: center; gap: 5px; }
.rcard-meta i { color: #4285f4; font-size: .75rem; }

/* Arrow Buttons */
.rc-arrow {
  width: 48px; height: 48px; border-radius: 50%;
  border: 1px solid #e8e3dc; background: var(--white);
  font-size: 1.8rem; display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; color: var(--ink);
  transition: all .3s var(--ease);
  box-shadow: 0 4px 16px rgba(13,13,13,.06);
  padding-bottom: 2px;
}
.rc-arrow:hover { background: var(--gold); border-color: var(--gold); color: var(--white); transform: scale(1.08); }

/* Dots */
.rc-dots {
  display: flex; align-items: center; justify-content: center;
  gap: .5rem; margin-top: 2rem;
}
.rc-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #d0c8bf; cursor: pointer;
  transition: all .35s var(--ease);
  border: none;
}
.rc-dot.active {
  width: 24px; border-radius: 4px; background: var(--gold);
}

/* Google Maps CTA */
.rc-gmap-btn {
  display: inline-flex; align-items: center; gap: .6rem;
  border: 1px solid #e8e3dc; background: var(--white);
  color: var(--ink); text-decoration: none;
  padding: .75rem 2rem; border-radius: 60px;
  font-size: .78rem; text-transform: uppercase; letter-spacing: .12em;
  font-weight: 500;
  transition: all .3s var(--ease);
  box-shadow: 0 4px 16px rgba(13,13,13,.06);
}
.rc-gmap-btn i { color: #4285f4; font-size: .95rem; }
.rc-gmap-btn:hover { background: var(--ink); color: var(--white); border-color: var(--ink); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(13,13,13,.12); }
.rc-gmap-btn:hover i { color: #fff; }



/* ─── RESPONSIVE ─────────────────────────────── */
@media (max-width:900px) {
  .hero-enquiry { display: none; }
}
@media (max-width:768px) {
  .topbar { justify-content:center; text-align:center; }
  .menu-toggle { display: block; }
  .nav-links {
    display: none; width: 100%; position: absolute; top: 100%; left: 0;
    background: var(--white); flex-direction: column; gap: 0;
    padding: 1rem 0; box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    z-index: 999;
  }
  .nav-links.active { display: flex; animation: fadeUp 0.3s var(--ease) forwards; }
  .nav-links li { width: 100%; text-align: center; }
  .nav-links a { display: block; padding: 1rem; font-size: 1rem; }
  .nav-links a::after { display: none; }
  
  .hero-content h1 { font-size:2.6rem; }
  .hero-bg { background-position: center 30%; } /* Better mobile focal point for buildings */
  .about-grid { grid-template-columns:1fr; }
  .about-img-wrap { order:-1; }
  .about-accent { display:none; }
  .contact-split { grid-template-columns:1fr; }
  .contact-left { order: 1; }
  .contact-right { order: -1; margin-bottom: 3rem; }
  .form-row { grid-template-columns:1fr; }
  .prop-hover-actions { opacity: 1; transform: none; }
  .stats-inner { gap: 1rem; }
  .s-sep { display: none; }
  .s-stat { padding: 0 1rem; }
  .hero-trust { gap: .8rem; }
  .why-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .why-card { padding: 1.5rem 1rem; }
  .why-card h6 { font-size: 1rem; }
  .why-card .section-sub { font-size: 0.8rem; line-height: 1.4; }
  .services-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .service { padding-top: 1rem; }
  .service h3 { font-size: 1.1rem; }
  .service p { font-size: 0.8rem; line-height: 1.5; }
  
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .gallery-filters { gap: 0.8rem; margin-bottom: 2rem; }
  .g-filter { padding: 0.4rem 0.8rem; font-size: 0.7rem; }

  /* Reviews carousel mobile */
  .reviews-section { padding: 4rem 4%; }
  .reviews-stats-bar {
    flex-direction: column; gap: .4rem; padding: 1rem 1.5rem;
    border-radius: 16px; width: 100%; box-sizing: border-box;
  }
  .rsb-item { padding: .25rem 0; justify-content: center; }
  .rsb-sep { display: none; }
  /* Hide arrows on mobile — swipe to navigate */
  .rc-arrow { display: none; }
  .reviews-carousel-wrap { margin: 0; gap: 0; }
  .rc-track-outer { width: 100%; }
  .rcard { padding: 1.8rem 1.4rem; border-radius: 16px; }
  .rcard-quote { font-size: 3.5rem; }
  .rcard-text { font-size: .95rem; line-height: 1.65; margin-bottom: 1.2rem; }
  .rcard-avatar, .rcard-avatar-initial { width: 42px; height: 42px; font-size: 1.1rem; }
  .rcard-name { font-size: .85rem; }
  .rcard-footer { gap: .75rem; }
}
