@charset "utf-8";
/* CSS Document */

.nav-links a.active{
    color:#c89b60;
}

/* =========================================
   LOCATION HERO
========================================= */

.location-hero{

    position:relative;

    height:86vh;

    min-height:720px;

    overflow:hidden;
}

.location-hero img{

    position:absolute;

    inset:0;

    width:100%;
    height:100%;

    object-fit:cover;

    object-position:center center;
}

.location-hero-overlay{

    position:absolute;

    inset:0;

    background:
    linear-gradient(
        rgba(0,0,0,.25),
        rgba(0,0,0,.65)
    );
}

.location-hero-content{

    position:absolute;

    left:50%;
    top:55%;

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

    width:90%;

    max-width:1000px;

    text-align:center;

    color:#fff;

    z-index:2;
}

.location-hero-content h1{

    font-family:'Cormorant Garamond', serif;

    font-size:3.2rem;

    line-height:1.05;

    margin:20px 0;
}

.location-hero-content p{

    max-width:760px;

    margin:auto;

    line-height:1.9;

    color:rgba(255,255,255,.9);
}

.location-meta{

    display:flex;

    justify-content:center;

    gap:15px;

    flex-wrap:wrap;

    margin-top:35px;
}

.location-meta span{

    padding:10px 20px;

    border-radius:999px;

    background:rgba(255,255,255,.12);

    backdrop-filter:blur(10px);

    border:1px solid rgba(255,255,255,.15);

    color:#fff;

    font-size:.85rem;
}


/* =========================================
   LOCATION MAP
========================================= */

.location-overview{

    padding:100px 7% 60px;
}

.location-grid{

    display:grid;

    grid-template-columns:1.2fr 1fr;

    gap:70px;

    align-items:center;
}

.location-map iframe{

    width:100%;

    height:580px;

    border:none;

    border-radius:28px;
}
.location-section-label{
    display: inline-block;
  margin-bottom: 2px;
  font-size: 0.78rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #8d7354;
}

.location-info h2{

    font-family:'Cormorant Garamond', serif;
    line-height:1.1;
    font-size:2.6rem;
    margin-top:0;
    margin:20px 0;
}

.location-info ul{

    list-style:none;

    padding:0;

    margin:25px 0;
}

.location-info li{

    margin-bottom:6px;

    padding-left:28px;

    position:relative;
}

.location-info li::before{

    content:"✓";

    position:absolute;

    left:0;

    color:#c89b60;
}

.location-btn{

    display:inline-block;

    padding:12px 30px;

    background:#d4b27a;

    color:#1f1f1f;

    border-radius:999px;

    text-decoration:none;
}

@media(max-width:991px){

.location-grid{

grid-template-columns:1fr;

gap:40px;

}
	
.location-map iframe{

height:380px;

}
	
.location-meta{

    gap:10px;

}

.location-meta span{

    padding:8px 14px;
    font-size:.75rem;

}
	
.location-hero-content{

    width:88%;
    top:54%;

}

}

/* =========================================
   LOCATION PAGE MOBILE FIX
========================================= */

@media (max-width:768px){

    .location-overview{
        padding:60px 5% 50px;
        overflow:hidden;
    }

    .location-grid{
        display:flex;
        flex-direction:column;
        gap:30px;
    }

    .location-map,
    .location-info{
        width:100%;
        max-width:100%;
    }

    .location-map iframe{
        width:100%;
        height:300px;
        display:block;
    }

    .location-info h2{
        font-size:2rem;
        line-height:1.15;
        margin-bottom:20px;

        word-break:break-word;
        overflow-wrap:break-word;
    }

    .location-info p{
        font-size:0.95rem;
        line-height:1.8;
    }

    .location-info ul{
        margin:20px 0;
    }

    .location-btn{
        width:100%;
        text-align:center;
        display:block;
    }

}

/* =========================================
   LOCATION TRUST
========================================= */

.location-trust-section{

    padding:0 7% 60px;
}


.trust-container{

    max-width:1200px;

    margin:auto;

    display:grid;

    grid-template-columns:
    1fr auto
    1fr auto
    1fr auto
    1fr;

    align-items:center;

    background:#faf8f3;

    border:1px solid rgba(0,0,0,.06);

    border-radius:28px;

    padding:30px 40px;
}


.trust-item{

    text-align:center;
}


