:root{
    --bg:#ffffff;
    --tint:#F1EDEA;
    --primary:#05B084;
    --secondary:#015A84;
    --mint:#BADFCD;

    --text:#0e1a22;
    --muted:#51616d;

    --radius:18px;
    --shadow:0 14px 40px rgba(1,90,132,.10);
    --border:1px solid rgba(1,90,132,.14);

    --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
    color:var(--text);
    background:var(--bg);
    line-height:1.55;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.container{
    width:min(var(--container), calc(100% - 40px));
    margin:0 auto;
}

/* Buttons */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.5rem;
    padding:12px 16px;
    border-radius:999px;
    background:var(--primary);
    color:#fff;
    font-weight:700;
    border:1px solid transparent;
    transition:transform .15s ease, filter .15s ease, background .15s ease;
    will-change:transform;
}
.btn:hover{transform:translateY(-1px); filter:brightness(.98)}
.btn:active{transform:translateY(0)}
.btn--ghost{
    background:transparent;
    color:var(--secondary);
    color: #ffffffee;
    border:1px solid #ffffffee;
}
.btn--wide{padding:14px 18px; min-width:220px}
.btn--sm{padding:10px 14px; font-size:.95rem}

.anchor{position:relative; top:-92px; display:block}

/* HERO */
.hero{
    position:relative;
    min-height:72vh;
    display:flex;
    align-items:stretch;
    overflow:hidden;
}
.hero__slides{
    position:absolute; inset:0;
}
.hero__slide{
    position:absolute; inset:0;
    background-size:cover;
    background-position:center;
    opacity:0;
    transform:scale(1.03);
    transition:opacity 1.2s ease, transform 3.5s ease;
}
.hero__slide.is-active{
    opacity:1;
    transform:scale(1.00);
}
.hero__overlay{
    position:absolute; inset:0;
    background:
            linear-gradient(90deg, rgba(1,90,132,.72), rgba(1,90,132,.18)),
            linear-gradient(180deg, rgba(0,0,0,.26), rgba(0,0,0,.05));
    pointer-events:none;
}
.hero__content{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    gap:24px;
    padding:22px 0 36px;
    width:100%;
    padding-left: 20px;
    padding-right: 20px;
}
.hero__topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
}
.brand{
    display:flex;
    align-items:center;
    gap:12px;
    color:#fff;
}
.brand__mark{
    width:42px; height:42px; border-radius:14px;
    background:linear-gradient(135deg, rgba(5,176,132,1), rgba(186,223,205,1));
    box-shadow:0 10px 30px rgba(0,0,0,.20);
}
.brand__name{display:block; font-weight:900; letter-spacing:.2px}
.brand__city{display:block; opacity:.9; font-size:.95rem}

.hero__cta{display:flex; gap:10px}
.hero__headline{
    margin-top:auto;
    max-width:760px;
    color:#fff;
    padding:26px 0 18px;
}
.hero__headline h1{
    margin:0 0 10px;
    font-size:clamp(28px, 3.6vw, 46px);
    line-height:1.08;
    letter-spacing:-.4px;
}
.hero__headline p{
    margin:0 0 18px;
    font-size:clamp(15px, 1.4vw, 18px);
    opacity:.95;
    max-width:58ch;
}
.hero__actions{display:flex; gap:12px; flex-wrap:wrap}

.burger{
    display:none;
    width:44px; height:44px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.25);
    background:rgba(255,255,255,.10);
    backdrop-filter: blur(10px);
    cursor:pointer;
}
.burger span{
    display:block;
    width:20px;
    height:2px;
    margin:5px auto;
    background:#fff;
    border-radius:2px;
}

/* NAV */
.nav{
    position:sticky;
    top:0;
    z-index:10;
    background:rgba(255,255,255,.82);
    backdrop-filter: blur(10px);
    border-bottom:1px solid rgba(1,90,132,.10);
}
.nav__inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    padding:12px 0;
}
.nav__brand{
    font-weight:900;
    color:var(--secondary);
    letter-spacing:.2px;
}
.nav__links{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    justify-content:center;
}
.nav__links a{
    padding:8px 10px;
    border-radius:999px;
    color:var(--secondary);
    font-weight:700;
    font-size:.98rem;
    transition:background .15s ease;
}
.nav__links a:hover{background:rgba(186,223,205,.45)}
.nav__right{display:flex; align-items:center}

/* SECTIONS */
.section{padding:70px 0}
.section--tint{background:var(--tint)}
.section--compact{padding:28px 0 0}
.section-head{margin-bottom:18px}
.section-head h2{
    margin:0 0 6px;
    font-size:clamp(22px, 2.2vw, 30px);
    letter-spacing:-.2px;
    color:var(--secondary);
}
.section-head p{margin:0; color:var(--muted)}
.section-head--row{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:14px;
}

/* BOOKING */
.booking{padding:44px 0 10px}
#booking-form{
    margin-top:12px;
    padding:16px;
    border-radius:var(--radius);
    border:var(--border);
    background:#fff;
    box-shadow:var(--shadow);
}

/* CARDS / GRID */
.card{
    background:#fff;
    border-radius:var(--radius);
    border:var(--border);
    box-shadow:var(--shadow);
}
.grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:16px;
}
.grid--3{grid-template-columns:repeat(3, 1fr)}

