:root{
    /* Палитра в духе “светло/золото/графит” */
    --bg: #f7f6ef;
    --surface: #ffffff;
    --text: #1e1f22;
    --muted: #6a6f76;
    --line: rgba(30,31,34,.12);
    --shadow: 0 18px 45px rgba(16, 18, 22, .10);

    --accent: #c8a46a;        /* золото */
    --accent-2: #1f2a2a;      /* глубокий графит */
    --accent-soft: rgba(200,164,106,.18);

    --radius: 22px;
    --radius-sm: 14px;

    --container: 1180px;
    --pad: clamp(16px, 3vw, 28px);

    --h1: clamp(34px, 4vw, 56px);
    --h2: clamp(24px, 2.8vw, 34px);
    --h3: 20px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
    margin:0;
    font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    color: var(--text);
    background: var(--bg);
    line-height: 1.6;
}

img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration:none; }
p{ margin: 0 0 14px; }
ul,ol{ margin: 0; padding-left: 18px; }
.container{
    width: min(var(--container), calc(100% - (var(--pad) * 2)));
    margin: 0 auto;
}

.center{ display:flex; justify-content:center; margin-top: 18px; }

/* Buttons */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding: 12px 18px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-weight: 700;
    letter-spacing: .2px;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
    cursor:pointer;
    user-select:none;
}
.btn:active{ transform: translateY(1px); }

.btn--primary{
    background: var(--accent);
    color: #111;
    box-shadow: 0 12px 28px rgba(200,164,106,.22);
}
.btn--primary:hover{ box-shadow: 0 16px 36px rgba(200,164,106,.28); }

.btn--ghost{
    background: transparent;
    border-color: rgba(255,255,255,.35);
    color: #fff;
}
.section .btn--ghost{
    border-color: var(--line);
    color: var(--text);
}
.section .btn--ghost:hover{ border-color: rgba(200,164,106,.55); }

.btn--sm{ padding: 10px 14px; font-size: 14px; }

.chip{
    display:inline-flex;
    align-items:center;
    padding: 9px 12px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.7);
    font-weight: 700;
    font-size: 13px;
}

/* HERO */
.hero{
    position:relative;
    min-height: 84vh;
    display:flex;
    align-items:stretch;
    overflow:hidden;
    background: #0f1114;
    color: #fff;
}
.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 6.5s ease;
}
.hero__slide.is-active{
    opacity: 1;
    transform: scale(1.0);
}
.hero__overlay{
    position:absolute; inset:0;
    background:
            radial-gradient(1200px 600px at 20% 40%, rgba(0,0,0,.32), rgba(0,0,0,.62)),
            linear-gradient(to top, rgba(0,0,0,.68), rgba(0,0,0,.22));
}
.hero__inner{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    gap: 28px;
    padding: 18px 0 34px;
}

/* Topbar */
.topbar{
    display:flex;
    align-items:center;
    gap: 14px;
    padding-top: 10px;
}
.brand{
    display:flex;
    align-items:center;
    gap: 10px;
    font-weight: 900;
    letter-spacing: .4px;
}
.brand__mark{
    width: 12px; height: 12px;
    border-radius: 4px;
    background: var(--accent);
    box-shadow: 0 0 0 6px rgba(200,164,106,.18);
}
.brand__text{ font-size: 16px; }

.nav{
    margin-left:auto;
    display:flex;
    gap: 16px;
    align-items:center;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(10px);
}
.nav a{
    font-weight: 700;
    font-size: 14px;
    color: rgba(255,255,255,.92);
    padding: 8px 10px;
    border-radius: 999px;
}
.nav a:hover{ background: rgba(255,255,255,.10); }
.nav a.is-active{ background: rgba(200,164,106,.20); color:#fff; }

.topbar__cta{ margin-left: 10px; }

.burger{
    display:none;
    margin-left:auto;
    width: 44px; height: 44px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.10);
    backdrop-filter: blur(10px);
    cursor:pointer;
}
.burger span{
    display:block;
    height: 2px;
    width: 18px;
    background: #fff;
    margin: 5px auto;
    border-radius: 2px;
}