.trust-value{

    display:block;

    margin-bottom:8px;

    font-size:1.3rem;

    font-weight:600;

    color:#1f1f1f;
}


.trust-label{

    display:block;

    font-size:.9rem;

    color:#777;
}


.trust-divider{

    width:1px;

    height:50px;

    background:rgba(0,0,0,.08);
}

/* =========================================
   LOCATION TRUST MOBILE
========================================= */

@media (max-width:768px){

    .location-trust-section{
        padding:0 5% 60px;
    }

    .trust-container{

        display:grid;

        grid-template-columns:1fr 1fr;

        gap:25px;

        padding:30px 20px;

        border-radius:24px;
    }

    .trust-divider{
        display:none;
    }

    .trust-item{
        text-align:center;
    }

    .trust-value{

        font-size:1.1rem;

        margin-bottom:6px;

        line-height:1.3;
    }

    .trust-label{

        font-size:0.8rem;

        line-height:1.4;
    }

}

/* =========================================
   AIRPORT TRANSFER
========================================= */

.airport-transfer{

    padding:0 7% 100px;
}

.airport-transfer-grid{

    max-width:1200px;

    margin:auto;

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:50px;

    align-items:center;
}

.airport-transfer-image{

    overflow:hidden;

    border-radius:28px;
}

.airport-transfer-image img{

    width:100%;
    height:500px;

    object-fit:cover;

    display:block;
}

.airport-transfer-content h2{

    font-family:'Cormorant Garamond', serif;

    font-size:2.6rem;

    line-height:1.1;

    margin:18px 0;
}

.airport-transfer-content p{

    color:#666;

    line-height:1.8;

    margin-bottom:25px;
}

.airport-transfer ul{
    list-style:none;
    padding:0;
}

.airport-transfer ul li{
    position:relative;
    padding-left:28px;
    margin-bottom:14px;
	color: #666;
}

.airport-transfer ul li::before{
    content:"-";
    position:absolute;
    left:0;
    top:0;
    color:#c9a063;
    font-weight:600;
}

.airport-transfer-btn{

    display:inline-block;

    padding:12px 34px;

    border-radius:999px;

    background:#d4b27a;

    color:#111;

    text-decoration:none;

    font-weight:500;
}

@media(max-width:991px){

.airport-transfer-grid{

    grid-template-columns:1fr;

    gap:35px;

}

.airport-transfer-image{

    order:1;

}

.airport-transfer-content{

    order:2;

}

.airport-transfer-content h2{

    font-size:2rem;
    line-height:1.15;

}

.airport-transfer-content{

    text-align:center;

}

.airport-transfer-content ul{

    text-align:left;

    max-width:450px;

    margin:25px auto;

}

}

@media(max-width:768px){

.airport-transfer{

    padding:80px 7%;

}

.airport-transfer-image img{

    height:280px;

}

.airport-transfer-content h2{

    font-size:1.9rem;

}
	
.location-info h2{

    font-size:2.2rem;
    line-height:1.15;

}
	
    .airport-transfer-grid{
        display:flex;
        flex-direction:column;
    }

    .airport-transfer-image,
    .airport-transfer-content{
        width:100%;
    }

}

/* =========================================
   MINI LOCATION CTA
========================================= */

.location-mini-cta{

    padding:0 7% 100px;
}


.mini-cta-content{

    max-width:1100px;

    margin:auto;

    text-align:center;

    padding:60px;

    border-radius:32px;

    background:#faf8f3;

    border:1px solid rgba(0,0,0,.06);
}


.mini-cta-content span{

    display:block;

    margin-bottom:15px;

    font-size:.78rem;

    letter-spacing:3px;

    color:#8d7354;

    text-transform:uppercase;
}


.mini-cta-content h2{

    font-family:'Cormorant Garamond', serif;

    font-size:2.6rem;

    line-height:1.1;

    margin-bottom:18px;

    color:#1f1f1f;
}


.mini-cta-content p{

    max-width:700px;

    margin:0 auto;

    color:#666;

    line-height:1.8;
}

.mini-social-proof{
    font-size: 0.8rem !important;
    line-height:1.8;
	margin-top: 20px !important;
}

.mini-cta-buttons{

    display:flex;

    justify-content:center;

    gap:16px;

    margin-top:20px;

    flex-wrap:wrap;
}


