:root{
  --green:#123f1e;
  --green-dark:#0d2c15;
  --gold:#c9a227;
  --cream:#f8f4ea;
  --navy:#0b2337;
  --text:#1f2b22;
  --muted:#5f665f;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:'Inter',sans-serif;
  background:#f2f2f2;
  color:var(--text);
}

a{
  text-decoration:none;
}

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

.section-space{
  padding:90px 0;
}

.text-gold{
  color:var(--gold);
}

.text-light-soft{
  color:rgba(255,255,255,0.78);
}

.section-title,
.menu-title,
.quote-text,
.hero-content h1,
.secondary-content h2,
.room-content-box h2,
.amenities-grid-title,
.connect-title{
  font-family:'Cormorant Garamond',serif;
}

.section-title{
  font-size:clamp(2rem,4vw,3.4rem);
  font-weight:700;
  line-height:1.08;
  margin-bottom:18px;
}

.section-title.centered{
  text-align:center;
}

.section-copy{
  color:var(--muted);
  line-height:1.85;
  font-size:1.02rem;
}

.section-tag{
  display:inline-block;
  margin-bottom:14px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-size:0.76rem;
  font-weight:700;
  color:var(--green);
}

/* NAVBAR */
.main-nav{
  padding:10px 0;
  border-bottom:1px solid #ececec;
  background:#fff !important;
}

.nav-container{
  max-width:1280px;
}

.brand-wrap{
  display:flex;
  align-items:center;
}

.brand-logo{
  width:120px;
  height:auto;
  object-fit:contain;
}

.nav-center{
  gap:18px;
}

.navbar .nav-link{
  color:var(--green);
  font-size:18px;
  font-weight:500;
  padding:10px 12px;
}

.navbar .nav-link:hover,
.navbar .nav-link.active{
  color:var(--green-dark);
}

.custom-menu{
  border:none;
  border-radius:8px;
  min-width:260px;
  padding:0;
  overflow:hidden;
  margin-top:10px;
  box-shadow:0 12px 32px rgba(0,0,0,0.12);
}

.custom-menu .dropdown-item{
  padding:18px 20px;
  font-size:17px;
  color:#244126;
  background:#f1f1f1;
  border-bottom:1px solid #cfa73a;
}

.custom-menu .dropdown-item:last-child{
  border-bottom:none;
}

.custom-menu .dropdown-item:hover{
  background:#e9e9e9;
  color:#17361c;
}

.nav-social a i{
  font-size:19px;
}

