/* ============================================================
   MENTAL QUEST — Главная таблица стилей
   ============================================================ */

/* ============================================================
   1. ПЕРЕМЕННЫЕ И СБРОС
   ============================================================ */
:root {
  --clr-bg:        #080808;
  --clr-bg-2:      #0d0d0d;
  --clr-bg-card:   #111111;
  --clr-bg-input:  #1a1a1a;
  --clr-red:       #c0392b;
  --clr-red-h:     #e74c3c;
  --clr-red-glow:  rgba(192,57,43,.28);
  --clr-red-line:  rgba(192,57,43,.15);
  --clr-text:      #e8e8e8;
  --clr-muted:     #808080;
  --clr-border:    #1e1e1e;
  --clr-white:     #ffffff;
  --font-h:        'Oswald', sans-serif;
  --font-b:        'Roboto', sans-serif;
  --radius:        8px;
  --radius-lg:     14px;
  --shadow:        0 8px 32px rgba(0,0,0,.55);
  --shadow-red:    0 8px 32px rgba(192,57,43,.35);
  --tr:            .3s cubic-bezier(.4,0,.2,1);
  --max-w:         1220px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  background: var(--clr-bg);
  color: var(--clr-text);
  font-family: var(--font-b);
  font-weight: 400;
  line-height: 1.65;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a  { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* ============================================================
   2. ТИПОГРАФИКА
   ============================================================ */
h1,h2,h3,h4 {
  font-family: var(--font-h);
  font-weight: 700;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: .03em;
}

/* ============================================================
   3. УТИЛИТЫ
   ============================================================ */
.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 24px;
}

.section { padding: 96px 0; }

.section__header {
  text-align: center;
  margin-bottom: 64px;
}
.section__pretitle {
  font-family: var(--font-h);
  font-size: .78rem;
  letter-spacing: .22em;
  color: var(--clr-red);
  margin-bottom: 12px;
}
.section__title {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 16px;
}
.section__subtitle {
  max-width: 560px;
  margin: 0 auto;
  color: var(--clr-muted);
  font-size: 1.05rem;
}

.accent { color: var(--clr-red); }
.link { color: var(--clr-red); text-decoration: underline; }

/* ============================================================
   4. КНОПКИ
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  font-family: var(--font-h);
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: var(--radius);
  transition: var(--tr);
  white-space: nowrap;
}
.btn--primary {
  background: var(--clr-red);
  color: var(--clr-white);
  box-shadow: 0 4px 18px rgba(192,57,43,.4);
}
.btn--primary:hover {
  background: var(--clr-red-h);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(192,57,43,.55);
}
.btn--outline {
  background: transparent;
  color: var(--clr-text);
  border: 1px solid var(--clr-border);
}
.btn--outline:hover {
  border-color: var(--clr-red);
  color: var(--clr-red);
}
.btn--large,
.btn--lg { padding: 16px 36px; font-size: 1rem; }
.btn--full { width: 100%; justify-content: center; }

/* ============================================================
   5. CANVAS ЧАСТИЦЫ
   ============================================================ */
#particles-canvas {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: .6;
}

/* ============================================================
   6. ХЕДЕР
   ============================================================ */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  transition: background var(--tr), box-shadow var(--tr);
  padding: 0;
  background: transparent;
}
.header.scrolled {
  background: rgba(8,8,8,.97);
  backdrop-filter: blur(14px);
  box-shadow: 0 2px 24px rgba(0,0,0,.6);
}

.nav {
  display: flex;
  align-items: center;
  gap: 32px;
  height: 72px;
}

.nav__logo {
  flex-shrink: 0;
  font-family: var(--font-h);
  font-size: 1.45rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.nav__logo-text { display: flex; align-items: center; gap: 2px; }

.nav__links {
  display: flex;
  gap: 8px;
  margin-left: auto;
}
.nav__link {
  font-family: var(--font-h);
  font-size: .85rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  padding: 6px 12px;
  border-radius: var(--radius);
  transition: var(--tr);
  text-shadow: 0 1px 10px rgba(0,0,0,1), 0 2px 20px rgba(0,0,0,1);
}
.nav__link:hover { color: var(--clr-red); }
.nav__link.accent { color: var(--clr-red); }

.nav__right {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}
.nav__phone {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-h);
  font-size: .85rem;
  letter-spacing: .1em;
  color: #fff;
  transition: var(--tr);
  text-shadow: 0 1px 10px rgba(0,0,0,1), 0 2px 20px rgba(0,0,0,1);
}
.nav__phone:hover { color: var(--clr-red); }
.nav__phone i { font-size: .8rem; }

.nav__burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 4px;
}
.nav__burger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--clr-text);
  border-radius: 2px;
  transition: var(--tr);
}
.nav__burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__burger.open span:nth-child(2) { opacity: 0; }
.nav__burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   7. HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  z-index: 1;
}

.hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 90% 60% at 50% 110%, rgba(130,5,5,.55) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 15% 50%, rgba(80,3,3,.25) 0%, transparent 45%),
    radial-gradient(ellipse 60% 40% at 85% 50%, rgba(80,3,3,.25) 0%, transparent 45%),
    linear-gradient(180deg, #030303 0%, #0a0202 50%, #030303 100%);
  animation: heroBreath 8s ease-in-out infinite;
}

@keyframes heroBreath {
  0%,100% { opacity: 1; }
  50%      { opacity: .75; }
}

/* Текстура поверх фона */
.hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='1' height='1' fill='rgba(255,255,255,0.015)'/%3E%3C/svg%3E");
  background-size: 4px 4px;
}

/* Фото-фон главной */
.hero__photo {
  position: absolute;
  inset: 0;
  background-image: url('/images/hotel/1.jpg');
  background-size: cover;
  background-position: center 30%;
  transform: scale(1.05);
  transition: transform 8s ease;
  will-change: transform;
}
.hero__photo-overlay {
  position: absolute;
  inset: 0;
  background:
    /* затемнение левой части — зона текста */
    linear-gradient(to right, rgba(0,0,0,.82) 0%, rgba(0,0,0,.6) 40%, rgba(0,0,0,.2) 70%, rgba(0,0,0,.1) 100%),
    /* плавный переход в чёрный снизу */
    linear-gradient(to top, rgba(5,5,5,1) 0%, rgba(5,5,5,.8) 20%, rgba(5,5,5,.2) 55%, transparent 100%),
    /* виньетка по краям */
    radial-gradient(ellipse 100% 100% at 50% 50%, transparent 40%, rgba(0,0,0,.65) 100%),
    /* красный акцент снизу */
    radial-gradient(ellipse 50% 25% at 30% 100%, rgba(100,5,5,.4) 0%, transparent 70%);
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(8,8,8,.3) 0%, transparent 40%, transparent 60%, rgba(8,8,8,.9) 100%);
}

.hero__container {
  position: relative;
  z-index: 2;
  padding-top: 120px;
  padding-bottom: 80px;
}

.hero__content { max-width: 740px; }

.hero__pretitle {
  font-family: var(--font-h);
  font-size: .8rem;
  letter-spacing: .24em;
  color: var(--clr-red);
  text-transform: uppercase;
  margin-bottom: 20px;
  opacity: 0;
  animation: fadeInUp .7s .2s forwards;
  text-shadow: 0 1px 12px rgba(0,0,0,1), 0 0 30px rgba(0,0,0,1);
}

/* Glitch effect */
.hero__title {
  font-size: clamp(3rem, 8vw, 6.5rem);
  line-height: 1;
  margin-bottom: 24px;
  position: relative;
  color: var(--clr-white);
  opacity: 0;
  animation: fadeInUp .7s .4s forwards;
  text-shadow: 0 2px 20px rgba(0,0,0,1), 0 4px 40px rgba(0,0,0,.9), 2px 2px 0 rgba(0,0,0,.8);
}
.hero__title::before,
.hero__title::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  font-family: var(--font-h);
  font-size: inherit;
  font-weight: 700;
  pointer-events: none;
}
.hero__title::before {
  color: #ff2020;
  clip-path: polygon(0 15%, 100% 15%, 100% 35%, 0 35%);
  animation: glitch1 6s infinite;
}
.hero__title::after {
  color: #00f0ff;
  clip-path: polygon(0 60%, 100% 60%, 100% 80%, 0 80%);
  animation: glitch2 6s infinite;
}

