/* ============================================================
   КАРАОКЕ МЕНДЕЛЕЕВСКАЯ · Барвиха Group
   Дизайн-система: тёмный какао + золото + кремовый текст
   Источник: barvikha-group-production.up.railway.app
   ============================================================ */

/* ---------- ПЕРЕМЕННЫЕ ---------- */
:root {
  /* Фоны */
  --bg:        #2A1B11;
  --bg-1:      #33221A;
  --bg-2:      #3B2A20;
  --bg-3:      #453324;

  /* Золото */
  --gold:        #C49262;
  --gold-soft:   #A07642;
  --gold-deep:   #6F4827;
  --gold-glow:   rgba(196,146,98,.35);

  /* Текст */
  --text:       #F4E9D5;
  --text-soft:  rgba(244,233,213,.62);
  --text-mute:  rgba(244,233,213,.38);

  /* Линии */
  --line:        rgba(196,146,98,.14);
  --line-strong: rgba(196,146,98,.32);
  --hair:        rgba(255,255,255,.06);

  /* Типографика */
  --font-display: "Tenor Sans", "Times New Roman", serif;
  --font-text:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-accent:  "Cormorant Garamond", "Times New Roman", serif;

  /* Анимации */
  --ease:      cubic-bezier(.22, .61, .36, 1);
  --ease-soft: cubic-bezier(.4, 0, .2, 1);

  /* Ритм */
  --container: 1280px;
  --gutter:    clamp(1.2rem, 3vw, 2.4rem);
}

/* ---------- БАЗА ---------- */
*, *::before, *::after { box-sizing: border-box; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  overscroll-behavior-y: none;
  /* Аппаратное ускорение скролла на iOS */
  -webkit-overflow-scrolling: touch;
}

/* Убираем нативную синюю подсветку при тапе на iOS/Android и
   ускоряем отклик кликов (нет 300ms-задержки) */
a, button, [role="button"], [tabindex]:not([tabindex="-1"]),
input[type="button"], input[type="submit"], label, summary {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* iOS zoom-fix: input/select с font-size < 16px вызывают auto-zoom при focus */
input, select, textarea { font-size: max(16px, 1rem); }

body {
  margin: 0;
  /* Глубокий многоуровневый «парчовый» градиент: почти-чёрные края, тёплый медный пик */
  background: linear-gradient(125deg,
    #1B110A 0%,
    #2A1B11 14%,
    #3B2A20 30%,
    #533720 45%,
    #6F4827 55%,
    #533720 65%,
    #3B2A20 80%,
    #2A1B11 92%,
    #1B110A 100%);
  background-size: 320% 320%;
  animation: brocade 32s ease-in-out infinite;
  color: var(--text);
  font-family: var(--font-text);
  font-weight: 400;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  position: relative;
  isolation: isolate;            /* стек-контекст: пятна и зерно уходят под контент, но остаются над фоном */
}

/* Парча — три золотых облака, плывут с разными ритмами */
body::before {
  content: "";
  position: fixed;
  inset: -15%;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(42vmin 42vmin at 18% 22%, rgba(196,146,98,.36), transparent 62%),
    radial-gradient(50vmin 50vmin at 78% 30%, rgba(241,217,176,.22), transparent 65%),
    radial-gradient(55vmin 55vmin at 48% 88%, rgba(160,118,66,.30), transparent 62%);
  filter: blur(40px);
  animation: brocade-drift 36s ease-in-out infinite;
}

/* Плёночное зерно — даёт градиенту фактуру, убирает «плоскость» */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .06;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.77  0 0 0 0 0.57  0 0 0 0 0.38  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
}

@keyframes brocade {
  0%   { background-position: 0% 50%; }
  25%  { background-position: 50% 0%; }
  50%  { background-position: 100% 50%; }
  75%  { background-position: 50% 100%; }
  100% { background-position: 0% 50%; }
}
@keyframes brocade-drift {
  0%, 100% { transform: translate(0, 0)        scale(1)    rotate(0deg); }
  33%      { transform: translate(3vw, -2vh)   scale(1.08) rotate(2deg); }
  66%      { transform: translate(-2vw, 3vh)   scale(.95)  rotate(-1.5deg); }
}

img, video { max-width: 100%; height: auto; display: block; }
button { font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }

::selection { background: var(--gold); color: #0a0a0a; }

/* ---------- ТИПОГРАФИКА ---------- */
.h-display {
  font-family: var(--font-display);
  font-size: clamp(3.6rem, 11vw, 9rem);
  font-weight: 700;
  letter-spacing: .04em;
  line-height: .92;
  margin: 0;
}

.h-1 {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 400;
  letter-spacing: .03em;
  line-height: 1.1;
  margin: 0;
  text-wrap: balance;
}

.h-2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.4vw, 2.6rem);
  font-weight: 400;
  letter-spacing: .04em;
  line-height: 1.15;
  margin: 0;
  text-wrap: balance;
}

.lead {
  font-size: 1.02rem;
  line-height: 1.7;
  color: var(--text-soft);
  margin: 0;
  text-wrap: pretty;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .9rem;
  font-family: var(--font-text);
  font-size: .7rem;
  font-weight: 500;
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0;
}

.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--gold);
}

.accent-italic {
  font-family: var(--font-accent);
  font-style: italic;
  font-weight: 400;
  color: var(--gold);
}

/* ---------- РАЗМЕТКА ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.section {
  padding: clamp(4rem, 9vw, 8rem) 0;
  position: relative;
}

.section--dark   { background: var(--bg); }
.section--card   { background: var(--bg-1); }

.hair {
  height: 1px;
  background: linear-gradient(to right, transparent, var(--line-strong), transparent);
  border: 0;
  margin: 0;
}

/* ---------- КНОПКИ ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  font-family: var(--font-display);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  padding: 1.05rem 2.1rem;
  border: 1px solid transparent;
  border-radius: 0;
  cursor: pointer;
  transition: all 350ms var(--ease);
  white-space: nowrap;
}

.btn-primary {
  background: var(--gold);
  color: #0a0a0a;
}
.btn-primary:hover {
  background: #E5C490;
  box-shadow: 0 18px 40px -16px var(--gold-glow);
  transform: translateY(-1px);
}

.btn-ghost {
  background: transparent;
  color: var(--text);
  border-color: rgba(255,255,255,.18);
}
.btn-ghost:hover {
  border-color: var(--gold);
  color: var(--gold);
}

.btn-line {
  background: transparent;
  color: var(--gold);
  border-color: var(--line-strong);
}
.btn-line:hover {
  background: var(--gold);
  color: #0a0a0a;
}

/* ---------- НАВИГАЦИЯ ---------- */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  padding: 1.4rem 0;
  transition: background 300ms var(--ease), padding 300ms var(--ease);
}
.nav.is-scrolled {
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  padding: .9rem 0;
}

.nav__row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 2rem;
}
.nav__menu { justify-self: center; }
.nav__cta { justify-self: end; }

.nav__logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
  min-width: 0;
  /* Жёстко ограничиваем ширину колонки логотипа, чтобы он
     гарантированно не залезал на меню при любом разрешении. */
  max-width: clamp(110px, 16vw, 180px);
}
.nav__logo-img {
  height: clamp(20px, 2.2vw, 26px);
  width: auto;
  max-width: 100%;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 1px 4px rgba(0,0,0,.4));
}
.nav.is-scrolled .nav__logo-img {
  height: clamp(18px, 2vw, 22px);
}

.nav__menu {
  display: flex;
  align-items: center;
  gap: 2.2rem;
}
.nav__link {
  position: relative;
  font-family: var(--font-display);
  font-size: .7rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text-soft);
  padding: .4rem 0;
  transition: color 250ms var(--ease);
}
.nav__link::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 1px;
  background: var(--gold);
  transition: width 300ms var(--ease), left 300ms var(--ease);
}
.nav__link:hover { color: var(--gold); }
.nav__link:hover::after { width: 100%; left: 0; }

.nav__link--accent {
  color: var(--gold);
}
.nav__link--accent::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: .55rem;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 10px var(--gold-glow);
  transform: translateY(-1px);
  animation: promoPulse 2.4s var(--ease-soft) infinite;
}
@keyframes promoPulse {
  0%, 100% { opacity: .55; transform: translateY(-1px) scale(.92); }
  50%      { opacity: 1;   transform: translateY(-1px) scale(1.05); }
}


.nav__burger {
  display: none;
  width: 36px;
  height: 36px;
  position: relative;
}
.nav__burger span {
  position: absolute;
  left: 6px;
  right: 6px;
  height: 1px;
  background: var(--text);
  transition: transform 300ms var(--ease), top 300ms var(--ease), opacity 200ms var(--ease);
}
.nav__burger span:nth-child(1) { top: 12px; }
.nav__burger span:nth-child(2) { top: 18px; }
.nav__burger span:nth-child(3) { top: 24px; }
.nav__burger.is-open span:nth-child(1) { top: 18px; transform: rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { top: 18px; transform: rotate(-45deg); }

@media (max-width: 1023px) {
  .nav__row {
    display: flex;
    justify-content: space-between;
  }
  .nav__menu {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    max-width: 100vw;
    height: 100vh;
    height: 100svh;
    flex-direction: column;
    justify-content: center;
    gap: 2.6rem;
    background: rgba(0,0,0,.96);
    -webkit-backdrop-filter: blur(24px);
    backdrop-filter: blur(24px);
    transform: translate3d(100%, 0, 0);
    transition: transform 400ms var(--ease), visibility 0s linear 400ms;
    visibility: hidden;
    z-index: 55;
    padding: 5rem 1.5rem 2rem;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    will-change: transform;
  }
  .nav__menu.is-open {
    transform: translate3d(0, 0, 0);
    visibility: visible;
    transition: transform 400ms var(--ease), visibility 0s linear 0s;
  }
  .nav__link { font-size: 1rem; }
  .nav__cta { display: none; }
  .nav__burger { display: block; z-index: 60; position: relative; }
}

/* ---------- HERO ---------- */
.hero {
  position: relative;
  min-height: 100vh;            /* fallback для старых браузеров */
  min-height: 100svh;           /* small viewport — учёт address bar в Safari */
  display: flex;
  align-items: center;
  padding: 8rem 0 5rem;
  overflow: hidden;
}



/* Бегущая строка с поводами — внизу hero */
.hero__marquee {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 2;
  padding: 1.1rem 0;
  background: linear-gradient(to right, rgba(0,0,0,.5), rgba(0,0,0,.3), rgba(0,0,0,.5));
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  white-space: nowrap;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.hero__marquee-track {
  display: inline-flex;
  gap: 3rem;
  padding-left: 3rem;
  animation: marquee 38s linear infinite;
}
.hero__marquee-track span {
  font-family: var(--font-display);
  font-size: .82rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--text-soft);
  display: inline-flex;
  align-items: center;
  gap: 3rem;
}
.hero__marquee-track span::after {
  content: "✦";
  color: var(--gold);
  font-size: .9rem;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__bg video,
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
/* Постер виден моментально, видео накладывается сверху по готовности */
.hero__poster {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__bg video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  z-index: 1;
  opacity: 0;
  transform: translateZ(0); /* GPU-слой */
  backface-visibility: hidden;
  transition: opacity 800ms ease;
}
.hero__bg video[src] {
  opacity: 1;
}
/* Маска правого верхнего угла — перекрывает BARVIKHA TV */
.hero__bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(ellipse 50% 30% at 100% 0%, rgba(0,0,0,1) 0%, rgba(0,0,0,.95) 30%, rgba(0,0,0,.6) 55%, transparent 75%),
    linear-gradient(to bottom, rgba(0,0,0,.55) 0%, transparent 22%);
  pointer-events: none;
}
.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background:
    /* МАСКА ЦЕНТРА — скрывает лого "Барвиха Lounge" из видео */
    radial-gradient(ellipse 60% 50% at 50% 38%, rgba(0,0,0,.92) 0%, rgba(0,0,0,.78) 35%, rgba(0,0,0,.45) 65%, transparent 100%),
    /* зона текста — плотное затемнение для читаемости */
    radial-gradient(ellipse 90% 75% at 50% 55%, rgba(0,0,0,.65) 0%, rgba(0,0,0,.5) 55%, rgba(0,0,0,.2) 100%),
    /* виньетка по краям → переливается в фон страницы */
    radial-gradient(ellipse 110% 105% at 50% 50%, transparent 18%, rgba(42,27,17,.5) 55%, rgba(27,17,10,.85) 80%, var(--bg) 100%),
    /* мягкий верх — нав не врезается */
    linear-gradient(to bottom, var(--bg) 0%, rgba(27,17,10,.88) 8%, rgba(0,0,0,.55) 22%, rgba(0,0,0,.25) 35%),
    /* плавный низ → бесшовно в следующую секцию */
    linear-gradient(to bottom, transparent 45%, rgba(42,27,17,.6) 72%, rgba(27,17,10,.92) 90%, var(--bg) 100%),
    /* общий dim — гасит яркие блики */
    rgba(0,0,0,.45);
}
/* Дополнительный мягкий "затухающий" блок над следующей секцией —
   делает переход от hero к section--dark абсолютно бесшовным */
.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 180px;
  background: linear-gradient(to bottom,
    transparent 0%,
    rgba(27,17,10,.5) 40%,
    rgba(27,17,10,.92) 75%,
    var(--bg) 100%);
  pointer-events: none;
  z-index: 0;
}

.hero__inner {
  position: relative;
  z-index: 1;
  max-width: 920px;
}

.hero__mark {
  display: block;
  width: clamp(72px, 9vw, 108px);
  height: auto;
  margin: 0 0 1.4rem;
  opacity: .92;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.5));
}
@media (max-width: 600px) {
  .hero__mark { width: clamp(58px, 16vw, 86px); margin-bottom: 1rem; }
}

.hero__title {
  margin-top: 1.6rem;
}
.hero__title .accent-italic {
  display: block;
  font-size: .55em;
  margin-top: .3em;
}

.hero__lead {
  margin: 2rem 0 2.4rem;
  max-width: 540px;
  color: var(--text-soft);
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.hero__scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-size: .65rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--text-mute);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .8rem;
}
.hero__scroll::after {
  content: "";
  width: 1px;
  height: 36px;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scroll-pulse 2.4s var(--ease) infinite;
}
@keyframes scroll-pulse {
  0%   { opacity: 0; transform: scaleY(.3); transform-origin: top; }
  50%  { opacity: 1; transform: scaleY(1);  transform-origin: top; }
  100% { opacity: 0; transform: scaleY(1);  transform-origin: bottom; }
}

/* ---------- ПОЧЕМУ МЫ ---------- */
.features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
}
#hookahs .features {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 768px) {
  #hookahs .features { grid-template-columns: 1fr; }
}
.feature {
  position: relative;
  padding: 2.4rem 2rem 2.2rem;
  border: 1px solid var(--line);
  border-radius: 4px;
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(196,146,98,.08) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, rgba(255,255,255,.012) 0%, rgba(0,0,0,.06) 100%);
  display: flex;
  flex-direction: column;
  gap: .65rem;
  overflow: hidden;
  transition:
    border-color .45s var(--ease),
    transform .45s var(--ease),
    box-shadow .45s var(--ease),
    background .45s var(--ease);
}
.feature::after {
  content: "";
  position: absolute;
  left: 2rem;
  right: 2rem;
  bottom: 1.3rem;
  height: 1px;
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold-soft) 60%, transparent 100%);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .55s var(--ease);
  opacity: .8;
  pointer-events: none;
}
.feature:hover {
  border-color: var(--line-strong);
  transform: translateY(-3px);
  box-shadow: 0 18px 40px -22px rgba(0,0,0,.55), 0 0 0 1px rgba(196,146,98,.05);
}
.feature:hover::after { transform: scaleX(1); }

