/* ═══════════════════════════════════════
   ROOT + RESET
═══════════════════════════════════════ */
:root {
  --forest:       #1b3d1e;
  --forest-mid:   #2d5a32;
  --forest-light: #3e7a44;
  --amber:        #f5a623;
  --amber-light:  #ffc355;
  --cream:        #f7f3ec;
  --cream-dark:   #ede8df;
  --charcoal:     #181818;
  --muted:        #6b7a6d;
  --white:        #ffffff;
  --nav-h:        66px;
  --radius:       16px;
  --shadow:       0 4px 24px rgba(27,61,30,0.10);
  --shadow-lg:    0 16px 48px rgba(27,61,30,0.18);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:'Urbanist',sans-serif;background:var(--cream);color:var(--charcoal);overflow-x:hidden;}
img{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}
button{font-family:inherit;cursor:pointer;}

/* ═══════════════════════════════════════
   LOADING SCREEN
═══════════════════════════════════════ */
.loading-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--forest);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity 0.18s ease, visibility 0.18s ease;
}
.loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loading-brand{font-family:'Cormorant Display',serif;font-size:2.8rem;font-weight:700;color:#fff;letter-spacing:-0.01em;}
.loading-logo{width:80px;height:auto;border-radius:12px;margin-bottom:16px;animation:fadeUp 0.6s ease both;}
.loading-brand em{color:var(--amber);font-style:normal;}
.loading-tagline{color:var(--amber);font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;margin-top:6px;}
.loading-bar{width:120px;height:3px;background:rgba(255,255,255,0.15);border-radius:3px;margin-top:28px;overflow:hidden;}
.loading-bar-fill{height:100%;width:0%;background:var(--amber);border-radius:3px;animation:loadFill 0.6s ease-in-out forwards;}
@keyframes loadFill{0%{width:0%}50%{width:70%}100%{width:100%}}

/* ═══════════════════════════════════════
   NAV
═══════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:var(--nav-h);
  padding:0 clamp(16px,5%,60px);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:rgba(27,61,30,0.97);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,0.07);
  transition:background 0.3s;
}
nav.scrolled{background:rgba(27,61,30,1);box-shadow:0 2px 20px rgba(0,0,0,0.2);}
.nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0;}
.nav-logo img{height:36px;width:auto;border-radius:7px;object-fit:contain;}
.nav-brand{display:flex;flex-direction:column;line-height:1;}
.nav-brand .nm{font-weight:700;font-size:1.1rem;color:#fff;letter-spacing:-0.01em;}
.nav-brand .tg{font-size:0.55rem;color:var(--amber);letter-spacing:0.16em;text-transform:uppercase;margin-top:2px;}

.nav-links{display:flex;gap:6px;list-style:none;}
.nav-links li a{
  padding:8px 14px;border-radius:50px;
  color:rgba(255,255,255,0.72);font-size:0.87rem;font-weight:500;
  transition:all 0.2s;display:block;
}
.nav-links li a:hover,.nav-links li a.active{color:#fff;background:rgba(255,255,255,0.1);}

.nav-cta{
  background:var(--amber);color:var(--forest);
  padding:9px 18px;border-radius:50px;
  font-weight:700;font-size:0.82rem;border:none;
  white-space:nowrap;transition:all 0.2s;flex-shrink:0;
  display:flex;align-items:center;gap:6px;
}
.nav-cta:hover{background:var(--amber-light);transform:translateY(-1px);}

/* hamburger */
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;z-index:600;border:none;background:none;}
.hbg span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all 0.3s;}
.hbg.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hbg.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hbg.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* mobile drawer */
.mob-nav{
  display:none;
  position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;z-index:490;
  background:rgba(20,46,23,0.99);
  flex-direction:column;align-items:stretch;
  transform:translateX(100%);transition:transform 0.32s cubic-bezier(0.4,0,0.2,1);
  overflow-y:auto;padding:12px 0 32px;
}
.mob-nav.open{transform:translateX(0);}
.mob-nav a{
  display:block;padding:18px 28px;
  color:rgba(255,255,255,0.82);font-size:1.1rem;font-weight:500;
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition:color 0.2s,background 0.2s;
}
.mob-nav a:hover,.mob-nav a.active{color:var(--amber);background:rgba(255,255,255,0.03);}
.mob-nav .mob-cta{
  margin:24px 28px 0;border-radius:50px;
  background:var(--amber);color:var(--forest);
  font-weight:700;text-align:center;padding:16px;
  font-size:0.95rem;border-bottom:none;
}