@keyframes glitch1 {
  0%,89%,100% { transform: translate(0); opacity: 0; }
  90%          { transform: translate(-4px, 1px); opacity: .9; }
  92%          { transform: translate(4px,-1px); opacity: .9; }
  94%          { transform: translate(-2px, 2px); opacity: .9; }
  96%          { transform: translate(0); opacity: 0; }
}
@keyframes glitch2 {
  0%,89%,100% { transform: translate(0); opacity: 0; }
  90%          { transform: translate(4px,-1px); opacity: .9; }
  92%          { transform: translate(-4px, 1px); opacity: .9; }
  94%          { transform: translate(2px,-2px); opacity: .9; }
  96%          { transform: translate(0); opacity: 0; }
}

.hero__subtitle {
  font-size: 1.15rem;
  color: #d0d0d0;
  margin-bottom: 40px;
  line-height: 1.75;
  opacity: 0;
  animation: fadeInUp .7s .6s forwards;
  text-shadow: 0 1px 12px rgba(0,0,0,1), 0 2px 24px rgba(0,0,0,1);
}

.hero__stats {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-bottom: 44px;
  opacity: 0;
  animation: fadeInUp .7s .8s forwards;
}
.hero__stat { text-align: center; }
.hero__stat-num {
  display: block;
  font-family: var(--font-h);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--clr-white);
  line-height: 1;
  text-shadow: 0 2px 16px rgba(0,0,0,1), 0 0 30px rgba(0,0,0,1);
}
.hero__stat-label {
  font-size: .78rem;
  color: #bbb;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: 4px;
  display: block;
  text-shadow: 0 1px 8px rgba(0,0,0,1);
}
.hero__stat-divider {
  width: 1px;
  height: 48px;
  background: var(--clr-border);
}

.hero__buttons {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeInUp .7s 1s forwards;
}

.hero__scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 2;
  opacity: .5;
}
.hero__scroll span {
  font-size: .68rem;
  letter-spacing: .2em;
  font-family: var(--font-h);
}
.hero__scroll-arrow {
  width: 20px;
  height: 20px;
  border-right: 2px solid var(--clr-muted);
  border-bottom: 2px solid var(--clr-muted);
  transform: rotate(45deg);
  animation: bounce 2s infinite;
}
@keyframes bounce {
  0%,100% { transform: rotate(45deg) translateY(0); }
  50%      { transform: rotate(45deg) translateY(6px); }
}

/* ============================================================
   8. КВЕСТ-КАРТОЧКИ
   ============================================================ */
.quests { background: var(--clr-bg-2); position: relative; z-index: 1; }

.quests__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.quest-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--clr-border);
  min-height: 620px;
  display: flex;
  flex-direction: column;
  transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
}
.quest-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-red);
  border-color: rgba(192,57,43,.4);
}

/* Фоновый градиент для каждого квеста */
.quest-card__bg {
  position: absolute;
  inset: 0;
  transition: transform .6s ease;
}
.quest-card:hover .quest-card__bg { transform: scale(1.04); }

.quest-card__bg--1 {
  background-color: #050e18;
  background-image:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(0,40,80,.55) 0%, transparent 70%),
    linear-gradient(155deg, rgba(12,30,48,.75) 0%, rgba(5,14,24,.5) 100%);
}
.quest-card__bg--1::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(255,255,255,.012) 3px, rgba(255,255,255,.012) 4px);
}
.quest-card__bg--1::after {
  content: '01';
  position: absolute;
  bottom: -30px;
  right: -12px;
  font-family: var(--font-h);
  font-size: 220px;
  font-weight: 700;
  color: rgba(255,255,255,.035);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.quest-card__bg--2 {
  background-color: #0a0403;
  background-image:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(100,10,0,.55) 0%, transparent 70%),
    linear-gradient(155deg, rgba(28,10,6,.75) 0%, rgba(16,6,5,.65) 50%, rgba(10,4,3,.5) 100%);
}
.quest-card__bg--2::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(255,100,0,.015) 3px, rgba(255,100,0,.015) 4px);
}
.quest-card__bg--2::after {
  content: '02';
  position: absolute;
  bottom: -30px;
  right: -12px;
  font-family: var(--font-h);
  font-size: 220px;
  font-weight: 700;
  color: rgba(255,100,0,.035);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

/* Нижний оверлей для читаемости */
.quest-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,5,5,.97) 0%, rgba(5,5,5,.6) 45%, rgba(5,5,5,.1) 100%);
}

.quest-card__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 28px;
}

.quest-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: auto;
}

.quest-card__genre {
  font-family: var(--font-h);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--clr-red);
  background: rgba(192,57,43,.15);
  border: 1px solid rgba(192,57,43,.3);
  padding: 5px 12px;
  border-radius: 4px;
}

.quest-card__difficulty {
  display: flex;
  gap: 3px;
}
.quest-card__difficulty i { font-size: .75rem; color: var(--clr-muted); }
.quest-card__difficulty i.fas { color: var(--clr-red); }

.quest-card__body { padding-top: 220px; margin-bottom: 24px; }

.quest-card__title {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  color: var(--clr-white);
  margin-bottom: 16px;
  text-shadow: 0 2px 12px rgba(0,0,0,.8);
}

.quest-card__desc {
  font-size: .93rem;
  color: #aaa;
  line-height: 1.7;
}

.quest-card__params {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 24px;
  padding: 16px;
  background: rgba(0,0,0,.4);
  border-radius: var(--radius);
  border: 1px solid var(--clr-border);
}

.quest-param {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .88rem;
  color: var(--clr-muted);
}
.quest-param i { color: var(--clr-red); font-size: .85rem; width: 14px; text-align: center; }
.quest-param--price { color: var(--clr-text); font-weight: 500; }

.quest-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.quest-card__address {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: .82rem;
  color: var(--clr-muted);
}
.quest-card__address i { color: var(--clr-red); font-size: .75rem; }

/* ============================================================
   9. КАК ЭТО РАБОТАЕТ
   ============================================================ */
.how-it-works { background: var(--clr-bg); }

.steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
}

.step {
  flex: 1;
  text-align: center;
  padding: 0 24px;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s ease, transform .6s ease;
}
.step.visible {
  opacity: 1;
  transform: translateY(0);
}
.step:nth-child(1) { transition-delay: 0s; }
.step:nth-child(3) { transition-delay: .15s; }
.step:nth-child(5) { transition-delay: .3s; }
.step:nth-child(7) { transition-delay: .45s; }

.step__number {
  font-family: var(--font-h);
  font-size: .72rem;
  letter-spacing: .2em;
  color: var(--clr-red);
  margin-bottom: 16px;
}

.step__icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 1.5rem;
  color: var(--clr-red);
  transition: var(--tr);
}
.step:hover .step__icon {
  background: var(--clr-red);
  color: var(--clr-white);
  box-shadow: var(--shadow-red);
  border-color: var(--clr-red);
}

.step__title {
  font-size: 1.1rem;
  margin-bottom: 10px;
  color: var(--clr-white);
}
.step__desc { font-size: .88rem; color: var(--clr-muted); }

.step__connector {
  flex-shrink: 0;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, var(--clr-red) 0%, rgba(192,57,43,.2) 100%);
  margin-top: 50px;
  position: relative;
}
.step__connector::after {
  content: '';
  position: absolute;
  right: -5px;
  top: -4px;
  width: 0;
  height: 0;
  border-left: 8px solid rgba(192,57,43,.5);
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}

/* ============================================================
   10. О НАС
   ============================================================ */
.about { background: var(--clr-bg-2); }

.about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.about__content.visible,
.about__stats.visible {
  opacity: 1;
  transform: translateY(0);
}
.about__content,
.about__stats {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .7s ease, transform .7s ease;
}
.about__stats { transition-delay: .2s; }

.about__content .section__title { text-align: left; margin-bottom: 20px; font-size: 2.2rem; }
.about__content .section__pretitle { text-align: left; }

.about__text {
  color: var(--clr-muted);
  font-size: .97rem;
  line-height: 1.8;
  margin-bottom: 16px;
}

.about__features { margin-top: 28px; display: flex; flex-direction: column; gap: 10px; }
.about__feature {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .92rem;
  color: var(--clr-text);
}
.about__feature i { color: var(--clr-red); font-size: .8rem; }

.about__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.about__stat-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 28px 20px;
  text-align: center;
  transition: var(--tr);
}
.about__stat-card:hover {
  border-color: var(--clr-red);
  box-shadow: inset 0 0 24px var(--clr-red-glow);
}
.about__stat-num {
  font-family: var(--font-h);
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--clr-white);
  line-height: 1;
}
.about__stat-plus {
  font-family: var(--font-h);
  font-size: 2rem;
  color: var(--clr-red);
  line-height: 1;
  margin-left: 3px;
}
.about__stat-top {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0;
  margin-bottom: 6px;
}
.about__stat-label { display: block; font-size: .78rem; color: var(--clr-muted); letter-spacing: .05em; }

