@charset "utf-8";

/* =========================================================
ROOM HERO
========================================================= */

.room-hero{
    position:relative;
    height:82vh;

    display:flex;
    align-items:center;
    justify-content:center;

    text-align:center;

    overflow:hidden;
}

/* =========================================================
ONE BEDROOM HERO
========================================================= */

.room-hero-bg{
    position:absolute;
    inset:0;

    background:
    linear-gradient(rgba(0,0,0,0.58),rgba(0,0,0,0.42)),
    url('../images/one-bedroom-pool-villa-hero.webp') center/cover no-repeat;

    animation:heroZoom 14s ease-in-out infinite alternate;
}

@keyframes heroZoom{

    from{
        transform:scale(1);
    }

    to{
        transform:scale(1.08);
    }

}

/* =========================================================
TWO BEDROOM HERO
========================================================= */

.two-bedroom-hero .room-hero-bg{

    position:absolute;
    inset:0;

    background:
    linear-gradient(rgba(0,0,0,0.45),rgba(0,0,0,0.35)),
    url('../images/two-bedroom-pool-villa-hero.webp') center/cover no-repeat;

    animation:heroZoom 14s ease-in-out infinite alternate;
}

@keyframes heroZoom{

    from{
        transform:scale(1);
    }

    to{
        transform:scale(1.08);
    }

}

/* =========================================================
ONE BEDROOM SUITE HERO
========================================================= */

.one-bedroom-suite-hero .room-hero-bg{

    position:absolute;
    inset:0;

    background:
    linear-gradient(rgba(0,0,0,0.45),rgba(0,0,0,0.35)),
    url('../images/one-bedroom-suite-villa-hero.webp') center/cover no-repeat;

    animation:heroZoom 14s ease-in-out infinite alternate;
}

@keyframes heroZoom{

    from{
        transform:scale(1);
    }

    to{
        transform:scale(1.08);
    }

}

.room-hero-content{
	position:relative;
    z-index:2;

    max-width:850px;

    color:var(--white);
}

.room-subtitle{
    font-size:12px;
    letter-spacing:3px;
    margin-bottom:16px;
    text-transform:uppercase;
}

.room-hero h1{
    font-family:'Cormorant Garamond',serif;
    font-size:48px;
    line-height:1.05;
    margin-bottom:28px;
	max-width: 1100px;
}

.room-hero p{
    font-size:18px;
    max-width:700px;
    margin:auto;
    margin-bottom:35px;
}

.room-info-row{
    display:flex;
    justify-content:center;
    gap:25px;
    flex-wrap:wrap;
    margin-top:10px;
    margin-bottom:40px;

    font-size:14px;
    letter-spacing:0.5px;
}

.hero-buttons{
    display:flex;
    justify-content:center;
    align-items:center;

    gap:20px;

    flex-wrap:wrap;

    margin-top:35px;
}

.hero-buttons a{
    min-width:280px;
}


/* =========================================================
VILLA HIGHLIGHTS
========================================================= */

.villa-highlights{
    padding:0 7%;
    margin-top:20px;
    position:relative;
    z-index:20;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}

.highlight-card{
    background:rgba(255,255,255,0.72);

    backdrop-filter:blur(14px);

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

    padding:18px;

    border-radius:22px;

    text-align:center;

    box-shadow:0 10px 28px rgba(0,0,0,0.06);

    font-size:14px;

    transition:0.35s ease;
}