/* Hero content */
.hero__content{
    max-width: 760px;
    padding: clamp(10px, 2vw, 20px) 0;
}
.hero__badge{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding: 8px 12px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.10);
    border-radius: 999px;
    font-weight: 700;
    font-size: 13px;
    color: rgba(255,255,255,.92);
}
.hero__title{
    margin: 14px 0 8px;
    font-family: "Playfair Display", serif;
    font-size: var(--h1);
    line-height: 1.05;
    letter-spacing: .2px;
}
.hero__subtitle{
    color: rgba(255,255,255,.88);
    font-size: 16px;
    max-width: 62ch;
}
.hero__actions{
    display:flex;
    gap: 12px;
    margin-top: 18px;
    flex-wrap: wrap;
}
.hero__facts{
    margin-top: 22px;
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.fact{
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
}
.fact__title{ display:block; font-weight: 900; font-size: 14px; }
.fact__text{ display:block; color: rgba(255,255,255,.86); font-size: 13px; }

/* Booking */
.booking{
    background: linear-gradient(to bottom, rgba(247,246,239,1), rgba(247,246,239,.6));
    padding: 28px 0 14px;
    padding-bottom: 65px;
}
.booking__inner{
    display:grid;
    grid-template-columns: 1fr;
    gap: 14px;
}
.booking__title h2{
    font-family:"Playfair Display", serif;
    font-size: var(--h2);
    margin: 0 0 6px;
}
.booking__title p{ color: var(--muted); margin: 0; }
.booking__box{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 12px;
}

/* Menu strip */
.menu-strip{
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(247,246,239,.84);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--line);
}
.menu-strip__inner{
    display:flex;
    align-items:center;
    justify-content:center;
    gap: 10px;
    padding: 10px 0;
    flex-wrap: wrap;
}
.menu-strip a{
    font-weight: 800;
    font-size: 13px;
    padding: 8px 10px;
    border-radius: 999px;
}
.menu-strip a:hover{ background: rgba(200,164,106,.14); }
.menu-strip__sep{ color: rgba(30,31,34,.22); }