.feature__icon {
  width: 44px;
  height: 44px;
  color: var(--gold);
  margin-bottom: .6rem;
  opacity: .92;
  transition: transform .55s var(--ease), opacity .45s var(--ease);
}
.feature__icon svg { width: 100%; height: 100%; display: block; }
.feature:hover .feature__icon { transform: translateY(-2px); opacity: 1; }

/* ---------- Дискошар: оболочка статична, "вращение" задаётся меридианами + бликом ---------- */
.feature__icon--disco svg { overflow: visible; }

.feature__icon--disco .dm {
  transform-origin: 50% 50%;
  transform-box: fill-box;
}
/* Статика по умолчанию — три меридиана разной ширины формируют 3D-видимость шара */
.feature__icon--disco .dm-1 { transform: scaleX(.25); }
.feature__icon--disco .dm-2 { transform: scaleX(.65); }
.feature__icon--disco .dm-3 { transform: scaleX(0);   }

.feature__icon--disco .disco-highlight {
  fill: currentColor;
  opacity: .4;
}
.feature__icon--disco .disco-ray {
  opacity: .35;
  transition: opacity 350ms var(--ease);
}

/* hover — каждый меридиан проходит цикл scaleX(0→1→0), фазово смещён */
.feature:hover .feature__icon--disco .dm-1,
.feature:focus-visible .feature__icon--disco .dm-1 {
  animation: disco-meridian 2.4s linear infinite;
}
.feature:hover .feature__icon--disco .dm-2,
.feature:focus-visible .feature__icon--disco .dm-2 {
  animation: disco-meridian 2.4s linear infinite -.8s;
}
.feature:hover .feature__icon--disco .dm-3,
.feature:focus-visible .feature__icon--disco .dm-3 {
  animation: disco-meridian 2.4s linear infinite -1.6s;
}
.feature:hover .feature__icon--disco .disco-highlight,
.feature:focus-visible .feature__icon--disco .disco-highlight {
  animation: disco-highlight 2.4s linear infinite;
}
.feature:hover .feature__icon--disco .disco-ray,
.feature:focus-visible .feature__icon--disco .disco-ray {
  opacity: .8;
  animation: disco-flicker 1.2s steps(2, end) infinite;
}

@keyframes disco-meridian {
  0%   { transform: scaleX(0); }
  50%  { transform: scaleX(1); }
  100% { transform: scaleX(0); }
}
@keyframes disco-highlight {
  0%, 100% { transform: translateX(-4px); opacity: 0; }
  25%      { transform: translateX(0);     opacity: .55; }
  50%      { transform: translateX(4px);   opacity: 0; }
  75%      { transform: translateX(0);     opacity: .55; }
}
@keyframes disco-flicker {
  0%, 100% { opacity: .8; }
  50%      { opacity: .35; }
}
@media (prefers-reduced-motion: reduce) {
  .feature:hover .feature__icon--disco .dm,
  .feature:hover .feature__icon--disco .disco-highlight,
  .feature:hover .feature__icon--disco .disco-ray { animation: none; }
}

/* ---------- Винил / каталог песен — крутится как пластинка ---------- */
.feature__icon--vinyl .vinyl-disc {
  transform-origin: 50% 50%;
  transform-box: fill-box;
  transition: transform 600ms var(--ease);
}
.feature:hover .feature__icon--vinyl .vinyl-disc,
.feature:focus-visible .feature__icon--vinyl .vinyl-disc {
  animation: vinyl-spin 3s linear infinite;
}
@keyframes vinyl-spin {
  to { transform: rotate(360deg); }
}

/* ---------- Микрофоны — покачиваются по очереди ---------- */
.feature__icon--mic .mic-1,
.feature__icon--mic .mic-2,
.feature__icon--mic .mic-3 {
  transform-origin: 50% 100%;
  transform-box: fill-box;
}
.feature:hover .feature__icon--mic .mic-1 { animation: mic-sway 1.6s ease-in-out infinite; }
.feature:hover .feature__icon--mic .mic-2 { animation: mic-sway 1.6s ease-in-out infinite -.2s; }
.feature:hover .feature__icon--mic .mic-3 { animation: mic-sway 1.6s ease-in-out infinite -.4s; }
@keyframes mic-sway {
  0%, 100% { transform: rotate(-6deg); }
  50%      { transform: rotate(6deg); }
}

/* ---------- Эквалайзер — ручки ездят по слайдерам ---------- */
.feature:hover .feature__icon--eq .eq-knob--1 { animation: eq-slide-1 2s ease-in-out infinite; }
.feature:hover .feature__icon--eq .eq-knob--2 { animation: eq-slide-2 2.4s ease-in-out infinite; }
.feature:hover .feature__icon--eq .eq-knob--3 { animation: eq-slide-3 1.8s ease-in-out infinite; }
@keyframes eq-slide-1 {
  0%, 100% { transform: translateX(-4px); }
  50%      { transform: translateX(8px); }
}
@keyframes eq-slide-2 {
  0%, 100% { transform: translateX(2px); }
  50%      { transform: translateX(-10px); }
}
@keyframes eq-slide-3 {
  0%, 100% { transform: translateX(-3px); }
  50%      { transform: translateX(6px); }
}

/* ---------- Большой экран — пульс play + лёгкое мерцание рамки ---------- */
.feature__icon--screen .screen-play {
  transform-origin: 50% 50%;
  transform-box: fill-box;
}
.feature:hover .feature__icon--screen .screen-play {
  animation: screen-pulse 1.4s ease-in-out infinite;
}
.feature:hover .feature__icon--screen .screen-frame {
  animation: screen-glow 1.8s ease-in-out infinite;
}
@keyframes screen-pulse {
  0%, 100% { transform: scale(1);    opacity: 1; }
  50%      { transform: scale(1.18); opacity: .55; }
}
@keyframes screen-glow {
  0%, 100% { stroke-opacity: 1; }
  50%      { stroke-opacity: .5; }
}

/* ---------- Сцена / столы — лампочки загораются по очереди ---------- */
.feature:hover .feature__icon--stage .stage-table--1 { animation: stage-blink 2s ease-in-out infinite 0s; }
.feature:hover .feature__icon--stage .stage-table--2 { animation: stage-blink 2s ease-in-out infinite .15s; }
.feature:hover .feature__icon--stage .stage-table--3 { animation: stage-blink 2s ease-in-out infinite .3s; }
.feature:hover .feature__icon--stage .stage-table--4 { animation: stage-blink 2s ease-in-out infinite .45s; }
.feature:hover .feature__icon--stage .stage-table--5 { animation: stage-blink 2s ease-in-out infinite .6s; }
.feature:hover .feature__icon--stage .stage-table--6 { animation: stage-blink 2s ease-in-out infinite .75s; }
@keyframes stage-blink {
  0%, 100% { stroke-opacity: .35; }
  20%      { stroke-opacity: 1; }
  40%      { stroke-opacity: .35; }
}

/* ---------- Кальян классика — дымок поднимается ---------- */
.feature__icon--hookah .hookah-smoke {
  transform-origin: 24px 18px;
  transform-box: view-box;
}
.feature:hover .feature__icon--hookah .hookah-smoke {
  animation: hookah-smoke 2.2s ease-in-out infinite;
}
@keyframes hookah-smoke {
  0%   { transform: translateY(2px);  opacity: 0; }
  30%  { opacity: 1; }
  100% { transform: translateY(-6px); opacity: 0; }
}

/* ---------- Кальян на фрукте — фрукт "дышит", листик качается ---------- */
.feature__icon--fruit .fruit-body {
  transform-origin: 50% 65%;
  transform-box: fill-box;
}
.feature__icon--fruit .fruit-leaf {
  transform-origin: 24px 14px;
  transform-box: view-box;
}
.feature:hover .feature__icon--fruit .fruit-body {
  animation: fruit-breath 2.4s ease-in-out infinite;
}
.feature:hover .feature__icon--fruit .fruit-leaf {
  animation: fruit-leaf 2s ease-in-out infinite;
}
@keyframes fruit-breath {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.06); }
}
@keyframes fruit-leaf {
  0%, 100% { transform: rotate(-4deg); }
  50%      { transform: rotate(6deg); }
}

/* ---------- Авторские миксы — шейкер трясётся, жидкость булькает ---------- */
.feature__icon--mix .mix-shaker {
  transform-origin: 50% 100%;
  transform-box: fill-box;
}
.feature:hover .feature__icon--mix .mix-shaker {
  animation: mix-shake .55s ease-in-out infinite;
}
.feature:hover .feature__icon--mix .mix-liquid {
  animation: mix-liquid .9s ease-in-out infinite;
}
@keyframes mix-shake {
  0%, 100% { transform: translateX(0)   rotate(0); }
  25%      { transform: translateX(-1.2px) rotate(-3deg); }
  75%      { transform: translateX(1.2px)  rotate(3deg); }
}
@keyframes mix-liquid {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-1.5px); }
}

@media (prefers-reduced-motion: reduce) {
  .feature:hover .vinyl-disc,
  .feature:hover [class^="mic-"],
  .feature:hover .eq-knob,
  .feature:hover .screen-play,
  .feature:hover .screen-frame,
  .feature:hover .stage-table,
  .feature:hover .hookah-smoke,
  .feature:hover .fruit-body,
  .feature:hover .fruit-leaf,
  .feature:hover .mix-shaker,
  .feature:hover .mix-liquid { animation: none; }
}

.feature__num {
  display: none;
  position: absolute;
  top: 1.4rem;
  right: 1.6rem;
  font-family: var(--font-accent);
  font-style: italic;
  font-size: 1.05rem;
  letter-spacing: .04em;
  color: var(--gold-soft);
  opacity: .55;
}
.feature__title {
  font-family: var(--font-display);
  font-size: 1.18rem;
  letter-spacing: .03em;
  color: var(--text);
  margin: 0;
}
.feature__text {
  font-size: .94rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
}

/* ---------- КАРАОКЕ-ЗАЛ: два главных аргумента ---------- */
.venue-hero {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.4rem;
  margin: 3rem 0 1rem;
}
.venue-hero__card {
  position: relative;
  padding: 2.4rem 2rem 2rem;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(196,146,98,.08) 0%, rgba(196,146,98,0) 50%),
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg) 100%);
  border: 1px solid var(--line-strong);
  overflow: hidden;
  transition: border-color 250ms var(--ease), transform 350ms var(--ease);
}
.venue-hero__card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: linear-gradient(180deg, var(--gold) 0%, rgba(196,146,98,.1) 100%);
}
.venue-hero__card:hover { border-color: var(--gold-soft); transform: translateY(-2px); }
.venue-hero__card--accent {
  background:
    radial-gradient(120% 80% at 100% 0%, rgba(196,146,98,.14) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg) 100%);
}
.venue-hero__kicker {
  font-family: var(--font-display);
  font-size: .7rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 .8rem;
}
.venue-hero__title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.2vw, 2.4rem);
  font-weight: 400;
  letter-spacing: .02em;
  line-height: 1.15;
  margin: 0 0 .9rem;
  color: var(--text);
}
.venue-hero__text {
  color: var(--text-soft);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0 0 1.2rem;
}
.venue-hero__list {
  list-style: none;
  margin: 0;
  padding: 1.1rem 0 0;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.venue-hero__list li {
  position: relative;
  padding-left: 1.3rem;
  font-size: .92rem;
  color: var(--text-soft);
  line-height: 1.45;
}
.venue-hero__list li::before {
  content: "";
  position: absolute;
  left: 0; top: .55rem;
  width: 8px; height: 1px;
  background: var(--gold);
}

.venue-more {
  margin: 2.4rem 0 1rem;
  text-align: center;
  font-family: var(--font-display);
  font-size: .72rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text-mute);
}

@media (max-width: 720px) {
  .venue-hero { grid-template-columns: 1fr; gap: 1rem; margin: 2.4rem 0 1rem; }
  .venue-hero__card { padding: 2rem 1.4rem 1.6rem; }
  .venue-hero__title { font-size: 1.6rem; }
}

/* ---------- КАРАОКЕ-ЗАЛ (оборудование) ---------- */
.features--venue {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}
.feature--venue { padding-top: 2.2rem; }

.feature__kicker {
  font-family: var(--font-text);
  font-size: .65rem;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold-soft);
  margin: 0 0 .1rem;
  opacity: .85;
}

/* первая карточка (AST-250) — главный фрагмент: тонкая золотая обводка */
.feature--venue-accent {
  border-color: var(--gold-soft);
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(196,146,98,.16) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, rgba(196,146,98,.04) 0%, rgba(0,0,0,.18) 100%);
}
.feature--venue-accent .feature__kicker { color: var(--gold); opacity: 1; }


/* VIP-карточка кальянов */
.feature--vip {
  position: relative;
  border-color: var(--gold-soft);
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(196,146,98,.18) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, rgba(196,146,98,.05) 0%, rgba(0,0,0,.22) 100%);
}
.feature__crown {
  position: absolute;
  top: 1.2rem;
  right: 1.4rem;
  font-family: var(--font-display);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--gold);
  padding: .35rem .65rem;
  border-radius: 2px;
}
.feature--vip .feature__num { display: none; }

@media (max-width: 900px) {
  .features--venue { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .features--venue { grid-template-columns: 1fr; }
}

/* кликабельные карточки (зал, бронь, меню) */
a.feature { text-decoration: none; color: inherit; }
a.feature:hover, a.feature:focus { text-decoration: none; }
.feature--clickable {
  cursor: pointer;
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(196,146,98,.12) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, rgba(196,146,98,.025) 0%, rgba(0,0,0,.06) 100%);
}
.feature--clickable:hover {
  border-color: var(--gold-soft);
  box-shadow: 0 22px 50px -22px rgba(0,0,0,.7), 0 0 0 1px rgba(196,146,98,.12);
}
.feature--clickable:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 3px;
}
.feature__cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-top: auto;
  padding-top: .4rem;
  font-family: var(--font-display);
  font-size: .7rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  transition: gap .35s var(--ease), color .35s var(--ease);
}
.feature__cta span { transition: transform .35s var(--ease); display: inline-block; }
.feature--clickable:hover .feature__cta { gap: .75rem; }
.feature--clickable:hover .feature__cta span { transform: translateX(3px); }

/* ---------- ЗАЛЫ (большие фото-карточки в стиле основного сайта) ---------- */
.halls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 1.4rem;
  margin-top: 3rem;
}
.hall {
  position: relative;
  overflow: hidden;
  display: block;
  aspect-ratio: 3 / 4;
  min-height: 520px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  text-decoration: none;
  transition: transform 500ms var(--ease), border-color 500ms var(--ease), box-shadow 500ms var(--ease);
  cursor: pointer;
}
.hall:hover {
  border-color: var(--gold);
  transform: translateY(-6px);
  box-shadow: 0 40px 80px -32px var(--gold-glow);
}

/* Полноразмерное медиа за всем контентом */
.hall__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hall__media img,
.hall__media video {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 800ms var(--ease);
}
.hall:hover .hall__media img,
.hall:hover .hall__media video {
  transform: scale(1.06);
}

/* Градиент, чтобы текст читался поверх фото */
.hall::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(to top, rgba(15,8,3,.96) 0%, rgba(15,8,3,.55) 35%, rgba(15,8,3,.05) 65%, rgba(15,8,3,.4) 100%);
  pointer-events: none;
  transition: opacity 500ms var(--ease);
}

/* Лейбл "ЗАЛ · 01" сверху слева */
.hall__label {
  position: absolute;
  top: 1.6rem; left: 1.6rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  font-family: var(--font-display);
  font-size: .68rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
}
.hall__label::before {
  content: "";
  width: 24px; height: 1px;
  background: var(--gold);
}

