/* ============================================================
   Отель «История» · Вариант 2 «Кирпич и витраж»
   Global stylesheet — tokens, components, responsive (mobile-first)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg:#F4EDE2; --bg-2:#E7DAC8; --bg-3:#EFE6D6;
  --accent:#9E4A33; --accent-dark:#7C3826;
  --cta:#7E2230; --cta-dark:#651925;
  --dark:#2A211D; --dark-2:#352a24;
  --text:#2B231E; --text-2:#6B5E52; --on-dark:#F4ECDD; --on-dark-dim:rgba(244,236,221,.62);
  --jewel-blue:#2E5E8C; --jewel-green:#4E7A52; --jewel-gold:#C9A24B;

  --font-display:"Prata",Georgia,serif;
  --font-text:"Montserrat",system-ui,-apple-system,sans-serif;
  --font-script:"Marck Script","Segoe Script",cursive;

  --radius-sm:2px; --radius:3px; --radius-lg:4px;
  --shadow-card:0 6px 22px -14px rgba(42,33,29,.45);
  --shadow-pop:0 14px 40px -18px rgba(42,33,29,.55);
  --line:color-mix(in srgb,var(--text) 14%,transparent);
  --line-strong:color-mix(in srgb,var(--text) 30%,transparent);
  --line-dark:rgba(244,236,221,.16);

  --container:1240px;
  --pad:16px;
  --header-h:60px;

  --photo-grade:contrast(1.06) saturate(1.09) sepia(.16) brightness(1.02);
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--font-text); font-size:16px; line-height:1.7;
  font-weight:400; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.no-scroll{overflow:hidden;}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer;}
h1,h2,h3,h4{font-family:var(--font-display); font-weight:400; color:var(--text); margin:0; line-height:1.15;}
p{margin:0 0 1em;}
ul{margin:0; padding:0; list-style:none;}

/* ---------- Layout ---------- */
.container{width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--pad);}
.section{padding:48px 0;}
.section--tight{padding:34px 0;}
.section--dark{background:var(--dark); color:var(--on-dark);}
.section--alt{background:var(--bg-2);}
.section__head{margin-bottom:28px;}
.kicker{display:inline-block; font-size:11px; font-weight:600; text-transform:uppercase;
  letter-spacing:.22em; color:var(--accent);}
.section--dark .kicker{color:var(--jewel-gold);}
.section__title{font-size:clamp(26px,4.4vw,40px); margin-top:10px; letter-spacing:.004em; text-wrap:balance;}
.section__sub{color:var(--text-2); max-width:60ch; margin-top:12px;}
.section--dark .section__sub{color:var(--on-dark-dim);}
.script{font-family:var(--font-script); color:var(--accent); font-size:clamp(28px,5vw,40px); line-height:1;}
.center{text-align:center;}
.center .section__sub{margin-left:auto; margin-right:auto;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-text); font-weight:600; font-size:14px; letter-spacing:.015em;
  border:none; border-radius:var(--radius); padding:14px 22px; min-height:48px;
  background:var(--cta); color:#F7EFE1; transition:background .15s, transform .15s, box-shadow .15s;}
.btn:hover{background:var(--cta-dark);}
.btn:active{transform:translateY(1px);}
.btn svg{flex:none;}
.btn--lg{font-size:15px; padding:16px 28px; min-height:54px;}
.btn--block{width:100%;}
.btn--accent{background:var(--accent);} .btn--accent:hover{background:var(--accent-dark);}
.btn--ghost{background:transparent; color:var(--text); box-shadow:inset 0 0 0 1.5px var(--line-strong);}
.btn--ghost:hover{background:color-mix(in srgb,var(--text) 7%,transparent);}
.btn--ghost-light{background:transparent; color:var(--on-dark); box-shadow:inset 0 0 0 1.5px rgba(244,236,221,.4);}
.btn--ghost-light:hover{background:rgba(244,236,221,.1);}
.btn--sm{font-size:13px; padding:11px 16px; min-height:44px;}

.link-arrow{display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:14px;
  color:var(--accent); letter-spacing:.01em;}
.link-arrow svg{transition:transform .15s;}
.link-arrow:hover svg{transform:translateX(4px);}

/* ---------- Top-bar ---------- */
.topbar{display:none; background:var(--dark); color:var(--on-dark); font-size:13px; font-weight:500;}
.topbar__in{display:flex; align-items:center; justify-content:space-between; height:38px; gap:24px;}
.topbar a{color:var(--on-dark);}
.topbar__item{display:inline-flex; align-items:center; gap:8px; color:var(--on-dark-dim);}
.topbar__item svg{color:var(--jewel-gold);}
.dot-live{width:9px; height:9px; border-radius:50%; background:var(--jewel-green); position:relative;}
.dot-live::after{content:""; position:absolute; inset:-4px; border-radius:50%; border:1px solid var(--jewel-green); animation:pulse 2s infinite;}
@keyframes pulse{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.8);opacity:0}}
.topbar__social{display:inline-flex; align-items:center; gap:14px;}
.topbar__social a{display:inline-flex; opacity:.8; transition:opacity .15s, color .15s;}
.topbar__social a:hover{opacity:1; color:var(--jewel-gold);}

