@import url('https://fonts.googleapis.com/css2?family=Lustria&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Marcellus&display=swap');



:root {

    --navy: #0b2330;

    /* deep navy */

    --gold: #c9a66b;

    --cream: #fbfaf8;

    --deep-green: #0f3d2e;

    --moss: #7a9a78;

    --sand: #f6efe6;

    --accent: #b07a4b;

    --muted: #6b7280;



}



* {

    box-sizing: border-box

}



body {

    background-color: #ffffff;

    color: #1c2230;

    font-family: "Lustria", serif;



}



.bg-clr {

    background: var(--sand) !important;

}



section {
    padding: 60px 0;
}



/* NAV */

.navbar {

    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.8));

}



.navbar-brand {

    font-family: "Lustria", serif;

    font-weight: 700;

    color: var(--navy);

}

a{color: #1c2230;

    text-decoration: none;}

footer a {

    color: #fff;

    text-decoration: none;

}



#attraction img {

    /* border-radius: 10px; */

}





main {

    margin-bottom: 60px;

}



#photo-gallery img {

    width: 100%

}



/* HERO big centered */



.hero {



    /* display: flex;

    align-items: top;

    justify-content: center; */

    text-align: center;

    position: relative;

    padding: 0rem 1rem 5rem 1rem;

    /* background: linear-gradient(180deg, rgba(246, 251, 255, 1) 18%, rgba(243, 248, 251, 0.1) 49%, rgba(255, 255, 255, 0) 99%), url("./images/slider-1.jpg"); */

    background: url("./images/slider-1.jpg");

    /* 

min-height:100vh; */

    background-size: cover;

    background-position: center;

    background-repeat: no-repeat;

}



.facility-card {

    position: relative;

    border: 1px solid #eaeaea;

    padding: 35px 20px;

    background: #fff;

    text-align: center;

    border-radius: 6px;

    overflow: hidden;

    max-height: 170px;

    transition: 0.3s ease;

}



.facility-card:hover {

    border-color: #c9b27a;

    /* Gold hover effect */

    box-shadow: 0 6px 25px rgba(0, 0, 0, 0.08);

}



.facility-icon {

    font-size: 62px;

    color: #b89b61;

    z-index: 2;

    position: relative;

    font-variation-settings:

        "FILL" 0,

        "wght" 200,

        "GRAD" 0,

        "opsz" 48;

}



.facility-bg {

    position: absolute;

    right: 10px;

    bottom: 5px;

    font-size: 80px;

    opacity: 0.05;

    /* Light faded */

    font-variation-settings:

        "FILL" 0,

        "wght" 200,

        "GRAD" 0,

        "opsz" 48;

}



.facility-card h5 {

    /* margin-top: 15px; */

    font-size: 20px;

    font-weight: 500;

    color: #222;

    position: relative;

    z-index: 2;

}



.rooms {



    background-image:



        linear-gradient(180deg, #f6fbff 0%, #f3f8fb 35%, #fff 100%) !important;

    min-height: auto;

}



.hero .wrap {

    /* max-width: 920px; */

    padding: 60px 0 0;

    /* background-image: linear-gradient(

  180deg,

  #f6fbff54 0%,

  #f3f8fb25 35%,

  rgba(255, 255, 255, 0.144) 100%

) !important; */

    padding: 20px;

}



.eyebrow {

    font-family: "Lustria", serif;

    color: #000;

    letter-spacing: 1px;

    font-size: 0.95rem

}



h1,

h2,

h3,

h4,

h5,

h6 {

    font-family: "Marcellus", serif;

    font-weight: 400 !important

}



.hero h1 {



    font-size: 2.8rem;

    line-height: 1.3;

    margin: .8rem 0;

    color: var(--navy)

}



.hero p.lead {

    color: #000;

    margin-bottom: 1.5rem;

    font-size: 1.05rem

}



#booking {

    top: -250px;

    position: relative;

    z-index: 1;

    margin-bottom: -180px;

}



#booking .book {

    max-width: 900px;

}



#booking form {

    box-shadow: 0px 30px 30px rgba(175, 175, 175, 0.16);

    background-color: transparent;

    position: relative;

    z-index: 1;

    overflow: hidden;

}



#booking .white-box {

    padding: 15px;

    background-color: rgba(0, 0, 0, 0.45);

}



#booking .form-control {

    border-radius: 0

}



#manovanCarousel {

    position: relative;

}



#manovanCarousel .carousel-item img {

    height: 100vh;

    animation: zoom 7s ease-in-out;

}



.btn-theme-fill {

    background-color: #c7aa69;

    border: 2px solid #c7aa69;

    padding: 5px 32px;

    font-weight: 500;

    border-radius: 0;

    transition: all 0.3s ease;

    color: #fff;

}



.btn-theme-fill:hover {

    background-color: #fff;



    color: #c7aa69

}



@keyframes zoom {

    0% {

        transform: scale(1);

        opacity: 1;

    }



    100% {

        transform: scale(1.1);

        opacity: 1;

    }

}



/* FOOTER */

.footer-section {

    background: #0c0e19;

    color: #fff;

    text-align: center;

    padding: 4rem 2rem 3rem;

}



.owl-carousel .item img {

    width: 100%;

    height: 400px;

    object-fit: cover;

    border-radius: 10px;

}



.btn-primary-hero {

    background: var(--navy);

    color: #fff;

    border: none;

    padding: 0.85rem 1.4rem;

    border-radius: 6px;

    font-weight: 600

}



.btn-ghost {

    border: 1px solid rgba(11, 35, 48, 0.08);

    background: transparent;

    padding: 0.75rem 1.2rem;

    border-radius: 6px

}



/* Section spacing */

.section {

    padding: 3.5rem 0

}



/* Two-up gallery style */

.gallery-row .col-lg-7 img,

