@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@500&display=swap');

:root {
    /* Individual Gold Colors from Figma Stops */
    --gold-dark-1: #BA8843;  /* 0% stop */
    --gold-mid-1: #DEC368;   /* 30% stop */
    --gold-light: #F6E37A;   /* 68% stop */
    --gold-dark-2: #A76A31;  /* 100% stop */

    /* The Full Linear Gradient for backgrounds */
    --gold-gradient: linear-gradient(
        90deg, 
        #BA8843 0%, 
        #DEC368 30%, 
        #F6E37A 68%, 
        #A76A31 100%
    );
}

/* ================= HERO SECTION ================= */

.hero-section{
    position:relative;
    width:100%;
    height:90vh;
    overflow:hidden;
}


.hero-bg{
    position:absolute;
    inset:0; 
    height:100%;
}

.hero-bg img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.active-slide {
    z-index: 1;
}
.next-slide {
    z-index: 2;
    transform: translateX(100%); /* Right side screen-ku veliya lock panniyachi */
    transition: transform 0.8s cubic-bezier(0.25, 1, 0.5, 1); /* Premium hardware sliding acceleration acceleration effect */
}

.next-slide.slide-incoming {
    transform: translateX(0%); 
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.4);
    z-index: 5;
}


.hero-content{
    position:relative;
    z-index:5;

    height:100%;
    width:100%;

    display:flex;
    flex-direction:column;
    justify-content:center;

    padding-left:65px;
    padding-top:15%;

    color:#fff;
}


.hero-subtitle{
    font-family:'Liberation Serif', serif;
    font-size:18px;
    font-style:italic;
    font-weight:100;

    line-height:24px;
    letter-spacing:0.5px;

    color:#ffffff;

    margin-bottom:16px;
}


.hero-title {
    font-family: 'Noto Serif', serif;
    font-size: 44px;
    font-weight: 600; 
    line-height: 50.4px;
    letter-spacing: 0.28px;
    color: #FFFFFF;
    text-align: left; 
    margin-bottom: 16px;}


.hero-buttons{
    display:flex;
    align-items:center;
    gap:20px;
    padding-top:10px;
}


.hero-btn{
    height:40px;
    padding:0 15px;

    font-size:15px;

    letter-spacing:0.6px;
    text-transform:uppercase;

    cursor:pointer;

    font-family: 'Manrope', sans-serif;
}



.primary-btn{
    background:#fff;
    border:none;
    color:#111;
}

.primary-btn:hover{
    color:#000;
    background: var(--gold-gradient);
    background-size: 200% auto;
    font-weight:600;
}


.secondary-btn{
    background:transparent;

    border:2px solid rgba(212,175,55,0.85);

    color:#fff;
}

.secondary-btn:hover{
    background: var(--gold-gradient);
    background-size: 200% auto;
    font-weight:600;
    color:#000;
    
    border:none;
}

/* ================= NEW HERO DOTS STYLES ================= */
.hero-dots {
    position: absolute;
    bottom: 50px; /* Stats bar block mela overlap aagama center layout shadow padding */
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 30; /* Title and image overlays-ku mela crisp ah theriyum */
}