/* ---------- Header ---------- */
.site-header{position:sticky; top:0; z-index:60; background:var(--dark); color:var(--on-dark);}
.header__in{display:flex; align-items:center; justify-content:space-between; height:var(--header-h); gap:16px;}
.header__logo img{height:28px; width:auto;}
.nav{display:none;}
.header__phone{display:none; align-items:center; gap:9px; white-space:nowrap;}
.header__phone .ic{color:var(--accent); display:flex;}
.header__phone b{font-weight:700; font-size:16px; color:#F7F0E2; letter-spacing:.01em;}
.header__phone small{display:block; font-size:10px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--on-dark-dim);}
.header__cta{display:none;}
.burger{display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px;
  background:transparent; border:none; color:var(--on-dark); margin-right:-8px;}
.burger svg{transition:color .15s;}
.burger:active svg{color:var(--accent);}
.header__mphone{display:inline-flex; align-items:center; gap:8px;}
.header__mphone b{font-weight:700; font-size:16px; color:#F7F0E2;}
.header__mphone .ic{color:var(--accent); display:flex;}

/* sticky compact */
.site-header.compact{box-shadow:var(--shadow-card);}
.site-header.compact .header__in{height:54px;}
.site-header.compact .header__logo img{height:40px;}

/* ---------- Promo strip ---------- */
.promo{background:var(--accent); color:var(--dark); position:relative; z-index:55;}
.promo__in{display:flex; align-items:center; justify-content:center; gap:10px; min-height:38px; padding:7px 44px 7px 16px; text-align:center;}
.promo p{margin:0; font-size:13px; font-weight:600; letter-spacing:.01em;}
.promo b{font-weight:800; letter-spacing:.06em;}
.promo__close{position:absolute; right:8px; top:50%; transform:translateY(-50%); width:32px; height:32px;
  background:transparent; border:none; color:var(--dark); display:inline-flex; align-items:center; justify-content:center; opacity:.7;}
.promo__close:hover{opacity:1;}
.promo.hidden{display:none;}
.promo{transition:max-height .28s ease, padding .28s ease, opacity .2s ease; max-height:60px; overflow:hidden;}
.promo.up{max-height:0; padding-top:0; padding-bottom:0; opacity:0;}

/* ---------- Mobile drawer ---------- */
.backdrop{position:fixed; inset:0; background:rgba(20,14,10,.55); z-index:90; opacity:0; visibility:hidden; transition:opacity .25s;}
.backdrop.open{opacity:1; visibility:visible;}
.drawer{position:fixed; top:0; right:0; height:100%; width:min(88%,360px); background:var(--dark); color:var(--on-dark);
  z-index:100; transform:translateX(100%); transition:transform .25s ease; display:flex; flex-direction:column;
  overflow-y:auto; padding:18px 22px 28px;}
.drawer.open{transform:translateX(0);}
.drawer__top{display:flex; align-items:center; justify-content:space-between; padding-bottom:18px; border-bottom:1px solid var(--line-dark);}
.drawer__top img{height:26px;}
.drawer__close{width:44px; height:44px; background:transparent; border:none; color:var(--on-dark); display:inline-flex; align-items:center; justify-content:center; margin-right:-8px;}
.drawer__nav{padding:8px 0;}
.drawer__nav a{display:block; padding:15px 2px; font-weight:600; font-size:18px; color:var(--on-dark); border-bottom:1px solid var(--line-dark);}
.drawer__nav a.active{color:var(--jewel-gold);}
.drawer__nav a:active{color:var(--accent);}
.drawer__book{margin:18px 0 16px;}
.drawer__phone{display:flex; align-items:center; gap:10px; padding:12px 0;}
.drawer__phone .ic{color:var(--accent);}
.drawer__phone b{font-size:21px; font-weight:700; color:#F7F0E2;}
.drawer__social{display:flex; gap:12px; margin:8px 0 18px;}
.drawer__social a{width:44px; height:44px; border-radius:var(--radius); background:rgba(244,236,221,.08); display:inline-flex; align-items:center; justify-content:center; color:var(--on-dark);}
.drawer__social a:hover{background:rgba(244,236,221,.16); color:var(--jewel-gold);}
.drawer__meta{font-size:13px; color:var(--on-dark-dim); display:flex; flex-direction:column; gap:12px; padding-top:14px; border-top:1px solid var(--line-dark);}
.drawer__meta .row{display:flex; align-items:center; gap:10px;}
.drawer__meta svg{color:var(--jewel-gold); flex:none;}
.drawer__promo{margin-top:16px; background:var(--accent); color:var(--dark); border-radius:var(--radius); padding:10px 12px; font-size:12px; font-weight:600; text-align:center;}
.drawer__promo b{font-weight:800; letter-spacing:.06em;}

/* ---------- Bottom bar (mobile) ---------- */
.bottombar{position:fixed; left:0; right:0; bottom:0; z-index:70; background:var(--dark);
  border-top:1px solid var(--line-dark); box-shadow:0 -6px 20px -10px rgba(0,0,0,.5);
  display:flex; gap:10px; padding:10px 12px calc(10px + env(safe-area-inset-bottom));}
.bottombar__call{flex:1; display:inline-flex; align-items:center; justify-content:center; gap:9px;
  background:var(--cta); color:#F7EFE1; border-radius:var(--radius); font-weight:700; font-size:15px; min-height:48px;}
.bottombar__ic{width:48px; min-width:48px; display:inline-flex; align-items:center; justify-content:center;
  border-radius:var(--radius); background:rgba(244,236,221,.1); color:var(--on-dark);}
.bottombar.hidden{transform:translateY(110%);}
.bottombar{transition:transform .25s;}
body.has-bottombar{padding-bottom:74px;}

/* ---------- Footer ---------- */
.footer{background:var(--dark); color:var(--on-dark); padding:48px 0 0;}
.footer__grid{display:grid; grid-template-columns:1fr; gap:32px;}
.footer__logo img{height:36px; margin-bottom:14px;}
.footer__desc{color:var(--on-dark-dim); font-size:14px; max-width:34ch;}
.footer__badge{margin-top:14px; display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:600;
  letter-spacing:.04em; color:var(--jewel-gold);}
.footer h4{font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.16em; color:var(--on-dark);
  font-family:var(--font-text); margin-bottom:14px;}
.footer__col a, .footer__contacts li{color:var(--on-dark-dim); font-size:14px; padding:6px 0; display:flex; gap:10px; align-items:flex-start;}
.footer__col a:hover{color:var(--jewel-gold);}
.footer__contacts svg{color:var(--jewel-gold); flex:none; margin-top:3px;}
.footer__contacts a{padding:0;}
.footer__social{display:flex; gap:10px; margin-top:6px;}
.footer__social a{width:42px; height:42px; border-radius:var(--radius); background:rgba(244,236,221,.08); display:inline-flex; align-items:center; justify-content:center;}
.footer__social a:hover{background:rgba(244,236,221,.16); color:var(--jewel-gold);}
.footer__trust{margin-top:36px; padding:18px 0; border-top:1px solid var(--line-dark); font-size:12px; color:var(--on-dark-dim); letter-spacing:.04em; text-align:center;}
.footer__bottom{padding:16px 0 28px; border-top:1px solid var(--line-dark); display:flex; flex-direction:column; gap:12px; align-items:center; font-size:12px; color:var(--on-dark-dim);}
.footer__bottom a:hover{color:var(--jewel-gold);}
.footer__links{display:flex; flex-wrap:wrap; gap:8px 18px; justify-content:center;}
.to-top{display:inline-flex; align-items:center; gap:8px; color:var(--on-dark-dim);}
.to-top:hover{color:var(--jewel-gold);}

/* ---------- Hero ---------- */
.hero{position:relative; min-height:78vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--dark);}
.hero__bg{position:absolute; inset:0;}
.hero__bg img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade);}
.hero__scrim{position:absolute; inset:0; background:
  linear-gradient(90deg,rgba(20,14,10,.86) 0%,rgba(20,14,10,.55) 48%,rgba(20,14,10,.2) 100%),
  linear-gradient(0deg,rgba(20,14,10,.78),rgba(20,14,10,0) 56%);}