.gallery-row .col-lg-5 img {

    width: 100%;

    height: 420px;

    object-fit: cover;

    border-radius: 10px

}



.gallery-row .stack img {

    height: 205px;

    object-fit: cover

}



/* About and feature list */

.features h2 {

    font-family: "Lustria", serif;

    font-size: 1.7rem

}



.feature-list li {

    padding: .75rem 0;

    border-bottom: 1px solid #f1f3f5;

    color: var(--muted)

}



/* Quote band with play button */

.quote-band {

    background: linear-gradient(90deg, rgba(11, 35, 48, 0.95), rgba(11, 35, 48, 0.85));

    color: #fff;

    padding: 3rem 1rem;

    margin-top: 1.5rem

}



.quote-band blockquote {

    margin: 0;

    font-family: "Lustria", serif;

    font-size: 1.05rem;

    opacity: 0.95

}



.play-circle {

    width: 64px;

    height: 64px;

    border-radius: 50%;

    background: rgba(255, 255, 255, 0.08);

    border: 1px solid rgba(255, 255, 255, 0.12);

    display: flex;

    align-items: center;

    justify-content: center;

    font-size: 1.1rem

}



/* Card tiles */

.card-hero {

    border-radius: 12px;

    overflow: hidden;

    border: 0

}



.card-hero img {

    width: 100%;

    height: 240px;

    object-fit: cover

}



/* Panels with background blur-ish */

.panel {

    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.82));

    padding: 1rem;

    border-radius: 10px

}



/* FAQ style */

.faq .accordion-button {

    font-weight: 600

}



/* Big beach image footer */

\  .beach-hero {

    height: 420px;

    border-radius: 12px;

    background-image: url('/mnt/data/harbour.framer.website_.png');

    background-size: cover;

    background-position: center;

    margin-top: 2rem

}



/* Footer */

footer {

    padding: 2rem 0;

    color: var(--muted)

}



/* Reveal animations */

.reveal {

    opacity: 0;

    transform: translateY(18px);

    transition: all 700ms cubic-bezier(.2, .9, .3, 1)

}



.reveal.show {

    opacity: 1;

    transform: none

}





.serenity-section {

    text-align: center;

    background-color: #fff;

    animation: fadeInUp 1.2s ease;

    background: url('./images/manovan.png');

    background-position: center center;

    background-repeat: no-repeat;

    background-size: contain;

    background-attachment: fixed;

}







.serenity-section h2 {



    font-size: 2.8rem;

    font-weight: 500;

    color: #1b2230;

    margin-bottom: 1.2rem;

    line-height: 1.3;

}



.social-circle {

    width: 45px;

    height: 45px;

    background: #fff;

    border-radius: 50%;

    color: #c7aa69;

    display: flex;

    align-items: center;

    justify-content: center;

    font-size: 20px;

    transition: 0.3s;

}



.social-circle:hover {

    transform: scale(1.1);

}





#manovanCarousel .carousel-caption.centered-caption {

    bottom: 60%;

    transform: translateY(60%);

    top: auto;

    z-index: 2;

    background: rgba(0, 0, 0, 0)

}



#manovanCarousel .carousel-caption h3 {

    font-size: 2.8rem;

    font-weight: 600;

    z-index: 2;

}



#manovanCarousel .carousel-caption p {

    font-size: 1.2rem;

    z-index: 2;

}



#manovanCarousel .overlay {

    position: absolute;

    inset: 0;

    background: rgba(0, 0, 0, 0.43);

    /* Adjust darkness */

    z-index: 1;

}



/* Base Navbar */

.minimal-nav {

    width: 100%;

    padding: 0.2rem 3rem;

    z-index: 1001;

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    z-index: 10;

    /* So it shows above the slider */

    background: linear-gradient(rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.7) 25%, rgba(0, 0, 0, 0.4) 50%, rgba(0, 0, 0, 0.2) 75%, rgba(0, 0, 0, 0) 100%);

}



button:hover {

    opacity: 1;

    color: #000;

    background: transparent !important;

}



.nav-container {

    display: flex;

    justify-content: space-between;

    align-items: center;

}



.logo {

    font-family: "Lustria", serif;

    font-size: 1.6rem;

    color: #1c2431;

    width: 120px;

}



.logo img {

    width: 120px;

}



.logo span {

    margin-left: 4px;

    font-size: 1.1rem;

}



.menu-icon {

    font-size: 3rem;

    font-weight: 300;

    color: #e7c475;

    cursor: pointer;

    transition: transform 0.4s ease;

}



.menu-icon.active {

    transform: rotate(45deg);

}



/* Slide Menu */

.slide-menu {

    position: fixed;

    top: 100px;

    right: -100%;

    padding: 20px 50px;

    width: auto;

    height: auto;

    background-color: #c7aa69;

    color: #fff;

    z-index: 9999;

    transition: right 0.5s ease;

    display: flex;

    justify-content: center;

    align-items: center;

    border-radius: 10px;

}



.slide-menu.active {

    right: 50px;

}



/* Close Button Inside Menu */

.close-menu {

    position: absolute;

    top: -10px;

    right: 25px;

    font-size: 4rem;

    color: #fff;

    cursor: pointer;

    font-weight: 300;

    transition: transform 0.3s ease;

}



.close-menu:hover {

    transform: rotate(0deg);

}



.menu-content {

    display: flex;

    flex-direction: column;

    justify-content: space-between;

    height: 80%;

    text-align: left;

    width: 100%;



}



.main-links {

    padding: 0

}



.main-links li {

    list-style: none;

    font-size: 1.6rem;

    margin-bottom: 0rem;

    font-family: "Lustria", serif;

    cursor: pointer;

    /* transition: opacity 0.3s ease; */

    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);

    transform: translateZ(0);

    padding: 2px 0;

}



.main-links li::before {



    background: rgba(255, 255, 255, 0.1);

    transition: left 0.5s ease;

    z-index: -1;

}



