/* ═══════════════════════════════════════════
   Adderley 43 — Design System
   navy=#20205C  oak=#A68A64  mist=#FCFAFA  obsidian=#1A1A1B
   ═══════════════════════════════════════════ */

:root {
  --navy:     #20205C;
  --oak:      #A68A64;
  --mist:     #FCFAFA;
  --obsidian: #1A1A1B;
  --navy-60:  rgba(32,32,92,0.6);
  --navy-95:  rgba(32,32,92,0.95);
  --oak-10:   rgba(166,138,100,0.1);
  --oak-30:   rgba(166,138,100,0.3);
  --font-heading: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;
  --radius: 0.75rem;
  --transition: 0.3s ease;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); font-size:1rem; line-height:1.6; color:var(--obsidian); background:var(--mist); }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font-family:var(--font-body); }
main { min-height:60vh; }

h1,h2,h3,h4,h5 { font-family:var(--font-heading); color:var(--navy); line-height:1.15; }

/* ── Navbar ── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:var(--navy-60); backdrop-filter:blur(8px);
  transition:background var(--transition), border-color var(--transition);
  border-bottom:1px solid transparent;
}
.navbar.scrolled {
  background:var(--navy-95);
  border-bottom-color:rgba(252,250,250,0.1);
  box-shadow:0 2px 20px rgba(0,0,0,0.15);
}
.nav-inner {
  max-width:1280px; margin:0 auto; padding:0 1.5rem;
  display:flex; align-items:center; justify-content:space-between; height:5rem;
}
.nav-logo .logo-img { height:3.5rem; width:auto; object-fit:contain; }
.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-link {
  font-family:var(--font-body); font-size:0.8rem; font-weight:600;
  color:var(--mist); text-transform:uppercase; letter-spacing:0.1em;
  transition:color var(--transition);
}
.nav-link:hover,.nav-link.active { color:var(--oak); }
.btn-booknow {
  font-family:var(--font-body); font-size:0.8rem; font-weight:600;
  color:var(--mist); background:transparent; border:2px solid var(--oak);
  padding:0.6rem 1.5rem; border-radius:50px; letter-spacing:0.06em;
  transition:background var(--transition), color var(--transition);
  animation:oakPulse 3s ease-in-out infinite;
}
.btn-booknow:hover { background:var(--oak); color:var(--mist); }
@keyframes oakPulse {
  0%,100% { box-shadow:0 0 0 0 rgba(166,138,100,0.3); }
  50%      { box-shadow:0 0 0 8px rgba(166,138,100,0); }
}
.nav-toggle {
  display:none; flex-direction:column; gap:5px; padding:6px;
  background:none; border:none;
}
.nav-toggle span { display:block; width:24px; height:2px; background:var(--mist); transition:var(--transition); border-radius:2px; }
.nav-mobile {
  display:none; flex-direction:column; gap:1.25rem;
  padding:1.5rem; border-top:1px solid rgba(252,250,250,0.1); background:var(--navy);
}
.nav-mobile.open { display:flex; }
.nav-mobile-link { font-size:0.85rem; font-weight:600; color:var(--mist); text-transform:uppercase; letter-spacing:0.08em; transition:color var(--transition); }
.nav-mobile-link:hover { color:var(--oak); }
.btn-booknow-mobile {
  display:block; text-align:center; background:var(--oak); color:var(--mist);
  padding:0.75rem; border-radius:50px; font-weight:600; font-size:0.85rem;
  border:2px solid var(--oak); transition:background var(--transition);
}
.btn-booknow-mobile:hover { background:transparent; }

/* Floating CTA */
.floating-book {
  position:fixed; bottom:2rem; left:2rem; z-index:90;
  background:var(--navy); color:var(--mist); border:2px solid var(--oak);
  padding:0.875rem 1.75rem; border-radius:50px; font-weight:600; font-size:0.85rem;
  letter-spacing:0.05em; box-shadow:0 8px 32px rgba(0,0,0,0.25);
  transition:background var(--transition), transform var(--transition);
  animation:oakPulse 3s ease-in-out infinite;
  display:none;
}
.floating-book.visible { display:flex; align-items:center; gap:0.5rem; }
.floating-book:hover { background:var(--oak); transform:translateY(-2px); }
@media(max-width:767px){ .floating-book { display:none !important; } }