.highlight-card:hover{
    transform:translateY(-5px);

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

/* =========================================================
ROOM INTRO
========================================================= */

.room-intro-grid{
    display:grid;
    grid-template-columns:1fr 1fr;

    gap:80px;
    align-items:center;
}

.room-intro-image img{
    height:560px;
    object-fit:cover;

    border-radius:20px;
}

.room-specs{
    margin-top:40px;

    display:grid;
    grid-template-columns:repeat(3,1fr);

    gap:15px;
}

@media(max-width:768px){

    .room-intro-grid{
        gap:40px;
    }

}

.spec-item{
    background:#faf7f2;

    padding:18px;

    border-radius:18px;

    border:1px solid rgba(0,0,0,0.04);

    transition:0.3s ease;
}

.spec-item:hover{
    transform:translateY(-3px);

    box-shadow:0 12px 30px rgba(0,0,0,0.04);
}

.spec-item span{
    display:block;

    margin-bottom:8px;

    font-size:12px;

    letter-spacing:1px;

    text-transform:uppercase;

    color:var(--primary-dark);
}

.intro-content a{
    color:var(--primary-dark);

    text-decoration:none;

    border-bottom:1px solid transparent;

    transition:0.3s ease;
}

.intro-content a:hover{
    color:var(--primary);

    border-bottom:1px solid var(--primary);
}

/* REMOVE PURPLE VISITED COLOR */

.intro-content a:visited{
    color:var(--primary-dark);
}

/* =========================================================
ROOM GALLERY
========================================================= */

.room-gallery{
    columns:3 280px;
    column-gap:20px;
}

.room-gallery img{
    width:100%;
    display:block;
    margin-bottom:20px;

    border-radius:20px;

    transition:0.5s ease;
}

.room-gallery img:hover{
    transform:scale(1.02);
}

/* =========================================================
AMENITIES
========================================================= */

.room-amenities-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);

    gap:30px;
}

.amenity-box{
    background:rgba(255,255,255,0.72);

	backdrop-filter:blur(12px);

	border:1px solid rgba(0,0,0,0.04);

    padding:40px;

    border-radius:24px;

    box-shadow:0 8px 24px rgba(0,0,0,0.04);
}

.amenity-box h3{
    font-family:'Cormorant Garamond',serif;

    font-size:32px;

    margin-bottom:20px;
}

.amenity-box ul li{
    list-style:none;

    margin-bottom:14px;

    color:var(--text-light);
}

/* =========================================================
ROOM EXPERIENCE
========================================================= */

.room-experience-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);

    gap:25px;
}

.room-experience-card{
    position:relative;

    overflow:hidden;

    border-radius:24px;
}

.room-experience-card img{
    height:520px;

    object-fit:cover;

    transition:0.5s ease;
}

.room-experience-card:hover img{
    transform:scale(1.05);
}

.room-experience-overlay{
    position:absolute;
    inset:0;

    background:
    linear-gradient(
    to top,
    rgba(0,0,0,0.65),
    transparent
    );

    display:flex;
    align-items:flex-end;

    padding:30px;
}

.room-experience-overlay h3{
    color:var(--white);

    font-family:'Cormorant Garamond',serif;

    font-size:36px;
}

/* =========================================================
BOOKING SECTION
========================================================= */

.room-booking-section{
    padding:110px 7%;
	background: var(--bg-soft);
}

.room-booking-card{
    background:var(--white);

    padding:50px;

    border-radius:32px;

    box-shadow:0 20px 60px rgba(0,0,0,0.06);
}

.room-booking-card h2{
    font-family:'Cormorant Garamond',serif;

    font-size:48px;

    text-align:center;

    margin-bottom:40px;
}

.room-booking-grid{
    display:grid;
    grid-template-columns:1fr 1fr 1fr auto;

    gap:20px;
}

.room-booking-trust{
    margin-top:30px;

    display:flex;
    justify-content:center;
    gap:30px;

    flex-wrap:wrap;

    color:#777;

    font-size:14px;
}

/* =========================================================
ROOM REVIEWS
========================================================= */

.room-review-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);

    gap:30px;
}

/* =========================================================
LOCATION HIGHLIGHTS
========================================================= */

.room-location-highlights{
    display:grid;
    grid-template-columns:repeat(4,1fr);

    gap:20px;
}

/* =========================================================
RESPONSIVE
========================================================= */