/* ═══════════════════════════════════════
   SHARED COMPONENTS
═══════════════════════════════════════ */
.eyebrow{font-size:0.7rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--amber);margin-bottom:8px;}
.section-title{font-family:'Cormorant Display',serif;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:600;color:var(--forest);line-height:1.05; letter-spacing: -0.01em;}
.section-sub{color:var(--muted);margin-top:8px;font-size:0.94rem;line-height:1.7;max-width:520px;}

.btn-primary{
  background:var(--amber);color:var(--forest);
  padding:13px 26px;border-radius:50px;
  font-weight:700;font-size:0.9rem;border:none;
  transition:all 0.25s;display:inline-flex;align-items:center;gap:8px;
}
.btn-primary:hover{background:var(--amber-light);transform:translateY(-2px);box-shadow:0 10px 28px rgba(245,166,35,0.32);}
.btn-outline{
  background:transparent;color:var(--forest);
  padding:12px 24px;border-radius:50px;
  font-weight:600;font-size:0.88rem;
  border:1.5px solid var(--forest);
  transition:all 0.25s;display:inline-flex;align-items:center;gap:8px;
}
.btn-outline:hover{background:var(--forest);color:#fff;}
.btn-ghost-w{
  background:transparent;color:#fff;
  padding:13px 26px;border-radius:50px;
  font-weight:500;font-size:0.9rem;
  border:1.5px solid rgba(255,255,255,0.4);
  transition:all 0.25s;display:inline-flex;align-items:center;gap:8px;
}
.btn-ghost-w:hover{border-color:#fff;background:rgba(255,255,255,0.08);}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 0.6s ease,transform 0.6s ease;}
.reveal.vis{opacity:1;transform:translateY(0);}
.d1{transition-delay:0.08s;}.d2{transition-delay:0.16s;}.d3{transition-delay:0.24s;}.d4{transition-delay:0.32s;}

/* ═══════════════════════════════════════
   ██ HERO CAROUSEL
═══════════════════════════════════════ */
.hero{
  min-height:100svh;
  position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:calc(var(--nav-h) + 24px) clamp(20px,5%,80px) 40px;
  overflow:hidden;
}
.hero-carousel{position:absolute;inset:0;z-index:0;}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;
  transform:scale(1.05);
}
.hero-slide.active{opacity:1;animation:heroZoom 8s ease-in-out forwards;}
@keyframes heroZoom{0%{transform:scale(1.05)}100%{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(155deg,rgba(0,0,0,0.52) 0%,rgba(27,61,30,0.48) 55%,rgba(0,0,0,0.68) 100%);
}
.hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:80px;z-index:2;
  background:linear-gradient(to bottom,transparent,var(--cream));
  pointer-events:none;
}
.hero-content{position:relative;z-index:3;max-width:960px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(245,166,35,0.12);border:1px solid rgba(245,166,35,0.25);
  color:var(--amber-light);padding:6px 16px;border-radius:50px;
  font-size:0.65rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  margin-bottom:20px;animation:fadeUp 0.6s ease both;
  backdrop-filter: blur(4px);
}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--amber);border-radius:50%;flex-shrink:0;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(1.2)}}
.hero h1{
  font-family:'Cormorant Display',serif;
  font-size:clamp(3rem,9vw,6.8rem);
  font-weight:600;color:#fff;
  line-height:0.95;letter-spacing:-0.04em;
  max-width:980px;margin: 0 auto 20px;
  animation:fadeUp 0.8s 0.1s cubic-bezier(0.16, 1, 0.3, 1) both;
  text-shadow: 0 10px 40px rgba(0,0,0,0.4);
}
.hero h1 em{
  color:var(--amber);
  font-style:italic;
  position: relative;
  display: inline-block;
}
.hero-sub{
  color:rgba(255,255,255,0.85);
  font-size:clamp(0.9rem,1.8vw,1.05rem);
  max-width:540px;line-height:1.65;margin:0 auto 32px;
  animation:fadeUp 0.8s 0.2s cubic-bezier(0.16, 1, 0.3, 1) both;
  font-weight: 400;
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;animation:fadeUp 0.8s 0.3s cubic-bezier(0.16, 1, 0.3, 1) both;}
.hero-stats{
  position:relative;z-index:2;
  display:flex;gap:clamp(24px,5vw,48px);flex-wrap:wrap;justify-content:center;
  margin-top:40px;animation:fadeUp 0.8s 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.stat .n{font-family:'Cormorant Display',serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:600;color:var(--amber);display:block; line-height: 1;}
.stat .l{color:rgba(255,255,255,0.6);font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* Carousel indicators */
.hero-indicators{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;gap:8px;
}
.hero-dot{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.35);
  border:none;cursor:pointer;transition:all 0.3s;padding:0;
}
.hero-dot.active{background:var(--amber);width:24px;border-radius:4px;}

/* ═══════════════════════════════════════
   DESTINATION CARDS
═══════════════════════════════════════ */
.dest-section{padding:clamp(50px,7vw,80px) clamp(20px,5%,60px);}
.dest-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr));
  gap:16px;margin-top:32px;
}
.dest-card{
  border-radius:18px;overflow:hidden;
  aspect-ratio:3/4;position:relative;cursor:pointer;
  transition:transform 0.3s;
}
.dest-card:hover{transform:translateY(-4px);}
.dest-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.dest-card:hover img{transform:scale(1.06);}
.dest-card-body{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,35,18,0.92) 0%,rgba(0,0,0,0.1) 55%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px 18px;
}
.dest-card-body h3{font-family:'Playfair Display',serif;font-size:1.15rem;color:#fff;font-weight:700;}
.dest-card-body p{color:rgba(255,255,255,0.68);font-size:0.75rem;margin-top:3px;}
.dest-card-body .arrow{
  position:absolute;top:14px;right:14px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(245,166,35,0.2);border:1px solid rgba(245,166,35,0.4);
  display:flex;align-items:center;justify-content:center;
  color:var(--amber);font-size:0.85rem;
  opacity:0;transform:scale(0.8);transition:all 0.25s;
}
.dest-card:hover .arrow{opacity:1;transform:scale(1);}

/* ═══════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════ */
.testimonials-section{
  background:var(--cream-dark);
  padding:clamp(50px,7vw,80px) clamp(20px,5%,60px);
}
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));
  gap:20px;margin-top:32px;
}
.testimonial-card{
  background:#fff;border-radius:var(--radius);padding:28px 24px;
  box-shadow:var(--shadow);position:relative;
  transition:transform 0.3s;
}
.testimonial-card:hover{transform:translateY(-3px);}
.testimonial-card::before{
  content:'"';position:absolute;top:16px;right:24px;
  font-family:'Playfair Display',serif;font-size:4rem;color:var(--amber);opacity:0.15;line-height:1;
}
.testimonial-stars{color:var(--amber);font-size:0.85rem;letter-spacing:2px;margin-bottom:12px;}
.testimonial-text{color:var(--muted);font-size:0.9rem;line-height:1.7;margin-bottom:16px;font-style:italic;}
.testimonial-author{display:flex;align-items:center;gap:10px;}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--forest);color:var(--amber);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:0.85rem;
}
.testimonial-name{font-weight:600;font-size:0.88rem;color:var(--forest);}
.testimonial-loc{font-size:0.72rem;color:var(--muted);}