/* Депозит — справа сверху, чтоб сразу видеть цену */
.hall__price-tag {
  position: absolute;
  top: 1.4rem; right: 1.4rem;
  z-index: 2;
  padding: .55rem .9rem;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--line-strong);
  font-family: var(--font-accent);
  font-style: italic;
  font-size: .95rem;
  color: var(--gold);
  white-space: nowrap;
}

/* Контент-блок внизу */
.hall__body {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 2;
  padding: 1.8rem 1.8rem 1.6rem;
  display: flex;
  flex-direction: column;
  gap: .8rem;
}

.hall__title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  letter-spacing: .03em;
  line-height: 1;
  margin: 0;
  color: var(--text);
}

.hall__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1.4rem;
  font-family: var(--font-display);
  font-size: .68rem;
  color: var(--text-soft);
  letter-spacing: .22em;
  text-transform: uppercase;
}
.hall__meta span { display: inline-flex; align-items: center; gap: .5rem; }
.hall__meta strong { color: var(--gold); font-weight: 400; }

.hall__text {
  font-size: .94rem;
  color: var(--text-soft);
  line-height: 1.55;
  margin: 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 500ms var(--ease), opacity 400ms var(--ease), margin-top 500ms var(--ease);
}
.hall:hover .hall__text {
  max-height: 200px;
  opacity: 1;
  margin-top: .2rem;
}

.hall__cta {
  margin-top: .4rem;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-family: var(--font-display);
  font-size: .68rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  padding: .5rem 0;
  border-bottom: 1px solid var(--gold);
  transition: gap 300ms var(--ease), letter-spacing 300ms var(--ease);
}
.hall__cta::after { content: "→"; }
.hall:hover .hall__cta { gap: 1.1rem; letter-spacing: .3em; }

/* Тач-устройства — раскрытый текст всегда виден */
@media (hover: none) {
  .hall__text { max-height: 200px; opacity: 1; margin-top: .2rem; }
}

/* ---------- ЕДИНСТВЕННЫЙ ЗАЛ — горизонтальная карточка ---------- */
.hall-solo {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 0;
  margin-top: 3rem;
  background: var(--bg-1);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: border-color 400ms var(--ease);
}
.hall-solo:hover { border-color: var(--line-strong); }

.hall-solo__media {
  position: relative;
  display: block;
  padding: 0;
  border: 0;
  background: var(--bg-3);
  min-height: 480px;
  cursor: pointer;
  overflow: hidden;
}
.hall-solo__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 800ms var(--ease);
}
.hall-solo__media:hover img { transform: scale(1.04); }
.hall-solo__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,8,3,.55) 0%, rgba(15,8,3,0) 50%);
  pointer-events: none;
}
.hall-solo__media-hint {
  position: absolute;
  bottom: 1.4rem; left: 1.4rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .7rem 1.1rem;
  background: rgba(0,0,0,.6);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid var(--line-strong);
  color: var(--text);
  font-family: var(--font-display);
  font-size: .66rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  transition: background 300ms var(--ease), color 300ms var(--ease);
}
.hall-solo__media-hint svg { width: 16px; height: 16px; }
.hall-solo__media:hover .hall-solo__media-hint { background: var(--gold); color: #0a0a0a; }

.hall-solo__body {
  padding: clamp(2rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  justify-content: center;
}
.hall-solo__label {
  font-family: var(--font-display);
  font-size: .66rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  gap: .8rem;
}
.hall-solo__label::before {
  content: "";
  width: 24px; height: 1px;
  background: var(--gold);
}
.hall-solo__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3vw, 2.6rem);
  letter-spacing: .03em;
  line-height: 1.05;
  margin: 0;
  color: var(--text);
}
.hall-solo__lead {
  color: var(--text-soft);
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
}
.hall-solo__facts {
  display: flex;
  gap: 1.6rem;
  flex-wrap: wrap;
  padding: 1.2rem 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin: .4rem 0;
}
.hall-solo__facts li {
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.hall-solo__fact-num {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: 1.6rem;
  color: var(--gold);
  line-height: 1;
}
.hall-solo__fact-lbl {
  font-family: var(--font-display);
  font-size: .62rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.hall-solo__cta {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
  margin-top: .4rem;
}

@media (max-width: 900px) {
  .hall-solo { grid-template-columns: 1fr; }
  .hall-solo__media { min-height: 320px; aspect-ratio: 4 / 3; }
}
@media (max-width: 480px) {
  .hall-solo__facts { gap: 1.1rem; }
  .hall-solo__fact-num { font-size: 1.3rem; }
  .hall-solo__cta .btn { flex: 1 1 100%; }
}

/* ---------- АТМОСФЕРА (Reels) — оставляем для будущих видео ---------- */
.reels {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin-top: 2.5rem;
}
.reel {
  position: relative;
  aspect-ratio: 9 / 16;
  background: var(--bg-2);
  overflow: hidden;
  border: 1px solid var(--line);
  transition: border-color 300ms var(--ease);
}
.reel:hover { border-color: var(--gold); }
.reel video, .reel img { width: 100%; height: 100%; object-fit: cover; }
.reel::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(0,0,0,.6) 100%);
  pointer-events: none;
}

/* ---------- АКЦИЯ ДНЯ ---------- */
.section--promo {
  position: relative;
  overflow: hidden;
  padding: clamp(4rem, 8vw, 6.5rem) 0;
  background:
    radial-gradient(70% 90% at 50% 0%, rgba(196,146,98,.10) 0%, rgba(196,146,98,0) 60%),
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg) 100%);
}
.section--promo::before,
.section--promo::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--line-strong), transparent);
  pointer-events: none;
}
.section--promo::before { top: 0; }
.section--promo::after  { bottom: 0; }

.promo-glow {
  position: absolute;
  top: -20%;
  left: 50%;
  width: 70%;
  aspect-ratio: 1 / 1;
  transform: translateX(-50%);
  background: radial-gradient(closest-side, rgba(196,146,98,.18), rgba(196,146,98,0) 70%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}
.section--promo .container { position: relative; z-index: 1; }

.promo-carousel {
  position: relative;
  margin-top: 3rem;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
.promo-carousel__viewport {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  gap: 1.4rem;
  padding: .4rem .2rem 1rem;
}
.promo-carousel__viewport::-webkit-scrollbar { display: none; }
.promo-carousel__viewport > .promo-card {
  flex: 0 0 100%;
  scroll-snap-align: center;
  scroll-snap-stop: always;
}
.promo-carousel__dots {
  display: flex;
  justify-content: center;
  gap: .55rem;
  margin-top: 1.2rem;
}
.promo-carousel__dot {
  width: 28px;
  height: 2px;
  padding: 0;
  border: 0;
  background: var(--line-strong);
  cursor: pointer;
  transition: background 300ms var(--ease), width 300ms var(--ease), color 300ms var(--ease);
  position: relative;
}
.promo-carousel__dots:not(.promo-carousel__dots--labels) .promo-carousel__dot::before {
  content: "";
  position: absolute;
  inset: -18px -6px;
  background: transparent;
}
.promo-carousel__dot.is-active {
  background: var(--gold);
  width: 44px;
}
.promo-carousel__dot:hover { background: var(--gold-soft); }
.promo-carousel__dot:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 4px;
}

/* Текстовая вариация пагинации — "Сет №1 · Сет №2 · Хет-трик" */
.promo-carousel__dots--labels {
  gap: 1.6rem;
  margin-top: 1.6rem;
}
.promo-carousel__dots--labels .promo-carousel__dot {
  position: relative;
  width: auto;
  height: auto;
  padding: .35rem 0 .55rem;
  background: transparent;
  font-family: var(--font-display);
  font-size: .68rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.promo-carousel__dots--labels .promo-carousel__dot::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 1px;
  background: var(--gold);
  transition: width 300ms var(--ease), left 300ms var(--ease);
}
.promo-carousel__dots--labels .promo-carousel__dot:hover {
  background: transparent;
  color: var(--gold-soft);
}
.promo-carousel__dots--labels .promo-carousel__dot.is-active {
  background: transparent;
  width: auto;
  color: var(--gold);
}
.promo-carousel__dots--labels .promo-carousel__dot.is-active::after {
  left: 0;
  width: 100%;
}

.promo-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.4rem;
  padding: 2.6rem 1.8rem 2.2rem;
  border: 1px solid var(--line);
  border-radius: 4px;
  text-align: center;
  background:
    radial-gradient(70% 55% at 50% 30%, rgba(196,146,98,.10) 0%, rgba(196,146,98,.03) 50%, transparent 85%),
    rgba(0,0,0,.18);
  overflow: hidden;
  transition: transform .5s var(--ease), border-color .4s var(--ease);
}
.promo-card::before { content: none; }
.promo-card:hover {
  transform: translateY(-3px);
  border-color: var(--line-strong);
}

.promo-card--featured {
  border-color: var(--line-strong);
  background:
    radial-gradient(70% 60% at 50% 25%, rgba(196,146,98,.18) 0%, rgba(196,146,98,.05) 55%, transparent 90%),
    rgba(0,0,0,.22);
}
.promo-card--featured:hover {
  border-color: var(--gold-soft);
}

.promo-card__tag {
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 400;
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.promo-card__count--ball {
  color: var(--gold);
  align-items: center;
}
.promo-card__count--ball svg {
  width: clamp(5.2rem, 10vw, 7.6rem);
  height: clamp(5.2rem, 10vw, 7.6rem);
  display: block;
}

.promo-card__ribbon {
  position: absolute;
  top: 1.1rem;
  right: 1.1rem;
  font-family: var(--font-text);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--gold);
  padding: .35rem .7rem;
  border-radius: 2px;
}

.promo-card__count {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0;
  margin: 1.4rem 0 .2rem;
  line-height: 1;
}
.promo-card__count-main {
  font-family: var(--font-display);
  font-size: clamp(4.8rem, 9.5vw, 7rem);
  font-weight: 400;
  color: var(--text);
  letter-spacing: -.02em;
}
.promo-card__count-plus {
  font-family: var(--font-display);
  font-size: clamp(3.6rem, 7vw, 5.4rem);
  font-weight: 300;
  color: var(--text-mute);
  padding: 0 .4rem;
  align-self: baseline;
}
.promo-card__count-bonus {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(4.8rem, 9.5vw, 7rem);
  color: var(--gold);
  letter-spacing: -.02em;
}

.promo-card__sub {
  font-family: var(--font-text);
  font-size: .74rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-soft);
  margin: 0;
  line-height: 1.4;
}
.promo-card__sub .accent-italic {
  font-size: 1.08rem;
  letter-spacing: .02em;
  text-transform: none;
}
.promo-card__sub .accent-italic--xl {
  font-size: 2.15rem;
  letter-spacing: 0;
  vertical-align: -.14em;
  margin: 0 .2em;
  line-height: 1;
  font-weight: 500;
}

.promo-card__rule {
  display: block;
  width: 60px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--line-strong), transparent);
  margin: .6rem 0 .3rem;
}

.promo-card__price {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4.8vw, 3.2rem);
  font-weight: 400;
  letter-spacing: .02em;
  color: var(--gold);
  line-height: 1;
  margin: 0;
}
.promo-card__cur {
  font-size: .72em;
  color: var(--gold-soft);
  letter-spacing: 0;
  margin-left: .12em;
  vertical-align: baseline;
}

.promo-card__cta {
  margin-top: .4rem;
  min-width: 200px;
}

/* ───── Подарок имениннику ───── */
.promo-card--gift {
  border-color: var(--line-strong);
  background:
    radial-gradient(70% 55% at 50% 22%, rgba(218,165,98,.16) 0%, rgba(196,146,98,.05) 55%, transparent 90%),
    rgba(0,0,0,.22);
}
.promo-card--gift:hover { border-color: var(--gold-soft); }
.promo-card__count--gift {
  margin: 1.2rem 0 .2rem;
}
.promo-card__count--gift svg {
  width: clamp(5.6rem, 11vw, 8rem);
  height: clamp(5.6rem, 11vw, 8rem);
  filter: drop-shadow(0 0 18px rgba(218,165,98,.18));
}
.promo-card__price--gift {
  letter-spacing: .03em;
  font-size: clamp(2.2rem, 4.8vw, 3rem);
}
.promo-card__note {
  margin: -.4rem 0 0;
  font-family: var(--font-text);
  font-size: .68rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--text-soft);
  line-height: 1.5;
}
.promo-card__fine {
  margin: -.6rem 0 .2rem;
  font-family: var(--font-text);
  font-size: .62rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-mute);
  line-height: 1.4;
}

.promo-flavors {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin-top: 2.8rem;
  padding-top: 2rem;
  border-top: 1px solid var(--hair);
}
.promo-flavors__label {
  font-family: var(--font-text);
  font-size: .7rem;
  font-weight: 500;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--text-mute);
  margin: 0;
}
.promo-flavors__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .55rem;
}
.promo-flavors__list li {
  padding: .55rem 1.1rem;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-size: .88rem;
  color: var(--text);
  letter-spacing: .02em;
  background: rgba(196,146,98,.025);
}

.section--promo .container { text-align: center; }
.section--promo .container > .section__header,
.section--promo .container > .promo-carousel,
.section--promo .container > .promo-flavors {
  text-align: initial;
}

@media (max-width: 720px) {
  .promo-card { padding: 2.2rem 1.4rem 1.8rem; }
  .promo-card__cta { width: 100%; }
}

/* ---------- ВЫВЕСКА: ОТКРЫВАЕМСЯ РАНЬШЕ ---------- */
.section--earlybird {
  background: var(--bg);
  padding: clamp(2.4rem, 5vw, 4rem) 0;
}

.earlybird {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(1.5rem, 3vw, 2.6rem);
  padding: clamp(1.8rem, 3.4vw, 2.6rem) clamp(1.6rem, 3.2vw, 2.8rem);
  border: 1px solid var(--gold-soft);
  border-radius: 4px;
  background:
    radial-gradient(140% 100% at 0% 0%, rgba(196,146,98,.12) 0%, rgba(196,146,98,0) 55%),
    radial-gradient(140% 100% at 100% 100%, rgba(196,146,98,.10) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, rgba(196,146,98,.04) 0%, rgba(0,0,0,.18) 100%);
  box-shadow: 0 22px 50px -28px rgba(0,0,0,.6);
}
.earlybird + .earlybird { margin-top: 1.4rem; }
.earlybird--events {
  background:
    radial-gradient(140% 100% at 100% 0%, rgba(196,146,98,.14) 0%, rgba(196,146,98,0) 55%),
    radial-gradient(140% 100% at 0% 100%, rgba(196,146,98,.08) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(196,146,98,.04) 100%);
}

/* угловые штрихи-уголки — намёк на «вывеску» */
.earlybird__corner {
  position: absolute;
  width: 18px;
  height: 18px;
  border-color: var(--gold);
  border-style: solid;
  border-width: 0;
  opacity: .8;
}
.earlybird__corner--tl { top: -1px; left: -1px;  border-top-width: 1px;    border-left-width: 1px;   }
.earlybird__corner--tr { top: -1px; right: -1px; border-top-width: 1px;    border-right-width: 1px;  }
.earlybird__corner--bl { bottom: -1px; left: -1px;  border-bottom-width: 1px; border-left-width: 1px;  }
.earlybird__corner--br { bottom: -1px; right: -1px; border-bottom-width: 1px; border-right-width: 1px; }

.earlybird__icon {
  width: clamp(48px, 6vw, 64px);
  height: clamp(48px, 6vw, 64px);
  color: var(--gold);
  opacity: .92;
  flex-shrink: 0;
}
.earlybird__icon svg { width: 100%; height: 100%; display: block; }

.earlybird__body {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  min-width: 0;
}

.earlybird__title {
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  letter-spacing: .025em;
  line-height: 1.2;
}

.earlybird__text {
  font-size: .98rem;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0;
  max-width: 60ch;
  text-wrap: pretty;
}