.main-links li:hover {



    transform: translateZ(20px) translateY(-10px);

    color: #1c2431;

}



.sub-links {

    list-style: none;

    padding: 0;

}



.sub-links li {

    font-size: 1rem;

    margin-top: 1rem;

    cursor: pointer;

}



.whatsapp i {

    position: fixed;

    bottom: 20px;

    left: 20px;

    color: #fff;

    width: 60px;

    height: 60px;

    text-align: center;

    line-height: 60px;

    background-color: #48c857;

    border-radius: 50%;

    z-index: 9999;

}



.menu-content .footer {

    display: flex;

    flex-direction: column;

    align-items: flex-start;

    font-size: 0.85rem;

    color: #f0f0f0;
    padding-top:0;
    background:transparent;

}



.footer .social {

    margin-bottom: 0.5rem;

}



.footer .social i {

    margin-right: 10px;

    cursor: pointer;

}



hr {

    border: none;

    border-top: 1px solid rgba(255, 255, 255, 0.4);

    margin: 1rem 0;

}



/* Font Awesome (for icons) */

@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css");



.features {

    display: flex;

    justify-content: center;

    align-items: center;

    padding: 4rem 2rem;

    background: #fff;

    font-family: "Lustria", serif;

}



.features .container {

    display: flex;



    width: 100%;

    gap: 3rem;

}



.container {

    /* display: flex; */

    /* max-width: 1100px;

    width: 100%;

    gap: 1rem; */

}



.feature-left {

    flex: 1;

    position: relative;

}



.image-wrapper {

    position: relative;

    width: 100%;

    height: 400px;

    /* Fixed height to prevent layout shift */

    overflow: hidden;

    border-radius: 1rem;

    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);

}



.image-wrapper img {

    position: absolute;

    width: 100%;

    height: 100%;

    top: 0;

    left: 0;

    object-fit: cover;

    border-radius: 1rem;

    opacity: 0;

    transition: opacity 0.8s ease-in-out;

}



.image-wrapper img.active {

    opacity: 1;

    z-index: 1;

}



.feature-right {

    flex: 1;

    display: flex;

    flex-direction: column;

    justify-content: center;

}



.feature-item {

    border-bottom: 1px solid #ddd;

    padding: 1rem 0;

    cursor: pointer;

    transition: 0.3s ease;

}



.feature-item h3 {

    font-weight: 600;

    color: #111;

    margin-bottom: 0.3rem;

    font-size: 1.4rem;

}



.feature-item p {

    color: #555;

    line-height: 1.6;

    display: none;

    margin: 0.5rem 0 0;

}



.feature-item.active p {

    display: block;

}



.feature-item.active h3 {

    color: #007bff;

}







/* ===== Parallax Section ===== */

.video-section {

    position: relative;

    height: 100vh;

    background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.5)),

        url("./images/jim-corbett.png") top center / cover no-repeat fixed;

    display: flex;

    align-items: center;

    justify-content: center;

    overflow: hidden;

    color: #fff;

}



/* ===== Text Content ===== */

.video-section .overlay {

    position: relative;

    z-index: 2;

    text-align: left;

    max-width: 1000px;

    padding: 2rem;

}



.video-section .content {

    position: relative;

    padding: 3rem;

    background: rgba(255, 255, 255, 0.1);

    backdrop-filter: blur(10px);

    border-radius: 20px;

    border: 1px solid rgba(255, 255, 255, 0.2);

    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);

    transform: translateY(30px);

    opacity: 0;

    animation: fadeUp 1s ease forwards 0.5s;

    text-align: center

}



.video-section .overlay blockquote {

    text-align: justify;

    font-size: 1rem;

    font-style: italic;

    line-height: 1.5;

    margin-bottom: 1.5rem;

    position: relative;

    text-align: center

        /* padding-left: 2rem; */

}



.video-section .overlay blockquote::before {

    content: "";

    position: absolute;

    left: -1rem;

    top: -1.5rem;

    font-size: 5rem;

    color: rgba(255, 255, 255, 0.3);

    font-family: Georgia, serif;

}



.video-section .overlay .author {

    font-size: 1.1rem;

    font-weight: 500;

    letter-spacing: 1px;

    position: relative;

    padding-left: 2rem;

}





/* ===== Play Button ===== */

.video-section .play-btn {

    position: absolute;

    right: 6%;

    bottom: 6%;

    transform: translateY(-50%);

    width: 80px;

    height: 80px;

    border-radius: 50%;

    background: linear-gradient(135deg, #fff, #e6e6e6);

    color: #111;

    display: flex;

    align-items: center;

    justify-content: center;

    font-size: 3rem;

    cursor: pointer;

    transition: all 0.4s ease;

    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);

    z-index: 10;

    opacity: 0;

    animation: fadeIn 1s ease forwards 1s;

}



.video-section .play-btn:hover {

    transform: translateY(-50%) scale(1.1);

    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.4);

    background: linear-gradient(135deg, #f8f8f8, #fff);

}



/* Pulse animation */

.video-section .play-btn::before {

    content: "";

    position: absolute;

    width: 100%;

    height: 100%;

    border-radius: 50%;

    background: rgba(255, 255, 255, 0.3);

    animation: pulse 2s ease-out infinite;

    z-index: -1;

}



@keyframes pulse {

    0% {

        transform: scale(1);

        opacity: 0.8;

    }



    100% {

        transform: scale(1.6);

        opacity: 0;

    }

}



/* ===== Video Popup ===== */

.video-section .video-popup {

    position: fixed;

    inset: 0;

    background: rgba(0, 0, 0, 0.9);

    display: none;

    align-items: center;

    justify-content: center;

    z-index: 9999;

    opacity: 0;

    transition: opacity 0.5s ease;

}



.video-section .video-popup.active {

    display: flex;

    opacity: 1;

}



