/* =========================================================
   FONTS (local)
   Папка: /fonts рядом с css
   ========================================================= */
@font-face{
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face{
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face{
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

/* =========================================================
   ROOT / TOKENS (WHITE THEME)
   ========================================================= */
:root{
  --bg: #ffffff;
  --text: #0b0f13;
  --muted: rgba(11,15,19,.68);

  --line: rgba(11,15,19,.10);
  --card: #ffffff;

  --r: 18px;
  --accent: #00BFFF;

  --shadow-soft: 0 18px 48px rgba(11,15,19,.10);
  --shadow-hover: 0 32px 80px rgba(11,15,19,.18), 0 12px 32px rgba(11,15,19,.12);

  /* services sizing */
  --svc-card-w: 250px;
  --svc-gap: 24px;
  --svc-media-h: 180px;

  /* typography */
  --ff: "Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;

  /* fixed header height (если JS выставляет) */
  --header-h: 0px;
}

/* =========================================================
   RESET / BASE
   ========================================================= */
*{ box-sizing:border-box; }
html,body{ height:100%; scroll-behavior:smooth; }

body{
  margin:0;
  font-family: var(--ff);
  font-weight: 500;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

a{ color:inherit; }
img{ max-width:100%; height:auto; scroll-behavior:smooth; }

.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 20px;
}

.muted{ color: var(--muted); }
.link{ text-decoration:none; }
.link:hover{ border-bottom-color: rgba(11,15,19,.65); }

/* =========================================================
   TYPE SCALE
   ========================================================= */
.hero__title,
.footer__title{ font-weight: 600; }

.section-title,
.subtitle,
.stages__title,
.nav__link{ font-weight: 600; }

/* =========================================================
   HEADER / NAV (white) — BASE 1920
   ========================================================= */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  z-index: 1000;
  transform: none !important;
  transition: none !important;
}

/* верхняя шапка */
.header__top {
  display: grid;
  grid-template-columns: auto 1fr auto auto auto auto;
  align-items: center;
  gap:106px;
  padding: 18px 24px;
}

.brand {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 0;
  margin: 0;
  line-height: 0;
}

.brand__logo {
  display: block;
  width: auto;
  height: 42px;
  max-width: 220px;
  object-fit: contain;
}

.hitem {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.hitem__label {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  color: rgba(11, 15, 19, 0.95);
}

.hitem__text {
  display: block;
  font-size: 15px;
  line-height: 1.35;
  color: rgba(11, 15, 19, 0.74);
  text-decoration: none;

}

a.hitem__text:hover {
  color: rgba(11, 15, 19, 1);
}

/* блок с 2 иконками */
.hsocial {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  margin: 0;
  padding: 0;
  min-width: max-content;
}

.hsocial__btn {
  width: 80px;
  height: 80px;
  min-width: 42px;
  flex: 0 0 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #fff;
  text-decoration: none;
  transition: 0.2s ease;
  overflow: hidden;
}

.hsocial__btn:hover {
  border-color: rgba(11, 15, 19, 0.16);
  transform: translateY(-1px);
}

.hsocial__btn img {
  display: block;
  width: 80px;
  height: 80px;
  object-fit: contain;
}

/* бургер пока скрыт */
.burger {
  display: none !important;
}

/* нижний навбар */
.nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8%;
  padding: 14px 24px;
  background: #fff;
}

.nav__link {
  text-decoration: none;
  color: rgba(11, 15, 19, 0.72);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.2;
  padding: 6px 2px;
  border-bottom: 2px solid transparent;
  transition: 0.2s ease;
}

.nav__link:hover {
  color: rgba(11, 15, 19, 0.95);
}

.nav__link.is-active {
  color: rgba(11, 15, 19, 1);
  border-bottom-color: var(--accent);
}

/* =========================================================
   HERO (readable on image)
   ========================================================= */
.hero{
  position:relative;
  min-height: 630px;
  display:flex;
  align-items:flex-end;
  padding-top: 24px !important;
}

.hero__bg{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.00), rgba(255,255,255,.70)),
    url("../assets/img/fon_block1.webp");
  background-size:cover;
  background-position:center;
}

.hero__inner{ position:relative; padding:44px 20px 34px; }
.hero__content{ max-width:820px; }
.hero__content--center{ max-width:1000px; margin:0 auto; text-align:center; margin-bottom: 8%; }

.hero__title{
  margin:0 0 18px;
  font-size:44px;
  line-height:1.15;
  color: var(--text);
  text-shadow: 0 2px 10px rgba(255,255,255,.55);
}

.hero__subtitle{
  margin: 10px 0 14px;
  font-size: 18px;
  line-height: 1.5;
  font-weight: 600;
  color: rgba(11,15,19,.78);
}

.hero__text{
  margin:0 0 26px;
  color: rgba(11,15,19,.72);
  font-size: 17px;
  line-height: 1.6;
  max-width:720px;
}
.hero__content--center .hero__text{ margin:0 auto 26px; }

.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.hero__actions--center{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
}

/* =========================================================
   BUTTONS (single version)
   ========================================================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:48px;
  padding:0 16px;
  border-radius:14px;
  border: none;
  background: #1E90FF;
  color: #FFFFFF;
  text-decoration:none;
  font-weight:700;
  box-shadow: 0 10px 28px rgba(11,15,19,.10);
  cursor:pointer;
}

.btn:hover{ background:#0099CC; }
.btn:active{ transform: translateY(1px); }

.btn--primary{ background:#1E90FF; }
.btn--ghost{ background:#FFDEAD }

/* одинаковый размер кнопок в hero */
.hero__actions--center .btn{
  width: 240px;
  height: 48px;
  justify-content:center;
}
/* =========================
   SEO BLOCK
========================= */

.seo-block {
  padding: 72px 0 88px;
}

.seo-block .container {
  max-width: 1180px;
}

.seo-block__inner {
  max-width: 980px;
  margin: 0 auto;
  padding: 56px 64px;
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
  border: 1px solid rgba(20, 20, 20, 0.06);
  border-radius: 32px;
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.04),
    0 2px 10px rgba(0, 0, 0, 0.03);
  position: relative;
  overflow: hidden;
}

.seo-block__inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 64px;
  width: 84px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #00bfff 0%, #8fdcff 100%);
}

.seo-block__title {
  max-width: 760px;
  margin: 0 auto 24px;
  text-align: center;
  font-size: 46px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #111111;
  text-wrap: balance;
}

.seo-block__text {
  max-width: 760px;
  margin: 0 auto;
}

.seo-block__text p {
  margin: 0 0 18px;
  font-size: 18px;
  line-height: 1.78;
  color: #3f3f46;
}

.seo-block__text p:last-child {
  margin-bottom: 0;
}

/* чуть усилить ключевые слова, если будешь использовать <strong> */
.seo-block__text strong {
  color: #111111;
  font-weight: 600;
}
/* =========================================================
   SECTIONS / TITLES
   ========================================================= */
.section{ padding:56px 0; }

.section-title{
  text-align:center;
  margin:0 0 26px;
  font-size:30px;
  letter-spacing:-0.2px;
  color: var(--text);
}

/* =========================================================
   SERVICES (carousel + extra grid)
   ========================================================= */
.services{ padding:72px 0 90px; }

.services-container{
  width: calc(var(--svc-card-w) * 4 + var(--svc-gap) * 3);
  margin: 0 auto;
}

.carousel{ position: relative; width: 100%; }

#services .services-container{ perspective: 1000px; }

/* НЕ режем hover (главное!) */
#services .carousel-viewport{
  overflow-x: hidden;
  overflow-y: visible;
  padding: 22px 14px;
}

#services .carousel-track{
  display:flex;
  gap: var(--svc-gap);
  transition: transform .35s ease;
  will-change: transform;
  overflow: visible;
}

/* карточки только в services */
#services .card{
  position: relative;
  z-index: 1;
  transform-origin: center bottom;
  will-change: transform;

  background: #ffffff;
  border: 1px solid rgba(11,15,19,.08);
  border-radius: 18px;
  box-shadow: var(--shadow-soft);

  padding: 18px;

  display:flex;
  flex-direction:column;
  gap: 12px;

  transition: transform .25s ease, box-shadow .25s ease;
}

/* Окно под изображение — без рамки */
#services .card-img{
  height: var(--svc-media-h);
  border-radius: 14px;
  background: #ffffff;
  overflow: hidden;

  display:flex;
  align-items:center;
  justify-content:center;

  padding: 12px;
}

/* Картинка без обрезки */
#services .card-img img{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display:block;
  transition: transform .25s ease;
}

/* Текст карточки */
#services .card p{
  margin:0;
  font-size:14px;
  line-height:1.35;
  font-weight:600;
  color: rgba(11,15,19,.86);
  text-align:center;
}

/* 3D hover */
#services .card:hover{
  z-index: 5;
  transform: translateY(-10px) scale(1.04);
  box-shadow: var(--shadow-hover);
}

#services .card:hover .card-img img{
  transform: scale(1.06);
}

/* стрелки */
.arrow{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:46px;
  height:46px;
  border-radius:14px;
  background: var(--accent);
  border:none;
  color:#fff;
  cursor:pointer;
  z-index:10;
  box-shadow: 0 10px 28px rgba(0,191,255,.25);
}
.arrow:hover{ filter: brightness(.95); }
.arrow:disabled{ opacity:.35; cursor:not-allowed; }

.left{ left: -70px; }
.right{ right: -70px; }

/* подпись между блоками */
.subtitle{
  margin: 30px auto 18px;
  max-width: 560px;
  text-align:center;
  font-weight:600;
  color: rgba(11,15,19,.78);
  background: #f3f6f9;
  border: 1px solid rgba(11,15,19,.08);
  border-radius: 999px;
  padding: 12px 16px;
}