.earlybird__cta {
  display: flex;
  flex-direction: column;
  gap: .6rem;
  flex-shrink: 0;
  min-width: 220px;
}
.earlybird__cta .btn { width: 100%; }

@media (max-width: 920px) {
  .earlybird {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    gap: 1.2rem;
  }
  .earlybird__body { align-items: center; }
  .earlybird__cta {
    width: 100%;
    flex-direction: row;
    min-width: 0;
  }
}

@media (max-width: 560px) {
  .earlybird__cta { flex-direction: column; }
}

/* ---------- АТМОСФЕРА — стат-блок (пока нет видео) ---------- */
.atm-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 4rem;
  border: 1px solid var(--line-strong);
}

.atm-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2.8rem 1.2rem;
  border-right: 1px solid var(--line-strong);
  text-align: center;
  min-height: 200px;
}
.atm-stat:last-child { border-right: 0; }

.atm-stat__value {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4.2vw, 3.6rem);
  font-weight: 400;
  color: var(--gold);
  line-height: 1;
  letter-spacing: .02em;
  white-space: nowrap;
}
.atm-stat__num {
  font: inherit;
  color: inherit;
  white-space: nowrap;
}
.atm-stat__suffix {
  display: inline-block;
  font-family: inherit;
  font-size: .55em;
  color: var(--gold);
  line-height: 1;
  margin-left: .1em;
  vertical-align: top;
  margin-top: .15em;
  letter-spacing: 0;
}
.atm-stat__label {
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 1.1rem;
  line-height: 1.5;
  max-width: 14rem;
}

/* ---------- ПРАЙС-ЛИСТ КАЛЬЯННОЙ КАРТЫ ---------- */
.price-list {
  max-width: 880px;
  margin: 3.5rem auto 0;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  padding: 2rem clamp(1.4rem, 3vw, 2.6rem);
}
.price-list__head {
  margin: 0;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: color 250ms var(--ease);
}
.price-list__head::-webkit-details-marker { display: none; }
.price-list__head::marker { display: none; }
.price-list__head:hover .price-list__chev { border-color: var(--gold); }
.price-list[open] .price-list__head { margin-bottom: 1.4rem; }
.price-list:not([open]) .price-list__head { border-bottom-color: transparent; padding-bottom: 0; }
.price-list__chev {
  position: relative;
  width: 22px;
  height: 22px;
  border: 1px solid var(--line-strong);
  flex-shrink: 0;
  transition: border-color 250ms var(--ease), transform 300ms var(--ease);
}
.price-list__chev::before,
.price-list__chev::after {
  content: "";
  position: absolute;
  background: var(--gold);
}
.price-list__chev::before { top: 50%; left: 4px; right: 4px; height: 1px; transform: translateY(-50%); }
.price-list__chev::after  { left: 50%; top: 4px; bottom: 4px; width: 1px; transform: translateX(-50%); transition: transform 300ms var(--ease); }
.price-list[open] .price-list__chev::after { transform: translateX(-50%) scaleY(0); }
.price-list__tease {
  margin: 1.4rem 0 0;
  padding-top: 1rem;
  border-top: 1px dashed var(--line);
  font-size: .85rem;
  color: var(--text-mute);
  line-height: 1.55;
  text-align: center;
}
.price-list__items { display: flex; flex-direction: column; gap: 0; }
.price-list__item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: 1.5rem;
  padding: 1.1rem 0;
  border-bottom: 1px dashed var(--line);
  transition: padding 250ms var(--ease);
}
.price-list__item:last-child { border-bottom: 0; }
.price-list__item:hover { padding-left: .4rem; }
.price-list__name {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  min-width: 0;
}
.price-list__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: .03em;
  color: var(--text);
}
.price-list__sub {
  font-size: .82rem;
  color: var(--text-mute);
  line-height: 1.5;
}
.price-list__price {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: 1.55rem;
  color: var(--gold);
  white-space: nowrap;
}
.price-list__item--offer .price-list__price { color: var(--gold); }
.price-list__item--vip { border-top: 1px solid var(--line-strong); padding-top: 1.4rem; margin-top: .3rem; }
.price-list__item--vip .price-list__price { font-size: 1.85rem; }
.price-list__badge {
  display: inline-block;
  margin-left: .6rem;
  padding: .15rem .55rem;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-display);
  font-style: normal;
  font-size: .56rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  vertical-align: middle;
}
@media (max-width: 600px) {
  .price-list { padding: 1.4rem 1.2rem; }
  .price-list__item { grid-template-columns: 1fr; gap: .5rem; padding: .9rem 0; }
  .price-list__price { font-size: 1.35rem; }
  .price-list__title { font-size: .98rem; }
}

/* ---------- Atm marquee: бесконечная карусель фото зала ---------- */
.atm-marquee {
  position: relative;
  overflow: hidden;
  margin: 3rem 0 1rem;
  padding: .5rem 0;
  -webkit-mask-image: linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
}
.atm-track {
  display: flex;
  flex-wrap: nowrap;
  gap: 1.2rem;
  width: max-content;
  animation: atmMarqueeRTL 42s linear infinite;
  will-change: transform;
}
.atm-marquee:hover .atm-track,
.atm-marquee:focus-within .atm-track {
  animation-play-state: paused;
}
.atm-cell {
  position: relative;
  flex: 0 0 auto;
  width: clamp(280px, 24vw, 360px);
  aspect-ratio: 4 / 5;
  margin: 0;
  overflow: hidden;
  cursor: pointer;
  background: var(--bg-2);
  border: 1px solid var(--line);
  outline: none;
  transition: border-color 250ms var(--ease), transform 350ms var(--ease), box-shadow 350ms var(--ease);
}
.atm-cell picture,
.atm-cell img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 700ms var(--ease), filter 350ms var(--ease);
  filter: brightness(.95) saturate(1.06);
}
.atm-cell:hover,
.atm-cell:focus-visible {
  border-color: var(--gold);
  transform: translateY(-4px);
  box-shadow: 0 24px 40px -20px rgba(0,0,0,.7);
}
.atm-cell:hover img,
.atm-cell:focus-visible img {
  transform: scale(1.05);
  filter: brightness(1.03) saturate(1.1);
}
.atm-cell::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.5) 100%);
}
.atm-track > [data-clone="true"] { user-select: none; }
.atm-track > [data-clone="true"] * { pointer-events: none; }

@keyframes atmMarqueeRTL {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(calc(-50% - .6rem), 0, 0); }
}

@media (max-width: 900px) {
  .atm-marquee { margin: 2.4rem 0 .8rem; }
  .atm-cell { width: clamp(240px, 72vw, 300px); }
  .atm-track { animation-duration: 34s; }
}

@media (prefers-reduced-motion: reduce) {
  .atm-track { animation: none; }
  .atm-marquee { -webkit-mask-image: none; mask-image: none; }
}

.atm-tagline {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  color: var(--text-soft);
  text-align: center;
  margin: 4rem auto 0;
  max-width: 680px;
  line-height: 1.5;
  letter-spacing: .01em;
}
.atm-tagline__br { display: none; }

/* ---------- МЕНЮ ТИЗЕР ---------- */
.menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.6rem;
  margin-top: 2.5rem;
}
.dish {
  position: relative;
  background: linear-gradient(180deg, var(--bg-2) 0%, var(--bg-1) 100%);
  border: 1px solid var(--line);
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 400ms var(--ease), border-color 400ms var(--ease), box-shadow 400ms var(--ease);
}
.dish::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 80% at 50% 0%, rgba(196,146,98,.10), transparent 60%);
  opacity: 0;
  transition: opacity 400ms var(--ease);
  pointer-events: none;
  z-index: 1;
}
.dish:hover {
  border-color: var(--line-strong);
  transform: translateY(-4px);
  box-shadow: 0 18px 40px -20px rgba(0,0,0,.55), 0 0 0 1px rgba(196,146,98,.05);
}
.dish:hover::before { opacity: 1; }

.dish__media {
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--bg-3);
  overflow: hidden;
}
.dish__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease);
}
.dish:hover .dish__media img { transform: scale(1.05); }
.dish__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(20,12,8,.55) 100%);
  pointer-events: none;
}

/* фото-карточка: вписываем композицию целиком, сливаем фон с карточкой */
.dish__media--photo {
  background:
    radial-gradient(80% 70% at 50% 40%, rgba(196,146,98,.12) 0%, rgba(196,146,98,0) 60%),
    var(--bg-3);
}
.dish__media--photo img {
  object-fit: contain;
  padding: 1.2rem;
  transition: transform 600ms var(--ease), filter 600ms var(--ease);
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.45));
}
.dish:hover .dish__media--photo img {
  transform: scale(1.04);
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.55));
}
.dish__media--photo::after {
  background: linear-gradient(180deg, transparent 70%, rgba(20,12,8,.35) 100%);
}

.dish__corner {
  position: absolute;
  width: 18px;
  height: 18px;
  border: 1px solid var(--gold);
  opacity: .55;
  transition: opacity 400ms var(--ease), width 400ms var(--ease), height 400ms var(--ease);
  z-index: 2;
  pointer-events: none;
}
.dish__corner--tl { top: 10px; left: 10px; border-right: none; border-bottom: none; }
.dish__corner--tr { top: 10px; right: 10px; border-left: none; border-bottom: none; }
.dish__corner--bl { bottom: 10px; left: 10px; border-right: none; border-top: none; }
.dish__corner--br { bottom: 10px; right: 10px; border-left: none; border-top: none; }
.dish:hover .dish__corner { opacity: 1; width: 24px; height: 24px; }

.dish__badge {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  font-family: var(--font-text);
  font-size: .66rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  background: rgba(20,12,8,.7);
  border: 1px solid var(--line-strong);
  padding: .35rem .7rem;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.dish__body {
  position: relative;
  padding: 1.3rem 1.4rem 1.6rem;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  flex: 1;
  z-index: 2;
}
.dish__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  font-size: .68rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.dish__cat { color: var(--gold-soft); }
.dish__num {
  display: none;
  font-family: var(--font-accent);
  font-style: italic;
  font-size: .95rem;
  letter-spacing: .04em;
  color: var(--gold-soft);
  text-transform: none;
}
.dish__title {
  font-family: var(--font-display);
  font-size: 1.18rem;
  letter-spacing: .01em;
  margin: 0;
  color: var(--text);
}
.dish__desc {
  font-size: .87rem;
  color: var(--text-soft);
  margin: 0;
  line-height: 1.5;
  flex: 1;
}
.dish__foot {
  display: flex;
  align-items: center;
  gap: .9rem;
  margin-top: .4rem;
}
.dish__rule {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
}
.dish__price {
  font-family: var(--font-accent);
  font-style: italic;
  color: var(--gold);
  font-size: 1.2rem;
  margin: 0;
  white-space: nowrap;
}

/* ---------- МЕНЮ ПО КАТЕГОРИЯМ ---------- */
.menu-cats {
  margin-top: clamp(3rem, 6vw, 4.5rem);
  padding-top: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--hair);
}
.menu-cats__head {
  display: flex;
  flex-direction: column;
  gap: .6rem;
  align-items: center;
  text-align: center;
  margin-bottom: 2.2rem;
}
.menu-cats__head .h-2 { margin: 0; }
.menu-cats__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.menu-cat {
  display: flex;
  flex-direction: column;
  gap: .9rem;
  padding: 1.6rem 1.4rem 1.6rem;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(255,255,255,.012) 0%, rgba(0,0,0,.10) 100%);
  transition: border-color .4s var(--ease), transform .4s var(--ease);
}
.menu-cat:hover {
  border-color: var(--line-strong);
  transform: translateY(-2px);
}
.menu-cat__head {
  display: flex;
  align-items: center;
  gap: .7rem;
}
.menu-cat__icon {
  width: 32px;
  height: 32px;
  color: var(--gold);
  opacity: .9;
  flex-shrink: 0;
}
.menu-cat__icon svg { width: 100%; height: 100%; display: block; }
.menu-cat__title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: .04em;
  color: var(--text);
  margin: 0;
}
.menu-cat__sub {
  font-size: .68rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-mute);
  margin: -.4rem 0 0;
}
.menu-cat__list {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  margin: 0;
  padding: .8rem 0 0;
  border-top: 1px solid var(--hair);
}
.menu-cat__list li {
  position: relative;
  padding-left: 1rem;
  font-size: .9rem;
  line-height: 1.45;
  color: var(--text-soft);
}
.menu-cat__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .65em;
  width: 6px;
  height: 1px;
  background: var(--gold-soft);
  opacity: .8;
}
@media (max-width: 1000px) {
  .menu-cats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px) {
  .menu-cats__grid { grid-template-columns: 1fr; }
}

/* ---------- ДЕПОЗИТЫ ---------- */
.deposits {
  margin-top: 2.5rem;
  border: 1px solid var(--line);
}
.deposits__row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  border-bottom: 1px solid var(--line);
}
.deposits__row:last-child { border-bottom: 0; }
.deposits__row > * { padding: 1.1rem 1.4rem; }
.deposits__row--head {
  font-family: var(--font-display);
  font-size: .72rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  background: var(--bg-1);
}
.deposits__row:not(.deposits__row--head) > *:first-child { font-family: var(--font-display); letter-spacing: .04em; }
.deposits__price { font-family: var(--font-accent); font-style: italic; color: var(--gold); font-size: 1.1rem; }

@media (max-width: 640px) {
  .deposits__row { grid-template-columns: 1.2fr 1fr; font-size: .9rem; }
  .deposits__row > *:nth-child(3) { display: none; }
}

/* ---------- FAQ (свёрнутая обёртка + аккордеоны) ---------- */
.section--compact { padding: clamp(2rem, 4vw, 3.2rem) 0; }

.faq-wrap {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.faq-wrap[open] { padding-bottom: 1.6rem; }
.faq-wrap__summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  padding: 1.4rem 0;
  transition: color 250ms var(--ease);
}
.faq-wrap__summary::-webkit-details-marker { display: none; }
.faq-wrap__label { display: flex; flex-direction: column; gap: .5rem; }
.faq-wrap__title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.4vw, 1.8rem);
  letter-spacing: .03em;
  color: var(--text);
  line-height: 1.1;
}
.faq-wrap__chev {
  flex-shrink: 0;
  width: 22px; height: 22px;
  position: relative;
  transition: transform 350ms var(--ease);
}
.faq-wrap__chev::before,
.faq-wrap__chev::after {
  content: ""; position: absolute; background: var(--gold);
}
.faq-wrap__chev::before { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
.faq-wrap__chev::after  { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); transition: transform 300ms var(--ease); }
.faq-wrap[open] .faq-wrap__chev { transform: rotate(90deg); }
.faq-wrap[open] .faq-wrap__chev::after { transform: translateX(-50%) scaleY(0); }
.faq-wrap__summary:hover .faq-wrap__title { color: var(--gold); }

.faq { margin-top: .4rem; border-top: 1px solid var(--line); }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q {
  width: 100%;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  padding: 1.6rem 0;
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: .02em;
  color: var(--text);
  transition: color 250ms var(--ease);
}
.faq__q:hover { color: var(--gold); }
.faq__q .plus {
  flex-shrink: 0;
  width: 18px; height: 18px;
  position: relative;
  transition: transform 350ms var(--ease);
}
.faq__q .plus::before,
.faq__q .plus::after {
  content: ""; position: absolute; background: var(--gold);
}
.faq__q .plus::before { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
.faq__q .plus::after  { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); transition: transform 300ms var(--ease); }
.faq__item.is-open .plus { transform: rotate(90deg); }
.faq__item.is-open .plus::after { transform: translateX(-50%) scaleY(0); }
.faq__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 400ms var(--ease);
}
.faq__a-inner {
  padding: 0 0 1.6rem;
  color: var(--text-soft);
  max-width: 720px;
  line-height: 1.7;
}