.video-section .video-container {

    position: relative;

    max-width: 900px;

    width: 90%;

    transform: scale(0.9);

    transition: transform 0.5s ease;

}



.video-section .video-popup.active .video-container {

    transform: scale(1);

}



.video-section .video-container video {

    width: 100%;

    border-radius: 15px;

    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);

}



#closeVideo {

    position: absolute;

    top: -50px;

    right: 0;

    background: rgba(255, 255, 255, 0.2);

    color: #fff;

    border: none;

    font-size: 2.5rem;

    border-radius: 50%;

    width: 50px;

    height: 50px;

    cursor: pointer;

    display: flex;

    align-items: center;

    justify-content: center;

    transition: all 0.3s ease;

    backdrop-filter: blur(5px);

}



#closeVideo:hover {

    background: rgba(255, 255, 255, 0.3);

    transform: rotate(90deg);

}



/* Floating elements for visual interest */

.video-section .floating-elements {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    overflow: hidden;

    z-index: 1;

}



.video-section .floating-element {

    position: absolute;

    background: rgba(255, 255, 255, 0.1);

    border-radius: 50%;

    animation: float 15s infinite linear;

}



.video-section .floating-element:nth-child(1) {

    width: 80px;

    height: 80px;

    top: 10%;

    left: 10%;

    animation-delay: 0s;

}



.video-section .floating-element:nth-child(2) {

    width: 120px;

    height: 120px;

    top: 70%;

    left: 80%;

    animation-delay: -5s;

}



.video-section .floating-element:nth-child(3) {

    width: 60px;

    height: 60px;

    top: 50%;

    left: 5%;

    animation-delay: -10s;

}



@keyframes float {

    0% {

        transform: translateY(0) rotate(0deg);

        opacity: 0.7;

    }



    50% {

        transform: translateY(-20px) rotate(180deg);

        opacity: 0.3;

    }



    100% {

        transform: translateY(0) rotate(360deg);

        opacity: 0.7;

    }

}



/* Animations */

@keyframes fadeUp {

    from {

        opacity: 0;

        transform: translateY(30px);

    }



    to {

        opacity: 1;

        transform: translateY(0);

    }

}



@keyframes fadeIn {

    from {

        opacity: 0;

    }



    to {

        opacity: 1;

    }

}









.dining-section::after {

    content: "";

    right: 0;

    top: 0;

    width: 48%;

    height: 100%;

    position: absolute;

    background: url(./images/dine-1.jpg);

    background-position: right;

    background-size: cover;

    background-repeat: no-repeat;

}



.dining-section {

    position: relative;

}



.dining-section {

    background: #ffffff;

}



.dining-subtitle {

    color: #b89b61;

    /* Soft gold-like tone */

    letter-spacing: 1px;

    font-size: 16px;

}



.dining-title {

    color: #0a1a33;

    /* Deep navy tone (premium look) */



    line-height: 1.3;

}



.dining-text {

    color: #333;

    font-size: 16px;

    line-height: 1.7;

}



.dining-btn {

    background: #b89b61;

    color: #fff;

    padding: 10px 25px;

    border-radius: 3px;

    text-decoration: none;

    font-weight: 500;

}



.dining-btn:hover {

    background: #a08452;

    color: #fff;

}



.dining-img {

    width: 100%;

    object-fit: cover;

}


.footer{
    background:#111;
    color:#ddd;
    padding-top:70px;
    font-size:15px;
}

.footer a{
    color:#ddd;
    text-decoration:none;
}

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

/* TOP AREA */

.footer-top{
    display:flex;
    justify-content:space-between;
    gap:60px;
    flex-wrap:wrap;
    padding-bottom:50px;
    border-bottom:1px solid rgba(255,255,255,0.08);
}

.footer-about{
    flex:1.4;
}

.footer-contact,
.footer-social{
    flex:1;
}

.footer h2{
    color:#fff;
    margin-bottom:15px;
}

.footer h3{
    color:#fff;
    margin-bottom:18px;
}

/* CONTACT */

.contact-item{
    display:flex;
    gap:15px;
    margin-bottom:18px;
    align-items:flex-start;
}

.contact-item i{
    background:#222;
    padding:10px;
    border-radius:50%;
    width:38px;
    height:38px;
    display:flex;
    align-items:center;
    justify-content:center;
}

/* SOCIAL */

.social-icons{
    display:flex;
    gap:15px;
}

.social-icons a{
    width:42px;
    height:42px;
    background:#222;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:.3s;
}

.social-icons a:hover{
    background:#c59d5f; /* luxury gold */
}

/* LINKS */

.footer-links{
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
    gap:20px;
    padding:30px 0;
}

.links{
    display:flex;
    gap:22px;
    flex-wrap:wrap;
}

/* COPYRIGHT */

.footer-bottom{
    text-align:center;
    padding:25px 0;
    border-top:1px solid rgba(255,255,255,0.08);
    color:#aaa;
}

/* MOBILE */

@media(max-width:768px){

.footer-top{
    flex-direction:column;
    gap:35px;
}

.footer-links{
    flex-direction:column;
    align-items:center;
    text-align:center;
}

}



/* Bottom to top smooth animation */

@keyframes slideUp {

    to {

        transform: translateY(0);

        opacity: 1;

    }

}



/* Hover interaction (optional) */

.dining-section .dining-images:hover .small-img {

    transform: translateY(-10px);

    transition: transform 0.5s ease;

}







.accordion-button:not(.collapsed) {

    color: var(--bs-accordion-active-color);

    background-color: #fff;

    box-shadow: none;

}



button:hover {

    opacity: 1;

    color: #000;

    background: rgb(227, 233, 238);

}



.facilities-section {

    padding: 20px 0;

}



.facilities-section h2 {

    font-weight: 600;

    text-align: center;

    color: #222;

}



.facility-category h5 {

    font-weight: 600;

    margin-bottom: 20px;

    color: #444;

}



