body {
  font-family: "Montserrat", Arial, sans-serif;
}
.seo-hero {
  position: relative;
  height: 100vh;
  overflow: hidden;
}

/* Slides */
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.8s ease-in-out; /* 👈 smooth fade */
}

.hero-slide.active {
  opacity: 1;
  z-index: 1;
}

/* Image is FIXED inside banner */
.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}


/* ONLY dark banner */
.seo-hero--dark .hero-overlay {
  background: rgba(0, 0, 0, 0.40); 
}


/* Overlay */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero-content p {
  font-size: 20px;
  letter-spacing: 1.83px;
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.85);
  color: #ffffff;
  margin-bottom: 120px;
}

.hero-content h1 { 
  font-size: 60px; 
  transform: translateY(16vh);
  color: #e8e8e1; 
  font-weight: 100;
  letter-spacing: 0.2em;
}

/* Mobile tweaks */
@media (max-width: 720px) {
  .seo-hero {
    height: 85vh;
  }
}
/* === FIXED HERO REVEAL (Oceanphere style) === */
/* Content */
.hero-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;       /* 👈 vertical middle */
  justify-content: flex-start;
  color: #fff;
}

/* LEFT aligned content */
.hero-content--left {
  padding-left: 8%;
  text-align: left;
}

.hero-content h1 { 
  font-size: 40px;
  font-weight: 700;
  letter-spacing: 0.18em;
  line-height: 1.2;
  color: #ffffff;
  text-shadow: 0 4px 10px rgba(0, 0, 0, 0.85);
  width: 100%;
}

/* Mobile tweaks */
@media (max-width: 720px) {
  .hero-content--left {
    padding-left: 6%;
  }

  .hero-content h1 {
    font-size: 20px;
    letter-spacing: 0.12em;
    transform: translateY(35vh)
  }
}

.hero-content--center {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-left: 0;
}

/* Heading */
.hero-content--center .banner-heading {
  font-size: 50px;
  margin-bottom: 10px;
  transform: translateY(8vh);   /* desktop only */
  letter-spacing: 1px;
}

/* Paragraph */
.hero-content--center p {
  width: 100%;
  max-width: 680px;
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: #ffffff;
  opacity: 0.9;
  transform: translateY(8vh);   /* desktop only */
}
@media (max-width: 768px) {

  .hero-content--center .banner-heading {
    font-size: 30px;
    transform: none;          /* 🔥 remove vh shift */
    margin-bottom: 12px;
    transform: translateY(8vh)
  }

  .hero-content--center p {
    font-size: 12px;
    transform: none;          /* 🔥 remove vh shift */
    padding: 0 16px;
    transform: translateY(8vh)
  }

}

/* DEFAULT HEADER (NORMAL STATE) */
.op-header {
  background: #ffffff;
  transition: background 0.4s ease, box-shadow 0.4s ease;
}
/* ONLY WHEN AT TOP */
.op-header.at-top {
  background: transparent;
  box-shadow: none;
}

/* White menu on transparent */
.op-header.at-top .op-nav-desktop a {
  color: #ffffff;
  font-weight: 700;
}




.hero-btn {
  background: #c7a06e;
  color: #fff;
  padding: 14px 30px;
  text-decoration: none;
  margin-top: 20px;
  border-radius: 4px;
}











.milenia-grid--no-gutters .milenia-grid-item {
  margin-bottom: 20px; /* Change value as per your design */
}

.milenia-entity {
  min-height: auto !important;
  height: auto !important;
  padding: 5px 1px !important;
}



/* .owl-carousel--vadaptive .Wellness-image {
            position: absolute;
            top: 0;
            bottom: 0;
            right: 0;
            left: 30px !important;
        } */

        .milenia-section--stretched  {
  min-height: 50vh;
  display: flex;
  align-items: center;
}

        /* book now button start */
        .milenia-section--stretched .adjustscreen-height {
  min-height: 90vh ;
  display: flex;
  align-items: center;
}


/* Book Now button milenia style override */
.milenia-btn--primary {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    border-radius: 12px !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    letter-spacing: 1px;
    font-size: 1rem !important;
    line-height: 1.2rem;
    padding-left: 2.7rem !important;
    padding-right: 2.7rem !important;
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

/* Hover effect like your screenshot */
.milenia-btn--primary:hover {
    background: rgba(255, 255, 255, 0.25) !important;
    color: #ffffff !important;
}

.content-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  text-align: center;
}

/* Paragraph */
.para-colour-adjust {
  font-size: 14px;
  margin: 30px auto;
  max-width: 750px;
  text-align: center !important;
  color: #ffffff !important;
}

/* Background image */
.milenia-colorizer-bg-image {
  background-position: center center !important;
  background-size: cover !important;
}

@media (max-width: 991px) {

  .milenia-section--stretched {
    min-height: 1vh;
    padding: 30px 30px;
  }

  .milenia-section-title {
    font-size: 44px !important;
  }

  .para-colour-adjust {
    font-size: 14px;
    max-width: 90%;
  }
}
@media (max-width: 767px) {

  .milenia-section--stretched {
    min-height: auto;
    padding: 10px 10px;
  }

  .milenia-section-title {
    font-size: 30px !important;
    line-height: 1.3;
  }
  .milenia-section-subtitle{
    font-size: 14px !important;
  
    
  }

  .para-colour-adjust {
    font-size: 13px;
    line-height: 1.7;
    margin: 20px auto;
    max-width: 100%;
  }

  /* Button mobile sizing */
  .milenia-btn--primary {
    font-size: 0.9rem !important;
    padding: 0.9rem 2.2rem !important;
  }

  .milenia-colorizer-bg-image {
    background-position: center top !important;
  }
}
@media (max-width: 480px) {

  .milenia-section-title {
    font-size: 22px;
  }

  .para-colour-adjust {
    font-size: 12.5px;
  }

  .milenia-btn--primary {
    width: 100%;
    max-width: 280px !important;
  }
}



/* home map  start*/
.get-in-touch-section {
    padding: 40px 20px;
    background: #fff;

}

.container-custom {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 40px;
}

.left-content {
    width: 40%;
    padding-left: 50px;
}

.right-map {
  width: 60%;
  height: 500px;
  border-radius: 16px;        /* smooth corners */
  overflow: hidden;
  padding: 10px;              /* 🔥 main fix */
  background: #f5f5f5;        /* subtle frame */
  box-sizing: border-box;
}


.title {
    font-size: 50px;
    font-weight: 700;
    margin-bottom: 20px;
    color: #00968d;
}

.left-content p {
    font-size: 14px;

    line-height: 1.8;
    margin-bottom: 5px;
    color: #00968d;
}

.social-icons a {
    margin-right: 20px;
    font-size: 26px;
    color: #00968d;
    text-decoration: none;
}

.social-icons a:hover {
    color: #00968d;
}

/* Responsive */
@media (max-width: 900px) {
    .container-custom {
        flex-direction: column;
    }
    .left-content, .right-map {
        width: 100%;
        padding-left: 0;
    }
    .left-content p{
      margin-bottom: 0;
    }
    .right-map {
        height: 350px;
    }
    .title{
        font-size: 40px;
    }
    .social-icons {
    display: flex;
    justify-content: center;   /* 🔥 center horizontally */
    align-items: center;
    gap: 22px;                 /* margin-right replace */
  }

  .social-icons .social-icon {
    margin-right: 0;           /* old margin remove */
  }
    
}
@media (max-width: 767px) {
  .social-icons {
    display: flex;
    justify-content: center;   /* 🔥 center horizontally */
    align-items: center;
    gap: 22px;                 /* margin-right replace */
  }

  .social-icons .social-icon {
    margin-right: 0;           /* old margin remove */
  }
}

.social-icons {
    margin-top: 25px;

}

.social-icons .social-icon {
    display: inline-block;
    margin-right: 20px;
    font-size: 28px;
    color: #00968d !important;
    transition: 0.3s ease;
}

.social-icons .social-icon:hover {
    color: #00968d !important;
    transform: translateY(-2px);
}

.right-map iframe {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 12px;        /* inner curve */
}



/* FAQ START  */

.faq-section {
    padding: 30px 0;
    text-align: center;
}

.faq-title {
    font-size: 50px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #00968d;
}

.faq-divider {
    width: 300px;
    height: 1px;
    background: rgba(138, 71, 243, 1);
    margin: 0 auto 40px;
}

.faq-container {
    width: 70%;
    margin: auto;
}

.faq-item {
    border-bottom: 1px solid #ddd;
    cursor: pointer;
}

.faq-question {
    width: 100%;
    padding: 18px 0;
    text-align: left;
    font-size: 16px;
    background: none;
    border: none;
    outline: none;
    cursor: pointer;
    position: relative;
    color: #00968d;
}
.faq-question {
  position: relative;
  padding-right: 30px; /* 🔥 icon ke liye space */
}
.faq-icon {
    position: absolute;
    right: 0;
    top: 18px;
    font-size: 22px;
    transition: 0.3s;
}

.faq-answer {
    display: none;
    background: #f6f6f6;
    padding: 15px 20px;
    text-align: left;
    font-size: 16px;
   color: #00968d;
}


