:root{
    --chalk:#e8e8e8;
    --slate:#393c4f;
    --steel:#59647a;
    --mist:#9098ab;
    --bay:#95bacd;

    --ink:#0e1223;
    --paper:#ffffff;
    --ring: rgba(149,186,205,.45);
    --shadow: 0 10px 30px rgba(17,22,42,.18);
    --radius: 18px;

    --font-text: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    --font-head: "Playfair Display", Georgia, "Times New Roman", serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
    margin:0;
    font-family: var(--font-text);
    color:var(--ink);
    background: linear-gradient(180deg, var(--chalk), #fff);
}

a{ color:inherit; text-decoration:none; }
.wrap{ width:min(1120px, calc(100% - 40px)); margin:0 auto; }

/* Верхняя панель */
.topline{
    background: rgba(57,60,79,.92);
    color: #fff;
    position: sticky;
    top:0;
    z-index: 50;
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(232,232,232,.12);
}
.topline__in{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    padding:10px 0;
    flex-wrap: wrap;
}
.brand{
    display:flex;
    align-items:baseline;
    gap:10px;
    min-width: 220px;
}
.brand__name{
    font-family:var(--font-head);
    font-weight:800;
    letter-spacing:.3px;
    font-size:20px;
    line-height:1;
}
.brand__tag{
    opacity:.85;
    font-size:13px;
    line-height:1.1;
    white-space:nowrap;
}

.nav{
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
    justify-content:center;
}
.nav a{
    font-size:13px;
    padding:8px 10px;
    border-radius:999px;
    opacity:.92;
    transition: transform .18s ease, background .18s ease, opacity .18s ease;
}
.nav a:hover{
    background: rgba(149,186,205,.18);
    opacity:1;
    transform: translateY(-1px);
}

.top-actions{
    display:flex;
    align-items:center;
    gap:10px;
    min-width: 220px;
    justify-content:flex-end;

}
.pill{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:8px 12px;
    border-radius:999px;
    background: rgba(232,232,232,.10);
    border: 1px solid rgba(232,232,232,.18);
    font-size:13px;
    transition: transform .18s ease, background .18s ease;
    white-space:nowrap;
}
.pill:hover{ background: rgba(232,232,232,.14); transform: translateY(-1px); }

.cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 14px;
    border-radius:999px;
    background: var(--bay);
    color: #0b1020;
    font-weight:700;
    font-size:13px;
    border: 1px solid rgba(255,255,255,.25);
    box-shadow: 0 8px 18px rgba(149,186,205,.25);
    transition: transform .18s ease, filter .18s ease;
    white-space:nowrap;
}
.cta:hover{ transform: translateY(-1px); filter: brightness(1.02); }

/* Бургер */
.burger{
    display:none;
    width:42px; height:42px;
    border-radius: 12px;
    border: 1px solid rgba(232,232,232,.18);
    background: rgba(232,232,232,.08);
    cursor:pointer;
    position:relative;
}
.burger span{
    position:absolute;
    left:11px; right:11px;
    height:2px;
    background:#fff;
    border-radius:2px;
    transition: transform .2s ease, top .2s ease, opacity .2s ease;
}
.burger span:nth-child(1){ top:14px; }
.burger span:nth-child(2){ top:20px; }
.burger span:nth-child(3){ top:26px; }
.burger.is-open span:nth-child(1){ top:20px; transform: rotate(45deg); }
.burger.is-open span:nth-child(2){ opacity:0; }
.burger.is-open span:nth-child(3){ top:20px; transform: rotate(-45deg); }

.mobile-panel{
    display:none;
    padding: 10px 0 14px;
    border-top: 1px solid rgba(232,232,232,.12);
}
.mobile-panel .nav{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
}
.mobile-panel .nav a{
    background: rgba(232,232,232,.08);
    border: 1px solid rgba(232,232,232,.14);
}