.hero__in{position:relative; padding:44px 0 54px; color:var(--on-dark);}
.hero__kicker{color:var(--jewel-gold); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.24em;}
.hero h1{color:#F9F2E5; font-size:clamp(30px,7vw,58px); line-height:1.08; margin:14px 0 16px; max-width:16ch; text-wrap:balance;}
.hero__sub{color:rgba(249,242,229,.86); font-size:clamp(15px,2.3vw,18px); max-width:42ch; margin-bottom:26px;}
.hero__actions{display:flex; flex-direction:column; gap:12px; align-items:stretch;}
.hero__online{color:rgba(249,242,229,.85); font-size:13px;}
.hero__promo{margin:18px 0 0; font-size:14px; color:rgba(249,242,229,.9); letter-spacing:.01em;}
.hero__promo b{color:var(--jewel-gold); font-weight:700; letter-spacing:.06em;}
.promo-badge{display:inline-flex; align-items:center; gap:8px; background:var(--accent); color:var(--dark);
  border-radius:var(--radius); padding:11px 16px; font-size:13px; font-weight:600;}
.promo-badge b{font-weight:800; letter-spacing:.06em;}

/* mini-hero (interior pages) */
.minihero{position:relative; min-height:300px; display:flex; align-items:flex-end; overflow:hidden; background:var(--dark);}
.minihero__bg{position:absolute; inset:0;}
.minihero__bg img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade);}
.minihero__scrim{position:absolute; inset:0; background:linear-gradient(90deg,rgba(20,14,10,.8),rgba(20,14,10,.3) 80%),linear-gradient(0deg,rgba(20,14,10,.7),transparent 60%);}
.minihero__in{position:relative; padding:32px 0 36px; color:var(--on-dark);}
.minihero h1{color:#F9F2E5; font-size:clamp(26px,5vw,42px); margin:10px 0 0; max-width:20ch; text-wrap:balance;}

/* ---------- Breadcrumbs ---------- */
.crumbs{font-size:12px; color:var(--text-2); padding:14px 0; display:flex; flex-wrap:wrap; gap:8px; align-items:center;}
.crumbs a{color:var(--text-2);} .crumbs a:hover{color:var(--accent);}
.crumbs .sep{opacity:.5;}
.crumbs .cur{color:var(--text);}
.minihero .crumbs, .minihero .crumbs a{color:rgba(249,242,229,.75);}
.minihero .crumbs .cur{color:#fff;}

/* ---------- USP arches ---------- */
.usp{display:grid; grid-template-columns:repeat(2,1fr); gap:14px;}
.usp__item{background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:26px 18px; text-align:center; transition:border-color .2s, box-shadow .2s, transform .2s;}
.usp__item:hover{border-color:var(--accent); box-shadow:var(--shadow-card); transform:translateY(-3px);}
.usp__ic{height:46px; margin:0 auto 14px; display:flex; align-items:center; justify-content:center; color:var(--accent); transition:transform .35s cubic-bezier(.34,1.56,.64,1);}
.usp__item:hover .usp__ic{transform:translateY(-5px) scale(1.12);}
.usp__t{font-family:var(--font-display); font-size:18px; margin-bottom:6px;}
.usp__d{font-size:13px; color:var(--text-2); line-height:1.5;}

/* ---------- Room card ---------- */
.rooms-grid{display:grid; grid-template-columns:1fr; gap:20px;}
.room-card{background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column; box-shadow:var(--shadow-card); transition:transform .2s, box-shadow .2s, border-color .2s;}
.room-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-pop); border-color:var(--line-strong);}
.room-card__arch{position:relative; height:220px; background:var(--dark); overflow:hidden;}
.room-card__arch img{transition:transform .45s ease;}
.room-card:hover .room-card__arch img{transform:scale(1.05);}
.room-card__arch img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade);}
.room-card__badges{position:absolute; top:14px; left:14px; display:flex; gap:7px;}
.badge{display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:700; letter-spacing:.02em; border-radius:var(--radius); padding:5px 9px;}
.badge--star{background:var(--accent); color:#F7EFDD;}
.badge--mansard{background:rgba(42,33,29,.82); color:var(--on-dark);}
.room-card__body{padding:18px 20px 20px; display:flex; flex-direction:column; flex:1;}
.room-card__name{font-family:var(--font-display); font-size:21px; line-height:1.2;}
.room-card__sub{font-size:13px; color:var(--text-2); margin-top:5px;}
.room-tags{display:flex; flex-wrap:wrap; gap:8px; margin:14px 0 18px;}
.room-tags span{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; color:var(--text);
  background:var(--bg); border:1px solid var(--line); border-radius:var(--radius); padding:6px 10px;}
.room-tags svg{color:var(--accent);}
.room-card__foot{margin-top:auto; display:flex; flex-direction:column; gap:10px;}
.room-card__foot .sec{font-size:13px; color:var(--accent); font-weight:600; text-align:center; transition:color .15s;}
.room-card__foot .sec:hover{color:var(--accent-dark); text-decoration:underline;}
/* rooms carousel (home) */
.car-track{display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding-bottom:6px;}
.car-track::-webkit-scrollbar{display:none;}
.car-track > .room-card{flex:0 0 300px; scroll-snap-align:start;}
@media (max-width:600px){ .car-track > .room-card{flex:0 0 85%;} }

/* ---------- Feature/amenity grid ---------- */
.amenities{display:grid; grid-template-columns:repeat(2,1fr); gap:14px;}
.amenity{display:flex; align-items:center; gap:14px; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:16px;}
.amenity__ic{width:42px; height:42px; flex:none; border-radius:var(--radius); background:var(--bg); display:flex; align-items:center; justify-content:center; color:var(--accent); border:1px solid var(--line);}
.amenity__t{font-weight:600; font-size:14px;}
.amenity__d{font-size:12px; color:var(--text-2);}

/* ---------- Split / media + text ---------- */
.split{display:grid; grid-template-columns:1fr; gap:28px; align-items:center;}
.split__media{position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-card); aspect-ratio:4/3; background:var(--dark);}
.split__media img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade);}
.split__media.arch{border-radius:var(--radius);}
.facts{display:flex; flex-wrap:wrap; gap:10px 22px; margin:18px 0;}
.facts li{display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600;}
.facts svg{color:var(--accent);}