.hero-dot {
    width: 10px;
    height: 10px;
    background-color: rgba(255, 255, 255, 0.4);
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.4s ease;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.hero-dot:hover {
    background-color: rgba(255, 255, 255, 0.8);
}

/* Active image loading state indicator */
.hero-dot.active {
    background-color: #ffffff;
    width: 28px; /* Modern dynamic capsules shape stretch loader */
    border-radius: 10px;
    box-shadow: 0 0 6px rgba(255, 255, 255, 0.5);
}

.hero-desktop-img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .hero-mobile-video {
        display: none;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }




/* ================= RESPONSIVE HERO SECTION ================= */

/* --- TABLET VIEW (992px and below) --- */
@media (max-width: 992px) {
    .hero-section {
        height: 70vh; /* Tablet-il height konjam kuraivurathu */
    }

    .hero-content {
        padding-left: 40px; /* Padding kuraivurathu */
        padding-top: 10%;
    }

    .hero-title {
        font-size: 38px; /* Text size adjust */
        line-height: 44px;
    }
}

/* --- MOBILE VIEW (768px and below) --- */
@media (max-width: 768px) {
    .hero-section {
        height: 80vh; /* Mobile-la content kulla vara height venum */
    }

    .hero-content {
        padding-left: 20px;
        padding-right: 20px;
        padding-top: 0;
        align-items: left; /* Center alignment for mobile */
        text-align: left;
        justify-content:end;
        margin-bottom:1px;

    }



    .hero-subtitle {
        font-size: 16px;
        margin-bottom: 0px;
    }

    .hero-title {
        font-size: 20px;
        line-height: 38px;
        text-align: left; 
        margin-bottom: 0px;
    }

    .hero-buttons {
        flex-direction: column; /* Buttons onre-pinn-onraga varum */
        width: 60%;
        gap: 15px;
    }

    .hero-btn {
        width: 100%; /* Buttons konjam perusaga mobile-il easy-a click seiya */
        height: 45px;
    }
}

/* --- SMALL MOBILE (480px and below) --- */
@media (max-width: 480px) {
    .hero-title {
        font-size: 20px;
        line-height: 34px;
        margin-bottom: 0px;
    }

    .hero-subtitle {
        font-size: 14px;
    }
    
    .hero-btn {
        width: 100%;
        margin-bottom: 2px;
    }
}

/* --- LARGE LAPTOPS (1400px and above) --- */
@media (min-width: 1400px) {
    .hero-content {
        padding-left: 10%; /* Periya screen-il oru katchithamana gap */
    }
    
    .hero-title {
        font-size: 52px; /* Periya laptop-il innum azhagaga theriyum */
        line-height: 60px;
    }
}
 

/* ================= TRENDING SECTION ================= */

.trending-section{
    background:#fff;
    padding:6% 0;
    overflow:hidden;
    position:relative;
}

/* TITLE */

/* .trending-title {
    text-align: center;
    font-family: 'Libertinus Serif', 'Liberation Serif', serif;
    font-size: 38px;
    font-weight: 600; 
    line-height: 42px;
    letter-spacing: 0px;
    color: #111;
    text-transform: uppercase;
    margin-bottom: 40px;
} */

.trending-title {
    text-align: center;
    font-family: 'Libertinus Serif', 'Liberation Serif', serif;
    font-size: 38px;
    font-weight: 600; 
    line-height: 42px;
    letter-spacing: 0px;
    color: #111;
    text-transform: uppercase;
    margin-bottom: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px; 
}

.trending-title .star {
    color: red;
    font-size: 24px;
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

.trending-title .line {
    display: inline-block;
    height: 1.5px;
    width: 120px;  
} 

.trending-title .line-left {
    background: linear-gradient(to left, red, transparent);
}

.trending-title .line-right {
    background: linear-gradient(to right, red, transparent);
}

.trending-carousel-container {
        position: relative;
        max-w: 1400px;
        margin: 0 auto;
        display: flex;
        align-items: center;
        width: 100%;
        padding: 0 10px;
}
/* ================= NEW HOVER SLIDER ================= */

.scroll-wrapper {
    display: flex;
    overflow-x: hidden;
    user-select: none;width: 100%;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
   
}

.scroll-wrapper:active {
    cursor: grabbing;
}

.trending-card {
    scroll-snap-align: start; 
}

/* CONTAINER */

.scroll-container{
    display:flex;
    align-items:center;
    gap:28px;
    width:max-content;
    /* padding:0 40px; */
    padding: 10px 0;
}

/* CARD */

.trending-card{
    position:relative;

    width:670px;
    height:auto;

    flex-shrink:0;

    overflow:hidden;
/* 
    box-shadow:0 15px 40px rgba(0,0,0,0.18); */

    transition:0.4s ease;
}

/* IMAGE */

.trending-card img{
    width:100%;
    height:100%;
    object-fit:cover;

    /* transition:0.5s ease; */
    pointer-events: none;
}



/* .trending-card:hover img{
    transform:scale(1.08);
} */


/* BUTTON */

.know-btn{
    position:absolute;
    right:35px;
    bottom:35px;
    height:40px;
    padding:3% 3% 3% 3%;
    font-size:15px;
    background:#FF0000;
    border:none;
    border-radius:8px;
    color:#fff;
    font-size:12px;
    font-weight:400;
    cursor:pointer;
    letter-spacing:0.6px;
    text-transform:uppercase;
    /* transition:0.3s ease;
    box-shadow:0 10px 20px rgba(0,0,0,0.20); */
    font-family: 'Manrope', sans-serif;
    display: flex;
    align-items: center;    /* Vertically center */
    justify-content: center;
}

/* BUTTON HOVER */

.know-btn:hover{
    color:#000;
    background-size: 200% auto;
    font-weight:600;
}

.nav-arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 50px;
        height: 50px;
        background-color: #ffffff;
        border: none;
        border-radius: 50%;
        color: #111111;
        font-size: 18px;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        z-index: 100;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
        transition: all 0.3s ease;
    }

    .nav-arrow:hover {
        background: var(--gold-gradient);
        color: #000000;
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
    }

    .left-arrow {
        left: 15px;
    }

    .right-arrow {
        right: 15px;
    }
/* ================= RESPONSIVE ================= */

@media(max-width:991px){

    .trending-section{
        padding:60px 0 110px;
    }

    .trending-title{
        font-size:18px;
        margin-bottom:25px;
        gap: 5px;
    }

    .trending-title .star {
        font-size: 18px;
        line-height: 0.5;
    }

    .scroll-container{
        gap:20px;
    }

    .trending-card{
        width:350px;
        height:260px;
    }

    .know-btn{
        right:20px;
        bottom:20px;
        height:46px;
        padding:0 24px;
        font-size:11px;
    }

}

@media(max-width: 768px) {
        .trending-carousel-container {
            padding: 0 5px; 
        }
        
        .nav-arrow {
            width: 20px;
            height: 20px;
            font-size: 10px;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
        }
        
        .left-arrow { left: 3px; }
        .right-arrow { right: 3px; }
    }
    
@media (max-width: 768px) {
    
    .scroll-wrapper {
    display: flex;
    overflow-x: auto; 
    scroll-snap-type: x mandatory; 
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; 
}

.scroll-wrapper::-webkit-scrollbar {
    display: none;
}

.trending-card {
    scroll-snap-align: center; /* or 'start' */
    flex-shrink: 0;
    width: 100%; /* Adjust this to match your design */
    position: relative;
    overflow: hidden;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    
}

.trending-card img {
border-radius: 30px; 
}

    /* --- TRENDING TITLE MOBILE --- */
    .trending-title {
        font-size: 24px;      
        line-height: 30px;
        margin-bottom: 25px;  
        gap: 10px;            
    }

    .trending-title .star {
        font-size: 16px;       
    }

    .trending-title .line {
        width: 50px;          
        height: 1px;          
    }

    /* --- CAROUSEL CONTAINER MOBILE --- */
    .trending-carousel-container {
        padding: 0px;     
        display: block;      
        width: 100%;
    }
}
@media(max-width:576px){


    .trending-section{
        padding:40px 0 10px;

    }

    .trending-title{
        font-size:22px;
        line-height: 35px;
    }

    .scroll-container{
        gap:14px;
    }

    .trending-card{
        width:100%;
        height:fit-content;
        margin:0px;
        padding:5px;

    }

    .know-btn{
        right:12px;
        bottom:12px;

        height:38px;
        padding:0 16px;

        font-size:10px;

        border-radius:6px;
    }

}



/* ================= FOOD SLIDER ================= */

.food-slider-wrapper{
    width:100%;

    overflow-x:auto;
    overflow-y:hidden;

    cursor:grab;

    scroll-behavior:smooth;

    scrollbar-width:none;

    padding-bottom:5px;

    user-select:none;
}


/* HIDE SCROLLBAR */

.food-slider-wrapper::-webkit-scrollbar{
    display:none;
}

/* DRAGGING */

.food-slider-wrapper.dragging{
    cursor:grabbing;
}

/* CONTAINER */

.food-slider-container{
    display:flex;

    align-items:center;

    gap:24px;

    width:max-content;

    padding:0 16px;
    animation: foodMarqueeScroll 28s linear infinite;
}

.food-slider-container:hover {
    animation-play-state: paused;
}

@keyframes foodMarqueeScroll {
    100% {
        transform: translateX(0);
    }
    0% {
        transform: translateX(calc(-250px * 8)); /* Scroll exactly half the total width */
    }
}

/* CARD */

.food-card{
    min-width:320px;

    height:180px;

    overflow:hidden;

    border-radius:18px;

    flex-shrink:0;

    /* box-shadow:0 10px 25px rgba(0,0,0,0.12); */

    /* transition:0.4s ease; */
}

.food-card:hover{
    /* transform:translateY(-6px); */
}

/* IMAGE */

.food-card img{
    width:100%;
    height:100%;

    object-fit:cover;

    pointer-events:none;

    /* transition:0.5s ease; */
}

.food-card:hover img{
    /* transform:scale(1.08); */
}
/* Food Card Hover */
    .food-card {
        transition: all 0.5s ease;
        border: 2px solid transparent;
    }

    .food-card:hover {
        /* transform: scale(1.05);
        border-color: #d4af37; */
        
        border-color: var(--gold-dark-1);
    }

/* ================= MOBILE ================= */

@media(max-width:768px){

    .food-slider-container{
        gap:14px;
    }

    .food-card{
        min-width:200px;

        height:150px;

        border-radius:14px;
    }

    /* Add this to your style block */
/* .stats-boxes, 
.thumbnail-row {
    display: none !important;
} */


}


/* Slider Wrapper */
.slider-wrapper {
    width: 100%;
    overflow: hidden;
    background: #ffffff; /* Light gray background like your image */
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    padding: 30px 0;
    position: relative;

    box-shadow: 0 10px 10px 10px rgba(0,0.1,0,0.2);


}

/* Container for Animation */
.animate-brands {
    display: flex;
    align-items: center;
    width: max-content; /* Content size-ku thaguntha mathiri extend aagum */
    gap: 80px; /* Logos-ku naduvula nalla gap iruka */
    animation: scrollLogos 30s linear infinite;
}

/* Brand Card */
.brand-item {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.brand-logo {
    height: 60px; /* Logo height size */
    width: auto;
    object-contain: contain;
    filter: grayscale(0%); /* Full color logos */
    transition: transform 0.3s ease;
}

.brand-logo:hover {
    transform: scale(1.1);
}

/* Keyframes for Infinite Scroll */
@keyframes scrollLogos {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}



/* ================= BRANDS SLIDER ================= */

.brands-slider-wrapper{
    width:100%;

    overflow:hidden;

    border-top:1px solid #efefef;
    border-bottom:1px solid #efefef;

    background:#fafafa;

    padding:35px 0;
}

.brands-slider-container{
    display:flex;

    align-items:center;

    gap:90px;

    width:max-content;

    animation:brandScroll 28s linear infinite;

    padding:0 30px;
}

/* BRAND ITEM */

.brand-item{
    min-width:180px;

    display:flex;
    align-items:center;
    justify-content:center;
}

/* LOGO */

.brand-logo{
    height:62px;

    width:auto;

    object-fit:contain;

    cursor:pointer;

    transition:0.35s ease;
}

.brand-logo:hover{
    transform:scale(1.08);

    opacity:0.85;
}

/* ANIMATION */

@keyframes brandScroll{

    0%{
        transform:translateX(0);
    }

    100%{
        transform:translateX(-50%);
    }

}

/* ================= BUSINESS SECTION ================= */

.business-section{
    width:100%;

    background:#fff;

    padding:40px 60px;

    overflow:hidden;

    text-align:center;

    font-family:'Montserrat', sans-serif;
}

/* TOP TEXT */

.business-top-text{
    font-size:15px;

    font-weight:600;

    text-transform:uppercase;

    color:#000;

    margin-bottom:16px;

    letter-spacing:0px;
}



.business-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    justify-items: center; 
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px; 
}

.business-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: 0.4s ease;
    width: 100%;
    max-width: 200px;
}