.extra-grid{
  display:grid;
  grid-template-columns: repeat(4, var(--svc-card-w));
  gap: var(--svc-gap);
  justify-content: space-between;
}

/* фиксируем 4 карточки в видимой области */
#services .services-container{
  width: calc(var(--svc-card-w) * 4 + var(--svc-gap) * 3);
  margin: 0 auto;
}

#services .carousel-viewport{
  overflow: hidden;
  padding: 22px 0;
}

#services .carousel-track{
  display: flex;
  gap: var(--svc-gap);
  transition: transform .35s ease;
  will-change: transform;
}

#services .carousel-track .card{
  width: var(--svc-card-w);
  flex: 0 0 var(--svc-card-w);
}

#services .carousel-track .card p{
  min-height: 40px;
}

/* =========================================================
   BENEFITS — carousel
   ========================================================= */
#benefits{
  padding: 72px 0 90px;
}

#benefits .benefits-container{
  --b-card-w: 250px;
  --b-gap: 24px;
  --b-media-h: 180px;

  width: calc(var(--b-card-w) * 4 + var(--b-gap) * 3);
  margin: 0 auto;
}

#benefits .benefits-carousel{
  position: relative;
  width: 100%;
}

#benefits .benefits-viewport{
  overflow: hidden;
  padding: 22px 0;
}

#benefits .benefits-track{
  display: flex;
  gap: var(--b-gap);
  transition: transform .35s ease;
  will-change: transform;
}

#benefits .benefits-card{
  width: var(--b-card-w);
  flex: 0 0 var(--b-card-w);

  background: #ffffff;
  border: 1px solid rgba(11,15,19,.08);
  border-radius: 18px;
  box-shadow: 0 18px 48px rgba(11,15,19,.10);

  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;

  transform-origin: center bottom;
  transition: transform .25s ease, box-shadow .25s ease;
  position: relative;
  z-index: 1;
}

#benefits .benefits-media{
  height: var(--b-media-h);
  border-radius: 14px;
  overflow: hidden;
  background: #ffffff;

  display: flex;
  align-items: center;
  justify-content: center;
  width: 222px;
}

#benefits .benefits-media img{
  width: 112%;
    height: 112%;
    object-fit: cover;
    display: block;
    transition: transform .25s ease;
    border-radius: 31px;
    margin-right: 18px;
    margin-right: auto;
        width: 212px;
}

#benefits .benefits-card p{
  margin: 0;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 600;
  color: rgba(11,15,19,.86);
  text-align: center;
  min-height: 40px;
}

#benefits .benefits-card:hover{
  z-index: 5;
  transform: translateY(-10px) scale(1.04);
  box-shadow:
    0 32px 80px rgba(11,15,19,.18),
    0 12px 32px rgba(11,15,19,.12);
}

#benefits .benefits-card:hover .benefits-media img{
  transform: scale(1.06);
}

#benefits .benefits-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: #00BFFF;
  border: none;
  color: #fff;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 10px 28px rgba(0,191,255,.25);
}

#benefits .benefits-arrow:hover{ filter: brightness(.95); }
#benefits .benefits-arrow:disabled{ opacity: .35; cursor: not-allowed; }

#benefits .benefits-arrow.left{ left: -70px; }
#benefits .benefits-arrow.right{ right: -70px; }

/* =========================================================
   FORM (clean white)
   ========================================================= */
.form-wrap,
.request-form,
.order-form,
#request form,
#order form,
#form form{
  max-width: 980px;
  margin: 0 auto;
  padding: 34px 34px 28px;
  background: #ffffff;
  border: 1px solid rgba(11,15,19,.10);
  border-radius: 22px;
  box-shadow: 0 18px 55px rgba(11,15,19,.10);
}

.form-grid,
.request-grid,
.order-grid,
#request form .grid,
#order form .grid,
#form form .grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 28px;
}

#request,
#order,
#form,
section#request,
section#order,
section#form{
  padding: 90px 0 110px;
}

#request .section-title,
#order .section-title,
#form .section-title{
  font-size: 36px;
  font-weight: 600;
  letter-spacing: -0.3px;
  margin-bottom: 30px;
}

#request label,
#order label,
#form label,
.form-label{
  display:block;
  font-size:14px;
  font-weight:600;
  color: rgba(11,15,19,.85);
  margin-bottom: 8px;
}

#request input,
#request select,
#request textarea,
#order input,
#order select,
#order textarea,
#form input,
#form select,
#form textarea{
  width:100%;
  height:52px;
  padding:0 16px;
  font-size:16px;
  font-weight:500;
  color: #0b0f13;
  background:#ffffff;
  border:1px solid rgba(11,15,19,.14);
  border-radius:14px;
  outline:none;
  box-shadow: 0 6px 18px rgba(11,15,19,.06);
}

#request textarea,
#order textarea,
#form textarea{
  height:auto;
  min-height:120px;
  padding:14px 16px;
  resize: vertical;
}

#request input::placeholder,
#order input::placeholder,
#form input::placeholder,
#request textarea::placeholder,
#order textarea::placeholder,
#form textarea::placeholder{
  color: rgba(11,15,19,.45);
}

#request input:focus,
#request select:focus,
#request textarea:focus,
#order input:focus,
#order select:focus,
#order textarea:focus,
#form input:focus,
#form select:focus,
#form textarea:focus{
  border-color: rgba(0,191,255,.75);
  box-shadow: 0 0 0 4px rgba(0,191,255,.18), 0 10px 22px rgba(11,15,19,.10);
}

#request button,
#order button,
#form button,
#request .btn-submit,
#order .btn-submit,
#form .btn-submit{
  width:100%;
  height:56px;
  margin-top:18px;
  border:none;
  border-radius:16px;
  background: var(--accent);
  color:#ffffff;
  font-size:16px;
  font-weight:600;
  letter-spacing:.2px;
  cursor:pointer;
  box-shadow: 0 16px 36px rgba(0,191,255,.25);
}
#request button:hover,
#order button:hover,
#form button:hover{ filter: brightness(.96); }
#request button:active,
#order button:active,
#form button:active{ transform: translateY(1px); }

.form-policy,
#request .policy,
#order .policy,
#form .policy{
  margin-top:12px;
  font-size:13px;
  line-height:1.35;
  color: rgba(11,15,19,.65);
}

.form-policy a,
#request .policy a,
#order .policy a,
#form .policy a{
  color: var(--accent);
  font-weight:600;
  text-decoration:none;
}
.form-policy a:hover,
#request .policy a:hover,
#order .policy a:hover,
#form .policy a:hover{ text-decoration: underline; }

/* =========================================================
   PRIVACY NOTE + MODAL (white)
   ========================================================= */
.privacy-note{
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.4;
  color: #000;
  text-align: left;
}
.privacy-link{
  background:none;
  border:none;
  padding:0;
  color: var(--accent);
  cursor:pointer;
  font-size:14px;
  font-weight:600;
  text-decoration: underline;
}
.privacy-link:hover{ opacity:.85; }

.modal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}
.modal.is-open{ display:block; }

.modal__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.45);
}

.modal__dialog{
  position: relative;
  width: min(720px, calc(100% - 32px));
  margin: 8vh auto;
  background:#ffffff;
  border-radius:16px;
  box-shadow: 0 24px 80px rgba(0,0,0,.25);
  border:1px solid rgba(0,0,0,.10);
  overflow:hidden;
}

.modal__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 18px 18px 12px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.modal__title{
  margin:0;
  font-size:18px;
  color:#000;
  font-weight:600;
}

.modal__close{
  background:none;
  border:none;
  font-size:20px;
  cursor:pointer;
  line-height:1;
  color:#000;
  opacity:.7;
}
.modal__close:hover{ opacity:1; }

.modal__content{
  padding: 16px 18px;
  max-height: 55vh;
  overflow: auto;
  color:#000;
  font-size:14px;
  line-height:1.55;
}

#map{ padding: 10px 0 170px; }

#map .map-full{
  width: 100%;
  max-width: 1100px;
  margin: 28px auto 0;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 55px rgba(11,15,19,.10);
  border: 1px solid rgba(11,15,19,.10);
  background: #fff;
}

#map .map-full iframe{
  width: 100%;
  height: 480px;
  display: block;
  border: 0;
}

@media (max-width: 900px){
  #map .map-full iframe{ height: 360px; }
}


/* =========================================================
   STAGES
   ========================================================= */
.stages{
  padding:90px 0;
  background:#f7f7f8;
}

.stages__board{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  min-height:1050px;
  padding-top:60px;
}

.stages__card{
  position:absolute;
  width:340px;
  padding:18px;
  border-radius:22px;
  background:#ffffff;
  border:1px solid rgba(11,15,19,.06);
  box-shadow:0 18px 40px rgba(11,15,19,.08);
  transition:.25s;
}

.stages__card:hover{
  transform:translateY(-6px);
  box-shadow:0 26px 60px rgba(11,15,19,.12);
}

.stages__image{
  width:100%;
  height:200px;
  object-fit:contain;
  margin-bottom:14px;
}

.stages__num{
  width:36px;
  height:36px;
  border-radius:12px;
  display:grid;
  place-items:center;
  font-weight:800;
  font-size:14px;
  color:#121212;
  background:var(--accent);
  margin-bottom:10px;
}

.stages__title{
  font-size:16px;
  font-weight:600;
  margin-bottom:8px;
}

.stages__text{
  font-size:14px;
  line-height:1.45;
  color:rgba(11,15,19,.7);
}

/* позиции карточек */
.stages__card--top{
  top:40px;
  left:50%;
  transform:translateX(-50%);
}

.stages__card--right{
  right:40px;
  top:220px;
}