/* ═══════════════════════════════════════
   WHY SECTION
═══════════════════════════════════════ */
.why-home{background:var(--forest);padding:clamp(50px,7vw,80px) clamp(20px,5%,60px);}
.why-home .section-title{color:#fff;}
.why-home .section-sub{color:rgba(255,255,255,0.58);}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(220px,100%),1fr));gap:20px;margin-top:36px;}
.why-card{padding:26px 24px;border-radius:16px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.09);transition:all 0.25s;}
.why-card:hover{background:rgba(255,255,255,0.09);transform:translateY(-3px);}
.why-icon{width:48px;height:48px;border-radius:14px;background:rgba(245,166,35,0.12);border:1px solid rgba(245,166,35,0.25);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:16px;}
.why-card h3{font-size:0.98rem;font-weight:600;color:#fff;margin-bottom:8px;}
.why-card p{color:rgba(255,255,255,0.58);font-size:0.85rem;line-height:1.65;}

/* HOME CTA STRIP */
.cta-strip{
  padding:clamp(50px,7vw,80px) clamp(20px,5%,60px);
  background:var(--cream-dark);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:28px;
}
.cta-strip h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--forest);max-width:480px;line-height:1.2;}
.cta-strip p{color:var(--muted);margin-top:8px;font-size:0.93rem;max-width:400px;line-height:1.65;}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0;}

/* ═══════════════════════════════════════
   ██ PROPERTIES PAGE
═══════════════════════════════════════ */
.props-page{padding-top:var(--nav-h);}
.page-banner{
  background:var(--forest);
  padding:clamp(36px,6vw,60px) clamp(20px,5%,60px);
  color:#fff;
}
.page-banner h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3.4rem);font-weight:900;line-height:1.08;margin-bottom:10px;}
.page-banner h1 em{color:var(--amber);font-style:normal;}
.page-banner p{color:rgba(255,255,255,0.65);font-size:0.95rem;max-width:480px;line-height:1.65;}