/* ===============================
   AWARDS SECTION
================================ */
.awards-section {
    padding: 30px 0 80px;
    background: #fff;
}

.awards-title {
    font-weight: 700;
    letter-spacing: 2px;
    margin-bottom: 1rem !important;
    font-size: 50px;
    color: #00968d;
}

/* Divider */
.awards-divider {
    width: 300px;
    height: 1px;
    background-color: rgba(138, 71, 243, 1);
    margin: 0 auto 60px;
}

/* GRID */
.awards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 👈 3 in one row */
    gap: 10px 15px;
    justify-items: center;
    align-items: center;
}

/* Each award */
.award-item img {
    max-width: 290px;
    width: 100%;
    height: auto;
}

/* Tablet */
@media (max-width: 991px) {
    .awards-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 60px 40px;
    }
}

/* Mobile */
@media (max-width: 576px) {
    .awards-grid {
        grid-template-columns: repeat(2, 1fr); /* ✅ 2 per row */
        gap: 30px 20px;
    }

    .award-item img {
        max-width: 160px;
    }
}



.milenia-footer-row {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}




/* FOOTER START  */
/* =========================================
   OCEANPHERE CENTER FOOTER
   Theme-safe (Milenia compatible)
========================================= */

/* FORCE PERFECT CENTER ALIGNMENT */

.ocean-footer-center,
.ocean-footer-center * {
  text-align: center !important;
}

.ocean-footer-content {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.ocean-footer-content p {
  width: 100%;
  text-align: center;
}


.ocean-footer-content {
  max-width: 800px;
  margin: 0 auto;
}

.ocean-footer-content p {
  margin-bottom: 12px;
  font-size: 15px;
  color: #ffffff;
}

.ocean-footer-content strong {
  color: #ffffff !important;
  font-weight: 500;
}

.ocean-footer-content a {
  color: #ffffff !important;
  text-decoration: none;
}

.ocean-footer-content a:hover {
  color: #ffffff;
}

/* Address spacing */
.ocean-footer-address {
  margin-top: 18px;
}

/* Social icons */
.ocean-footer-social {
  margin-top: 22px;
}

.ocean-footer-social a {
  display: inline-block;
  margin: 0 10px;
  font-size: 18px;
  color: #fff;
  transition: color 0.3s ease;
}

.ocean-footer-social a:hover {
  color: #ffffff;
}
.milenia-footer .milenia-colorizer--scheme-dark {
  background-color: #00968d !important;
}

/* Footer bottom credit text white */
.milenia-footer-row--thin .milenia-widget {
  color: #ffffff !important;
}

 /* pool-villas-section start */

 /* ===============================
   POOL VILLAS SECTION
================================ */


.pool-villas-section {
  padding: 40px 0 60px;
  background-color: #ffffff;
}

.container-pool{
  max-width: 1600px !important;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

.pool-villas-title {

  font-size: 70px;
  font-weight: 700;
  letter-spacing: 6px;
  text-transform: uppercase;
  color: #00968d;
  margin-bottom: 12px;
}

.pool-villas-divider {
  display: block;
  width: 300px;
  height: 1px;
  background-color: #7a4cff; /* thin red line */
  margin-bottom: 30px;
}

.pool-villas-description {
  width: 100%;
     margin-bottom: 15px;
  font-size: 16px;
  line-height: 1.8;
  color: #00968d;
}
.pool-villas-section h5 {
  font-size: 30px;
  font-weight: 600;
  margin-bottom: 8px;
  color: #00968d
}




@media (max-width: 991px) {
  .pool-villas-title {
    font-size: 40px !important;
  }
  .pool-villas-description {
  
  font-size: 14px;
  
  color: #00968d;
}
}


@media (max-width: 767px) {
  .pool-villas-title {
    font-size: 40px !important;
  }
  .pool-villas-description {
  
  font-size: 14px;
  
  color: #00968d;
}
}











/* ===============================
   POOL VILLAS SECTION
================================ */
.pool-villas-header {
  max-width: 900px;
  margin: 0 auto 60px;
}

.pool-villas-title {
  font-size: 70px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #00968d;
  margin-bottom: 12px;
}

.pool-villas-line {
  display: block;
  width: 80px;
  height: 2px;
  background: #c89b6d;
  margin: 20px auto;
}

.pool-villas-desc {
  font-size: 15px;
  line-height: 1.8;
  color: #666;
}

/* Grid */
.pool-villas-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.pool-villa-item {
  position: relative;
  overflow: hidden;
}

.pool-villa-item img {
  width: 100%;
  display: block;
}

/* Overlay */
.villa-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.85);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  opacity: 0;
  transition: 0.3s ease;
  text-align: center;
}

.pool-villa-item:hover .villa-overlay {
  opacity: 1;
}

.villa-overlay h4 {
 
  margin-bottom: 10px;
  font-family: "Montserrat", Arial, sans-serif;
    font-size: 26px;
}
.villa-overlay {
  pointer-events: none;
}

.villa-overlay .villa-link {
  pointer-events: auto;
  color: #000;
}


.villa-link {
  font-size: 12px;
 
  text-decoration: none;
  color: #000;
  position: relative;
}

.villa-link::after {
  content: " →";
  
}

/* Responsive */
@media (max-width: 768px) {
  .pool-villas-grid {
    grid-template-columns: 1fr;
  }
}







/* ===============================
   POOL VILLAS – TEXT SECTION STYLE
================================ */


.pool-villas-info {
  padding: 30px 0;

}

.offer-container{
  width: 100%;
  max-width: 1200px;
  margin: auto;
}

.pool-villas-info-title {
  font-size: 50px;
  font-weight: 700;
  letter-spacing: 2px;
  margin-bottom: 18px;
  color: #00968d;
}

.pool-villas-info-line {
  display: block;
  width: 20%;
  /* max-width: 520px; */
  height: 1px;
  background-color: #7a4cff; /* red line */
  margin-bottom: 35px;
}

.pool-villas-info-text p {
  font-size: 14px;
  line-height: 1.9;
  color: #00968d;
  margin-bottom: 10px;
  width: 100%;
}

/* Responsive */
@media (max-width: 768px) {
  .pool-villas-info-title {
    font-size: 36px;
  }

  .pool-villas-info-line {
    max-width: 100%;
  }
}

@media (min-width: 1400px) {
  .pool-villas-section .container {
    max-width: 1600px !important;
  }
}






/* villa file  */


/* ==============================
 DELUXE ROOM START
================================ */

.villa-feature-section {
  width: 100%;
  margin: 10px 0
}

.villa-feature-bg,
.villa-feature-right-bg {
  background-size: cover;
  background-position: center center;
}
.villa-feature-bg {
  position: relative;
  min-height: 895px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
}

/* White content box */
.villa-feature-overlay {
  background: rgba(255, 255, 255, 0.92);
  max-width: 694px;
  padding: 100px 50px;
  margin-left: auto;
  margin-right: 10%;
  text-align: center;
}

/* Title */
.villa-feature-title {
  font-size: 30px;
  letter-spacing: 3px;
  font-weight: 700;
  margin-bottom: 16px;
  color: #00968d;
}

/* Red divider */
.villa-feature-line {
  display: block;
  width: 250px;
  height: 1px;
  background: #7a4cff;
  margin: 0 auto 24px;
}

/* Paragraph */
.villa-feature-text {
  font-size: 14px;
  line-height: 1.8;
  color: #009688;
  margin-bottom: 28px;
  margin: 0 20px;
  text-align: justify;
}

/* Text button */
.villa-feature-link {
  font-size: 13px;
  letter-spacing: 1px;
  color: #00968d !important;
  text-decoration: none;
  transition: color 0.3s ease;
}

.villa-feature-link:hover {
  color: #7a4cff !important;
}

/* ==============================
   RESPONSIVE
================================ */
@media (max-width: 991px) {
  .villa-feature-bg {
    justify-content: center;
  }

  .villa-feature-overlay {
    margin: 0 20px;
    padding: 40px 30px;
  }
}
/* ==============================
 DELUXE ROOM END
================================ */

/* ======================================
    EXECUTIVE SEAVIEW  START
====================================== */

.villa-feature-right-section {
  width: 100%;
}

/* Background image wrapper */
.villa-feature-right-bg {
  position: relative;
  min-height: 895px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
}

/* ===== PERFECT OVERLAY (LOOK SAME) ===== */
.villa-feature-right-overlay {
  background: rgba(255, 255, 255, 0.92);   /* SAME opacity */
  max-width: 694px;                        /* SAME width */
  padding: 100px 50px;                     /* SAME padding */

  /* 🔥 ONLY POSITION CHANGE */
  margin-right: auto;
  margin-left: 10%;

  text-align: center;
}

/* Title */
.villa-feature-right-title {
 
  font-size: 30px;              /* SAME */
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 16px;
  color: #00968d;
}

/* Divider */
.villa-feature-right-line {
  display: block;
  width: 250px;
  height: 1px;
  background: #7a4cff;
  margin: 0 auto 24px;
}

/* Paragraph */
.villa-feature-right-text {
  font-size: 14px;              /* SAME */
  line-height: 1.8;
  color: #00968d;
  margin-bottom: 28px;
  margin: 0 20px;
  text-align: justify !important;
}