@media(max-width:992px){

    .villa-highlights,
    .room-specs{
        grid-template-columns:1fr 1fr;
    }

    .room-intro-grid,
    .room-amenities-grid,
    .room-experience-grid,
    .room-review-grid,
    .room-location-highlights{
        grid-template-columns:1fr;
    }

    .room-booking-grid{
        grid-template-columns:1fr;
    }

    .room-hero h1{
        font-size:58px;
    }

}

@media(max-width:768px){

    .room-hero h1{
        font-size:46px;
    }

    .room-intro-image img,
    .room-experience-card img{
        height:420px;
    }

    .villa-highlights,
    .room-specs{
        grid-template-columns:1fr;
    }

    .room-booking-card{
        padding:40px 25px;
    }

    .room-booking-card h2{
        font-size:42px;
    }
	
	.room-hero-bg{
    animation:none;
	}

}

/* =========================================================
FAQ
========================================================= */

.faq-grid{
    max-width:900px;
    margin:auto;

    display:grid;
    gap:20px;
}

.faq-item{
    background:var(--white);

    padding:35px;

    border-radius:20px;

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

.faq-item h3{
    font-size:20px;

    margin-bottom:14px;

    color:var(--text);
}

.faq-item p{
    color:var(--text-light);

    line-height:1.8;
}

/* =========================================================
ROOM COMPARISON
========================================================= */

.comparison-grid{
    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:30px;

    max-width:1100px;

    margin:auto;
}

.comparison-card{
    background:var(--white);

    border-radius:24px;

    overflow:hidden;

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

    transition:0.4s ease;
}

.comparison-card:hover{
    transform:translateY(-8px);

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

.comparison-image{
    overflow:hidden;
}

.comparison-image img{
    height:320px;

    object-fit:cover;

    transition:0.5s ease;
}

.comparison-card:hover img{
    transform:scale(1.05);
}

.comparison-content{
    padding:35px;
}

.comparison-subtitle{
    font-size:12px;

    letter-spacing:2px;

    text-transform:uppercase;

    color:var(--primary-dark);

    margin-bottom:14px;
}

.comparison-content h3{
    font-family:'Cormorant Garamond',serif;

    font-size:38px;

    line-height:1.1;

    margin-bottom:18px;
}

.comparison-content p{
    color:var(--text-light);

    margin-bottom:24px;

    line-height:1.8;
}

.comparison-info{
    margin-bottom:28px;

    font-size:14px;

    color:#777;
}

.comparison-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    padding:14px 28px;

    border-radius:50px;

    background:var(--primary);

    color:var(--white);

    text-decoration:none;

    font-size:13px;

    letter-spacing:1px;

    transition:0.35s ease;
}

.comparison-btn:hover{
    background:var(--primary-dark);

    transform:translateY(-3px);
}

@media(max-width:768px){
	
.comparison-grid{
    grid-template-columns:1fr;
    gap:24px;
}

.comparison-image img{
    height:240px;
}

.comparison-content{
    padding:26px;
}

.comparison-content h3{
    font-size:30px;
}

.comparison-content p{
    font-size:15px;
    line-height:1.7;
}

.comparison-btn{
    width:100%;
}
	
 .comparison-subtitle{
        display:none;
    }
	
    .comparison-card{
        border-radius:22px;
    }

    .comparison-image img{
        border-radius:0;
    }
	
	
}

/* =========================================================
GALLERY HOVER
========================================================= */

.room-gallery a{
    position:relative;

    display:block;

    overflow:hidden;

    border-radius:24px;
}

.room-gallery a::after{
    content:'+';

    position:absolute;
    inset:0;

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

    display:flex;
    align-items:center;
    justify-content:center;

    color:#fff;

    font-size:42px;

    opacity:0;

    transition:0.35s ease;
}

.room-gallery a:hover::after{
    opacity:1;
}

/* =========================================================
ROOM MOBILE HERO
========================================================= */

@media(max-width:768px){

    .room-hero{
    min-height:82svh;

    padding:
    120px 24px 70px;
}

    .room-hero-content{
    max-width:320px;
    margin:auto;
}

    .room-hero h1{
    font-size:42px;

    line-height:1.02;

    max-width:320px;

    margin:auto;

    margin-bottom:20px;
}

    .room-hero p{
    font-size:15px;

    max-width:300px;

    line-height:1.7;

    margin-bottom:28px;
}

    .room-info-row{
        gap:14px;

        font-size:13px;
    }
	
.btn-secondary{
        height:54px;
        font-size:14px;
        opacity:0.92;
    }

}


/* =========================================================
PREMIUM BOOKING CTA
========================================================= */

.booking-premium-card{
    position:relative;

    max-width:980px;

    margin:auto;

    padding:50px 70px;

    border-radius:30px;

    overflow:hidden;

    text-align:center;

    background:
    linear-gradient(
    135deg,
    #f7f2eb,
    #ffffff
    );

    box-shadow: 0 18px 50px rgba(0,0,0,0.06);

    isolation:isolate;
}

/* BACKGROUND GLOW */

.booking-premium-card::before{
    content:'';

    position:absolute;

    width:420px;
    height:420px;

    border-radius:50%;

    background:
    radial-gradient(
    rgba(200,162,122,0.16),
    transparent 70%
    );

    top:-180px;
    right:-100px;

    z-index:-1;
}

.booking-badge{
    display:inline-flex;

    align-items:center;
    justify-content:center;

    height:36px;

    padding:0 18px;

    border-radius:50px;

    background:rgba(200,162,122,0.12);

    color:var(--primary-dark);

    font-size:11px;

    letter-spacing:2px;

    text-transform:uppercase;

    margin-bottom:28px;
}

.booking-premium-card h2{
    font-family:'Cormorant Garamond',serif;

    font-size:52px;

    line-height:0.98;

    max-width:720px;

    margin:auto;

    margin-bottom:28px;
}

.booking-premium-card p{
    max-width:700px;

    margin:auto;

    margin-bottom:40px;

    color:var(--text-light);

    line-height:1.9;

    font-size:17px;
}

.booking-trust-row{
    display:flex;

    justify-content:center;

    gap:30px;

    flex-wrap:wrap;

    margin-bottom:46px;

    font-size:14px;

    color:#777;
}

.booking-action-group{
    display:flex;

    justify-content:center;

    gap:18px;

    flex-wrap:wrap;
}

.booking-main-btn{
    height:64px;

    min-width:260px;

    padding:0 48px;

    border-radius:50px;

    background:#BE9A72;

    color:#fff;

    display:inline-flex;
    align-items:center;
    justify-content:center;

    text-decoration:none;

    font-size:15px;

    font-weight:500;

    letter-spacing:1px;

    transition:0.4s ease;

    box-shadow:
    0 14px 34px rgba(185,122,86,0.25);
}

.booking-main-btn:hover{
    background:#A9845D;

    transform:
    translateY(-4px)
    scale(1.03);

    box-shadow:
    0 18px 40px rgba(159,101,69,0.35);
}

.booking-wa-btn{
    height:62px;

    padding:0 42px;

    border-radius:50px;

    border:1px solid rgba(0,0,0,0.08);

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

    backdrop-filter:blur(10px);

    color:var(--text);

    display:inline-flex;
    align-items:center;
    justify-content:center;

    text-decoration:none;

    font-size:13px;

    letter-spacing:1px;

    transition:0.35s ease;
}

.booking-wa-btn:hover{
    background:#fff;

    transform:translateY(-4px);
}

.booking-small-note{
    margin-top:24px;

    text-align:center;

    font-size:13px;

    color:#999;
}

@media(max-width:768px){

    .booking-premium-card{
        padding:60px 28px;
    }

    .booking-premium-card h2{
        font-size:46px;

        line-height:1.05;
    }

    .booking-action-group{
        flex-direction:column;
    }

    .booking-main-btn,
    .booking-wa-btn{
        width:100%;
    }

}

.soft-review-note{
    margin-top:28px;

    font-size:14px;

    color:#8d8d8d;

    font-style:italic;

    line-height:1.8;
}