/* ---------- Phone CTA block ---------- */
.callblock{text-align:center;}
.callblock__num{font-family:var(--font-display); font-size:clamp(30px,6vw,46px); color:#F9F2E5; letter-spacing:.01em; display:inline-flex; align-items:center; gap:14px;}
.callblock__num .ic{color:var(--jewel-gold);}
.callblock__chans{display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:22px;}
.chan{display:inline-flex; align-items:center; gap:9px; padding:12px 18px; border-radius:var(--radius); font-weight:600; font-size:14px;
  background:rgba(244,236,221,.1); color:var(--on-dark); border:1px solid var(--line-dark);}
.chan:hover{background:rgba(244,236,221,.18);}
.chan svg{color:var(--jewel-gold);}

/* ---------- Location ---------- */
.map-card{position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); aspect-ratio:16/10; background:var(--bg-2);}
.map-card__placeholder{position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; color:var(--text-2); background:
  repeating-linear-gradient(45deg,rgba(110,82,54,.05) 0 14px,transparent 14px 28px), var(--bg-2);}
.distances li{display:flex; align-items:baseline; gap:12px; padding:12px 0; border-bottom:1px solid var(--line); font-size:15px;}
.distances .d{font-family:var(--font-display); color:var(--accent); font-size:18px; min-width:64px;}

