*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    background:#0d0d0d;
    color:#fff;
    font-family:'Inter',sans-serif;
    overflow-x:hidden;
}

img{
    width:100%;
    display:block;
}

.hero{
    min-height:100vh;
    background:url('hero.jpg') center/cover no-repeat;
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to bottom,rgba(0,0,0,.4),rgba(0,0,0,.75));
}

nav{
    position:relative;
    z-index:5;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:35px 7%;
}

.logo{
    font-weight:700;
    letter-spacing:2px;
}

.nav-links{
    display:flex;
    gap:35px;
}

.nav-links a{
    text-decoration:none;
    color:#fff;
    opacity:.8;
    transition:.3s;
}

.nav-links a:hover{
    opacity:1;
}

.hero-content{
    position:relative;
    z-index:5;
    max-width:760px;
    padding:0 7% 110px;
}

.location,
.section-label{
    color:#cfa46a;
    letter-spacing:2px;
    font-size:.8rem;
    margin-bottom:20px;
    display:inline-block;
}

.hero-content h1,
.about-left h2,
.gallery-text h2,
.availability-header h2,
.contact-box h2{
    font-family:'Cormorant Garamond',serif;
    font-size:5rem;
    line-height:.95;
    margin-bottom:28px;
    font-weight:600;
}

.hero-content p,
.about-left p,
.gallery-text p,
.availability-header p,
.contact-box p{
    color:#c8c8c8;
    line-height:1.9;
    font-size:1.05rem;
}

.hero-buttons{
    display:flex;
    gap:18px;
    margin-top:35px;
    flex-wrap:wrap;
}

.primary-btn,
.secondary-btn{
    padding:16px 28px;
    border-radius:14px;
    text-decoration:none;
    font-weight:600;
    transition:.3s;
}

.primary-btn{
    background:#cfa46a;
    color:#111;
}

.primary-btn:hover{
    transform:translateY(-2px);
}

.secondary-btn{
    border:1px solid rgba(255,255,255,.15);
    color:#fff;
}

.secondary-btn:hover{
    background:rgba(255,255,255,.08);
}

.about,
.gallery,
.availability,
.contact{
    padding:120px 7%;
}

.about{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:70px;
    align-items:center;
}

.about-right{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
}

.feature-card{
    background:#151515;
    border-radius:24px;
    padding:45px 30px;
    border:1px solid rgba(255,255,255,.05);
}

.feature-card h3{
    color:#cfa46a;
    font-size:2rem;
    margin-bottom:10px;
}

.feature-card span{
    color:#aaa;
}

.gallery-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
    align-items:center;
}

.gallery-image img{
    border-radius:28px;
    min-height:450px;
    object-fit:cover;
}

.gallery-image.large img{
    min-height:650px;
}

.gallery-text ul{
    margin-top:30px;
    list-style:none;
}

.gallery-text ul li{
    margin-bottom:15px;
    color:#d0d0d0;
}

.gallery-text ul li::before{
    content:'•';
    color:#cfa46a;
    margin-right:10px;
}

.availability-header{
    text-align:center;
    max-width:700px;
    margin:auto;
    margin-bottom:60px;
}

.calendar-wrapper{
    display:grid;
    grid-template-columns:340px 1fr;
    gap:35px;
    align-items:start;
    max-width:1200px;
    margin:auto;
}

.calendar-sidebar{
    background:#141414;
    border:1px solid rgba(255,255,255,.06);
    border-radius:28px;
    padding:35px;
    position:sticky;
    top:30px;
}

.calendar-sidebar h3{
    font-size:2rem;
    margin:18px 0;
}

.calendar-sidebar p{
    color:#9f9f9f;
    line-height:1.8;
    margin-bottom:30px;
}

.calendar-legend{
    display:flex;
    flex-direction:column;
    gap:16px;
    margin-bottom:35px;
}

.legend-item{
    display:flex;
    align-items:center;
    gap:12px;
    color:#d2d2d2;
}

.legend-dot{
    width:14px;
    height:14px;
    border-radius:50%;
}

.legend-dot.available{
    background:#3fa85c;
}

.legend-dot.booked{
    background:#8f3d3d;
}

.legend-dot.selected{
    background:#cfa46a;
}

.booking-card{
    background:#0f0f0f;
    border-radius:20px;
    padding:24px;
    border:1px solid rgba(255,255,255,.06);
}

#selectedDate{
    font-size:1rem;
    margin-bottom:20px;
    color:#fff;
}

.booking-btn{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:center;
    text-decoration:none;
    background:#cfa46a;
    color:#111;
    padding:16px;
    border-radius:14px;
    font-weight:700;
    transition:.25s;
}

