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

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

/* =========================================
   CONTACT HERO
========================================= */

.contact-hero{

    position:relative;

    height:86vh;

    min-height:720px;

    overflow:hidden;
}

.contact-hero img{

    position:absolute;

    inset:0;

    width:100%;
    height:100%;

    object-fit:cover;

    object-position:center center;
}

.contact-hero-overlay{

    position:absolute;

    inset:0;

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

.contact-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;
}

.contact-hero-content h1{

    font-family:'Cormorant Garamond', serif;

    font-size:3.2rem;

    line-height:1.05;

    margin:20px 0;
}

.contact-hero-content p{

    max-width:760px;

    margin:auto;

    line-height:1.9;

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

.contact-hero-content p a{

    color:#d8b27c;

    font-weight:500;

    text-decoration:none;

    transition:.3s ease;

}

.contact-hero-content p a:hover{

    color:#ffffff;

}

.contact-hero-content p a:visited{

    color:#e0c08a;

}

.contact-hero-content p a:active{

    color:#ffffff;

}

.contact-meta{

    display:flex;

    justify-content:center;

    gap:15px;

    flex-wrap:wrap;

    margin-top:35px;
}

.contact-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;
}

@media(max-width:768px){

.contact-hero{

height:75vh;

min-height:550px;

}
	
.contact-hero-content h1{

font-size:2.8rem;

}

}

/* =========================================
   CONTACT INFO
========================================= */

.contact-info-section{
    padding:100px 0;
    background:#ffffff;
}

.contact-container{
    max-width:1400px;
    margin:auto;
    padding:0 24px;

    display:grid;
    grid-template-columns:500px 1fr;
    gap:60px;

    align-items:center;
}

.contact-details h2{
    margin:1px 0 18px;
	font-family:'Cormorant Garamond', serif;
    font-size: 2.6rem;
    line-height:1.1;
    color:#2f2a25;
}

.contact-details p{
    margin-bottom:40px;

    color:#666;
    line-height:1.8;
}

.contact-item{
    margin-bottom:28px;
}

.contact-item h3{
    margin-bottom:8px;

    font-size:1rem;
    color:#999;
    text-transform:uppercase;
    letter-spacing:1px;
}

.contact-item a{
    font-size:1.3rem;
    font-weight:500;

    color:#2f2a25;
    text-decoration:none;
}

.contact-hours{
    margin:30px 0;

    color:#666;
    line-height:1.8;
}

.contact-btn{
    display:inline-flex;
    align-items:center;

    padding:16px 34px;

    border-radius:999px;

    background:#d8b27c;
    color:#fff;

    text-decoration:none;
    transition:.3s;
}

.contact-btn:hover{
    transform:translateY(-2px);
}

.contact-map iframe{
    width:100%;
    height:600px;

    border:none;
    border-radius:28px;
}

/* MOBILE */

@media(max-width:991px){

    .contact-container{
        grid-template-columns:1fr;
        gap:40px;
    }

    .contact-map iframe{
        height:450px;
    }

}

/* =========================================
   CONTACT FORM
========================================= */

.contact-form-section{

    padding:100px 0;

    background:#faf8f3;
}

.contact-form-wrapper{

    max-width:1000px;

    margin:auto;

    padding:0 24px;
}

.form-heading{

    text-align:center;

    margin-bottom:50px;
}

.form-heading h2{

    margin:18px 0;
    font-family:'Cormorant Garamond', serif;
    font-size: 2.6rem;

    line-height:1.1;

    color:#2f2a25;
}

.form-heading p{

    max-width:700px;

    margin:auto;

    color:#666;

    line-height:1.8;
}

.form-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:24px;
}

.form-group{

    margin-bottom:24px;
}

.form-group label{

    display:block;

    margin-bottom:10px;

    font-size:.9rem;

    color:#666;
}

.contact-form input,
.contact-form textarea{

    width:100%;

    padding:16px 18px;

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

    border-radius:14px;

    background:#fff;

    font-family:inherit;

    font-size:1rem;
}

.contact-form textarea{

    resize:vertical;
}

.contact-form input:focus,
.contact-form textarea:focus{

    outline:none;

    border-color:#d8b27c;
}

.form-submit-btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    padding:18px 38px;

    border:none;

    border-radius:999px;

    background:#d8b27c;

    color:#fff;

    cursor:pointer;

    font-size:1rem;

    transition:.3s;
}

.form-submit-btn:hover{

    transform:translateY(-2px);
}

/* MOBILE */

@media(max-width:768px){

    .form-grid{

        grid-template-columns:1fr;
    }

    .form-submit-btn{

        width:100%;
    }

}

/* =========================================
   WHY CONTACT US
========================================= */

.contact-benefits{

    padding:100px 7%;

    background:#fff;
}


.contact-benefits-grid{

    max-width:1200px;

    margin:60px auto 0;

    display:grid;

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

    gap:30px;
}


/* CARD */

.contact-benefit-card{

    padding:35px;

    background:#faf8f3;

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

    border-radius:24px;

    transition:.35s ease;
}


.contact-benefit-card:hover{

    transform:translateY(-4px);

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


/* ICON */

.contact-benefit-icon{

    width:60px;
    height:60px;

    margin-bottom:24px;

    border-radius:50%;

    display:flex;

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

    background:#f2e8d8;

    color:#b38a52;

    font-size:1.4rem;
}


/* TITLE */

.contact-benefit-card h3{

    margin-bottom:12px;

    font-size:1.25rem;

    line-height:1.3;

    color:#2f2a25;
}


/* TEXT */

.contact-benefit-card p{

    color:#666;

    line-height:1.8;

    font-size:.95rem;
}

@media(max-width:991px){

.contact-benefits-grid{

grid-template-columns:1fr 1fr;

}

}

@media(max-width:768px){

.contact-benefits-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);
}

/* =========================================
   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;

}

}

@media(max-width:768px){

.final-cta{

    min-height:700px;
    margin:70px auto 120px;

}

.cta-content{

    min-height:700px;
    padding:50px 24px 120px;

}

.cta-buttons{

    flex-direction:column;
    width:100%;

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

.btn-primary,
.btn-secondary{

    width:100%;

}

.cta-note{

    margin-top:25px;

}

}