/* ABOUT */
.about{
    display:grid;
    grid-template-columns:1.3fr .9fr;
    gap:18px;
    align-items:start;
}
.about__text{
    padding:18px 0;
    color:var(--text);
    font-size:1.02rem;
}
.about__media img{
    border-radius:var(--radius);
    border:var(--border);
    box-shadow:var(--shadow);
}
.about__badges{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:12px;
}
.badge{
    display:inline-flex;
    padding:8px 10px;
    border-radius:999px;
    background:rgba(186,223,205,.50);
    color:var(--secondary);
    font-weight:800;
    font-size:.92rem;
    border:1px solid rgba(1,90,132,.10);
}

/* FEATURES */
.feature{padding:16px}
.feature__icon{
    width:44px; height:44px;
    display:flex; align-items:center; justify-content:center;
    border-radius:14px;
    background:rgba(5,176,132,.12);
    color:var(--secondary);
    margin-bottom:10px;
    font-size:20px;
}
.feature h3{margin:0 0 6px; color:var(--secondary)}
.feature p{margin:0; color:var(--muted)}

/* ROOMS */
.room-list{display:flex; flex-direction:column; gap:16px}
.room{
    display:grid;
    grid-template-columns: 1fr 1fr;
    overflow:hidden;
}
.room__media img{
    width:100%;
    height:100%;
    object-fit:cover;
    min-height:260px;
}
.room__body{
    padding:18px;
    display:flex;
    flex-direction:column;
    gap:10px;
}
.room__body h3{
    margin:0;
    color:var(--secondary);
    font-size:1.25rem;
}
.room__body p{margin:0; color:var(--muted)}
.room__meta{display:flex; flex-direction:column; gap:4px; margin-top:auto}
.price{font-weight:900; color:var(--secondary)}
.meta{font-size:.95rem; color:var(--muted)}
.room--right .room__media{order:2}
.room--right .room__body{order:1}

/* REVIEWS */
.review{padding:16px}
.review blockquote{
    margin:0;
    color:var(--text);
    font-weight:600;
}
.review figcaption{
    margin-top:10px;
    color:var(--muted);
    font-weight:800;
}

/* CITY */
.city{
    display:grid;
    grid-template-columns:1.35fr .65fr;
    gap:16px;
}
.city__text{padding:16px}
.city__text p{margin:0 0 12px; color:var(--muted)}
.city__text p:last-child{margin:0}
.city__tips{display:flex; flex-direction:column; gap:16px}
.tip{padding:16px}
.tip h3{margin:0 0 6px; color:var(--secondary)}
.tip p{margin:0; color:var(--muted)}

/* CONTACTS */
.contacts{
    display:grid;
    grid-template-columns: .95fr 1.05fr;
    gap:16px;
    align-items:stretch;
}
.contacts__info{padding:16px}
.contacts__info h3{margin:0 0 10px; color:var(--secondary)}
.contact-list{list-style:none; padding:0; margin:0 0 14px; display:flex; flex-direction:column; gap:10px}
.contact-list .k{display:inline-block; min-width:120px; color:var(--muted); font-weight:800}
.contact-list .v{color:var(--text); font-weight:700}
.contacts__actions{display:grid; grid-template-columns:1fr; gap:10px}
.contacts__map{padding:0; overflow:hidden}
.contacts__map iframe{width:100%; height:100%; min-height:320px; border:0}

/* FOOTER */
.footer{
    background:#07131a;
    color:#e8f1f6;
    padding:26px 0;
}
.footer__inner{
    display:grid;
    grid-template-columns: 1fr 1.3fr 1fr;
    gap:16px;
    align-items:center;
}
.footer__brand{font-weight:900; letter-spacing:.2px}
.footer__copy{opacity:.85; margin-top:6px}
.footer__nav{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    justify-content:center;
}
.footer__nav a{
    padding:6px 25px;
    border-radius:999px;
    background:rgba(255,255,255,.06);
    min-width: 140px;
    text-align: center;
}
.footer__nav a:hover{background:rgba(255,255,255,.10)}
.footer__right{display:flex; justify-content:flex-end}

/* RESPONSIVE */
@media (max-width: 980px){
    .grid{grid-template-columns:repeat(2, 1fr)}
    .about{grid-template-columns:1fr}
    .city{grid-template-columns:1fr}
    .contacts{grid-template-columns:1fr}
    .footer__inner{grid-template-columns:1fr; text-align:center}
    .footer__right{justify-content:center}
}
@media (max-width: 760px){
    .hero{min-height:78vh}
    .hero__cta{display:none}
    .burger{display:inline-block}
    .nav__right{display:none}
    .nav__links{
        position:fixed;
        inset:72px 14px auto 14px;
        background:#fff;
        border-radius:18px;
        border:var(--border);
        box-shadow:var(--shadow);
        padding:10px;
        display:none;
        flex-direction:column;
        gap:6px;
    }
    .nav__links.is-open{display:flex}
    .nav__links a{padding:12px 12px}
    .room{grid-template-columns:1fr}
    .room--right .room__media{order:1}
    .room--right .room__body{order:2}
    .grid, .grid--3{grid-template-columns:1fr}
}

img{
    width: 100%;
}
iframe{
    border-radius: 10px;
    overflow: hidden;
}
textarea, input{
    width: 100%;
    padding: 5px;
    margin: 3px 0;
    border-radius: 4px;
    border: 1px solid rgba(1, 90, 132, .22);
    background: #ffffff90;
    font-family: sans-serif;
    outline: none ;
}
textarea{
    height:100px;
}
#contact-form .button{
    border-radius: 4px !important;
    border: 1px solid rgba(1, 90, 132, .22);
    background: #ffffff10 !important;
}
#contact-form{
    max-width: 600px;
    margin: 0 auto;
    background: #fff;
    padding: 40px;
    padding-bottom: 64px;
    border-radius: var(--radius);
    border: var(--border);
    box-shadow: var(--shadow);
}