/* ---------- CTA banner ---------- */
.cta-banner{position:relative; overflow:hidden; border-radius:var(--radius); background:var(--dark); color:var(--on-dark);}
.cta-banner__bg{position:absolute; inset:0;}
.cta-banner__bg img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade); opacity:.55;}
.cta-banner__scrim{position:absolute; inset:0; background:linear-gradient(90deg,rgba(20,14,10,.85),rgba(20,14,10,.45));}
.cta-banner__in{position:relative; padding:40px 24px; text-align:center;}

/* ---------- Tabs (gallery) ---------- */
.tabs{display:flex; gap:8px; overflow-x:auto; padding-bottom:6px; -webkit-overflow-scrolling:touch; scrollbar-width:none;}
.tabs::-webkit-scrollbar{display:none;}
.tab{white-space:nowrap; padding:9px 16px; border-radius:999px; border:1px solid var(--line-strong); background:transparent;
  font-weight:600; font-size:13px; color:var(--text-2);}
.tab.active{background:var(--accent); color:#F7EFDD; border-color:var(--accent);}

/* ---------- Gallery mosaic ---------- */
.mosaic{columns:2; column-gap:12px;}
.mosaic__item{break-inside:avoid; margin-bottom:12px; border-radius:var(--radius); overflow:hidden; cursor:pointer; background:var(--bg-2); position:relative;}
.mosaic__item img{width:100%; filter:var(--photo-grade); transition:transform .3s;}
.mosaic__item:hover img{transform:scale(1.04);}
.mosaic__item.archive img{filter:grayscale(.62) sepia(.46) contrast(1.05) brightness(1.05);}
.mosaic__cap{position:absolute; left:0; right:0; bottom:0; padding:18px 12px 10px; font-size:12px; font-weight:600; color:#fff;
  background:linear-gradient(0deg,rgba(20,14,10,.8),transparent); opacity:0; transition:opacity .2s;}
.mosaic__item:hover .mosaic__cap{opacity:1;}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed; inset:0; z-index:200; background:rgba(18,12,8,.94); display:none; align-items:center; justify-content:center;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw; max-height:84vh; border-radius:var(--radius); filter:var(--photo-grade);}
.lightbox__close,.lightbox__nav{position:absolute; background:rgba(244,236,221,.12); border:none; color:#fff; width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center;}
.lightbox__close{top:18px; right:18px;}
.lightbox__nav{top:50%; transform:translateY(-50%);}
.lightbox__nav.prev{left:14px;} .lightbox__nav.next{right:14px;}
.lightbox__cap{position:absolute; bottom:22px; left:0; right:0; text-align:center; color:rgba(255,255,255,.85); font-size:13px;}

/* ---------- Accordion / FAQ ---------- */
.acc__item{border:1px solid var(--line); border-radius:var(--radius); background:var(--bg-2); margin-bottom:10px; overflow:hidden;}
.acc__q{width:100%; text-align:left; background:transparent; border:none; padding:18px 20px; display:flex; justify-content:space-between; align-items:center; gap:16px; font-weight:600; font-size:15px; color:var(--text);}
.acc__q svg{flex:none; transition:transform .2s; color:var(--accent);}
.acc__item.open .acc__q svg{transform:rotate(45deg);}
.acc__a{max-height:0; overflow:hidden; transition:max-height .25s ease; }
.acc__a__in{padding:0 20px 18px; color:var(--text-2); font-size:14px; line-height:1.65;}

/* ---------- Doc / download list ---------- */
.docs{display:grid; grid-template-columns:1fr; gap:12px;}
.doc{display:flex; align-items:center; gap:14px; padding:16px; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius);}
.doc__ic{width:40px; height:48px; flex:none; border-radius:var(--radius-sm); background:var(--bg); display:flex; align-items:center; justify-content:center; color:var(--accent); border:1px solid var(--line); font-size:10px; font-weight:700;}
.doc__t{font-weight:600; font-size:14px;}
.doc__m{font-size:12px; color:var(--text-2);}
.doc__dl{margin-left:auto; color:var(--accent);}