.stages__card--bottom-right{
  right:120px;
  bottom:40px;
}

.stages__card--bottom-left{
  left:120px;
  bottom:40px;
}

.stages__card--left{
  left:40px;
  top:220px;
}

/* hover */
.stages__card--top:hover{
  transform:translateX(-50%) translateY(-6px);
}

.stages__card--right:hover,
.stages__card--left:hover,
.stages__card--bottom-right:hover,
.stages__card--bottom-left:hover{
  transform:translateY(-6px);
}

/* ЖЕЛЕЗОБЕТОННЫЕ СТРЕЛКИ */
.stages__card {
  position: absolute;
  width: 340px;
  padding: 18px;
  border-radius: 22px;
  background: #ffffff;
  border: 1px solid rgba(11, 15, 19, .06);
  box-shadow: 0 18px 40px rgba(11, 15, 19, .08);
  z-index: 2;
  overflow: visible !important;
}

.stages__card--bottom-left::before {
  content: "";
  position: absolute;
  top: -120px;
  left: 47px;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 6px solid #00bfff;
}

.stages__card--left::after,
.stages__card--left::before {
  display: none !important;
}

div.stages__card {
  overflow: visible !important;
  position: absolute !important;
}

div.stages__card::after {
  content: "" !important;
  position: absolute !important;
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
  z-index: 99 !important;
}
div.stages__card--top::after {
  width: 140px !important;
  height: 90px !important;
  top: 52px !important;
  right: -132px !important;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 140 90'%3E%3Cpath d='M8 10 C 55 10, 118 14, 118 62' stroke='%2300bfff' stroke-width='4' stroke-dasharray='10 6' fill='none'/%3E%3Cpath d='M110 58 L118 72 L126 58 Z' fill='%2300bfff'/%3E%3C/svg%3E") no-repeat center / contain !important;
}

div.stages__card--right::after {
  width: 24px !important;
  height: 100px !important;
  bottom: -110px !important;
  left: 45px !important;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 100'%3E%3Cline x1='10' y1='0' x2='10' y2='85' stroke='%2300bfff' stroke-width='4' stroke-dasharray='8 5'/%3E%3Cpath d='M4 80 l6 12 l6 -12' fill='%2300bfff'/%3E%3C/svg%3E") no-repeat center / contain !important;
}

div.stages__card--bottom-right::after {
  width: 240px !important;
  height: 30px !important;
  top: 50% !important;
  left: -245px !important;
  transform: translateY(-50%) !important;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 24'%3E%3Cline x1='300' y1='12' x2='25' y2='12' stroke='%2300bfff' stroke-width='4' stroke-dasharray='10 6'/%3E%3Cpath d='M30 4 l-12 8 l12 8' fill='%2300bfff'/%3E%3C/svg%3E") no-repeat center / contain !important;
}

div.stages__card--bottom-left::after {
  width: 24px !important;
  height: 100px !important;
  top: -110px !important;
  left: 45px !important;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 100'%3E%3Cline x1='10' y1='100' x2='10' y2='20' stroke='%2300bfff' stroke-width='4' stroke-dasharray='8 5'/%3E%3Cpath d='M4 25 l6 -12 l6 12' fill='%2300bfff'/%3E%3C/svg%3E") no-repeat center / contain !important;
}

div.stages__card:hover {
  transform: none !important;
}
div.stages__card--top:hover {
  transform: translateX(-50%) !important;
}

/* =========================================================
   REVIEWS (white)
   ========================================================= */
.reviews__top{
  max-width: 1100px;
  margin: 0 auto 18px;
  display:flex;
  align-items:center;
  justify-content:space-around;
  gap: 14px;
  flex-wrap: wrap;
}

.reviews__scorebox{
  display:flex;
  align-items:center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}

.reviews__score{
  font-size: 54px;
  font-weight: 900;
  line-height: 1;
}

.reviews__meta{ display:flex; flex-direction:column; gap:6px; }
.reviews__count{ font-size: 12px; color: rgba(0,0,0,.55); }

.reviews__stars{ display:flex; gap:3px; }
.reviews__star{ opacity: .95; font-size: 14px; color:#f6c343; }

.reviews__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}

.reviews__grid{
  max-width: 1100px;
  margin: 0 auto;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.review{
  padding: 14px 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}

.review__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.review__user{ display:flex; align-items:center; gap:10px; min-width:0; }

.review__avatar{
  width: 34px; height: 34px;
  border-radius: 50%;
  display:grid;
  place-items:center;
  font-weight:900;
  border:1px solid rgba(0,0,0,.08);
  background: #f2f3f5;
  color: #111;
}

.review__name{ font-weight:700; font-size:14px; }
.review__lvl{ font-size:12px; color: rgba(0,0,0,.55); }
.review__date{ font-size:12px; color: rgba(0,0,0,.55); white-space:nowrap; }

.review__stars{ display:flex; gap:3px; opacity:.95; font-size:13px; color:#f6c343; }
.review__text{ margin-top:10px; font-size:14px; line-height:1.35; color: rgba(0,0,0,.85); }

#reviews .reviews__bottom{
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

#reviews .reviews__bigbtn{
  margin: 0;
}

.footer {
  background: #9b9b9b;
  padding: 38px 0 28px;
}

.footer__inner {
  display: flex;
  flex-direction: column;
}

.footer__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px 56px;
  align-items: start;
}

.footer__col {
  min-width: 0;
  margin: auto;
}

.footer__title {
  margin-bottom: 14px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.2;
  color: #fff;
}

.footer__text {
  margin-bottom: 10px;
  font-size: 15px;
  line-height: 1.6;
  color: #fff;
  word-break: break-word;
}

.footer__text:last-child {
  margin-bottom: 0;
}

.footer .link {
  color: #fff;
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.footer .link:hover {
  opacity: 0.8;
  text-decoration: underline;
}

.footer__bottom {
  margin-top: 50px;
  text-align: center;
  
}

.footer__bottom-text {
  font-size: 14px;
  line-height: 1.5;
  color: #fff;
  margin-bottom: 8px;
}

.footer__bottom-credit {
    font-size: 14px;
    line-height: 1.5;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: #ffffff;
}
/* =========================================
   1440
   ========================================= */
@media (max-width: 1440px) {
  .header__top {
    grid-template-columns: auto 1fr auto auto auto auto;
    gap: 90px;
    padding: 16px 20px;
  }

  .brand__logo {
    height: 38px;
    max-width: 190px;
  }

  .hitem__label {
    font-size: 11px;
  }

  .hitem__text {
    font-size: 14px;
    line-height: 1.3;
  }

  .hsocial {
    gap: 10px;
  }

  .hsocial__btn {
    width: 42px;
    height: 42px;
    min-width: 42px;
    flex: 0 0 42px;
  }

  .hsocial__btn img {
    width: 42px;
    height: 42px;
    object-fit: contain;
  }

  .nav {
    gap: 9%;
    padding: 12px 20px;
  }

  .nav__link {
    font-size: 14px;
  }

  .container {
    max-width: 1200px;
    padding: 0 20px;
  }

  .hero__title {
    font-size: 40px;
    line-height: 1.14;
  }
  .hero__content--center{  margin-bottom: 15%; }
  .hero__subtitle {
    font-size: 18px;
  }

  .hero__text {
    font-size: 16px;
    line-height: 1.55;
    max-width: 760px;
  }

  .section {
    padding: 25px 0;
  }

  .section-title {
    font-size: 30px;
  }

  .services-container {
    width: calc(250px * 4 + 24px * 3);
    max-width: 100%;
  }

  #services .carousel-viewport {
    overflow-x: hidden;
    overflow-y: visible;
    padding: 18px 8px;
  }

  #services .carousel-track {
    overflow: visible;
  }

  #services .card:hover {
    transform: translateY(-8px) scale(1.03);
  }

  .extra-grid {
    grid-template-columns: repeat(4, 250px);
    gap: 24px;
    justify-content: center;
  }

  .arrow.left {
    left: -56px;
  }

  .arrow.right {
    right: -56px;
  }

  #benefits .benefits-container {
    width: calc(250px * 4 + 24px * 3);
    max-width: 100%;
  }

  #benefits .benefits-viewport {
    overflow-x: hidden;
    overflow-y: visible;
    padding: 18px 8px;
  }

  #benefits .benefits-track {
    overflow: visible;
  }

  #benefits .benefits-card:hover {
    transform: translateY(-8px) scale(1.03);
  }

  #benefits .benefits-arrow.left {
    left: -56px;
  }

  #benefits .benefits-arrow.right {
    right: -56px;
  }

  .reviews__grid {
    gap: 16px;
  }
 .footer .container {
    width: min(1100px, calc(100% - 48px));
  }

  .footer__grid {
    column-gap: 40px;
  }
}
/* планшет */
@media (max-width: 1024px) {
  .footer .container.footer__grid {
    grid-template-columns: 1fr 1fr !important;
    column-gap: 48px !important;
  }

  .footer .container.footer__grid > div:nth-child(1),
  .footer .container.footer__grid > div:nth-child(2) {
    max-width: none !important;
  }
}



/* =========================================
   1280
   ========================================= */