.card-space-top{
    margin-top:80px;
}

/* IMAGE BOX */

.business-image-box{
    width:100%;

    height:320px;

    overflow:hidden;

    border-radius:24px;

    margin-bottom:15px;

    box-shadow:0 15px 35px rgba(0,0,0,0.15);
}

/* IMAGE */

.business-image-box img{
    width:100%;
    height:100%;

    object-fit:cover;

}

.business-card-title {
    font-size: 16px;
    font-weight: 700;
    color: #111;
    text-align: left;
    width: 100%; 
    margin-bottom: 8px; 
}

.business-card-desc {
    font-size: 14px;
    line-height: 1.8;
    color: #000;
    text-align: left;
    max-width: 250px; 
    width: 100%;
    margin-bottom: 15px;
}

/* BUTTON */

.business-btn{
    width:fit-content;

    height:45px;
    padding:0 28px;

    background:#FF0000;

    border:none;
    border-radius:8px;

    color:#fff;

    font-size:12px;
    font-weight:400;

    text-transform:uppercase;

    letter-spacing:1px;

    cursor:pointer;

    
    font-family:'manrope',sans-serif;
    align-self: center;
}

/* BUTTON HOVER */

.business-btn:hover{
    background-size: 200% auto;
    color:#000;
    font-weight:600;

}