.mini-btn-primary{

    display:inline-block;

    padding:16px 34px;

    border-radius:999px;

    background:#d4b27a;

    color:#111;

    text-decoration:none;

    font-weight:500;

    transition:.3s ease;
}


.mini-btn-primary:hover{

    transform:translateY(-2px);
}


.mini-btn-secondary{

    display:inline-block;

    padding:16px 34px;

    border-radius:999px;

    border:1px solid #d4b27a;

    color:#8a6a3d;

    text-decoration:none;

    font-weight:500;

    transition:.3s ease;
}


.mini-btn-secondary:hover{

    background:#f4ede3;
}

@media(max-width:768px){

.mini-cta-content{

    padding:40px 25px;
}
	
.location-mini-cta{
    padding:0 5% 60px;
}

.location-mini-cta h2{

    font-size:2rem;
    line-height:1.15;
    max-width:300px;
    margin:0 auto 20px;

}
	
.location-mini-cta .mini-btn-secondary{
    display:none;
}

}

/* =========================================
   WHY OUR LOCATION MATTERS
========================================= */

.location-benefits{

    padding:120px 0;

    background:#faf8f3;
}


.benefits-grid{

    width:min(1400px,92%);

    margin:70px auto 0;

    display:grid;

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

    gap:30px;
}


.benefit-card{

    position:relative;

    overflow:hidden;

    border-radius:30px;

    min-height:420px;

    cursor:pointer;
}


.benefit-card img{

    position:absolute;

    inset:0;

    width:100%;
    height:100%;

    object-fit:cover;

    transition:.8s ease;
}


.benefit-card::before{

    content:"";

    position:absolute;

    inset:0;

    background:
    linear-gradient(
        to top,
        rgba(0,0,0,.75),
        rgba(0,0,0,.15)
    );

    z-index:1;
}


.benefit-content{

    position:absolute;

    left:35px;

    right:35px;

    bottom:35px;

    z-index:2;

    color:#fff;
}


.benefit-content span{

    display:block;

    margin-bottom:12px;

    font-size:.75rem;

    letter-spacing:3px;

    opacity:.9;
}


.benefit-content h3{

    font-family:'Cormorant Garamond', serif;

    font-size:2rem;

    line-height:1.15;

    margin-bottom:14px;
}


.benefit-content p{

    line-height:1.8;

    opacity:.9;
}


.benefit-card:hover img{

    transform:scale(1.06);
}


.benefit-card:hover{

    transform:translateY(-6px);

    transition:.35s ease;
}


/* MOBILE */

@media(max-width:991px){

    .benefits-grid{

        grid-template-columns:1fr;
    }

}

/* =========================================
   NEARBY ATTRACTIONS
========================================= */

.nearby-attractions{

    padding:120px 0;

    background:#fff;
}


.attractions-grid{

    width:min(1400px,92%);

    margin:70px auto 0;

    display:grid;

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

    gap:30px;
}


.attraction-card{

    background:#fff;

    border-radius:28px;

    overflow:hidden;

    box-shadow:0 20px 40px rgba(0,0,0,.05);

    transition:.35s ease;
}


.attraction-card:hover{

    transform:translateY(-8px);

    box-shadow:0 30px 60px rgba(0,0,0,.08);
}


.attraction-card img{

    width:100%;

    height:260px;

    object-fit:cover;

    transition:.7s ease;
}


.attraction-card:hover img{

    transform:scale(1.05);
}


.attraction-content{

    padding:28px;
}


.distance{

    display:inline-block;

    margin-bottom:15px;

    padding:6px 12px;

    border-radius:999px;

    background:#f4ede3;

    color:#8a6a3d;

    font-size:.8rem;

    font-weight:500;
}


.attraction-content h3{

    font-family:'Cormorant Garamond', serif;

    font-size:1.8rem;

    margin-bottom:12px;
}


.attraction-content p{

    color:#666;

    line-height:1.8;
}

.attraction-card{
    display:block;
    text-decoration:none;
    color:inherit;
}

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

.attraction-card img{
    transition:.4s ease;
}


/* MOBILE */