@media (max-width: 1280px) {
  .header__top {
    display: grid;
    grid-template-columns: 165px 1fr 110px 145px 95px 88px;
    align-items: center;
    gap: 10px 6%;
    padding: 12px 18px 10px;
  }

  .brand {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
  }

  .brand__logo {
    height: 32px;
    max-width: 150px;
  }

  .header__top .hitem:nth-of-type(1) {
    grid-column: 2;
    grid-row: 1;
    max-width: 220px;
  }

  .header__top .hitem:nth-of-type(2) {
    grid-column: 3;
    grid-row: 1;
    max-width: 105px;
  }

  .header__top .hitem:nth-of-type(3) {
    grid-column: 4;
    grid-row: 1;
    max-width: 145px;
    min-width: 145px;
  }

  .header__top .hitem:nth-of-type(4) {
    grid-column: 5;
    grid-row: 1;
    max-width: 95px;
  }

  .hitem {
    min-width: 0;
  }

  .hitem__label {
    margin-bottom: 2px;
    font-size: 10px;
    line-height: 1.1;
  }

  .hitem__text {
    width: 168px;
    font-size: 12px;
    line-height: 1.15;
    margin-top: 11px;
  }

  .hsocial {
    grid-column: 6;
    grid-row: 1;
    justify-self: end;
    align-self: center;
    display: flex;
    gap: 8px;
    margin-top: 12px;
    min-width: max-content;
  }

  .hsocial__btn {
    width: 34px;
    height: 34px;
    min-width: 34px;
    flex: 0 0 34px;
    border-radius: 10px;
  }

  .hsocial__btn img {
    width: 50px;
    height: 50px;
    object-fit: contain;
  }
     .seo-block {
    padding: 64px 0 80px;
  }

  .seo-block__inner {
    max-width: 920px;
    padding: 52px 56px;
    border-radius: 28px;
  }

  .seo-block__inner::before {
    left: 56px;
  }

  .seo-block__title {
    font-size: 40px;
  }

  .seo-block__text,
  .seo-block__title {
    max-width: 720px;
  }

  .seo-block__text p {
    font-size: 17px;
  }
  .nav {
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 10px 18px 9px;
  }

  .nav__link {
    font-size: 12px;
    line-height: 1.1;
    padding: 4px 0;
    white-space: nowrap;
  }
}

/* =========================================
   1200
   ========================================= */
@media (max-width: 1200px) {
  .container {
    padding: 0 18px;
  }

  .hero {
    min-height: 400px;
  }

  .hero__inner {
    padding: 48px 18px 34px;
  }

  .hero__title {
    font-size: 36px;
  }

  .hero__subtitle {
    font-size: 17px;
  }

  .hero__text {
    font-size: 15px;
    max-width: 700px;
  }

  .hero__actions--center .btn {
    width: 220px;
  }
  .hero__content--center{  margin-bottom: -23px; }
  :root {
    --svc-card-w: 280px;
    --svc-gap: 18px;
    --svc-media-h: 180px;
  }

  .services-container {
    width: calc(var(--svc-card-w) * 3 + var(--svc-gap) * 2);
  }

  .extra-grid {
    grid-template-columns: repeat(2, var(--svc-card-w));
    gap: var(--svc-gap);
    justify-content: center;
  }

  .arrow.left {
    left: -48px;
  }

  .arrow.right {
    right: -48px;
  }

  #benefits .benefits-container {
    --b-card-w: 280px;
    --b-gap: 18px;
    --b-media-h: 180px;
    width: calc(var(--b-card-w) * 3 + var(--b-gap) * 2);
  }

  #benefits .benefits-arrow.left {
    left: -48px;
  }

  #benefits .benefits-arrow.right {
    right: -48px;
  }
  .footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer__col--right {
    text-align: left;
  }
}

/* =========================================
   1100
   ========================================= */
@media (max-width: 1100px) {
  .header__top {
    grid-template-columns: auto 1fr auto auto;
    gap: 57px;
    padding: 14px 16px;
    align-items: center;
  }

  .header__top .hitem:nth-of-type(4) {
    display: none;
  }

  .brand__logo {
    height: 32px;
    max-width: 155px;
  }

  .header__top .hitem:nth-of-type(1) {
    max-width: 170px;
  }

  .header__top .hitem:nth-of-type(2) {
    max-width: 155px;
  }

  .header__top .hitem:nth-of-type(3) {
    max-width: 145px;
  }

  .hitem__label {
    font-size: 10px;
  }

  .hitem__text {
    font-size: 12px;
  }

  .nav {
    gap: 12px;
    padding: 10px 16px;
  }

  .nav__link {
    font-size: 12px;
  }

  .hsocial {
    grid-column: 6;
    grid-row: 1;
    justify-self: end;
    align-self: center;
    display: flex;
    gap: 27px;
    margin-top: 12px;
    min-width: max-content;
  }

  .stages__card::after,
  .stages__card::before {
    display: none !important;
  }
}

/* =========================================
   1024
   ========================================= */
@media (max-width: 1024px) {
  .container {
    max-width: 100%;
    padding: 0 16px;
  }

  .hero {
    min-height: 380px;
  }

  .hero__inner {
    padding: 42px 16px 30px;
  }

  .hero__title {
    font-size: 32px;
    line-height: 1.15;
  }

  .hero__subtitle {
    font-size: 16px;
  }

  .hero__text {
    font-size: 15px;
    line-height: 1.5;
    max-width: 680px;
  }

  .hero__actions--center .btn {
    width: 220px;
  }
   .seo-block {
    padding: 56px 0 72px;
  }

  .seo-block__inner {
    max-width: 100%;
    padding: 44px 40px;
    border-radius: 24px;
  }

  .seo-block__inner::before {
    left: 40px;
    width: 72px;
  }

  .seo-block__title {
    margin-bottom: 20px;
    font-size: 34px;
    line-height: 1.12;
  }

  .seo-block__text p {
    margin-bottom: 16px;
    font-size: 16px;
    line-height: 1.72;
  }
  :root {
    --svc-card-w: 220px;
    --svc-gap: 16px;
    --svc-media-h: 150px;
  }

  #services .services-container {
    width: calc(var(--svc-card-w) * 2 + var(--svc-gap));
  }

  #services .carousel-viewport {
    overflow: hidden;
    padding: 16px 0;
  }

  #services .carousel-track {
    gap: var(--svc-gap);
  }

  #services .carousel-track .card {
    width: var(--svc-card-w);
    flex: 0 0 var(--svc-card-w);
  }

  .extra-grid {
    grid-template-columns: repeat(2, var(--svc-card-w));
    gap: 16px;
    justify-content: center;
  }

  #benefits .benefits-container {
    width: calc(var(--b-card-w) * 2 + var(--b-gap));
  }

  #benefits .benefits-viewport {
    overflow: hidden;
    padding: 16px 0;
  }

  #benefits .benefits-track {
    gap: var(--b-gap);
  }

  #benefits .benefits-card {
    width: var(--b-card-w);
    flex: 0 0 var(--b-card-w);
  }

  .arrow.left {
    left: -52px;
  }

  .arrow.right {
    right: -52px;
  }

  #benefits .benefits-arrow.left {
    left: -42px;
  }

  #benefits .benefits-arrow.right {
    right: -42px;
  }

  section.stages {
    padding: 64px 0 !important;
  }

  section.stages .stages__board {
    position: static !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
    min-height: 0 !important;
    height: auto !important;
    max-width: 720px !important;
    margin: 0 auto !important;
    padding-top: 0 !important;
  }

  section.stages div.stages__card,
  section.stages div.stages__card--top,
  section.stages div.stages__card--right,
  section.stages div.stages__card--bottom-right,
  section.stages div.stages__card--bottom-left,
  section.stages div.stages__card--left {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    z-index: 2 !important;
  }

  section.stages div.stages__card:hover,
  section.stages div.stages__card--top:hover,
  section.stages div.stages__card--right:hover,
  section.stages div.stages__card--bottom-right:hover,
  section.stages div.stages__card--bottom-left:hover,
  section.stages div.stages__card--left:hover {
    transform: translateY(-4px) !important;
  }

  section.stages div.stages__card::before,
  section.stages div.stages__card::after,
  section.stages div.stages__card--top::before,
  section.stages div.stages__card--top::after,
  section.stages div.stages__card--right::before,
  section.stages div.stages__card--right::after,
  section.stages div.stages__card--bottom-right::before,
  section.stages div.stages__card--bottom-right::after,
  section.stages div.stages__card--bottom-left::before,
  section.stages div.stages__card--bottom-left::after,
  section.stages div.stages__card--left::before,
  section.stages div.stages__card--left::after {
    display: none !important;
    content: none !important;
    background: none !important;
  }

  section.stages .stages__image {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    margin-bottom: 14px !important;
  }

  section.stages .stages__title {
    font-size: 16px !important;
    line-height: 1.3 !important;
    margin-bottom: 8px !important;
  }

  section.stages .stages__text {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  .footer {
    padding: 32px 0;
  }

  .footer__grid{
    display:grid !important;
    grid-template-columns:1fr 1fr 1fr !important;
    gap:24px !important;
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
  }

  .footer__grid > div:nth-child(1),
  .footer__grid > div:nth-child(2){
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    justify-self:stretch !important;
    text-align:left !important;
  }

  .footer__right{
    grid-column:1 / -1 !important;
    text-align:center !important;
    margin-top:12px !important;
    padding-top:8px !important;
  }
}

/* =========================================
   992
   ========================================= */
@media (max-width: 992px) {
  .container {
    padding: 0 16px;
  }

  .hero {
    min-height: 380px;
  }

  .hero__inner {
    padding: 44px 16px 30px;
  }

  .hero__title {
    font-size: 32px;
    line-height: 1.16;
  }

  .hero__subtitle {
    font-size: 16px;
  }

  .hero__text {
    font-size: 15px;
    line-height: 1.5;
  }

  .section-title {
    font-size: 28px;
  }

  :root {
    --svc-card-w: 250px;
    --svc-gap: 16px;
    --svc-media-h: 168px;
  }

  .services-container {
    width: calc(var(--svc-card-w) * 2 + var(--svc-gap));
  }

  .extra-grid {
    grid-template-columns: repeat(2, var(--svc-card-w));
    gap: var(--svc-gap);
    justify-content: center;
  }

  #benefits .benefits-container {
    --b-card-w: 250px;
    --b-gap: 16px;
    --b-media-h: 168px;
    width: calc(var(--b-card-w) * 2 + var(--b-gap));
  }

  .form-grid,
  .request-grid,
  .order-grid,
  #request form .grid,
  #order form .grid,
  #form form .grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .reviews__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #map .map-full iframe {
    height: 360px;
  }
  .footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 32px;
    row-gap: 24px;
  }

  .footer__bottom {
    flex-wrap: wrap;
  }
}