/* Link */
.villa-feature-right-link {
  font-size: 13px;
  letter-spacing: 1px;
  color: #00968d !important;
  text-decoration: none;
  transition: color 0.3s ease;
}

.villa-feature-right-link:hover {
  color: #7a4cff !important;
}

/* ======================================
   RESPONSIVE – PERFECT
====================================== */

@media (max-width: 991px) {
  .villa-feature-right-bg {
    justify-content: center;
  }

  .villa-feature-right-overlay {
    margin: 0 20px;
    padding: 40px 30px;
    max-width: 100%;
  }
}

@media (max-width: 576px) {
  .villa-feature-right-title {
    font-size: 26px;
  }
}

/* ======================================
    EXECUTIVE SEAVIEW  END
====================================== */




/* ===============================
   POOL FEATURE – LAYOUT
================================ */

.pool-feature-section {
  padding: 20px 0;
  overflow: hidden;
}

.pool-feature-row {
  display: flex;
  align-items: center;
}

/* Image – FULL BLEED */
.pool-feature-image {
  width: 70%;
  min-height: 520px;
  background-size: cover;
  background-position: center;
}

/* Content */
.pool-feature-content {
  width: 30%;
  padding: 0 80px;
}

/* Typography */
.pool-feature-title {
  font-size: 38px;
  letter-spacing: 6px;
  font-weight: 400;
  margin-bottom: 30px;
}

.pool-feature-content p {
  font-size: 15px;
  line-height: 1.8;
  color: #555;
  margin-bottom: 22px;
}

.pool-hours {
  margin-top: 30px;
  font-size: 14px;
  color: #222;
}

/* ===============================
   SUBTLE ANIMATION (NO LIB)
================================ */

.animate-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.animate-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ===============================
   RESPONSIVE
================================ */

@media (max-width: 991px) {
  .pool-feature-row {
    flex-direction: column;
  }

  .pool-feature-image {
    width: 100%;
    min-height: 380px;
  }

  .pool-feature-content {
    width: 100%;
    padding: 50px 25px;
  }
}




/* ===============================
   POOL FEATURE – LAYOUT
================================ */

.pool-feature-section {
  width: 100%;
  background: #ffffff;
}

.pool-feature-row {
  display: flex;
  min-height: 520px; /* EXACT controlled height */
}

/* LEFT IMAGE */
.pool-feature-image {
  width: 65%;
 
  background-size: cover;        /* image repeat nahi hogi */
  background-position: center;   /* crop natural rahe */
  background-repeat: no-repeat;
}

.pool-feature-image {
   background-image: url("../images/play/pool.webp"); /* CHANGE IMAGE PATH */
}

/* RIGHT CONTENT */
.pool-feature-content {
  width: 35%;
  padding: 40px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* TEXT STYLING */
.pool-title {
  font-size: 42px;
  letter-spacing: 4px;
  margin-bottom: 25px;
}

.pool-feature-content p {
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 18px;
  color: #555;
}

.pool-hours {
  margin-top: 10px;
  font-size: 14px;
}


@media (max-width: 991px) {
  .pool-feature-row {
    flex-direction: column;
  }

  .pool-feature-image,
  .pool-feature-content {
    width: 100%;
  }

  .pool-feature-image {
    height: 280px;
  }

  .pool-feature-content {
    padding: 40px 25px;
  }
}

.reveal-image {
  opacity: 0;
  transform: scale(1.05);
  animation: imageReveal 1.4s ease forwards;
}

@keyframes imageReveal {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.reveal-content {
  opacity: 0;
  transform: translateX(40px);
  animation: contentReveal 1.2s ease forwards;
  animation-delay: 0.4s;
}

@keyframes contentReveal {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}


/* ===== INITIAL (page load) ===== */
.js-reveal-image {
  opacity: 0;
  transform: scale(1.06);
  transition: opacity 1.4s ease, transform 1.4s ease;
}

.js-reveal-content {
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 1.2s ease, transform 1.2s ease;
}

/* ===== WHEN SECTION IS IN VIEW ===== */
.js-reveal-section.is-visible .js-reveal-image {
  opacity: 1;
  transform: scale(1);
}

.js-reveal-section.is-visible .js-reveal-content {
  opacity: 1;
  transform: translateX(0);
  transition-delay: 0.3s;
}

.pool-feature-image {
  position: relative;
  overflow: hidden;
}

/* fake image layer */
.pool-feature-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: inherit;
  background-size: cover;
  background-position: center;
  transition: transform 1.2s ease;
  z-index: 0;
}

/* hover zoom */
.pool-feature-section:hover .pool-feature-image::before {
  transform: scale(1.03);
}


/* villa fully responsive code end here  */
@media (max-width: 767px) {

  /* RESET LAYOUT */
  .villa-feature-bg,
  .villa-feature-right-bg {
    min-height: auto;
    flex-direction: column;
    align-items: stretch;
    background-image: none !important;
  }

  /* IMAGE BLOCK */
  .villa-feature-bg::before,
  .villa-feature-right-bg::before {
    content: "";
    width: 100%;
    height: 260px;
    display: block;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }

  /* ✅ INDIVIDUAL IMAGES (PER SECTION) */
  .villa-img-private::before {
    background-image: url('../images/sea-home/DELUXE-ROOM.webp');
  }

  .villa-img-duplex::before {
    background-image: url('../images/sea-home/EXECUTIVE-SEAVIEW.webp');
  }

  .villa-img-two-bedroom::before {
    background-image: url('../images/sea-home/CLASSIC-SUITE.webp');
  }

  .villa-img-four-bedroom::before {
    background-image: url('../images/sea-home/Classic-Suite-Seaview.webp');
  }

  /* CONTENT */
  .villa-feature-overlay,
  .villa-feature-right-overlay {
    position: static;
    max-width: 100%;
    margin: 0;
    padding: 30px 22px;
    background: #ffffff;
    text-align: center;
  }

  /* TEXT */
  .villa-feature-title,
  .villa-feature-right-title {
    font-size: 24px;
    letter-spacing: 2px;
    font-weight: 700;
  }

  .villa-feature-text,
  .villa-feature-right-text {
    font-size: 13px;
    line-height: 1.7;
    margin: 0;
    text-align: center;
  }

  .villa-feature-line,
  .villa-feature-right-line {
    width: 140px;
  }
}


 /* OCEAN FIT start   */

.pool-image-ocean {
  background-image: url("../images/building/banner1.jpg");
}
.pool-feature-switch .pool-feature-row {
  flex-direction: row-reverse;
}

/* mobile behaviour SAME rahe */
@media (max-width: 991px) {
  .pool-feature-switch .pool-feature-row {
    flex-direction: column;
  }
}
/* ACTIVITIES IMAGE */
.pool-image-activities {
  background-image: url("../images/play/Buggy.webp");
}
@media (max-width: 991px) {
  .pool-image-activities {
    flex-direction: column;
  }}

/* POOL IMAGE */
.pool-image-ocean  {
  background-image: url("../images/play/playgym.webp");
}




   /* =================
   OCEAN SPA – FULL BLEED 
   ======================*/

.spa-feature-section {
  width: 100%;
  background: #ffffff;
   padding: 30px 0;
  overflow: hidden;
}

.spa-feature-row {
  display: flex;
  min-height: 520px;
}

/* IMAGE */
.spa-feature-image {
  width: 65%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}


/* CONTENT */
.spa-feature-content {
  width: 35%;
  padding: 40px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* TEXT */
.spa-title {
  font-size: 42px;
  letter-spacing: 4px;
  margin-bottom: 25px;
}

.spa-feature-content p {
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 18px;
  color: #555;
}

.spa-hours {
  margin-top: 10px;
  font-size: 14px;
}





@media (max-width: 991px) {
  
  .spa-feature-row {
    flex-direction: column;
  }

  .spa-feature-image {
    width: 100% !important;
    height: 320px;          /* ✅ KEY LINE */
    min-height: 320px;
  }

  .spa-feature-content {
    width: 100%;
    padding: 40px 25px;
  }

  .spa-feature-image,
  .spa-feature-content {
    width: 100%;
  }
 .spa-feature-image {
    width: 100vw;              /* full screen width */
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    height: 320px;
    min-height: 320px;
  }
  
}
@media (max-width: 576px) {

  .spa-feature-image {
    height: 260px;          /* mobile friendly */
    min-height: 260px;
  }
}

.spa-feature-image {
  position: relative;
  width: 65%;
  overflow: hidden;
}

/* image layers */
.spa-feature-image .spa-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  animation: spaFade 9s infinite;
}

/* images */
.spa-feature-image .img1 {
  background-image: url("../images/relax/CROSS-SPA.webp");
  animation-delay: 0s;
  opacity: 1; /* page load pe first visible */
}

.spa-feature-image .img2 {
  background-image: url("../images/relax/CROSS-SPA-2.webp");
  animation-delay: 3s;
}

.spa-feature-image .img3 {
  background-image: url("../images/relax/CROSS-Spa3.webp");
  animation-delay: 6s;
}

@keyframes spaFade {
  0%   { opacity: 0; }
  10%  { opacity: 1; }
  30%  { opacity: 1; }
  40%  { opacity: 0; }
  100% { opacity: 0; }
}
.spa-feature-image .spa-img {
  animation-timing-function: ease-in-out;
}


/* ===============================
   SPA SPECIAL – STYLE
================================ */

.spa-special-section {
  width: 100%;
  background: #ffffff;
  padding: 20px 20px 80px;
}

.spa-special-inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}

