
:root{
  --ink:#14181f; --ink-2:#1b212b; --ink-3:#27303c;
  --cream:#edf1f0; --cream-2:#e2e8e6; --paper:#f7f8f7;
  --gold:#15897a; --gold-deep:#0d6354; --gold-light:#3fbfa9; --gold-soft:#bce4dc;
  --line:rgba(20,24,31,.13);
  --shadow:0 30px 70px -34px rgba(20,24,31,.5);
  --shadow-sm:0 14px 36px -22px rgba(20,24,31,.5);
  --display:'Sora',-apple-system,BlinkMacSystemFont,sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
/* faint paper grain */
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1240px;margin:0 auto;padding:0 30px;position:relative;z-index:2}
.eyebrow{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);font-weight:500;display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:var(--gold-light)} .eyebrow.light::before{background:var(--gold-light)}
h2.title{font-family:var(--display);font-weight:600;font-size:clamp(2.3rem,4.8vw,3.7rem);line-height:1.02;letter-spacing:.4px;margin:.32em 0 .15em}
.section-head{margin-bottom:56px}
.section-head.center{text-align:center}
.section-head p{color:#6f6557;max-width:50ch;font-weight:300;font-size:1.05rem}
.section-head.center p{margin:0 auto}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6em;font-family:var(--body);font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;padding:1.1em 2.1em;border:1px solid var(--gold);color:var(--ink);background:transparent;cursor:pointer;transition:.4s cubic-bezier(.4,0,.2,1);border-radius:2px;white-space:nowrap}
.btn:hover{background:var(--gold);color:#fff}
.btn-solid{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-solid:hover{background:var(--gold);border-color:var(--gold)}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-deep);border-color:var(--gold-deep)}