/* =========================================
   960
   ========================================= */
@media (max-width: 960px) {
  .header__top {
    display: grid;
    grid-template-columns: 145px 1fr 120px 92px 78px;
    align-items: center;
    gap: 8px 80px;
    padding: 10px 14px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }

  .brand {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
  }

  .brand__logo {
    height: 28px;
    max-width: 135px;
  }

  .header__top .hitem:nth-of-type(1) {
    display: flex;
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    max-width: 210px;
  }

  .header__top .hitem:nth-of-type(2) {
    display: none;
  }

  .header__top .hitem:nth-of-type(3) {
    display: flex;
    grid-column: 3;
    grid-row: 1;
    min-width: 120px;
    max-width: 120px;
  }

  .header__top .hitem:nth-of-type(4) {
    display: flex;
    grid-column: 4;
    grid-row: 1;
    min-width: 92px;
    max-width: 92px;
  }

  .hitem {
    min-width: 0;
  }

  .hitem__label {
    font-size: 9px;
    margin-bottom: 2px;
    line-height: 1.05;
  }

  .hitem__text {
    font-size: 11px;
    line-height: 1.1;
  }

  .hsocial {
    grid-column: 5;
    grid-row: 1;
    display: flex;
    gap: 6px;
    justify-self: end;
    align-self: center;
    min-width: max-content;
    margin: 0;
  }

  .hsocial__btn {
    width: 30px;
    height: 30px;
    min-width: 30px;
    flex: 0 0 30px;
    border-radius: 9px;
  }

  .hsocial__btn img {
    width: 35px;
    height: 35px;
    object-fit: contain;
  }

  .nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px 9.5%;
    padding: 10px 14px;
  }

  .nav__link {
    font-size: 12px;
    line-height: 1.1;
    padding: 4px 0;
    white-space: nowrap;
  }
}

/* =========================================
   900
   ========================================= */
@media (max-width: 900px) {
  #map .map-full iframe {
    height: 360px;
  }
}

/* =========================================
   768
   ========================================= */
@media (max-width: 768px) {
  html,
  body {
    overflow-x: hidden !important;
  }

  .header {
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    background: #fff !important;
    transform: none !important;
    transition: none !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .header.is-hidden,
  .header.hide,
  .header.header--hidden,
  .header.is-scrolled {
    transform: translateY(0) !important;
    top: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .header__top {
    display: grid !important;
    grid-template-columns: 1fr 126px 96px auto !important;
    align-items: center !important;
    gap: 10px 88px !important;
    padding: 10px 14px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .brand {
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important;
  }

  .brand__logo {
    display: block !important;
    height: 26px !important;
    width: auto !important;
    max-width: 132px !important;
    object-fit: contain !important;
  }

  .header__top > .hitem {
    display: none !important;
  }

  .header__top > .hitem:nth-of-type(1) {
    display: none !important;
  }

  .header__top > .hitem:nth-of-type(2) {
    display: none !important;
  }

  .header__top > .hitem:nth-of-type(3) {
    display: flex !important;
    flex-direction: column !important;
    min-width: 126px !important;
    max-width: 126px !important;
    margin: 0 !important;
    grid-column: 2 !important;
  }

  .header__top > .hitem:nth-of-type(4) {
    display: flex !important;
    flex-direction: column !important;
    min-width: 96px !important;
    max-width: 96px !important;
    margin: 0 !important;
    grid-column: 3 !important;
  }

  .hitem__label {
    display: block !important;
    margin-bottom: 1px !important;
    font-size: 9px !important;
    line-height: 1 !important;
  }

  .hitem__text {
    display: block !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
  }

  .hsocial {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 25px !important;
    margin: 0 !important;
    padding: 0 !important;
    min-width: max-content !important;
    grid-column: 4 !important;
    justify-self: end !important;
  }

  .hsocial__btn {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    flex: 0 0 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
  }

  .hsocial__btn img {
    display: block !important;
    width: 35px !important;
    height: 35px !important;
    object-fit: contain !important;
  }

  .burger {
    display: none !important;
  }

  .nav {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 55px!important;
    background: #fff !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: nowrap !important;
    scrollbar-width: none !important;
    padding: 10px 16px 14px !important;
  }

  .nav::-webkit-scrollbar {
    display: none;
  }

 .nav__link,
  .nav__link.is-active,
  .nav__link.is-active-768 {
    color: rgba(11, 15, 19, 0.72) !important;
    border-bottom: none !important;
    box-shadow: none !important;
  }

  .nav__link:hover,
  .nav__link:focus,
  .nav__link:active {
    color: rgba(11, 15, 19, 0.95) !important;
    border-bottom: none !important;
    box-shadow: none !important;
  }

  .container {
    max-width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .hero {
    min-height: 300px !important;
  }

  .hero__bg {
    position: absolute;
    inset: 0;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, .00), rgba(255, 255, 255, .70)),
      url(../assets/img/fon_block1.webp);
    background-size: 100% auto !important;
    background-position: center 28px !important;
    background-position: center;
  }

 /* .hero__inner {
    padding: 28px 12px 22px !important;
  }*/
 .hero__content--center{  margin-bottom: 25px; }
  .hero__title {
    font-size: 24px !important;
    line-height: 1.15 !important;
  }

  .hero__subtitle {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  .hero__text {
    font-size: 12px !important;
    line-height: 1.4 !important;
    max-width: 70% !important;
  }

  .hero__actions--center {
    gap: 10px !important;
  }

  .hero__actions--center .btn {
    width: min(100%, 280px) !important;
  }
   .seo-block {
    padding: 48px 0 64px;
  }

  .seo-block__inner {
    padding: 36px 24px;
    border-radius: 20px;
  }

  .seo-block__inner::before {
    left: 24px;
    width: 64px;
    height: 3px;
  }

  .seo-block__title {
    font-size: 28px;
    line-height: 1.18;
  }

  .seo-block__text p {
    font-size: 15px;
    line-height: 1.68;
  }
  #services,
  #benefits {
    overflow: hidden !important;
  }

  #services .services-container,
  #benefits .benefits-container {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  #services .carousel,
  #benefits .benefits-carousel {
    width: 100% !important;
    overflow: hidden !important;
  }

  #services .carousel-viewport,
  #benefits .benefits-viewport {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    padding: 12px 0 14px !important;
  }

  #services .carousel-viewport::-webkit-scrollbar,
  #benefits .benefits-viewport::-webkit-scrollbar {
    display: none !important;
  }

  #services .carousel-track,
  #benefits .benefits-track {
    display: flex !important;
    gap: 12px !important;
    width: max-content !important;
    min-width: 100% !important;
  }

  #services .carousel-track .card,
  #benefits .benefits-card {
    width: calc((100vw - 36px) / 2) !important;
    max-width: 240px !important;
    flex: 0 0 calc((100vw - 36px) / 2) !important;
    scroll-snap-align: start !important;
  }

  #services .card,
  #benefits .benefits-card,
  #services .card:hover,
  #benefits .benefits-card:hover {
    transform: none !important;
  }

  .arrow,
  #benefits .benefits-arrow {
    display: none !important;
  }

  .extra-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    justify-content: stretch !important;
  }

  .extra-grid .card {
    width: 100% !important;
    min-width: 0 !important;
  }

  #benefits .benefits-container {
    width: 100%;
    max-width: 100%;
    --b-card-w: calc((100vw - 42px) / 2);
    --b-gap: 12px;
    --b-media-h: 150px;
  }

  #benefits .benefits-viewport {
    overflow: hidden;
    padding: 12px 0 16px;
  }

  #benefits .benefits-card {
    width: var(--b-card-w);
    flex: 0 0 var(--b-card-w);
    padding: 14px;
  }

  #benefits .benefits-media {
    height: var(--b-media-h);
    padding: 10px;
  }

  #benefits .benefits-card p {
    font-size: 12px;
    line-height: 1.35;
    min-height: auto;
  }

  .arrow.left,
  .arrow.right,
  #benefits .benefits-arrow {
    display: none;
  }

  .form-wrap,
  .request-form,
  .order-form,
  #request form,
  #order form,
  #form form {
    padding: 22px 18px 20px;
    border-radius: 18px;
  }

  #request,
  #order,
  #form,
  section#request,
  section#order,
  section#form {
    padding: 0px 0 80px;
  }

  #request .section-title,
  #order .section-title,
  #form .section-title {
    font-size: 28px;
  }

  .reviews__grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .reviews__scorebox,
  .reviews__actions .btn,
  .reviews__bigbtn {
    width: 100%;
  }

  #map .map-full iframe {
    height: 300px;
  }

  .footer {
    padding: 30px 0 22px;
  }

  .footer .container {
    width: calc(100% - 32px);
  }

  .footer__grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .footer__title {
    font-size: 17px;
    margin-bottom: 10px;
  }

  .footer__text {
    font-size: 12px;
    margin-bottom: 8px;
  }

  .footer__bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-top: 24px;
  }

  .footer__bottom-text {
    font-size: 13px;
  }
}

/* =========================================
   640
   ========================================= */