/* ── Utility Classes ── */
.container { max-width:1280px; margin:0 auto; padding:0 1.5rem; }
.container-md { max-width:900px; margin:0 auto; padding:0 1.5rem; }
.container-sm { max-width:640px; margin:0 auto; padding:0 1.5rem; }
.section { padding:5rem 1.5rem; }
.section-sm { padding:3rem 1.5rem; }
.text-oak { color:var(--oak); }
.text-navy { color:var(--navy); }
.text-mist { color:var(--mist); }
.bg-navy { background:var(--navy); }
.bg-mist { background:var(--mist); }
.overline { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.2em; color:var(--oak); margin-bottom:0.75rem; display:block; }
.glass-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(32,32,92,0.5), rgba(32,32,92,0.7)); }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:0.5rem;
  font-family:var(--font-body); font-weight:600; border-radius:50px;
  letter-spacing:0.06em; transition:all var(--transition); cursor:pointer;
  font-size:0.875rem; padding:0.875rem 2rem; border:2px solid transparent;
}
.btn-navy { background:var(--navy); color:var(--mist); border-color:var(--oak); }
.btn-navy:hover { background:var(--oak); border-color:var(--oak); }
.btn-oak  { background:var(--oak); color:var(--mist); border-color:var(--oak); }
.btn-oak:hover { background:var(--navy); border-color:var(--navy); }
.btn-outline { background:transparent; color:var(--mist); border-color:var(--mist); }
.btn-outline:hover { background:var(--mist); color:var(--navy); }
.btn-sm { padding:0.5rem 1.25rem; font-size:0.8rem; }
.btn-lg { padding:1rem 2.5rem; font-size:1rem; }

/* ── Hero ── */
.hero {
  position:relative; height:100vh; min-height:600px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.hero-slide {
  position:absolute; inset:0; transition:opacity 1.5s ease;
  opacity:0;
}
.hero-slide.active { opacity:1; }
.hero-slide img { width:100%; height:100%; object-fit:cover; }
.hero-content {
  position:relative; z-index:10; text-align:center; padding:0 1.5rem;
  max-width:900px;
}
.hero-content .overline { color:var(--oak); }
.hero-title { font-size:clamp(2.5rem,8vw,5.5rem); font-weight:300; color:var(--mist); margin-bottom:1.5rem; }
.hero-title em { font-style:italic; }
.hero-subtitle { font-size:clamp(1rem,2.5vw,1.25rem); color:rgba(252,250,250,0.8); max-width:640px; margin:0 auto 2.5rem; }
.hero-actions { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }
.hero-link {
  font-size:0.875rem; color:var(--mist); letter-spacing:0.08em;
  border-bottom:1px solid rgba(252,250,250,0.4); padding-bottom:2px;
  transition:color var(--transition), border-color var(--transition);
}
.hero-link:hover { color:var(--oak); border-color:var(--oak); }

/* Hero scroll indicator */
.hero-scroll {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%); z-index:10;
  animation:bounce 2s infinite;
}
.hero-scroll svg { color:rgba(252,250,250,0.5); }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* Hero dots */
.hero-dots {
  position:absolute; bottom:2.5rem; right:2.5rem; z-index:10;
  display:flex; gap:0.5rem;
}
.hero-dot {
  width:8px; height:8px; border-radius:50px; background:rgba(252,250,250,0.4);
  border:none; transition:all var(--transition); cursor:pointer;
}
.hero-dot.active { width:24px; background:var(--oak); }

/* ── Stats Bar ── */
.stats-bar { background:var(--navy); padding:2rem 1.5rem; }
.stats-grid { max-width:900px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; text-align:center; }
.stat-num { font-family:var(--font-heading); font-size:2.25rem; color:var(--oak); }
.stat-label { font-size:0.65rem; font-weight:600; color:rgba(252,250,250,0.5); text-transform:uppercase; letter-spacing:0.15em; margin-top:0.25rem; }

/* ── Two-col sections ── */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.two-col.reverse { direction:rtl; }
.two-col.reverse > * { direction:ltr; }
.img-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; }
.img-grid-wide { grid-column:span 2; }
.img-card { overflow:hidden; border-radius:var(--radius); }
.img-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.img-card:hover img { transform:scale(1.05); }

/* ── Section Headers ── */
.section-header { text-align:center; margin-bottom:3.5rem; }
.section-title { font-size:clamp(2rem,5vw,3.25rem); font-weight:400; margin-bottom:0.5rem; }
.section-title em { font-style:italic; }
.section-sub { font-size:1rem; color:rgba(26,26,27,0.6); }

/* ── Amenity Cards ── */
.amenity-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.5rem; }
.amenity-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.amenity-card {
  background:var(--mist); border:1px solid rgba(32,32,92,0.08);
  border-radius:var(--radius); padding:1.5rem;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.amenity-card:hover { border-color:var(--oak-30); box-shadow:0 4px 20px rgba(0,0,0,0.08); }
.amenity-icon { color:var(--oak); margin-bottom:0.75rem; }
.amenity-title { font-weight:600; color:var(--navy); font-size:0.95rem; margin-bottom:0.25rem; }
.amenity-desc { font-size:0.85rem; color:rgba(26,26,27,0.6); }

/* ── Gallery Grid ── */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.75rem; }
.gallery-item { aspect-ratio:1; overflow:hidden; border-radius:var(--radius); }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.gallery-item:hover img { transform:scale(1.1); }