.instagram{ color:#a83bd6; }
.facebook{ color:#4267B2; }
.twitterx{ color:#111; }
.whats{ color:#2fc85f; }
.youtube{ color:#ff0000; }

/* HERO */
.hero-section{
  padding:40px 0 0;
  background:#f2f2f2;
}

.hero-frame{
  width:90%;
  margin:0 auto;
  position:relative;
  overflow:hidden;
  background:#f2f2f2;
  border-radius:4px;
  padding-bottom:0px;
}

.hero-video{
  width:100%;
  height:630px;
  object-fit:cover;
  display:block;
  padding-bottom: 30px;
}

.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(247, 247, 247, 0.18), rgba(255, 253, 253, 0.08));
}

/* ROOMS SECTION */
.rooms-section{
  background:#f3f3f3;
  padding:70px 0 50px;
}

.room-wrap{
  width:92%;
  margin:0 auto;
}

.room-row{
  margin-bottom:14px;
}

.room-image-box{
  height:100%;
  min-height:340px;
  overflow:hidden;
  background:#ddd;
}

.room-image-box img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.room-content-box{
  height:100%;
  background:#f3f3f3;
  padding:28px 22px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.room-content-box h2{
  font-size:clamp(2rem,3.2vw,3.3rem);
  font-weight:700;
  line-height:1.05;
  color:#111;
  margin-bottom:14px;
}

.room-content-box p{
  font-size:1.02rem;
  line-height:1.55;
  color:#111;
  margin-bottom:16px;
  max-width:95%;
}

.room-points{
  list-style:none;
  padding:0;
  margin:0;
}

.room-points li{
  font-size:1rem;
  color:#111;
  margin-bottom:12px;
  line-height:1.5;
}

/* RETREAT */
.retreat-section{
  background:#fff;
}

.section-image{
  min-height:420px;
  object-fit:cover;
  border-radius:1rem;
}

.thumb-row{
  display:flex;
  gap:12px;
  margin-top:14px;
}

.thumb-row img{
  width:33.333%;
  height:90px;
  object-fit:cover;
  border-radius:14px;
}

/* AMENITIES GRID */
.amenities-grid-section{
  background:#f3f3f3;
  padding:30px 0 50px;
}

.amenities-grid-title{
  text-align:center;
  font-size:clamp(2rem,3vw,3.3rem);
  font-weight:700;
  color:#111;
  margin-bottom:18px;
}

.amenity-icon-card{
  text-align:center;
}

.amenity-icon-box{
  width:100%;
  max-width:240px;
  height:230px;
  margin:0 auto 18px;
  background:#f3f3f3;
  border-left:2px solid #555;
  border-right:2px solid #555;
  border-bottom:2px solid #555;
  border-top:none;
  border-radius:0 0 36px 36px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  overflow:hidden;
  position:relative;
}

.amenity-icon-box::before,
.amenity-icon-box::after{
  content:"";
  position:absolute;
  top:0;
  width:38px;
  height:2px;
  background:#555;
  z-index:2;
}

.amenity-icon-box::before{
  left:0;
}

.amenity-icon-box::after{
  right:0;
}

.amenity-icon-box img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.amenity-icon-card h4{
  font-size:1.15rem;
  font-weight:500;
  color:#222;
  margin:0;
}

/* BUTTON */
.btn-forest{
  background:var(--green);
  border-color:var(--green);
  color:#fff;
}

.btn-forest:hover{
  background:var(--green-dark);
  border-color:var(--green-dark);
  color:#fff;
}

/* DARK SECTION */
.dark-section{
  background:linear-gradient(180deg,#123f1e 0%, #0c2f16 100%);
}

.circle-image-wrap{
  display:flex;
  justify-content:center;
}

.circle-image{
  width:340px;
  height:340px;
  object-fit:cover;
  border-radius:50%;
  border:8px solid rgba(255,255,255,0.08);
}

/* QUOTE */
.quote-section{
  padding:90px 0;
  background:var(--cream);
}

.quote-mark{
  font-size:5rem;
  color:var(--gold);
  line-height:1;
}

.quote-mark.bottom{
  margin-top:10px;
}

.quote-text{
  font-size:clamp(2rem,4vw,3.3rem);
  color:#2c372d;
  font-weight:600;
  max-width:980px;
  margin:0 auto;
  line-height:1.2;
}

/* ABOUT */
.about-main-section{
  background:#fff;
}

.read-more-link{
  color:var(--green);
  font-weight:700;
  letter-spacing:0.1em;
}

/* MENU */
.menu-section{
  background:var(--cream);
}

.menu-desc{
  max-width:700px;
  margin:0 auto 12px;
  color:var(--muted);
}

.menu-divider{
  color:var(--gold);
  letter-spacing:0.35em;
  font-size:1.2rem;
}

.menu-card{
  border-radius:28px;
  padding:36px;
  min-height:100%;
  box-shadow:0 16px 35px rgba(0,0,0,0.06);
}

.dark-card{
  background:#08240e;
  color:#fff;
}

.light-card{
  background:#e6d58e;
  color:#1e211c;
}

.menu-title{
  font-size:2.1rem;
  margin-bottom:20px;
  font-weight:700;
}

.menu-list{
  list-style:none;
  padding:0;
  margin:0;
}

.menu-list li{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:14px 0;
  border-bottom:1px dashed rgba(255,255,255,0.25);
}

.dark-lines li{
  border-bottom:1px dashed rgba(0,0,0,0.25);
}

/* AMENITY FEATURE CARDS */
.amenity-feature-card{
  background:#fff;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 16px 35px rgba(0,0,0,0.08);
  height:100%;
}

.amenity-feature-card img{
  height:280px;
  object-fit:cover;
}

.feature-card-content{
  padding:24px;
}

.feature-card-content h3{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem;
  margin-bottom:12px;
}

.feature-card-content p{
  color:#5f665f;
  line-height:1.75;
}

/* LOCATION */
.location-section{
  background:#fff;
}

.location-card{
  background:#f8f8f8;
  border-radius:26px;
  padding:30px;
  box-shadow:0 12px 28px rgba(0,0,0,0.05);
}

.location-list{
  margin-top:20px;
  display:grid;
  gap:10px;
}

.map-box{
  background:#fff;
  border-radius:26px;
  overflow:hidden;
  box-shadow:0 12px 28px rgba(0,0,0,0.06);
}

.map-box img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
}

/* CONNECT */
.connect-strip{
  background:#032f12;
  padding:70px 0;
  color:#fff;
}

.connect-title{
  text-align:center;
  font-size:clamp(2rem, 3vw, 3.2rem);
  font-weight:700;
  color:#fff;
  margin-bottom:10px;
}

.connect-box{
  text-align:center;
  padding:10px 20px;
}

.connect-box i{
  font-size:2rem;
  color:#fff;
  margin-bottom:12px;
  display:block;
}

.connect-box h5{
  font-size:1.5rem;
  font-family:'Cormorant Garamond', serif;
  font-weight:700;
  color:#fff;
  margin-bottom:10px;
}

.connect-box p{
  margin:0;
  color:#f2f2f2;
  line-height:1.7;
  font-size:1rem;
}

.connect-highlight{
  font-size:1.2rem;
  font-weight:700;
  color:#fff;
}

/* INQUIRY */
.inquiry-section{
  background:linear-gradient(180deg,#0d2d15 0%, #091f0f 100%);
}

.inquiry-info{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.form-card{
  background:#fff;
  border-radius:26px;
  padding:28px;
  box-shadow:0 16px 35px rgba(0,0,0,0.08);
}

.form-control{
  padding:14px 16px;
  border-radius:14px;
  border:1px solid #d8dfd8;
}

.form-control:focus{
  box-shadow:none;
  border-color:var(--green);
}

/* GALLERY */
.gallery-service-section{
  background:#fff;
}

.gallery-img{
  width:100%;
  min-height:280px;
  height:100%;
  object-fit:cover;
  box-shadow:0 16px 35px rgba(0,0,0,0.08);
  transition:transform 0.25s ease;
  cursor:pointer;
}

.gallery-img:hover{
  transform:translateY(-4px);
}

.lightbox{
  display:none;
  position:fixed;
  inset:0;
  z-index:99999;
  background:rgba(0,0,0,0.9);
  justify-content:center;
  align-items:center;
  padding:30px;
}

.lightbox-content{
  max-width:90%;
  max-height:90%;
  object-fit:contain;
}

.lightbox-close{
  position:absolute;
  top:20px;
  right:30px;
  color:#fff;
  font-size:42px;
  font-weight:700;
  cursor:pointer;
  line-height:1;
}

/* SECONDARY HERO */
.secondary-hero{
  position:relative;
  overflow:hidden;
  border-radius:28px;
}

.secondary-hero img{
  width:150%;
  height:560px;
  object-fit:cover;
}

.secondary-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.28);
}

.secondary-content{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  padding:30px;
}

.secondary-content h2{
  font-size:clamp(2rem,4vw,3.5rem);
  margin-bottom:18px;
}

/* POLICY */
.policy-section{
  background:linear-gradient(180deg,#0f4a24,#0a341a);
  padding:80px 0;
}

.policy-copy{
  max-width:760px;
  margin:0 auto;
  line-height:1.9;
  color:rgba(255,255,255,0.78);
}

/* FOOTER */
.footer-section{
  background:var(--navy);
  color:#d7e1eb;
  padding:65px 0 25px;
}

.footer-section h5,
.footer-section h6{
  color:#fff;
  margin-bottom:16px;
}

.footer-section p{
  color:#bed0dc;
  line-height:1.8;
}

.footer-links{
  list-style:none;
  padding:0;
  margin:0;
}

.footer-links li{
  margin-bottom:10px;
}

.footer-links a{
  color:#bed0dc;
}

.footer-links a:hover{
  color:#fff;
}

.footer-social a{
  color:#fff;
  font-size:1.1rem;
}

.footer-bottom{
  margin-top:26px;
  border-top:1px solid rgba(255,255,255,0.12);
  padding-top:20px;
  color:#91a8ba;
  font-size:0.92rem;
}

/* FLOATING ICONS */
.floating-icons{
  position:fixed;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  flex-direction:column;
  gap:18px;
  z-index:9999;
}

.float-icon{
  width:56px;
  height:56px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  box-shadow:0 10px 20px rgba(0,0,0,0.12);
}

.float-icon.phone{
  background:#0cc143;
  color:#fff;
}

.float-icon.pdf{
  background:#fff;
  color:#e53935;
  border:1px solid #ddd;
}

.float-icon.whatsapp{
  background:#2ed164;
  color:#fff;
}

/* DESKTOP DROPDOWN */
@media (min-width:992px){
  .custom-dropdown:hover .custom-menu{
    display:block;
  }
}

/* TABLET */
@media (max-width:991px){
  .section-space{
    padding:72px 0;
  }

  .brand-logo{
    width:95px;
  }

  .nav-center{
    gap:0;
  }

  .nav-social{
    padding-top:12px;
  }

  .custom-menu{
    min-width:100%;
    margin-top:0;
    box-shadow:none;
  }

  .hero-frame{
    width:94%;
  }

  .hero-video{
    height:300px;
  }

  .room-wrap{
    width:96%;
  }

  .room-content-box{
    padding:24px 18px;
  }

  .room-image-box{
    min-height:260px;
  }

  .room-content-box h2{
    font-size:2.2rem;
  }

  .section-image{
    min-height:320px;
  }

  .circle-image{
    width:260px;
    height:260px;
  }

  .secondary-hero img{
    height:300px;
  }
}

@media (max-width:767px){
  .amenity-icon-box{
    height:180px;
    max-width:180px;
  }

  .amenity-icon-card h4{
    font-size:1rem;
  }

  .connect-strip{
    padding:50px 0;
  }

  .connect-box{
    padding:8px 10px;
  }

  .connect-box h5{
    font-size:1.25rem;
  }

  .connect-box p{
    font-size:.95rem;
  }

  .connect-highlight{
    font-size:1.05rem;
  }
}

/* MOBILE */
@media (max-width:575px){
  .menu-title{
    font-size:1.7rem;
  }

  .floating-icons{
    right:8px;
    gap:12px;
  }

  .float-icon{
    width:46px;
    height:46px;
    font-size:22px;
  }

  .form-card,
  .location-card,
  .menu-card{
    padding:22px;
  }
}