@media (max-width: 640px) {
  .header {
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    background: #fff !important;
    transform: none !important;
    transition: none !important;
  }

  .header.is-hidden,
  .header.hide,
  .header.header--hidden,
  .header.is-scrolled {
    transform: translateY(0) !important;
    top: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .header__top {
    display: grid !important;
    grid-template-columns: auto 1fr auto auto auto !important;
    align-items: center !important;
    column-gap: 8px !important;
    padding: 8px 12px !important;
    min-height: 48px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  }

  /* скрываем адрес, почту и график */
  .header__top > .hitem:nth-of-type(1),
  .header__top > .hitem:nth-of-type(2),
  .header__top > .hitem:nth-of-type(4),
  .hstack {
    display: none !important;
  }

  /* logo */
  .brand {
    grid-column: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    min-width: 0 !important;
    margin: 0 !important;
    line-height: 0 !important;
  }

  .brand__logo {
    display: block !important;
    width: auto !important;
    height: 22px !important;
    max-width: 120px !important;
    object-fit: contain !important;
  }

  /* телефон */
  .header__top > .hitem:nth-of-type(3) {
    grid-column: 2 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-self: center !important;
    text-align: center !important;
    min-width: 0 !important;
    max-width: 120px !important;
    margin: 0 !important;
  }

  .header__top > .hitem:nth-of-type(3) .hitem__label {
    display: none !important;
  }

  .header__top > .hitem:nth-of-type(3) .hitem__text {
    display: block !important;
    font-size: 11px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    text-align: center !important;
    margin: 0 !important;
  }

  /* соцсети */
  .hsocial {
    grid-column: 3 / 5 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    justify-self: end !important;
    gap: 6px !important;
    margin: 0 !important;
    padding: 0 !important;
    min-width: max-content !important;
  }

  .hsocial__btn {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    flex: 0 0 28px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 8px !important;
    background: #fff !important;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05) !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .hsocial__btn img {
    width: 28px !important;
    height: 28px !important;
    object-fit: contain !important;
    display: block !important;
  }

  /* бургер */
  .burger {
    grid-column: 5 !important;
    justify-self: end !important;
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 8px !important;
    background: #fff !important;
    position: relative !important;
    cursor: pointer !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
  }

  .burger span {
    position: absolute !important;
    left: 7px !important;
    width: 15px !important;
    height: 2px !important;
    background: #111 !important;
    border-radius: 2px !important;
    transition: transform 0.25s ease, opacity 0.2s ease, top 0.25s ease !important;
  }

  .burger span:nth-child(1) { top: 9px !important; }
  .burger span:nth-child(2) { top: 14px !important; }
  .burger span:nth-child(3) { top: 19px !important; }

  .burger[aria-expanded="true"] span:nth-child(1) {
    top: 14px !important;
    transform: rotate(45deg) !important;
  }

  .burger[aria-expanded="true"] span:nth-child(2) {
    opacity: 0 !important;
  }

  .burger[aria-expanded="true"] span:nth-child(3) {
    top: 14px !important;
    transform: rotate(-45deg) !important;
  }

  /* nav в выпадашку */
  .nav {
    display: none !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 10px 12px 14px !important;
    background: #fff !important;
    flex-direction: column !important;
    gap: 8px !important;
    box-shadow: 0 14px 24px rgba(0, 0, 0, 0.08) !important;
    z-index: 1001 !important;
    overflow: hidden !important;
  }

  .nav.is-open {
    display: flex !important;
  }

  .nav__link {
    display: block !important;
    width: 100% !important;
    padding: 12px 14px !important;
    background: #f5f6f7 !important;
    border-radius: 12px !important;
    color: #111 !important;
    font-size: 14px !important;
    line-height: 1.3 !important;
    text-decoration: none !important;
    border-bottom: none !important;
  }

  .nav__link.is-active,
  .nav__link.is-active-768 {
    border-bottom: none !important;
    color: #111 !important;
  }
   .footer {
    padding: 28px 0 !important;
  }

  .footer .container.footer__grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    column-gap: 20px !important;
    row-gap: 18px !important;
    align-items: start !important;

    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 16px !important;
    box-sizing: border-box !important;
  }

  .footer .container.footer__grid > div:nth-child(1),
  .footer .container.footer__grid > div:nth-child(2) {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .footer .container.footer__grid > div:nth-child(1) {
    justify-self: start !important;
    text-align: left !important;
  }

  .footer .container.footer__grid > div:nth-child(2) {
    justify-self: end !important;
    text-align: right !important;
  }

  .footer__title {
    margin: 0 0 10px !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
  }

  .footer__text,
  .footer__text a,
  .footer .link {
    margin: 4px 0 !important;
    font-size: 9px !important;
    line-height: 1.45 !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    text-decoration: none !important;
  }

  .footer__right {
    grid-column: 1 / -1 !important;
    text-align: center !important;
    margin-top: 6px !important;
    padding-top: 8px !important;
  }
}

/* =========================================
   548
   ========================================= */
@media (max-width: 548px) {
   .header__top {
    display: grid !important;
    grid-template-columns: auto 1fr auto auto !important;
    align-items: center !important;
    column-gap: 8px !important;
    padding: 8px 12px !important;
    min-height: 44px !important;
  }

  /* скрываем адрес, почту и график */
  .header__top > .hitem:nth-of-type(1),
  .header__top > .hitem:nth-of-type(2),
  .header__top > .hitem:nth-of-type(4),
  .hstack {
    display: none !important;
  }

  /* оставляем только телефон */
  .header__top > .hitem:nth-of-type(3) {
   display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-self: center !important;
    text-align: center !important;
    min-width: 110px !important;
    margin: 0 !important;
     grid-template-columns: auto 1fr auto auto !important;
  }

  .brand {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    min-width: 0 !important;
    margin: 0 !important;
    line-height: 0 !important;
    grid-column: 1 !important;
  }
   .header__top > .hitem:nth-of-type(3) .hitem__text {
    font-size: 12px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    text-align: center !important;
     grid-column: 2 !important;
    margin-top: 0px;
  }
  .brand__logo {
    display: block !important;
    width: auto !important;
    height: 20px !important;
    max-width: 96px !important;
    object-fit: contain !important;
  }

  .hitem__label {
    display: none !important;
  }

  .hitem__text {
    display: block !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }

  .hsocial {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 5px !important;
    margin: 0 !important;
    padding: 0 !important;
    grid-column: 3 !important;
    justify-self: end !important;
  }

  .hsocial__btn {
    width: 31px !important;
    height: 31px !important;
    min-width: 24px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 7px !important;
    background: #fff !important;
    color: #111 !important;
    text-decoration: none !important;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05) !important;
    font-size: 10px !important;
    line-height: 1 !important;
    padding: 0 !important;
  }

  .burger {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 8px !important;
    background: #fff !important;
    position: relative !important;
    cursor: pointer !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
    grid-column: 4 !important;
    justify-self: end !important;
  }

  .burger span {
    position: absolute !important;
    left: 7px !important;
    width: 15px !important;
    height: 2px !important;
    background: #111 !important;
    border-radius: 2px !important;
    transition: transform 0.25s ease, opacity 0.2s ease, top 0.25s ease !important;
  }

  .burger span:nth-child(1) { top: 9px !important; }
  .burger span:nth-child(2) { top: 14px !important; }
  .burger span:nth-child(3) { top: 19px !important; }

  .burger[aria-expanded="true"] span:nth-child(1) {
    top: 14px !important;
    transform: rotate(45deg) !important;
  }

  .burger[aria-expanded="true"] span:nth-child(2) {
    opacity: 0 !important;
  }

  .burger[aria-expanded="true"] span:nth-child(3) {
    top: 14px !important;
    transform: rotate(-45deg) !important;
  }

  .nav {
    display: none !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 10px 14px 14px !important;
    background: #fff !important;
    flex-direction: column !important;
    gap: 8px !important;
    box-shadow: 0 14px 24px rgba(0, 0, 0, 0.08) !important;
    z-index: 1001 !important;
  }

  .nav.is-open {
    display: flex !important;
  }

  .nav__link {
    display: block !important;
    width: 100% !important;
    padding: 12px 14px !important;
    background: #f5f6f7 !important;
    border-radius: 12px !important;
    color: #111 !important;
    font-size: 14px !important;
    line-height: 1.3 !important;
    text-decoration: none !important;
  }
 .seo-block {
    padding: 40px 0 56px;
  }

  .seo-block__inner {
    padding: 30px 18px;
    border-radius: 18px;
  }

  .seo-block__inner::before {
    left: 18px;
    width: 56px;
  }

  .seo-block__title {
    margin-bottom: 16px;
    font-size: 24px;
    line-height: 1.2;
  }

  .seo-block__text p {
    margin-bottom: 14px;
    font-size: 14px;
    line-height: 1.62;
  }
  #services .arrow,
  #services .left,
  #services .right {
    display: none !important;
  }

  #services .carousel,
  #services .carousel-viewport,
  #services .services-container {
    width: 100% !important;
    max-width: 100% !important;
  }

  #services .carousel {
    overflow: hidden !important;
  }

  #services .carousel-viewport {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
    padding: 0 16px 6px !important;
  }

  #services .carousel-viewport::-webkit-scrollbar {
    display: none !important;
  }

  #services .carousel-track {
    display: flex !important;
    gap: 14px !important;
    width: max-content !important;
    min-width: 100% !important;
    transform: none !important;
    margin: 0 !important;
    box-sizing: border-box !important;
  }

  #services .carousel-track > .card {
    width: min(320px, calc(100vw - 60px)) !important;
    max-width: min(320px, calc(100vw - 60px)) !important;
    min-width: 0 !important;
    margin: 0 !important;
    flex: 0 0 min(320px, calc(100vw - 60px)) !important;
    scroll-snap-align: start !important;
  }

  #services .extra-grid > .card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    flex: none !important;
  }

  #services .card {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding: 16px !important;
    border-radius: 16px !important;
    min-height: 300px !important;
  }

  #services .card-img {
    width: 100% !important;
    height: 200px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 16px 14px 10px !important;
    margin-bottom: 12px !important;
  }

  #services .card-img img,
  #services .card img {
    display: block !important;
    width: auto !important;
    max-width: 88% !important;
    max-height: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    margin: 0 auto !important;
  }

  #services .card p {
    margin: 0 !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    text-align: center !important;
    min-height: 38px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  #services .extra-grid {
    display: flex !important;
    gap: 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
    padding: 0 16px 6px !important;
    margin: 14px 0 0 !important;
  }

  #services .extra-grid::-webkit-scrollbar {
    display: none !important;
  }

  #services .extra-grid > .card {
    width: min(320px, calc(100vw - 60px)) !important;
    max-width: min(320px, calc(100vw - 60px)) !important;
    min-width: 0 !important;
    margin: 0 !important;
    flex: 0 0 min(320px, calc(100vw - 60px)) !important;
    scroll-snap-align: start !important;
  }

  #benefits .benefits-arrow,
  #benefits .left,
  #benefits .right {
    display: none !important;
  }

  #benefits .benefits-carousel,
  #benefits .benefits-container,
  #benefits .benefits-viewport {
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  #benefits .benefits-viewport {
    overflow: visible !important;
    padding: 0 !important;
  }

  #benefits .benefits-track {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    transform: none !important;
    margin: 0 !important;
  }

  #benefits .benefits-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    flex: none !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 16px !important;
    border-radius: 16px !important;
  }

  #benefits .benefits-media {
    width: 100% !important;
    height: 190px !important;
    margin-bottom: 12px !important;
  }

  #benefits .benefits-media img,
  #benefits .benefits-card img {
    display: block !important;
    width: 83% !important;
    height: 113% !important;
    object-fit: cover !important;
    margin: 0 auto !important;
    border-radius: 12px !important;
  }

  #benefits .benefits-card p {
    margin: 0 !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    text-align: center !important;
  }
    #reviews.section {
    overflow-x: hidden !important;
  }

  #reviews .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  #reviews .reviews__top,
  #reviews .reviews__grid,
  #reviews .reviews__bottom {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    box-sizing: border-box !important;
  }

  #reviews .reviews__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  #reviews .review {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 12px !important;
    border-radius: 16px !important;
    box-sizing: border-box !important;
  }

  #reviews .reviews__scorebox,
  #reviews .reviews__actions,
  #reviews .reviews__bigbtn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #reviews .reviews__actions .btn,
  #reviews .reviews__bigbtn {
    width: 100% !important;
  }

  #reviews .review__head {
    gap: 8px !important;
  }

  #reviews .review__user {
    min-width: 0 !important;
  }

  #reviews .review__name {
    font-size: 13px !important;
    line-height: 1.2 !important;
  }

  #reviews .review__lvl,
  #reviews .review__date {
    font-size: 11px !important;
  }

  #reviews .review__text {
    font-size: 13px !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
  }
   .footer__text,
  .footer__text a,
  .footer .link {
    font-size: 14px !important;
  }
}