/* ── CTA Band ── */
.cta-band { background:var(--navy); padding:6rem 1.5rem; text-align:center; position:relative; overflow:hidden; }
.cta-band-bg { position:absolute; inset:0; opacity:0.1; }
.cta-band-bg img { width:100%; height:100%; object-fit:cover; }
.cta-content { position:relative; z-index:2; max-width:800px; margin:0 auto; }
.cta-title { font-size:clamp(2rem,6vw,4rem); font-weight:300; color:var(--mist); margin-bottom:1.5rem; }
.cta-title em { font-style:italic; }
.cta-text { color:rgba(252,250,250,0.7); font-size:1.1rem; margin-bottom:2.5rem; line-height:1.8; }

/* ── Page Header ── */
.page-header {
  position:relative; height:18rem; overflow:hidden;
  display:flex; align-items:center; justify-content:center; text-align:center;
}
.page-header-md { height:24rem; }
.page-header img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-header-content { position:relative; z-index:2; padding:0 1.5rem; }
.page-header-title { font-size:clamp(2rem,6vw,4rem); font-weight:300; color:var(--mist); }

/* ── Accommodation ── */
.unit-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; margin-bottom:6rem; }
.unit-hero { overflow:hidden; border-radius:var(--radius); height:20rem; margin-bottom:1rem; }
.unit-hero img { width:100%; height:100%; object-fit:cover; }
.unit-tabs { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:0.75rem; }
.unit-tab {
  font-size:0.75rem; font-weight:600; padding:0.375rem 1rem;
  border-radius:50px; border:1px solid rgba(32,32,92,0.2);
  color:var(--navy); background:var(--mist); cursor:pointer;
  transition:all var(--transition); letter-spacing:0.06em;
}
.unit-tab.active, .unit-tab:hover { background:var(--navy); color:var(--mist); border-color:var(--navy); }
.room-gallery { display:none; }
.room-gallery.active { display:block; }
.room-gallery-main-link { display:block; }
.room-gallery-main { overflow:hidden; border-radius:var(--radius); height:16rem; margin-bottom:0.5rem; cursor:zoom-in; }
.room-gallery-main img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.room-gallery-main:hover img { transform:scale(1.03); }
.room-gallery-thumbs { display:flex; gap:0.5rem; overflow-x:auto; padding-bottom:0.25rem; }
.room-thumb { width:4rem; height:3rem; flex-shrink:0; overflow:hidden; border-radius:calc(var(--radius)/2); opacity:0.55; transition:opacity var(--transition); display:block; }
.room-thumb:hover,.room-thumb.active { opacity:1; outline:2px solid var(--oak); outline-offset:2px; }
.room-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.unit-sleeps { display:flex; align-items:center; gap:0.5rem; color:var(--oak); font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:0.15em; margin-bottom:0.5rem; }
.unit-name { font-size:clamp(1.75rem,4vw,3rem); font-weight:400; margin-bottom:0.25rem; }
.unit-tagline { color:var(--oak); font-style:italic; font-size:0.9rem; margin-bottom:1.25rem; }
.unit-desc { color:rgba(26,26,27,0.8); line-height:1.8; margin-bottom:2rem; }
.unit-features { list-style:none; margin-bottom:2.5rem; }
.unit-features li { display:flex; align-items:center; gap:0.5rem; color:rgba(26,26,27,0.7); font-size:0.9rem; margin-bottom:0.5rem; }
.unit-features li::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--oak); display:inline-block; flex-shrink:0; }
.shared-amenities { background:rgba(32,32,92,0.04); padding:4rem 1.5rem; }