/* Filter bar */
.filter-bar{
  position:sticky;top:var(--nav-h);z-index:100;
  background:rgba(247,243,236,0.97);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--cream-dark);
  padding:0 clamp(16px,5%,60px);
}
.filter-bar-inner{
  display:flex;align-items:center;gap:12px;
  overflow-x:auto;padding:14px 0;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.filter-bar-inner::-webkit-scrollbar{display:none;}

.filter-label{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap;flex-shrink:0;}
.filter-divider{width:1px;height:24px;background:var(--cream-dark);flex-shrink:0;}

.chip{
  flex-shrink:0;padding:8px 16px;border-radius:50px;
  font-size:0.82rem;font-weight:500;cursor:pointer;
  border:1.5px solid var(--cream-dark);
  background:#fff;color:var(--muted);
  transition:all 0.2s;white-space:nowrap;
  display:flex;align-items:center;gap:5px;
}
.chip:hover{border-color:var(--forest-light);color:var(--forest);}
.chip.active{background:var(--forest);color:#fff;border-color:var(--forest);}
.chip .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0;}

/* Type filter */
.type-bar{
  background:#fff;border-bottom:1px solid var(--cream-dark);
  padding:0 clamp(16px,5%,60px);
}
.type-bar-inner{
  display:flex;gap:8px;overflow-x:auto;padding:10px 0;
  scrollbar-width:none;
}
.type-bar-inner::-webkit-scrollbar{display:none;}
.type-chip{
  flex-shrink:0;padding:6px 14px;border-radius:50px;
  font-size:0.78rem;font-weight:500;cursor:pointer;
  border:1.5px solid var(--cream-dark);
  background:var(--cream);color:var(--muted);
  transition:all 0.2s;white-space:nowrap;
}
.type-chip:hover{border-color:var(--amber);color:var(--charcoal);}
.type-chip.active{background:var(--amber);color:var(--forest);border-color:var(--amber);font-weight:700;}

/* Results meta */
.results-meta{
  padding:16px clamp(16px,5%,60px) 0;
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
}
.results-count{font-size:0.82rem;color:var(--muted);}
.results-count strong{color:var(--charcoal);}

/* PROPERTY GRID */
.props-grid-wrap{padding:20px clamp(16px,5%,60px) 60px;}
.props-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));
  gap:22px;
}

/* PROPERTY CARD */
.prop-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform 0.3s ease,box-shadow 0.3s ease;
  display:flex;flex-direction:column;
  cursor:pointer;min-width:0;
}
.prop-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.card-img{height:220px;position:relative;overflow:hidden;flex-shrink:0;aspect-ratio:4/3;}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.prop-card:hover .card-img img{transform:scale(1.06);}