/* ---------- КАРТА И КОНТАКТЫ ---------- */
.contacts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: 2.5rem;
  border: 1px solid var(--line);
}
@media (max-width: 900px) { .contacts { grid-template-columns: 1fr; } }

.contacts__map {
  min-height: 480px;
  background: var(--bg-2);
  position: relative;
  display: flex;
  flex-direction: column;
}
.contacts__map iframe,
.contacts__map > img {
  width: 100%;
  flex: 1 1 auto;
  min-height: 380px;
  border: 0;
  display: block;
  filter: grayscale(.35) contrast(.92) brightness(.95);
}

.contacts__map-actions {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--line-strong);
  border-top: 1px solid var(--line-strong);
  flex-shrink: 0;
}
@media (max-width: 1100px) {
  .contacts__map-actions { grid-template-columns: repeat(3, 1fr); }
}
.map-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  padding: 1rem .8rem;
  background: var(--bg-1);
  color: var(--text-soft);
  font-size: .76rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-align: center;
  transition: background .35s var(--ease), color .35s var(--ease);
  min-height: 58px;
  line-height: 1.2;
}
.map-btn svg {
  width: 18px;
  height: 18px;
  color: var(--gold);
  flex-shrink: 0;
  transition: transform .35s var(--ease);
}
.map-btn:hover {
  background: var(--bg-2);
  color: var(--text);
}
.map-btn:hover svg { transform: translateY(-1px); }
@media (max-width: 600px) {
  .contacts__map-actions { grid-template-columns: 1fr; gap: 1px; }
  .map-btn { justify-content: flex-start; padding: .95rem 1.2rem; font-size: .72rem; min-height: 52px; }
}
.contacts__info {
  padding: 2.4rem;
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
  background: var(--bg-1);
  border-left: 1px solid var(--line);
}
@media (max-width: 900px) { .contacts__info { border-left: 0; border-top: 1px solid var(--line); } }

.contacts__item { display: flex; flex-direction: column; gap: .35rem; }
.contacts__label { font-size: .68rem; letter-spacing: .3em; text-transform: uppercase; color: var(--text-mute); }
.contacts__value { font-family: var(--font-display); font-size: 1.15rem; color: var(--text); }
.contacts__value a:hover { color: var(--gold); }

/* ---------- ФОРМА БРОНИ / RESTOPLACE (inline) ---------- */
.booking__header {
  max-width: 720px;
  margin: 0 auto 2rem;
  text-align: center;
}
.booking__title { margin: 1.4rem 0 .8rem; }
.booking__lead { color: var(--text-soft); margin-bottom: 0; }

.booking__frame {
  height: min(78vh, 820px);
  max-width: 1100px;
  margin: 0 auto;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  overflow: hidden;
  position: relative;
}
.booking__frame::before {
  content: "Загружаем форму бронирования…";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-mute);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  pointer-events: none;
}
.booking__frame iframe {
  width: 100%; height: 100%;
  border: 0;
  display: block;
  position: relative;
  background: var(--bg-1);
}

.booking__alt {
  max-width: 1100px;
  margin: 1.6rem auto 0;
  padding-top: 1.4rem;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .9rem;
}
.booking__alt-label {
  font-size: .68rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.booking__alt-buttons {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
  justify-content: center;
}
.booking__alt-buttons .btn { min-width: 160px; padding: .9rem 1.2rem; font-size: .68rem; }

/* ---------- FOOTER ---------- */
.footer {
  padding: 3.5rem 0 2rem;
  background: #1d1209;
  border-top: 1px solid var(--line);
  font-size: .9rem;
  color: var(--text-soft);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 2.4rem;
  margin-bottom: 2.5rem;
}
@media (max-width: 900px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
.footer__col h4 {
  font-family: var(--font-display);
  font-size: .72rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 1rem;
}
.footer__col a { display: block; padding: .25rem 0; transition: color 200ms; }
.footer__col a:hover { color: var(--gold); }
.footer__bottom {
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: .78rem;
  color: var(--text-mute);
}

/* ---------- SIDE RAIL (контакты + бронь, столбиком снизу справа) ---------- */
.side-rail {
  position: fixed;
  right: 1.4rem;
  bottom: 1.4rem;
  z-index: 45;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity 400ms var(--ease), transform 400ms var(--ease);
}
.side-rail.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.side-rail__icons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
}
.side-rail__icon,
.side-rail__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 1px solid var(--line-strong);
  background: rgba(10,5,2,.78);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  color: var(--text);
  cursor: pointer;
  box-shadow: 0 14px 30px -18px rgba(0,0,0,.65);
  transition: border-color 220ms var(--ease), color 220ms var(--ease),
              background 220ms var(--ease), transform 200ms var(--ease);
}
.side-rail__icon svg,
.side-rail__btn svg { display: block; }
.side-rail__icon:hover,
.side-rail__btn:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(196,146,98,.14);
  transform: translateY(-1px);
}
.side-rail__icon:active,
.side-rail__btn:active { transform: translateY(0); }
.side-rail__icon:focus-visible,
.side-rail__btn:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 2px;
}
.side-rail__btn {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(196,146,98,.10);
}
.side-rail__btn:hover {
  background: var(--gold);
  color: #0a0a0a;
}

/* ---------- МОДАЛКА БРОНИРОВАНИЯ (Restoplace) ---------- */
.modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 350ms var(--ease), visibility 0s linear 350ms;
}
.modal.is-open {
  opacity: 1;
  visibility: visible;
  transition: opacity 350ms var(--ease), visibility 0s linear 0s;
}
.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8,4,2,.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.modal__dialog {
  position: relative;
  width: 100%;
  max-width: 720px;
  max-height: 92vh;
  background: var(--bg-1);
  border: 1px solid var(--line-strong);
  padding: 2.6rem 2.4rem 2.2rem;
  overflow-y: auto;
  transform: translateY(20px) scale(.98);
  transition: transform 400ms var(--ease);
  box-shadow: 0 40px 100px -30px rgba(0,0,0,.7);
}
.modal.is-open .modal__dialog {
  transform: translateY(0) scale(1);
}
.modal__close {
  position: absolute;
  top: .9rem; right: .9rem;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  color: var(--text-soft);
  font-size: 1.4rem;
  line-height: 1;
  transition: all 250ms var(--ease);
}
.modal__close:hover { border-color: var(--gold); color: var(--gold); }
.modal__title { margin: 0 0 .4rem; }
.modal__lead { color: var(--text-soft); margin: 0 0 2rem; font-size: .95rem; }
.modal__body { min-height: 120px; }

.modal__alt {
  margin-top: 2rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
.modal__alt-label {
  font-size: .68rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text-mute);
  text-align: center;
}
.modal__alt-buttons {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
}
.modal__alt-buttons .btn { flex: 1 1 calc(33% - .5rem); min-width: 120px; padding: .9rem .8rem; font-size: .66rem; }

.modal__sub { color: var(--text-soft); margin: 0 0 1.6rem; font-size: .95rem; }

/* Большая модалка под iframe Restoplace */
.modal__dialog--wide {
  max-width: 1100px;
  padding: 1.6rem 1.6rem 1.4rem;
}
.modal__body--frame {
  height: min(78vh, 820px);
  margin-top: .6rem;
  border: 1px solid var(--line);
  background: var(--bg);
  overflow: hidden;
}
.modal__body--frame iframe {
  width: 100%; height: 100%;
  border: 0;
  display: block;
}

/* ---------- МОДАЛКА: ВЫБОР МЕССЕНДЖЕРА ---------- */
.modal__dialog--messenger {
  max-width: 460px;
  padding: 2rem 1.8rem 1.6rem;
  text-align: center;
}

.messenger-picker__lead {
  color: var(--text-soft);
  font-size: .92rem;
  line-height: 1.55;
  margin: .8rem 0 1.6rem;
  text-wrap: pretty;
}

.messenger-picker {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  margin-top: .4rem;
}

.messenger-option {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(255,255,255,.012) 0%, rgba(0,0,0,.18) 100%);
  text-decoration: none;
  color: var(--text);
  text-align: left;
  transition:
    transform .35s var(--ease),
    border-color .35s var(--ease),
    background .35s var(--ease),
    box-shadow .35s var(--ease);
}
.messenger-option:hover,
.messenger-option:focus-visible {
  transform: translateY(-2px);
  border-color: var(--gold-soft);
  background: linear-gradient(180deg, rgba(196,146,98,.05) 0%, rgba(0,0,0,.22) 100%);
  box-shadow: 0 14px 30px -18px rgba(0,0,0,.6);
  outline: none;
  text-decoration: none;
  color: var(--text);
}

.messenger-option__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(196,146,98,.08);
  border: 1px solid var(--line);
  color: var(--gold);
  transition: background .35s var(--ease), color .35s var(--ease);
}
.messenger-option__icon svg { width: 24px; height: 24px; display: block; }

.messenger-option--wa  .messenger-option__icon { color: #25D366; background: rgba(37,211,102,.10);  border-color: rgba(37,211,102,.25);  }
.messenger-option--tg  .messenger-option__icon { color: #229ED9; background: rgba(34,158,217,.10); border-color: rgba(34,158,217,.25); }
.messenger-option--max .messenger-option__icon { color: var(--gold); background: rgba(196,146,98,.10); border-color: rgba(196,146,98,.30); }

.messenger-option__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .15rem;
  min-width: 0;
}
.messenger-option__name {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: .03em;
  color: var(--text);
  line-height: 1.2;
}
.messenger-option__sub {
  font-size: .8rem;
  color: var(--text-mute);
  letter-spacing: .02em;
  line-height: 1.3;
}

.messenger-option__arrow {
  flex-shrink: 0;
  color: var(--gold-soft);
  font-size: 1.1rem;
  font-family: var(--font-text);
  transition: transform .35s var(--ease), color .35s var(--ease);
}
.messenger-option:hover .messenger-option__arrow,
.messenger-option:focus-visible .messenger-option__arrow {
  color: var(--gold);
  transform: translateX(4px);
}

.messenger-picker__phone {
  margin: 1.4rem 0 0;
  padding-top: 1.2rem;
  border-top: 1px solid var(--hair);
  font-size: .82rem;
  letter-spacing: .04em;
  color: var(--text-mute);
}
.messenger-picker__phone a {
  color: var(--gold);
  font-family: var(--font-display);
  letter-spacing: .04em;
}
.messenger-picker__phone a:hover { color: var(--text); }

@media (max-width: 480px) {
  .modal__dialog--messenger { padding: 1.6rem 1.2rem 1.2rem; }
  .messenger-option { padding: .85rem .9rem; gap: .8rem; }
  .messenger-option__icon { width: 40px; height: 40px; }
  .messenger-option__name { font-size: .98rem; }
}

/* ---------- ГАЛЕРЕЯ ФОТО ЗАЛА ---------- */
.modal__dialog--gallery {
  max-width: 1200px;
  padding: 1.4rem 1.4rem 1.6rem;
  background: var(--bg);
}
.gallery__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .6rem;
  margin: .4rem 0 1.2rem;
  text-align: center;
}
.gallery__header .eyebrow { font-size: .64rem; letter-spacing: .32em; }
.gallery__header .modal__title { margin: 0; }

.gallery {
  position: relative;
  background: #000;
  border: 1px solid var(--line-strong);
  aspect-ratio: 16 / 9;
  min-height: 220px;
  overflow: hidden;
  box-shadow:
    0 30px 80px -24px rgba(0,0,0,.65),
    inset 0 0 0 1px rgba(196,146,98,.08);
}
.gallery::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.45) 100%);
  z-index: 1;
}
.gallery__track {
  display: flex;
  height: 100%;
  scroll-snap-type: x mandatory;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  scrollbar-width: none;
}
.gallery__track::-webkit-scrollbar { display: none; }
.gallery__slide {
  flex: 0 0 100%;
  scroll-snap-align: start;
  position: relative;
  background: #000;
  overflow: hidden;
}
.gallery__slide img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  animation: gallery-kenburns 14s ease-in-out infinite alternate;
  transform-origin: center center;
}
@keyframes gallery-kenburns {
  0%   { transform: scale(1.04) translate3d(0, 0, 0); }
  100% { transform: scale(1.12) translate3d(-1.5%, -1%, 0); }
}
.gallery__slide--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: .8rem;
  letter-spacing: .26em;
  color: var(--text-mute);
  text-transform: uppercase;
  background: var(--bg-2);
}
.gallery__slide--empty img { display: none; }

.gallery__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) scale(.94);
  width: 56px; height: 56px;
  background: rgba(15,8,3,.55);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  border: 1px solid rgba(196,146,98,.35);
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 1.5rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  opacity: 0;
  cursor: pointer;
  transition: opacity 350ms var(--ease), transform 350ms var(--ease),
              background 250ms var(--ease), color 250ms var(--ease),
              border-color 250ms var(--ease);
}
.gallery__nav span { display: block; margin-top: -3px; }
.gallery:hover .gallery__nav,
.gallery__nav:focus-visible {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}
.gallery__nav:hover {
  background: var(--gold);
  color: #0a0a0a;
  border-color: var(--gold);
  transform: translateY(-50%) scale(1.06);
  box-shadow: 0 14px 32px -10px var(--gold-glow);
}
.gallery__nav--prev { left: 1.2rem; }
.gallery__nav--next { right: 1.2rem; }

.gallery__counter {
  position: absolute;
  top: 1rem; right: 1.1rem;
  z-index: 3;
  padding: .45rem .8rem;
  background: rgba(15,8,3,.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(196,146,98,.28);
  font-family: var(--font-display);
  font-size: .64rem;
  letter-spacing: .26em;
  color: var(--gold);
}
.gallery__counter:empty { display: none; }

.gallery__dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5rem;
  margin-top: 1.2rem;
  padding-top: .4rem;
}
.gallery__dot {
  width: 22px;
  height: 2px;
  border-radius: 0;
  background: rgba(196,146,98,.22);
  transition: background 350ms var(--ease), width 350ms var(--ease);
  cursor: pointer;
  border: 0;
  padding: 0;
  position: relative;
}
/* Невидимая увеличенная зона нажатия для touch — 44×44 как требует WCAG */
.gallery__dot::before {
  content: "";
  position: absolute;
  inset: -16px -4px;
  background: transparent;
}
.gallery__dot:hover { background: rgba(196,146,98,.55); }
.gallery__dot.is-active {
  background: var(--gold);
  width: 44px;
}

/* Тач-устройства: стрелки видны всегда — нет hover */
@media (hover: none) {
  .gallery__nav { opacity: 1; transform: translateY(-50%) scale(1); }
}

@media (max-width: 600px) {
  .modal__dialog { padding: 2.2rem 1.4rem 1.6rem; }
  .modal__dialog--wide { padding: 1.2rem 1rem 1rem; }
  .modal__body--frame { height: 72vh; }
  .modal__alt-buttons .btn { flex: 1 1 100%; }
  .modal__dialog--gallery { padding: 1rem .8rem 1.2rem; }
  .gallery { aspect-ratio: 4 / 3; }
  .gallery__nav { width: 42px; height: 42px; font-size: 1.2rem; }
  .gallery__nav--prev { left: .6rem; }
  .gallery__nav--next { right: .6rem; }
  .gallery__counter { top: .6rem; right: .7rem; padding: .35rem .65rem; font-size: .58rem; }
  .gallery__dot { width: 18px; }
  .gallery__dot.is-active { width: 32px; }
}

body.modal-open { overflow: hidden; }

/* ---------- КНОПКА «СМОТРЕТЬ ФОТО» НА ЗАЛЕ ---------- */
.hall__media-btn {
  position: absolute;
  top: 1.2rem; right: 1.2rem;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .55rem .9rem;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--line-strong);
  color: var(--text);
  font-family: var(--font-display);
  font-size: .62rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 250ms var(--ease), border-color 250ms var(--ease), color 250ms var(--ease);
}
.hall__media-btn svg { width: 16px; height: 16px; }
.hall__media-btn:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #0a0a0a;
}