/* =========================================
   520
   ========================================= */
@media (max-width: 520px){
  .hero__actions--center{
    flex-direction: column;
    align-items: center;
  }
  .hero__actions--center .btn{
    width: min(92vw, 320px);
  }
  .footer {
    background: #9b9b9b;
    padding: 24px 0 20px;
  }

  .footer .container,
  .footer__inner {
    width: calc(100% - 24px);
    margin: 0 auto;
  }

  .footer__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .footer__col {
    width: 100% !important;
    min-width: 0 !important;
    padding: 0;
    border: none !important;
    text-align: left;
  }

  .footer__title {
    margin: 0 0 10px;
    font-size: 16px;
    line-height: 1.2;
    font-weight: 700;
    color: #fff;
    text-align: left;
  }

  .footer__text {
    margin: 0 0 6px;
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.95);
    text-align: left;
    word-break: break-word;
  }

  .footer__text:last-child {
    margin-bottom: 0;
  }

  .footer .link {
    color: rgba(255, 255, 255, 0.95);
    text-decoration: none;
  }

  .footer .link:hover {
    color: #fff;
    text-decoration: underline;
  }

  .footer__bottom {
    margin-top: 18px !important;
    padding-top: 0;
    border: none !important;
    text-align: center !important;
  }

  .footer__bottom-text {
    margin: 0 0 6px !important;
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.9);
    text-align: center;
  }

  .footer__bottom-credit {
    display: block !important;
    font-size: 13px;
    line-height: 1.5;
    font-weight: 500;
    color: #ffffff;
    text-align: center;
    margin-top: 15px;
  }
}

/* =========================================
   420
   ========================================= */
@media (max-width: 425px) {
  .container {
    padding: 0 10px;
  }

  .nav {
    padding: 8px 10px 10px;
    gap: 8px 12px;
  }

  .nav__link {
    font-size: 12px;
  }
  .hero {
    position: relative !important;
    overflow: hidden !important;
  }

  .hero::after {
    content: "" !important;
    position: absolute !important;
    inset: 10px 10px 14px 10px !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, 0.30) !important;
    -webkit-backdrop-filter: blur(10px) saturate(135%) !important;
    backdrop-filter: blur(10px) saturate(135%) !important;
    border: 1px solid rgba(255, 255, 255, 0.34) !important;
    box-shadow:
      0 8px 24px rgba(11, 15, 19, 0.10),
      inset 0 1px 0 rgba(255, 255, 255, 0.22) !important;
    z-index: 1 !important;
    pointer-events: none !important;
  }

  .hero__inner {
    position: relative !important;
    z-index: 2 !important;
  }

  .hero__content--center {
    max-width: 92% !important;
    margin: 0 auto !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  .hero__title,
  .hero__subtitle,
  .hero__text,
  .hero__actions,
  .hero__actions--center {
    position: relative !important;
    z-index: 2 !important;
  }

  .hero__title {
    text-shadow: none !important;
  }
  /*.hero__inner {
    padding: 32px 10px 22px;
  }*/

  .hero__title {
    font-size: 22px;
  }

  .hero__subtitle {
    font-size: 13px;
  }

  .hero__text {
    font-size: 12.5px;
  }
   .hero__actions {
    gap: 10px;
    padding-bottom: 20px;
  }

  .hero__actions .btn,
  .hero__actions-center .btn {
    min-height: 42px;
    padding: 0 18px;
    font-size: 14px;
    line-height: 1;
    border-radius: 12px;
  }

  .hero__actions .btn--primary,
  .hero__actions .btn--ghost,
  .hero__actions-center .btn--primary,
  .hero__actions-center .btn--ghost {
    width: 100%;
    max-width: 220px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }
   .seo-block {
    padding: 42px 0;
  }

  .seo-block__title {
    font-size: 22px;
  }

  .seo-block__text p {
    font-size: 14px;
    line-height: 1.6;
  }
  .section-title {
    font-size: 20px;
  }

  :root {
    --svc-card-w: calc(100vw - 40px);
  }

  #benefits .benefits-container {
    --b-card-w: calc(100vw - 40px);
  }

  .form-wrap,
  .request-form,
  .order-form,
  #request form,
  #order form,
  #form form {
    padding: 18px 14px 16px;
  }
  #reviews .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  #reviews .reviews__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  #reviews .review {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    padding: 12px !important;
    border-radius: 16px !important;
  }

  #reviews .reviews__top,
  #reviews .reviews__scorebox,
  #reviews .reviews__actions,
  #reviews .reviews__bottom,
  #reviews .reviews__bigbtn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #reviews .reviews__actions .btn,
  #reviews .reviews__bigbtn {
    width: 100% !important;
    margin-bottom: 10px;
    margin-top: 10px;
  }

  #reviews .review__head {
    gap: 8px !important;
  }

  #reviews .review__name {
    font-size: 13px !important;
    line-height: 1.2 !important;
  }

  #reviews .review__lvl,
  #reviews .review__date {
    font-size: 11px !important;
  }

  #reviews .review__text {
    font-size: 13px !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
  }
  #request .section-title,
  #order .section-title,
  #form .section-title {
    font-size: 22px;
  }

  #map .map-full iframe {
    height: 230px;
  }

  .reviews__score {
    font-size: 38px;
  }
}

 
@media (max-width: 375px) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip !important;
  }

  body * {
    min-width: 0 !important;
  }

  .container,
  .header,
  .header__top,
  .hero,
  .section,
  .services,
  .services-container,
  #services .carousel,
  #services .carousel-viewport,
  #services .carousel-track,
  #benefits,
  #benefits .benefits-container,
  #benefits .benefits-carousel,
  #benefits .benefits-viewport,
  #benefits .benefits-track,
  #reviews,
  #reviews .reviews__grid,
  .stages,
  .stages__board,
  .footer,
  .footer__grid {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* если скролл даёт шапка */
  .header__top {
    overflow: hidden !important;
  }

  .nav {
    max-width: 100% !important;
    box-sizing: border-box !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
  }
  .hero .container,
  .hero__inner {
    width: calc(100% - 16px) !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  .hero__content.hero__content--center {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    box-sizing: border-box !important;
  }

  .hero__content-center {
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
  }
  /* services */
  #services .card,
  #services .extra-grid > .card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #services .carousel-track > .card {
    width: min(320px, calc(100vw - 60px)) !important;
    max-width: min(320px, calc(100vw - 60px)) !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #services .extra-grid > .card {
    width: min(320px, calc(100vw - 60px)) !important;
    max-width: min(320px, calc(100vw - 60px)) !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  /* benefits */
  #benefits .benefits-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #benefits .benefits-media {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
  }

  /* reviews */
   #reviews,
  #reviews .container,
  #reviews .reviews__grid {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #reviews .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
    overflow-x: hidden !important;
  }

  #reviews .reviews__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    overflow-x: hidden !important;
  }

  #reviews .review {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #reviews .reviews__top,
  #reviews .reviews__scorebox,
  #reviews .reviews__actions,
  #reviews .reviews__bottom,
  #reviews .reviews__bigbtn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #reviews .reviews__actions .btn,
  #reviews .reviews__bigbtn {
    width: 100% !important;
  }

  /* stages — чаще всего именно они ломают ширину */
  section.stages .stages__board {
    overflow: hidden !important;
  }

  section.stages .stages__card,
  section.stages .stages__card--top,
  section.stages .stages__card--right,
  section.stages .stages__card--bottom-right,
  section.stages .stages__card--bottom-left,
  section.stages .stages__card--left {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 0 14px 0 !important;
    padding: 12px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  section.stages .stages__image {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
  }
  .footer__text, .footer__text a, .footer .link
{
  font-size: 9px !important;
}
}
/* =========================================
   360
   ========================================= */