/* ============================================================
   11. ФУТЕР
   ============================================================ */
.footer {
  background: #050505;
  border-top: 1px solid var(--clr-border);
  padding: 64px 0 0;
  position: relative;
  z-index: 1;
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--clr-border);
}

.footer__logo {
  font-family: var(--font-h);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 12px;
}

.footer__tagline { font-size: .88rem; color: var(--clr-muted); margin-bottom: 24px; }

.social { display: flex; gap: 12px; }
.social__link {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-muted);
  font-size: 1rem;
  transition: var(--tr);
}
.social__link:hover { background: var(--clr-red); border-color: var(--clr-red); color: var(--clr-white); transform: translateY(-3px); }

.footer__nav-title {
  font-family: var(--font-h);
  font-size: .78rem;
  letter-spacing: .18em;
  color: var(--clr-muted);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.footer__nav ul { display: flex; flex-direction: column; gap: 10px; }
.footer__nav a {
  font-size: .9rem;
  color: var(--clr-muted);
  transition: var(--tr);
}
.footer__nav a:hover { color: var(--clr-red); }

.footer__contact-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .88rem;
  color: var(--clr-muted);
  margin-bottom: 12px;
}
.footer__contact-item i { color: var(--clr-red); font-size: .85rem; margin-top: 3px; width: 14px; text-align: center; }
.footer__contact-item a:hover { color: var(--clr-red); }

.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
  font-size: .82rem;
  color: var(--clr-muted);
}

/* ============================================================
   12. МОДАЛЬНОЕ ОКНО БРОНИРОВАНИЯ
   ============================================================ */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0,0,0,.85);
  backdrop-filter: blur(6px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  overflow-y: auto;
}
.modal-overlay.open { display: flex; animation: overlayIn .25s ease; }
@keyframes overlayIn { from { opacity: 0; } to { opacity: 1; } }

.modal {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 40px;
  width: 100%;
  max-width: 560px;
  position: relative;
  animation: modalIn .3s cubic-bezier(.4,0,.2,1);
  max-height: 90vh;
  overflow-y: auto;
}
/* Расширенный модал для iframe */
.modal--crm { max-width: 620px; }
.modal--crm.crm-expanded { max-width: 860px; padding: 28px 28px 20px; }

.modal__subtitle {
  color: var(--clr-muted);
  font-size: .95rem;
  margin-bottom: 28px;
  margin-top: -8px;
}

/* Кнопки выбора квеста */
.crm-quest-buttons { display: flex; flex-direction: column; gap: 14px; }
.crm-quest-btn {
  display: flex;
  align-items: center;
  gap: 20px;
  width: 100%;
  background: var(--clr-bg-2);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 20px 24px;
  cursor: pointer;
  transition: var(--tr);
  text-align: left;
  position: relative;
  overflow: hidden;
}
.crm-quest-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(192,57,43,.08) 0%, transparent 60%);
  opacity: 0;
  transition: var(--tr);
}
.crm-quest-btn:hover { border-color: rgba(192,57,43,.5); transform: translateX(4px); }
.crm-quest-btn:hover::before { opacity: 1; }
.crm-quest-btn__num {
  font-family: var(--font-h);
  font-size: 1.8rem;
  font-weight: 700;
  color: rgba(192,57,43,.3);
  line-height: 1;
  flex-shrink: 0;
  width: 40px;
}
.crm-quest-btn__name {
  font-family: var(--font-h);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--clr-white);
  line-height: 1.25;
  flex: 1;
}
.crm-quest-btn__genre {
  font-size: .75rem;
  color: var(--clr-red);
  font-family: var(--font-h);
  letter-spacing: .14em;
  text-transform: uppercase;
  flex-shrink: 0;
}
.crm-quest-btn__arrow {
  color: var(--clr-muted);
  font-size: .9rem;
  flex-shrink: 0;
  transition: var(--tr);
}
.crm-quest-btn:hover .crm-quest-btn__arrow { color: var(--clr-red); transform: translateX(4px); }

/* Кнопка назад */
.crm-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: 1px solid var(--clr-border);
  color: var(--clr-muted);
  font-family: var(--font-h);
  font-size: .8rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 7px 14px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: var(--tr);
  margin-bottom: 20px;
}
.crm-back-btn:hover { color: var(--clr-white); border-color: rgba(255,255,255,.2); }

/* QR оплата */
.qr-payment { display: flex; flex-direction: column; align-items: center; gap: 20px; }

.qr-amount {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(192,57,43,.1);
  border: 1px solid rgba(192,57,43,.25);
  border-radius: var(--radius);
  padding: 14px 28px;
  width: 100%;
  justify-content: center;
}
.qr-amount__label { font-size: .85rem; color: var(--clr-muted); font-family: var(--font-h); letter-spacing: .1em; text-transform: uppercase; }
.qr-amount__value { font-family: var(--font-h); font-size: 1.8rem; font-weight: 700; color: var(--clr-white); }