@media(max-width:1200px){

    .attractions-grid{

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

}


@media(max-width:768px){

    .attractions-grid{

        grid-template-columns:1fr;
    }

}

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

.room-faq-section{
    padding:120px 8%;

    background:#f8f4ef;
}

.faq-wrapper{
    max-width:900px;

    margin:70px auto 0;
}

.faq-item{
    border-bottom:1px solid rgba(0,0,0,0.08);
}

.faq-question{
    width:100%;

    background:none;

    border:none;

    padding:30px 0;

    display:flex;

    justify-content:space-between;

    align-items:center;

    text-align:left;

    cursor:pointer;

    font-size:1.15rem;

    font-weight:500;

    color:#2d241c;

    font-family:'Inter', sans-serif;
}

.faq-question span{
    font-size:1.4rem;

    color:#a6845e;

    transition:0.3s ease;
}

.faq-answer{
    max-height:0;

    overflow:hidden;

    transition:max-height 0.4s ease;
}

.faq-answer p{
    padding:0 0 28px;

    font-size:1rem;

    line-height:1.9;

    color:#5f5a54;

    max-width:760px;
}


/* ACTIVE FAQ */

.faq-item.active .faq-answer{
    max-height:300px;
}

.faq-item.active .faq-question span{
    transform:rotate(45deg);
}


/* =========================================
   EXPLORE YOUR STAY
========================================= */

.explore-stay{

    padding:140px 0;

    background:#fff;
}


.explore-stay .section-heading{

    max-width:760px;

    margin:0 auto 70px;

    text-align:center;
}


.explore-stay .section-heading p{

    margin-top:20px;

    color:#666;

    line-height:1.9;
}


/* GRID */

.stay-grid{

    width:min(1400px,92%);

    margin:auto;

    display:grid;

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

    gap:28px;

}


/* CARD */

.stay-card{

    background:#fff;

    border-radius:28px;

    overflow:hidden;

    box-shadow:0 20px 40px rgba(0,0,0,.05);

    transition:.4s ease;
}


.stay-card:hover{

    transform:translateY(-8px);

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


.stay-card img{

    width:100%;

    height:260px;

    object-fit:cover;

    transition:.7s ease;
}


.stay-card:hover img{

    transform:scale(1.05);
}


.stay-content{

    padding:30px;
}


.stay-content h3{

    font-family:'Cormorant Garamond', serif;

    font-size:1.8rem;

    margin-bottom:15px;

    color:#1f1f1f;
}


.stay-content p{

    color:#666;

    line-height:1.8;

    margin-bottom:22px;
}


.stay-content a{

    color:#b99152;

    text-decoration:none;

    font-weight:500;

    transition:.3s ease;
}


.stay-content a:hover{

    color:#8f6d3a;
}

.room-tag{

    display:inline-block;

    margin-bottom:16px;

    padding:6px 12px;

    border-radius:999px;

    background:#f4ede3;

    color:#8a6a3d;

    font-size:.78rem;

    font-weight:500;
}


/* RESPONSIVE */

@media(max-width:1200px){

    .stay-grid{

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

}


@media(max-width:768px){

    .stay-grid{

        grid-template-columns:1fr;
    }

    .stay-card img{

        height:220px;
    }

}

/* =========================================
   CTA
========================================= */

.final-cta{

    position:relative;

    width:min(1400px,92%);

    margin:90px auto;

    border-radius:40px;

    overflow:hidden;

    min-height:280px;
}


.final-cta img{

    position:absolute;

    inset:0;

    width:100%;
    height:100%;

    object-fit:cover;

}

.cta-overlay{

    position:absolute;

    inset:0;

    background:
    linear-gradient(
    rgba(0,0,0,.35),
    rgba(0,0,0,.55)
    );

}

.cta-content{

    position:relative;

    z-index:2;

    max-width:760px;

    margin:auto;

    min-height:350px;

    display:flex;

    flex-direction:column;

    justify-content:center;

    align-items:center;

    text-align:center;

    color:#fff;

    padding:40px;

}

.cta-content span{

    letter-spacing:4px;

    font-size:.8rem;

    opacity:.9;

}

.cta-content h2{

    margin:20px 0;

    font-size:2.6rem;

    line-height:1.1;

}

.cta-content p{

    max-width:700px;

    line-height:1.8;

    opacity:.95;

}

.cta-buttons{

    margin-top:35px;

    display:flex;

    gap:18px;

    flex-wrap:wrap;

}

.btn-primary{

    background:#d4b27a;

    color:#111;

    padding:16px 34px;

    border-radius:999px;

    text-decoration:none;

}

.btn-secondary{

    border:1px solid rgba(255,255,255,.5);

    color:#fff;

    padding:16px 34px;

    border-radius:999px;

    text-decoration:none;

}

.cta-note{

    margin-top:25px;

    max-width:700px;

    font-size:.95rem;

    line-height:1.8;

    color:rgba(255,255,255,.85);

}

@media(max-width:768px){

.cta-content h2{

font-size:2.2rem;

}

}

/* =========================================
   ROOM TAG
========================================= */

.room-tag{

    display:inline-block;

    margin-bottom:16px;

    padding:6px 12px;

    border-radius:999px;

    background:#f4ede3;

    color:#8a6a3d;

    font-size:.78rem;

    font-weight:500;
}

@media(max-width:768px){

.location-hero{

    height:auto;
    min-height:720px;

}

.location-hero-content{

    width:88%;
    top:54%;

}

.location-hero-content h1{

    font-size:2.1rem;
    line-height:1.15;
    margin:18px 0;

}

.location-hero-content p{

    font-size:.95rem;
    line-height:1.7;

}

.location-meta{

    gap:10px;
    margin-top:25px;

}

.location-meta span{

    padding:8px 14px;
    font-size:.75rem;

}

}

/* =========================================
   WHY OUR LOCATION MATTERS - MOBILE FIX
========================================= */

@media(max-width:768px){

    .location-benefits{

        padding:70px 5%;

        overflow:hidden;

    }

    .benefits-grid{

        width:100%;

        margin-top:40px;

        grid-template-columns:1fr;

        gap:20px;

    }

    .benefit-card{

        min-height:320px;

        border-radius:24px;

    }

    .benefit-content{

        left:20px;
        right:20px;
        bottom:20px;

    }

    .benefit-content span{

        font-size:.7rem;

        letter-spacing:2px;

    }

    .benefit-content h3{

        font-size:1.6rem;

        line-height:1.15;

        margin-bottom:10px;

    }

    .benefit-content p{

        font-size:.9rem;

        line-height:1.6;

    }

}

/* =========================================
   GLOBAL MOBILE OPTIMIZATION
========================================= */

@media (max-width:768px){

    html,
    body{
        overflow-x:hidden;
    }

    section{
        overflow:hidden;
    }

    /* Heading */

    h1{
        font-size:2.1rem !important;
        line-height:1.15 !important;
    }

    h2{
        font-size:2rem !important;
        line-height:1.15 !important;
    }

    h3{
        font-size:1.5rem !important;
        line-height:1.2 !important;
    }

    /* Section spacing */

    .location-overview,
    .location-trust-section,
    .airport-transfer,
    .location-mini-cta,
    .location-benefits,
    .nearby-attractions,
    .faq-section,
    .explore-stay{

        padding-left:5%;
        padding-right:5%;
    }

    /* Global content width */

    .section-heading,
    .location-info,
    .airport-transfer-content,
    .mini-cta-content,
    .cta-content{

        max-width:100%;
    }

    /* Cards */

    .benefit-card,
    .attraction-card,
    .stay-card{

        width:100%;
        max-width:100%;
    }

    /* Buttons */

    .btn-primary,
    .mini-btn-primary,
    .airport-transfer-btn,
    .location-btn{

        width:100%;
        display:block;
        text-align:center;
    }

}

@media(max-width:768px){

    .explore-stay{
        padding:70px 5%;
    }

    .stay-grid{
        width:100%;
        gap:20px;
    }

    .stay-content{
        padding:20px;
    }

    .stay-content h3{
        font-size:1.5rem;
    }

}

@media(max-width:768px){

    .final-cta{

        width:90%;

        margin:60px auto;

        border-radius:24px;

        min-height:auto;
    }

    .cta-content{

        min-height:auto;

        padding:50px 25px;
    }

    .cta-content h2{

        font-size:2rem;

        line-height:1.15;
    }

    .cta-buttons{

        flex-direction:column;

        width:100%;
    }

    .btn-primary,
    .btn-secondary{

        width:100%;

        text-align:center;
    }
	
	.final-cta .btn-secondary{
    display:none;
}

}
@media(max-width:768px){

    .nearby-attractions{
        padding:70px 5%;
    }

    .attractions-grid{
        width:100%;
        margin-top:40px;
        gap:20px;
    }

    .attraction-card img{
        height:220px;
    }

    .attraction-content{
        padding:20px;
    }

    .attraction-content h3{
        font-size:1.5rem;
    }

}