.facility-item {

    display: flex;

    align-items: center;

    margin-bottom: 12px;

    font-size: 15px;

    color: #555;

}



.facility-item .material-icons {

    font-size: 22px;

    margin-right: 10px;

    color: #c7aa69;

}



.facility-category {

    border-top: 1px solid #e5e7eb;

    padding-top: 20px;

}



#contact .resort-card {

    max-width: 450px;

    margin: 50px auto;

    border: none;

    border-radius: 20px;

    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);

    overflow: hidden;

}



#contact .resort-header {

    background: linear-gradient(135deg, #292f3f, #292f3f);

    color: #e7c076;

    padding: 25px 20px;

    text-align: center;

}



#contact .resort-header h4 {

    font-weight: 600;

    margin-bottom: 10px;

}



#contact .resort-body {

    padding: 25px;

    background-color: #fff;

}



#contact .resort-body p {

    margin: 8px 0;

    color: #333;

}



#contact .resort-body a {

    text-decoration: none;

    color: #006699;

    font-weight: 500;

}



#contact .contact-icons i {

    color: #006699;

    margin-right: 10px;

}













.h2,

h2 {

    font-size: 2rem;

    font-weight: 600;

    margin-bottom: 1.2rem;

}





.serenity-section p {

    /* max-width: 720px; */

    margin: 0 auto 2rem;

    font-size: 1.05rem;

    color: #4b5563;

    line-height: 1.5;

}



.serenity-section .btn-primary {

    background-color: #0d1b2a;

    border: none;

    padding: 12px 32px;

    font-weight: 500;

    border-radius: 0;

    transition: all 0.3s ease;

    color: #fff;

}



.btn-theme {

    background-color: transparent;

    border: 2px solid #c7aa69;

    padding: 12px 32px;

    font-weight: 500;

    border-radius: 0;

    transition: all 0.3s ease;

    color: #c7aa69;

}



.btn-theme:hover {

    background-color: #c7aa69;

    color: #fff

}







.serenity-section .btn-primary:hover {

    background-color: #142e47;

    transform: scale(1.05);

}



@keyframes fadeInUp {

    from {

        opacity: 0;

        transform: translateY(30px);

    }



    to {

        opacity: 1;

        transform: translateY(0);

    }

}



:root {

    --gap: 20px;

    --slide-w: 600px;

    --slide-h: 400px;

}





.slider-section {

    padding: 48px 0;

}



/* Outer visible frame */

.slider-frame {

    overflow: hidden;

    position: relative;

    width: 100%;

    display: flex;

    justify-content: center;

    align-items: center;

    padding: 10px 0;

}



/* Track that will be shifted */

.slider-track {

    display: flex;

    gap: var(--gap);

    align-items: center;

    /* allow smooth manual scroll on touch */

    scroll-behavior: smooth;

    will-change: transform;

    padding: 12px;

}



/* Individual slides */

.slide1 {

    flex: 0 0 auto;

    width: var(--slide-w);

    height: var(--slide-h);

    border-radius: 16px;

    overflow: hidden;

    position: relative;

    transform-origin: center center;

    transition: transform 4500ms cubic-bezier(.2, .9, .3, 1), box-shadow 300ms;

    background: #eee;

    box-shadow: 0 6px 18px rgba(11, 35, 48, 0.06);



}



.slide1 img {

    width: 100%;

    height: 100%;

    object-fit: cover;

    display: block;

    transition: transform 650ms ease;

    will-change: transform;

}



/* Base transform (slightly scaled down) */

.slide1:not(.is-focused) {

    transform: perspective(1200px) scale(0.98);

}



/* Focused/center slide */

.slide1.is-focused {

    transform: perspective(1200px) scale(1.15);

    z-index: 3;

    box-shadow: 0 20px 40px rgba(6, 12, 34, 0.12);

}



.slide.is-focused img {

    transform: scale(1.05);

}





/* optional nav buttons */

.slider-controls {

    position: absolute;

    top: 50%;

    left: 12px;

    right: 12px;

    pointer-events: none;

    transform: translateY(-50%);

    display: flex;

    justify-content: space-between;

    gap: 10px;

}



.ctrl {

    pointer-events: all;

    background: rgba(11, 35, 48, 0.06);

    border: 0;

    width: 44px;

    height: 44px;

    border-radius: 10px;

    display: flex;

    align-items: center;

    justify-content: center;

    backdrop-filter: blur(4px);

}



.section {

    display: flex;

    flex-wrap: wrap;

    align-items: center;

    justify-content: space-between;

    padding: 80px 10%;

    gap: 40px;

}



.section h1 {

    font-family: "Lustria", serif;

    font-size: 48px;

    font-weight: 400;

    color: #0a0f1a;

    line-height: 1.2;

    max-width: 500px;

}



.section p {

    font-size: 18px;

    line-height: 1.8;

    color: #384150;

    max-width: 600px;

}



















.explore-section {

    display: flex;

    justify-content: center;

    align-items: flex-start;

    gap: 2rem;

    background: #fff;

    flex-wrap: wrap;

    font-family: "Lustria", serif;

}



/* Each card */

.explore-card {

    flex: 1 1 300px;

    max-width: 420px;

    position: relative;

}



/* Image container */

.card-image {

    position: relative;

    /* border-radius: 20px; */

    overflow: hidden;

    cursor: pointer;

    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);

}



.card-image img {

    width: 100%;

    height: 350px;

    object-fit: cover;

    /* border-radius: 20px; */

    transition: transform 0.6s ease, filter 0.6s ease;

}



.card-image::before {

    content: "";

    position: absolute;

    inset: 0;

    background: linear-gradient(180deg, rgba(0, 0, 0, 0.5) 13%, rgba(0, 0, 0, 0) 64%);

    z-index: 1;

}



/* Hover zoom effect */