.card-badge{
  position:absolute;top:12px;left:12px;
  padding:4px 11px;border-radius:50px;
  font-size:0.68rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  backdrop-filter:blur(8px);
}
.badge-std{background:rgba(27,61,30,0.88);color:#fff;}
.badge-budget{background:rgba(245,166,35,0.92);color:var(--forest);}
.badge-premium{background:rgba(10,10,10,0.80);color:var(--amber);}
.badge-luxury{background:linear-gradient(135deg,#b8860b,#d4a017);color:#fff;}

.card-body{padding:18px;flex:1;display:flex;flex-direction:column;min-width:0;}
.card-loc{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;font-weight:600;margin-bottom:5px;display:flex;align-items:center;gap:4px;}
.card-name{
  font-family:'Cormorant Display',serif;font-size:1.08rem;font-weight:700;color:var(--forest);margin-bottom:10px;line-height:1.3;
  overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.card-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;}
.tag{padding:3px 10px;border-radius:50px;font-size:0.68rem;font-weight:500;background:var(--cream);color:var(--forest-mid);border:1px solid var(--cream-dark);max-width:100%;overflow-wrap:anywhere;}
.card-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-top:auto;padding-top:14px;border-top:1px solid var(--cream-dark);flex-wrap:wrap;}
.card-footer > *{min-width:0;}
.card-price-block{flex:1 1 150px;min-width:0;}
.card-price-main{font-family:'Cormorant Display',serif;font-size:1.2rem;font-weight:700;color:var(--forest);line-height:1.05;overflow-wrap:anywhere;}
.card-price-main span{font-size:0.78rem;font-weight:400;color:var(--muted);font-family:'Urbanist',sans-serif;}
.card-price-old{font-size:0.74rem;color:#bbb;text-decoration:line-through;}
.book-btn{
  background:var(--forest);color:#fff;border:none;
  padding:10px 18px;border-radius:50px;
  font-size:0.8rem;font-weight:700;
  transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap;flex-shrink:0;text-align:center;
}
.book-btn:hover{background:var(--forest-light);}

/* No results */
.no-results{
  grid-column:1/-1;text-align:center;padding:80px 20px;
  display:none;
}
.no-results.show{display:block;}
.no-results .icon{font-size:3rem;margin-bottom:16px;}
.no-results h3{font-family:'Playfair Display',serif;color:var(--forest);font-size:1.5rem;margin-bottom:8px;}
.no-results p{color:var(--muted);margin-bottom:20px;}

/* ═══════════════════════════════════════
   ██ PROPERTY DETAIL PAGE
═══════════════════════════════════════ */
.detail-page{padding-top:var(--nav-h);}
.detail-container{max-width:1100px;margin:0 auto;padding:clamp(24px,4vw,40px) clamp(16px,5%,60px);}
.detail-back{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--muted);font-size:0.85rem;font-weight:500;
  margin-bottom:20px;transition:color 0.2s;cursor:pointer;
  background:none;border:none;
}
.detail-back:hover{color:var(--forest);}

/* Gallery */
.detail-gallery{
  border-radius:20px;overflow:hidden;margin-bottom:32px;
  position:relative;aspect-ratio:16/9;background:var(--cream-dark);
}
.detail-gallery img,
.detail-gallery iframe,
.detail-gallery video{
  width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;
  opacity:0;transition:opacity 0.5s ease;
  border:0;
}
.detail-gallery img.active,
.detail-gallery iframe.active,
.detail-gallery video.active{opacity:1;}
.gallery-nav{
  position:absolute;top:50%;z-index:2;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,0.9);border:none;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:var(--forest);cursor:pointer;
  transition:all 0.2s;box-shadow:var(--shadow);
  transform:translateY(-50%);
}
.gallery-nav:hover{background:#fff;transform:translateY(-50%) scale(1.08);}
.gallery-nav.prev{left:16px;}
.gallery-nav.next{right:16px;}
.gallery-dots{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;gap:6px;
}
.gallery-dots button{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.5);
  border:none;cursor:pointer;transition:all 0.3s;padding:0;
}
.gallery-dots button.active{background:#fff;width:20px;border-radius:4px;}

/* Detail content */
.detail-layout{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(24px,4vw,48px);align-items:start;}
.detail-badge{
  display:inline-block;padding:4px 14px;border-radius:50px;
  font-size:0.7rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  margin-bottom:12px;
}
.detail-location{font-size:0.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:4px;}
.detail-name{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;color:var(--forest);line-height:1.15;margin-bottom:16px;}
.detail-desc{color:var(--muted);line-height:1.75;font-size:0.95rem;margin-bottom:24px;}
.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px;}
.detail-tags .tag{max-width:100%;}

/* Amenities */
.detail-amenities h3{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--forest);margin-bottom:14px;}
.amenities-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:24px;}
.amenity-item{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:12px;
  background:var(--cream);font-size:0.85rem;color:var(--forest-mid);
}
.amenity-item::before{content:'✓';color:var(--amber);font-weight:700;}

.detail-sections{display:grid;gap:14px;margin-top:26px;}
.detail-info-section{
  padding:18px;border:1px solid var(--cream-dark);border-radius:14px;
  background:rgba(255,255,255,0.62);
}
.detail-info-section h3{
  font-family:'Playfair Display',serif;font-size:1.08rem;color:var(--forest);margin-bottom:10px;
}
.detail-info-section ul{
  display:grid;gap:8px;margin:0;padding-left:18px;
  color:var(--muted);line-height:1.55;font-size:0.9rem;
}
.detail-info-section li::marker{color:var(--amber);}