/* ================= TABLET ================= */

@media(max-width:991px){

    .business-section{
        padding:40px 25px;
    }

    .business-title{
        font-size:38px;

        margin-bottom:50px;
    }

    .business-grid{
        grid-template-columns:repeat(2,1fr);

        gap:35px;
    }

    .business-image-box{
        height:300px;
    }

    .card-space-top{ 
        margin-top:0;
    }

}

/* ================= MOBILE ================= */

@media(max-width:768px){

    .brands-slider-container{
        gap:35px;
    }

    .brand-item{
        min-width:110px;
    }

    .brand-logo{
        height:40px;
    }

    .business-section{
        /* padding:40px 16px; */
        padding:0px 16px 20px;
    }

    .business-top-text{
        font-size:12px;
    }

    .business-title{
        font-size:30px;
        margin-bottom:35px;
    }

    .business-grid{
        grid-template-columns:repeat(1,1fr);
        gap:10px;
        padding:0px;
    }

    .business-image-box{
        height:240px;
        border-radius:18px;
    }

    .business-card-title{
        font-size:22px;
        letter-spacing: 0px;
    }

    

    .business-card-desc{
        font-size:15px;
        letter-spacing: 0px;
        margin-bottom: 15px !important;
        
    }
    .business-card {
        display: flex !important;
        flex-direction: column !important;
        height: 100% !important; 
        max-width: 100% !important;
    }
    .business-btn {
        margin-top: auto !important; 
        /* padding:0 8px; */
        width: 100%;
        font-size:20px;
        padding:6px 15px;
        height:fit-content;
    }
    

}


/* ================= EXPERIENCE SECTION ================= */

.experience-section{
    padding:42px 80px;

    background:linear-gradient(
        to right,
        #E10004,
        #5B0000
    );

    overflow:hidden;

    color:#fff;
    /* height: 480px; */

    height: fit-content;
}

/* CONTAINER */

.experience-container{
    max-width:1400px;
    margin:auto;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
    justify-items: center; 
    align-items:center;
}

/* CARD */

.experience-card{
    cursor:pointer;
    width:200px;
}

/* IMAGE BOX */

.experience-image-box{
    position:relative;

    height:320px;


    overflow:hidden;

    border-radius:10px;

    margin-bottom:22px;

    transition:0.5s ease;

}

/* IMAGE */

.experience-image-box img{
    width:100%;
    height:100%;

    object-fit:cover;

    transition:0.7s ease;
}

/* OVERLAY */

.experience-overlay{
    position:absolute;
    inset:0;

    transition:0.5s ease;
}

/* HOVER */



/* .experience-card:hover img{
    transform:scale(1.10);
} */

.experience-card:hover .experience-overlay{
    background:transparent;
}

