@font-face{ font-family:'Roboto'; src:local(''), url('/fonts/Roboto-Regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face{ font-family:'Roboto'; src:local(''), url('/fonts/Roboto-Medium.woff2') format('woff2');  font-weight:500; font-style:normal; font-display:swap; }
@font-face{ font-family:'Roboto'; src:local(''), url('/fonts/Roboto-Bold.woff2') format('woff2');    font-weight:700; font-style:normal; font-display:swap; }
@font-face{ font-family:'Roboto'; src:local(''), url('/fonts/Roboto-Black.woff2') format('woff2');  font-weight:900; font-style:normal; font-display:swap; }

html, body{
  font-family:'Roboto', system-ui, 'Segoe UI', Arial, sans-serif;
  font-synthesis:none; /* без синтетической жирности */
}


:root{
  --yellow:#ffd33d;
  --orange:#ff6a3d;
  --black:#111;
  --text:#1d1d1f;
  --white:#fff;
  --container:1180px;
  --cta-start:#FF9F2E; --cta-mid:#FF834B; --cta-end:#FF6E61;
  --cta-shadow:rgba(255,110,97,.22); --cta-shadow-hover:rgba(255,110,97,.26);
}

/* Типографическая карта весов под подключенные файлы */
strong, b { font-weight:700; }
em, i { font-style:italic; }

/* Глобальная типографическая шкала */

/* База: обычный текст */
body, p, li, .card__meta, .gallery__subtitle, .form__muted {
  font-weight: 400;
}

/* Лёгкий акцент: описания под заголовками, вводные */
.about__text p,
.projects__subtitle,
.gallery__subtitle,
h1 + p, h2 + p, h1 + .subtitle, h2 + .subtitle {
  font-weight: 500;
}

/* Жирный: заметные подписи и элементы интерфейса */
strong, b,
.logo__text, .phone, .contacts__label, .form__label,
.quiz__opt, .quiz__status {
  font-weight: 700;
}

/* Сверхжирный: крупные заголовки, цены, CTA, названия карточек */
h1, h2,
.pretitle, .title,
.videos__title, .about__title, .structure__title, .projects__title, .gallery__title, .contacts__title,
.card__title, .card__price,
.btn-topbar, .btn-lg, .btn-orange,
.card__actions .btn-cta,
.quiz__title,
.form__submit,
.form__success-title {
  font-weight: 900;
}

/* === Фикс "худых" текстов === */

/* 1) Слоган в шапке */
.slogan{
  font-weight: 700 !important; 
  font-synthesis: none;
}

/* 2) Подзаголовок под главным заголовком (форма/призыв) */
.subtitle,
.hero .subtitle,
.form__subtitle,
.modal__subtitle,
.quiz__hint {
  font-weight: 500 !important;
  font-synthesis: none;
}

/* 3) Метаданные/характеристики в карточках проектов (Площадь, Габариты) */
.card__meta,
.card__meta p,
.card__body .card__meta {
  font-weight: 500 !important;  
  font-synthesis: none;
}

/* 4) Подзаголовки секций/описания под H1/H2 (включая Посмотрите фото) */
h1 + p,
h2 + p,
.section__subtitle,
.projects__subtitle,
.gallery__subtitle,
.about__text p,
.gallery .gallery__subtitle {
  font-weight: 500 !important;  
  font-synthesis: none;
}


*{box-sizing:border-box}
html, body { overflow-x: hidden; }

body{
  margin:0;
  font-family:'Roboto', system-ui, 'Segoe UI', Arial, 'Helvetica Neue', sans-serif;
  color:var(--text);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.container{max-width:calc(var(--container) + 32px); padding:0 16px; margin:0 auto}
.y{ color: var(--yellow); }
.o{ color: var(--orange); }

/* HEADER */
.topbar{background:#fff; border-bottom:1px solid #ececec}
.topbar__row{height:74px; display:flex; align-items:center; justify-content:space-between; gap:12px}
.topbar__row > * { min-width: 0; }
.topbar .logo__text{
  text-shadow: 0 0 0 rgba(0,0,0,0);
}

.logo{display:flex; align-items:center; gap:8px}
.logo__mark{width:34px; height:34px; background:#f4b000; border-radius:6px; box-shadow:inset 0 -3px 0 rgb(0 0 0 / 12%)}
.logo__text{
  font-weight:700;
  letter-spacing:.02em;
  white-space:nowrap;
  color:#000;
  margin-left: 44px;
}
.slogan{color:#111; font-size:14px}
.right{display:flex; align-items:center; gap:12px}
.phone{font-weight:700; white-space:nowrap; color:var(--black); text-decoration:none; padding:10px 14px; background:#f5f6f7; border-radius:10px ; margin-right: 5px;}
.btn{height:42px; display:inline-flex; align-items:center; justify-content:center; padding:0 16px; border-radius:10px; font-weight:700; cursor:pointer; border:1px solid transparent; text-decoration:none}
.btn-topbar{background:linear-gradient(#ffe368,#ffd33d); color:#2a2a2a; font-weight:900; border:1px solid #f0c200}

@media (max-width:767px){
  .slogan{display:none}
  .btn-topbar{display:none}
}

@media (max-width: 420px){
  .topbar__row{
    height:60px;
    padding:8px 0;
    flex-wrap:nowrap;
    gap:10px;
  }
  .logo{ flex: 0 1 auto; min-width: 0; }
  .right{ flex: 1 1 auto; min-width: 0; display:flex; justify-content:flex-end; gap:8px; }
  .phone{ padding:8px 12px; font-size:14px; }
}
@media (max-width: 350px){
  .phone{ font-size:13px; padding:7px 10px; }
}

/* HERO */
.hero{position:relative; min-height:860px; display:flex; align-items:center; justify-content:center; color:#fff; overflow:hidden; background:#000}
@media (max-width:1023px){ .hero{ min-height:700px } }
@media (max-width:640px){ .hero{ min-height:600px } }
.hero__bg{position:absolute; inset:0; background:url('../img/hero.jpg') center/cover no-repeat; transform: translateY(0px) scale(1.15); will-change: transform;}
.hero::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.52) 0%, rgba(0,0,0,.52) 100%)}
.hero__inner{position:relative; z-index:1; width:100%; display:flex; align-items:center; justify-content:center}
.hero__content{max-width:1000px; margin:0 auto; text-align:center}
.pretitle{margin:0 0 6px 0; font-weight:900; font-size:22px; color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.35)}
.title{margin:8px 0 14px 0; font-weight:900; line-height:1.12; font-size:48px; color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.35)}
.subtitle{margin:0 0 24px 0; font-size:18px; line-height:1.55; color:#f2f2f2; text-shadow:0 1px 10px rgba(0,0,0,.35)}
.actions{display:flex; gap:16px; flex-wrap:wrap; justify-content:center}
.btn-lg{height:48px; padding:0 22px; border-radius:999px; font-weight:900; font-size:16px; border:1px solid transparent}
.btn-yellow{background:linear-gradient(#ffe368,#ffd33d); color:#2a2a2a; border-color:#f0c200; box-shadow:0 8px 24px rgba(255,205,0,.35)}
.btn-pink{background:linear-gradient(180deg,#ff8070 0%, #ff6a3d 100%); color:#fff; border-color:rgba(255,106,61,.85); box-shadow:0 10px 26px rgba(0,0,0,.35)}
@media (max-width:1023px){ .title{font-size:40px} .pretitle{font-size:20px} }
@media (max-width:640px){ .title{font-size:32px} .pretitle{font-size:18px} }

.hero-br{ display:none; }
@media (min-width:860px){ .hero-br{ display:inline; } }

/* Скрытый текст */
.sr-only{
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* VIDEOS */
.videos{ padding: 56px 0 40px; background:#fff; color:#111; }
.videos__title{ margin:0 0 32px 0; text-align:center; font-weight:900; line-height:1.35; font-size:28px; }
@media (min-width: 1200px){ .videos__title{ margin-bottom: 40px; font-size:32px } }

/* Сетка: горизонтальный + две вертикальные карточки */
.videos__grid{
  display:flex;
  flex-wrap:wrap;
  gap:24px;
  justify-content:center;
}

/* Базовая карточка (горизонтальная) */
.video-card{
  position:relative;
  aspect-ratio:16/9;
  background:#000;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  width:min(860px, 100%);
}

/* Вертикальная карточка (9:16) */
.video-card--vertical{
  aspect-ratio: 9/16;
  width: min(420px, 100%);
  max-height: var(--main-video-height, 560px);
  flex: 1 1 360px;
}

/* Постер и видео внутри вертикалок */
.video-card--vertical .video-card__thumb,
.video-card--vertical .video-card__video{
  object-fit: cover;
}

@media (min-width: 641px){
    .video-card--vertical{
    max-width: 420px;
  }
}

/* Содержимое карточки */
.video-card{ position:relative; }
.video-card__thumb{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; z-index:1; }
.video-card__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; z-index:2; display:none; background:#000; }
.video-card__play { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:3; pointer-events:auto; }

/* В полноэкранном режиме не показываем оверлей */
:fullscreen .video-card__play,
:-webkit-full-screen .video-card__play { display: none !important; }

/* Оверлей скрывается навсегда после старта */
.video-card.is-started .video-card__play { display: none !important; }

.video-card__btn{
  pointer-events:auto;
  width:84px; height:84px; border-radius:50%;
  background:rgba(255,255,255,.18);
  backdrop-filter:saturate(1.2) blur(.5px);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.35), 0 10px 26px rgba(0,0,0,.35);
  display:grid; place-items:center;
  transition:.18s;
}
.video-card__btn::before{
  content:"";
  width:0; height:0;
  border-left:20px solid rgba(255,255,255,.95);
  border-top:12px solid transparent;
  border-bottom:12px solid transparent;
  margin-left:4px;
  filter:drop-shadow(0 2px 2px rgba(0,0,0,.2));
}

/* Ховер-анимация только для ПК */
@media (hover: hover) and (pointer: fine) {
  .video-card__btn {
    transition: transform .16s ease, box-shadow .16s ease;
  }
  .video-card__btn:hover {
    transform: scale(1.06);
    box-shadow:
      inset 0 0 0 2px rgba(255,255,255,.42),
      0 12px 28px rgba(0,0,0,.38);
  }
}

/* Мобильная адаптация размеров кнопки */
@media (max-width:640px){
  .video-card__btn{ width:70px; height:70px; }
  .video-card__btn::before{
    border-left-width:18px;
    border-top-width:11px;
    border-bottom-width:11px;
  }
}

/* Скрыть визуально */
.visually-hidden{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
  border:0;
}

/* ABOUT */
.about{ padding: 32px 0 56px; background:#fff; }
.about__grid{ display:grid; gap:24px; grid-template-columns: 1fr; align-items:start; justify-items:center; }
.about__content{ max-width:780px; margin:0 auto; text-align:center; }
.about__title{ margin:0 0 10px 0; font-weight:900; font-size:34px; line-height:1.2; color:#000; }
.about__text p{ margin:0 0 12px 0; color:#111; font-size:18.5px; line-height:1.6; }
@media (max-width:640px){ .about{ padding:24px 0 40px; } .about__title{ font-size:28px; } .about__text p{ font-size:16.5px; } }
.btn-orange{ display:inline-flex; align-items:center; gap:10px; min-height:44px; padding:0 16px; border-radius:10px; font-weight:900; color:#fff; background:linear-gradient(180deg,#ff8a00 0%, #ff6a3d 100%); border:1px solid rgba(255,106,61,.85); text-decoration:none; }
.btn-orange svg{ width:18px; height:18px; }

/* STRUCTURE */
.structure{ padding: 40px 0 72px; background:#fff; }
.structure__title{ margin: 0 0 20px 0; text-align:center; font-weight:900; font-size:32px; color:#000; }
@media (min-width:1200px){ .structure__title{ font-size:36px } }
.structure__wrap{ width: 100%; max-width: 100vw; margin: 0 auto; overflow:hidden; }
.structure__img{ display:block; width:min(2000px, 100vw); max-width:100%; height:auto; margin:0 auto; object-fit:contain; }

/* PROJECTS */
.projects{ padding: 68px 0 84px; background:#fff; position:relative; z-index:2; }
.projects__title{ margin:0; text-align:center; font-weight:900; font-size:36px; color:#000; }
.projects__subtitle{ margin: 4px 0 24px 0; text-align:center; font-size:24px; color:#333; }

.projects__grid{ max-width:1200px; margin:0 auto; display:grid; gap:24px; grid-template-columns:1fr; }
@media (min-width: 760px){ .projects__grid{ grid-template-columns: repeat(2, 1fr); row-gap:28px; } }
@media (min-width: 1120px){ .projects__grid{ grid-template-columns: repeat(3, 1fr); row-gap:32px; } }

.card{ background:#fff; border-radius:14px; box-shadow:0 10px 26px rgba(0,0,0,.08); overflow:hidden; display:flex; flex-direction:column; }

.slider{ position:relative; aspect-ratio:16/10; background:#f2f2f2; overflow:hidden; }
.slider__stage{ position:absolute; inset:0; }
.slider__stage { touch-action: pan-y; }

.slider__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; transition: transform .32s cubic-bezier(.2,.65,.2,1), opacity .32s linear; will-change: transform, opacity; -webkit-backface-visibility:hidden; backface-visibility:hidden; transform: translateZ(0); }
.slide-enter-right{ transform: translateX(100%); opacity:0; }
.slide-enter-left { transform: translateX(-100%); opacity:0; }
.slide-center     { transform: translateX(0); opacity:1; }
.slide-exit-left  { transform: translateX(-100%); opacity:0; }
.slide-exit-right { transform: translateX(100%); opacity:0; }

.slider__nav{ position:absolute; top:50%; transform:translateY(-50%); width:36px; height:36px; border-radius:50%; border:0; background:rgba(0,0,0,.45); color:#fff; font-size:24px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s ease, opacity .2s ease; }
.slider__nav:hover{ background:rgba(0,0,0,.6) }
.slider__nav:disabled{ opacity:.35; cursor:default }
.slider__nav--prev{ left:10px } .slider__nav--next{ right:10px }

.card__bullets{ position:absolute; left:14px; bottom:10px; display:flex; gap:6px; }
.card__dot{ width:6px; height:6px; border-radius:50%; background:#fff; opacity:.55 }
.card__dot--active{ opacity:1 }

.card__body{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:10px }
.card__title{ margin:0; font-weight:900; font-size:18px; color:#000 }
.card__meta{ color:#555; font-size:14px; line-height:1.6 }
.card__price{ margin-top:2px; font-weight:900; color:#000 }
.card__actions{ margin-top:12px }
.card__actions .btn-cta{ display:flex; align-items:center; justify-content:center; width:100%; min-height:56px; padding:0 26px; border:0; border-radius:28px; color:#fff; text-decoration:none; font-weight:900; font-size:16px; letter-spacing:.2px; background: linear-gradient(180deg, var(--cta-start) 0%, var(--cta-mid) 55%, var(--cta-end) 100%); box-shadow: 0 10px 22px var(--cta-shadow); transition: transform .06s ease, box-shadow .2s ease, filter .2s ease; }
.card__actions .btn-cta:hover{ box-shadow:0 14px 28px var(--cta-shadow-hover); filter:brightness(1.01) }
.card__actions .btn-cta:active{ transform:translateY(1px) }
.card__actions .btn-cta:focus{ outline:2px solid rgba(255,160,120,.35); outline-offset:2px }

/* GALLERY */
.gallery{ padding:72px 0 84px; background:#fff; position:relative; z-index:1; }
.gallery__title{ margin:0 0 8px 0; text-align:center; font-weight:900; font-size:34px; color:#000; }
.gallery__subtitle{ margin:0 0 22px 0; text-align:center; font-size:18px; color:#444; }
.gallery__wrap{ max-width: 1480px; padding: 0 20px; margin: 0 auto; }
@media (min-width: 1600px){ .gallery__wrap{ max-width: 1680px; } }
.big-slider3{ position:relative; }
.big-slider3__viewport{ overflow:hidden; border-radius:16px; box-shadow:0 14px 34px rgba(0,0,0,.08); touch-action: pan-y; }
.big-slider3__track{
  display:flex; gap:24px; will-change:transform;
  transform:translateX(0); transition:transform .46s cubic-bezier(.22,.72,.2,1);
  padding:2px;
}
.big-slider3__item{ flex:0 0 calc((100% - 24px*2)/3); aspect-ratio: 7/5; background:#f2f2f2; border-radius:12px; overflow:hidden; position:relative; }
.big-slider3__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; -webkit-backface-visibility:hidden; backface-visibility:hidden; transform:translateZ(0); }
.big-slider3__nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%; border:0; cursor:pointer;
  background:rgba(0,0,0,.45); color:#fff; font-size:26px; display:flex; align-items:center; justify-content:center;
  transition:background .2s ease, opacity .2s ease; z-index:2;
}
.big-slider3__nav:hover{ background:rgba(0,0,0,.6); }
.big-slider3__nav:disabled{ opacity:.35; cursor:default; }
.big-slider3__nav--prev{ left:10px; } .big-slider3__nav--next{ right:10px; }
.big-slider3__dots{ display:flex; gap:6px; justify-content:center; margin-top:12px; }
.big-slider3__dot{
  -webkit-appearance: none;
  appearance: none;
  border: 0;
  box-shadow: none;
  background:#bbb;
  opacity:.6;
  border-radius:50%;
  width:7px;
  height:7px;
  padding:0;
  margin:0;
  cursor:pointer;
  outline:none;
}
.big-slider3__dot--active{ background:#333; opacity:1; }

.big-slider3__dot:hover,
.big-slider3__dot:focus-visible{
  opacity:.9;
}

@media (max-width:1024px){
  .big-slider3__track{ gap:20px; }
  .big-slider3__item{ flex:0 0 calc((100% - 20px)/2); }
}
@media (max-width:640px){
  .gallery__wrap{ padding:0 16px; }
  .big-slider3__track{ gap:12px; }
  .big-slider3__item{ flex:0 0 100%; aspect-ratio:4/3; }
  .big-slider3__nav{ width:42px; height:42px; font-size:24px; }
}

.lightbox{ position:fixed; inset:0; background:rgba(0,0,0,.92); display:none; align-items:center; justify-content:center; z-index:1000; }
.lightbox--open{ display:flex }
.lightbox__close{ position:fixed; top:14px; right:18px; color:#fff; font-size:22px; width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,.5); display:flex; align-items:center; justify-content:center; cursor:pointer; background:transparent; }
.lightbox__counter{ position:fixed; top:14px; left:18px; color:#fff; font-weight:700; font-size:14px; opacity:.9; }
.lightbox__img{ max-width:calc(100vw - 120px); max-height:calc(100vh - 120px); object-fit:contain; box-shadow:0 10px 30px rgba(0,0,0,.5); transition: opacity .28s ease; }
.lb-fade-out{ opacity:0; }
@media (max-width:760px){
  .lightbox__img{ max-width:calc(100vw - 40px); max-height:calc(100vh - 80px) }
}
.lightbox__nav{
  position:fixed; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%; border:1px solid rgba(255,255,255,.5);
  background:rgba(0,0,0,.35); color:#fff; font-size:24px;
  display:flex; align-items:center; justify-content:center; cursor:pointer;
}
.lightbox__nav--prev{ left:16px; }
.lightbox__nav--next{ right:16px; }

/* CONTACTS */
.contacts{ padding:64px 0 84px; background:#fff; }
.contacts__title{ margin:0 0 28px 0; text-align:center; font-weight:900; font-size:34px; color:#000; }
.contacts__layout{ display:grid; grid-template-columns: 1.15fr 0.85fr; grid-template-areas: "map info"; gap:28px; align-items:start; }
.contacts__map{ grid-area: map; border-radius:14px; overflow:hidden; box-shadow:0 10px 26px rgba(0,0,0,.08); background:#f2f2f2; }
.ymap-embed{ position:relative; width:100%; aspect-ratio: 16/10; }
.ymap-embed iframe{ position:absolute; inset:0; width:100%; height:100%; display:block; border:0; }
.contacts__info{ grid-area: info; display:flex; flex-direction:column; gap:14px; }
.contacts__row{ padding:12px 0; border-bottom:1px solid #f0f0f0; }
.contacts__label{ font-weight:700; color:#111; margin-bottom:6px; }
.contacts__value{ color:#111; line-height:1.55; }
.contacts__teltext{ font-weight:900; }
@media (max-width: 992px){ .contacts__layout{ grid-template-columns: 1fr; grid-template-areas: "map" "info"; gap:20px; } .ymap-embed{ aspect-ratio: 4/3; } }

/* MODAL + FORM */
.modal{ position:fixed; inset:0; display:none; z-index:1200; }
.modal--open{ display:block; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.66); backdrop-filter:saturate(1.2) blur(.5px); }
.modal__dialog{
  position:relative; z-index:1; width:min(560px, calc(100vw - 28px));
  margin: 10vh auto; background:#fff; border-radius:16px; box-shadow:0 24px 80px rgba(0,0,0,.35);
}
@media (max-width:640px){ .modal__dialog{ margin: 8vh auto; border-radius:14px; } }
.modal__content{ padding:26px 24px 24px; }
.modal__close{
  position:absolute; top:10px; right:10px; width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(0,0,0,.15); background:#fff; cursor:pointer; color:#000; font-size:18px;
  display:flex; align-items:center; justify-content:center;
}
.modal__title{ margin:6px 0 8px; font-size:24px; font-weight:900; color:#000; text-align:center; }
.modal__subtitle{ margin:0 0 18px; color:#444; text-align:center; }

.form__row{ margin-bottom:14px; }
.form__label{ display:block; margin:0 0 6px; font-weight:700; color:#111; }
.form__muted{ color:#888; font-weight:400; }
.form__req{ color:var(--orange); font-weight:900; }
.form__input{
  width:100%; height:46px; padding:0 14px; border-radius:10px; border:1px solid #ddd; background:#fff;
  font-size:16px; color:#111; outline:none; transition:border .15s ease, box-shadow .15s ease;
}
.form__input:focus{ border-color:#c9c9c9; box-shadow:0 0 0 3px rgba(255,165,140,.18); }
.form__error{ min-height:16px; font-size:13px; color:#d9534f; margin-top:6px; }
.form__submit{
  width:100%; min-height:52px; border:0; border-radius:26px; cursor:pointer; position:relative;
  color:#2a2a2a; font-weight:900; font-size:16px; letter-spacing:.2px;
  background:linear-gradient(#ffe368,#ffd33d); box-shadow:0 10px 22px rgba(255,205,0,.35);
}
.form__submit[disabled]{ opacity:.7; cursor:default; }
.form__spinner{
  display:none; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:20px; height:20px; border-radius:50%; border:2px solid #0000; border-top-color:#333; border-left-color:#333;
  animation:spin .6s linear infinite;
}
@keyframes spin{ to{ transform:translate(-50%,-50%) rotate(360deg); } }
.form__submit.loading .form__submit-text{ opacity:0; }
.form__submit.loading .form__spinner{ display:block; }
.form__privacy{ margin-top:10px; font-size:13px; color:#666; text-align:center; line-height:1.4; }

.form__success{ text-align:center; padding:8px 0 6px; }
.form__success-title{ font-weight:900; font-size:22px; color:#000; margin-bottom:6px; }
.form__success-text{ color:#333; margin-bottom:14px; }

html { scrollbar-gutter: auto; background-color: transparent; }

body {
  overflow-y: auto;
  overflow-x: hidden;
}

.lock-scroll { overflow: hidden !important; }

/* ===== QUIZ (fullscreen) ===== */

/* Блокировка скролла */
.body-scroll-lock{
  position: fixed;
  overflow: hidden !important;
  width: 100%;
  left: 0; right: 0;
}

/* Модалка квиза */
.quiz-modal{ position:fixed; inset:0; z-index:1400; display:none; }
.quiz-modal[aria-hidden="false"]{ display:block; }

.quiz__backdrop{
  position:absolute; inset:0;
  background: linear-gradient(rgba(0,0,0,.72), rgba(0,0,0,.72));
  opacity:0; transition: opacity .24s ease;
}
.quiz-modal[aria-hidden="false"] .quiz__backdrop{ opacity:1; }

.quiz__wrap{
  position:relative; z-index:1; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding:24px 16px;
}

.quiz__card{
  width:min(940px, 100%); background:rgba(255,255,255,.98);
  border-radius:16px; box-shadow:0 24px 80px rgba(0,0,0,.5); overflow:hidden;
  opacity:0; transform:translateY(10px) scale(.985);
  transition: opacity .24s ease, transform .24s ease; will-change:opacity, transform;
}
.quiz-modal[aria-hidden="false"] .quiz__card{ opacity:1; transform:translateY(0) scale(1); }

/* Шапка и прогресс */
.quiz__head{
  padding:14px 18px;
  background:rgba(255,255,255,.9);
  display:flex; align-items:center; gap:14px;
  position: relative;
  padding-right: 56px;
  overflow: visible;   
}
.quiz__title{ font-weight:900; font-size:18px; color:#000; margin-right:auto; }
.quiz__progress{ flex:0 0 260px; }
.quiz__bar{ height:8px; border-radius:6px; background:#efefef; overflow:hidden; }
.quiz__bar > span{ display:block; height:100%; width:0%; background:linear-gradient(180deg,#ff8a00 0%, #ff6a3d 100%); transition:width .25s ease; border-radius:6px; }

/* Кнопка закрытия квиза (крестик) */
.quiz__close{
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 5;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  cursor: pointer;
  background: rgba(0,0,0,0.06);
  backdrop-filter: saturate(120%) blur(2px);
  border: 1px solid rgba(0,0,0,.1);
  color:#000;
  font-size: 18px;
}

/* Контент и шаги */
.quiz__steps{ padding:18px; }

/* Держит высоту активного шага */
.quiz-steps-wrap{
  position: relative;
  height: auto;
  min-height: 420px;
}

/* Каждый шаг - слой поверх контейнера */
.quiz-step{
  position: absolute; inset: 0;
  opacity: 0;
  transform: translateX(24px);
  transition: opacity 280ms ease, transform 320ms cubic-bezier(.22,.61,.36,1);
  pointer-events: none;
  will-change: opacity, transform;
}
.quiz-step.is-active{
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

/* Состояния входа/выхода */
.quiz-step.anim-exit-left   { opacity: 0; transform: translateX(-24px); }
.quiz-step.anim-exit-right  { opacity: 0; transform: translateX(24px);  }
.quiz-step.anim-enter-left  { opacity: 0; transform: translateX(-24px); }
.quiz-step.anim-enter-right { opacity: 0; transform: translateX(24px);  }

.quiz__h{ margin:0 0 12px; font-weight:900; font-size:22px; color:#000; }
.quiz__hint{ margin:0 0 14px; color:#555; }

/* Ответы - один столбец */
.quiz__grid{ display:grid; gap:12px; grid-template-columns:1fr; }
@media (min-width:641px){ .quiz__grid{ grid-template-columns:1fr; } }

.quiz__opt{
  display:flex; align-items:center; gap:10px; min-height:54px;
  padding:12px 14px; border-radius:12px; border:2px solid #e9e9e9;
  background:#fff; cursor:pointer; font-weight:700; color:#111;
  transition:border .15s ease, box-shadow .15s ease, background .15s ease, transform .05s ease;
}
.quiz__opt:hover{ border-color:#d9d9d9; background:#fcfcfc; }
.quiz__opt:active{ transform:translateY(1px); }

.quiz__radio{ position:absolute; inset:auto; width:1px; height:1px; opacity:0; pointer-events:none; }
.quiz__radio:checked + .quiz__opt{
  border-color:#ff7e4a; box-shadow:0 0 0 3px rgba(255,125,80,.12); background:#fffaf7;
}

/* Подвал квиза */
.quiz__footer{ padding:16px 18px; display:flex; gap:10px; justify-content:space-between; border-top:1px solid #f2f2f2; background:#fff; }
.quiz__btn{ min-height:46px; padding:0 16px; border-radius:12px; font-weight:900; border:1px solid transparent; cursor:pointer; }
.quiz__btn--prev{ background:#f5f6f7; color:#111; }
.quiz__btn--next{ background:linear-gradient(180deg,#ff8a00 0%, #ff6a3d 100%); color:#fff; border-color:rgba(255,106,61,.85); box-shadow:0 10px 20px rgba(0,0,0,.2); }
.quiz__status{ margin-left:auto; display:flex; align-items:center; gap:10px; color:#555; font-weight:700; }

/* Поле телефона и ошибки */
.quiz__phone{ width:100%; height:48px; padding:0 14px; border-radius:12px; border:2px solid #e9e9e9; font-size:16px; }
.quiz__phone.is-invalid{ border-color:#d9534f; box-shadow:0 0 0 3px rgba(217,83,79,.12); }
.quiz__error{ margin-top:8px; color:#d9534f; font-size:13px; min-height:16px; }
/* Поля ввода (Имя/Телефон) на 6 шаге */
.quiz__input,
.quiz__phone{
  width:100%;
  height:48px;
  padding:0 14px;
  border-radius:12px;
  border:2px solid #e9e9e9;
  font-size:16px;
  background:#fff;
  color:#111;
  outline:none;
  transition:border .15s ease, box-shadow .15s ease, background .15s ease;
}

.quiz__input:focus,
.quiz__phone:focus{
  border-color:#d9d9d9;
  box-shadow:0 0 0 3px rgba(255,125,80,.10);
}

/* Универсальное состояние ошибки для любых полей */
.is-invalid{
  border-color:#d9534f !important;
  box-shadow:0 0 0 3px rgba(217,83,79,.12) !important;
}

/* Плейсхолдеры */
.quiz__input::placeholder,
.quiz__phone::placeholder{ color:#999; }

/* Экраны результата */
.quiz__result{ padding:22px; text-align:center; }
.quiz__result h3{ margin:0 0 10px; font-size:22px; font-weight:900; color:#000; }
.quiz__result p{ margin:0 0 14px; color:#333; }
.quiz__result .btn{ height:44px; padding:0 16px; border-radius:12px; background:linear-gradient(#ffe368,#ffd33d); color:#2a2a2a; font-weight:900; border:1px solid #f0c200; }

/* Компактный зазор на шаге 6 */
.quiz-step[data-step="6"] {
  display: block !important;
}

.quiz-step[data-step="6"] #quiz_name,
.quiz-step[data-step="6"] #quiz_phone {
  margin: 4px 0 4px 0 !important;
  display: block;
}

.quiz-step[data-step="6"] #err_name,
.quiz-step[data-step="6"] #err_phone {
  margin: 4px 0 4px 0 !important;
}

.quiz-step[data-step="6"] .quiz__hint {
  margin-bottom: 8px !important;
}

.quiz-step[data-step="6"] {
  gap: 0 !important;
  row-gap: 0 !important;
}

/* Мобильные твики для шапки квиза и крестика */
@media (max-width: 480px){
  .quiz__progress{ flex: 0 0 180px; }
  .quiz__head{ padding-right: 48px; }
  .quiz__close{ width: 32px; height: 32px; top: 6px; right: 6px; font-size:16px; }
}
@media (max-width: 360px){
  .quiz__progress{ flex: 0 0 150px; }
  .quiz__head{ padding-right: 44px; }
  .quiz__close{ width: 30px; height: 30px; top: 6px; right: 6px; font-size:15px; }
}