/* Sections */
.section{
    padding: 56px 0;
}
.section--alt{
    background: rgba(255,255,255,.65);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.section__head{
    margin-bottom: 20px;
}
.section__head h2{
    margin: 0 0 6px;
    font-family:"Playfair Display", serif;
    font-size: var(--h2);
}
.section__head p{
    margin: 0;
    color: var(--muted);
}

/* About */
.about{
    display:grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 18px;
    align-items: start;
}
.about__text{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 18px;
    box-shadow: var(--shadow);
}
.about__chips{
    display:flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 14px 0 16px;
}
.about__media{
    position:relative;
    border-radius: var(--radius);
    overflow:hidden;
    border: 1px solid var(--line);
    box-shadow: var(--shadow);
    background: var(--surface);
}
.about__media img{
    width:100%;
    height: 100%;
    object-fit: cover;
    min-height: 320px;
}
.about__media-note{
    position:absolute;
    left: 14px;
    bottom: 14px;
    display:flex;
    align-items:center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(30,31,34,.10);
    font-weight: 800;
    font-size: 13px;
}
.dot{
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 6px var(--accent-soft);
}

/* Rooms */
.rooms{
    display:flex;
    flex-direction: column;
    gap: 16px;
}
.room-card{
    display:grid;
    grid-template-columns: 420px 1fr;
    gap: 0;
    border-radius: var(--radius);
    overflow:hidden;
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: var(--shadow);
}
.room-card__img img{
    width:100%;
    height: 100%;
    min-height: 260px;
    object-fit: cover;
}
.room-card__body{
    padding: 18px;
}
.room-card__body h3{
    margin: 0 0 6px;
    font-size: clamp(18px, 2vw, 22px);
    font-weight: 900;
}
.room-card__desc{ color: var(--muted); }
.room-card__meta{
    margin: 10px 0 0;
    color: rgba(30,31,34,.86);
}
.room-card__bottom{
    margin-top: 16px;
    display:flex;
    align-items:flex-end;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.price__label{
    font-size: 12px;
    color: var(--muted);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.price__value{
    font-weight: 900;
    font-size: 18px;
}

/* Note */
.note{
    margin-top: 16px;
    display:flex;
    gap: 12px;
    align-items:flex-start;
    background: rgba(200,164,106,.10);
    border: 1px solid rgba(200,164,106,.32);
    border-radius: var(--radius);
    padding: 14px;
}
.note__icon{
    width: 26px; height: 26px;
    border-radius: 10px;
    background: var(--accent);
    color:#111;
    display:grid;
    place-items:center;
    font-weight: 900;
}
.note__text{ margin:0; color: rgba(30,31,34,.86); }

/* Services */
.services{
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.service{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 16px;
    box-shadow: var(--shadow);
    display:flex;
    flex-direction: column;
    gap: 8px;
}
.service__title{
    font-weight: 900;
    font-size: 16px;
}
.service__text{
    color: var(--muted);
    margin-bottom: 8px;
}

/* Reviews */
.reviews{
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.review{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 16px;
    box-shadow: var(--shadow);
}
.review__top{
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}
.review__name{ font-weight: 900; }
.review__stars{ color: var(--accent); letter-spacing: 1px; }
.review__text{ color: rgba(30,31,34,.86); margin: 0; }

/* City */
.city{
    display:grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 16px;
    align-items:start;
}
.card{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 16px;
    box-shadow: var(--shadow);
}
.card h3{
    margin: 0 0 10px;
    font-weight: 900;
}
.steps{
    padding-left: 0;
    margin: 0 0 14px;
    list-style:none;
    display:flex;
    flex-direction: column;
    gap: 10px;
}
.steps li{
    display:flex;
    align-items:center;
    gap: 10px;
    color: rgba(30,31,34,.86);
    font-weight: 800;
}
.steps span{
    width: 26px; height: 26px;
    border-radius: 10px;
    border: 1px solid rgba(200,164,106,.45);
    background: rgba(200,164,106,.14);
    display:grid;
    place-items:center;
}

/* FAQ */
.faq{
    display:grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
.faq__item{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 12px 14px;
    box-shadow: var(--shadow);
}
.faq__item summary{
    cursor:pointer;
    font-weight: 900;
    list-style:none;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__content{
    padding-top: 10px;
    color: rgba(30,31,34,.86);
}

/* Contacts */
.contacts{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    align-items:start;
}
.contact-card{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 16px;
    box-shadow: var(--shadow);
}
.contact-line{ margin: 0 0 8px; color: rgba(30,31,34,.86); }
.contact-line span{ color: var(--muted); font-weight: 800; }
.contact-actions{ display:flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }

.contact-form-wrap{
    margin-top: 14px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 16px;
    box-shadow: var(--shadow);
}
.contact-form-title{
    font-weight: 900;
    margin-bottom: 10px;
}

.map-box{
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow:hidden;
    box-shadow: var(--shadow);
    min-height: 360px;
    display:flex;
}
.map-placeholder{
    padding: 18px;
    display:flex;
    flex-direction: column;
    justify-content:center;
    width:100%;
    background:
            radial-gradient(600px 240px at 30% 30%, rgba(200,164,106,.18), transparent 60%),
            linear-gradient(to bottom, rgba(31,42,42,.06), transparent);
}
.map-placeholder__title{
    font-family:"Playfair Display", serif;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 6px;
}
.map-placeholder__text{ color: var(--muted); max-width: 48ch; }

.mini-note{
    margin-top: 10px;
    color: var(--muted);
    font-size: 13px;
}

/* Footer */
.footer{
    background: #0f1114;
    color: rgba(255,255,255,.86);
    padding: 18px 0;
}
.footer__inner{
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.footer__brand{
    font-weight: 900;
    color: #fff;
    letter-spacing: .3px;
}
.footer__copy{
    color: rgba(255,255,255,.70);
    font-size: 13px;
}

/* Responsive */
@media (max-width: 980px){
    .hero__facts{ grid-template-columns: 1fr; }
    .about, .city{ grid-template-columns: 1fr; }
    .services{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .reviews{ grid-template-columns: 1fr; }
    .room-card{ grid-template-columns: 1fr; }
    .room-card__img img{ min-height: 220px; }
    .contacts{ grid-template-columns: 1fr; }
}

@media (max-width: 860px){
    .nav{
        display:none;
        margin-left: 0;
        width: 100%;
        border-radius: 16px;
        padding: 10px;
        flex-wrap: wrap;
        justify-content: center;
    }
    .nav.is-open{ display:flex; }
    .burger{ display:inline-block; }
    .topbar__cta{ display:none; }
}

@media (prefers-reduced-motion: reduce){
    *{ scroll-behavior:auto !important; }
    .hero__slide{ transition: none !important; }
    .btn{ transition:none !important; }
}

iframe{
    border-radius: 10px;
    overflow: hidden;
    height: 566px;
}
textarea, input{
    width: 100%;
    padding: 8px !important;
    margin: 3px 0 !important;
    border-radius: 4px;
    border: 1px solid #e5e5e5 !important;
    background: #ffffff05;
}
textarea{
    height:100px;
}
#contact-form .button{
    border-radius: 4px !important;
    border: 1px solid #bbb !important;
    background: rgba(255, 255, 255, .06);
    color: rgba(255, 255, 255, .92);
    background: #fff !important;
}