/* Booking sidebar */
.detail-sidebar{
  position:sticky;top:calc(var(--nav-h) + 20px);
  background:#fff;border-radius:20px;padding:28px;
  box-shadow:var(--shadow-lg);
}
.sidebar-price{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--forest);margin-bottom:4px;}
.sidebar-price span{font-size:0.9rem;font-weight:400;color:var(--muted);font-family:'DM Sans',sans-serif;}
.sidebar-price-old{font-size:0.85rem;color:#bbb;text-decoration:line-through;margin-bottom:20px;display:block;}
.sidebar-divider{height:1px;background:var(--cream-dark);margin:20px 0;}
.sidebar-wa{
  width:100%;padding:16px;border-radius:50px;
  background:#25D366;color:#fff;border:none;
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.95rem;
  cursor:pointer;transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.sidebar-wa:hover{background:#1fbb5a;transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,0.3);}
.sidebar-note{text-align:center;color:var(--muted);font-size:0.74rem;margin-top:10px;}

/* ═══════════════════════════════════════
   ██ ABOUT PAGE
═══════════════════════════════════════ */
.about-page{padding-top:var(--nav-h);}
.about-hero{
  background:
    linear-gradient(180deg,rgba(0,0,0,0.45) 0%,rgba(27,61,30,0.55) 100%),
    url('https://images.unsplash.com/photo-1470770903676-69b98201ea1c?w=1600&q=80') center/cover no-repeat;
  min-height:60svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:clamp(40px,8vw,100px) clamp(20px,8%,120px);
}
.about-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,6vw,4.5rem);color:#fff;font-weight:900;line-height:1.08;margin-bottom:16px;}
.about-hero p{color:rgba(255,255,255,0.72);font-size:clamp(0.95rem,2vw,1.12rem);max-width:520px;line-height:1.7;}

.about-section{padding:clamp(50px,7vw,80px) clamp(20px,8%,120px);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,72px);align-items:center;}
.about-grid.flip{direction:rtl;}
.about-grid.flip>*{direction:ltr;}
.about-img{border-radius:20px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-lg);}
.about-img img{width:100%;height:100%;object-fit:cover;}
.about-text h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--forest);margin-bottom:16px;line-height:1.15;}
.about-text p{color:var(--muted);line-height:1.75;font-size:0.95rem;margin-bottom:14px;}

.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr));gap:20px;margin-top:16px;}
.value-card{padding:24px;border-radius:16px;background:var(--cream-dark);border:1px solid rgba(27,61,30,0.08);}
.value-card h3{font-size:0.95rem;font-weight:700;color:var(--forest);margin-bottom:8px;display:flex;align-items:center;gap:8px;}
.value-card p{font-size:0.84rem;color:var(--muted);line-height:1.65;}

.about-cta{
  background:var(--forest);padding:clamp(50px,7vw,80px) clamp(20px,8%,120px);
  text-align:center;
}
.about-cta h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,4vw,3rem);color:#fff;margin-bottom:14px;}
.about-cta p{color:rgba(255,255,255,0.62);font-size:0.95rem;max-width:480px;margin:0 auto 28px;line-height:1.7;}

/* ═══════════════════════════════════════
   ██ CONTACT PAGE
═══════════════════════════════════════ */
.contact-page{padding-top:var(--nav-h);}
.contact-hero{
  background:var(--forest);
  padding:clamp(40px,7vw,80px) clamp(20px,8%,120px);
  color:#fff;
}
.contact-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3.2rem);font-weight:900;margin-bottom:12px;line-height:1.1;}
.contact-hero p{color:rgba(255,255,255,0.62);font-size:0.95rem;max-width:440px;line-height:1.7;}

.contact-body{padding:clamp(40px,6vw,70px) clamp(20px,8%,120px);}
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(32px,5vw,64px);align-items:start;}

.contact-cards{display:flex;flex-direction:column;gap:16px;}
.contact-card{
  padding:22px;border-radius:16px;
  background:#fff;box-shadow:var(--shadow);
  display:flex;align-items:flex-start;gap:14px;
  transition:transform 0.2s;
}
.contact-card:hover{transform:translateY(-2px);}
.cc-icon{width:44px;height:44px;border-radius:12px;background:var(--cream);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.cc-text label{display:block;font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:4px;}
.cc-text span{font-weight:600;color:var(--forest);font-size:0.92rem;}
.cc-text a{color:var(--forest-light);text-decoration:none;transition:color 0.2s;}
.cc-text a:hover{color:var(--amber);}

.wa-card{
  padding:22px;border-radius:16px;
  background:linear-gradient(135deg,#1fae5a,#25D366);
  color:#fff;display:flex;align-items:center;gap:14px;
  text-decoration:none;transition:transform 0.2s,box-shadow 0.2s;
  box-shadow:0 6px 24px rgba(37,211,102,0.25);
}
.wa-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(37,211,102,0.35);}
.wa-card svg{flex-shrink:0;}
.wa-card div{flex:1;}
.wa-card .wt{font-weight:700;font-size:1rem;margin-bottom:2px;}
.wa-card .ws{font-size:0.8rem;opacity:0.82;}

/* Enquiry form */
.enquiry-form{background:#fff;border-radius:20px;padding:clamp(24px,4vw,36px);box-shadow:var(--shadow);}
.enquiry-form h2{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--forest);margin-bottom:6px;}
.enquiry-form p{color:var(--muted);font-size:0.86rem;margin-bottom:24px;}
.form-row{margin-bottom:16px;}
.form-row label{display:block;font-size:0.74rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--forest);margin-bottom:6px;}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:12px 16px;border-radius:12px;
  border:1.5px solid var(--cream-dark);background:var(--cream);
  font-family:'DM Sans',sans-serif;font-size:0.92rem;color:var(--charcoal);
  outline:none;transition:border 0.2s,background 0.2s;-webkit-appearance:none;appearance:none;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--forest-mid);background:#fff;}