/* ---------- РОЛИ В КОНТАКТАХ ---------- */
.contacts__item--role { gap: .25rem; }
.contacts__sub {
  font-size: .82rem;
  color: var(--text-mute);
  letter-spacing: .04em;
  margin-top: .15rem;
}
.contacts__sub a { color: var(--text-soft); transition: color 200ms; }
.contacts__sub a:hover { color: var(--gold); }


/* ---------- УТИЛИТЫ ---------- */
.text-center { text-align: center; }
.section__header { display: flex; flex-direction: column; gap: 1rem; max-width: 780px; }
.section__header--center { margin: 0 auto; align-items: center; text-align: center; }

.fade-in { opacity: 0; transform: translateY(20px); transition: opacity 700ms var(--ease), transform 700ms var(--ease); }
.fade-in.is-visible { opacity: 1; transform: translateY(0); }

/* ---------- ШИММЕР НА ЗОЛОТЫХ АКЦЕНТАХ (вариант «парча») ---------- */
.eyebrow,
.accent-italic,
.feature__num,
.dish__num,
.atm-stat__num,
.deposits__price {
  background: linear-gradient(100deg,
    #6F4827   0%,
    #A07642  22%,
    #C49262  42%,
    #F1D9B0  50%,
    #C49262  58%,
    #A07642  78%,
    #6F4827 100%);
  background-size: 280% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
          color: transparent;
  animation: shimmer 9s linear infinite;
}
/* линия слева у .eyebrow должна остаться твёрдо-золотой (text-fill: transparent её бы потерял) */
.eyebrow::before { background: var(--gold); }

/* Главная кнопка — мягкая золотая волна по фону */
.btn-primary {
  background: linear-gradient(100deg,
    #B68353  0%,
    #C49262 30%,
    #E5C490 50%,
    #C49262 70%,
    #B68353 100%);
  background-size: 240% 100%;
  animation: btn-shimmer 10s linear infinite;
}

@keyframes shimmer {
  0%   { background-position: 280% 0; }
  100% { background-position: -280% 0; }
}
@keyframes btn-shimmer {
  0%   { background-position: 0 0; }
  100% { background-position: 240% 0; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ============================================================
   АДАПТИВНОСТЬ · BREAKPOINTS
   - 1440+    desktop large
   - 1280–    desktop / большой ноут
   - 1024–    планшеты (iPad Pro)
   - 768–     планшеты / большой телефон (iPad mini)
   - 480–     телефоны (iPhone 14/15)
   - 360–     маленькие телефоны (iPhone SE, старые Android)
   - landscape on phones — отдельно
   - touch (hover: none) — отдельно
   ============================================================ */

/* ---------- 1280px ↓ (большой ноут / маленький десктоп) ---------- */
@media (max-width: 1280px) {
  :root { --gutter: clamp(1.2rem, 3vw, 2rem); }
  .nav__menu { gap: 1.8rem; }
}

/* ---------- 1024px ↓ (планшеты, активируется мобильное меню) ---------- */
@media (max-width: 1023px) {
  .section { padding: clamp(3.2rem, 7vw, 6rem) 0; }
  .hero { padding: 7rem 0 4rem; }

  .features { grid-template-columns: repeat(2, 1fr); }
  .feature { padding: 2rem 1.4rem; }

  .halls { grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }

  .reels { grid-template-columns: repeat(3, 1fr); }
  .reels > :nth-child(4) { display: none; } /* убираем 4-й reel, чтобы был ровный ряд */

  .atm-stats { grid-template-columns: repeat(3, 1fr); }
  .atm-stat:last-child { border-right: 0; }

  .menu-grid { grid-template-columns: repeat(2, 1fr); }

  .footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

/* ---------- 768px ↓ (планшеты в портрете / большие телефоны) ---------- */
@media (max-width: 767px) {
  html { font-size: 15.5px; }
  :root { --gutter: 1.1rem; --container: 100%; }

  /* HERO */
  .hero { padding: 6.5rem 0 3.5rem; min-height: 92svh; }
  .hero__lead { font-size: .98rem; }
  .hero__cta { width: 100%; }
  .hero__cta .btn { flex: 1 1 auto; min-width: 0; padding: 1rem 1.2rem; font-size: .68rem; letter-spacing: .18em; }
  .hero__scroll { display: none; }

  /* НАВИГАЦИЯ */
  .nav { padding: 1rem 0; }
  .nav.is-scrolled { padding: .7rem 0; }
  .nav__logo { font-size: .92rem; letter-spacing: .18em; }

  /* СЕТКИ — в одну колонку */
  .features { grid-template-columns: 1fr; }
  .feature { padding: 1.8rem 1.2rem; }

  .halls { grid-template-columns: 1fr; gap: 1.2rem; }
  .hall { min-height: 0; aspect-ratio: 4 / 5; }
  .hall__body { padding: 1.4rem; gap: .8rem; }
  .hall__title { font-size: 1.25rem; }

  .reels { grid-template-columns: repeat(2, 1fr); gap: .7rem; }
  .reels > :nth-child(4) { display: block; } /* возвращаем 4-й — выходит 2×2 */

  .atm-stat { padding: 2.2rem 1rem; }
  .atm-tagline { font-size: clamp(1.2rem, 4vw, 1.6rem); }
  .atm-tagline__br { display: inline; }

  .menu-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .dish__body { padding: 1rem 1.1rem 1.3rem; gap: .45rem; }
  .dish__title { font-size: 1.02rem; }
  .dish__desc { font-size: .8rem; }
  .dish__price { font-size: 1.05rem; }
  .dish__badge { top: 10px; right: 10px; font-size: .6rem; padding: .28rem .55rem; }
  .dish__corner { width: 14px; height: 14px; top: 8px; left: 8px; }
  .dish__corner--tr { left: auto; right: 8px; }
  .dish__corner--bl { top: auto; bottom: 8px; }
  .dish__corner--br { top: auto; left: auto; bottom: 8px; right: 8px; }

  /* ДЕПОЗИТЫ — упрощаем */
  .deposits__row { font-size: .88rem; padding: 0; }
  .deposits__row > * { padding: .9rem 1rem; }

  /* ОТЗЫВЫ */
  .review { padding: 1.6rem 1.4rem; }
  .review__text { font-size: 1.05rem; }

  /* FAQ */
  .faq__q { font-size: 1rem; padding: 1.3rem 0; gap: 1rem; }
  .faq__a-inner { font-size: .94rem; padding-bottom: 1.3rem; }

  /* КАРТА И КОНТАКТЫ */
  .contacts__map { min-height: 280px; }
  .contacts__map iframe, .contacts__map img { min-height: 280px; }
  .contacts__info { padding: 1.8rem 1.4rem; gap: 1.2rem; }
  .contacts__value { font-size: 1.02rem; }

  /* ФОРМА */
  .booking__frame { height: 72vh; }
  .booking__alt-buttons .btn { flex: 1 1 100%; }

  /* FOOTER */
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 1.6rem; }
  .footer__col h4 { font-size: .68rem; }
  .footer__bottom { flex-direction: column; align-items: flex-start; font-size: .72rem; }

  /* Side rail — на планшете чуть ближе к краю */
  .side-rail { right: 1rem; bottom: 1rem; }
  .side-rail__icon,
  .side-rail__btn { width: 36px; height: 36px; }
}

/* ---------- 480px ↓ (стандартный телефон в портрете) ---------- */
@media (max-width: 480px) {
  html { font-size: 15px; }

  .hero__title { line-height: .94; }
  .hero__lead { margin: 1.6rem 0 2rem; }

  .hero__cta { flex-direction: column; gap: .7rem; }
  .hero__cta .btn { width: 100%; padding: 1.05rem 1rem; }

  .nav__cta { display: none; }

  /* Закуглим читаемость таблицы депозитов */
  .deposits__row { grid-template-columns: 1.4fr 1fr; }
  .deposits__row--head > *:nth-child(3),
  .deposits__row > *:nth-child(3) { display: none; } /* скрываем 3-й столбец */
  .deposits__row > *:nth-child(2)::before {
    content: "пн–чт · ";
    font-family: var(--font-text);
    font-style: normal;
    font-size: .68rem;
    color: var(--text-mute);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-right: .4rem;
  }

  /* Раскрытые цены — компактнее */
  .deposits__price { font-size: 1rem; }

  /* Меню — список 1 колонка */
  .menu-grid { grid-template-columns: 1fr; }

  /* FAQ-плюсик меньше */
  .faq__q .plus { width: 16px; height: 16px; }

  /* Reel — крупнее, 2 в ряд */
  .reels { grid-template-columns: repeat(2, 1fr); }

  .atm-stats { grid-template-columns: 1fr; border: 1px solid var(--line-strong); }
  .atm-stat { padding: 1.8rem .8rem; border-right: 0; border-bottom: 1px solid var(--line-strong); }
  .atm-stat:last-child { border-bottom: 0; }
}

/* ---------- 360px ↓ (iPhone SE, маленькие Android) ---------- */
@media (max-width: 360px) {
  html { font-size: 14.5px; }
  :root { --gutter: .9rem; }

  .hero { padding: 5.5rem 0 3rem; }
  .hero__title { font-size: clamp(3rem, 14vw, 4.4rem); }
  .hero__lead { font-size: .92rem; }

  .h-1 { font-size: clamp(2rem, 7.5vw, 2.6rem); }
  .h-2 { font-size: clamp(1.5rem, 6vw, 1.9rem); }

  .nav__logo { max-width: 56vw; }

  .feature { padding: 1.4rem 1rem; }
  .feature__title { font-size: 1.05rem; }

  .hall__body { padding: 1.2rem; }

  .booking__lead { font-size: .9rem; }
  .booking__frame { height: 80vh; }

  .footer__grid { grid-template-columns: 1fr; }
  .fab a { width: 42px; height: 42px; }
}

/* ---------- LANDSCAPE на телефонах ---------- */
@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px) {
  .hero { min-height: auto; padding: 5rem 0 3rem; }
  .hero__inner { max-width: 720px; }
  .hero__scroll { display: none; }
  .nav__menu.is-open { padding: 4rem 1rem 1rem; overflow-y: auto; gap: 1.6rem; }
}

/* ---------- БОЛЬШИЕ ЭКРАНЫ (1600px+) ---------- */
@media (min-width: 1600px) {
  :root { --container: 1440px; }
  html { font-size: 17px; }
}

/* ---------- ОЧЕНЬ БОЛЬШИЕ (4K и выше) ---------- */
@media (min-width: 2200px) {
  :root { --container: 1600px; }
  html { font-size: 18px; }
}

/* ---------- TOUCH-устройства (без hover) ---------- */
@media (hover: none) and (pointer: coarse) {
  /* Hover-эффекты на тач-устройствах вызывают «залипание», убираем избыточные */
  .hall:hover { transform: none; box-shadow: none; }
  .hall:hover .hall__media img { transform: none; }

  /* Активное состояние при касании — для обратной связи */
  .btn:active { transform: scale(.97); }
  .hall:active { border-color: var(--gold); }
  .nav__link:active { color: var(--gold); }
}

/* ---------- Поддержка safe-area на iPhone с челкой ---------- */
@supports (padding: env(safe-area-inset-top)) {
  .nav { padding-top: calc(1.4rem + env(safe-area-inset-top)); }
  .nav.is-scrolled { padding-top: calc(.9rem + env(safe-area-inset-top)); }
  .side-rail {
    right: calc(1rem + env(safe-area-inset-right));
    bottom: calc(1rem + env(safe-area-inset-bottom));
  }
  .footer { padding-bottom: calc(2rem + env(safe-area-inset-bottom)); }
}

/* ---------- PWA standalone: нет адресной строки Safari ----------
   display-mode: standalone активен когда сайт сохранён на главный экран.
   Контент начинается прямо под статус-баром → добавляем отступ под него. */
@media (display-mode: standalone) {
  .nav {
    padding-top: calc(1.4rem + env(safe-area-inset-top, 44px));
  }
  .nav.is-scrolled {
    padding-top: calc(.9rem + env(safe-area-inset-top, 44px));
  }
  .hero {
    padding-top: env(safe-area-inset-top, 44px);
  }
}

/* ---------- ПЕЧАТЬ ---------- */
@media print {
  .nav, .side-rail, .hero__scroll, .booking__frame, .booking__alt { display: none !important; }
  body { background: white; color: black; }
  .section { padding: 1rem 0; page-break-inside: avoid; }
}

/* ============================================================
   HERO — дополнения (микрофон, разделитель, факты, бейдж "Открыто")
   ============================================================ */

.hero__mic {
  width: 52px;
  height: 52px;
  color: var(--gold);
  opacity: .92;
  margin-bottom: 1.2rem;
  filter: drop-shadow(0 8px 24px rgba(196,146,98,.25));
}
.hero__mic svg { width: 100%; height: 100%; display: block; }

.hero__rule {
  margin: 2rem 0 1.4rem;
  width: 96px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
}

.hero__lead { margin-top: 0; margin-bottom: 1.6rem; }

.hero__facts {
  list-style: none;
  padding: 0;
  margin: 0 0 2.4rem;
  display: flex;
  flex-wrap: wrap;
  gap: .7rem 2rem;
  font-size: .92rem;
  color: var(--text-soft);
  align-items: baseline;
}
.hero__facts li {
  display: inline-flex;
  align-items: baseline;
  gap: .5rem;
  white-space: nowrap;
}
.hero__facts-num {
  font-family: var(--font-display);
  color: var(--gold);
  font-size: 1.08rem;
  letter-spacing: .04em;
}
.hero__facts-lbl {
  font-size: .82rem;
  color: var(--text-mute);
  letter-spacing: .04em;
}

@media (max-width: 768px) {
  .hero__mic { width: 42px; height: 42px; margin-bottom: 1rem; }
  .hero__rule { width: 64px; margin: 1.4rem 0 1rem; }
}

/* ---------- Карусель карточек караоке-зала (бесконечная лента + ручная прокрутка) ---------- */
.features--marquee {
  display: block !important;
  grid-template-columns: none !important;
  position: relative;
  padding: 1rem 0;
  overflow: hidden;
  cursor: grab;
  -webkit-mask-image: linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
  touch-action: pan-y;
}
.features--marquee.is-grabbing { cursor: grabbing; }
.features--marquee .features__track {
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 1.2rem;
  width: max-content;
  will-change: transform;
}
.features--marquee .feature {
  flex: 0 0 auto;
  width: clamp(310px, 32vw, 380px);
  min-height: 300px;
  transition:
    border-color .45s var(--ease),
    transform .45s var(--ease),
    box-shadow .45s var(--ease),
    background .45s var(--ease);
}
.features--marquee .feature:hover {
  transform: translateY(-6px) scale(1.02);
  border-color: var(--gold-soft);
  box-shadow:
    0 28px 60px -28px rgba(0,0,0,.7),
    0 0 0 1px rgba(196,146,98,.12),
    0 0 40px -10px rgba(196,146,98,.25);
}
.features--marquee .feature:hover .feature__icon {
  transform: translateY(-3px) scale(1.1) rotate(-2deg);
  opacity: 1;
  filter: drop-shadow(0 0 8px rgba(196,146,98,.45));
}
.features--marquee .feature:hover .feature__title { color: var(--gold); }
.features--marquee .feature:hover .feature__kicker { color: var(--gold); opacity: 1; }
.features--marquee .feature:hover::after { transform: scaleX(1); }
.features--marquee .feature__icon { animation: none; }

.features__track > [data-clone="true"] { user-select: none; }
.features__track > [data-clone="true"] * { pointer-events: none; }

@media (prefers-reduced-motion: reduce) {
  .features--marquee { -webkit-mask-image: none; mask-image: none; }
}
@media (max-width: 900px) {
  .features--marquee .feature { width: clamp(280px, 75vw, 340px); min-height: 270px; }
}
@media (max-width: 600px) {
  .features--marquee .feature { width: clamp(260px, 82vw, 320px); }
}

/* ---------- Карусель карточек меню (бесконечная, справа налево) ---------- */
.menu-marquee {
  position: relative;
  overflow: hidden;
  padding: 1rem 0;
  cursor: grab;
  -webkit-mask-image: linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
}
.menu-marquee.is-grabbing {
  cursor: grabbing;
}
.menu-grid--marquee {
  display: flex !important;
  grid-template-columns: none !important;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 1.4rem;
  width: max-content;
  will-change: transform;
  cursor: grab;
}
.menu-grid--marquee.is-grabbing,
.menu-marquee.is-grabbing .menu-grid--marquee {
  cursor: grabbing;
}
.menu-grid--marquee .dish {
  flex: 0 0 auto;
  width: clamp(280px, 24vw, 340px);
}
.menu-grid--marquee > [data-clone="true"] { user-select: none; }
.menu-grid--marquee > [data-clone="true"] * { pointer-events: none; }

/* menuMarqueeRTL — управляется через JS-transform, CSS-анимация удалена */

@media (prefers-reduced-motion: reduce) {
  .menu-marquee { -webkit-mask-image: none; mask-image: none; }
}
@media (max-width: 900px) {
  .menu-grid--marquee .dish { width: clamp(260px, 70vw, 320px); }
  .menu-grid--marquee { animation-duration: 38s; }
}
@media (max-width: 600px) {
  .menu-grid--marquee .dish { width: clamp(240px, 80vw, 300px); }
  .menu-grid--marquee { animation-duration: 32s; }
}

/* ---------- Дым-машина в карточке дискошара ---------- */
.feature--smoke { position: relative; }
.feature__smoke {
  position: absolute;
  inset: auto 0 -10% 0;
  height: 70%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
  mix-blend-mode: screen;
}
.feature__smoke .puff {
  position: absolute;
  bottom: -30%;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    rgba(255,240,220,.22) 0%,
    rgba(196,146,98,.14) 35%,
    rgba(196,146,98,.05) 60%,
    transparent 75%);
  filter: blur(14px);
  opacity: 0;
  will-change: transform, opacity;
}
.feature__smoke .puff--1 { left: 10%;  width: 130px; height: 130px; animation: smokeRise 7.5s ease-in-out -0.0s infinite; }
.feature__smoke .puff--2 { left: 38%;  width: 95px;  height: 95px;  animation: smokeRise 9s   ease-in-out -2.4s infinite; }
.feature__smoke .puff--3 { left: 62%;  width: 140px; height: 140px; animation: smokeRise 8s   ease-in-out -4.8s infinite; }
.feature__smoke .puff--4 { left: 80%;  width: 100px; height: 100px; animation: smokeRise 10s  ease-in-out -6.2s infinite; }

@keyframes smokeRise {
  0%   { transform: translate3d(0, 0, 0) scale(.6);   opacity: 0; }
  15%  { opacity: .55; }
  55%  { opacity: .8; }
  100% { transform: translate3d(8%, -160%, 0) scale(1.6); opacity: 0; }
}

.feature--smoke > .feature__icon,
.feature--smoke > .feature__kicker,
.feature--smoke > .feature__title,
.feature--smoke > .feature__text { position: relative; z-index: 1; }

.feature--smoke:hover .feature__smoke .puff { animation-duration: 5.5s; }

@media (prefers-reduced-motion: reduce) {
  .feature__smoke .puff { animation: none; opacity: .3; bottom: 10%; }
}

/* ============================================================
   PROMO TEASER (тонкая лента под hero, якорь на блок акции)
   ============================================================ */
.promo-teaser {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: .6rem;
  padding: .8rem 1.4rem;
  background: linear-gradient(90deg,
    rgba(196,146,98,.18) 0%,
    rgba(241,217,176,.10) 50%,
    rgba(196,146,98,.18) 100%);
  border-top: 1px solid rgba(196,146,98,.28);
  border-bottom: 1px solid rgba(196,146,98,.28);
  color: var(--text);
  text-decoration: none;
  font-family: var(--font-text);
  font-size: .92rem;
  letter-spacing: .02em;
  text-align: center;
  transition: background 300ms var(--ease);
  position: relative;
  z-index: 5;
}
.promo-teaser:hover {
  background: linear-gradient(90deg,
    rgba(196,146,98,.28) 0%,
    rgba(241,217,176,.18) 50%,
    rgba(196,146,98,.28) 100%);
}
.promo-teaser__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--gold);
  animation: promo-pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes promo-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(196,146,98,.55); }
  50%      { box-shadow: 0 0 0 7px rgba(196,146,98,0); }
}
.promo-teaser__label {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  font-size: .72rem;
}
.promo-teaser__sep { color: var(--text-mute); }
.promo-teaser__text { color: var(--text-soft); }
.promo-teaser__cta { color: var(--gold); font-weight: 500; margin-left: .3rem; }
@media (max-width: 600px) {
  .promo-teaser { font-size: .82rem; padding: .7rem 1rem; gap: .45rem; }
  .promo-teaser__label { font-size: .66rem; }
}