.qr-code-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  background: var(--clr-bg-2);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 24px;
  width: 100%;
}
.qr-canvas-wrap {
  width: 220px;
  height: 220px;
  background: #fff;
  padding: 10px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.qr-canvas-wrap img,
.qr-canvas-wrap canvas {
  display: block;
  width: 200px !important;
  height: 200px !important;
}
.qr-hint {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .85rem;
  color: var(--clr-muted);
  text-align: center;
  line-height: 1.5;
}
.qr-hint i { color: var(--clr-red); font-size: 1.1rem; flex-shrink: 0; }
.qr-sbp-badge {
  position: absolute;
  top: 12px; right: 14px;
  background: linear-gradient(135deg, #1a5aab, #00a0e3);
  color: #fff;
  font-family: var(--font-h);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  padding: 4px 10px;
  border-radius: 6px;
}

.qr-mobile-wrap { display: flex; flex-direction: column; align-items: center; gap: 12px; width: 100%; }
.qr-pay-btn { font-size: 1rem; gap: 10px; }
.qr-mobile-hint { font-size: .82rem; color: var(--clr-muted); text-align: center; line-height: 1.5; }

.qr-info {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .82rem;
  color: var(--clr-muted);
  background: var(--clr-bg-2);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 12px 16px;
  line-height: 1.55;
  width: 100%;
}
.qr-info i { color: var(--clr-red); flex-shrink: 0; margin-top: 2px; }

/* Модал бронирования CRM */
.modal--crm-booking { max-width: 860px; padding: 28px 28px 20px; }
.modal--crm-booking .modal__title { margin-bottom: 16px; }

/* iframe обёртка */
.crm-iframe-wrap {
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  overflow: hidden;
  background: #fff;
}
.crm-iframe-wrap iframe {
  display: block;
  width: 100%;
  height: 560px;
  border: none;
}
@keyframes modalIn {
  from { opacity: 0; transform: translateY(24px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.modal__close {
  position: absolute;
  top: 16px; right: 16px;
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  color: var(--clr-muted);
  font-size: 1rem;
  transition: var(--tr);
  background: var(--clr-bg-input);
}
.modal__close:hover { color: var(--clr-white); background: var(--clr-red); }

.modal__progress {
  display: flex;
  align-items: center;
  margin-bottom: 32px;
}
.modal__progress-step {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--clr-bg-input);
  border: 2px solid var(--clr-border);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-h);
  font-size: .85rem;
  color: var(--clr-muted);
  transition: var(--tr);
  flex-shrink: 0;
}
.modal__progress-step.active { border-color: var(--clr-red); background: var(--clr-red); color: #fff; }
.modal__progress-step.done  { border-color: var(--clr-red); background: transparent; color: var(--clr-red); }
.modal__progress-line {
  flex: 1;
  height: 2px;
  background: var(--clr-border);
  transition: var(--tr);
}
.modal__progress-line.done { background: var(--clr-red); }

.modal__title {
  font-size: 1.5rem;
  margin-bottom: 28px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.modal__step { display: none; }
.modal__step.active { display: block; animation: stepIn .3s ease; }
@keyframes stepIn { from { opacity: 0; transform: translateX(12px); } to { opacity: 1; transform: translateX(0); } }

.modal__buttons {
  display: flex;
  gap: 12px;
  margin-top: 28px;
}
.modal__buttons .btn--primary { flex: 1; justify-content: center; }

/* ============================================================
   13. ФОРМЫ
   ============================================================ */
.form-group { margin-bottom: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-label {
  display: block;
  font-size: .8rem;
  font-family: var(--font-h);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--clr-muted);
  margin-bottom: 8px;
}

.form-control {
  width: 100%;
  background: var(--clr-bg-input);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--clr-text);
  font-size: .95rem;
  transition: var(--tr);
  appearance: none;
  -webkit-appearance: none;
}
.form-control:focus {
  outline: none;
  border-color: var(--clr-red);
  box-shadow: 0 0 0 3px var(--clr-red-glow);
}
.form-control.error { border-color: #e74c3c; }
.form-control::placeholder { color: #555; }
textarea.form-control { resize: vertical; min-height: 100px; }
select.form-control { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23808080' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
select.form-control option { background: #1a1a1a; }

.form-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .88rem;
  color: var(--clr-muted);
  cursor: pointer;
  line-height: 1.5;
}
.form-check input[type="checkbox"] {
  width: 18px; height: 18px;
  border: 1px solid var(--clr-border);
  background: var(--clr-bg-input);
  border-radius: 4px;
  flex-shrink: 0;
  margin-top: 2px;
  cursor: pointer;
  accent-color: var(--clr-red);
}

/* Временны́е слоты */
.time-slots { display: flex; flex-wrap: wrap; gap: 8px; }
.time-slot {
  padding: 8px 16px;
  background: var(--clr-bg-input);
  border: 1px solid var(--clr-border);
  border-radius: 6px;
  font-family: var(--font-h);
  font-size: .9rem;
  color: var(--clr-muted);
  cursor: pointer;
  transition: var(--tr);
}
.time-slot:hover { border-color: var(--clr-red); color: var(--clr-text); }
.time-slot.selected { background: var(--clr-red); border-color: var(--clr-red); color: #fff; }
.time-slots__hint { font-size: .85rem; color: var(--clr-muted); font-style: italic; }

/* Сводка бронирования */
.booking-summary {
  background: var(--clr-bg-input);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 20px;
  margin-bottom: 20px;
  font-size: .9rem;
}
.booking-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--clr-border);
}
.booking-summary__row:last-child { border-bottom: none; }
.booking-summary__label { color: var(--clr-muted); font-size: .82rem; }
.booking-summary__value { font-family: var(--font-h); font-size: .95rem; text-align: right; }

/* Капча */
.captcha {
  display: flex;
  align-items: center;
  gap: 12px;
}
.captcha__question {
  font-family: var(--font-h);
  font-size: 1.3rem;
  color: var(--clr-white);
  background: var(--clr-bg-input);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 10px 18px;
  white-space: nowrap;
  flex-shrink: 0;
}
.captcha__equals { font-size: 1.3rem; color: var(--clr-muted); }
.captcha__input { max-width: 100px; text-align: center; font-size: 1.1rem; }

/* Успех */
.booking-success {
  text-align: center;
  padding: 20px 0;
}
.booking-success__icon {
  font-size: 4rem;
  color: #27ae60;
  margin-bottom: 16px;
  animation: popIn .4s cubic-bezier(.4,0,.2,1);
}
@keyframes popIn { from { transform: scale(0); } to { transform: scale(1); } }
.booking-success__title { font-size: 1.8rem; margin-bottom: 12px; }
.booking-success__text { color: var(--clr-muted); margin-bottom: 24px; line-height: 1.7; }
.booking-success__details {
  background: var(--clr-bg-input);
  border-radius: var(--radius);
  padding: 16px;
  margin-bottom: 24px;
  font-size: .9rem;
  color: var(--clr-muted);
  text-align: left;
  line-height: 2;
}

/* ============================================================
   14. СТРАНИЦА КОНТАКТОВ
   ============================================================ */
.page-hero {
  position: relative;
  padding: 160px 0 80px;
  background:
    radial-gradient(ellipse 80% 50% at 50% 100%, rgba(120,5,5,.4) 0%, transparent 60%),
    linear-gradient(180deg, #030303 0%, #0a0202 100%);
  text-align: center;
  z-index: 1;
}
.page-hero__pretitle { font-family: var(--font-h); font-size: .8rem; letter-spacing: .22em; color: var(--clr-red); margin-bottom: 12px; }
.page-hero__title { font-size: clamp(2.5rem, 5vw, 4rem); }

.contacts-section { background: var(--clr-bg-2); }

.contacts__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 64px;
}

.contact-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 32px;
  transition: var(--tr);
}
.contact-card:hover { border-color: rgba(192,57,43,.4); box-shadow: var(--shadow-red); }
.contact-card__title {
  font-size: 1.2rem;
  margin-bottom: 8px;
}
.contact-card__quest { font-size: .8rem; color: var(--clr-red); letter-spacing: .1em; margin-bottom: 20px; font-family: var(--font-h); }
.contact-card__info { display: flex; flex-direction: column; gap: 12px; }
.contact-card__row { display: flex; align-items: center; gap: 10px; font-size: .9rem; color: var(--clr-muted); }
.contact-card__row i { color: var(--clr-red); width: 16px; text-align: center; }
.contact-card__row a:hover { color: var(--clr-red); }

.map-wrapper {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--clr-border);
  margin-bottom: 64px;
}
.map-wrapper iframe { display: block; filter: invert(.85) hue-rotate(180deg); }

.feedback-section { background: var(--clr-bg); }
.feedback__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: start; }
.feedback__info .section__title { text-align: left; margin-bottom: 16px; font-size: 2rem; }
.feedback__info .section__pretitle { text-align: left; }
.feedback__text { color: var(--clr-muted); font-size: .95rem; line-height: 1.8; margin-bottom: 24px; }
.feedback__contacts { display: flex; flex-direction: column; gap: 14px; }
.feedback__contact-row { display: flex; align-items: center; gap: 12px; font-size: .92rem; color: var(--clr-muted); }
.feedback__contact-row i { color: var(--clr-red); width: 18px; text-align: center; }
.feedback__contact-row a:hover { color: var(--clr-red); }

.feedback-form {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 40px;
}
.feedback-form .form-success {
  display: none;
  text-align: center;
  padding: 20px 0;
  color: #27ae60;
}
.feedback-form .form-success i { font-size: 2.5rem; margin-bottom: 12px; display: block; }
.feedback-form .form-success.show { display: block; }

/* ============================================================
   15. АНИМАЦИИ
   ============================================================ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.animate-on-scroll {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .65s ease, transform .65s ease;
}
.animate-on-scroll.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Разделитель с декором */
.divider {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0 auto 64px;
  max-width: 200px;
}
.divider::before, .divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--clr-border);
}
.divider__icon { color: var(--clr-red); font-size: .9rem; }

/* Лоадер на кнопке */
.btn.loading { pointer-events: none; opacity: .7; }
.btn.loading::after {
  content: '';
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .6s linear infinite;
  margin-left: 8px;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   16. СКРОЛЛБАР
   ============================================================ */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--clr-bg); }
::-webkit-scrollbar-thumb { background: #333; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--clr-red); }

/* ============================================================
   17. АДАПТИВ — 1200px (ноутбук)
   ============================================================ */
@media (max-width: 1200px) {
  .about__grid { gap: 48px; }
  .footer__grid { grid-template-columns: 1.5fr 1fr 1fr 1.4fr; gap: 28px; }
  .hero__container { padding-top: 100px; }
  .quest-pricing__grid { gap: 18px; }
}

/* ============================================================
   18. АДАПТИВ — 992px (планшет горизонтально)
   ============================================================ */
@media (max-width: 992px) {
  .section { padding: 72px 0; }
  .section__header { margin-bottom: 48px; }

  /* Хедер / навигация */
  .nav__links {
    display: none;
    flex-direction: column;
    gap: 0;
    position: fixed;
    top: 72px; left: 0; right: 0;
    background: rgba(8,8,8,.98);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--clr-border);
    padding: 8px 0 16px;
    z-index: 999;
  }
  .nav__links.open { display: flex; }
  .nav__link { padding: 14px 24px; border-radius: 0; font-size: .95rem; }
  .nav__phone { display: none; }
  .nav__burger { display: flex; }
  .nav__cta { display: none; }

  /* Hero */
  .hero__container { padding-top: 100px; padding-bottom: 60px; }

  /* О нас */
  .about__grid { grid-template-columns: 1fr; gap: 40px; }
  .about__stats { grid-template-columns: repeat(4, 1fr); }
  .about__content .section__title { font-size: 2rem; }

  /* Квест-карточки */
  .quests__grid { gap: 16px; }
  .quest-card { min-height: 520px; }

  /* Футер */
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 28px; }

  /* Контакты */
  .contacts__grid { grid-template-columns: 1fr; gap: 24px; }
  .feedback__grid { grid-template-columns: 1fr; gap: 40px; }

  /* Страница квеста */
  .quest-story__grid { grid-template-columns: 1fr; gap: 40px; }
  .quest-pricing__grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .quest-page-hero { padding-bottom: 48px; }
}