@media (max-width: 360px) {
  .hero {
    min-height: 300px !important;
    padding-top: 10px !important;
  }

  .hero__inner {
    padding: 20px 10px 18px !important;
  }

  .hero__content,
  .hero__content--center {
    max-width: 100% !important;
    margin: 18px 0px 34px !important;
    text-align: center !important;
  }

  .hero__title {
    font-size: 16px !important;
    line-height: 1.12 !important;
    margin: 0 0 8px !important;
    max-width: 290px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-wrap: balance;
  }

  .hero__subtitle {
    font-size: 11px !important;
    line-height: 1.25 !important;
    margin: 0 0 6px !important;
    max-width: 260px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .hero__text {
    font-size: 10px !important;
    line-height: 1.28 !important;
    margin: 0 0 12px !important;
    max-width: 270px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .hero__actions,
  .hero__actions--center {
    gap: 8px !important;
  }

  .hero__actions .btn,
  .hero__actions--center .btn {
    max-width: 250px !important;
    height: 36px !important;
    font-size: 11px !important;
    border-radius: 10px !important;
  }
  .seo-block__inner {
    padding: 26px 16px;
    border-radius: 16px;
  }

  .seo-block__inner::before {
    left: 16px;
    width: 48px;
  }

  .seo-block__title {
    font-size: 21px;
  }

  .seo-block__text p {
    font-size: 14px;
    line-height: 1.58;
  }
  .btn {
    font-size: 13px;
    padding: 0 12px;
  }

  .section-title {
    font-size: 19px;
  }
    section.stages .stages__image {
    height: 205px !important;
  }

 #benefits .benefits-media {
    height: 185px !important;
    padding: 2px !important;
  }

  #benefits .benefits-media img,
  #benefits .benefits-card img {
    width: 100% !important;
    height: 100% !important;
  }
  #request input,
  #request select,
  #request textarea,
  #order input,
  #order select,
  #order textarea,
  #form input,
  #form select,
  #form textarea {
    font-size: 14px;
  }
#reviews .reviews__top {
    gap: 10px !important;
    margin-bottom: 14px !important;
  }

  #reviews .reviews__scorebox {
    width: 100% !important;
    padding: 12px 14px !important;
  }

  #reviews .reviews__actions {
    width: 100% !important;
  }

  #reviews .reviews__actions .btn,
  #reviews .reviews__bigbtn {
    width: 100% !important;
  }

  #reviews .reviews__grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  #reviews .review {
    width: 100% !important;
    min-width: 0 !important;
    padding: 12px !important;
    border-radius: 16px !important;
  }

  #reviews .review__head {
    gap: 8px !important;
  }

  #reviews .review__user {
    min-width: 0 !important;
  }

  #reviews .review__name {
    font-size: 13px !important;
    line-height: 1.2 !important;
  }

  #reviews .review__lvl,
  #reviews .review__date {
    font-size: 11px !important;
  }

  #reviews .review__text {
    font-size: 13px !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
  }
 
}
@media (max-width: 320px) {
  .header__top {
    display: grid !important;
    grid-template-columns: 72px 1fr auto auto !important;
    align-items: center !important;
    column-gap: 4px !important;
    padding: 6px 8px !important;
    min-height: 40px !important;
  }

  .brand {
    grid-column: 1 !important;
    min-width: 0 !important;
    margin: 0 !important;
    line-height: 0 !important;
  }

  .brand__logo {
    display: block !important;
    width: auto !important;
    height: 16px !important;
    max-width: 72px !important;
    object-fit: contain !important;
  }

  /* оставляем только телефон */
  .header__top > .hitem:nth-of-type(1),
  .header__top > .hitem:nth-of-type(2),
  .header__top > .hitem:nth-of-type(4),
  .hstack {
    display: none !important;
  }

  .header__top > .hitem:nth-of-type(3) {
    grid-column: 2 !important;
    display: flex !important;
    align-items: center !important;
    justify-self: center !important;
    min-width: 0 !important;
    max-width: 92px !important;
    margin: 0 !important;
    text-align: center !important;
  }

  .header__top > .hitem:nth-of-type(3) .hitem__label {
    display: none !important;
  }

  .header__top > .hitem:nth-of-type(3) .hitem__text {
    display: block !important;
    font-size: 8px !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    text-align: center !important;
    margin: 0 !important;
  }

  .hsocial {
    grid-column: 3 !important;
    display: flex !important;
    align-items: center !important;
    justify-self: end !important;
    gap: 4px !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .hsocial__btn {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    border-radius: 6px !important;
    padding: 0 !important;
  }

  .hsocial__btn img {
    width: 20px !important;
    height: 20px !important;
    object-fit: contain !important;
  }

  .burger {
    grid-column: 4 !important;
    justify-self: end !important;
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    border-radius: 6px !important;
    padding: 0 !important;
  }

  .burger span {
    left: 5px !important;
    width: 12px !important;
    height: 2px !important;
  }

  .burger span:nth-child(1) { top: 7px !important; }
  .burger span:nth-child(2) { top: 11px !important; }
  .burger span:nth-child(3) { top: 15px !important; }

  .burger[aria-expanded="true"] span:nth-child(1) {
    top: 11px !important;
  }

  .burger[aria-expanded="true"] span:nth-child(3) {
    top: 11px !important;
  }
   .hero {
    min-height: 250px !important;
    padding-top: 8px !important;
  }

  .hero__bg {
    background-size: cover !important;
    background-position: center top !important;
  }

  .hero__inner {
    padding: 18px 8px 16px !important;
  }

  .hero__content,
  .hero__content--center {
    max-width: 100% !important;
    margin: 0 auto !important;
    text-align: center !important;
  }

  .hero__title {
    font-size: 18px !important;
    line-height: 1.12 !important;
    margin: 0 0 8px !important;
    word-break: break-word !important;
  }

  .hero__subtitle {
    font-size: 11px !important;
    line-height: 1.25 !important;
    margin: 0 0 8px !important;
  }

  .hero__text {
    font-size: 10.5px !important;
    line-height: 1.3 !important;
    margin: 0 0 12px !important;
    max-width: 92% !important;
  }

  .hero__actions,
  .hero__actions--center {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
  }

  .hero__actions .btn,
  .hero__actions--center .btn {
    width: 100% !important;
    max-width: 220px !important;
    height: 38px !important;
    font-size: 12px !important;
    padding: 0 10px !important;
    border-radius: 10px !important;
  }
   .reviews__top {
    gap: 10px !important;
    margin-bottom: 14px !important;
  }

  .reviews__scorebox {
    width: 100% !important;
    padding: 12px 14px !important;
  }

  .reviews__actions {
    width: 100% !important;
  }

  .reviews__actions .btn,
  .reviews__bigbtn {
    width: 100% !important;
  }

  .reviews__grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .review {
    width: 100% !important;
    min-width: 0 !important;
    padding: 12px !important;
    border-radius: 16px !important;
  }

  .review__head {
    gap: 8px !important;
  }

  .review__user {
    min-width: 0 !important;
  }

  .review__name {
    font-size: 13px !important;
    line-height: 1.2 !important;
  }

  .review__lvl,
  .review__date {
    font-size: 11px !important;
  }

  .review__text {
    font-size: 13px !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
  }

}
/* =========================================
   hover only for real mouse
   ========================================= */
@media (hover: hover) and (pointer: fine) {
  #services .card:hover {
    z-index: 5;
    transform: translateY(-10px) scale(1.04);
    box-shadow: var(--shadow-hover);
  }

  #services .card:hover .card-img img {
    transform: scale(1.06);
  }

  #benefits .benefits-card:hover {
    z-index: 5;
    transform: translateY(-10px) scale(1.04);
    box-shadow:
      0 32px 80px rgba(11,15,19,.18),
      0 12px 32px rgba(11,15,19,.12);
  }

  #benefits .benefits-card:hover .benefits-media img {
    transform: scale(1.06);
  }
}

/* =========================================
   touch devices
   ========================================= */
@media (hover: none), (pointer: coarse) {
  #services .card:hover,
  #benefits .benefits-card:hover {
    transform: none;
    box-shadow: var(--shadow-soft);
  }

  #services .card:hover .card-img img,
  #benefits .benefits-card:hover .benefits-media img {
    transform: none;
  }

  .reviews__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  #map .map-full iframe {
    height: 360px;
  }

  

  .footer__right {
    justify-content: flex-start;
  }
}