/* ---------- Forms ---------- */
.form{display:grid; grid-template-columns:1fr; gap:14px;}
.field label{display:block; font-size:13px; font-weight:600; margin-bottom:6px; color:var(--text);}
.field input,.field select,.field textarea{width:100%; min-height:48px; padding:12px 14px; border:1px solid var(--line-strong);
  border-radius:var(--radius); background:#fff; font-family:inherit; font-size:15px; color:var(--text);}
.field textarea{min-height:96px; resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent);}
.consent{display:flex; gap:10px; align-items:flex-start; font-size:12px; color:var(--text-2);}
.consent input{width:18px; height:18px; margin-top:2px; flex:none;}
.btn[disabled]{opacity:.5; pointer-events:none;}

/* ---------- Widget placeholder (TravelLine) ---------- */
.widget{border:1px dashed var(--line-strong); border-radius:var(--radius); background:var(--bg-3); padding:22px; text-align:center; color:var(--text-2);}
.widget__bar{display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-top:16px;}
.widget__bar .f{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:12px 16px; font-size:13px; min-width:120px; text-align:left;}
.widget__bar .f b{display:block; font-size:11px; color:var(--text-2); font-weight:600;}

/* ---------- Trust strip ---------- */
.trust{display:grid; grid-template-columns:1fr; gap:14px;}
.trust__item{display:flex; gap:12px; align-items:flex-start; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:16px;}
.trust__item svg{color:var(--accent); flex:none; margin-top:2px;}
.trust__item b{font-size:14px;} .trust__item p{margin:3px 0 0; font-size:13px; color:var(--text-2);}

/* ---------- Blog ---------- */
.posts{display:grid; grid-template-columns:1fr; gap:20px;}
.post-card{background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--shadow-card);}
.post-card__img{aspect-ratio:16/10; overflow:hidden; background:var(--dark);}
.post-card__img img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade);}
.post-card__body{padding:18px 18px 20px; display:flex; flex-direction:column; flex:1;}
.post-cat{align-self:flex-start; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--accent); margin-bottom:10px;}
.post-card__t{font-family:var(--font-display); font-size:20px; line-height:1.25; margin-bottom:8px;}
.post-card__ex{font-size:14px; color:var(--text-2); margin-bottom:14px;}
.post-card__meta{margin-top:auto; font-size:12px; color:var(--text-2); display:flex; gap:14px;}
.post-card{transition:transform .2s, box-shadow .2s, border-color .2s;}
.post-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-pop); border-color:var(--line-strong);}
.post-card__img img{transition:transform .45s ease;}
.post-card:hover .post-card__img img{transform:scale(1.05);}
.post-card__t{transition:color .15s;}
.post-card:hover .post-card__t{color:var(--accent);}