.form-row textarea{resize:vertical;min-height:100px;}
.form-duo{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
/* ═══════════════════════════════════════
   FOOTER
   Redesigned for a richer, premium feel
   ═══════════════════════════════════════ */
footer{
  background: #0d1a0e;
  color:rgba(255,255,255,0.55);
  padding:clamp(60px,8vw,100px) clamp(20px,5%,60px) 40px;
  position: relative;
  overflow: hidden;
}
footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}
.footer-inner{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr 0.8fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  margin-bottom: 60px;
}
.footer-brand .fn{font-weight:700;color:#fff;font-size:1.3rem;font-family:'Playfair Display',serif;display:block;}
.footer-brand .ft{font-size:0.65rem;color:var(--amber);letter-spacing:0.2em;text-transform:uppercase;margin-top:2px;display:block;}
.footer-logo-img { height: 56px; width: auto; border-radius: 10px; object-fit: contain; margin-bottom: 16px; }
.footer-brand p{font-size:0.88rem;color:rgba(255,255,255,0.45);margin-top:16px;max-width:280px;line-height:1.7;}

.footer-col h4 {
  color: #fff;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 24px;
  font-weight: 700;
}
.footer-links{display:flex; flex-direction: column; gap: 14px;}
.footer-links a{
  color:rgba(255,255,255,0.55);
  font-size:0.92rem;
  transition:all 0.3s;
  width: fit-content;
}
.footer-links a:hover{color:var(--amber); transform: translateX(4px);}

.footer-newsletter h4 { color: #fff; font-size: 0.85rem; margin-bottom: 16px; }
.newsletter-form {
  display: flex;
  gap: 8px;
  margin-top: 16px;
  background: rgba(255,255,255,0.05);
  padding: 6px;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,0.1);
}
.newsletter-form input {
  background: transparent;
  border: none;
  padding: 8px 16px;
  color: #fff;
  font-size: 0.85rem;
  width: 100%;
  outline: none;
}
.newsletter-form button {
  background: var(--amber);
  color: var(--forest);
  border: none;
  padding: 8px 16px;
  border-radius: 50px;
  font-weight: 700;
  font-size: 0.8rem;
  transition: all 0.2s;
}
.newsletter-form button:hover { background: var(--amber-light); transform: scale(1.05); }

.footer-socials{display:flex;gap:12px; margin-top: 24px;}
.social-btn{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,0.05);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.65);font-size:1rem;transition:all 0.3s; border: 1px solid rgba(255,255,255,0.05);}
.social-btn:hover{background:var(--forest-light);color:#fff; border-color: var(--amber); transform: translateY(-3px);}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.05);
  padding-top:32px;
  font-size:0.8rem;
  color: rgba(255,255,255,0.35);
  display:flex;justify-content:space-between;align-items: center;
  flex-wrap:wrap;gap:16px;
}
.footer-bottom-links { display: flex; gap: 24px; }
.footer-bottom-links a { color: inherit; transition: color 0.2s; }
.footer-bottom-links a:hover { color: #fff; }

/* ═══════════════════════════════════════
   BOOKING MODAL
═══════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;z-index:999;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:16px;}
.modal-overlay.open{display:flex;}
.modal{background:#fff;border-radius:24px;width:100%;max-width:480px;padding:clamp(22px,5vw,32px);position:relative;animation:modalIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both;max-height:92svh;overflow-y:auto;}
@keyframes modalIn{from{opacity:0;transform:scale(0.88) translateY(28px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:var(--cream);border:none;cursor:pointer;font-size:0.95rem;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}
.modal-close:hover{background:var(--cream-dark);transform:rotate(90deg);}
.modal-prop-name{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--forest);margin-bottom:4px;}
.modal-prop-loc{font-size:0.8rem;color:var(--muted);margin-bottom:22px;}
.modal-submit{
  width:100%;padding:14px;border-radius:50px;
  background:#25D366;color:#fff;border:none;
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.95rem;
  cursor:pointer;margin-top:8px;transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.modal-submit:hover{background:#1fbb5a;}
.modal-note{text-align:center;color:var(--muted);font-size:0.74rem;margin-top:10px;}
.modal-grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1080px){
  .footer-inner{grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;}
}
@media(max-width:980px){
  .detail-layout{grid-template-columns:1fr;}
  .detail-sidebar{position:relative;top:0;}
}
@media(max-width:860px){
  .nav-links,.nav-cta{display:none;}
  .hbg{display:flex;}
  .mob-nav{display:flex;}
  .about-grid{grid-template-columns:1fr;gap:28px;}
  .about-grid.flip{direction:ltr;}
  .about-img{aspect-ratio:16/9;}
  .contact-layout{grid-template-columns:1fr;}
  .page-banner{padding-inline:20px;}
  .filter-bar,.type-bar,.results-meta,.props-grid-wrap{padding-left:20px;padding-right:20px;}
}
@media(max-width:640px){
  .hero-btns{flex-direction:column;align-items:center;}
  .hero-btns a,.hero-btns button{width:min(280px,85vw);justify-content:center;}
  .props-grid{grid-template-columns:1fr;}
  .card-img{height:auto;min-height:220px;}
  .card-footer{align-items:stretch;}
  .card-price-block,.book-btn{width:100%;}
  .dest-grid{grid-template-columns:repeat(2,1fr);}
  .cta-strip{flex-direction:column;}
  .footer-inner{grid-template-columns:1fr;gap:22px;}
  .footer-links{gap:16px;}
  .footer-bottom{flex-direction:column;gap:10px;}
  .footer-bottom-links{flex-wrap:wrap;justify-content:center;gap:14px;}
  .newsletter-form{flex-direction:column;border-radius:18px;}
  .newsletter-form button{width:100%;}
  .form-duo{grid-template-columns:1fr;}
  .amenities-grid{grid-template-columns:1fr;}
  .modal-grid-two{grid-template-columns:1fr;}
  .modal-submit,.sidebar-wa,.book-btn{min-height:48px;}
  .detail-gallery{aspect-ratio:4/3;}
  .gallery-nav{width:38px;height:38px;}
}
@media(max-width:640px){
  footer{padding:34px 20px 22px;}
  .footer-inner{gap:16px;margin-bottom:26px;}
  .footer-logo-img{height:42px;margin-bottom:10px;}
  .footer-brand p{margin-top:10px;font-size:0.82rem;line-height:1.5;}
  .footer-col h4{margin-bottom:12px;font-size:0.7rem;}
  .footer-links{gap:9px;}
  .footer-links a{font-size:0.84rem;}
  .footer-socials{margin-top:14px;gap:9px;}
  .social-btn{width:34px;height:34px;border-radius:10px;}
  .footer-bottom{padding-top:18px;font-size:0.74rem;}
  .footer-bottom-links{gap:10px;}
}
@media(max-width:380px){
  .dest-grid{grid-template-columns:1fr 1fr;}
  .dest-card{aspect-ratio:2/3;}
  .page-banner h1{font-size:1.9rem;}
  .card-body{padding:16px;}
  .book-btn{padding-inline:14px;font-size:0.78rem;}
}
/* ═══════════════════════════════════════
   SKELETON LOADING
   Provides a premium feel while waiting for APIs
   especially during Render cold starts.
═══════════════════════════════════════ */
.skeleton {
  background: #eee;
  background: linear-gradient(110deg, #ececec 8%, #f5f5f5 18%, #ececec 33%);
  background-size: 200% 100%;
  animation: shine 1.5s linear infinite;
  border-radius: var(--radius);
}
@keyframes shine {
  to { background-position-x: -200%; }
}

.sk-card { height: 380px; width: 100%; border-radius: 18px; }
.sk-dest { height: 100%; width: 100%; border-radius: 18px; aspect-ratio: 3/4; }

/* Hide skeletons once data arrives */
.hide-after-load { display: none !important; }

/* ═══════════════════════════════════════
   FAQ SECTION
═══════════════════════════════════════ */
.faq-section {
  padding: 100px 5%;
  background: #fff;
}
.faq-container {
  max-width: 800px;
  margin: 40px auto 0;
}
.faq-item {
  border-bottom: 1px solid #eee;
  padding: 15px 0;
}
.faq-question {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--dark);
  padding: 15px 0;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: color 0.3s;
}
.faq-question:hover {
  color: var(--amber);
}
.faq-icon {
  font-size: 1.5rem;
  font-weight: 300;
  transition: transform 0.4s;
  color: var(--muted);
}
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.4s ease;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.6;
}
.faq-item.open .faq-answer {
  max-height: 300px; /* Adjust based on content */
  padding-bottom: 20px;
}
.faq-item.open .faq-icon {
  transform: rotate(45deg);
  color: var(--amber);
}
@media (max-width: 768px) {
  .faq-section { padding: 60px 20px; }
  .faq-question { font-size: 1rem; }
}