.booking-btn:hover{
    transform:translateY(-2px);
}

.booking-btn.disabled{
    opacity:.4;
    pointer-events:none;
}

.calendar-container{
    background:#141414;
    border-radius:28px;
    padding:35px;
    border:1px solid rgba(255,255,255,.06);
}

.calendar-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:28px;
}

.calendar-top h3{
    font-size:1.3rem;
    font-weight:600;
}

.calendar-top button{
    width:48px;
    height:48px;
    border:none;
    border-radius:14px;
    background:#1f1f1f;
    color:#fff;
    cursor:pointer;
    transition:.2s;
    font-size:1rem;
}

.calendar-top button:hover{
    background:#2b2b2b;
    transform:translateY(-2px);
}

.calendar-days{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:10px;
    margin-bottom:10px;
}

.calendar-days div{
    text-align:center;
    color:#777;
    font-size:.85rem;
    font-weight:600;
}

#calendar{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:10px;
}

.day{
    aspect-ratio:1/1;
    border-radius:20px;
    padding:12px;
    position:relative;
    transition:.2s;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.day-number{
    font-weight:700;
    font-size:1rem;
}

.day-status{
    font-size:.7rem;
    letter-spacing:.5px;
    text-transform:uppercase;
}

.day.available{
    background:#18241c;
    border:1px solid rgba(80,180,110,.15);
    cursor:pointer;
}

.day.available:hover{
    transform:translateY(-4px);
    border-color:rgba(80,180,110,.45);
    background:#1d2d22;
    box-shadow:0 10px 30px rgba(0,0,0,.35);
}

.day.available:active{
    transform:scale(.97);
}

.day.booked{
    background:#241818;
    border:1px solid rgba(180,80,80,.12);
    opacity:.45;
    cursor:not-allowed;
}

.day.booked .day-status{
    color:#d46b6b;
}

.day.available .day-status{
    color:#7de29a;
}

.day.selected{
    background:#cfa46a;
    border-color:#cfa46a;
    color:#111;
    transform:scale(.97);
}

.day.selected .day-status{
    color:#111;
}

@media(max-width:1000px){

    .calendar-wrapper{
        grid-template-columns:1fr;
    }

    .calendar-sidebar{
        position:relative;
        top:0;
    }

}

@media(max-width:700px){

    .calendar-container,
    .calendar-sidebar{
        padding:18px;
        border-radius:22px;
    }

    .calendar-days,
    #calendar{
        gap:5px;
    }

    .day{
        border-radius:14px;
        padding:8px;
    }

    .day-number{
        font-size:.85rem;
    }

    .day-status{
        display:none;
    }

    .calendar-top button{
        width:42px;
        height:42px;
    }

    .calendar-top h3{
        font-size:1rem;
    }

}

#contactLink{
    opacity:.6;
    pointer-events:none;
    transition:.25s;
}

#contactLink.active-booking{
    opacity:1;
    pointer-events:auto;
}

.contact-box{
    background:#151515;
    border-radius:30px;
    padding:80px;
    text-align:center;
}

.visitor-counter{
    text-align:center;
    color:#888;
    margin-bottom:20px;
    font-size:.95rem;
}

footer{
    padding:40px;
    text-align:center;
    color:#666;
}

@media(max-width:1000px){

    .about,
    .gallery-grid{
        grid-template-columns:1fr;
    }

    .hero-content h1,
    .about-left h2,
    .gallery-text h2,
    .availability-header h2,
    .contact-box h2{
        font-size:3.4rem;
    }
}

@media(max-width:700px){

    nav{
        flex-direction:column;
        gap:20px;
    }

    .nav-links{
        gap:18px;
        flex-wrap:wrap;
        justify-content:center;
    }

    .about-right{
        grid-template-columns:1fr;
    }

    .calendar-container{
        padding:14px;
        border-radius:22px;
    }

    .calendar-days,
    #calendar{
        gap:6px;
    }

    .calendar-days div{
        font-size:.7rem;
    }

    .day{
        min-height:62px;
        padding:8px;
        border-radius:14px;
    }

    .day-number{
        font-size:.9rem;
    }

    .day-status{
        display:none;
    }

    .calendar-top{
        margin-bottom:18px;
    }

    .calendar-top h3{
        font-size:1rem;
    }

    .contact-box{
        padding:50px 30px;
    }

    .hero-content h1,
    .about-left h2,
    .gallery-text h2,
    .availability-header h2,
    .contact-box h2{
        font-size:2.7rem;
    }
}