/* ============================================================
   19. АДАПТИВ — 768px (планшет вертикально)
   ============================================================ */
@media (max-width: 768px) {
  .section { padding: 56px 0; }
  .section__header { margin-bottom: 40px; }
  .container { padding: 0 16px; }

  /* Hero главной */
  .hero__container { padding-top: 88px; padding-bottom: 48px; }
  .hero__content { max-width: 100%; }
  .hero__subtitle { font-size: 1rem; }
  .hero__stats { gap: 16px; flex-wrap: wrap; justify-content: center; }
  .hero__stat { text-align: center; }
  .hero__stat-num { font-size: 2rem; }
  .hero__stat-divider { height: 32px; }
  .hero__buttons { flex-direction: column; gap: 12px; }
  .hero__buttons .btn { justify-content: center; }

  /* Квест-карточки */
  .quests__grid { grid-template-columns: 1fr; max-width: 500px; margin-left: auto; margin-right: auto; }
  .quest-card { min-height: 480px; }

  /* Как работает */
  .steps { flex-direction: column; align-items: center; gap: 24px; }
  .step { padding: 0 16px; max-width: 320px; }
  .step__connector {
    width: 2px; height: 36px;
    background: linear-gradient(180deg, var(--clr-red) 0%, rgba(192,57,43,.2) 100%);
    margin: 0 auto;
  }
  .step__connector::after {
    right: -4px; top: auto; bottom: -5px;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 8px solid rgba(192,57,43,.5);
    border-bottom: none;
  }

  /* О нас */
  .about__stats { grid-template-columns: 1fr 1fr; }

  /* Футер */
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .footer__bottom { flex-direction: column; gap: 8px; text-align: center; }

  /* Формы и модалы */
  .modal { padding: 24px 16px; border-radius: var(--radius); }
  .modal--crm-booking { padding: 20px 16px 16px; }
  .crm-iframe-wrap iframe { height: 480px; }
  .form-row { grid-template-columns: 1fr; }
  .modal__buttons { flex-direction: column; }
  .feedback-form { padding: 24px 16px; }

  /* QR модал */
  .qr-code-wrap { padding: 20px; }
  .qr-canvas-wrap img,
  .qr-canvas-wrap canvas { width: 180px !important; height: 180px !important; }

  /* Страница квеста — hero */
  .quest-page-hero { min-height: 55vh; padding-bottom: 40px; }
  .quest-page-hero__title { font-size: clamp(2rem, 8vw, 3.2rem); margin-bottom: 20px; }
  .quest-page-hero__params { gap: 16px; margin-bottom: 28px; }
  .quest-page-hero__param-sep { display: none; }
  .quest-page-hero__param-val { font-size: 1.25rem; }
  .quest-page-hero__actions { gap: 12px; }
  .quest-page-hero__actions .btn { flex: 1; justify-content: center; }

  /* Галерея */
  .quest-gallery__grid { grid-template-columns: 1fr 1fr; }
  .gallery-item--wide { grid-column: span 2; }
  .gallery-item--tall { grid-row: span 1; }
  .hotel-gallery { grid-template-columns: 1fr 1fr; }
  .hotel-gallery__col--center { display: none; }
  .hotel-gallery__col:not(.hotel-gallery__col--center) .hotel-gallery__item { height: 180px; }

  /* CTA квеста */
  .quest-cta-section { padding: 64px 0; }
  .quest-cta-section .section__subtitle { font-size: .95rem; }

  /* Отзывы */
  .reviews__grid { grid-template-columns: 1fr; }
  .reviews__summary { gap: 24px; padding: 20px 16px; }
  .reviews__sep { display: none; }
}

/* ============================================================
   20. АДАПТИВ — 480px (смартфон)
   ============================================================ */
@media (max-width: 480px) {
  .section { padding: 48px 0; }
  .container { padding: 0 14px; }

  /* Hero */
  .hero__pretitle { font-size: .7rem; letter-spacing: .16em; }
  .hero__subtitle { font-size: .95rem; }
  .hero__stats { gap: 12px; justify-content: center; }
  .reviews__grid { grid-template-columns: 1fr; }
  .hero__stat-num { font-size: 1.8rem; }
  .hero__stat-divider { height: 28px; }

  /* Кнопки */
  .btn--large, .btn--lg { padding: 14px 22px; font-size: .88rem; }
  .btn { white-space: normal; text-align: center; }

  /* Квест-карточки */
  .quest-card { min-height: 440px; }
  .quest-card__params { grid-template-columns: 1fr 1fr; gap: 8px; }
  .quest-card__footer { flex-direction: column; align-items: stretch; gap: 10px; }
  .quest-card__footer .btn { width: 100%; justify-content: center; }
  .quest-card__content { padding: 20px 16px 20px; }

  /* О нас */
  .about__stat-num { font-size: 2.1rem; }
  .about__stats { grid-template-columns: 1fr 1fr; gap: 10px; }
  .about__stat-card { padding: 18px 12px; }

  /* Футер */
  .footer__grid { grid-template-columns: 1fr; gap: 28px; }

  /* Формы */
  .captcha { flex-wrap: wrap; }
  .feedback-form { padding: 20px 14px; }

  /* Страница квеста */
  .quest-page-hero { min-height: auto; padding-top: 100px; padding-bottom: 32px; }
  .quest-page-hero__params { gap: 12px; }
  .quest-page-hero__param-val { font-size: 1.15rem; }
  .quest-page-hero__actions { flex-direction: column; }
  .quest-page-hero__actions .btn { width: 100%; justify-content: center; }

  /* Галерея */
  .quest-gallery__grid { grid-template-columns: 1fr; }
  .gallery-item--wide, .gallery-item--tall { grid-column: span 1; grid-row: span 1; }
  .hotel-gallery { grid-template-columns: 1fr; }
  .hotel-gallery__col:not(.hotel-gallery__col--center) .hotel-gallery__item { height: 200px; }

  /* Цены */
  .price-card { padding: 24px 16px; }
  .price-card__price { font-size: 2.2rem; }

  /* Модалы */
  .modal { padding: 20px 14px; }
  .modal--crm-booking { padding: 16px 12px; }
  .crm-iframe-wrap iframe { height: 420px; }
  .modal__overlay { padding: 8px; }

  /* QR */
  .qr-payment { padding: 16px; gap: 14px; }
  .qr-amount { flex-direction: column; gap: 4px; align-items: flex-start; }
  .qr-canvas-wrap img,
  .qr-canvas-wrap canvas { width: 160px !important; height: 160px !important; }

  /* CRM кнопки */
  .crm-quest-btn { padding: 16px 14px; }
  .crm-quest-btn__name { font-size: 1.05rem; }

  /* CTA */
  .quest-cta-section { padding: 48px 0; }
  .quest-cta-section div[style*="display:flex"] { flex-direction: column; }
  .quest-cta-section .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   21. АДАПТИВ — 360px (маленький смартфон)
   ============================================================ */
@media (max-width: 360px) {
  .container { padding: 0 12px; }
  .nav__logo-text { font-size: 1.2rem; }
  .hero__stat-num { font-size: 1.6rem; }
  .about__stat-num { font-size: 1.8rem; }
  .about__stat-card { padding: 14px 10px; }
  .quest-card__title { font-size: 1.5rem; }
  .quest-page-hero__title { font-size: 2rem; }
  .price-card { padding: 18px 12px; }
  .price-card__price { font-size: 1.9rem; }
  .btn { font-size: .82rem; padding: 12px 16px; }
  .btn--lg, .btn--large { padding: 13px 18px; }
}

/* ============================================================
   ПРОДАЮЩИЕ УЛУЧШЕНИЯ — ВИЗУАЛ 1000/10
   ============================================================ */

/* ── Промо-полоска ── */
.promo-bar {
  position: relative;
  z-index: 1001;
  background: linear-gradient(90deg, #6b0000 0%, #c0392b 50%, #6b0000 100%);
  overflow: hidden;
  padding: 0;
}
.promo-bar__track {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  padding: 10px 24px;
  white-space: nowrap;
  font-family: var(--font-h);
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #fff;
}
.promo-bar__sep { opacity: .4; }
.promo-bar__code {
  display: inline-block;
  background: rgba(0,0,0,.3);
  border: 1px solid rgba(255,255,255,.35);
  padding: 1px 10px;
  border-radius: 4px;
  font-weight: 700;
  letter-spacing: .2em;
  margin-left: 8px;
}
.promo-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.12) 50%, transparent 100%);
  animation: promoShine 3.5s linear infinite;
}
@keyframes promoShine {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* ── Коридор-фон героя (SVG) ── */
.hero__corridor-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero__light-anim { animation: flickerLight 5s infinite; }
.hero__glow-anim  { animation: glowPulse 6s ease-in-out infinite; }

@keyframes flickerLight {
  0%,100% { opacity: 1; }
  5%       { opacity: .88; }
  10%      { opacity: 1; }
  28%      { opacity: .92; }
  30%      { opacity: .55; }
  31%      { opacity: 1; }
  44%      { opacity: .85; }
  46%      { opacity: .4; }
  48%      { opacity: 1; }
  82%      { opacity: .9; }
  84%      { opacity: .7; }
  86%      { opacity: 1; }
}
@keyframes glowPulse {
  0%,100% { opacity: .7; }
  50%      { opacity: 1; }
}

/* ── Сканлайны поверх героя ── */
.hero__scanlines {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background-image: repeating-linear-gradient(
    0deg,
    rgba(0,0,0,.07) 0px,
    rgba(0,0,0,.07) 1px,
    transparent 1px,
    transparent 4px
  );
}

/* ── Film-grain canvas ── */
#grain-canvas {
  position: fixed;
  inset: 0;
  z-index: 9990;
  pointer-events: none;
  opacity: .045;
  mix-blend-mode: overlay;
}