.card-image:hover img {

    transform: scale(1.08);

    filter: brightness(0.7);

}



/* Title positioned at top left (always visible) */

.card-title {

    position: absolute;

    top: 20px;

    left: 20px;

    right: 20px;

    color: #fff;

    font-size: 1.5rem;

    font-weight: 600;

    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);

    z-index: 3;

    transition: transform 0.3s ease;

}



.card-image:hover .card-title {

    transform: translateY(-5px);

}



/* Overlay container */

.room .overlay {

    position: absolute;

    inset: 0;

    background: linear-gradient(180deg, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.2) 100%);

    color: #fff;

    opacity: 0;

    transition: opacity 0.6s ease;

    padding: 2rem;



    display: flex;

    flex-direction: column;

    justify-content: space-between;

    z-index: 2;

}



/* Text appears top-left in overlay */

.room .overlay-text {

    transform: translateY(-20px);

    transition: transform 0.5s ease, opacity 0.5s ease;

    opacity: 0;

    margin-top: 50px;

}



.room .overlay-text p {

    margin-top: 10px;

    line-height: 1.6;

    font-size: 0.95rem;

}



/* Link at bottom-right with white background */

.room .overlay-link {

    align-self: flex-end;

    font-size: 1rem;

    color: #333;

    text-decoration: none;

    font-weight: 500;

    transition: all 0.5s ease;

    transform: translateY(20px);

    opacity: 1;

    background: #fff;

    padding: 10px 20px;

    border-radius: 25px;

    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);

    position: absolute;

    bottom: 40px;

    right: 20px;

}



/* Hover reveal */

.room .card-image:hover .overlay {

    opacity: 1;

}



.room .card-image:hover .overlay-text {

    opacity: 1;

    transform: translateY(0);

}



.room .card-image:hover .overlay-link {

    opacity: 1;

    transform: translateY(0);

}



/* Hover effects for link */

.room .overlay-link:hover {

    background: #c7aa69;

    color: #fff;

    transform: translateY(-2px);

    box-shadow: 0 6px 20px rgba(255, 77, 0, 0.4);

}



/* Responsive */







/* VIDEO SECTION */

.video-section-btm {

    position: relative;

    /* height: 100vh; */

    overflow: hidden;

    display: flex;

    align-items: flex-end;

    justify-content: center;



}

.pre-footer{    background: url(./images/slider-5.jpg);

    background-attachment: fixed;

    background-position: center;

}

.video-section-btm .bg-video {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    object-fit: cover;

    z-index: 1;

    display:none;

}



.bg-video-mb {

    display: none;

}



/* Floating info card */

.video-section-btm .info-card {

    position: relative;

    z-index: 2;

    background: #fff;

    border-radius: 6px;

    width: 85%;

    max-width: 950px;

    padding: 2.5rem;

    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);



}



.video-section-btm .info-card h3 {

    font-size: 1.4rem;

    font-weight: 600;

    margin-bottom: 1.5rem;

    color: #111;

}



                    .facilities-section {

                        padding: 20px 0;

                    }



                    .facilities-section h2 {

                        font-weight: 600;

                        font-size: 2rem;

                        margin-bottom: 40px;

                        text-align: center;

                        color: #222;

                    }



                    .facility-category h5 {

                        font-weight: 600;

                        margin-bottom: 20px;

                        color: #444;

                    }



                    .facility-item {

                        display: flex;

                        align-items: center;

                        margin-bottom: 12px;

                        font-size: 15px;

                        color: #555;

                    }



                    .facility-item .material-icons {

                        font-size: 22px;

                        margin-right: 10px;

                        color: #555;

                    }



                    .facility-category {

                        border-top: 1px solid #e5e7eb;

                        padding-top: 20px;

                    }

             

.video-section-btm .features {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));

    gap: 1.5rem;

    margin-bottom: 1.5rem;

}



.video-section-btm .feature-group h4 {

    font-size: 0.95rem;

    font-weight: 600;

    margin-bottom: 0.5rem;

    color: #222;

}



.feature-group ul {

    list-style: none;

    padding: 0;

    margin: 0;

}



.video-section-btm .feature-group li {

    font-size: 0.9rem;

    color: #555;

    margin-bottom: 0.4rem;

}



.video-section-btm .bottom-info {

    display: flex;

    justify-content: space-between;

    align-items: center;

    border-top: 1px solid #eaeaea;

    padding-top: 1rem;

    flex-wrap: wrap;

    gap: 1rem;

}



.video-section-btm .bottom-info p {

    color: #333;

    font-size: 0.9rem;

}



.video-section-btm.btn-outline:hover {

    background: #111;

    color: #fff;

}







.footer-content h2 {

    font-size: 2rem;

    font-weight: 500;

    line-height: 1.4;

    margin-bottom: 1rem;

}



.footer-content span {

    color: #fff;

}



.footer-content p {

    color: #ccc;

    font-size: 0.95rem;

    margin: 0 auto 2rem;

    line-height: 1.6;

}



.btn-primary {

    background: #fff;

    color: #111;

    border: none;

    padding: 0.75rem 1.6rem;

    border-radius: 4px;

    font-weight: 500;

    cursor: pointer;

    transition: all 0.3s ease;

}







.btn-primary:hover {

    background: #f6a623;

    color: #fff;

}



/* Footer bottom */

.footer-bottom {

    border-top: 1px solid rgba(255, 255, 255, 0.15);

    /* margin-top: 4rem; */

    padding-top: 1.5rem;

}



.footer-links {

    margin-bottom: 1rem;

}



.footer-links a {

    color: #ccc;

    margin: 0 10px;

    font-size: 0.9rem;

    text-decoration: none;

    transition: color 0.3s ease;

}



.footer-links a:hover {

    color: #fff;

}



.footer-bottom p {

    color: #999;

    font-size: 0.85rem;

}