/* ── Activities ── */
.filter-bar { display:flex; flex-wrap:wrap; gap:0.75rem; justify-content:center; margin-bottom:3rem; }
.filter-btn {
  font-size:0.75rem; font-weight:600; padding:0.5rem 1.25rem; border-radius:50px;
  border:1px solid rgba(32,32,92,0.2); color:var(--navy); background:var(--mist);
  cursor:pointer; transition:all var(--transition); letter-spacing:0.08em; text-transform:capitalize;
}
.filter-btn:hover,.filter-btn.active { background:var(--navy); color:var(--mist); border-color:var(--navy); }
.activities-masonry { column-count:1; column-gap:1.5rem; }
.activity-card {
  break-inside:avoid; background:var(--mist); border:1px solid rgba(32,32,92,0.08);
  border-radius:1rem; overflow:hidden; margin-bottom:1.5rem;
  transition:box-shadow var(--transition), transform var(--transition);
}
.activity-card:hover { box-shadow:0 8px 40px rgba(0,0,0,0.12); transform:translateY(-2px); }
.activity-img { overflow:hidden; position:relative; }
.activity-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.activity-card:hover .activity-img img { transform:scale(1.05); }
.activity-img-featured { height:14rem; }
.activity-img-normal { height:10rem; }
.activity-body { padding:1.25rem; }
.activity-meta { display:flex; justify-content:space-between; align-items:center; margin-bottom:0.5rem; }
.activity-cat {
  font-size:0.7rem; font-weight:600; padding:0.25rem 0.625rem;
  border-radius:50px; text-transform:capitalize;
}
.cat-adventure { background:#fff7ed; color:#c2410c; }
.cat-nature    { background:#f0fdf4; color:#15803d; }
.cat-culture   { background:#faf5ff; color:#7e22ce; }
.cat-dining    { background:#fffbeb; color:#d97706; }
.cat-wellness  { background:#eff6ff; color:#1d4ed8; }
.activity-dist { font-size:0.75rem; color:rgba(26,26,27,0.5); display:flex; align-items:center; gap:0.25rem; }
.activity-title { font-size:1.2rem; font-weight:500; color:var(--navy); margin-bottom:0.5rem; }
.activity-desc  { font-size:0.875rem; color:rgba(26,26,27,0.7); line-height:1.7; }

/* ── Blog ── */
.blog-post { margin-bottom:5rem; }
.blog-img { width:100%; height:18rem; overflow:hidden; border-radius:1rem; margin-bottom:2rem; }
.blog-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s; }
.blog-img:hover img { transform:scale(1.03); }
.blog-meta { display:flex; align-items:center; flex-wrap:wrap; gap:1rem; margin-bottom:1rem; }
.blog-date { font-size:0.75rem; color:rgba(26,26,27,0.5); display:flex; align-items:center; gap:0.375rem; }
.blog-tag { font-size:0.7rem; font-weight:600; color:var(--oak); background:var(--oak-10); padding:0.25rem 0.625rem; border-radius:50px; }
.blog-title { font-size:clamp(1.5rem,3vw,2.25rem); font-weight:400; color:var(--navy); margin-bottom:1rem; }
.blog-excerpt { font-size:1.1rem; color:rgba(26,26,27,0.7); line-height:1.8; margin-bottom:1.5rem; }
.blog-read-more { font-size:0.875rem; font-weight:600; color:var(--navy); border-bottom:2px solid var(--oak); padding-bottom:2px; transition:color var(--transition); }
.blog-read-more:hover { color:var(--oak); }
.blog-divider { width:4rem; height:1px; background:var(--oak-30); margin:3.5rem auto; }

/* ── Blog Post ── */
.post-hero { height:18rem; overflow:hidden; }
.post-hero-lg { height:min(50vh,500px); }
.post-hero img { width:100%; height:100%; object-fit:cover; }
.post-article { max-width:720px; margin:0 auto; padding:4rem 1.5rem; }
.post-back { display:inline-flex; align-items:center; gap:0.5rem; font-size:0.875rem; color:var(--oak); margin-bottom:2rem; transition:color var(--transition); }
.post-back:hover { color:var(--navy); }
.post-title { font-size:clamp(2rem,5vw,3.5rem); font-weight:400; color:var(--navy); margin-bottom:2rem; }
.post-excerpt { font-size:1.2rem; color:rgba(26,26,27,0.8); line-height:1.8; border-left:4px solid var(--oak); padding-left:1.25rem; font-style:italic; margin-bottom:2rem; }
.post-content { color:rgba(26,26,27,0.8); line-height:1.9; font-size:1.05rem; }
.post-content h2,.post-content h3 { font-family:var(--font-heading); color:var(--navy); margin:2rem 0 1rem; }
.post-content p { margin-bottom:1.25rem; }
.post-content ul { padding-left:1.5rem; margin-bottom:1.25rem; }
.post-content li { margin-bottom:0.5rem; }
.post-cta { background:var(--navy); border-radius:1rem; padding:2rem; text-align:center; margin-top:4rem; }
.post-cta h3 { font-family:var(--font-heading); color:var(--mist); font-size:2rem; font-weight:400; margin-bottom:0.75rem; }
.post-cta p { color:rgba(252,250,250,0.7); margin-bottom:1.5rem; }

/* ── Contact ── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; }
.contact-title { font-size:clamp(1.75rem,4vw,3rem); font-weight:400; margin-bottom:1rem; }
.contact-intro { color:rgba(26,26,27,0.7); line-height:1.8; margin-bottom:2.5rem; }
.contact-item { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.5rem; }
.contact-icon-wrap { width:2.5rem; height:2.5rem; background:var(--oak-10); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-icon-wrap svg { color:var(--oak); }
.contact-label { font-weight:600; color:var(--navy); font-size:0.875rem; margin-bottom:0.25rem; }
.contact-val { color:rgba(26,26,27,0.7); font-size:0.875rem; line-height:1.6; }
.contact-val a { color:var(--oak); transition:color var(--transition); }
.contact-val a:hover { color:var(--navy); }
.contact-book-box { background:var(--navy); border-radius:1rem; padding:1.5rem; margin-top:3rem; }
.contact-book-box h3 { font-family:var(--font-heading); color:var(--mist); font-size:1.5rem; font-weight:400; margin-bottom:0.5rem; }
.contact-book-box p { color:rgba(252,250,250,0.7); font-size:0.875rem; margin-bottom:1.25rem; }

/* Contact Form */
.contact-form { display:flex; flex-direction:column; gap:1.25rem; }
.form-label { display:block; font-size:0.875rem; font-weight:600; color:var(--navy); margin-bottom:0.375rem; letter-spacing:0.05em; }
.form-input,.form-textarea {
  width:100%; border:1px solid rgba(32,32,92,0.2); border-radius:var(--radius);
  padding:0.875rem 1rem; font-family:var(--font-body); font-size:0.9375rem;
  color:var(--obsidian); background:var(--mist);
  transition:border-color var(--transition), box-shadow var(--transition);
}
.form-input:focus,.form-textarea:focus {
  outline:none; border-color:var(--oak); box-shadow:0 0 0 3px rgba(166,138,100,0.15);
}
.form-textarea { resize:none; }
.form-submit {
  width:100%; background:var(--navy); color:var(--mist);
  font-family:var(--font-body); font-weight:600; font-size:0.9rem; letter-spacing:0.06em;
  padding:1rem; border-radius:var(--radius); border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:0.5rem;
  transition:background var(--transition);
}
.form-submit:hover { background:var(--oak); }
.form-submit:disabled { opacity:0.6; cursor:not-allowed; }
.form-success {
  text-align:center; padding:4rem 2rem;
  display:flex; flex-direction:column; align-items:center;
}
.form-success svg { color:#22c55e; margin-bottom:1.25rem; }
.form-success h3 { font-family:var(--font-heading); font-size:2rem; color:var(--navy); margin-bottom:0.75rem; }
.form-success p { color:rgba(26,26,27,0.7); line-height:1.8; }
.form-success button { margin-top:2rem; color:var(--oak); border-bottom:1px solid var(--oak); font-size:0.875rem; transition:color var(--transition); }
.form-success button:hover { color:var(--navy); }

/* ── Alert ── */
.alert { padding:1rem 1.25rem; border-radius:var(--radius); margin-bottom:1.25rem; font-size:0.9rem; }
.alert-success { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; }
.alert-error   { background:#fef2f2; color:#991b1b; border:1px solid #fecaca; }

/* ── Footer ── */
.site-footer { background:var(--navy); color:var(--mist); }
.footer-inner { max-width:1280px; margin:0 auto; padding:4rem 1.5rem; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.footer-logo { height:5rem; width:auto; margin-bottom:1.5rem; opacity:0.9; }
.footer-desc { font-size:0.875rem; color:rgba(252,250,250,0.7); line-height:1.8; }
.footer-social { display:flex; gap:1rem; margin-top:1.5rem; }
.footer-social a { color:rgba(252,250,250,0.5); transition:color var(--transition); }
.footer-social a:hover { color:var(--oak); }
.footer-heading { font-family:var(--font-heading); font-size:1.25rem; color:var(--oak); margin-bottom:1.25rem; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:0.75rem; }
.footer-links a { font-size:0.875rem; color:rgba(252,250,250,0.7); transition:color var(--transition); }
.footer-links a:hover { color:var(--oak); }
.footer-info { list-style:none; }
.footer-info li { display:flex; align-items:flex-start; gap:0.75rem; font-size:0.875rem; color:rgba(252,250,250,0.7); margin-bottom:1rem; }
.footer-info svg { color:var(--oak); flex-shrink:0; margin-top:2px; }
.footer-info a { color:rgba(252,250,250,0.7); transition:color var(--transition); }
.footer-info a:hover { color:var(--oak); }
.footer-book-btn {
  display:inline-block; margin-top:1.5rem; background:var(--oak); color:var(--mist);
  padding:0.625rem 1.5rem; border-radius:50px; font-size:0.8rem; font-weight:600;
  transition:background var(--transition);
}
.footer-book-btn:hover { background:rgba(166,138,100,0.8); }
.footer-bottom {
  border-top:1px solid rgba(252,250,250,0.1); padding-top:2rem;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
}
.footer-bottom p { font-size:0.75rem; color:rgba(252,250,250,0.4); }
.footer-admin-link { font-size:0.625rem; color:rgba(252,250,250,0.2); letter-spacing:0.2em; text-transform:uppercase; transition:color var(--transition); }
.footer-admin-link:hover { color:rgba(252,250,250,0.4); }

/* ── Admin ── */
.admin-wrap { display:flex; min-height:100vh; background:#0f1729; }
.admin-sidebar {
  width:260px; background:var(--navy); flex-shrink:0;
  display:flex; flex-direction:column; position:fixed; top:0; left:0; bottom:0; z-index:200;
  transition:transform var(--transition);
}
.admin-sidebar-header {
  padding:1.5rem; border-bottom:1px solid rgba(252,250,250,0.08);
  display:flex; align-items:center; justify-content:space-between;
}
.admin-sidebar-header h2 { font-family:var(--font-heading); color:var(--mist); font-size:1.5rem; font-weight:400; }
.admin-nav { flex:1; padding:1rem 0; overflow-y:auto; }
.admin-nav-link {
  display:flex; align-items:center; gap:0.875rem;
  padding:0.75rem 1.5rem; color:rgba(252,250,250,0.6);
  font-size:0.875rem; font-weight:500; transition:all var(--transition);
  border-left:3px solid transparent;
}
.admin-nav-link:hover,.admin-nav-link.active { color:var(--mist); background:rgba(252,250,250,0.05); border-left-color:var(--oak); }
.admin-nav-link svg { width:18px; height:18px; flex-shrink:0; }
.admin-sidebar-footer { padding:1rem 1.5rem; border-top:1px solid rgba(252,250,250,0.08); }
.admin-main { flex:1; margin-left:260px; display:flex; flex-direction:column; }
.admin-topbar {
  height:4rem; background:var(--navy); border-bottom:1px solid rgba(252,250,250,0.08);
  display:flex; align-items:center; padding:0 2rem; gap:1rem;
  position:sticky; top:0; z-index:100;
}
.admin-topbar-title { font-family:var(--font-heading); color:var(--mist); font-size:1.25rem; flex:1; }
.admin-topbar-user { font-size:0.8rem; color:rgba(252,250,250,0.5); }
.admin-topbar-signout { font-size:0.8rem; color:rgba(252,250,250,0.4); transition:color var(--transition); }
.admin-topbar-signout:hover { color:var(--oak); }
.admin-content { flex:1; padding:2rem; }

/* Admin Cards / Grids */
.admin-stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1rem; margin-bottom:2rem; }
.admin-stat-card {
  background:rgba(252,250,250,0.04); border:1px solid rgba(252,250,250,0.08);
  border-radius:var(--radius); padding:1.25rem;
  transition:border-color var(--transition), background var(--transition);
  text-decoration:none; display:block;
}
.admin-stat-card:hover { border-color:rgba(166,138,100,0.4); background:rgba(252,250,250,0.06); }
.admin-stat-num { font-family:var(--font-heading); font-size:2rem; color:var(--mist); }
.admin-stat-label { font-size:0.7rem; font-weight:600; color:rgba(252,250,250,0.4); text-transform:uppercase; letter-spacing:0.12em; margin-top:0.25rem; }
.admin-stat-badge { background:rgba(166,138,100,0.2); color:var(--oak); font-size:0.7rem; font-weight:600; padding:0.2rem 0.5rem; border-radius:50px; margin-top:0.5rem; display:inline-block; }
.admin-card {
  background:rgba(252,250,250,0.04); border:1px solid rgba(252,250,250,0.08);
  border-radius:var(--radius); padding:1.5rem; margin-bottom:1.5rem;
}
.admin-card-title { font-family:var(--font-heading); color:var(--mist); font-size:1.25rem; font-weight:400; margin-bottom:1.25rem; }
.admin-page-title { font-family:var(--font-heading); color:var(--mist); font-size:1.75rem; font-weight:400; margin-bottom:0.5rem; }
.admin-page-sub { color:rgba(252,250,250,0.4); font-size:0.875rem; margin-bottom:1.5rem; }
.admin-page-header { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-bottom:1.5rem; }

/* Admin Form Fields */
.admin-label { display:block; font-size:0.8rem; font-weight:600; color:rgba(252,250,250,0.7); margin-bottom:0.375rem; letter-spacing:0.04em; }
.admin-input,.admin-textarea,.admin-select {
  width:100%; background:rgba(0,0,0,0.3); border:1px solid rgba(252,250,250,0.12);
  border-radius:calc(var(--radius)/1.5); padding:0.75rem 1rem;
  font-family:var(--font-body); font-size:0.9rem; color:var(--mist);
  transition:border-color var(--transition); outline:none;
}
.admin-input:focus,.admin-textarea:focus,.admin-select:focus { border-color:var(--oak); }
.admin-textarea { resize:vertical; }
.admin-select option { background:var(--navy); }
.admin-hint { font-size:0.75rem; color:rgba(252,250,250,0.35); margin-top:0.25rem; }
.admin-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.admin-form-field { margin-bottom:1.25rem; }
.admin-switch { display:flex; align-items:center; gap:0.75rem; }
.admin-switch-input { width:42px; height:22px; appearance:none; background:rgba(252,250,250,0.15); border-radius:50px; cursor:pointer; position:relative; transition:background var(--transition); }
.admin-switch-input:checked { background:var(--oak); }
.admin-switch-input::after { content:''; position:absolute; left:3px; top:3px; width:16px; height:16px; border-radius:50%; background:#fff; transition:transform var(--transition); }
.admin-switch-input:checked::after { transform:translateX(20px); }
.admin-switch-label { font-size:0.875rem; color:rgba(252,250,250,0.7); }

/* Admin Table */
.admin-table-wrap { overflow-x:auto; }
.admin-table { width:100%; border-collapse:collapse; }
.admin-table th { font-size:0.7rem; font-weight:600; color:rgba(252,250,250,0.4); text-transform:uppercase; letter-spacing:0.1em; padding:0.75rem 1rem; text-align:left; border-bottom:1px solid rgba(252,250,250,0.08); }
.admin-table td { padding:0.875rem 1rem; border-bottom:1px solid rgba(252,250,250,0.05); font-size:0.875rem; color:rgba(252,250,250,0.8); vertical-align:middle; }
.admin-table tr:hover td { background:rgba(252,250,250,0.02); }

/* Admin Buttons */
.btn-admin {
  display:inline-flex; align-items:center; gap:0.5rem; font-family:var(--font-body);
  font-size:0.8rem; font-weight:600; padding:0.5rem 1.125rem; border-radius:var(--radius);
  cursor:pointer; transition:all var(--transition); letter-spacing:0.04em; border:none;
}
.btn-admin-primary { background:var(--oak); color:var(--mist); }
.btn-admin-primary:hover { background:rgba(166,138,100,0.8); }
.btn-admin-ghost { background:rgba(252,250,250,0.08); color:rgba(252,250,250,0.7); }
.btn-admin-ghost:hover { background:rgba(252,250,250,0.12); color:var(--mist); }
.btn-admin-danger { background:rgba(239,68,68,0.15); color:#f87171; }
.btn-admin-danger:hover { background:rgba(239,68,68,0.25); }
.btn-admin-sm { padding:0.375rem 0.75rem; font-size:0.75rem; }
.badge-unread { background:rgba(166,138,100,0.2); color:var(--oak); font-size:0.7rem; font-weight:700; padding:0.15rem 0.5rem; border-radius:50px; }
.badge-status-pub  { background:#f0fdf4; color:#15803d; font-size:0.7rem; font-weight:600; padding:0.2rem 0.625rem; border-radius:50px; }
.badge-status-draft{ background:#f3f4f6; color:#6b7280; font-size:0.7rem; font-weight:600; padding:0.2rem 0.625rem; border-radius:50px; }

/* Edit Panel */
.edit-panel {
  background:rgba(252,250,250,0.03); border:1px solid rgba(166,138,100,0.3);
  border-radius:var(--radius); padding:1.5rem; margin-bottom:1.5rem;
}
.edit-panel-title { font-size:0.875rem; font-weight:600; color:var(--mist); margin-bottom:1.25rem; }

/* Quill overrides in admin */
.ql-toolbar.ql-snow { background:rgba(0,0,0,0.2); border-color:rgba(252,250,250,0.12) !important; border-radius:calc(var(--radius)/1.5) calc(var(--radius)/1.5) 0 0; }
.ql-container.ql-snow { border-color:rgba(252,250,250,0.12) !important; border-top:none; background:rgba(0,0,0,0.2); border-radius:0 0 calc(var(--radius)/1.5) calc(var(--radius)/1.5); min-height:200px; }
.ql-editor { color:var(--mist); font-family:var(--font-body); min-height:200px; }
.ql-toolbar.ql-snow .ql-stroke { stroke:rgba(252,250,250,0.6); }
.ql-toolbar.ql-snow .ql-fill  { fill:rgba(252,250,250,0.6); }
.ql-toolbar.ql-snow .ql-picker { color:rgba(252,250,250,0.6); }
.ql-toolbar.ql-snow .ql-picker-options { background:var(--navy); }

/* Gallery upload */
.upload-zone {
  border:2px dashed rgba(252,250,250,0.2); border-radius:var(--radius);
  padding:3rem; text-align:center; cursor:pointer;
  transition:border-color var(--transition), background var(--transition);
}
.upload-zone:hover,.upload-zone.drag-over { border-color:var(--oak); background:rgba(166,138,100,0.05); }
.upload-zone svg { color:rgba(252,250,250,0.3); margin-bottom:1rem; }
.upload-zone p { color:rgba(252,250,250,0.5); font-size:0.875rem; }

/* Gallery grid admin */
.admin-gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:0.75rem; margin-top:1.5rem; }
.admin-gallery-item { position:relative; aspect-ratio:1; border-radius:calc(var(--radius)/2); overflow:hidden; }
.admin-gallery-item img { width:100%; height:100%; object-fit:cover; }
.admin-gallery-overlay {
  position:absolute; inset:0; background:rgba(0,0,0,0.5);
  opacity:0; transition:opacity var(--transition);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.5rem;
}
.admin-gallery-item:hover .admin-gallery-overlay { opacity:1; }
.admin-gallery-cat { font-size:0.65rem; font-weight:600; color:var(--mist); text-transform:uppercase; letter-spacing:0.1em; }

/* Contact entries */
.contact-list { display:flex; flex-direction:column; gap:0.5rem; }
.contact-entry {
  padding:1rem; border-radius:calc(var(--radius)/2);
  background:rgba(252,250,250,0.04); border:1px solid rgba(252,250,250,0.06);
  cursor:pointer; transition:all var(--transition);
}
.contact-entry:hover,.contact-entry.selected { background:rgba(252,250,250,0.07); border-color:rgba(166,138,100,0.3); }
.contact-entry.unread { border-left:3px solid var(--oak); }
.contact-entry-name { font-weight:600; color:var(--mist); font-size:0.875rem; }
.contact-entry-preview { font-size:0.8rem; color:rgba(252,250,250,0.4); margin-top:0.25rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.contact-entry-time { font-size:0.7rem; color:rgba(252,250,250,0.3); margin-top:0.25rem; }
.contact-detail { background:rgba(252,250,250,0.04); border:1px solid rgba(252,250,250,0.08); border-radius:var(--radius); padding:1.5rem; }
.contact-detail-name { font-family:var(--font-heading); color:var(--mist); font-size:1.5rem; font-weight:400; margin-bottom:0.25rem; }
.contact-detail-info { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:1.5rem; }
.contact-detail-info span { font-size:0.8rem; color:rgba(252,250,250,0.5); display:flex; align-items:center; gap:0.375rem; }
.contact-message { background:rgba(0,0,0,0.2); border-radius:calc(var(--radius)/2); padding:1.25rem; font-size:0.9rem; color:rgba(252,250,250,0.8); line-height:1.8; white-space:pre-wrap; }

/* Admin Login */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; background:#0f1729; padding:2rem; }
.login-card { background:var(--navy); border:1px solid rgba(252,250,250,0.1); border-radius:1.25rem; padding:3rem; width:100%; max-width:420px; }
.login-logo { margin-bottom:2rem; }
.login-logo img { height:4rem; width:auto; }
.login-title { font-family:var(--font-heading); font-size:2rem; font-weight:400; color:var(--mist); margin-bottom:0.5rem; }
.login-sub { font-size:0.875rem; color:rgba(252,250,250,0.5); margin-bottom:2rem; }
.login-btn {
  width:100%; background:var(--oak); color:var(--mist); border:none;
  padding:0.875rem; border-radius:var(--radius); font-family:var(--font-body);
  font-weight:600; font-size:0.9rem; cursor:pointer; transition:background var(--transition);
  display:flex; align-items:center; justify-content:center; gap:0.5rem;
}
.login-btn:hover { background:rgba(166,138,100,0.8); }

/* Toast */
#toast {
  position:fixed; bottom:2rem; right:2rem; z-index:9999;
  background:var(--navy); color:var(--mist); padding:1rem 1.5rem;
  border-radius:var(--radius); border-left:4px solid var(--oak);
  font-size:0.875rem; box-shadow:0 8px 32px rgba(0,0,0,0.3);
  transform:translateY(100px); opacity:0; transition:all 0.35s ease;
  max-width:360px;
}
#toast.show { transform:translateY(0); opacity:1; }
#toast.error { border-left-color:#ef4444; }

/* Mobile sidebar toggle */
.admin-menu-btn { display:none; background:none; border:none; color:var(--mist); cursor:pointer; }
@media(max-width:1023px){
  .admin-sidebar { transform:translateX(-100%); }
  .admin-sidebar.open { transform:translateX(0); }
  .admin-main { margin-left:0; }
  .admin-menu-btn { display:flex; }
  .admin-sidebar-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:190; display:none; }
  .admin-sidebar-overlay.active { display:block; }
}

/* ── Responsive ── */
@media(max-width:767px){
  .two-col,.contact-grid { grid-template-columns:1fr; }
  .two-col.reverse { direction:ltr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .unit-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .admin-form-row { grid-template-columns:1fr; }
  .admin-main { margin-left:0; }
  .nav-links { display:none; }
  .nav-toggle { display:flex; }
  .amenity-grid-3 { grid-template-columns:repeat(2,1fr); }
}
@media(min-width:768px){
  .nav-mobile { display:none !important; }
}

/* ── Activities responsive columns (mirrors original: 1→2→3) ── */
@media(min-width:768px)  { .activities-masonry { column-count:2; } }
@media(min-width:1024px) { .activities-masonry { column-count:3; } }