/* ── Промо-бейдж над заголовком ── */
.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: rgba(192,57,43,.14);
  border: 1px solid rgba(192,57,43,.45);
  color: var(--clr-red);
  font-family: var(--font-h);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 6px 18px;
  border-radius: 50px;
  margin-bottom: 22px;
  opacity: 0;
  animation: fadeInUp .7s .1s forwards;
}
.hero__badge::before {
  content: '';
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--clr-red);
  flex-shrink: 0;
  animation: dotPulse 1.5s infinite;
}
@keyframes dotPulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .5; transform: scale(.8); }
}

/* ── Улучшение: blood-drip декор под заголовком ── */
.hero__drip {
  display: flex;
  justify-content: flex-start;
  gap: 20px;
  margin-bottom: 20px;
  opacity: 0;
  animation: fadeInUp .7s .45s forwards;
}
.hero__drip-line {
  width: 2px;
  border-radius: 2px;
  background: linear-gradient(to bottom, var(--clr-red), transparent);
  animation: drip 3s ease-in-out infinite;
}
.hero__drip-line:nth-child(1) { height: 28px; animation-delay: 0s; }
.hero__drip-line:nth-child(2) { height: 18px; animation-delay: .4s; }
.hero__drip-line:nth-child(3) { height: 36px; animation-delay: .8s; }
.hero__drip-line:nth-child(4) { height: 22px; animation-delay: .2s; }
.hero__drip-line:nth-child(5) { height: 32px; animation-delay: .6s; }
@keyframes drip {
  0%,100% { height: var(--h, 28px); opacity: .7; }
  50%      { height: calc(var(--h, 28px) + 8px); opacity: 1; }
}

/* ── Urgency strip под статистикой ── */
.hero__urgency {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(192,57,43,.12);
  border: 1px solid rgba(192,57,43,.3);
  border-radius: 8px;
  padding: 8px 16px;
  font-size: .82rem;
  color: #e88;
  margin-bottom: 28px;
  opacity: 0;
  animation: fadeInUp .7s .95s forwards;
}
.hero__urgency i { color: var(--clr-red); }

/* ── Карточка квеста: улучшения ── */
.quest-card { transform-style: preserve-3d; perspective: 1200px; }

.quest-badge {
  position: absolute;
  top: 0; right: 0;
  background: linear-gradient(135deg, #e84800, #c0392b);
  color: #fff;
  font-family: var(--font-h);
  font-size: .68rem;
  letter-spacing: .15em;
  padding: 7px 16px 7px 14px;
  text-transform: uppercase;
  z-index: 5;
  clip-path: polygon(12px 0%, 100% 0%, 100% 100%, 0% 100%);
  animation: badgePulse 2.5s ease-in-out infinite;
}
@keyframes badgePulse {
  0%,100% { box-shadow: none; }
  50%      { box-shadow: 0 0 18px rgba(232,72,0,.5); }
}

.quest-availability {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .8rem;
  color: #6dbe6d;
  margin-top: 12px;
}
.quest-availability__dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #6dbe6d;
  animation: dotPulse 1.5s ease-in-out infinite;
}

/* ── Секция отзывов ── */
.reviews { background: var(--clr-bg-2); }

.reviews__summary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 56px;
  padding: 36px 40px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.reviews__big-score {
  font-family: var(--font-h);
  font-size: 5.5rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.reviews__stars-row { display: flex; gap: 5px; margin-bottom: 6px; }
.reviews__star-icon { color: #e8a020; font-size: 1.3rem; }
.reviews__star-count { font-size: .84rem; color: var(--clr-muted); }
.reviews__sep { width: 1px; height: 60px; background: var(--clr-border); }
.reviews__metric { text-align: center; }
.reviews__metric-val { font-family: var(--font-h); font-size: 2.2rem; color: #fff; }
.reviews__metric-label { font-size: .8rem; color: var(--clr-muted); margin-top: 4px; }

.reviews__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.review-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 32px 32px 28px;
  position: relative;
  overflow: hidden;
  transition: var(--tr);
}
.review-card::before {
  content: '"';
  position: absolute;
  top: 10px; left: 22px;
  font-size: 6rem;
  line-height: 1;
  font-family: Georgia, serif;
  color: rgba(192,57,43,.12);
  user-select: none;
}
.review-card:hover {
  border-color: rgba(192,57,43,.35);
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(0,0,0,.55), 0 0 0 1px rgba(192,57,43,.15);
}
.review-card__stars { display: flex; gap: 3px; margin-bottom: 14px; }
.review-card__star  { color: #e8a020; font-size: .88rem; }
.review-card__text  {
  font-size: .96rem;
  color: #aaa;
  line-height: 1.75;
  margin-bottom: 22px;
  font-style: italic;
}
.review-card__author { display: flex; align-items: center; gap: 13px; }
.review-card__avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clr-red), #7a0000);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-h);
  font-size: 1rem; font-weight: 700;
  color: #fff; flex-shrink: 0;
}
.review-card__name  { font-weight: 500; font-size: .93rem; }
.review-card__quest { font-size: .76rem; color: var(--clr-red); font-family: var(--font-h); letter-spacing: .08em; margin-top: 2px; }

/* ── Плавающая кнопка ── */
.float-btn {
  position: fixed;
  bottom: 32px; right: 32px;
  z-index: 1500;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease;
}
.float-btn.visible { opacity: 1; pointer-events: all; }

.float-btn__book {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--clr-red);
  color: #fff;
  padding: 14px 26px;
  border-radius: 50px;
  font-family: var(--font-h);
  font-size: .88rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  box-shadow: 0 8px 32px rgba(192,57,43,.5);
  transition: var(--tr);
  animation: floatPulse 2.5s ease-in-out infinite;
}
.float-btn__book:hover {
  background: var(--clr-red-h);
  transform: translateY(-3px) scale(1.04);
  box-shadow: 0 14px 44px rgba(192,57,43,.65);
}
.float-btn__call {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  color: var(--clr-text);
  padding: 10px 20px;
  border-radius: 50px;
  font-size: .85rem;
  cursor: pointer;
  text-decoration: none;
  transition: var(--tr);
  box-shadow: 0 4px 20px rgba(0,0,0,.45);
}
.float-btn__call:hover { border-color: var(--clr-red); color: var(--clr-red); }

@keyframes floatPulse {
  0%,100% { box-shadow: 0 8px 32px rgba(192,57,43,.5); }
  50%      { box-shadow: 0 8px 48px rgba(192,57,43,.75), 0 0 0 10px rgba(192,57,43,.08); }
}

/* ── Декоративный разделитель ── */
.section-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--clr-red), transparent);
  opacity: .35;
  margin: 0;
}

/* ============================================================
   СТРАНИЦЫ КВЕСТОВ (outlast.php / belward.php)
   ============================================================ */