/* CONTENT */

.experience-content h3{
    font-size:16px;

    font-weight:500;

    margin-bottom:5px;

    text-transform:uppercase;

    transition:0.4s ease;
}

.experience-content p{
    font-size:11px;

    color:#f1f1f1;

    line-height:1;
}

/* GOLD TITLE HOVER */


/* GOLD LINE */

.experience-line{
    width:0;

    height:3px;

    background:#fff;

    margin-top:18px;

    transition:0.5s ease;
}

.experience-card:hover .experience-line{
    width:100px;
}

/* ================= RESPONSIVE ================= */

/* ================= RESPONSIVE FIX ================= */

@media(max-width:991px){
    .experience-section {
        padding: 40px 20px; /* Padding reduced for tablets */
    }

    .experience-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px;
        justify-items: center;
    }

    .experience-card {
        width: 100%; /* Card container width-ku ethaarpola maarum */
        max-width: 300px; 
    }

    .experience-image-box {
        height: 280px;
        width: 100%;
    }
}

@media(max-width:576px){
    .experience-section {
        padding: 40px 15px;
    }

    .experience-container {
        grid-template-columns: repeat(1, 1fr); /* Mobile-layum 2 columns nalla irukkum */
        gap: 15px; /* Gap kuraivurathu space save panna */
    }

    .experience-card {
        width: 100%; /* Important: Fixed 100px-ai remove seithullan */
        max-width: 100%;
    }

    .experience-image-box {
        height: 400px; /* Mobile-ukku etha height */
        width: 100%;
        border-radius: 12px;
        margin-bottom: 10px;
    }

    .experience-content h3 {
        font-size: 22px; /* Text size refined */
        margin-bottom: 4px;
        letter-spacing: 0.5px;
    }

    .experience-content p {
        font-size: 15px;
        line-height: 1.3;
        display: -webkit-box; /* Description romba neelama ponaal 2 lines-la cut aagum */
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .experience-line {
        margin-top: 8px;
        height: 5px;
    }
    
    .experience-card:hover .experience-line {
        width: 100px; /* Mobile-la chinna line pothum */
    }
}

/* Very Small Screen (e.g. iPhone SE) */
@media(max-width: 360px) {
    .experience-container {
        grid-template-columns: 1fr; /* Romba chinna phone-na oru column best */
        gap: 25px;
    }
    .experience-image-box {
        height: 220px;
    }
}


/* ================= AMENITIES SECTION ================= */

.amenities-section{
    padding:60px 20px;
    background:#fff;
    overflow:hidden;
    font-family:'Montserrat',sans-serif;
}

/* CONTAINER */

.amenities-container{
    max-width:1250px;
    margin:auto;
}

/* TOP LABEL */

.amenities-tag{
    font-family: 'Manrope', sans-serif; 
    font-size:16px;
    font-weight:400;

    display:inline-block;

    background:#ff0000;
    border:none;
    border-radius:8px;
    color:#fff;

    padding:10px 35px;
    text-transform:uppercase;
    letter-spacing:1px;

    cursor:pointer;

    /* margin-bottom:28px; */
}

.amenities-btn{
    font-family: 'Manrope', sans-serif; 
    font-size:16px;
    font-weight:400;

    display:inline-block;

    background:#ff0000;
    border:none;
    border-radius:8px;
    color:#fff;

    padding:10px 35px;
    text-transform:uppercase;
    letter-spacing:1px;

    cursor:pointer;

    margin-bottom:5px;
}

.amenities-btn:hover{
    color:#000;
    font-weight:600;
}
/* TITLE */

.amenities-title{
    font-family:'Libertinus Serif', serif;

    font-size:38px;
    font-weight:600;

    line-height:1.1;

    text-transform:uppercase;
    color:#111;
    margin-bottom:40px;
}


.amenities-grid{
    display:grid;

    grid-template-columns:1fr 1fr 1fr;

    gap:26px;

    align-items:center;
}


.img-box{
    position:relative;

    overflow:hidden;


    transition:0.5s ease;

    cursor:pointer;
}


.img-left{
    height:350px;

    margin-top:90px;
}

.img-center{
    height:460px;

    margin-top:40px;
}

.img-right{
    height:555px;
}

.img-box img{
    width:100%;
    height:100%;

    object-fit:cover;

    transition:0.7s ease;
}

.img-box::after{
    content:"";

    position:absolute;
    inset:0;

    background:linear-gradient(
        to top,
        rgba(0,0,0,0.15),
        transparent
    );

    transition:0.4s ease;
}



.img-box:hover::after{
    background:rgba(0,0,0,0.05);
}


.amenities-btn-wrap{
    display:flex;

    justify-content:center;

    margin-top:60px;
}




.dot-container{
    display:flex;

    justify-content:center;

    gap:10px;

    margin-top:35px;
}

.dot{
    width:10px;
    height:10px;

    border-radius:50%;

    background:#d7d7d7;

    transition:0.4s ease;
}

.active-dot{
    width:34px;

    border-radius:20px;

    background:#e11919;
}


.fade-img{
    animation:fadeImage 0.8s ease;
}

@keyframes fadeImage{

    from{
        opacity:0.4;
        transform:scale(1.03);
    }

    to{
        opacity:1;
        transform:scale(1);
    }

}


@media(max-width:991px){

    .amenities-title{
        font-size:40px;

        margin-bottom:25px;
    }

    .amenities-grid{
        gap:18px;
    }

    .img-left{
        height:300px;

        margin-top:60px;
    }

    .img-center{
        height:420px;

        margin-top:30px;
    }

    .img-right{
        height:520px;
    }

}

@media(max-width:576px){

    .amenities-section{
        padding:55px 0px;
    }

    .amenities-title{
        font-size:22px;

        line-height:1.25;

        margin-bottom:35px;
    }

    .amenities-grid{
        grid-template-columns:1fr 1fr;
        gap:12px;
    }
    .amenities-tag{
    font-size:12px;
    padding:6px 15px;
    margin-bottom:5px;
}

.amenities-btn{
    font-size:12px;
    padding:6px 15px;
    margin-bottom:5px;
}


    .img-left{
        height:180px;

        margin-top:50px;
    }

    .img-center{
        height:240px;

        margin-top:20px;
    }

    .img-right{
        height:320px;

        grid-column:span 2;
    }

    .btn-gold{
        height:44px;

        padding:0 24px;

        font-size:11px;
    }

    .dot{
        width:8px;
        height:8px;
    }

    .active-dot{
        width:24px;
    }

}


.founder-section{
    padding:42px 80px;

    background:linear-gradient(
        to bottom,
        #000000,
        #3F301D
    );

    overflow:hidden;

    color:#fff;
    height: fit-content;
}


.faq-section{
    width:100%;
    background:#efefef;
}


.faq-top{
    text-align:center;

    padding:28px 20px 55px;
}

.faq-mini-title{
    font-size:15px;

    font-weight:600;

    color:#111;

    margin-bottom:16px;

    font-family:'Montserrat', sans-serif;

    letter-spacing:0.5px;
}

.faq-main-title{
    font-family:'Times New Roman', serif;

    font-size:72px;

    font-weight:500;

    line-height:1.1;

    color:#000;

    text-transform:uppercase;

    letter-spacing:1.5px;
}


.faq-body-section{
    width:100%;
    background:#E3174F;
     /* padding:55px 60px 65px; */
    padding:40px 20px;
    display:flex;
    justify-content:center;
}

/* .faq-grid{
    max-width:1200px;
    margin:0 ;
    display:grid;
    grid-template-columns:repeat(2,1fr);
    column-gap:50px;
} */

.faq-grid{
    max-width:1200px;
    width:100%;
    display:flex;
    gap:50px;
}

.faq-column{
    flex:1;
}


.faq-item{
    border-bottom:1px solid rgba(255,255,255,0.45);

    padding: 10px 20px;

    transition:0.3s ease;
}


.faq-question{
    display:flex;

    align-items:center;

    justify-content:space-between;

    gap:20px;

    cursor:pointer;
}

.faq-text{
    /* font-size:10px; */

    font-weight:700;

    line-height:1.5;

    color:#fff;

    font-family:'Montserrat', sans-serif;
}


.faq-num{
    margin-right:15px;

    font-weight:800;
}


.faq-arrow{
    width:30px;
    height:30px;

    min-width:30px;

    border:3px solid #fff;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    transition:0.4s ease;

    color:#fff;
}

.faq-arrow i{
    font-size:13px;
}


.faq-item.active .faq-arrow{
    transform:rotate(180deg);

    background:#fff;

    color:#E3174F;
}


.faq-answer{
    max-height:0;

    overflow:hidden;

    transition:
    max-height 0.5s ease,
    padding-top 0.5s ease;

    padding-left:36px;
}

.faq-answer p{
    color:rgba(255,255,255,0.88);

    font-size:15px;

    line-height:1.8;

    font-weight:500;

    padding-right:20px;

    font-family:'Montserrat', sans-serif;
}

.faq-item.active .faq-answer{
    max-height:220px;

    padding-top:18px;
} 

/* ================= MOBILE ================= */

@media(max-width:1024px){

    .faq-grid{
        flex-direction:column;
        gap:0;
    }

}

@media(max-width:991px){

    .faq-main-title{
        font-size:42px;

        line-height:1.2;
    }

    .faq-body-section{
        padding:35px 20px 45px;
    }

    .faq-grid{
        grid-template-columns:1fr;

        column-gap:0;
    }

    .faq-item{
        padding:10px 0px;
    }

    /* .faq-question{
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:20px;
        cursor:pointer;
    } */

    .faq-text{
        font-size:15px;

        line-height:1.6;
    }

    .faq-arrow{
        width:32px;
        height:32px;

        min-width:32px;
    }

    .faq-arrow i{
        font-size:11px;
    }

    .faq-answer{
        padding-left:24px;
    }

    .faq-answer p{
        font-size:13px;

        line-height:1.7;
    }

}

@media(max-width:430px){
    .faq-text{
        font-size:13px;

        line-height:1.6;
    }

    .faq-arrow{
        width:25px;
        height:25px;
        min-width:25px;
    }

    .faq-arrow i{
        font-size:10px;
    }
}

/* ================= CONTACT SECTION ================= */

/* 
.contact-section {

    position: relative;

    width: 100%;

    min-height: 70vh;

    display: flex;

    flex-direction: column;

    align-items: center;

    justify-content: center;

    padding: 60px 20px;

    overflow: hidden;

    font-family: Georgia, serif;


    background-image: url("../images/customer-support.jpg");

    background-position: center center;

    background-repeat: no-repeat;

    background-size: 100% 100%;
}


.contact-content-wrapper{
    width:100%;

    max-width:1400px;

    display:flex;

    justify-content:flex-start;
}


.form-container{
    width:100%;

    max-width:360px;
}


.form-group{
    margin-bottom:24px;
}


.form-input{
    width:100%;

    height:50px;

    border:none;

    outline:none;

    border-radius:40px;

    background:#fff;

    padding:0 30px;

    font-size:18px;

    color:#444;

    font-family:'Times New Roman', serif;

    box-shadow:
    0 6px 20px rgba(0,0,0,0.08);
}


.form-textarea{
    height:120px;

    padding-top:28px;

    resize:none;

    border-radius:28px;
}


.form-input::placeholder{
    color:#9a9a9a;

    letter-spacing:1px;
}

.send-btn{
    width:80%;

    height:50px;

    border:none;

    border-radius:40px;

    background:#000;

    color:#fff;

    font-size:20px;

    text-transform:uppercase;

    font-family:'Times New Roman', serif;

    cursor:pointer;

    transition:0.4s ease;

    box-shadow:
    0 10px 25px rgba(0,0,0,0.15);
}


.send-btn:hover{
     background: linear-gradient(
        90deg, 
        #BF953F 0%, 
        #FCF6BA 30%, 
        #B38728 60%, 
        #FBF5B7 80%, 
        #AA771C 100%
    );
    background-size: 200% auto;
    color:#000;

    transform:translateY(-2px);
}


@media(max-width:768px){

    .contact-section{
        padding:60px 18px;

        align-items:flex-start;
    }

    .contact-content-wrapper{
        justify-content:center;
    }

    .form-input{
        height:58px;

        font-size:15px;

        padding:0 22px;
    }

    .form-textarea{
        height:140px;

        padding-top:20px;
    }

    .send-btn{
        height:58px;

        font-size:16px;
    }

}
 */

/* ================= CONTACT SECTION ================= */

.contact-section {
    width: 100%;
    background: #fff;
    overflow: hidden;
    font-family: Georgia, serif;
    max-width: 1680px;
    align-items: center;
    justify-content: center;
}

/* .contact-main-container {
    display: flex;
    max-height: 400px;
    width: 100%;
    background-image: url('images/contact-support.jpg');
    
} */

.contact-main-container {
    display: flex;
    min-height: 400px; 
    width: 100%;
    
    /* Background Image setup */
    background-image: url('../images/contact-support.jpg'); 
    background-size: 50% cover, cover;       
    background-position: right center, left center;
    background-repeat: no-repeat, no-repeat;  
    
    /* Flex alignment properties (Optional layout support) */
    justify-content: flex-start;       
    align-items: center; 
    position: relative;
}

/* LEFT SIDE - Form Background */
.contact-left-side {
    flex: 0 0 50%;
    /* background-color: #ffffff;  */
    display: flex;
    align-items: center;    
    justify-content: center; 
    padding: 60px 0px 60px 60px;
    z-index: 2;
}
.form-container{
    width:100%;
    max-width:360px;
}

.form-wrapper {
    width: 100%;
    max-width: 400px; 
}

/* RIGHT SIDE - Image Area */
.contact-right-side {
    flex: 1;
    display: flex;
}

.contact-right-side img {
    width: 100%;
    height: 100%;
    /* object-fit: cover;  */
    padding-right:0px;
    margin-right:0px;
}

/* FORM STYLES */
/* .form-group {
    margin-bottom: 24px;
} */

.form-input {
    width: 100%;
    height: 54px;
    border: 1px solid #e0e0e0; 
    border:none;  
    outline: none;
    border-radius: 40px;
    background: #fff;
    padding: 0 30px;
    font-size: 18px;
    color: #444;
    font-family: 'Times New Roman', serif;
    box-shadow: 0 4px 15px rgba(0,0,0,0.03); /* Subtle shadow */
    transition: border-color 0.3s;
}

.form-input:focus {
    border-color: #000;
}

/* .form-textarea {
    height: 120px;
    padding-top: 28px;
    resize: none;
    border-radius: 20px;
} */

.form-textarea {
        border-radius: 25px;
        height: 150px;
        resize: none;
        padding-top: 20px;
    }


.form-input::placeholder{
    color:#9a9a9a;
    letter-spacing:1px;
}

.form-input::placeholder {
  color: #9a9a9a;
  letter-spacing: 1px;
}

/* .form-group {
  margin-bottom: 24px;
} */

.form-input {
  width: 100%;
  height: 54px;
  /* Use a proper border definition if needed */
  border: 1px solid #e0e0e0; 
  /* Removing border:none to allow shadow to be visible */
  outline: none;
  border-radius: 40px;
  background: #fff;
  padding: 0 30px;
  font-size: 18px;
  color: #444;
  font-family: 'Times New Roman', serif;
  box-shadow: 0 4px 15px rgba(0,0,0,0.03); /* Subtle shadow */
  transition: border-color 0.3s;
}

.form-input:focus {
  border-color: #000;
}

/* BUTTON CENTERING */
.btn-center-wrapper {
    display: flex;
    justify-content: center;
}

.send-btn {
    width: 100%;
    /* max-width: 280px;  */
    height: 50px;
    border: none;
    border-radius: 40px;
    background: #000;
    color: #fff;
    font-size: 18px;
    text-transform: uppercase;
    font-family: 'Libertinus Serif', Georgia, serif;
    cursor: pointer;
    transition: 0.4s ease;
}

.send-btn:hover {
    background: var(--gold-gradient);
    color: #000;
    /* transform: translateY(-2px); */
}

/* ================= MOBILE RESPONSIVE ================= */

@media (max-width: 992px) {
    .contact-main-container {
        flex-direction: column;
        background-image: url('../images/contact-support.jpg'); 
        background-size: cover;
        background-position: center;
    }
    
    .contact-right-side {
        /* height: 350px; 
        order: 2; */
        display: none !important;
    }
    
    .contact-left-side {
        /* order: 1; */
        flex: 0 0 100%;
        width: 100%;
        padding: 40px 20px;
    }
}


.custom-input, .custom-textarea {
    width: 100%;
    font-family: 'Libertinus Serif', Georgia, serif;
    font-weight: 600; 
    font-size: 18px;
    line-height: 54px; 
    letter-spacing: 0px;
    color: #9F9F9F; 
    
    border: 1px solid #e0e0e0;
    border-radius: 40px;
    background-color: #ffffff;
    padding: 0 15px;
    outline: none;
    box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.27);
    margin-bottom: 10px;
    transition: box-shadow 0.3s ease;
}