/* HEADING */
.spa-special-title {
  font-size: 30px;
  letter-spacing: 4px;
  font-weight: 400;
  margin-bottom: 25px;
  color: #555;
}

/* PARAGRAPH */
.spa-special-text {
  font-size: 16px;
  line-height: 1.8;
  color: #777;
  
}
@media (max-width: 768px) {
  .spa-special-title {
    font-size: 32px;
  }

  .spa-special-text {
    font-size: 15px;
    text-align: justify;
  }
}


/* ===============================
   SPA SPECIAL – IMAGE GRID
================================ */
.spa-special-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;

  width: 100%;
  max-width: 1510px;
  margin: 0 auto;

  padding: 60px 20px 20px;
  box-sizing: border-box;
}

.spa-special-item {
  position: relative;
  overflow: hidden;
  height: 470px;
}

.spa-special-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Overlay */
.spa-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  opacity: 0;
  transition: 0.3s ease;
  text-align: center;
  pointer-events: none;
}

.spa-special-item:hover .spa-overlay {
  opacity: 1;
}

.spa-overlay h4 {
  letter-spacing: 2px;
  margin-bottom: 10px;
  font-size: 16px;
}

.spa-overlay p {
  font-size: 14px;
  line-height: 1.5;
}


.fancybox-caption {
    bottom: 0;
    color: #fff;
    font-size: 14px;
    font-weight: 400;
    left: 0;
    line-height: 1.5;
    padding: 25px 44px;
    right: 0;
    text-align: center;
}

/* Responsive */
@media (max-width: 991px) {
  .spa-special-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .spa-special-item {
    height: 300px;
  }
}
.spa-special-item img {
  transition: transform 1.2s ease;
}

.spa-special-item:hover img {
  transform: scale(1.03);
}


/* pool  */
 .new-bg-colour{
  background-color: #5d5d5d !important;
}


.colour-white{
  color: #f2f2ed;
}
.pool-para-color{
  color: #f2f2ed;
}



/* =========================
   HERO SLIDER PARALLAX
========================= */

#seoHero {
  position: relative;
  overflow: hidden;
}

.hero-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* .hero-slide img {
  width: 100%;
  height: 110%; 
  object-fit: cover;
  transform: translateY(0);
  transition: transform 0.1s linear;
  will-change: transform;
} */

.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  will-change: transform;
  transform: translate3d(0,0,0);
  backface-visibility: hidden;
}


/* Active slide only */
.hero-slide:not(.active) {
  opacity: 0;
  pointer-events: none;
}

/* Optional overlay */
.hero-overlay {
  position: absolute;
  inset: 0;
 
  z-index: 2;
}
@media (min-width: 992px) {
  .hero-slide img {
    height: 100%;
  }
}




/* ===============================
   OCEAN BISTRO – LAYOUT start
================================ */
.bistro-section {
  padding: 40px;
  background: #fff;
  padding-bottom: 50px;
}

.bistro-row {
  max-width: 1500px;
  margin: auto;
  display: grid;
  grid-template-columns: 0.9fr 1.6fr; /* 🔥 BIG IMAGE MORE SPACE */
  align-items: center;
}


/* LEFT WHITE BOX */
.bistro-content {
  background: #fff;
  padding: 15px 60px;
  margin-right: -60px; /* 🔥 little more overlap */
  z-index: 2;
  box-shadow: 0 30px 70px rgba(0,0,0,1.08);
  border: 1px solid;
  border-radius: 25px;
}


.bistro-content h2 {
  font-family: "Playfair Display", serif;
  font-size: 36px;
  margin-bottom: 30px;
}

.bistro-content p {
  line-height: 1.8;
  color: #555;
}

/* RIGHT IMAGE AREA */
.bistro-media {
  position: relative;
}

/* BIG IMAGE – NATURAL */
.bistro-big {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 1199px) {
.bistro-section {
    padding: 40px 0;
            padding-bottom: 200px;
  }

  .bistro-row {
    grid-template-columns: 1fr;
    gap: 60px;
  }

  .bistro-content {
    margin-right: 0;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
  }

  .bistro-media {
    max-width: 900px;
    margin: auto;
  }

 
}
@media (max-width: 767px) {

  .bistro-section {
    padding: 40px 0;
  }

  .bistro-row {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  /* CONTENT */
  .bistro-content {
    padding: 40px 30px;
    margin: 0;
    box-shadow: none;
  }

  /* BIG IMAGE */
  .bistro-big {
    width: 100%;
    height: auto;
    display: block;
  }


}



/* ===============================
   CHILI BLUE POOL BAR – LAYOUT
================================ */


@media (min-width: 1200px) {

  .bistro-reverse .bistro-row {
    grid-template-columns: 1.6fr 0.9fr; /* image gets more space */
  }

  .bistro-reverse .bistro-media {
    order: 1; /* IMAGE FIRST */
  }

  .bistro-reverse .bistro-content {
    order: 2; /* CONTENT SECOND */
    margin-right: 0;
    margin-left: -60px; /* overlap from other side */
  }

}




/* dine image  start */
/* SECTION SPACING */
.triple-image-section {
  padding: 60px 0;            /* 🔥 top & bottom spacing */
  width: 100%;
}

/* GRID */
.triple-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.3fr;
  gap: 24px;                  /* 🔥 gap between images */
  height: 600px;
  padding: 0 40px;            /* 🔥 left-right breathing space */
}

/* IMAGE BOX */
.img-box {
  height: 100%;
  overflow: hidden;
}

.img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ===============================
   LEFT ➝ RIGHT SCROLL ANIMATION
================================ */
.reveal {
  opacity: 0;
  transform: translateX(-120px);  /* 🔥 LEFT se entry */
  transition: all 0.9s ease;
}

.reveal.active {
  opacity: 1;
  transform: translateX(0);
}

/* ONE BY ONE TIMING */
.img-1.active { transition-delay: 0.1s; }
.img-2.active { transition-delay: 0.3s; }
.img-3.active { transition-delay: 0.5s; }

/* ===============================
   MOBILE SLIDER
================================ */
@media (max-width: 991px) {

  .triple-grid {
    display: flex;               /* 🔥 slider */
    gap: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    height: auto;
    padding: 0 0px 20px;
  }

  .img-box {
    flex: 0 0 100%;               /* 🔥 one image at a time */
    scroll-snap-align: start;
    height: auto;
  }

  .img-box img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    border-radius: 6px;
  }

  /* hide scrollbar */
  .triple-grid::-webkit-scrollbar {
    display: none;
  }
}






/* ===============================
   MEETING ROOM SECTION
================================ */

/* SECTION */
.meeting-feature-section {
  width: 100%;
  background: #ffffff;
  padding: 40px 0;
}

/* ROW */
.meeting-feature-row {
  display: flex;
  min-height: 520px;
}