/* Скрыто визуально, доступно скринридеру */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  overflow: hidden;
  white-space: nowrap;
}

/* ============================================================
   18+ ГЕЙТ
   ============================================================ */
.agegate {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(.6rem, 3vw, 1.5rem);
  overflow-y: auto;
}
.agegate-active .agegate { display: flex; }
.agegate-active body { overflow: hidden; }
.agegate-active .nav,
.agegate-active .side-rail,
.agegate-active main,
.agegate-active footer,
.agegate-active .hero,
.agegate-active section { filter: blur(8px); pointer-events: none; user-select: none; }
.agegate__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8,4,2,.92);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
}
.agegate__dialog {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  max-width: 440px;
  padding: clamp(1.4rem, 5vw, 2.4rem) clamp(1rem, 4vw, 1.8rem) clamp(1.2rem, 4vw, 1.8rem);
  background: linear-gradient(160deg, #1a1108 0%, #0d0905 100%);
  border: 1px solid rgba(196,146,98,.35);
  border-radius: 6px;
  text-align: center;
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
  overflow-wrap: break-word;
  word-break: break-word;
}
.agegate__title {
  overflow-wrap: break-word;
  word-break: break-word;
  font-size: clamp(1.4rem, 6vw, 2.2rem);
  line-height: 1.15;
}
.agegate__text { overflow-wrap: break-word; }
.agegate__brand {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 11vw, 3rem);
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 1.2rem;
}
.agegate__title { margin: .8rem 0 1rem; }
.agegate__text {
  color: var(--text-soft);
  font-size: .95rem;
  line-height: 1.55;
  margin: 0 0 1.6rem;
}
.agegate__actions {
  display: flex;
  flex-direction: column;
  gap: .7rem;
  margin-bottom: 1.4rem;
}
.agegate__actions .btn { width: 100%; }
.agegate__legal {
  font-size: .72rem;
  color: var(--text-mute);
  line-height: 1.5;
  margin: 0;
}
.agegate__legal a { color: var(--gold); }
.agegate--leaving { animation: agegate-leave .4s ease forwards; }
@keyframes agegate-leave {
  to { opacity: 0; transform: scale(.96); }
}

/* Экран блокировки — стилизованная 404 */
.agegate__dialog--blocked { text-align: center; }
.agegate__404 {
  font-family: var(--font-display);
  font-size: clamp(4.5rem, 14vw, 6.5rem);
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--gold);
  line-height: 1;
  margin-bottom: .8rem;
  background: linear-gradient(180deg, var(--gold) 0%, rgba(196,146,98,.4) 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 40px rgba(196,146,98,.25);
}

/* Полная блокировка сайта при отказе */
html.site-locked,
html.site-locked body { overflow: hidden !important; }
html.site-locked .agegate { display: flex !important; }
html.site-locked main,
html.site-locked .nav,
html.site-locked footer,
html.site-locked .side-rail,
html.site-locked .sticky-cta {
  pointer-events: none !important;
  user-select: none !important;
  filter: blur(12px) grayscale(.6) !important;
}

/* ============================================================
   ОТЗЫВЫ (REVIEWS)
   ============================================================ */
/* ---------- Бейдж рейтинга над отзывами ---------- */
.reviews__badge {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  max-width: 420px;
  margin: 2rem auto 0;
  padding: 1rem 1.4rem;
  background:
    radial-gradient(120% 100% at 0% 0%, rgba(196,146,98,.14) 0%, rgba(196,146,98,0) 60%),
    rgba(20,12,6,.55);
  border: 1px solid var(--gold-soft);
  border-radius: 6px;
  text-decoration: none;
  transition: border-color 250ms var(--ease), transform 300ms var(--ease);
}
.reviews__badge:hover { border-color: var(--gold); transform: translateY(-2px); }
.reviews__badge-score {
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  letter-spacing: .01em;
}
.reviews__badge-body { display: flex; flex-direction: column; gap: .3rem; }
.reviews__badge-stars {
  color: var(--gold);
  letter-spacing: .14em;
  font-size: 1.05rem;
  line-height: 1;
}
.reviews__badge-meta {
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.reviews {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.4rem;
  margin-top: 2.4rem;
}
.review {
  padding: 1.6rem 1.4rem;
  background: rgba(20,12,6,.55);
  border: 1px solid rgba(196,146,98,.22);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
.review__rating {
  display: flex;
  align-items: center;
  gap: .55rem;
  color: var(--gold);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
}
.review__stars { letter-spacing: .12em; font-size: 1.1rem; }
.review__text {
  font-size: .95rem;
  line-height: 1.6;
  color: var(--text);
  margin: 0;
  font-style: italic;
}
.review__author {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: .8rem;
  font-size: .78rem;
  color: var(--text-mute);
  letter-spacing: .12em;
  text-transform: uppercase;
  border-top: 1px solid rgba(196,146,98,.15);
  padding-top: .8rem;
  margin-top: auto;
}
.review__source { color: var(--gold); }
.reviews__cta {
  text-align: center;
  margin-top: 2.2rem;
}
.reviews__aggregate {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  padding: .8rem 1.4rem;
  background: rgba(0,0,0,.4);
  border: 1px solid rgba(196,146,98,.25);
  border-radius: 4px;
  margin-bottom: 1.2rem;
}
.reviews__aggregate-num {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
}
.reviews__aggregate-label {
  font-size: .74rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-soft);
  text-align: left;
}

/* ============================================================
   АДАПТИВНОСТЬ · v2 — расширенное покрытие
   - все актуальные смартфоны (320–500px) включая складные
   - планшеты (600–1024) в портрете и ландшафте
   - ноутбуки и десктопы (1280, 1600, 1920, 2200+)
   - тач-устройства, кросс-браузерные фоллбэки
   ============================================================ */

/* --- Базовая защита от горизонтального переполнения --- */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}
@supports (overflow: clip) {
  html, body { overflow-x: clip; }
}
img, video, iframe, svg, canvas, object, embed { max-width: 100%; }
iframe { width: 100%; }