/* Шапка со слайдами */
.panorama{
    position: relative;
    min-height: 64vh;
    display:flex;
    align-items:flex-end;
    overflow:hidden;
    background: #11162a;
}
.panorama__slides{
    position:absolute;
    inset:0;
}
.panorama__slides img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    opacity:0;
    transform: scale(1.02);
    transition: opacity 1.2s ease, transform 6s ease;
}
.panorama__slides img.is-active{
    opacity:1;
    transform: scale(1.06);
}
.panorama__veil{
    position:absolute;
    inset:0;
    background:
            radial-gradient(1200px 600px at 20% 20%, rgba(149,186,205,.18), transparent 60%),
            linear-gradient(180deg, rgba(17,22,42,.25) 0%, rgba(17,22,42,.70) 70%, rgba(17,22,42,.92) 100%);
    pointer-events:none;
}
.panorama__content{
    position:relative;
    width:100%;
    padding: 54px 0 34px;
    color:#fff;
}
.headline{
    display:grid;
    grid-template-columns: 1.4fr .6fr;
    gap: 20px;
    align-items:end;
}
.headline h1{
    margin:0;
    font-family:var(--font-head);
    font-size: clamp(30px, 4.2vw, 52px);
    line-height:1.04;
    letter-spacing:.2px;
}
.headline p{
    margin: 12px 0 0;
    max-width: 58ch;
    opacity:.92;
    font-size: 16px;
    line-height: 1.55;
}
.badges{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    justify-content:flex-end;
    align-items:flex-end;
}
.badge{
    display:inline-flex;
    gap:8px;
    align-items:center;
    padding:10px 12px;
    border-radius: 14px;
    background: rgba(232,232,232,.10);
    border:1px solid rgba(232,232,232,.14);
    backdrop-filter: blur(10px);
    font-size:13px;
    line-height:1.2;
    white-space:nowrap;
}
.badge b{ font-weight:800; }

/* Форма бронирования (вставка) */
.booking{
    background: #fff;
    border-bottom: 1px solid rgba(57,60,79,.10);
}
.booking__in{
    padding: 18px 0 24px;
}
.booking__card{
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(149,186,205,.25), rgba(232,232,232,.55));
    border:1px solid rgba(57,60,79,.10);
    box-shadow: var(--shadow);
    padding: 14px;
}
.booking__hint{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding: 0 6px 10px;
    color: var(--slate);
    font-size:13px;
}
.booking__hint strong{ font-weight:800; }
.booking__slot{
    border-radius: 14px;
    background:#fff;
    border:1px solid rgba(57,60,79,.10);
    padding: 12px;
}

/* Общие секции */
section{ padding: 54px 0; }
.section-title{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:20px;
    margin-bottom: 18px;
}
.section-title h2{
    margin:0;
    font-family: var(--font-head);
    font-size: clamp(22px, 3vw, 34px);
    letter-spacing:.2px;
}
.section-title p{
    margin:0;
    color: rgba(57,60,79,.82);
    max-width: 52ch;
    line-height:1.5;
    font-size:14px;
    text-align: right;
}

.card{
    background: #fff;
    border:1px solid rgba(57,60,79,.10);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

/* Об отеле */
.facts{
    display:grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 18px;
    align-items: start;
}
.facts__text{
    padding: 18px;
}
.facts__text p{
    margin:0;
    color: rgba(17,22,42,.92);
    line-height:1.75;
    font-size:16px;
    text-indent: 40px;
}
.facts__grid{
    padding: 18px;
    display:grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
.chip{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    padding: 12px 12px;
    border-radius: 14px;
    background: rgba(232,232,232,.55);
    border: 1px solid rgba(57,60,79,.08);
}
.chip span{ color: rgba(57,60,79,.85); font-size:13px; }
.chip b{ color: var(--slate); font-size:14px; }

/* Номера */
.rooms{
    display:grid;
    gap: 14px;
}
.room{
    display:grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 0;
    overflow:hidden;
}
.room__media{
    position:relative;
    min-height: 260px;
    background: #11162a;
}
.room__media img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
}
.room__body{
    padding: 18px;
    display:flex;
    flex-direction:column;
    gap: 10px;
}
.room__body h3{
    margin:0;
    font-family: var(--font-head);
    font-size: 22px;
    letter-spacing:.2px;
}
.room__body p{
    margin:0;
    color: rgba(57,60,79,.86);
    line-height: 1.65;
    font-size: 14.5px;
}
.room__meta{
    display:flex;
    flex-wrap:wrap;
    gap: 8px;
    margin-top: 2px;
}
.tag{
    font-size: 12px;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(149,186,205,.22);
    border: 1px solid rgba(149,186,205,.35);
    color: rgba(17,22,42,.88);
    white-space:nowrap;
}
.room__foot{
    margin-top:auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding-top: 8px;
    border-top: 1px dashed rgba(57,60,79,.18);
}
.price{
    display:flex;
    flex-direction:column;
    gap:2px;
    line-height:1.1;
}
.price small{
    color: rgba(57,60,79,.74);
    font-size:12px;
}
.price b{
    font-size: 18px;
    color: var(--slate);
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding: 10px 14px;
    border-radius: 14px;
    border: 1px solid rgba(57,60,79,.16);
    background: linear-gradient(135deg, rgba(149,186,205,.40), rgba(232,232,232,.95));
    font-weight: 800;
    font-size: 13px;
    color: var(--slate);
    cursor:pointer;
    transition: transform .18s ease, filter .18s ease;
    white-space:nowrap;
}
.btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }

.rooms .room:nth-child(even){
    grid-template-columns: 1.1fr 1fr;
}
.rooms .room:nth-child(even) .room__media{ order:2; }
.rooms .room:nth-child(even) .room__body{ order:1; }

/* Услуги */
.services{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
.service{
    padding: 14px;
    border-radius: var(--radius);
    background: #fff;
    border: 1px solid rgba(57,60,79,.10);
    box-shadow: 0 8px 18px rgba(17,22,42,.08);
    min-height: 118px;
    display:flex;
    flex-direction:column;
    gap: 8px;
    transition: transform .18s ease;
}
.service:hover{ transform: translateY(-2px); }
.service b{ color: var(--slate); }
.service span{ color: rgba(57,60,79,.82); font-size: 13px; line-height:1.5; }

/* Отзывы */
.reviews{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.review{
    padding: 16px;
}
.review p{
    margin:0;
    line-height:1.7;
    color: rgba(17,22,42,.90);
    font-size: 14.5px;
}
.review__who{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(57,60,79,.10);
    color: rgba(57,60,79,.82);
    font-size: 13px;
}
.stars{ letter-spacing: 1px; }

/* О городе */
.city{
    display:grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 12px;
    align-items: start;
}
.city__text{ padding: 18px; }
.city__text p{ margin:10px 0; line-height:1.75; color: rgba(17,22,42,.92); text-indent: 40px }
.city__tips{
    padding: 18px;
    display:grid;
    gap: 10px;
}
.tip{
    padding: 12px;
    border-radius: 14px;
    background: rgba(232,232,232,.55);
    border: 1px solid rgba(57,60,79,.08);
    color: rgba(57,60,79,.88);
    font-size: 13px;
    line-height: 1.55;
}

/* FAQ */
.faq{
    display:grid;
    gap: 10px;
}
details{
    border-radius: var(--radius);
    background:#fff;
    border:1px solid rgba(57,60,79,.10);
    box-shadow: 0 8px 18px rgba(17,22,42,.06);
    overflow:hidden;
}
summary{
    list-style:none;
    cursor:pointer;
    padding: 14px 16px;
    font-weight: 800;
    color: var(--slate);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
}
summary::-webkit-details-marker{ display:none; }
summary::after{
    content:"+";
    width:28px; height:28px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius: 10px;
    border:1px solid rgba(57,60,79,.14);
    background: rgba(232,232,232,.55);
    flex:0 0 auto;
    transition: transform .18s ease;
}
details[open] summary::after{ content:"—"; transform: rotate(180deg); }
.faq__body{
    padding: 0 16px 16px;
    color: rgba(57,60,79,.86);
    line-height:1.7;
    font-size:14px;
}

/* Контакты + карта */
.contacts{
    display:grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 12px;
    align-items: start;
}
.contacts__left{ padding: 18px; }
.contacts__left h3{
    margin:0 0 10px;
    font-family: var(--font-head);
    font-size: 22px;
}
.contacts__left p{
    margin: 0 0 10px;
    color: rgba(57,60,79,.86);
    line-height:1.6;
}
.contact-list{
    display:grid;
    gap:10px;
    margin-top: 12px;
}
.contact-item{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    padding: 12px;
    border-radius: 14px;
    background: rgba(232,232,232,.55);
    border: 1px solid rgba(57,60,79,.08);
    color: rgba(17,22,42,.92);
}
.contact-item span{
    color: rgba(57,60,79,.78);
    font-size: 12px;
}
.contact-item b{
    font-size: 14px;
    color: var(--slate);
    text-align:right;
}

.contacts__right{
    display:grid;
    gap: 12px;
}
.mapbox{
    overflow:hidden;
    border-radius: var(--radius);
    border:1px solid rgba(57,60,79,.10);
    box-shadow: var(--shadow);
    background:#fff;
}
.mapbox iframe{
    display:block;
    width:100%;
    height: 360px;
    border:0;
}

/* Футер */
footer{
    background: #11162a;
    color:#fff;
    padding: 26px 0;
    margin-top: 30px;
}
.footer__in{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 14px;
    flex-wrap:wrap;
}
.footer__left{
    display:flex;
    flex-direction:column;
    gap:6px;
    opacity:.92;
}
.footer__left b{
    font-family: var(--font-head);
    font-size: 18px;
    letter-spacing:.2px;
}
.footer__left small{ opacity:.82; }

.footer__right{
    display:flex;
    gap: 10px;
    align-items:center;
    flex-wrap:wrap;
    justify-content:flex-end;
}
.footer__right a{
    color:#fff;
}
.cta--dark{
    background: rgba(149,186,205,.92);
    color:#0b1020;
}

/* Анимации появления блоков */
.reveal{
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .55s ease, transform .55s ease;
    will-change: opacity, transform;
}
.reveal.is-in{
    opacity: 1;
    transform: translateY(0);
}

.gallery-list img{
    display: block;
    border-radius: var(--radius);
    max-width: 100%;
    height: 100%;
}
.gallery-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
#contact-form .button,
input, textarea{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border-radius: 14px !important;
    background: rgba(232, 232, 232, .55) !important;
    border: 1px solid rgba(57, 60, 79, .08) !important;
    color: rgba(17, 22, 42, .92) !important;
    width: 100%;
    margin: 10px 0;
    outline-color:  #999;
}
#contact-form .button:not(.active){
    color: #999 !important;
    background: rgba(232, 232, 232, .55) !important;
}
#contact-form .button.active{
 background: linear-gradient(135deg, rgba(149, 186, 205, .40), rgba(232, 232, 232, .95)) !important;
}
/* Адаптив */
@media (max-width: 980px){
    .headline{ grid-template-columns: 1fr; }
    .badges{ justify-content:flex-start; }
    .facts{ grid-template-columns: 1fr; }
    .services{ grid-template-columns: repeat(2, 1fr); }
    .reviews{ grid-template-columns: 1fr; }
    .city{ grid-template-columns: 1fr; }
    .contacts{ grid-template-columns: 1fr; }
    .mapbox iframe{ height: 320px; }
}
@media (max-width: 840px){
    .nav{ display:none; }
    .is-open nav{display: block}
    .burger{ display:inline-flex; }
    .mobile-panel{ display:block; }
    .top-actions{ min-width:auto; }
    .brand{ min-width:auto; }
}