/* IMAGE SIDE */
.meeting-feature-image {
  width: 65%;
  background-image: url("../images/meeting/meeting-room.webp"); /* change path */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* CONTENT SIDE */
.meeting-feature-content {
  width: 35%;
  padding: 40px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* TEXT */
.meeting-title {
  font-size: 40px;
  letter-spacing: 3px;
  margin-bottom: 22px;
}

.meeting-feature-content p {
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 18px;
  color: #555;
}

.meeting-hours {
  margin-top: 10px;
  font-size: 14px;
}

/* RESPONSIVE */
@media (max-width: 991px) {
  .meeting-feature-row {
    flex-direction: column;
  }

  .meeting-feature-image,
  .meeting-feature-content {
    width: 100%;
  }

  .meeting-feature-image {
    height: 280px;
  }

  .meeting-feature-content {
    padding: 40px 25px;
  }

  .meeting-title{
    font-size: 32px;
  }
}









/* Booking Inquiry Section */
/* Booking Inquiry Section */
.booking-inquiry-section {
  padding: 70px 0;
  background: #fff;
}

.booking-inquiry-container {
  max-width: 520px;
  margin: 0 auto;
}

.booking-title {
  text-align: center;
  font-size: 30px;
  letter-spacing: 3px;
  margin-bottom: 40px;
  color: #484848;
}

/* Fields */
.booking-field {
  margin-bottom: 22px;
}

.booking-field label {
  display: block;
  font-size: 14px;
  margin-bottom: 6px;
}

/* Inputs & Select */
.booking-field input,
.booking-field textarea,
.booking-field select {
  width: 100%;
  border: none;
  border-bottom: 1px solid #000;
  background: transparent;
  font-size: 14px;
  padding: 6px 0;
  appearance: none;
}

.booking-field select {
  cursor: pointer;
}

/* Focus */
.booking-field input:focus,
.booking-field textarea:focus,
.booking-field select:focus {
  outline: none;
  border-bottom-color: #a67c52;
}

/* Submit */
.booking-submit {
  margin-top: 35px;
  text-align: center;
}

.booking-send {
  background: none;
  border: none;
  font-size: 14px;
  letter-spacing: 2px;
  cursor: pointer;
  padding: 0;
}

.booking-send:hover {
  text-decoration: underline;
}



/* ================= LOCATION SECTION ================= */

.location-section {
  padding: 40px 0 50px;
}

.location-title {
  font-size: 60px;
  letter-spacing: 6px;
  margin-bottom: 25px;
  font-weight: 400;
  color: #484848;
}

.location-text {
  max-width: 900px;
  margin: 0 auto;
  font-size: 14px;
  line-height: 1.8;
  text-align: justify;
  color: #5d5d5d;
}

/* ================= MAP SECTION ================= */

.location-map-section {
  padding-bottom: 80px;
}

.map-wrapper {
  width: 100%;
  height: 500px;
}

.map-wrapper iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

/* ================= RESPONSIVE ================= */

@media (max-width: 991px) {
  .location-title {
    font-size: 36px;
    letter-spacing: 4px;
  }

  .map-wrapper {
    height: 400px;
  }
}

@media (max-width: 575px) {
  .location-section {
    padding: 60px 15px 40px;
  }

  .location-title {
    font-size: 28px;
    letter-spacing: 3px;
  }

  .location-text {
    font-size: 15px;
  }

  .map-wrapper {
    height: 320px;
  }
}


/* ================= CONTACT INFO LINE ================= */

.contact-info-line {
  padding: 40px 0;
}

/* Shared centered width */
.contact-center {
  max-width: 900px;
  margin: 0 auto;
  text-align: center; /* THIS is the key fix */
}


/* Line */
.info-divider {
  width: 100%;
  height: 1px;
  background-color: #910919;
  margin-bottom: 35px;
}

/* Text */
.info-text p {
  margin: 8px 0;
  font-size: 14px;
  color: #5d5d5d;
  letter-spacing: 0.3px;
  text-align: center;
}

.info-text a {
  color: inherit;
  text-decoration: none;
}

.info-text a:hover {
  text-decoration: underline;
}

/* ================= RESPONSIVE ================= */

@media (max-width: 768px) {
  .contact-info-line {
    padding: 60px 15px;
  }

  .contact-center {
    max-width: 100%;
  }

  .info-text p {
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .info-text p {
    font-size: 13.5px;
    line-height: 1.6;
  }
}









/* ================= MOBILE & TABLET SIDEBAR FIX ================= */

@media (max-width: 991px) {

  /* Sidebar takes full screen */
  .milenia-sidebar-hidden {
    height: 100vh;
    overflow: hidden;
  }

  /* Header stays fixed height */
  .milenia-sidebar-hidden-header {
    flex-shrink: 0;
  }

  /* Footer stays fixed height */
  .milenia-sidebar-hidden-footer {
    flex-shrink: 0;
  }

  /* Scrollable navigation area */
  .milenia-sidebar-hidden-content {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Remove fixed height (THIS fixes clipping) */
  .milenia-sidebar-hidden-content 
  .milenia-navigation-container {
    height: auto;
    max-height: none;
  }

  /* Navigation spacing */
  .milenia-navigation-vertical > li {
    padding: 12px 0;
  }

  /* Bigger touch targets */
  .milenia-navigation-vertical a {
    font-size: 16px;
    padding: 10px 0;
  }

  /* Close button visible */
  .milenia-sidebar-hidden-close {
    display: block;
    position: absolute;
    top: 20px;
    right: 20px;
    z-index: 10;
  }
}




@media (max-width: 767px) {
  .milenia-navigation-vertical {
    text-align: center;
  }
}
.milenia-navigation-vertical a {
  letter-spacing: 1px;
  text-transform: uppercase;
}






/* =====================================
   USE FONT AWESOME FOR BOOKING ICONS
   (NO NEW LINKS)
===================================== */

/* Calendar icon */
.milenia-field-datepicker::after {
  content: "\f073"; /* fa-calendar */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  color: #00968d;
  pointer-events: none;
  opacity: 1;
}

/* Plus icon */
.milenia-field-counter-control--increase::before {
  content: "\f067"; /* fa-plus */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: #00968d;
}

/* Minus icon */
.milenia-field-counter-control--decrease::before {
  content: "\f068"; /* fa-minus */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: #00968d;
}

/* Clean buttons */
.milenia-field-counter-control {
  background: none;
  border: none;
  min-width: 28px;
  min-height: 28px;
}








   /* PRIVATE POOL VILLA  */


.features {
  list-style: none;   /* dash / bullet remove */
  padding-left: 0;    /* left gap bhi remove */
  margin: 0;
  font-size: 14px;
  padding-bottom: 1vw;
}


/* Amenities grid spacing */
.amenities-grid {
  margin-top: 60px;
}

/* Single amenity item */
.amenity-item {
  margin-bottom: 50px;
}

/* Icons */
/* Force outline icons to pure black */
.amenity-item i {
  font-size: 42px;
  display: block;
  margin-bottom: 14px;
  color: #00968d !important;   /* solid black */
  opacity: 1 !important;   /* no fading */
}
.amenity-item i {
  -webkit-text-stroke: 0.4px #00968d; /* outline thicken */
}


/* Text */
.amenity-item p {
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 0;
  color: #00968d;
}

/* Back link */
.back-to-villas {
  margin-top: 40px;
  color: #00968d;
}

.back-to-villas a {
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #00968d;
  text-decoration: none;
  transition: color 0.3s ease;
}

.back-to-villas a:hover {
  color: #00968d;
}
.amenity-svg {
  width: 42px;
  height: 42px;
  margin: 0 auto 14px auto; /* 👈 horizontally center */
  display: block;
  color: #00968d;
}

 /* FULLSCREEN VILLA SLIDER  */
.fullscreen-villa-slider {
  position: relative;
  width: 100%;
  height: 90vh;
  overflow: hidden;
  padding: 0; /* ✅ remove padding */
}

/* SLIDES */
.villa-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transform: scale(1.05);
  transition: opacity 1.2s ease, transform 6s ease;
}

.villa-slide.active {
  opacity: 1;
  transform: scale(1);
}

/* OVERLAY */
.villa-slider-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  background: rgba(0,0,0,0.25);
  z-index: 2;
}

.villa-slider-overlay h2 {
  font-size: 42px;
  letter-spacing: 3px;
}
@media (max-width: 768px) {

  .fullscreen-villa-slider {
    height: 65vh; /* ✅ correct mobile height */
  }

  .villa-slide {
    background-position: center top; /* ✅ MOST IMPORTANT */
  }

  .villa-slider-overlay h2 {
    font-size: 26px;
    letter-spacing: 2px;
  }
}
@media (max-width: 480px) {
  .fullscreen-villa-slider {
    height: 60vh;
  }
}


/* EXPLORE MORE POOL VILLAS section start */

/* Grid layout */
.explore-villas-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 50px;
}

/* Image item */
.explore-villa-item {
  position: relative;
  overflow: hidden;
  aspect-ratio: 6 / 5;
}

.explore-villa-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* White overlay */
.explore-villa-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.88);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.4s ease;
  text-align: center;
}

/* Show overlay on hover */
.explore-villa-item:hover .explore-villa-overlay {
  opacity: 1;
}

/* Text */
.explore-villa-overlay h4 {
  font-size: 30px;
  letter-spacing: 1.5px;
  margin-bottom: 12px;
  color: #00968d;
}

.explore-villa-overlay a {
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none;
  color: #00968d !important;
  border-bottom: 1px solid #000;
  padding-bottom: 2px;
}

/* Hover effect on link */
.explore-villa-overlay a:hover {
  color: #2f7dc1;
  border-color: #2f7dc1;
}

/* Tablet */
@media (max-width: 992px) {
  .explore-villas-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile */
@media (max-width: 576px) {
  .explore-villas-grid {
    grid-template-columns: 1fr;
  }
}









/* GALLERY START  */
/* ===== Editorial Masonry (Premium Look) ===== */
.editorial-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 220px;
  gap: 28px;
  padding: 20px;

  /* THIS IS THE FIX */
  grid-auto-flow: dense;
}

.tile {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  background: #000;
}

.tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}

/* ONLY TWO SHAPES */
.tile.square {
  grid-row: span 2;
}

.tile.tall {
  grid-row: span 3;
}

/* luxury hover */
.tile:hover img {
  transform: scale(1.05);
}

/* responsive */
@media (max-width: 991px) {
  .editorial-gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .editorial-gallery {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 200px;
    gap: 20px;
    padding: 16px;
  }

  .tile.square {
    grid-row: span 2;
  }

  .tile.tall {
    grid-row: span 2; /* reduce height on tablets */
  }
}
@media (max-width: 576px) {
  .editorial-gallery {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    gap: 18px;
    padding: 14px;
  }

  .tile {
    aspect-ratio: 4 / 5; /* luxury editorial ratio */
  }

  .tile.square,
  .tile.tall {
    grid-row: auto; /* reset spans for clean stacking */
  }

  .tile img {
    height: 100%;
  }
}


/* ================= OFFER SECTION START================= */

.offer-heading{
  font-size: 30px;
  font-family: "Montserrat", Arial, sans-serif;
  text-align: center;
  color: #00968d;
  font-weight: 700;
}