/* Длинные ссылки/слова не должны выпирать (телефон, e-mail, max-ссылка) */
.contacts__value,
.contacts__sub,
.footer__col a,
.messenger-option__sub,
.faq__a-inner,
.feature__text {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Защита от схлопывания флекс-/грид-детей */
.feature, .dish, .menu-cat, .promo-card, .hall, .contacts__item,
.earlybird__body, .hall-solo__body, .footer__col {
  min-width: 0;
}

/* Кнопки и ссылки — корректный перенос на узких */
.btn { max-width: 100%; }

/* --- Fallback: нет backdrop-filter (старый Firefox, embedded webviews) --- */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .nav.is-scrolled         { background: rgba(0,0,0,.92); }
  .nav__menu               { background: #0d0905; }
  .hero__marquee           { background: rgba(0,0,0,.78); }
  .modal__backdrop         { background: rgba(8,4,2,.96); }
  .side-rail__icon,
  .side-rail__btn          { background: rgba(10,5,2,.94); }
  .hall__media-btn,
  .hall-solo__media-hint,
  .hall__price-tag,
  .gallery__nav,
  .gallery__counter,
  .dish__badge             { background: rgba(0,0,0,.78); }
}

/* --- Fallback: нет mask-image (Edge legacy, очень старый WebKit) --- */
@supports not ((mask-image: linear-gradient(black,black)) or (-webkit-mask-image: linear-gradient(black,black))) {
  .features--marquee,
  .menu-marquee { -webkit-mask-image: none; mask-image: none; }
}

/* --- Fallback: нет background-clip:text (золотой шиммер) --- */
@supports not ((background-clip: text) or (-webkit-background-clip: text)) {
  .eyebrow, .accent-italic,
  .feature__num, .dish__num,
  .atm-stat__num, .deposits__price {
    background: none;
    color: var(--gold);
    -webkit-text-fill-color: currentColor;
    animation: none;
  }
}

/* --- Тач-устройства: тапаемые цели ≥44×44px (WCAG / Apple HIG) --- */
@media (hover: none) and (pointer: coarse) {
  .btn { min-height: 44px; }
  .nav__burger { width: 44px; height: 44px; }
  .nav__link { padding: .75rem 0; }
  .side-rail__icon,
  .side-rail__btn { width: 44px; height: 44px; }
  .map-btn { min-height: 56px; padding: 1rem 1rem; }
  .faq__q { min-height: 56px; padding: 1.4rem 0; }
  .faq-wrap__summary { min-height: 56px; padding: 1.3rem 0; }
  .price-list__head { min-height: 52px; }
  .modal__close { width: 44px; height: 44px; font-size: 1.6rem; }
  .gallery__nav { width: 48px; height: 48px; font-size: 1.3rem; }
  .messenger-option { min-height: 64px; }
  .promo-carousel__dot { min-height: 32px; min-width: 44px; }
  .footer__col a { padding: .55rem 0; }
  /* Свободный вертикальный скролл сквозь карусели */
  .features--marquee { touch-action: pan-y; }
  .menu-marquee     { touch-action: pan-y; }
}

/* --- Большой десктоп / ультравайд: подтянем кегль и ширину --- */
@media (min-width: 1920px) {
  :root { --container: 1520px; }
  html  { font-size: 17.5px; }
  .hero { min-height: 90svh; }
}
@media (min-width: 2560px) {
  :root { --container: 1720px; }
  html  { font-size: 19px; }
}

/* --- Узкая полоса между десктопом и планшетом (1280–1024) --- */
@media (min-width: 1024px) and (max-width: 1279px) {
  .nav__menu { gap: 1.4rem; }
  .nav__link { font-size: .66rem; letter-spacing: .22em; }
  .features { gap: 1rem; }
}

/* --- Планшеты в портрете и ландшафте (900–768) --- */
@media (max-width: 900px) {
  #hookahs .features { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .promo-carousel    { max-width: 100%; }
  .booking__frame    { height: min(78vh, 720px); min-height: 540px; }
  .hero__inner       { max-width: 100%; }
  .hero__facts       { gap: .5rem 1.4rem; font-size: .86rem; }
  .modal__dialog--wide { max-width: 96vw; }
  .gallery           { aspect-ratio: 16 / 10; }
}

/* --- Большие телефоны / маленькие планшеты (600px) --- */
@media (max-width: 600px) {
  #hookahs .features { grid-template-columns: 1fr; }
  .booking__frame    { height: 78vh; min-height: 520px; max-height: 760px; }
  .nav__menu         { padding: 4.5rem 1.5rem 1.5rem; overflow-y: auto; -webkit-overflow-scrolling: touch; }
  .menu-cat          { padding: 1.3rem 1.1rem; }
  .menu-cat__list li { font-size: .88rem; line-height: 1.5; }
  .promo-card        { padding: 2rem 1.2rem 1.6rem; gap: 1.2rem; }
  .promo-card__count-main,
  .promo-card__count-bonus { font-size: clamp(3.6rem, 16vw, 5.4rem); }
  .promo-flavors__list li  { font-size: .82rem; padding: .45rem .9rem; }
  .promo-flavors           { margin-top: 2.2rem; padding-top: 1.6rem; }
  .atm-stat__value         { font-size: clamp(2rem, 8vw, 2.8rem); }
  .atm-stat__label         { font-size: .66rem; letter-spacing: .14em; }
  .price-list              { margin-top: 2.4rem; }
  .modal__dialog           { max-height: 94svh; max-height: 94vh; }
  .hero__cta .btn          { letter-spacing: .12em; }
  .hero__rule              { width: 56px; margin: 1rem 0 .8rem; }
  .earlybird__icon         { width: 44px; height: 44px; }
  .contacts__info          { padding: 1.6rem 1.2rem; gap: 1.1rem; }
  .footer__col h4          { font-size: .64rem; letter-spacing: .26em; }
  .footer__col p           { font-size: .85rem; }
  .footer                  { padding: 2.5rem 0 1.4rem; }
}

/* --- Тонкие телефоны (≤359px) — iPhone 5/SE 1, старые Android --- */
@media (max-width: 359px) {
  html { font-size: 14px; }
  :root { --gutter: .75rem; }

  .hero__title           { font-size: clamp(2.4rem, 13vw, 3.4rem); letter-spacing: .02em; }
  .h-1                   { font-size: clamp(1.7rem, 7vw, 2.2rem); }
  .h-2                   { font-size: clamp(1.3rem, 6vw, 1.7rem); }

  .nav__cta              { display: none; }

  .hero__cta .btn        { font-size: .62rem; padding: .9rem .8rem; letter-spacing: .14em; }
  .btn                   { padding: .9rem 1.1rem; font-size: .66rem; letter-spacing: .14em; }

  .feature               { padding: 1.3rem .95rem; }
  .feature__title        { font-size: 1.02rem; }
  .feature__icon         { width: 38px; height: 38px; }

  .price-list            { padding: 1.2rem .9rem; }
  .price-list__title     { font-size: .92rem; }
  .price-list__price     { font-size: 1.18rem; }
  .price-list__sub       { font-size: .76rem; }

  .menu-cat__title       { font-size: 1rem; }

  .contacts__value       { font-size: .96rem; }
  .contacts__info        { padding: 1.4rem 1rem; gap: 1rem; }
  .map-btn               { font-size: .68rem; padding: .85rem 1rem; }

  .modal__dialog         { padding: 1.8rem 1rem 1.2rem; }
  .modal__close          { width: 38px; height: 38px; top: .6rem; right: .6rem; }
  .modal__alt-buttons .btn { flex: 1 1 100%; }

  .footer__grid          { grid-template-columns: 1fr; gap: 1.2rem; }
  .footer__bottom        { font-size: .72rem; }

  .side-rail             { right: .6rem; bottom: .6rem; gap: .35rem; }
  .side-rail__icon,
  .side-rail__btn        { width: 38px; height: 38px; }

  .booking__frame        { height: 78vh; min-height: 460px; }

  .gallery__nav          { width: 36px; height: 36px; font-size: 1rem; }
  .gallery__counter      { font-size: .56rem; padding: .3rem .55rem; }
}

/* --- Очень узкие (≤280px) — складные в закрытом виде, нестандартные --- */
@media (max-width: 280px) {
  :root { --gutter: .55rem; }
  html  { font-size: 13px; }
  .hero__title         { font-size: 2rem; }
  .hero__lead          { font-size: .88rem; }
  .feature__title      { font-size: .98rem; }
  .feature__text       { font-size: .85rem; }
  .modal__dialog       { padding: 1.4rem .8rem 1rem; }
  .booking__frame      { min-height: 420px; }
}

/* --- Низкие экраны (телефон в ландшафте, складные внутри) --- */
@media (max-height: 480px) and (orientation: landscape) {
  .hero               { min-height: auto; padding: 4rem 0 2.4rem; }
  .hero__scroll       { display: none; }
  .hero__rule         { margin: 1rem 0 .8rem; }
  .nav__menu.is-open  { padding: 3.4rem 1rem 1rem; overflow-y: auto; gap: 1.3rem; -webkit-overflow-scrolling: touch; }
  .modal__dialog      { max-height: 94svh; max-height: 94vh; }
  .booking__frame     { height: 88svh; min-height: 0; }
  .section            { padding: 2.4rem 0; }
}

/* --- Hi-DPI / Retina: чуть резче рендер шрифта --- */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  body { text-rendering: optimizeLegibility; }
}

/* --- Динамический viewport: безопасный hero на iOS Safari 16+ --- */
@supports (height: 100dvh) {
  .hero { min-height: 100dvh; }
}

/* --- Forced colors / Windows High Contrast --- */
@media (forced-colors: active) {
  .btn          { border: 1px solid CanvasText; }
  .feature,
  .dish,
  .menu-cat,
  .price-list   { border-color: CanvasText; }
  .nav__link    { color: LinkText; }
}

/* --- Старые движки: gap внутри grid (Safari <14.1) --- */
@supports not (gap: 1rem) {
  .features,
  .footer__grid,
  .menu-cats__grid,
  .atm-stats,
  .menu-grid { grid-row-gap: 1rem; grid-column-gap: 1rem; }
}

/* --- Прицельные правки под низкие экраны iPhone SE2/SE3 в портрете (568×320 → 667×375) --- */
@media (max-width: 414px) and (max-height: 700px) {
  .hero__title  { font-size: clamp(2.6rem, 12vw, 3.4rem); }
  .hero__lead   { margin-bottom: 1.4rem; }
  .hero__rule   { margin: 1rem 0 .8rem; }
}

/* --- Side-rail: на мобильных не закрываем кнопку CTA «Забронировать» внизу --- */
@media (max-width: 600px) {
  .side-rail { gap: .4rem; }
}

/* --- Safari iOS: предотвращаем авто-zoom при фокусе в форму ---
   (Сейчас собственных форм нет, но Restoplace-iframe может рендерить инпуты —
    iframe рендерится в собственном контексте, поэтому правило здесь — задел.) */
input:not([type="checkbox"]):not([type="radio"]),
textarea,
select { font-size: max(16px, 1rem); }

/* --- Печать: компактный белый вид (расширение существующего) --- */
@media print {
  .hero { min-height: auto; padding: 1rem 0; }
  .hero__bg, .hero__marquee, .promo-glow, body::before, body::after { display: none !important; }
  .feature, .dish, .menu-cat, .price-list,
  .hall, .hall-solo, .earlybird, .atm-stat,
  .contacts, .footer { border-color: #333; box-shadow: none; background: white !important; color: black !important; }
  .accent-italic, .eyebrow, .feature__num, .dish__num, .atm-stat__num, .deposits__price {
    background: none; color: #555; -webkit-text-fill-color: currentColor;
  }
  a { color: #000 !important; text-decoration: underline; }
  .features--marquee, .menu-marquee { mask-image: none; -webkit-mask-image: none; }
  .features__track, .menu-grid--marquee { animation: none !important; transform: none !important; flex-wrap: wrap !important; width: auto !important; }
}

/* ============================================================
   ЛОГО В ШАПКЕ · фикс масштаба и переполнения
   - на узких экранах венюшный сабтайтл «Менделеевская» убираем
   - картинку дополнительно ужимаем под мобайл и складные
   ============================================================ */

/* На ≤1279px нет места для «· Менделеевская» рядом с лого + меню */
/* На планшетах и крупных телефонах лого ниже + колонка уже под бургер */
@media (max-width: 767px) {
  .nav__logo     { max-width: clamp(110px, 38vw, 160px); }
  .nav__logo-img { height: clamp(18px, 4.6vw, 24px); }
  .nav.is-scrolled .nav__logo-img { height: clamp(16px, 4vw, 22px); }
}

@media (max-width: 480px) {
  .nav__logo     { max-width: 140px; }
  .nav__logo-img { height: 20px; }
  .nav.is-scrolled .nav__logo-img { height: 18px; }
}

@media (max-width: 359px) {
  .nav__logo     { max-width: 120px; }
  .nav__logo-img { height: 18px; }
}

@media (max-width: 280px) {
  .nav__logo     { max-width: 100px; }
  .nav__logo-img { height: 16px; }
}

/* ============================================================
   АФИША · ФИНАЛ ЛЧ 30.05
   - Промо-постер в карточке Хет-трик
   - Модалка с афишей + CTA
   - Pulse-кнопка в side-rail (повторный просмотр после закрытия)
   ============================================================ */

/* Модалка афиши */
.modal__dialog--announce {
  max-width: 900px;
  max-height: 92svh;
  max-height: 92vh;
  padding: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  background: var(--bg);
  border: 1px solid var(--gold-soft);
  box-shadow: 0 50px 120px -30px rgba(0,0,0,.8), 0 0 0 1px rgba(196,146,98,.08);
}
.modal__dialog--announce .modal__close {
  top: 1rem; right: 1rem;
  z-index: 5;
  background: rgba(0,0,0,.55);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  border-color: rgba(196,146,98,.4);
  color: var(--text);
}
.modal__dialog--announce .modal__close:hover {
  background: var(--gold);
  color: #0a0a0a;
  border-color: var(--gold);
}

.announce {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  align-items: stretch;
  min-height: 480px;
}
.announce__poster {
  position: relative;
  background: #000;
  overflow: hidden;
  min-height: 100%;
}
.announce__poster picture,
.announce__poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: contrast(1.04) saturate(1.05);
}
.announce__poster::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(to right, transparent 70%, rgba(42,27,17,.5) 100%);
}

.announce__body {
  padding: clamp(1.8rem, 3vw, 2.6rem);
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  justify-content: center;
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(196,146,98,.12) 0%, rgba(196,146,98,0) 55%),
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg) 100%);
}
.announce__title {
  margin: .2rem 0 0;
  letter-spacing: .02em;
  line-height: 1.1;
}
.announce__match {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gold);
  margin: .4rem 0 0;
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}
.announce__match::before,
.announce__match::after {
  content: "";
  flex: 0 0 24px;
  height: 1px;
  background: var(--gold-soft);
}
.announce__facts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  padding: 1rem 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin: .6rem 0 .2rem;
  list-style: none;
}
.announce__facts li {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  align-items: flex-start;
  padding: 0 .6rem;
  border-right: 1px solid var(--hair);
}
.announce__facts li:first-child { padding-left: 0; }
.announce__facts li:last-child  { border-right: 0; padding-right: 0; }
.announce__facts-num {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: clamp(1.4rem, 2.4vw, 1.8rem);
  color: var(--gold);
  line-height: 1;
}
.announce__facts-lbl {
  font-family: var(--font-display);
  font-size: .62rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.announce__text {
  font-size: .96rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
  max-width: 44ch;
  text-wrap: pretty;
}
.announce__cta {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
  margin-top: .4rem;
}
.announce__cta .btn { min-width: 180px; }

@media (max-width: 820px) {
  .modal__dialog--announce { max-width: 96vw; }
  .announce { grid-template-columns: 1fr; min-height: 0; }
  .announce__poster { aspect-ratio: 16 / 11; max-height: 38svh; max-height: 38vh; }
  .announce__poster::after { background: linear-gradient(to bottom, transparent 65%, rgba(42,27,17,.6) 100%); }
  .announce__body { padding: 1.4rem 1.2rem 1.6rem; gap: .9rem; }
}
@media (max-width: 480px) {
  .announce__facts li { padding: 0 .35rem; }
  .announce__facts-num { font-size: 1.2rem; }
  .announce__facts-lbl { font-size: .56rem; letter-spacing: .18em; }
  .announce__cta .btn { flex: 1 1 100%; min-width: 0; }
  .announce__poster { aspect-ratio: 16 / 10; max-height: 34svh; max-height: 34vh; }
}

/* Кнопка-афиша в side-rail (появляется после закрытия модалки) */
.side-rail__announce {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  margin-bottom: .35rem;
  border: 1px solid var(--gold);
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(196,146,98,.22), rgba(196,146,98,.06));
  color: var(--gold);
  cursor: pointer;
  box-shadow: 0 14px 30px -16px var(--gold-glow), 0 0 0 1px rgba(196,146,98,.18);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px) scale(.9);
  transition: opacity 350ms var(--ease), transform 350ms var(--ease), visibility 0s linear 350ms,
              border-color 220ms var(--ease), color 220ms var(--ease), background 220ms var(--ease);
}
.side-rail__announce.is-pinned {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  transition: opacity 350ms var(--ease), transform 350ms var(--ease), visibility 0s linear 0s,
              border-color 220ms var(--ease), color 220ms var(--ease), background 220ms var(--ease);
}
.side-rail__announce:hover {
  background: var(--gold);
  color: #0a0a0a;
  transform: translateY(-1px) scale(1.04);
}
.side-rail__announce:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.side-rail__announce svg { display: block; }

.side-rail__announce-dot {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #E94545;
  border: 1.5px solid var(--bg);
  box-shadow: 0 0 8px rgba(233,69,69,.7);
}

.side-rail__announce-pulse {
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  border: 1.5px solid var(--gold);
  opacity: 0;
  pointer-events: none;
  animation: announce-pulse 2.2s cubic-bezier(.22,.61,.36,1) infinite;
}
@keyframes announce-pulse {
  0%   { transform: scale(.9);  opacity: .85; }
  70%  { transform: scale(1.45); opacity: 0; }
  100% { transform: scale(1.45); opacity: 0; }
}
.side-rail__announce:hover .side-rail__announce-pulse { animation-play-state: paused; opacity: 0; }
@media (prefers-reduced-motion: reduce) {
  .side-rail__announce-pulse { animation: none; }
}

/* ============================================================
   ЗАЩИТА ОТ ГОРИЗОНТАЛЬНОГО СКРОЛЛА
   ============================================================ */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}
img, video, iframe {
  max-width: 100%;
}
/* Слова не должны выезжать за экран на узких устройствах */
.hero__title, .h-1, .h-2, .feature__title, .hall__title,
.dish__title, .review__text, .faq__q, .footer__col h4 {
  overflow-wrap: anywhere;
  word-wrap: break-word;
}

/* ============================================================
   УЛЬТРА-УЗКИЕ ЭКРАНЫ (≤ 359px) — финальная подгонка
   ============================================================ */
@media (max-width: 359px) {
  :root { --gutter: .75rem; }
  .hero__title { font-size: clamp(2.6rem, 13vw, 3.8rem); }
  .promo-card__cta { min-width: 0; width: 100%; }
  .modal__dialog { padding: 1.8rem 1rem 1.4rem; }
  .modal__dialog--wide { padding: 1rem .8rem .8rem; }
  .modal__close { width: 36px; height: 36px; top: .6rem; right: .6rem; }
  .nav__logo-img { height: 38px; width: auto; }
  .side-rail__icon, .side-rail__btn { width: 34px; height: 34px; }
}

@media (max-width: 359px) {
  .side-rail__announce { width: 38px; height: 38px; }
  .side-rail__announce-dot { width: 7px; height: 7px; top: 3px; right: 3px; }
}

/* ============================================================
   FLOOR LOCK — заглушка над дропдауном залов Restoplace
   Скрыта: floor=4 в URL + watchdog в JS уже форсят Караоке зал,
   а сам дропдаун виджета сразу показывает "КАРАОКЕ ЗАЛ".
   Дополнительная плашка визуально дублирует и не нужна.
   ============================================================ */
.booking__frame { position: relative; }
.floor-lock { display: none !important; }