/* Hero квеста */
.quest-page-hero {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  padding-bottom: 64px;
}
.quest-page-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.05);
  transition: transform 8s ease;
}
.quest-page-hero__bg--outlast {
  background:
    radial-gradient(ellipse 80% 60% at 50% 110%, rgba(0,40,80,.6) 0%, transparent 70%),
    linear-gradient(155deg, #0c1e30 0%, #091624 50%, #050e18 100%);
}
.quest-page-hero__bg--belward {
  background:
    radial-gradient(ellipse 60% 40% at 30% 60%, rgba(140,60,0,.18) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 75% 40%, rgba(180,20,0,.1) 0%, transparent 50%),
    linear-gradient(170deg, #0d0808 0%, #100606 30%, #0a0404 60%, #050202 100%);
}

/* Мерцающие световые пятна */
.belward-light {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(80px);
  animation: belwardFlicker 4s ease-in-out infinite;
}
.belward-light--1 {
  width: 460px; height: 320px;
  top: 10%; left: 15%;
  background: radial-gradient(ellipse, rgba(200,120,30,.22) 0%, transparent 70%);
  animation-duration: 5.5s;
  animation-delay: 0s;
}
.belward-light--2 {
  width: 300px; height: 400px;
  bottom: 5%; right: 12%;
  background: radial-gradient(ellipse, rgba(160,20,0,.18) 0%, transparent 70%);
  animation-duration: 7s;
  animation-delay: -2.5s;
}
@keyframes belwardFlicker {
  0%,100% { opacity: 1;   transform: scale(1); }
  20%      { opacity: .6;  transform: scale(.97); }
  40%      { opacity: .9;  transform: scale(1.02); }
  60%      { opacity: .5;  transform: scale(.96); }
  80%      { opacity: .85; transform: scale(1.01); }
}

/* Сканлайны-полосы */
.belward-scanlines {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 3px,
      rgba(0,0,0,.18) 3px,
      rgba(0,0,0,.18) 4px
    );
  z-index: 1;
}
.quest-page-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,5,5,.98) 0%, rgba(5,5,5,.6) 50%, rgba(5,5,5,.2) 100%);
}
.quest-page-hero__content {
  position: relative;
  z-index: 2;
}
.quest-page-hero__genre {
  font-family: var(--font-h);
  font-size: .75rem;
  letter-spacing: .22em;
  color: var(--clr-red);
  text-transform: uppercase;
  margin-bottom: 16px;
  display: block;
}
.quest-page-hero__title {
  font-size: clamp(2.8rem, 6vw, 5.5rem);
  color: var(--clr-white);
  margin-bottom: 32px;
  text-shadow: 0 4px 24px rgba(0,0,0,.8);
}
.quest-page-hero__params {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.quest-page-hero__param {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.quest-page-hero__param-label {
  font-size: .72rem;
  color: var(--clr-muted);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-family: var(--font-h);
}
.quest-page-hero__param-val {
  font-family: var(--font-h);
  font-size: 1.5rem;
  color: var(--clr-white);
  font-weight: 700;
}
.quest-page-hero__param-sep {
  width: 1px;
  background: var(--clr-border);
  align-self: stretch;
}
.quest-page-hero__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

/* Галерея */
.quest-gallery { background: var(--clr-bg); }
.quest-gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: 12px;
}
.gallery-item {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  cursor: pointer;
  transition: var(--tr);
}
.gallery-item:hover { transform: scale(1.02); box-shadow: var(--shadow-red); border-color: rgba(192,57,43,.4); }
.gallery-item--wide { grid-column: span 2; }
.gallery-item--tall { grid-row: span 2; }

.gallery-item__inner {
  width: 100%;
  padding-top: 66%;
  position: relative;
}
.gallery-item--wide .gallery-item__inner { padding-top: 44%; }
.gallery-item--tall .gallery-item__inner { padding-top: 145%; }

.gallery-item__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Плейсхолдер (до загрузки фото) */
.gallery-item__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: var(--clr-border);
  font-size: .8rem;
  font-family: var(--font-h);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.gallery-item__placeholder i { font-size: 2rem; color: #2a2a2a; }

/* Masonry-галерея отеля */
.hotel-gallery {
  display: grid;
  grid-template-columns: 1fr 1.4fr 1fr;
  gap: 12px;
  align-items: start;
}
.hotel-gallery__col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.hotel-gallery__item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--clr-border);
  cursor: pointer;
  background: var(--clr-bg-card);
  transition: var(--tr);
}
.hotel-gallery__item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.hotel-gallery__col:not(.hotel-gallery__col--center) .hotel-gallery__item {
  height: 220px;
}
.hotel-gallery__item--main {
  height: calc(220px * 2 + 12px); /* 2 карточки + gap */
}
.hotel-gallery__item:hover img { transform: scale(1.07); }
.hotel-gallery__item:hover { border-color: rgba(192,57,43,.5); box-shadow: 0 8px 32px rgba(0,0,0,.6), 0 0 0 1px rgba(192,57,43,.2); }
.hotel-gallery__zoom {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(5,5,5,.5);
  opacity: 0;
  transition: opacity .3s ease;
  font-size: 1.6rem;
  color: #fff;
}
.hotel-gallery__item:hover .hotel-gallery__zoom { opacity: 1; }

/* hotel-gallery responsive: см. секцию 19–20 выше */

/* Лайтбокс */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.95);
  z-index: 5000;
  display: none;
  align-items: center;
  justify-content: center;
}
.lightbox.open { display: flex; animation: overlayIn .2s ease; }
.lightbox__img { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: var(--radius); }
.lightbox__close {
  position: absolute;
  top: 20px; right: 24px;
  font-size: 1.8rem;
  color: #fff;
  cursor: pointer;
  background: rgba(0,0,0,.5);
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: var(--tr);
}
.lightbox__close:hover { background: var(--clr-red); }

/* Описание квеста */
.quest-story { background: var(--clr-bg-2); }
.quest-story__grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: start; }

.quest-story__intro {
  font-size: 1.08rem;
  color: var(--clr-muted);
  line-height: 1.9;
  margin-bottom: 28px;
  border-left: 3px solid var(--clr-red);
  padding-left: 20px;
  font-style: italic;
}
.quest-story__text {
  font-size: .97rem;
  color: var(--clr-muted);
  line-height: 1.85;
  margin-bottom: 16px;
}

/* Особенности */
.quest-features__list { display: flex; flex-direction: column; gap: 14px; margin-top: 8px; }
.quest-feature {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  font-size: .92rem;
  color: var(--clr-text);
  line-height: 1.5;
  transition: var(--tr);
}
.quest-feature:hover { border-color: rgba(192,57,43,.3); }
.quest-feature i { color: var(--clr-red); font-size: .9rem; flex-shrink: 0; margin-top: 3px; width: 16px; text-align: center; }