@media (max-width: 991px ) {
  .offer-heading{
    font-size: 28px;

  }
 .ocean-lux-title {
 
  font-size: 36px !important;
  font-weight: 700;
  line-height: 1.2;
  color: #000;
  margin-bottom: 2px !important;

}

.ocean-lux-subtitle {
  position: relative;

  font-size: 36px !important;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #00968d;
  margin-bottom: 10px !important;
  font-weight: 600;
}

}

@media (max-width: 768px) {
  .offer-heading{
    font-size: 24px;

  }
 .ocean-lux-title {
 
  font-size: 36px !important;
  font-weight: 700;
  line-height: 1.2;
  color: #000;

}

.ocean-lux-subtitle {
  position: relative;

  font-size: 36px !important;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #00968d;
  margin-bottom: 35px;
  font-weight: 600;
}

}


/* new section  */
/* LEFT COLUMN */
.ocean-offer-left {
  position: relative;
  padding-right: 40px;
}

/* SAVE BADGE */
.ocean-offer-badge {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
}

.badge-text {
  background: #00968d;
  color: #fff;
  padding: 8px 14px;
  text-align: center;
}

.badge-text span {
  display: block;
  font-size: 18px;
  letter-spacing: 1px;
}

.badge-text strong {
  font-size: 18px;
  font-weight: 700;
}

.badge-icon {
  background: #4a4a4a;
  color: #fff;
  padding: 21px 23px;
  font-size: 25px;
}

/* TITLE */
.ocean-lux-title {
 
  font-size: 57px;
  font-weight: 700;
  line-height: 1.2;
  color: #000;
  margin-bottom: 10px;
}

/* SUBTITLE */
.ocean-lux-subtitle {
  position: relative;

  font-size: 57px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #00968d;
  margin-bottom: 35px;
  font-weight: 600;
}

/* underline accent */

/* BODY TEXT */
.ocean-lux-text {
  font-size: 15px;
  line-height: 1.8;
  color: #333;
  margin-bottom: 35px;
  max-width: 460px;
}

/* BUTTON */
.ocean-lux-btn {
  padding: 11px 53px !important;
    border-radius: 30px !important;
    margin-top: 2.25rem !important;
}

/* initial hidden state */
.ocean-animate-left,
.ocean-animate-right {
  opacity: 0;
  transition: all 0.9s ease;
}

/* left text */
.ocean-animate-left {
  transform: translateY(60px);
}

/* right image */
.ocean-animate-right {
  transform: translateX(80px);
}

/* when visible */
.ocean-animate-show {
  opacity: 1;
  transform: translate(0, 0);
}


/* for ul working in offer page*/
/* FORCE RESET bullets for this section only */
.ocean-offer-left ul {
  list-style: disc !important;
  padding-left: 20px !important;
  margin-left: 0 !important;
}

.ocean-offer-left ul li {
  list-style: disc !important;
  padding-left: 0 !important;
  position: relative;
}

/* KILL any custom bullet/square/icon */
.ocean-offer-left ul li::before,
.ocean-offer-left ul li::after {
  content: none !important;
  display: none !important;
}






/* MOBILE menu START */
/* ===== HEADER BASE ===== */

.op-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  z-index: 99999;
}


/* CENTERED CONTAINER (IMPORTANT) */
.op-header-inner {
  max-width: 1400px;        /* controls left-right balance */
  margin: 0 auto;          /* centers everything */
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;      /* natural spacing */
}

/* LOGO */
.op-logo {
  flex: 0 0 auto;
}

.op-logo img {
  height: 90px;            /* 120 was too big */
}

/* DESKTOP NAV */
.op-nav-desktop {
  flex: 1;
  display: flex;
  justify-content: center; /* menu perfectly centered */
}

.op-nav-desktop ul {
  display: flex;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.op-nav-desktop a {
  text-decoration: none;
  letter-spacing: 2px;
  font-size: 14px;
  color: #000;
}

/* RIGHT SIDE */
.op-right {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 35px;
}

.op-book {
  background: #00968d;
  color: #fff;
  padding: 14px 28px;
  border-radius: 30px;
  text-decoration: none;
  letter-spacing: 2px;
  white-space: nowrap;
}

/* MOBILE BUTTON */
.op-mobile-btn {
  display: none;
  width: 44px;
  height: 44px;
  border: none;
  background: #00968d;
  color: #fff;
}

/* MOBILE MENU */
.op-nav-mobile {
  display: none;
  background: #fff;
  border-top: 1px solid #eee;
}

.op-nav-mobile ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.op-nav-mobile li {
  border-bottom: 1px solid #eee;
  text-align: center;
}

.op-nav-mobile a {
  display: block;
  padding: 16px;
  letter-spacing: 2px;
}

/* ACTIVE */
body.op-mobile-open .op-nav-mobile {
  display: block;
}

body.op-mobile-open .op-mobile-btn i {
  transform: rotate(180deg);
}

/* RESPONSIVE */
@media (max-width: 991px) {
  .op-nav-desktop {
    display: none;
  }

  .op-mobile-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .op-header-inner {
    padding: 14px 18px;
  }

  .op-logo img {
    height: 70px;
  }
}
/* =========================================
   REMOVE ONLY THE HOVER LINE FROM LOGO
   (SAFE FIX – LOGO WILL NOT DISAPPEAR)
========================================= */

/* Milenia adds line using background-size animation on link */
.op-logo a {
  background-image: none !important;
  background-size: 0 0 !important;
}

/* On hover also kill it */
.op-logo a:hover {
  background-image: none !important;
  background-size: 0 0 !important;
}

/* Kill underline if any */
.op-logo a,
.op-logo a:hover {
  text-decoration: none !important;
  border-bottom: 0 !important;
}

/* Image must stay visible */
.op-logo img {
  display: block !important;
}


/* ---------------------------
   LOGO SWAP FIX (SAFE)
---------------------------- */

/* base */
.op-logo {
  position: relative;
}

/* default: show BLACK, hide WHITE */
.op-logo .logo-white {
  display: none !important;
}

.op-logo .logo-black {
  display: block !important;
}

/* TOP (transparent header) */
.op-header.at-top .op-logo .logo-black {
  display: none !important;
}

.op-header.at-top .op-logo .logo-white {
  display: block !important;
}




/* FIX: allow mobile scroll on sliders */
.owl-carousel,
.milenia-entity-media,
.milenia-entity-slide {
  touch-action: pan-y !important;
}


                                /* SEAPHARE START FROM HERE  */



/* Section */
.why-seaphere {
  padding: 80px 0;
  background: #ffffff;
}

.container {
  width: 100%;
  max-width: 1400px;
  margin: auto;
}

/* Title */
.why-title {
  text-align: center;
  font-size: 50px;
  font-weight: 700;
  letter-spacing: 2px;
  color: #009688;
  margin-bottom: 60px !important;
}

/* Grid */
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

/* Card */
.why-card {
  position: relative;
  min-height: 520px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
  color: #ffffff;
  overflow: hidden;
}

/* LIGHT COLOR OVERLAY */
.why-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}

/* Overlay colors */
.why-card.purple .why-overlay {
  opacity: 0.8 ;
  background-color: rgba(138, 71, 243, 1) ;
}
.why-card.blue .why-overlay {
  opacity: 0.8 ;
  background-color: rgba(14, 47, 185, 1) ;
}
.why-card.green .why-overlay {
  opacity: 0.8 ;
  background-color: rgba(0, 150, 141, 1) ;
}

/* Content */
.why-content {
  position: relative;
  z-index: 2;
  text-align: center;
      width: 100%;
    min-width: 405px;
    height: auto;
}

.why-content h3 {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 1px;
  margin-bottom: 20px;
  color: #ffffff;
}

.why-content p {
  font-size: 16px;
  line-height: 1.7;
  opacity: 0.95;
}

/* Responsive */
@media (max-width: 1024px) {
  .why-grid {
    grid-template-columns: 1fr;
  }

  .why-card {
    min-height: auto;
    padding: 60px 30px;
  }

  .why-title {
    font-size: 30px;
  }
  .why-content h3 {
  font-size: 24px;
  font-weight: 700;
  
  color: #ffffff;
}
  .why-content p {
  font-size: 14px;
  padding: 0px 25px;
  text-align: justify;
}
  .why-seaphere .container{
    
    padding-right: 0px;
    padding-left: 0px;
  }
}


/* new card section end  */
/* NEW START  */

/* MAIN SECTION */
.floating-image-section {
  position: relative;
  max-height: 485px;
  overflow: hidden;
}

/* FULL BACKGROUND GRADIENT */
.bg-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(
  90deg,
  #00968D 57%,
  #8A47F3 100%
);
  z-index: 1;
}

/* FLOATING IMAGE */
.floating-image {
  position: absolute;
  left: 7%;
  top: 0;
  bottom: 0;
  width: 27%;
  z-index: 2;

  clip-path: polygon(0 0, 75% 0, 100% 100%, 25% 100%);
}

.floating-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* CONTENT ON GRADIENT */
.floating-content {
  position: relative;
  z-index: 2;
  margin-left: 46%;
  padding: 90px 90px;
  display: flex;
  align-items: center;
  min-height: 520px;
}

