:root{
    --bg:#0b1714;
    --bg2:#0f1f1a;
    --card:#0f231e;
    --text:#0f1b17;
    --white:#ffffff;
    --muted:rgba(255,255,255,.72);
    --muted2:rgba(15,27,23,.68);
    --line:rgba(255,255,255,.14);
    --line2:rgba(15,27,23,.12);
    --accent:#21a07a;
    --accent2:#1b7d5f;
    --shadow:0 16px 40px rgba(0,0,0,.28);
    --radius:18px;
    --radius2:24px;
    --container:1120px;
}

*{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:#f7f8f7;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{
    width:min(var(--container), calc(100% - 32px));
    margin:0 auto;
}

/* Buttons */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.5rem;
    padding:12px 16px;
    border-radius:14px;
    border:1px solid transparent;
    background:var(--accent);
    color:#fff;
    font-weight:700;
    letter-spacing:.2px;
    transition:transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
    white-space:nowrap;
}
.btn:hover{background:var(--accent2)}
.btn:active{transform:translateY(1px)}
.btn--ghost{
    background:transparent;
    border-color:rgba(255,255,255,.28);
    color:#fff;
}
.btn--ghost:hover{
    border-color:rgba(255,255,255,.52);
    background:rgba(255,255,255,.10);
}
.btn--wide{width:100%}

/* Header / Hero */
.site-header{position:relative; color:#fff}
.hero{
    position:relative;
    min-height:76vh;
    background:var(--bg);
    overflow:hidden;
}
.hero__slides{
    position:absolute; inset:0;
}
.hero__slide{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    opacity:0;
    transform:scale(1.02);
    transition:opacity 900ms ease, transform 1200ms ease;
}
.hero__slide.is-active{
    opacity:1;
    transform:scale(1.00);
}
.hero__overlay{
    position:absolute; inset:0;
    background:
            radial-gradient(900px 500px at 20% 20%, rgba(33,160,122,.26), transparent 60%),
            linear-gradient(to bottom, rgba(8,16,14,.62), rgba(8,16,14,.75) 42%, rgba(8,16,14,.92));
}
.hero__content{
    position:relative;
    padding:18px 0 38px;
}

.header-row{
    display:grid;
    grid-template-columns: 1fr auto auto;
    align-items:center;
    gap:14px;
    padding:10px 0;
}
.brand{display:flex; align-items:center; gap:12px}
.brand__mark{
    width:44px; height:44px;
    border-radius:14px;
    background: linear-gradient(135deg, rgba(33,160,122,.95), rgba(33,160,122,.22));
    border:1px solid rgba(255,255,255,.22);
    box-shadow: 0 10px 24px rgba(0,0,0,.22);

    background: url("/favicon.png");
    background-size: cover;
    opacity: 0.5;
    transform: rotateY(-180deg);
}
.brand__text strong{display:block; font-size:16px; line-height:1.1}
.brand__text span{display:block; font-size:12px; color:rgba(255,255,255,.72)}

.nav{
    display:flex;
    gap:14px;
    padding:10px 14px;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(9,16,14,.34);
    backdrop-filter: blur(8px);
}
.nav a{
    font-weight:650;
    font-size:14px;
    color:rgba(255,255,255,.92);
    padding:8px 10px;
    border-radius:12px;
    transition: background .15s ease;
}
.nav a:hover{background:rgba(255,255,255,.10)}

.header-cta{display:flex; gap:10px; align-items:center}

.burger{
    display:none;
    width:44px; height:44px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(9,16,14,.34);
    backdrop-filter: blur(8px);
    cursor:pointer;
    padding:10px;
}
.burger span{
    display:block;
    height:2px;
    background:#fff;
    border-radius:999px;
}
.burger span + span{margin-top:6px}

.hero__grid{
    display:grid;
    grid-template-columns: 1.25fr .75fr;
    gap:22px;
    padding:32px 0 10px;
}
.hero__left h1{
    margin:0 0 10px;
    font-size:44px;
    line-height:1.08;
    letter-spacing:-.6px;
}
.lead{
    margin:0 0 18px;
    max-width:56ch;
    color:rgba(255,255,255,.86);
    font-size:16.5px;
    line-height:1.55;
}
.hero__facts{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:18px 0 18px;
}
.fact{
    padding:10px 12px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(9,16,14,.28);
    backdrop-filter: blur(8px);
    min-width: 190px;
}
.fact__title{display:block; font-size:12px; color:rgba(255,255,255,.68)}
.fact__value{display:block; font-weight:750; font-size:14px; margin-top:4px}

.hero__actions{
    display:flex;
    gap:12px;
    max-width:520px;
}

.glass-card{
    border-radius: var(--radius2);
    border:1px solid rgba(255,255,255,.18);
    background:rgba(9,16,14,.34);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow);
    padding:18px;
}
.glass-card__title{font-weight:800; margin-bottom:10px}
.checklist{
    list-style:none;
    padding:0; margin:0;
    display:grid;
    gap:10px;
}
.checklist li{
    position:relative;
    padding-left:26px;
    color:rgba(255,255,255,.88);
    line-height:1.35;
}
.checklist li::before{
    content:"✓";
    position:absolute; left:0; top:-1px;
    width:18px; height:18px;
    display:inline-flex; align-items:center; justify-content:center;
    border-radius:999px;
    background:rgba(33,160,122,.22);
    border:1px solid rgba(33,160,122,.55);
    color:#fff;
    font-size:12px;
}