.carousel-caption {



    right: 25%;

    left: 25%;



}



/* Slider Wrapper */









/* Responsive adjustments */

@media (max-width: 992px) {

    .video-section .play-btn {

        right: 5%;

        width: 80px;

        height: 80px;

        font-size: 2.5rem;

    }



    .video-section .overlay blockquote {

        font-size: 1rem;

    }



    .dining-section {

        flex-direction: column;

        text-align: center;

    }



    .dining-section .dining-images {

        margin-top: 2rem;

    }



    .dining-section .small-img {

        left: 50%;

        transform: translate(-50%, 50px);

    }



    .footer-contact {

        flex-direction: column;

    }



    .dining-section::after {

        display: none;

    }



    .room .explore-section {

        flex-direction: column;

        align-items: center;

    }



    .room .explore-card {

        max-width: 100%;

        margin-bottom: 2rem;

    }





    :root {

        --slide-w: 300px;

        --slide-h: 360px;

    }



    .section {

        flex-direction: column;

        text-align: center;

        padding: 60px 5%;

    }



    .section h1 {

        font-size: 36px;

    }



    .section p {

        font-size: 16px;

    }



    .footer-links a {

        margin-right: 5px;

        font-size: 14px;

    }



    /* Add | after every link EXCEPT the last one */

    .footer-links a:not(:last-child)::after {

        content: "|";

        margin-left: 5px;

        font-size: 12px;

        font-weight: 200;

    }



}



@media (max-width: 768px) {

    .serenity-section h2 {

        font-size: 2rem;



    }



    .logo img {



        width: 100px;

    }



    .minimal-nav {



        padding: 0.2rem 1rem;



    }



    .video-section .video-section .content {

        padding: 2rem;

    }



    .video-section .video-section .overlay blockquote {

        font-size: 1.5rem;

        padding-left: 1.5rem;

    }



    .video-section .video-section .play-btn {

        position: relative;

        right: auto;

        top: auto;

        transform: none;

        margin: 2rem auto 0;

        display: block;

    }



    .video-section .play-btn:hover {

        transform: scale(1.1);

    }



    .video-section .video-section .overlay {

        text-align: center;

    }



    .video-section .video-section .overlay .author {

        padding-left: 0;

    }



    .video-section .video-section .overlay .author::before {

        display: none;

    }



    .dining-section .small-img {

        display: none;

    }



    .container {

        flex-direction: column;

    }



    .image-wrapper {

        height: 300px;

        /* Adjust height for mobile */

    }



    #manovanCarousel .carousel-item img {

        height: 45vh

    }



    #manovanCarousel .carousel-caption.centered-caption {

        display: none

    }



    #booking {

        top: -80px;

        position: relative;

        z-index: 1;

        margin-bottom: -100px;

    }



    .btn-theme-fill {

        width: 100%;

        margin-top: 20px;

    }



    #booking .book {

        padding: 0

    }



    #booking img {

        padding-top: 20px;

        align-items: center;

        text-align: center;

    }



    #booking .white-box {

        padding: 15px;

        background-color: #282f40;

        display: none

    }



    /* Responsive */

    .video-section-btm .info-card {

        position: relative;

        z-index: 2;

        background: #fff;

        border-radius: 6px;

        width: 95%;

        max-width: 950px;

        padding: 2.5rem;

        box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);

    }



    .video-section-btm .bg-video {

        display: none

    }



.bg-video-mb  {

  

    width: 100%;

    height: 100%;

    display:block;

    object-fit: cover;

    z-index: 1;

}





    .bottom-info {

        flex-direction: column;

        align-items: flex-start;

    }



    .footer-section {

        padding: 6rem 1.5rem 3rem;

    }



    /* smaller devices */



    .hero h1 {

        font-size: 2rem

    }



    .gallery-row .col-lg-7 img {

        height: 260px

    }



    .gallery-row .stack img {

        height: 130px

    }



    .dining-section::after {

        display: none;

    }



    .video-section .overlay {

        padding: 1rem;

    }



    .video-section .content {



        padding: 1rem;



    }



}