.custom-textarea {
    height: 130px;
    line-height: 1.5; 
    padding-top: 20px;
    border-radius: 30px;
    resize: none;
}

.custom-input::placeholder, .custom-textarea::placeholder {
    color: #9F9F9F;
    opacity: 1; 
}

.custom-input:focus, .custom-textarea:focus {
    box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.35);
    border-color: #000;
}



 /* ================= FOUNDER SECTION MOBILE RESPONSIVE ================= */

@media (max-width: 768px) {
    /* Section padding kuraikalam */
    .founder-section {
        padding: 40px 0;
    }

    /* Main Box-ah column-ah mathanum */
    .founder-section .flex-col.md\:flex-row {
        flex-direction: column !important;
        align-items: center;
        text-align: center;
        padding-bottom: 30px;
    }

    /* Image Section width full-ah mathanum */
    .founder-section .md\:w-\[40\%\] {
        width: 100% !important;
        display: flex;
        justify-content: center;
        margin-bottom: 20px;
    }

    /* Image-oda overlap position-ah reset pannanum */
    .founder-section .md\:-top-10 {
        position: relative !important;
        top: 0 !important;
        left: 0 !important;
        max-width: 280px; /* Mobile-la image romba perusa theriya koodathu */
        padding: 0;
    }

    /* Image margin-ah center panna reset pannunga */
    .founder-section img {
        margin-left: 0 !important;
        margin-top: 0px !important;
        border-radius: 15px;
    }

    /* Content Section padding matrum text center */
    .founder-section .md\:w-\[60\%\] {
        width: 100% !important;
        padding: 0 25px !important;
        text-align: center !important;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    /* Quote icon-ah center panna */
    .founder-section .text-5xl {
        font-size: 60px;
        margin-top: 10px;
        line-height: 1;
    }

    /* Paragraph text alignment */
    .founder-section .text-black {
        text-align: center !important;
    }

    /* Founder Info (Name & LinkedIn) alignment center */
    .founder-section .items-end {
        align-items: center !important;
        margin-top: 25px;
    }

    .founder-section .group {
        justify-content: center;
    }
}


/* ================= CONTACT FORM MOBILE VIEW ================= */

@media (max-width: 768px) {
.custom-input, .custom-textarea {
 
    font-size: 12px;
}


}

    @media (max-width: 768px) {
    .hide-on-mobile {
        display: none !important;
    }
    /* .trending-section .trending-card {
        width: 100%; 
        height: 200px;
    } */
    /* .trending-section .know-btn {
        font-size: 10px;
        padding: 5px 10px;
        background: rgba(0,0,0,0.6); 
    } */
}

@media (min-width: 769px) {
    .hide-on-desktop {
        display: none !important;
    }
}

.hero-mobile-content { display: none; }
.hero-desktop-content { display: block; }

@media (max-width: 1023px) {
    /* On mobile, swap them */
    .hero-desktop-content { display: none !important; }
    .hero-mobile-content { 
        display: block !important; 
        width: 100%; 
        height: 100%; 
    }
    .hero-mobile-content video {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
}