/* Возраст */
.age-cards { display: flex; flex-direction: column; gap: 10px; margin-top: 28px; }
.age-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  font-size: .9rem;
  color: var(--clr-muted);
}
.age-card__badge {
  font-family: var(--font-h);
  font-size: .8rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  flex-shrink: 0;
}
.age-card--12 .age-card__badge { background: rgba(39,174,96,.15); color: #4cae6c; border: 1px solid rgba(39,174,96,.3); }
.age-card--16 .age-card__badge { background: rgba(230,126,34,.15); color: #e67e22; border: 1px solid rgba(230,126,34,.3); }
.age-card--18 .age-card__badge { background: rgba(192,57,43,.15); color: var(--clr-red); border: 1px solid rgba(192,57,43,.3); }

/* Цена */
.quest-pricing-section { background: var(--clr-bg); }
.quest-pricing__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.price-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 32px;
  text-align: center;
  transition: var(--tr);
}
.price-card:hover { border-color: rgba(192,57,43,.4); box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.price-card--featured { border-color: rgba(192,57,43,.4); background: linear-gradient(135deg, #141414, #1a0d0d); }
.price-card__label { font-family: var(--font-h); font-size: .75rem; letter-spacing: .2em; color: var(--clr-muted); margin-bottom: 12px; }
.price-card__price { font-family: var(--font-h); font-size: 3rem; font-weight: 700; color: var(--clr-white); line-height: 1; margin-bottom: 8px; }
.price-card__sub  { font-size: .84rem; color: var(--clr-muted); margin-bottom: 20px; line-height: 1.6; }
.price-card__note {
  display: inline-block;
  background: rgba(192,57,43,.12);
  border: 1px solid rgba(192,57,43,.25);
  color: var(--clr-red);
  font-size: .8rem;
  padding: 6px 14px;
  border-radius: 6px;
  font-family: var(--font-h);
  letter-spacing: .08em;
}

/* Предоплата */
.prepay-notice {
  margin-top: 32px;
  padding: 20px 24px;
  background: rgba(192,57,43,.08);
  border: 1px solid rgba(192,57,43,.2);
  border-radius: var(--radius);
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: .9rem;
  color: var(--clr-muted);
  line-height: 1.65;
}
.prepay-notice i { color: var(--clr-red); font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }

/* CTA секция */
.quest-cta-section {
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(100,10,0,.4) 0%, transparent 60%),
    var(--clr-bg-2);
  text-align: center;
  padding: 100px 0;
}
.quest-cta-section .section__title { margin-bottom: 16px; }
.quest-cta-section .section__subtitle { margin-bottom: 40px; }

/* ============================================================
   КАРТОЧКА «В РАЗРАБОТКЕ»
   ============================================================ */

/* Сетка квестов (2 активных + WIP-карточки) */
.quests__grid--3 { grid-template-columns: 1fr 1fr; }

/* Фон WIP-карточки */
.quest-card__bg--wip {
  background:
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(60,60,60,.5) 0%, transparent 70%),
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,.012) 0px, rgba(255,255,255,.012) 1px,
      transparent 1px, transparent 8px
    ),
    linear-gradient(160deg, #111 0%, #0a0a0a 100%);
}

/* Бейдж «Скоро» */
.quest-badge--wip {
  background: linear-gradient(135deg, #444, #222);
  border: 1px solid #555;
  color: #aaa;
}

/* Полупрозрачный оверлей с иконкой */
.quest-card__wip-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.quest-card__wip-icon {
  width: 80px; height: 80px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.4);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem;
  color: rgba(255,255,255,.25);
  animation: wipPulse 3s ease-in-out infinite;
}
@keyframes wipPulse {
  0%,100% { opacity: .6; transform: scale(1); }
  50%      { opacity: 1;  transform: scale(1.08); }
}

/* Знак вопроса вместо названия */
.quest-card__title--wip {
  font-size: 3.5rem;
  letter-spacing: .15em;
  color: rgba(255,255,255,.2);
  text-shadow: 0 0 40px rgba(255,255,255,.08);
  animation: wipGlow 3s ease-in-out infinite;
}
@keyframes wipGlow {
  0%,100% { color: rgba(255,255,255,.18); }
  50%      { color: rgba(255,255,255,.32); }
}

/* Прогресс-бар */
.quest-card__wip-progress {
  margin-bottom: 24px;
  padding: 14px 16px;
  background: rgba(0,0,0,.4);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
}
.wip-progress__label {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-h);
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--clr-muted);
  margin-bottom: 10px;
}
.wip-progress__dots span {
  animation: wipDot 1.4s infinite;
  opacity: 0;
}
.wip-progress__dots span:nth-child(1) { animation-delay: 0s; }
.wip-progress__dots span:nth-child(2) { animation-delay: .2s; }
.wip-progress__dots span:nth-child(3) { animation-delay: .4s; }
@keyframes wipDot {
  0%,80%,100% { opacity: 0; }
  40%          { opacity: 1; }
}
.wip-progress__bar {
  height: 4px;
  background: rgba(255,255,255,.08);
  border-radius: 2px;
  overflow: hidden;
}
.wip-progress__fill {
  height: 100%;
  width: 40%;
  background: linear-gradient(90deg, #444, #888);
  border-radius: 2px;
  animation: wipFill 4s ease-in-out infinite;
}
@keyframes wipFill {
  0%   { width: 35%; }
  50%  { width: 55%; }
  100% { width: 35%; }
}

/* WIP карточка не поднимается при ховере */
.quest-card--wip:hover {
  transform: none;
  box-shadow: none;
  border-color: #2a2a2a;
}
.quest-card--wip:hover .quest-card__bg { transform: none; }

/* Адаптив WIP-сетки */
@media (max-width: 600px) {
  .quests__grid--3 { grid-template-columns: 1fr; }
}

/* ============================================================
   QUEST-PAGE RESPONSIVE OVERRIDES
   (определены ПОСЛЕ базовых стилей, чтобы корректно перекрывать их)
   ============================================================ */

/* 992px — планшет */
@media (max-width: 992px) {
  .quest-story__grid { grid-template-columns: 1fr; gap: 40px; }
  .quest-pricing__grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .quest-page-hero { padding-bottom: 48px; }
}

/* 768px — планшет вертикально */
@media (max-width: 768px) {
  .quest-page-hero { min-height: 55vh; padding-bottom: 40px; }
  .quest-page-hero__title {
    font-size: clamp(2rem, 8vw, 3.2rem);
    margin-bottom: 20px;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .quest-page-hero__params { gap: 16px; margin-bottom: 28px; }
  .quest-page-hero__param-sep { display: none; }
  .quest-page-hero__param-val { font-size: 1.25rem; }
  .quest-page-hero__actions { gap: 12px; }
  .quest-page-hero__actions .btn { flex: 1; justify-content: center; }
  .quest-gallery__grid { grid-template-columns: 1fr 1fr; }
  .gallery-item--wide { grid-column: span 2; }
  .gallery-item--tall { grid-row: span 1; }
  .hotel-gallery { grid-template-columns: 1fr 1fr; }
  .hotel-gallery__col--center { display: none; }
  .hotel-gallery__col:not(.hotel-gallery__col--center) .hotel-gallery__item { height: 180px; }
  .quest-cta-section { padding: 64px 0; }
}

/* 480px — смартфон */
@media (max-width: 480px) {
  .quest-page-hero {
    min-height: auto;
    padding-top: 100px;
    padding-bottom: 32px;
    align-items: flex-start;
  }
  .quest-page-hero .container { padding-top: 0; }
  .quest-page-hero__title {
    font-size: clamp(1.8rem, 7vw, 2.4rem);
    margin-bottom: 16px;
    word-break: break-word;
  }
  .quest-page-hero__params { gap: 12px; flex-wrap: wrap; }
  .quest-page-hero__param-val { font-size: 1.15rem; }
  .quest-page-hero__actions { flex-direction: column; }
  .quest-page-hero__actions .btn { width: 100%; justify-content: center; }
  .quest-gallery__grid { grid-template-columns: 1fr; }
  .gallery-item--wide, .gallery-item--tall { grid-column: span 1; grid-row: span 1; }
  .hotel-gallery { grid-template-columns: 1fr; }
  .hotel-gallery__col:not(.hotel-gallery__col--center) .hotel-gallery__item { height: 200px; }
  .price-card { padding: 24px 16px; }
  .price-card__price { font-size: 2.2rem; }
  .quest-cta-section { padding: 48px 0; }
}

/* 360px — маленький смартфон */
@media (max-width: 360px) {
  .quest-page-hero__title { font-size: 1.7rem; }
}

/* ============================================================
   СЕКЦИЯ РЕЙТИНГОВ (виджеты агрегаторов)
   ============================================================ */
.ratings-section {
  background: var(--clr-bg);
  padding-top: 72px;
  padding-bottom: 72px;
}
.ratings-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 40px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.rating-widget-item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 32px;
  border-right: 1px solid var(--clr-border);
  transition: background var(--tr), opacity var(--tr);
  flex: 1;
  min-width: 180px;
}
.rating-widget-item:last-child {
  border-right: none;
}
.rating-widget-item:hover {
  background: rgba(255,255,255,.04);
  opacity: .85;
}
.rating-widget-item img {
  height: 72px;
  width: auto;
  max-width: 100%;
  display: block;
  object-fit: contain;
}

/* Адаптив рейтингов */
@media (max-width: 992px) {
  .rating-widget-item { flex: 1 1 calc(50% - 1px); border-right: none; border-bottom: 1px solid var(--clr-border); }
  .rating-widget-item:nth-child(odd) { border-right: 1px solid var(--clr-border); }
  .rating-widget-item:last-child,
  .rating-widget-item:nth-last-child(2):nth-child(odd) { border-bottom: none; }
}
@media (max-width: 480px) {
  .rating-widget-item { flex: 1 1 calc(50% - 1px); padding: 16px 12px; }
  .rating-widget-item img { height: 54px; }
}
@media (max-width: 360px) {
  .rating-widget-item { flex: 1 1 100%; border-right: none; border-bottom: 1px solid var(--clr-border); }
  .rating-widget-item:last-child { border-bottom: none; }
}

/* ============================================================
   TOUCH / iOS — дополнительные фиксы
   ============================================================ */
@media (hover: none) and (pointer: coarse) {
  /* Убираем hover-анимации на тач-устройствах */
  .quest-card:hover { transform: none; }
  .quest-card:hover .quest-card__bg { transform: none; }
  .btn--primary:hover { transform: none; }
  .gallery-item:hover { transform: none; }
  .hotel-gallery__item:hover img { transform: none; }
  /* Минимальный tap-target */
  .btn, .nav__link, .social__link { min-height: 44px; }
  .social__link { min-width: 44px; }
}

/* iOS Safari: фикс 100vh */
@supports (-webkit-touch-callout: none) {
  .hero { min-height: -webkit-fill-available; }
}

/* Улучшенный скролл для iframe на мобильных */
.crm-iframe-wrap { -webkit-overflow-scrolling: touch; overflow-y: auto; }