/* article */
.article{max-width:740px; margin:0 auto;}
.article__cover{border-radius:var(--radius); overflow:hidden; margin:18px 0 24px; background:var(--dark); aspect-ratio:16/9;}
.article__cover img{width:100%; height:100%; object-fit:cover; filter:var(--photo-grade);}
.article__meta{display:flex; flex-wrap:wrap; gap:14px; font-size:13px; color:var(--text-2); margin-bottom:6px;}
.prose{font-size:16px; line-height:1.8; color:var(--text);}
.prose h2{font-size:26px; margin:32px 0 12px;}
.prose h3{font-size:20px; margin:24px 0 10px;}
.prose p{margin:0 0 1.1em;}
.prose ul{margin:0 0 1.2em; padding-left:0;}
.prose ul li{position:relative; padding-left:26px; margin-bottom:8px;}
.prose ul li::before{content:""; position:absolute; left:6px; top:11px; width:7px; height:7px; background:var(--accent); border-radius:1px; transform:rotate(45deg);}
.prose blockquote{margin:24px 0; padding:16px 22px; border-left:3px solid var(--accent); background:var(--bg-2); border-radius:0 var(--radius) var(--radius) 0; font-family:var(--font-display); font-size:19px; line-height:1.5;}
.toc{background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:18px 20px; margin:0 0 26px;}
.toc h4{font-family:var(--font-text); font-size:12px; text-transform:uppercase; letter-spacing:.16em; color:var(--text-2); margin-bottom:10px;}
.toc a{display:block; padding:6px 0; color:var(--accent); font-size:14px; font-weight:500;}
.article-cta{margin:30px 0; background:var(--dark); color:var(--on-dark); border-radius:var(--radius); padding:26px 22px; text-align:center;}
.article-cta h3{color:#F9F2E5; font-size:24px; margin-bottom:8px;}
.article-cta p{color:var(--on-dark-dim); margin-bottom:18px;}

/* ---------- Requisites table ---------- */
.req-table{width:100%; border-collapse:collapse; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;}
.req-table th,.req-table td{text-align:left; padding:13px 16px; font-size:14px; border-bottom:1px solid var(--line); vertical-align:top;}
.req-table th{width:42%; color:var(--text-2); font-weight:600;}
.req-table td{font-weight:600; word-break:break-word;}
.req-table tr:last-child th,.req-table tr:last-child td{border-bottom:none;}

/* ---------- Timeline ---------- */
.timeline{position:relative; display:flex; flex-direction:column; gap:24px;}
.tl-item{display:grid; grid-template-columns:1fr; gap:14px; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;}
.tl-item__media{aspect-ratio:16/10; background:var(--dark); overflow:hidden;}
.tl-item__media img{width:100%; height:100%; object-fit:cover;}
.tl-item.archive .tl-item__media img{filter:grayscale(.62) sepia(.46) contrast(1.05) brightness(1.05);}
.tl-item.now .tl-item__media img{filter:var(--photo-grade);}
.tl-item__body{padding:18px 20px 20px;}
.tl-year{font-family:var(--font-display); color:var(--accent); font-size:30px; line-height:1;}

/* ---------- Certificates ---------- */
.certs{display:grid; grid-template-columns:repeat(2,1fr); gap:14px;}
.cert{aspect-ratio:3/4; border:1px solid var(--line); border-radius:var(--radius); background:var(--bg-2); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; color:var(--text-2); padding:16px; text-align:center; cursor:pointer;}
.cert svg{color:var(--accent);}
.cert span{font-size:12px; font-weight:600;}

/* ---------- 404 ---------- */
.err{min-height:70vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:18px; padding:40px 0;}
.err__code{font-family:var(--font-display); font-size:clamp(80px,20vw,160px); color:var(--accent); line-height:.9;}

/* ---------- Filters ---------- */
.filters{display:none; gap:10px; flex-wrap:wrap; margin-bottom:8px;}
.filters select{min-height:44px; padding:8px 14px; border:1px solid var(--line-strong); border-radius:var(--radius); background:#fff; font-family:inherit; font-size:14px; font-weight:600; color:var(--text);}
.filters__open{display:inline-flex; align-items:center; gap:8px; margin-bottom:18px; }
.filter-sheet{position:fixed; left:0; right:0; bottom:0; z-index:80; background:var(--bg); border-radius:14px 14px 0 0; box-shadow:var(--shadow-pop); transform:translateY(110%); transition:transform .25s; padding:22px 18px calc(28px + env(safe-area-inset-bottom));}
.filter-sheet.open{transform:translateY(0);}
.filter-sheet h4{font-family:var(--font-text); font-size:16px; margin-bottom:16px;}
.filter-sheet .field{margin-bottom:14px;}

/* ---------- Helpers ---------- */
.grid-2{display:grid; grid-template-columns:1fr; gap:20px;}
.divider-script{text-align:center; margin:8px 0 22px;}
.muted{color:var(--text-2);}
.stack-sm > * + *{margin-top:10px;}
.hide-mobile{display:none;}
.tag-pill{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; background:var(--bg-2); border:1px solid var(--line); border-radius:999px; padding:6px 12px; color:var(--text);}
.tag-pill svg{color:var(--accent);}

/* ---------- Hover states (all clickable) ---------- */
.tab{transition:color .15s, border-color .15s, background .15s;}
.tab:not(.active):hover{color:var(--text); border-color:var(--accent);}
.doc{transition:border-color .15s, box-shadow .15s, transform .15s;}
.doc:hover{border-color:var(--line-strong); box-shadow:var(--shadow-card); transform:translateY(-2px);}
.doc:hover .doc__dl{transform:translateX(3px);}
.doc__dl{transition:transform .15s;}
.cert{transition:border-color .15s, box-shadow .15s, color .15s, transform .15s;}
.cert:hover{border-color:var(--accent); color:var(--text); box-shadow:var(--shadow-card); transform:translateY(-2px);}
.header__phone{transition:opacity .15s;}
.header__phone:hover b{color:#fff;}
.header__logo{transition:opacity .15s;}
.header__logo:hover{opacity:.85;}
.bottombar__call,.bottombar__ic{transition:background .15s;}
.bottombar__call:active{transform:translateY(1px);}
.bottombar__ic:hover{background:rgba(244,236,221,.2);}
.amenity{transition:border-color .15s, transform .15s;}
.distances li{transition:color .15s;}
.req-table tr{transition:background .15s;}
.tag-pill,.room-tags span{transition:border-color .15s;}
.mosaic__item{transition:box-shadow .2s;}
.mosaic__item:hover{box-shadow:var(--shadow-pop);}
.minihero h1, .hero h1{will-change:auto;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:480px){
  .usp{grid-template-columns:repeat(2,1fr);}
}
@media (min-width:768px){
  :root{--pad:24px;}
  .section{padding:64px 0;}
  .usp{grid-template-columns:repeat(4,1fr);}
  .amenities{grid-template-columns:repeat(3,1fr);}
  .rooms-grid{grid-template-columns:repeat(2,1fr);}
  .posts{grid-template-columns:repeat(2,1fr);}
  .footer__grid{grid-template-columns:2fr 1fr 1.4fr;}
  .footer__social{margin-top:14px;}
  .trust{grid-template-columns:repeat(3,1fr);}
  .docs{grid-template-columns:repeat(2,1fr);}
  .grid-2{grid-template-columns:1fr 1fr;}
  .split{grid-template-columns:1fr 1fr; gap:40px;}
  .tl-item{grid-template-columns:1fr 1fr; align-items:stretch;}
  .tl-item__media{aspect-ratio:auto;}
  .certs{grid-template-columns:repeat(4,1fr);}
  .mosaic{columns:3;}
  .hero__actions{flex-direction:row; align-items:center; flex-wrap:wrap;}
  .hide-mobile{display:revert;}
}
@media (min-width:1024px){
  :root{--header-h:74px;}
  .topbar{display:block;}
  .burger,.header__mphone{display:none;}
  .header__logo img{height:50px;}
  .nav{display:flex; gap:30px;}
  .nav a{position:relative; font-weight:600; font-size:14px; color:var(--on-dark); padding:6px 0; letter-spacing:.01em;}
  .nav a::after{content:""; position:absolute; left:50%; right:50%; bottom:0; height:2px; background:var(--accent); transition:left .15s,right .15s;}
  .nav a:hover::after,.nav a.active::after{left:0; right:0;}
  .nav a.active{color:#fff;}
  .header__phone{display:inline-flex;}
  .header__cta{display:inline-flex;}
  .header__right{display:flex; align-items:center; gap:22px;}
  .bottombar{display:none;}
  body.has-bottombar{padding-bottom:0;}
  .rooms-grid{grid-template-columns:repeat(3,1fr);}
  .posts{grid-template-columns:repeat(3,1fr);}
  .hero{min-height:84vh;}
  .minihero{min-height:340px;}
  .filters{display:flex;}
  .filters__open{display:none;}
}
@media (min-width:1240px){
  .container{padding:0 20px;}
}

/* ============================================================
   UX-ПРАВКИ (общий аудит юзабилити)
   ============================================================ */

/* Якоря не прячутся под липкой шапкой */
html{scroll-padding-top:calc(var(--header-h) + 12px);}

/* Плавающая кнопка «Наверх» — появляется при скролле, не в подвале */
.to-top-float{
  position:fixed; right:16px; bottom:calc(86px + env(safe-area-inset-bottom));
  width:48px; height:48px; border-radius:50%; border:none; z-index:75;
  background:var(--dark); color:var(--on-dark); box-shadow:var(--shadow-pop);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(12px) scale(.9); pointer-events:none;
  transition:opacity .2s, transform .2s, background .15s;
}
.to-top-float.show{opacity:1; transform:none; pointer-events:auto;}
.to-top-float:hover{background:var(--accent);}
.to-top-float:active{transform:translateY(1px);}
@media (min-width:1024px){
  .to-top-float{right:24px; bottom:24px;}   /* на десктопе нет нижнего бара */
}

/* Доступность: видимый фокус для клавиатуры */
:where(a,button,input,select,textarea,[tabindex]):focus-visible{
  outline:2px solid var(--accent); outline-offset:2px; border-radius:var(--radius-sm);
}
.section--dark :focus-visible, .site-header :focus-visible, .drawer :focus-visible, .bottombar :focus-visible{
  outline-color:var(--jewel-gold);
}

/* Чуть больше «воздуха» между ключевыми CTA в hero */
.hero__actions{gap:14px;}
.hero__promo{margin-top:20px;}

/* Уважение к prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important;
  }
  .usp__item:hover,.room-card:hover,.post-card:hover,.doc:hover,.cert:hover{transform:none;}
}