.floating-content p {
  max-width: 620px;
  color: #ffffff;
  font-size: 16px;
  line-height: 1.8;
}

/* RESPONSIVE */
@media (max-width: 1024px) {

  .floating-image-section {
    min-height: 554px;
  }

  /* IMAGE STACKS ON TOP */
  .floating-image {
  position: relative;
  left: 25px;
  top: 25px;
  transform: none;
  width: 79%;
  height: 269px;
  clip-path: polygon(0 0, 75% 0, 100% 100%, 25% 100%);
  }

  .floating-image img {
    border-radius: 0;
  }

  /* TEXT BELOW IMAGE */
  .floating-content {
    margin-left: 0;
    padding: 40px 24px 60px;
    min-height: auto;
    text-align: left;
  }

  .floating-content p {
    font-size: 15px;
    line-height: 1.5;
    max-width: 100%;
    text-align: justify;
    margin-top: 25px;
  }
}


/* new END  */

/* dual-zoom-section START  */
/* ==============================
   DUAL IMAGE ZOOM SECTION
================================ */



.dual-zoom-section {
  display: flex;
  width: 100%;
  min-height: 520px;
  overflow: hidden;
}

/* BOTH HALVES */
.dual-half {
  position: relative;
  width: 50%;
  background-size: cover;
  background-position: center;
  overflow: hidden;

  animation: slowZoom 9s ease-in-out infinite alternate;
}

/* smooth zoom animation */
@keyframes slowZoom {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(1.08);
  }
}

/* WHITE OVERLAY BOX */
.dual-overlay-box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  
  background: rgba(255, 255, 255, 0.65);
  padding: 40px 50px;
  text-align: center;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.15);
}

/* TITLE */
.dual-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  letter-spacing: 4px;
  font-weight: 500;
  color: #111;
  margin-bottom: 18px;
}

/* BUTTON */
.dual-btn {
  display: inline-block;
  padding: 10px 26px;
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #111;
  border: 1px solid #111;
  transition: all 0.35s ease;
  border-radius: 25px;
}

.dual-btn:hover {
  background: #111;
  color: #fff;
  text-decoration: none;
}

/* RESPONSIVE */
@media (max-width: 991px) {
  .dual-zoom-section {
    flex-direction: column;
  }

  .dual-half {
    width: 100%;
    min-height: 420px;
  }

  .dual-overlay-box {
    padding: 30px 35px;
  }
}


.dual-zoom-heading {
  flex: 0 0 100%;     /* 👈 full width, top row */
  text-align: center;
  padding: 70px 0 40px;
}

.dual-zoom-title {
  font-size: 48px;
  font-weight: 300;
  letter-spacing: 6px;
  color: #111;
  margin-bottom: 18px;
}

/* Thin red underline */
.dual-zoom-divider {
  display: inline-block;
  width: 320px;
  height: 1px;
  background-color: #910919;
}

/* Responsive */
@media (max-width: 768px) {
  .dual-zoom-title {
    font-size: 32px;
    letter-spacing: 3px;
  }

  .dual-zoom-divider {
    width: 220px;
  }
}


/* dual-zoom-section END  */

/* DRINK and DINE SECTION START */
/* ================= DRINK & DINE SECTION ================= */
/* SECTION */
.drink-dine-section {
  padding: 60px 0;
  background: #fff;
}

/* HEADING */
.drink-dine-heading {
  text-align: left;
  max-width: 1200px;
  margin: 0 auto 60px;
  padding: 0 20px;
}

.drink-dine-heading h2 {
  font-size: 50px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #00968d;
}

.drink-dine-heading span {
  width: 25%;
  height: 2px;
  background: #7a4cff;
  display: block;
  margin-top: 10px;
}

/* WRAPPER */
.drink-dine-wrapper {
  max-width: 1200px;
  margin: auto;
  display: flex;
  gap: 40px;
  padding: 0 2px;
}

/* IMAGE BOX */
.dd-image {
  position: relative;
  width: 50%;
  height: 582px;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

/* RIGHT IMAGE (scroll movement base) */
.dd-right {
  transform: translateY(100px);
}

/* OVERLAY */
.dd-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 160, 170, 0.65); /* 👈 teal colour */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.4s ease;
}


.dd-overlay h3 {
  color: #fff;
  font-size: 32px;
  margin-bottom: 15px;
  font-weight: 700;
}

.dd-overlay a {
  color: #fff !important;
  border: 1px solid #fff;
  padding: 10px 28px;
  text-decoration: none;
  font-size: 14px;
  border-radius: 25px;
  font-weight: 700;
}

/* HOVER EFFECT */
.dd-image:hover .dd-overlay {
  opacity: 1;
}

/* =========================
   MOBILE RESPONSIVE ONLY
   (DESKTOP UNCHANGED)
========================= */
@media (max-width: 991px) {

  /* STACK LAYOUT */
  .drink-dine-wrapper {
    flex-direction: column;
    gap: 0;
  }

  /* IMAGE FULL WIDTH */
  .dd-image {
    width: 100%;
    height: 345px;
    overflow: visible; /* important */
  }

  /* REMOVE DESKTOP OFFSET */
  .dd-right {
    transform: none;
  }

  /* OVERLAY = NORMAL BLOCK BELOW IMAGE */
  .dd-overlay {
    position: relative;
    inset: unset;
    opacity: 1;               /* mobile me visible */
    pointer-events: auto;

    background: #00968d;
    padding: 22px 20px 28px;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  /* IMAGE KE NICHE CHIPKA DO */
  .dd-image .dd-overlay {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -110px;
  }

  /* IMAGE + CONTENT KE LIYE SPACE */
  .dd-image {
    margin-bottom: 130px;
  }

  /* MOBILE TEXT SIZE */
  .dd-overlay h3 {
    font-size: 22px;
    margin-bottom: 12px;
  }

  .dd-overlay a {
    font-size: 13px;
    padding: 10px 26px;
  }

  .drink-dine-heading h2{
   font-size: 40px; 
  }
  .drink-dine-heading span {
    width: 100%;
  height: 2px;
  background: #7a4cff;

  
  }
}
@media (max-width: 991px) {

  /* HIDE ORIGINAL TEXT */
  .dd-left .dd-overlay h3,
  .dd-right .dd-overlay h3 {
    visibility: hidden;
    position: relative;
  }

  /* RESTAURANT → Sky Vibe Restaurant */
  .dd-left .dd-overlay h3::after {
    content: "Sky Vibe Restaurant";
    visibility: visible;
    position: absolute;
    inset: 0;
    text-align: center;
  }

  /* ROOFTOP BAR → SKY VIBE ROOFTOP BAR */
  .dd-right .dd-overlay h3::after {
    content: "SKY VIBE ROOFTOP BAR";
    visibility: visible;
    position: absolute;
    inset: 0;
    text-align: center;
  }

}
@media (max-width: 991px) {

  .dd-overlay h3::after {
    white-space: nowrap;     
    font-size: 20px;     
    transform: translateX(-20%); 
  }

}



/* DRINK AND DINE SECTION END  */

/* NEW SECTION */
.drink-dine-reverse-section {
  padding: 60px 0;
  background: #fff;
}

/* Heading RIGHT aligned */
.heading-right {
  text-align: right;
}
.heading-right span {
  margin-left: auto;
}

/* LEFT IMAGE movement base */
.dd-left-move {
  transform: translateY(250px);
}

/* RIGHT image fixed */
.dd-right-fixed {
  transform: translateY(0);
}






















/* new dine start  */
/* SECTION */
.restaurant-showcase {
  padding: 60px 0;
  background: #fff;
}

/* WRAPPER */
.restaurant-wrap {
  max-width: 1192px !important;
  margin: auto;
  display: flex;
  gap: 10px;
}

/* LEFT CONTENT */
.restaurant-content {
  width: 50%;
  background: #009688;
  color: #fff;
  padding: 90px 70px;
  text-align: center;
  transform: translateY(120px); /* base for animation */
}

/* TEXT */
.restaurant-content h2 {
  font-size: 34px;
  font-weight: 700;
  margin-bottom: 35px;
}

.restaurant-content .hours {
  font-size: 16px;
  margin-bottom: 35px;
  font-weight: 700;
  text-align: center;
}

.restaurant-content .desc {
  font-size: 16px;
  line-height: 1.9;
  margin-bottom: 40px;
}

.restaurant-content .note {
  font-size: 16px;
  opacity: 0.9;
}

/* RIGHT SLIDER */
.restaurant-slider {
  width: 50%;
  position: relative;
  overflow: hidden;
  min-height: 520px;
}

/* SLIDES */
.rs-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s ease;
}

.rs-slide.active {
  opacity: 1;
  z-index: 1;
}

/* ARROWS */
.rs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.75);
  border: none;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  font-size: 26px;
  cursor: pointer;
  z-index: 5;
}

.rs-prev { left: 20px; }
.rs-next { right: 20px; }

.rs-arrow:hover {
  background: rgba(255,255,255,0.95);
}