/* ===== TOP BAR ===== */
.topbar{background:var(--ink);color:rgba(255,255,255,.78);font-size:.74rem;letter-spacing:.06em;position:relative;z-index:55}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar .t-trust{display:flex;gap:22px;align-items:center}
.topbar .t-trust span{display:flex;align-items:center;gap:7px}
.topbar .t-trust svg{width:13px;height:13px;fill:var(--gold-light)}
.topbar .t-right{display:flex;align-items:center;gap:18px}
.topbar a:hover{color:#fff}
.topbar .lang a{opacity:.6}.topbar .lang a.on{opacity:1;color:var(--gold-light)}

/* ===== HEADER ===== */
header{position:sticky;top:0;z-index:50;transition:.4s;background:rgba(250,246,238,.0)}
header.float{position:fixed;left:0;right:0;top:0}
.head-inner{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;max-width:1300px;margin:0 auto;transition:.4s}
header.scrolled{background:rgba(250,246,238,.96);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
header.scrolled .head-inner{padding:13px 30px}
.brand{display:flex;align-items:center;gap:13px;color:#fff;transition:.4s}
header.scrolled .brand,header.on-light .brand{color:var(--ink)}
.brand .crown{font-family:var(--display);font-size:1.6rem;font-weight:600;letter-spacing:.2em;line-height:1}
.brand small{display:block;font-size:.58rem;letter-spacing:.42em;text-transform:uppercase;opacity:.75;margin-top:1px}
nav.main{display:flex;align-items:center;gap:30px}
nav.main a{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:#fff;font-weight:400;position:relative;padding:4px 0;transition:.3s}
header.scrolled nav.main a,header.on-light nav.main a{color:var(--ink)}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:.35s}
nav.main a:hover::after{width:100%}
.head-cta{display:flex;align-items:center;gap:18px}
.head-phone{font-size:.82rem;font-weight:500;color:#fff;white-space:nowrap;transition:.4s}
header.scrolled .head-phone,header.on-light .head-phone{color:var(--ink)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:25px;height:2px;background:#fff;transition:.3s}
header.scrolled .burger span,header.on-light .burger span{background:var(--ink)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:#fff;overflow:hidden;margin-top:-88px;padding-top:88px}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slides .s{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.07);transition:opacity 1.7s ease,transform 8s ease}
.hero-slides .s.on{opacity:1;transform:scale(1)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(18,13,10,.6),rgba(18,13,10,.28) 42%,rgba(18,13,10,.78))}
.hero-inner{position:relative;z-index:2;width:100%;padding:60px 0 230px}
.hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.9rem,7.2vw,5.8rem);line-height:.98;letter-spacing:.5px;max-width:15ch;margin:.2em 0 .45em}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero p.lead{max-width:48ch;font-size:1.08rem;font-weight:300;opacity:.94}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px 12px;margin-top:30px}
.chip{display:inline-flex;align-items:center;gap:9px;font-size:.74rem;letter-spacing:.06em;padding:9px 16px;border:1px solid rgba(255,255,255,.32);border-radius:40px;backdrop-filter:blur(4px);background:rgba(255,255,255,.06)}
.chip svg{width:14px;height:14px;fill:var(--gold-light)}

/* ===== BOOKING WIDGET ===== */
.book-band{position:relative;z-index:30;margin-top:-160px}
.book-card{background:var(--paper);border-radius:5px;box-shadow:var(--shadow);overflow:hidden;border:1px solid rgba(180,137,74,.25)}
.book-card .bc-top{background:linear-gradient(90deg,var(--ink),var(--ink-3));color:#fff;padding:14px 26px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.book-card .bc-top .h{font-family:var(--display);font-size:1.35rem;font-weight:600;letter-spacing:.4px}
.book-card .bc-top .promo{font-size:.74rem;letter-spacing:.05em;display:flex;align-items:center;gap:9px;color:var(--gold-soft)}
.book-card .bc-top .promo svg{width:15px;height:15px;fill:var(--gold-light)}
/* контейнер для поисковой формы Exely */
#exely-search-form{padding:24px 26px}
.sf{display:grid;grid-template-columns:1.2fr 1.2fr .9fr 1fr auto;gap:16px;align-items:end}
.sf .fld{display:flex;flex-direction:column;gap:7px}
.sf label{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:#8a8072;font-weight:500}
.sf input{font-family:var(--body);font-size:.98rem;padding:.9em 1em;border:1px solid var(--line);background:#fff;border-radius:3px;color:var(--ink);transition:.3s}
.sf input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(180,137,74,.12)}
.sf .btn{height:48px;padding-inline:1.7em}
.bc-note{padding:0 26px 20px;font-size:.78rem;color:#8a8072;display:flex;align-items:center;gap:8px}
.bc-note svg{width:14px;height:14px;fill:var(--gold)}

section{padding:clamp(72px,9vw,128px) 0;position:relative}

/* ===== TRUST STRIP ===== */
.trust{background:var(--cream);padding:34px 0}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.trust .ti{display:flex;align-items:center;gap:14px}
.trust .ti svg{width:30px;height:30px;fill:none;stroke:var(--gold-deep);stroke-width:1.4;flex-shrink:0}
.trust .ti b{font-family:var(--display);font-size:1.3rem;font-weight:600;display:block;line-height:1.1}
.trust .ti span{font-size:.78rem;color:#6f6557;letter-spacing:.03em}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(40px,6vw,92px);align-items:center}
.about-text p{color:#6f6557;margin-bottom:1.15em;font-weight:300;font-size:1.06rem}
.about-stats{display:flex;gap:46px;margin-top:36px;flex-wrap:wrap}
.about-stats .s b{font-family:var(--display);font-size:2.7rem;color:var(--gold-deep);font-weight:600;display:block;line-height:.9}
.about-stats .s span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#8a8072}
.about-imgs{position:relative;aspect-ratio:4/4.5}
.about-imgs img{position:absolute;border-radius:4px;object-fit:cover;box-shadow:var(--shadow)}
.about-imgs .a1{width:76%;height:80%;top:0;right:0}
.about-imgs .a2{width:54%;height:50%;bottom:0;left:0;border:9px solid var(--paper)}
.about-imgs .badge{position:absolute;top:20px;left:0;background:var(--ink);color:#fff;padding:16px 20px;border-radius:3px;box-shadow:var(--shadow-sm);z-index:3}
.about-imgs .badge b{font-family:var(--display);font-size:1.7rem;color:var(--gold-light);display:block;line-height:1}
.about-imgs .badge span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;opacity:.8}

/* ===== WHY DIRECT ===== */
.why{background:var(--ink);color:#fff}
.why .section-head p{color:rgba(255,255,255,.66)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why-card{border:1px solid rgba(255,255,255,.13);border-radius:4px;padding:32px 26px;transition:.4s;background:rgba(255,255,255,.015)}
.why-card:hover{border-color:var(--gold);transform:translateY(-6px);background:rgba(180,137,74,.07)}
.why-card .ic{width:46px;height:46px;margin-bottom:20px;fill:none;stroke:var(--gold-light);stroke-width:1.3}
.why-card h3{font-family:var(--display);font-size:1.55rem;font-weight:600;margin-bottom:10px}
.why-card p{font-size:.92rem;font-weight:300;color:rgba(255,255,255,.66);line-height:1.6}

/* ===== ROOMS ===== */
#rooms{background:var(--cream)}
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.room{background:var(--paper);border-radius:4px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.5s;display:flex;flex-direction:column}
.room:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.room .ph{position:relative;aspect-ratio:3/2.15;overflow:hidden}
.room .ph img{width:100%;height:100%;object-fit:cover;transition:1.2s}
.room:hover .ph img{transform:scale(1.07)}
.room .tag{position:absolute;top:14px;left:14px;background:rgba(23,18,16,.82);color:var(--gold-soft);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;border-radius:30px;backdrop-filter:blur(3px)}
.room .body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.room h3{font-family:var(--display);font-size:1.75rem;font-weight:600}
.room .feat{display:flex;flex-wrap:wrap;gap:7px 14px;margin:10px 0 20px;font-size:.78rem;color:#8a8072}
.room .feat span{display:flex;align-items:center;gap:6px}
.room .feat svg{width:14px;height:14px;fill:var(--gold)}
.room .row{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--line);padding-top:18px}
.room .price small{font-size:.7rem;color:#8a8072;display:block;letter-spacing:.04em}
.room .price b{font-family:var(--display);font-size:1.45rem;color:var(--ink);font-weight:600}
.room a.book{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:var(--gold);padding:.85em 1.4em;border-radius:2px;font-weight:500;transition:.35s}
.room a.book:hover{background:var(--gold-deep)}

/* ===== OFFERS ===== */
.offers-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.offer{position:relative;border-radius:4px;overflow:hidden;min-height:360px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow)}
.offer img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:1.2s}
.offer:hover img{transform:scale(1.06)}
.offer::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,13,10,0) 28%,rgba(18,13,10,.9))}
.offer .c{position:relative;z-index:2;padding:36px}
.offer h3{font-family:var(--display);font-size:2.1rem;font-weight:600;margin:.15em 0 .4em}
.offer p{font-weight:300;opacity:.92;max-width:36ch;margin-bottom:22px}
.offer .btn{color:#fff;border-color:rgba(255,255,255,.55)}
.offer .btn:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ===== SERVICES ===== */
#services{background:var(--ink);color:#fff}
#services .section-head p{color:rgba(255,255,255,.66)}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.svc{position:relative;border-radius:4px;overflow:hidden;aspect-ratio:3/3.6;display:flex;align-items:flex-end}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:1s}
.svc:hover img{transform:scale(1.08)}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,13,10,0) 42%,rgba(18,13,10,.85))}
.svc span{position:relative;z-index:2;padding:24px;font-family:var(--display);font-size:1.5rem;font-weight:600}
.amenities{display:flex;flex-wrap:wrap;gap:15px 36px;margin-top:46px;border-top:1px solid rgba(255,255,255,.15);padding-top:36px}
.amenities span{font-size:.84rem;letter-spacing:.05em;color:rgba(255,255,255,.84);display:flex;align-items:center;gap:10px}
.amenities span::before{content:"";width:6px;height:6px;background:var(--gold-light);border-radius:50%}

/* ===== GALLERY ===== */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:16px}
.gal a{overflow:hidden;border-radius:3px;position:relative}
.gal img{width:100%;height:100%;object-fit:cover;transition:.9s}
.gal a:hover img{transform:scale(1.08)}
.gal a:nth-child(1){grid-column:span 2;grid-row:span 2}
.gal a:nth-child(6){grid-column:span 2}

/* ===== REVIEWS ===== */
#reviews{background:var(--cream)}
.rev-top{text-align:center;margin-bottom:50px}
.stars{color:var(--gold);font-size:1.4rem;letter-spacing:4px}
.rev-top .big{font-family:var(--display);font-size:clamp(2rem,4vw,2.8rem);font-weight:600;margin:.2em 0 .1em}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rev{background:var(--paper);border-radius:4px;padding:32px 30px;box-shadow:var(--shadow-sm);position:relative}
.rev .q{font-family:var(--display);font-size:3.4rem;color:var(--gold-soft);line-height:.4;position:absolute;top:26px;right:26px}
.rev .stars{font-size:.95rem;letter-spacing:2px;margin-bottom:14px}
.rev p{color:#5f5648;font-weight:300;font-style:italic;font-size:1.04rem;margin-bottom:18px;font-family:var(--display)}
.rev .who{font-size:.82rem;letter-spacing:.05em;color:var(--ink)}
.rev .who b{font-weight:500}.rev .who span{color:#8a8072}

/* ===== CTA BAND ===== */
.cta{position:relative;color:#fff;text-align:center;overflow:hidden;padding:clamp(80px,11vw,150px) 0}
.cta img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cta::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,13,10,.74),rgba(18,13,10,.6))}
.cta .wrap{position:relative;z-index:2}
.cta h2{font-family:var(--display);font-weight:500;font-size:clamp(2.2rem,5vw,3.6rem);max-width:18ch;margin:.3em auto .4em;line-height:1.05}
.cta p{max-width:46ch;margin:0 auto 32px;font-weight:300;opacity:.92}

/* ===== CONTACT ===== */
#contact{background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:1fr 1.18fr;gap:clamp(36px,5vw,72px);align-items:stretch}
.ci{margin-bottom:26px}
.ci b{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);display:block;margin-bottom:6px;font-weight:500}
.ci p,.ci a.cl{font-size:1.1rem;color:var(--ink);font-weight:300}
.ci a.cl:hover{color:var(--gold-deep)}
.msg-row{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 28px}
.msg-row a{display:inline-flex;align-items:center;gap:9px;font-size:.8rem;letter-spacing:.04em;padding:.8em 1.2em;border:1px solid var(--line);border-radius:40px;transition:.3s;font-weight:500}
.msg-row a:hover{border-color:var(--gold);background:var(--cream)}
.msg-row a svg{width:17px;height:17px}
.map{border-radius:4px;overflow:hidden;min-height:400px;box-shadow:var(--shadow)}
.map iframe{width:100%;height:100%;border:0;min-height:400px}

/* ===== FOOTER ===== */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:70px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.13)}
footer .crown{font-family:var(--display);color:#fff;font-size:1.7rem;letter-spacing:.2em;font-weight:600}
footer .fdesc{margin-top:14px;max-width:32ch;font-weight:300;font-size:.92rem}
footer h4{color:#fff;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;font-weight:500}
footer ul{list-style:none}
footer ul li{margin-bottom:11px}
footer ul a{font-size:.92rem;font-weight:300;transition:.3s}
footer ul a:hover{color:var(--gold-light)}
.fsocial{display:flex;gap:12px;margin-top:18px}
.fsocial a{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
.fsocial a:hover{background:var(--gold);border-color:var(--gold)}
.fsocial svg{width:18px;height:18px;fill:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:24px;font-size:.78rem;flex-wrap:wrap;color:rgba(255,255,255,.55)}
.foot-bottom a:hover{color:#fff}

/* ===== FLOATING CONTACT DOCK ===== */
.dock{position:fixed;right:20px;bottom:24px;z-index:80;display:flex;flex-direction:column;gap:12px}
.dock a{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 26px -10px rgba(0,0,0,.5);transition:.35s;position:relative}
.dock a:hover{transform:translateY(-3px) scale(1.05)}
.dock a svg{width:26px;height:26px;fill:#fff}
.dock .wa{background:#25D366}.dock .tg{background:#27A7E7}.dock .mx{background:#7C3AED}
.dock .ph{background:var(--ink)}.dock .ig{background:radial-gradient(circle at 30% 110%,#fdf497,#fd5949 45%,#d6249f 70%,#285AEB 100%)}
.dock a .tip{position:absolute;right:64px;top:50%;transform:translateY(-50%);background:var(--ink);color:#fff;font-size:.72rem;letter-spacing:.06em;padding:6px 12px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:.3s}
.dock a:hover .tip{opacity:1}
.mx b{color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.02em}

/* ===== MOBILE BOOK BAR ===== */
.mobile-book{position:fixed;left:0;right:0;bottom:0;z-index:75;display:none;background:rgba(250,246,238,.97);backdrop-filter:blur(10px);box-shadow:0 -1px 0 var(--line);padding:11px 16px;gap:10px}
.mobile-book a{flex:1}
.mobile-book .btn{width:100%;padding:1em}

/* reveal */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.stagger.in>*{opacity:1;transform:none}
.stagger.in>*:nth-child(2){transition-delay:.08s}
.stagger.in>*:nth-child(3){transition-delay:.16s}
.stagger.in>*:nth-child(4){transition-delay:.24s}
.stagger.in>*:nth-child(5){transition-delay:.32s}
.stagger.in>*:nth-child(6){transition-delay:.4s}

/* mobile menu */
.mnav{position:fixed;inset:0;background:var(--ink);z-index:95;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:24px;transform:translateY(-100%);transition:.5s cubic-bezier(.7,0,.2,1)}
.mnav.open{transform:none}
.mnav a{color:#fff;font-family:var(--display);font-size:2rem;font-weight:500}
.mnav .close{position:absolute;top:24px;right:28px;background:none;border:0;color:#fff;font-size:2.2rem;cursor:pointer}
.mnav .mph{font-family:var(--body);font-size:1rem;color:var(--gold-light);letter-spacing:.05em;margin-top:6px}

@media(max-width:1024px){
  nav.main,.head-phone,.topbar .t-trust{display:none}
  .burger{display:flex}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .rooms-grid,.why-grid,.svc-grid{grid-template-columns:repeat(2,1fr)}
  .about-imgs{aspect-ratio:16/10;max-width:540px}
  .sf{grid-template-columns:1fr 1fr;gap:14px}
  .sf .btn{grid-column:span 2}
}
@media(max-width:680px){
  .wrap{padding:0 20px}
  .head-inner,header.scrolled .head-inner{padding:14px 20px}
  .rooms-grid,.why-grid,.svc-grid,.offers-grid,.rev-grid{grid-template-columns:1fr}
  .trust .wrap{grid-template-columns:1fr 1fr;gap:22px}
  .sf{grid-template-columns:1fr}.sf .btn{grid-column:auto}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .gal a:nth-child(1),.gal a:nth-child(6){grid-column:span 2}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .book-band{margin-top:-120px}
  .hero-inner{padding-bottom:200px}
  .dock{bottom:78px;right:14px}.dock a{width:48px;height:48px}.dock a svg{width:23px;height:23px}
  .mobile-book{display:flex}
  body{padding-bottom:64px}
}

/* modern theme tweaks */
.hero h1 em{font-style:normal;color:var(--gold-light)}
h2.title{letter-spacing:-.6px}
.brand .crown{letter-spacing:.24em;font-weight:600}
.rev p{font-style:normal;font-family:var(--body);font-size:1rem;color:#5a6168}
.eyebrow{font-weight:600}
.why-card h3,.room h3,.offer h3,.tours h2,.svc span{letter-spacing:-.3px}
/* Exely search widget sits seamlessly inside our booking card */
.book-card #block-search{background:transparent !important;border:0 !important;backdrop-filter:none !important;border-radius:0 !important;max-width:none !important;margin:0 !important;width:100%}
.book-card .be-container{padding:0 !important}
#exely-search-form{padding:22px 24px}
/* offers: 3 cards, responsive */
.offers-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