/* Booking */
.booking{
    background:#fff;
    border-bottom:1px solid var(--line2);
    padding:26px 0 34px;
}
.booking__box{
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    background: linear-gradient(180deg, #ffffff, #fbfbfb);
    padding:16px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}

/* Sections */
.section{padding:56px 0}
.section-head{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:16px;
    margin-bottom:18px;
}
.section-head--tight{margin-bottom:10px}
.section h2{
    margin:0;
    font-size:28px;
    letter-spacing:-.3px;
}
.muted{color:var(--muted2); margin:0; line-height:1.5}
.section-head .muted{max-width:62ch; text-align: right}

/* About */
.about{
    display:grid;
    grid-template-columns: 1.15fr .85fr;
    gap:18px;
    align-items:start;
}
.about__text{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    padding:18px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.about__text p{margin:0; line-height:1.68}
.about__badges{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:14px;
}
.badge{
    display:inline-flex;
    padding:8px 10px;
    border-radius:999px;
    border:1px solid rgba(33,160,122,.24);
    background: rgba(33,160,122,.08);
    font-weight:700;
    font-size:13px;
}
.about__media{
    border-radius: var(--radius2);
    overflow:hidden;
    border:1px solid var(--line2);
    background:#fff;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.about__media img{height:260px; object-fit:cover; width: 100%;}
.about__media-note{
    padding:14px 14px 16px;
    font-size:14px;
    line-height:1.55;
    color:rgba(15,27,23,.82);
}

/* Cards (Rooms) */
.cards{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap:16px;
}
.card{
    border-radius: var(--radius2);
    overflow:hidden;
    border:1px solid var(--line2);
    background:#fff;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
    display:flex;
    flex-direction:column;
}
.card__img{
    height:220px;
    object-fit:cover;
}
.card__body{padding:16px}
.card__top{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.card h3{margin:0; font-size:18px; line-height:1.25}
.price{font-size:14px; color:rgba(15,27,23,.75)}
.price strong{font-size:18px; color:rgba(15,27,23,.95)}
.card__desc{margin:10px 0 12px; color:rgba(15,27,23,.78); line-height:1.6}
.mini-list{
    margin:0;
    padding:0;
    list-style:none;
    display:grid;
    gap:8px;
}
.mini-list li{
    padding-left:18px;
    position:relative;
    color:rgba(15,27,23,.84);
}
.mini-list li::before{
    content:"•";
    position:absolute; left:4px; top:-1px;
    color:rgba(33,160,122,.92);
    font-weight:900;
}
.card__actions{margin-top:14px}
.note{
    margin-top:14px;
    padding:12px 14px;
    border-radius:16px;
    border:1px dashed rgba(15,27,23,.20);
    background: rgba(15,27,23,.02);
}

/* Reviews */
.reviews{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap:14px;
}
.review{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    padding:16px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.review__head{display:flex; align-items:center; gap:12px; margin-bottom:10px}
.avatar{
    width:42px; height:42px;
    border-radius:14px;
    display:flex; align-items:center; justify-content:center;
    background: rgba(33,160,122,.10);
    border:1px solid rgba(33,160,122,.25);
    font-weight:900;
}
.review__name{font-weight:850; line-height:1.1}
.stars{color:#f1b24a; letter-spacing:.5px; font-size:14px}
.review p{margin:0; line-height:1.65; color:rgba(15,27,23,.78)}

/* Services */
.service-grid{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap:12px;
}
.service{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    padding:14px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.service__icon{font-size:20px; margin-bottom:10px}
.service__title{font-weight:850; margin-bottom:6px}
.service__text{color:rgba(15,27,23,.74); line-height:1.5; font-size:14px}

.cta-strip{
    margin-top:16px;
    border-radius: var(--radius2);
    padding:14px;
    border:1px solid rgba(33,160,122,.20);
    background: linear-gradient(90deg, rgba(33,160,122,.10), rgba(33,160,122,.03));
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
}
.cta-strip__actions{display:flex; gap:10px}
.cta-strip .muted{color:rgba(15,27,23,.70)}

/* City */
.city{
    display:grid;
    grid-template-columns: 1.15fr .85fr;
    gap:16px;
    align-items:start;
}
.city__text{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    padding:18px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.city__text p{margin:0; line-height:1.75; color:rgba(15,27,23,.80)}
.city__media{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    overflow:hidden;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.city__media img{height:220px; object-fit:cover; width: 100%}
.city__tips{padding:14px; display:grid; gap:10px}
.tip{
    padding:10px 12px;
    border-radius:16px;
    border:1px solid rgba(15,27,23,.10);
    background: rgba(15,27,23,.02);
    color:rgba(15,27,23,.78);
}

/* FAQ */
.faq{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:12px;
}
.faq__item{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    padding:12px 14px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.faq__item summary{
    cursor:pointer;
    font-weight:850;
    list-style:none;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__content{
    margin-top:10px;
    color:rgba(15,27,23,.76);
    line-height:1.6;
}

/* Contacts */
.contacts{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:16px;
    align-items:stretch;
}
.contact-card{
    background:#fff;
    border:1px solid var(--line2);
    border-radius: var(--radius2);
    padding:18px;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.contact-row{
    display:grid;
    grid-template-columns: 140px 1fr;
    gap:12px;
    padding:10px 0;
    border-bottom:1px solid rgba(15,27,23,.08);
}
.contact-row:last-of-type{border-bottom:0}
.contact-label{color:rgba(15,27,23,.62); font-weight:750}
.contact-value a{color:rgba(15,27,23,.92); text-decoration:underline; text-underline-offset:3px}
.contact-actions{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:10px;
    margin-top:14px;
}
.small-note{
    margin-top:12px;
    padding:12px 14px;
    border-radius:16px;
    border:1px dashed rgba(15,27,23,.20);
    background: rgba(15,27,23,.02);
    color:rgba(15,27,23,.76);
}
.map-box{
    height:100%;
    min-height: 340px;
    border-radius: var(--radius2);
    overflow:hidden;
    border:1px solid var(--line2);
    background:#fff;
    box-shadow: 0 12px 30px rgba(0,0,0,.05);
}
.map-placeholder{
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:8px;
    background:
            radial-gradient(420px 240px at 30% 25%, rgba(33,160,122,.14), transparent 65%),
            linear-gradient(180deg, rgba(15,27,23,.03), rgba(15,27,23,.02));
    color:rgba(15,27,23,.70);
    text-align:center;
    padding:18px;
}
.map-placeholder__title{font-weight:900; font-size:18px}
.map-placeholder__text{max-width:40ch}

/* Footer */
.footer{
    background:var(--bg2);
    color:#fff;
    padding:18px 0;
}
.footer__row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
}
.footer__title{font-weight:900}
.footer__meta{color:rgba(255,255,255,.72); font-size:13px}
.footer__right{display:flex; gap:10px}

/* Responsive */
@media (max-width: 980px){
    .hero__grid{grid-template-columns: 1fr; padding-top:18px}
    .header-row{grid-template-columns: 1fr auto}
    .nav{display:none}
    .header-cta{display:none}
    .burger{display:inline-flex}
    .hero__actions{flex-direction:column; max-width:520px}
    .service-grid{grid-template-columns: repeat(2, 1fr)}
    .reviews{grid-template-columns: repeat(2, 1fr)}
    .cards{grid-template-columns: 1fr}
    .about, .city, .contacts{grid-template-columns: 1fr}
    .map-box{min-height:280px}
}

@media (max-width: 560px){
    .hero{min-height:78vh}
    .hero__left h1{font-size:34px}
    .lead{font-size:15.5px}
    .reviews{grid-template-columns: 1fr}
    .faq{grid-template-columns: 1fr}
    .contact-row{grid-template-columns: 1fr}
    .section-head .muted{display: none}
}

/* Mobile menu (opened) */
body.nav-open .nav{
    display:flex;
    position:fixed;
    left:16px; right:16px; top:74px;
    z-index:50;
    flex-direction:column;
    padding:12px;
    gap:6px;
    border-radius:18px;
    background:rgba(9,16,14,.88);
    border:1px solid rgba(255,255,255,.18);
}
body.nav-open .header-cta{
    display:flex;
    position:fixed;
    left:16px; right:16px; top: calc(74px + 220px);
    z-index:50;
    gap:10px;
}