/* RESPONSIVE */
@media (max-width: 991px) {
  .restaurant-wrap {
    flex-direction: column;
  }

  .restaurant-content,
  .restaurant-slider {
    width: 100%;
  }

  .restaurant-content {
    padding: 50px 30px;
    transform: none;
  }

  .restaurant-slider {
    min-height: 320px;
  }
}


/* new dine end  */
/* BASE LAYOUT (reuse) */
.restaurant-showcase {
  padding: 60px 0;
  background: #fff;
}

.restaurant-wrap {
  max-width: 1400px;
  margin: auto;
  display: flex;
  align-items: stretch;
}

/* IMAGE */
.restaurant-slider {
  width: 50%;
  position: relative;
  height: 520px;
  overflow: hidden;
}

.rs-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s ease;
}

.rs-slide.active {
  opacity: 1;
}

/* ARROWS */
.rs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.6);
  border: none;
  font-size: 28px;
  padding: 0px 14px;
  cursor: pointer;
}

.rs-prev { left: 15px; }
.rs-next { right: 15px; }

/* TEXT BOX */
.restaurant-content {
  width: 50%;
  padding: 100px 18px;
  color: #fff;
}

/* PURPLE BACKGROUND */
.purple-box {
  background: #8c4cf3;
  text-align: center;
}

/* TYPOGRAPHY */
.restaurant-content h2 {
  font-size: 34px;
  letter-spacing: 2px;
  margin-bottom: 30px;
  color: #fff;
}

.restaurant-content p {
  font-size: 15px;
  line-height: 1.8;
}

.note {
  margin-top: 25px;
  font-size: 14px;
  opacity: 0.9;
}

/* 🔥 REVERSE LAYOUT */
.restaurant-showcase--reverse .restaurant-wrap {
  flex-direction: row;
}

/* MOBILE */
@media (max-width: 991px) {
  .restaurant-wrap {
    flex-direction: column;
  }

  .restaurant-slider,
  .restaurant-content {
    width: 100%;
  }

  .restaurant-slider {
    height: 320px;
  }

  .restaurant-content {
    padding: 50px 30px;
  }
}
/* =====================================
   RESTAURANT SHOWCASE – MOBILE ONLY
   Desktop UNCHANGED
===================================== */
@media (max-width: 991px) {

  /* Stack layout */
  .restaurant-showcase .restaurant-wrap {
    flex-direction: column;
  }

  /* IMAGE FIRST */
  .restaurant-showcase .restaurant-slider {
    width: 100%;
    height: 320px;
    order: 2;
  }

  /* CONTENT SECOND */
  .restaurant-showcase .restaurant-content {
    width: 100%;
    order: 1;

    padding: 40px 25px;
    transform: none !important;   /* 🔥 stop desktop movement */
    text-align: center;
    color: #00968d;
    background-color: #fff;
  }

  /* Text scaling */
  .restaurant-showcase .restaurant-content h2 {
    font-size: 28px;
    margin-bottom: 20px;
    color: #00968d;
  }

  .restaurant-showcase .restaurant-content .hours {
    font-size: 14px;
    margin-bottom: 20px;
    color: #7a4cff !important;
    text-align: center;
        font-weight: 700;
  }

  .restaurant-showcase .restaurant-content .desc {
    font-size: 14px;
    line-height: 1.7;
    margin-bottom: 22px;
  }

  .restaurant-showcase .restaurant-content .note {
    font-size: 13px;
  }

  /* Slider arrows smaller */
  .restaurant-showcase .rs-arrow {
    width: 36px;
    height: 36px;
    font-size: 22px;
  }
}



/* new contact form  */
/* SECTION */
.contact-simple {
  padding: 120px 0;
  background: #ffffff;
}

/* CONTAINER */
.contact-container {
  max-width: 1300px;
  margin: auto;
  display: flex;
  align-items: center;
  gap: 60px;
}

/* LEFT FORM */
.contact-form {
  width: 50%;
}

.contact-form h2 {
  font-size: 30px;
  font-weight: 700;
  color: #009688;
  margin-bottom: 50px;
}

/* FORM */
.form-group {
  margin-bottom: 30px;
}

.form-group label {
  display: block;
  font-size: 16px;
  color: #009688;
  margin-bottom: 10px;
  font-weight: 700;
}

.form-group input,
.form-group textarea {
  width: 100%;
  border: none;
  border-bottom: 1px solid #7a4cff;
  padding: 10px 5px;
  font-size: 15px;
  outline: none;
}

.form-group textarea {
  resize: none;
}

/* BUTTON */
.contact-btn {
  margin-top: 30px;
  padding: 12px 40px;
  border-radius: 30px;
  border: 2px solid #009688;
  background: transparent;
  color: #009688;
  font-weight: 700;
  letter-spacing: 1px;
  cursor: pointer;
  transition: 0.3s ease;
}

.contact-btn:hover {
  background: #009688;
  color: #ffffff;
}

/* RIGHT IMAGE */
.contact-image {
  width: 50%;
  height: 460px;
  background-size: cover;
  background-position: center;
}

/* RESPONSIVE */
/* =====================================
   CONTACT SECTION – RESPONSIVE FIX
   Desktop UNCHANGED
===================================== */

/* Large tablets */
@media (max-width: 1200px) {
  .contact-container {
    gap: 40px;
    padding: 0 30px;
  }

  .contact-form h2 {
    font-size: 28px;
  }
}

/* Tablets & small laptops */
@media (max-width: 991px) {
  .contact-simple {
    padding: 80px 0;
  }

  .contact-container {
    flex-direction: column;
    gap: 50px;
  }

  .contact-form,
  .contact-image {
    width: 100%;
  }

  .contact-image {
    height: 360px;
  }

  .contact-form h2 {
    text-align: center;
    margin-bottom: 40px;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .contact-simple {
    padding: 60px 0;
  }

  .contact-container {
    padding: 0 20px;
    gap: 40px;
  }

  .contact-form h2 {
    font-size: 24px;
    margin-bottom: 30px;
  }

  .form-group label {
    font-size: 14px;
  }

  .form-group input,
  .form-group textarea {
    font-size: 14px;
    padding: 12px 6px;
  }

  .contact-btn {
    width: 100%;          /* 🔥 important for mobile UX */
    text-align: center;
    padding: 14px 0;
  }

  .contact-image {
    height: 280px;
    border-radius: 12px; /* optional but looks premium */
  }
}

/* Small mobile */
@media (max-width: 480px) {
  .contact-form h2 {
    font-size: 22px;
  }

  .contact-image {
    height: 240px;
  }
}



/* new  */
/* STRIP SECTION */
.contact-strip {
  width: 100%;
  height: 335px;
  background: linear-gradient(90deg, #009688 0%, #8c4cf3 100%);
  display: flex;
  align-items: center;
  margin-bottom: 40px;
}

/* CONTAINER */
.contact-strip-container {
  max-width: 1300px;
  margin: auto;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;            /* 🔥 FIX */
  column-gap: 120px;
}

/* LEFT */
.contact-strip-left {
  color: #ffffff;
}

/* RIGHT */
.contact-strip-right {
  color: #ffffff;
  display: flex;                /* 🔥 FIX */
  flex-direction: column;
  align-items: flex-start;
}

/* HEADINGS (perfect alignment) */
.contact-strip-left h3,
.contact-strip-right h3 {
  font-size: 30px;
  font-weight: 700;
  margin-top: 0;                /* 🔥 FIX */
  margin-bottom: 25px;
  color: #ffffff;
}

/* TEXT */
.contact-strip-left p {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 25px;
}

.contact-strip-left .call {
  font-size: 17px;
  font-weight: 600;
}

/* SOCIAL ICONS */
.contact-social a {
  display: inline-block;
  margin-right: 25px;
  font-size: 34px;
  color: #ffffff !important;
  transition: transform 0.3s ease;
}

.contact-social a:hover {
  transform: translateY(-4px);
}

/* MOBILE */
@media (max-width: 991px) {
  .contact-strip {
    height: auto;
    padding: 60px 0;
  }
  .contact-strip-left p {
    font-size: 15px;
    padding: 0 5px ;
  }

  .contact-strip-container {
    grid-template-columns: 1fr;
    text-align: center;
    row-gap: 10px;
  }

  .contact-strip-right {
    align-items: center;
    text-align: center;
  }
}













/* new icons  */
/* ===============================
   ROOM FEATURES (UNDER PARAGRAPH)
================================ */

.room-features {
  margin: 10px;
  display: grid;
  grid-template-columns: repeat(2, max-content);
  column-gap: 80px;
  row-gap: 22px;
}

/* Single item */
.room-feature-item {
  display: flex;
  align-items: center;
  gap: 14px;
  color: #00968d;
}

/* Icon */
.room-feature-item i {
  font-size: 30px;
  line-height: 1;
}

/* Text */
.room-feature-item span {
  font-size: 15px;
  font-weight: 500;
  white-space: nowrap;
}

.room-feature-svg {
  width: 30px;
  height: 30px;
  color: #00968d;     /* same green */
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .room-feature-svg {
    width: 26px;
    height: 26px;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .room-features {
    column-gap: 40px;
    row-gap: 18px;
  }

  .room-feature-item i {
    font-size: 26px;
  }

  .room-feature-item span {
    font-size: 14px;
  }
}