@media (max-width: 576px) {

    .video-section .video-section .overlay blockquote {

        font-size: 1.3rem;

    }



    .video-section .video-section .content {

        padding: 1.5rem;

    }



    .room .explore-section {

        padding: 2rem 1rem;

    }



    .room .card-title {

        font-size: 1.3rem;

    }



    .room .overlay-link {

        padding: 8px 16px;

        font-size: 0.9rem;

    }





    :root {

        --slide-w: 260px;

        --slide-h: 320px;

    }

}



        /* Make slider images full width & responsive */

        #manovanCarousel .carousel-item img {

            width: 100%;

            height: 100vh;

            /* Full-screen on desktop */

            object-fit: cover;

            /* Prevent narrow / stretched images */

            object-position: center;

        }



        /* Mobile responsive height */

        @media (max-width: 768px) {

            #manovanCarousel .carousel-item img {

                height: 60vh;

                /* Reduce height but keep broad look */

            }

        }



        /* Optional: Dark overlay */

        #manovanCarousel .overlay {

            position: absolute;

            inset: 0;

            background: rgba(0, 0, 0, 0.35);

            z-index: 1;

        }



        /* Center captions */

        #manovanCarousel .carousel-caption {

            z-index: 2;

        }

   

   

        /* Default (Mobile) */

        .custom-carousel .carousel-item img {

            width: 100%;

            height: 450px;

            object-fit: cover;

        }



        /* Desktop & large screens */

        @media (min-width: 992px) {

            .custom-carousel .carousel-item {

                height: 720px;

                /* adjust as needed */

            }



            .custom-carousel .carousel-item img {

                height: 100%;

        

            }}





        .room-section {



            margin: auto;

        }



        .room-card {

            border: none;

            /* border-radius: 10px; */

            overflow: hidden;

            background: #fff;

            transition: all 0.3s ease;

        }



        .room-card img {

            width: 100%;

            height: 350px;

            object-fit: cover;

            /* border-radius: 10px; */

        }



        .room-card:hover {

            transform: translateY(-5px);

           box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);

        }



        .room-content {

            padding: 25px;

        }



        .room-content h6 {

            letter-spacing: 2px;

            font-size: 12px;

            text-transform: uppercase;

            color: #555;

            margin-bottom: 10px;

        }



        .room-content h3 {

            font-weight: 600;

            margin-bottom: 10px;

        }



        .room-content p {

            color: #666;

            font-size: 15px;

            margin-bottom: 20px;

        }



        .btn-dark {

            border-radius: 0;

            padding: 8px 22px;

            font-size: 14px;

            transition: 0.2s;

        }

 .btn-dark:hover {

          border:2px solid #212529;

          color:#212529;

        }

        .btn-link {

            color: #000;

            text-decoration: none;

            border-bottom: 1px solid #000;

            margin-left: 15px;

            font-weight: 500;

        }



        @media (max-width: 768px) {

            .room-card img {

                height: 280px;

            }

        }

    

        /* Center navigation arrows vertically */

        .owl-nav {

            position: absolute;

            top: 50%;

            width: 100%;

            transform: translateY(-50%);

            display: flex;

            justify-content: space-between;

            pointer-events: none;

            /* allow clicking only on buttons */

        }



        /* Style arrows */

        .owl-nav button.owl-prev,

        .owl-nav button.owl-next {

            width: 45px;

            height: 45px;

            background: rgba(0, 0, 0, 0.4) !important;

            border-radius: 50%;

            color: #fff !important;

            font-size: 22px !important;

            display: flex;

            justify-content: center;

            align-items: center;

            pointer-events: auto;

            /* enable button clicking */

            border: none;

            transition: 0.3s ease;

        }



        /* Hover effect */

        .owl-nav button.owl-prev:hover,

        .owl-nav button.owl-next:hover {

            background: rgba(0, 0, 0, 0.7) !important;

        }



        /* Remove default disabled style (Owl adds opacity) */

        .owl-nav button.owl-prev.disabled,

        .owl-nav button.owl-next.disabled {

            opacity: 0.4 !important;

        }



        label {

            color: #fff

        }



                .resort-card {

                    position: relative;

                    border-radius: 16px;

                    overflow: hidden;

                    box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.25);



                }



                .resort-card img {

                    width: 100%;

                    height: 450px !important;

                    object-fit: cover;

                    transition: .4s;

                }



                .resort-card:hover img {

                    transform: scale(1.05);

                }



                .resort-info {

                    position: absolute;

                    bottom: 0;

                    left: 0;

                    right: 0;

                    padding: 20px;

                    text-align: center;

                    color: #fff;



                    background: linear-gradient(to top,

                            rgba(0, 0, 0, 0.7),

                            rgba(0, 0, 0, 0));



                    .resort-info h3 {

                        font-size: 20px;

                        font-weight: 600;

                    }

                }

     

            .animals-section {

                background: #fff

            }



            .animal-card {

                background: #f6efe6;

                border-radius: 10px;

                padding: 10px;

                text-align: center;

                transition: 0.3s ease;

                width: 100%;

            }



            .animal-card img {

                border-radius: 10px;

                height: 180px;

                width: 100%;

                object-fit: cover;

            }



            .animal-card:hover {

                transform: translateY(-5px);

                box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);

            }



            .animal-name {

                margin-top: 10px;

                margin-bottom: 0;

                font-weight: 600;

                font-size: 1.1rem;

                color: #0b3d06;

            }



        

    .golf-section img {

        width: 100%

    }

.slide-menu a{color:#fff}

                                .hotel-section .fa {

                                    color: #c7aa69;

                                    border-radius: 50%;

                                    border: 1px solid #c7aa69;

                                    width: 40px;

                                    height: 40px;

                                    text-align: center;

                                    line-height: 40px;
                                    margin-right:10px;

                                }

                           

.hotel-facilities {

    background: #f8f9fa;

}



.facility-card {

    background: #ffffff;

    padding: 30px 20px;

    border-radius: 4px;

    height: 100%;

    transition: all 0.3s ease;

    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);

}



.facility-card:hover {

    transform: translateY(-8px);

    box-shadow: 0 12px 35px rgba(0, 0, 0, 0.12);

}



.facility-card .material-symbols-outlined {

    font-size: 48px;

    color: #2c3255;

    margin-bottom: 15px;

}



.facility-card h5 {

    font-weight: 600;

    margin-bottom: 8px;

}



.facility-card p {

    font-size: 14px;

    color: #6c757d;

    margin: 0;

}



        .room-section {



            margin: auto;

        }



        .room-card {

            border: none;

            border-radius: 10px;

            overflow: hidden;

            background: #fff;

            transition: all 0.3s ease;

        }



        .room-card img {

            width: 100%;

            height: 350px;

            object-fit: cover;

            border-radius: 10px;

        }



        .room-card:hover {

            transform: translateY(-5px);

            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);

        }



        .room-content {

            padding: 25px;

        }



        .room-content h6 {

            letter-spacing: 2px;

            font-size: 12px;

            text-transform: uppercase;

            color: #555;

            margin-bottom: 10px;

        }



        .room-content h3 {

            font-weight: 600;

            margin-bottom: 10px;

        }



        .room-content p {

            color: #666;

            font-size: 15px;

            margin-bottom: 20px;

        }



        .btn-dark {

            border-radius: 0;

            padding: 8px 22px;

            font-size: 14px;

        }



        .btn-link {

            color: #000;

            text-decoration: none;

            border-bottom: 1px solid #000;

            margin-left: 15px;

            font-weight: 500;

        }



        @media (max-width: 768px) {

            .room-card img {

                height: 280px;

            }

        }

   