@media (max-width: 760px){
    .room{ grid-template-columns: 1fr; }
    .rooms .room:nth-child(even){ grid-template-columns: 1fr; }
    .rooms .room:nth-child(even) .room__media{ order:0; }
    .rooms .room:nth-child(even) .room__body{ order:0; }
    .room__media{ min-height: 220px; }
    .services{ grid-template-columns: 1fr; }
    .section-title{ flex-direction:column; align-items:flex-start; }
    .booking__hint{ flex-direction:column; align-items:flex-start; }

    .gallery-list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .gallery-list img:nth-child(odd){
        display: none;
    }
}

@media (max-width: 660px){
    .top-actions{
        width: 100%;
        justify-content: space-between;
    }
    .brand {
        min-width: auto;
        width: 100%;
        text-align: center;
        justify-content: center;
        padding: 10px;
        border-bottom: 1px solid #ffffff20;
        padding-bottom: 20px;
    }
    .brand__tag{display: none}
    .brand__name{font-size:30px}
    .top-actions .pill{display: none}
    .mobile-panel.is-open{
        padding: 20px 0;
    }

    .mobile-panel.is-open .nav{
        display: flex;
        flex-direction: row;
        justify-content: space-around;
        flex-wrap: wrap;
    }
    .mobile-panel.is-open .nav a{
         min-width: 100px;
        text-align: center;
    }
    .section-title h2,
    .section-title p{
        text-align: center;
        width: 100%;
    }
}