/* ============================================================
   ЭТАЛОННАЯ ГЛАВНАЯ probiv.by — «Аварийный экспресс» (К1)
   + прайс-карта и гигиена из К3, форма и ошибки из К2.
   Тёмная база, один горячий акцент, сетка 8px, mobile-first.
   ============================================================ */

/* ---------- Дизайн-токены ---------- */
:root{
  /* Палитра: база */
  --bg-0:      #0B0D11;
  --bg-1:      #11141A;
  --surface:   #171B22;
  --surface-2: #1E232D;
  --field:     #0E1116;
  --line:      #262C37;
  --line-2:    #39414F;
  --line-3:    #495365;

  /* Палитра: текст */
  --ink:   #F4F6F9;
  --ink-2: #A7B0BE;
  --ink-3: #7C8698; /* мелкий текст: >=4.5:1 на --bg-0 (WCAG AA) */

  /* Горячий акцент — единственный цветной голос */
  --hot:      #FF4A17;
  --hot-2:    #FF7A33;
  --hot-deep: #D93B0F;
  --hot-soft: rgba(255,74,23,.12);
  --hot-line: rgba(255,74,23,.35);
  /* Градиент CTA затемнён: белый bold 16-17px даёт >=4.5:1 (WCAG AA) по всей длине */
  --grad-hot: linear-gradient(160deg, #D2400E 0%, #C23809 55%, #AC2F07 100%);

  /* Служебные */
  --ok: #35D07F;
  --err: #E5484D;
  --err-soft: rgba(229,72,77,.15);
  --amber: #F5C55A;             /* янтарный чип ночного режима */
  --amber-soft: rgba(240,180,41,.12);
  --amber-line: rgba(240,180,41,.4);

  /* Типографика */
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;

  /* Сетка 8px */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:40px; --s6:48px; --s7:56px; --s8:64px;
  --container: 1180px;

  /* Радиусы: важнее — больше */
  --r-s: 10px;   /* мелкие элементы: инпуты, чипы */
  --r-m: 14px;   /* кнопки, вторичные карточки */
  --r-l: 18px;   /* основные карточки */
  --r-xl: 22px;  /* прайс-карта, модалка */

  /* Тени: три уровня */
  --shadow-1: 0 2px 8px rgba(0,0,0,.25);
  --shadow-2: 0 12px 32px rgba(0,0,0,.35);
  --shadow-3: 0 24px 64px rgba(0,0,0,.5);
  --shadow-hot: 0 8px 24px rgba(255,74,23,.35);

  --sticky-h: 88px; /* topline ~23px + кнопки 64 + бордер: футер не перекрывается */
}

/* ---------- Сброс и база ---------- */
*,*::before,*::after{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font:400 16px/1.55 var(--font);
  background:var(--bg-0);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  /* место под sticky-панель + вырез iPhone; футер компенсируется этим же отступом */
  padding-bottom:calc(var(--sticky-h) + env(safe-area-inset-bottom, 0px));
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--hot-2); text-decoration:none; }
a:hover{ text-decoration:underline; }
ul,ol{ list-style:none; }
button{ font:inherit; }
h1,h2,h3,h4{ line-height:1.15; letter-spacing:-.015em; }
section{ scroll-margin-top:72px; }
:focus-visible{ outline:2px solid var(--hot-2); outline-offset:3px; border-radius:4px; }
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation:none!important; transition:none!important; }
  html{ scroll-behavior:auto; }
}

.container{ max-width:var(--container); margin-inline:auto; padding-inline:var(--s2); }
.section{ padding-block:var(--s7); }
.section-alt{ background:var(--bg-1); }
@media (min-width:768px){
  .container{ padding-inline:var(--s3); }
  .section{ padding-block:calc(var(--s8) + var(--s4)); }
}

.skip-link{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--hot-deep); color:#fff; padding:var(--s1) var(--s2); border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0; }

.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.nowrap{ white-space:nowrap; } /* телефон и т.п. переносятся целиком, а не по дефису */

/* SVG-спрайт: вне потока, не display:none — иначе <use> ломается в старых Safari */
.sprite{ position:absolute; width:0; height:0; }

/* Заголовки секций */
.sec-kicker{
  display:inline-flex; align-items:center; gap:var(--s1);
  font-size:12.5px; font-weight:700; letter-spacing:.09em; text-transform:uppercase;
  color:var(--hot-2); margin-bottom:var(--s2);
}
.sec-kicker::before{ content:""; width:24px; height:2px; background:var(--hot); border-radius:1px; }
.sec-title{ font-size:clamp(24px,4.5vw,36px); font-weight:800; margin-bottom:var(--s2); }
.sec-lead{ color:var(--ink-2); max-width:640px; margin-bottom:var(--s4); }

/* Иконки */
.ic{ width:24px; height:24px; flex:none; }
.ic-s{ width:20px; height:20px; flex:none; }

/* ---------- Кнопки ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:var(--s1);
  min-height:48px; padding:0 var(--s3);
  border-radius:var(--r-m); border:1px solid transparent;
  font-weight:700; font-size:16px; line-height:1.2;
  cursor:pointer; text-decoration:none; user-select:none;
  transition:transform .15s ease, box-shadow .2s ease, filter .2s ease,
             background-color .2s ease, border-color .2s ease, color .2s ease;
}
.btn:hover{ text-decoration:none; }
.btn:focus-visible{ outline:2px solid var(--hot-2); outline-offset:3px; }

.btn-hot{
  background:var(--grad-hot); color:#fff;
  box-shadow:var(--shadow-hot), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-hot:hover{ filter:brightness(1.05); transform:translateY(-1px);
  box-shadow:0 12px 32px rgba(255,74,23,.5), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-hot:active{ filter:brightness(.96); transform:translateY(1px);
  box-shadow:0 4px 12px rgba(255,74,23,.3); }
.btn-hot:disabled{
  background:var(--surface-2); color:var(--ink-3); box-shadow:none; cursor:not-allowed;
  filter:none; transform:none;
}

.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--hot); color:var(--hot-2); background:var(--hot-soft); }
.btn-ghost:active{ background:rgba(255,74,23,.2); transform:translateY(1px); }

.btn-quiet{ background:var(--surface-2); color:var(--ink); border-color:var(--line); }
.btn-quiet:hover{ border-color:var(--line-2); background:var(--surface); }
.btn-quiet:active{ transform:translateY(1px); }

.btn-lg{ min-height:56px; padding:0 var(--s4); font-size:17px; border-radius:var(--r-m); }
.btn-block{ width:100%; }
.btn-note{ font-size:13px; color:var(--ink-3); margin-top:6px; }
.btn-note b{ color:var(--ink-2); font-weight:600; white-space:nowrap; }

/* ---------- Бейджи и чипы ---------- */
.badge{
  display:inline-flex; align-items:center; gap:6px;
  min-height:32px; padding:4px 12px;
  border:1px solid var(--line-2); border-radius:999px;
  background:rgba(23,27,34,.7);
  font-size:13.5px; font-weight:600; color:var(--ink);
}
.badge .ic-s{ width:16px; height:16px; color:var(--hot-2); }
.badge-hot{ border-color:rgba(255,74,23,.5); background:var(--hot-soft); color:var(--hot-2); }

/* Статичная точка доступности: без пульса, чтобы не имитировать live-статус линии */
.dot-live{
  width:8px; height:8px; border-radius:50%; background:var(--ok); flex:none;
}

.chip{
  display:inline-flex; align-items:center; min-height:32px; padding:4px 14px;
  border:1px solid var(--line-2); border-radius:999px;
  font-size:13.5px; color:var(--ink-2); background:var(--surface);
}

/* ---------- Шапка ---------- */
.hdr{
  position:sticky; top:0; z-index:60;
  background:rgba(11,13,17,.85); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.hdr-in{ display:flex; align-items:center; gap:var(--s2); min-height:56px; }
.logo{
  display:inline-flex; align-items:center; gap:var(--s1);
  font-weight:800; font-size:19px; letter-spacing:.02em; color:var(--ink);
}
.logo:hover{ text-decoration:none; }
.logo .ic{ color:var(--hot); }
.logo b{ color:var(--hot); font-weight:800; }
.hdr-nav{ display:none; }
.hdr-phone{
  display:inline-flex; flex-direction:column; justify-content:center; min-height:44px; /* tap-зона >= 44px */
  margin-left:auto; text-align:right; color:var(--ink); line-height:1.2; padding:var(--s1) 0;
}
.hdr-phone:hover{ text-decoration:none; color:var(--hot-2); }
.hdr-phone strong{ display:block; font-size:16px; font-weight:800; white-space:nowrap; font-variant-numeric:tabular-nums; }
.hdr-phone span{ display:none; font-size:12px; color:var(--ink-3); }
.hdr-cta{ display:none; }

/* Мобильное меню: бургер >=44x44 + выпадающая панель под шапкой */
.hdr-burger{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; flex:none;
  background:transparent; border:1px solid var(--line-2); border-radius:var(--r-s);
  color:var(--ink); cursor:pointer;
}
.hdr-burger[aria-expanded="true"]{ border-color:var(--hot); color:var(--hot-2); background:var(--hot-soft); }
.hdr-menu{
  position:absolute; left:0; right:0; top:100%;
  display:flex; flex-direction:column;
  padding:var(--s1) var(--s2) var(--s2);
  background:var(--bg-1); border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-2);
}
.hdr-menu[hidden]{ display:none; }
.hdr-menu a{
  display:flex; align-items:center; min-height:44px; padding:10px var(--s1);
  color:var(--ink); font-weight:600; border-bottom:1px solid var(--line);
}
.hdr-menu a:last-child{ border-bottom:none; }
.hdr-menu a:hover{ color:var(--hot-2); text-decoration:none; }

@media (min-width:1024px){
  .hdr-in{ min-height:72px; }
  .hdr-nav{ display:flex; gap:var(--s3); margin-left:var(--s4); }
  .hdr-nav a{ color:var(--ink-2); font-size:14.5px; font-weight:600; }
  .hdr-nav a:hover{ color:var(--hot-2); text-decoration:none; }
  .hdr-phone strong{ font-size:20px; }
  .hdr-phone span{ display:block; }
  .hdr-cta{ display:inline-flex; }
  .hdr-burger{ display:none; }
  .hdr-menu{ display:none!important; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(720px 420px at 85% -10%, rgba(255,74,23,.16), transparent 65%),
    radial-gradient(520px 320px at -10% 110%, rgba(255,74,23,.07), transparent 60%),
    var(--bg-0);
  padding-block:var(--s2) var(--s5); /* мобайл: -8px до сгиба (К1) */
}
.hero-grid{ display:grid; gap:var(--s4); }
.hero-kicker{
  display:inline-flex; align-items:center; gap:var(--s1);
  font-size:12.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:var(--s2);
}
/* Кикер на мобиле — короткая версия в одну строку (К1: экономим строку до сгиба) */
.hero-kicker-full{ display:none; }
.hero-kicker-short{ white-space:nowrap; }
@media (min-width:640px){
  .hero-kicker-full{ display:inline; }
  .hero-kicker-short{ display:none; }
}
.hero h1{
  font-size:clamp(27px,6.6vw,48px); font-weight:800; letter-spacing:-.02em;
  margin-bottom:var(--s2);
}
.hero h1 em{ font-style:normal; color:var(--hot); }
.hero-sub{ color:var(--ink-2); font-size:15.5px; margin-bottom:var(--s2); max-width:560px; }
/* Лид: на узком мобиле — короткая версия целым предложением (по паттерну hero-kicker-full/short) */
.hero-sub-full{ display:none; }
@media (min-width:640px){
  .hero-sub-full{ display:inline; }
  .hero-sub-short{ display:none; }
}

.hero-badges{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:var(--s2); }
.hero-badges .badge{ font-size:12.5px; padding:4px 10px; min-height:30px; }
@media (min-width:640px){
  .hero-badges{ gap:var(--s1); }
  .hero-badges .badge{ font-size:13.5px; padding:4px 12px; min-height:32px; }
}

/* Гигантский телефон — без свечения */
.hero-phone{
  display:block; width:fit-content; white-space:nowrap;
  font-size:clamp(31px,8.4vw,52px); font-weight:800; letter-spacing:-.01em;
  font-variant-numeric:tabular-nums;
  color:var(--ink); line-height:1.1;
}
.hero-phone:hover{ color:var(--hot-2); text-decoration:none; }
.hero-phone:active{ color:var(--hot); }
.hero-phone-note{
  display:flex; align-items:center; gap:var(--s1);
  font-size:13.5px; color:var(--ink-3); margin:6px 0 12px; /* мобайл компактнее (К1); десктоп — ниже в @media 1024 */
}
.hero-cta{ display:flex; flex-wrap:wrap; align-items:flex-start; gap:var(--s2); margin-bottom:var(--s3); }
.hero-cta-col{ display:flex; flex-direction:column; }
/* На узком мобиле второй CTA скрыт: первый экран = H1 + цены + телефон + кнопка */
.hero-cta .btn-ghost,
.hero-cta .hero-cta-ghost{ display:none; }
/* Страховка: вторичная ghost-кнопка не может разрастись шире главной оранжевой */
.hero-cta .btn-ghost{ max-width:300px; }
@media (min-width:640px){
  .hero-cta .btn-ghost{ display:inline-flex; }
  .hero-cta .hero-cta-ghost{ display:flex; }
}
.hero-trust{ font-size:13.5px; color:var(--ink-3); }
.hero-trust b{ color:var(--ink-2); font-weight:600; }

/* Прайс-карта (К3): десктоп — правая колонка hero */
.pricecard{
  display:none; position:relative;
  background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-xl);
  box-shadow:var(--shadow-2); padding:var(--s3);
}
.pricecard-float{
  position:absolute; top:-14px; right:20px;
  display:inline-flex; align-items:center; gap:6px;
  background:var(--grad-hot); color:#fff; font-size:12.5px; font-weight:700;
  padding:6px 12px; border-radius:999px; box-shadow:var(--shadow-1);
}
.pricecard-float .ic-s{ width:14px; height:14px; }
.pricecard-head{ display:flex; align-items:center; justify-content:space-between; gap:var(--s2); margin-bottom:var(--s1); }
.pricecard-title{ font-size:18px; font-weight:800; letter-spacing:-.015em; }
.pricecard-rows{ display:flex; flex-direction:column; }
.pricecard-row{
  display:flex; align-items:baseline; justify-content:space-between; gap:var(--s2);
  padding:14px 0; border-bottom:1px dashed var(--line-2);
}
.pricecard-row:last-of-type{ border-bottom:0; }
.pricecard-row .seg{ font-weight:600; font-size:15.5px; }
.pricecard-row .seg small{ display:block; font-weight:500; font-size:12.5px; color:var(--ink-3); }
.pricecard-row .val{
  font-weight:800; font-size:20px; letter-spacing:-.02em; white-space:nowrap;
  font-variant-numeric:tabular-nums;
}
.pricecard-row .val i{ font-style:normal; font-size:13px; font-weight:600; color:var(--ink-3); }
.pricecard-fix{
  display:flex; gap:10px; align-items:flex-start;
  background:var(--hot-soft); border:1px solid var(--hot-line); border-radius:var(--r-s);
  padding:12px 14px; margin-top:var(--s2);
  font-size:14px; font-weight:600; color:var(--ink);
}
.pricecard-fix .ic-s{ margin-top:1px; color:var(--hot-2); }
.pricecard-night{
  display:flex; gap:10px; align-items:flex-start;
  background:var(--amber-soft); border:1px solid var(--amber-line); border-radius:var(--r-s);
  padding:10px 14px; margin-top:var(--s1);
  font-size:13px; color:var(--amber);
}
.pricecard-night .ic-s{ width:16px; height:16px; margin-top:2px; }
.pricecard .btn{ margin-top:var(--s2); }
@media (min-width:1024px){
  .hero{ padding-block:var(--s8); }
  .hero-grid{ grid-template-columns:1.1fr .9fr; align-items:center; gap:var(--s8); }
  .hero-phone-note{ margin:var(--s1) 0 var(--s3); } /* десктоп — принятые отступы */
  .pricecard{ display:block; }
}

/* Прайс-карта: компакт для мобилы — сразу под бейджами, не под сгибом */
.pricecard-mini{
  border:1px solid var(--line-2); border-radius:var(--r-m);
  background:rgba(23,27,34,.7); padding:4px var(--s2);
  margin-bottom:var(--s2); max-width:430px;
}
.pricecard-mini-row{
  display:flex; align-items:baseline; justify-content:space-between; gap:var(--s2);
  padding:6px 0; border-bottom:1px dashed var(--line-2);
  font-size:14px;
}
.pricecard-mini-row:last-of-type{ border-bottom:0; }
.pricecard-mini-row .val{ font-weight:800; white-space:nowrap; font-variant-numeric:tabular-nums; }
.pricecard-mini-fix{
  display:flex; align-items:center; gap:6px;
  padding:6px 0; font-size:12.5px; color:var(--ink-3);
}
.pricecard-mini-fix .ic-s{ width:14px; height:14px; color:var(--hot-2); }
@media (min-width:1024px){ .pricecard-mini{ display:none; } }

/* ---------- «Пока едет мастер» ---------- */
.sos{ background:var(--bg-1); border-block:1px solid var(--line); }
.sos-in{ display:grid; gap:var(--s2); padding-block:var(--s3); }
.sos-title{
  display:flex; align-items:center; gap:var(--s1);
  font-size:14px; font-weight:800; text-transform:uppercase; letter-spacing:.06em;
  color:var(--hot-2);
}
.sos-list{ display:grid; gap:var(--s1); }
.sos-list li{ display:flex; gap:var(--s1); align-items:flex-start; color:var(--ink-2); font-size:14.5px; }
.sos-list .ic-s{ color:var(--hot); margin-top:2px; }
@media (min-width:768px){
  .sos-in{ grid-template-columns:auto 1fr; align-items:center; gap:var(--s4); }
  .sos-list{ grid-template-columns:repeat(3,1fr); gap:var(--s3); }
}

/* ---------- Услуги ---------- */
.svc-grid{ display:grid; gap:var(--s2); }
@media (min-width:640px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){ .svc-grid{ grid-template-columns:repeat(3,1fr); gap:var(--s3); } }
.svc{
  position:relative; display:flex; flex-direction:column; gap:var(--s2);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-l);
  padding:var(--s3);
  transition:border-color .2s ease, transform .2s ease, background .2s ease;
}
.svc:hover{ border-color:rgba(255,74,23,.55); transform:translateY(-2px); background:var(--surface-2); }
.svc-ico{
  width:48px; height:48px; border-radius:var(--r-s); display:grid; place-items:center;
  background:var(--hot-soft); color:var(--hot-2); border:1px solid rgba(255,74,23,.25);
}
.svc h3{ font-size:17.5px; font-weight:800; }
/* Заголовок карточки — ссылка на посадочную: цвет наследует, ховер — акцент */
.svc h3 a{ color:inherit; }
.svc h3 a:hover{ color:var(--hot-2); text-decoration:none; }
.price-tag a{ color:inherit; }
.price-tag a:hover{ color:var(--hot-2); text-decoration:none; }
.svc-price{ font-size:14px; font-weight:700; color:var(--hot-2); font-variant-numeric:tabular-nums; }
.svc p{ color:var(--ink-2); font-size:14.5px; flex:1; }
.svc-meta{ display:flex; align-items:center; justify-content:space-between; gap:var(--s1); }
/* tel-ссылка в карточке: tap-зона >= 44px за счёт паддингов */
.svc-call{
  display:inline-flex; align-items:center; gap:6px;
  min-height:44px; padding:10px 14px; margin:-10px -14px -10px 0;
  font-size:14.5px; font-weight:700; color:var(--hot-2); border-radius:var(--r-s);
}
.svc-call:hover{ background:var(--hot-soft); text-decoration:none; }
.svc-call .ic-s{ width:16px; height:16px; }
.svc-more{
  display:inline-flex; align-items:center; gap:4px;
  min-height:44px; padding:10px 0;
  font-size:14px; font-weight:600; color:var(--ink-3);
}
.svc-more:hover{ color:var(--hot-2); text-decoration:none; }

.scope-note{
  margin-top:var(--s3); display:grid; gap:var(--s1);
  border:1px dashed var(--line-2); border-radius:var(--r-m);
  padding:var(--s2) var(--s3); font-size:14px; color:var(--ink-2);
}
.scope-note div{ display:flex; gap:var(--s1); align-items:flex-start; }
.scope-note .ic-s{ margin-top:2px; }
.scope-note .yes{ color:var(--ok); }
.scope-note .no{ color:var(--ink-3); }
@media (min-width:768px){ .scope-note{ grid-template-columns:1fr 1fr; gap:var(--s2) var(--s4); } }

/* ---------- Цены ---------- */
.price-grid{ display:grid; gap:var(--s2); }
@media (min-width:900px){ .price-grid{ grid-template-columns:repeat(3,1fr); gap:var(--s3); } }
.price{
  display:flex; flex-direction:column; gap:var(--s2);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-l);
  padding:var(--s3);
  transition:border-color .2s ease, transform .2s ease;
}
.price:hover{ border-color:var(--line-2); transform:translateY(-2px); }
.price-feat{ border-color:rgba(255,74,23,.55); box-shadow:var(--shadow-2); }
.price-tag{
  align-self:flex-start; font-size:12px; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  color:var(--hot-2); background:var(--hot-soft); border:1px solid rgba(255,74,23,.3);
  border-radius:999px; padding:4px 12px;
}
.price h3{ font-size:19px; font-weight:800; }
.price-num{ font-size:clamp(28px,5vw,36px); font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; }
.price-num small{ font-size:15px; font-weight:600; color:var(--ink-3); }
.price ul{ display:grid; gap:var(--s1); flex:1; }
.price li{ display:flex; gap:var(--s1); font-size:14.5px; color:var(--ink-2); align-items:flex-start; }
.price li .ic-s{ width:16px; height:16px; color:var(--hot-2); margin-top:3px; }
.price li b{ color:var(--ink); font-weight:600; font-variant-numeric:tabular-nums; }
.fix-line{
  margin-top:var(--s3);
  display:flex; align-items:flex-start; gap:var(--s2);
  background:linear-gradient(160deg, rgba(255,122,51,.14), rgba(255,74,23,.06));
  border:1px solid var(--hot-line); border-radius:var(--r-m);
  padding:var(--s2) var(--s3);
  font-size:17px; font-weight:700; line-height:1.4;
}
.fix-line .ic{ color:var(--hot-2); margin-top:2px; }

/* ---------- Промежуточные CTA ---------- */
.midcta{
  margin-top:var(--s4);
  display:grid; gap:var(--s2); justify-items:start;
  background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-l);
  padding:var(--s3); box-shadow:var(--shadow-1);
}
.midcta h3{ font-size:20px; font-weight:800; }
.midcta p{ color:var(--ink-2); font-size:14.5px; max-width:640px; }
.midcta .btn-note{ margin-top:0; }
/* Раскладка колонки действия — на всех ширинах, а не только с 900px:
   стабильный воздух между кнопкой, подписью и второй кнопкой */
.midcta-action{ display:flex; flex-direction:column; align-items:flex-start; gap:10px; }
@media (min-width:900px){
  .midcta{ grid-template-columns:1fr auto; align-items:center; padding:var(--s4); }
  .midcta-text{ max-width:640px; }
}

/* ---------- Как проходит выезд ---------- */
.steps{ display:grid; gap:var(--s2); counter-reset:step; }
@media (min-width:1024px){ .steps{ grid-template-columns:repeat(4,1fr); gap:var(--s2); } }
.step{
  position:relative; counter-increment:step;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-l);
  padding:var(--s3); padding-top:var(--s6);
}
.step::before{
  content:"0" counter(step);
  position:absolute; top:var(--s2); left:var(--s3);
  font-size:26px; font-weight:800; color:var(--hot); opacity:.9;
  font-variant-numeric:tabular-nums;
}
.step h3{ font-size:16.5px; font-weight:800; margin-bottom:var(--s1); }
.step p{ font-size:14px; color:var(--ink-2); }

/* ---------- Почему звонят нам ---------- */
.why-list{ display:grid; gap:var(--s2); }
@media (min-width:900px){ .why-list{ grid-template-columns:1fr 1fr; gap:var(--s3); } }
.why{
  display:flex; gap:var(--s2); align-items:flex-start;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-l);
  padding:var(--s3);
}
.why .ic{ color:var(--hot-2); margin-top:2px; }
.why b{ font-weight:700; }
.why p{ color:var(--ink-2); font-size:14.5px; }

/* Оборудование: карусель на мобиле (scroll-snap, кадр 78%) */
.equip{ margin-top:var(--s5); }
.equip h3{ font-size:20px; font-weight:800; margin-bottom:var(--s1); }
.equip > p{ color:var(--ink-2); font-size:14.5px; margin-bottom:var(--s3); }
.equip-track{
  display:grid; grid-auto-flow:column; grid-auto-columns:78%;
  gap:var(--s2); overflow-x:auto; scroll-snap-type:x mandatory;
  padding-bottom:var(--s1); margin-inline:calc(-1 * var(--s2)); padding-inline:var(--s2);
  scrollbar-width:none;
}
.equip-track::-webkit-scrollbar{ display:none; }
.equip-track figure{
  scroll-snap-align:center;
  border:1px solid var(--line); border-radius:var(--r-m); overflow:hidden; background:var(--surface);
}
.equip-track img{
  width:100%; aspect-ratio:4/3; object-fit:cover;
  background:var(--surface-2); color:var(--ink-3); font-size:12.5px;
  border-bottom:1px dashed var(--line-2);
}
.equip-track figcaption{
  padding:var(--s1) var(--s2) var(--s2);
  font-size:12.5px; color:var(--ink-2);
  font-family:var(--mono); font-variant-numeric:tabular-nums;
}
@media (min-width:768px){
  .equip-track{
    grid-auto-flow:row; grid-template-columns:1fr 1fr; grid-auto-columns:auto;
    overflow:visible; margin-inline:0; padding-inline:0;
  }
}
@media (min-width:1024px){ .equip-track{ grid-template-columns:repeat(4,1fr); } }

/* ---------- Наши работы ---------- */
.cases{ display:grid; gap:var(--s2); }
@media (min-width:640px){ .cases{ grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){ .cases{ grid-template-columns:repeat(4,1fr); gap:var(--s3); } }
.case{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-l);
  overflow:hidden; transition:border-color .2s ease, transform .2s ease;
  display:flex; flex-direction:column;
}
.case:hover{ border-color:var(--line-2); transform:translateY(-2px); }
.case-img{ aspect-ratio:4/3; overflow:hidden; border-bottom:1px dashed var(--line-2); background:var(--surface-2); }
.case-img img{ width:100%; height:100%; object-fit:cover; color:var(--ink-3); font-size:13px; }
.case figcaption{ padding:var(--s2) var(--s3) var(--s3); display:grid; gap:var(--s1); align-content:start; flex:1; }
.case figcaption b{ font-size:15px; font-weight:700; }
.case figcaption span{ font-size:13px; color:var(--ink-2); }
.case .badge{
  justify-self:start; align-self:end; min-height:26px; font-size:12px; padding:2px 10px;
  font-family:var(--mono); font-variant-numeric:tabular-nums;
}
.works-note{ margin-top:var(--s3); font-size:14.5px; color:var(--ink-2); }
.works-note a{ font-weight:600; }

/* ---------- FAQ ---------- */
.faq{ max-width:800px; }
.faq details{
  border:1px solid var(--line); border-radius:var(--r-m);
  background:var(--surface); margin-bottom:var(--s1);
  transition:border-color .2s ease;
}
.faq details[open]{ border-color:var(--line-2); background:var(--surface-2); }
.faq summary{
  display:flex; align-items:center; justify-content:space-between; gap:var(--s2);
  padding:var(--s2) var(--s3); cursor:pointer; list-style:none;
  font-weight:700; font-size:15.5px; min-height:56px;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ic-s{ color:var(--hot-2); transition:transform .2s ease; }
.faq details[open] summary .ic-s{ transform:rotate(180deg); }
.faq summary:hover{ color:var(--hot-2); }
.faq .faq-a{ padding:0 var(--s3) var(--s3); color:var(--ink-2); font-size:14.5px; }

/* ---------- Куда выезжаем ---------- */
.area-grid{ display:grid; gap:var(--s3); }
@media (min-width:900px){ .area-grid{ grid-template-columns:1.1fr .9fr; align-items:start; } }
.area-block h3{ font-size:15px; font-weight:700; margin:var(--s3) 0 var(--s1); color:var(--ink); }
.area-block p{ color:var(--ink-2); font-size:14.5px; }
.area-chips{ display:flex; flex-wrap:wrap; gap:var(--s1); margin-top:var(--s1); }
.area-chips + .prose{ margin-top:var(--s3); }
.area-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-l);
  padding:var(--s3); display:grid; gap:var(--s2);
}
.area-card li{ display:flex; gap:var(--s1); align-items:flex-start; color:var(--ink-2); font-size:14.5px; }
.area-card .ic-s{ color:var(--hot-2); margin-top:2px; }
.area-card .area-close{ font-size:14.5px; color:var(--ink-2); }
.area-link{ display:inline-flex; align-items:center; gap:6px; font-weight:700; }

/* ---------- Контакты + инлайн-форма ---------- */
.contact-grid{ display:grid; gap:var(--s3); }
@media (min-width:1024px){ .contact-grid{ grid-template-columns:1fr 1fr; gap:var(--s6); align-items:start; } }
.contact-list{ display:grid; gap:var(--s2); margin-top:var(--s3); }
.contact-item{
  display:flex; align-items:center; gap:var(--s2);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-m);
  padding:var(--s2) var(--s3); color:var(--ink);
  transition:border-color .2s ease;
}
a.contact-item:hover{ text-decoration:none; border-color:rgba(255,74,23,.5); }
.contact-item .ic{ color:var(--hot-2); }
.contact-item b{ display:block; font-size:16.5px; font-weight:800; font-variant-numeric:tabular-nums; }
.contact-item span{ display:block; font-size:12.5px; color:var(--ink-3); }

/* ---------- Формы ---------- */
.form-card{
  background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-l);
  padding:var(--s3); box-shadow:var(--shadow-2);
}
.form-card h3{ font-size:20px; font-weight:800; margin-bottom:4px; }
.form-card .form-sub{ font-size:14px; color:var(--ink-2); margin-bottom:var(--s3); }
/* Honeypot: невидим для людей, доступен ботам (не display:none) */
.hp-field{ position:absolute; left:-9999px; opacity:0; height:0; width:0; }
.field{ display:grid; gap:6px; margin-bottom:var(--s2); position:relative; }
.field > .field-label{ font-size:13px; font-weight:600; color:var(--ink-2); }
.input{
  width:100%; min-height:48px; padding:12px 14px;
  background:var(--field); color:var(--ink);
  border:1px solid var(--line-2); border-radius:var(--r-s);
  font-family:var(--font); font-size:16px; line-height:1.4; /* явные 16px — iOS не зумит */
  transition:border-color .15s ease, box-shadow .15s ease;
}
textarea.input{ min-height:88px; resize:vertical; }
.input::placeholder{ color:var(--ink-3); }
.input:hover{ border-color:var(--line-3); }
.input:focus{ outline:none; border-color:var(--hot); box-shadow:0 0 0 3px var(--hot-soft); }
.input:disabled{ opacity:.5; cursor:not-allowed; }

/* Пофилдовые ошибки (К2) */
.field__err{ display:none; font-style:normal; font-size:12.5px; color:var(--err); }
.field.is-error .input{ border-color:var(--err); box-shadow:0 0 0 3px var(--err-soft); }
.field.is-error .field__err{ display:block; }

.field--consent{ display:flex; gap:10px; align-items:flex-start; flex-wrap:wrap; cursor:pointer; }
.field--consent input{ width:18px; height:18px; margin-top:2px; accent-color:var(--hot); flex:none; cursor:pointer; }
.field--consent .consent-text{ flex:1; min-width:200px; font-size:12.5px; color:var(--ink-3); }
.field--consent .consent-text a{ color:var(--ink-2); text-decoration:underline; }
.field--consent .consent-text a:hover{ color:var(--hot-2); }
.field--consent.is-error .consent-text{ color:var(--err); }
.field--consent .field__err{ flex-basis:100%; }

.form-foot{ font-size:12.5px; color:var(--ink-3); margin-top:var(--s2); }
.form-err{
  display:none; margin-top:var(--s2); padding:var(--s2);
  border:1px solid var(--err); border-radius:var(--r-s); background:var(--err-soft);
  font-size:14px; color:var(--ink);
}
form.has-err .form-err{ display:block; }
.form-ok{ display:none; text-align:center; padding:var(--s4) var(--s2); }
.form-ok .ic{ width:48px; height:48px; color:var(--ok); margin:0 auto var(--s2); }
.form-ok b{ display:block; font-size:19px; margin-bottom:var(--s1); }
.form-ok p{ color:var(--ink-2); font-size:14.5px; }
.form-ok a{ font-weight:700; white-space:nowrap; }
form.is-done .form-body{ display:none; }
form.is-done .form-ok{ display:block; }

/* ---------- Финальный CTA ---------- */
.final{
  background:
    radial-gradient(640px 360px at 50% -20%, rgba(255,74,23,.18), transparent 65%),
    var(--bg-1);
  border-top:1px solid var(--line); text-align:center;
}
.final h2{ font-size:clamp(24px,4.5vw,36px); font-weight:800; margin-bottom:var(--s2); }
.final p.final-text{ color:var(--ink-2); max-width:620px; margin:0 auto var(--s4); }
.final-cta{ display:flex; flex-wrap:wrap; justify-content:center; gap:var(--s2); margin-bottom:var(--s3); }
/* Узкий мобайл: кнопки финального CTA на всю ширину — длинный текст не рвёт ряд */
@media (max-width:480px){ .final-cta .btn{ width:100%; max-width:420px; } }
.final-note{ font-size:13.5px; color:var(--ink-3); }
.final-note a{ font-weight:600; }

/* ---------- Футер ---------- */
.footer{
  background:var(--bg-1); border-top:1px solid var(--line);
  padding-block:var(--s5) var(--s4); font-size:14px; color:var(--ink-2);
}
.footer-grid{ display:grid; gap:var(--s3); }
@media (min-width:900px){ .footer-grid{ grid-template-columns:1.2fr 1fr 1fr; gap:var(--s6); } }
.footer h4{ font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-3); margin-bottom:var(--s2); }
.footer li{ margin-bottom:var(--s1); }
.footer a{ color:var(--ink-2); }
.footer a:hover{ color:var(--hot-2); }
.footer-about{ margin-top:var(--s2); max-width:320px; }
.footer-legal{
  margin-top:var(--s4); padding-top:var(--s3); border-top:1px solid var(--line);
  font-size:12.5px; color:var(--ink-3); display:grid; gap:var(--s1);
}

/* ---------- Sticky-панель: до 1024px (закрывает планшетную дыру 768–1023) ---------- */
.stickybar{
  position:fixed; left:0; right:0; bottom:0; z-index:70;
}
.sticky-topline{
  display:flex; align-items:center; justify-content:center; gap:var(--s1);
  background:rgba(11,13,17,.92); backdrop-filter:blur(8px);
  border-top:1px solid var(--line);
  font-size:12px; line-height:1.2; color:var(--ink-2); padding:4px var(--s5) 4px var(--s2);
  position:relative;
}
.sticky-topline[hidden]{ display:none; } /* авторский display:flex перебивал UA [hidden] */
/* Когда тонкая строка скрыта — паддинг body компенсирует только кнопки 64px + бордер */
body.sticky-topline-hidden{ --sticky-h:65px; }
.sticky-topline .dot-live{ width:6px; height:6px; }
.sticky-topline-close{
  position:absolute; right:2px; top:50%; bottom:auto; transform:translateY(-50%);
  width:44px; min-height:44px; display:grid; place-items:center; /* tap-зона >= 44px */
  background:none; border:0; color:var(--ink-3); cursor:pointer; font-size:16px;
  z-index:1; /* hit-area шире строки — не отдаём клики кнопкам панели */
}
.stickybar-btns{
  display:grid; grid-template-columns:1.5fr 1fr; gap:1px;
  background:var(--line); border-top:1px solid var(--line-2);
  padding-bottom:env(safe-area-inset-bottom, 0px);
}
.sb{
  display:flex; align-items:center; justify-content:center; gap:var(--s1);
  min-height:64px; font-size:15px; font-weight:700; text-decoration:none;
  background:var(--bg-1); color:var(--ink); border:0; cursor:pointer;
  transition:background .15s ease;
}
.sb:hover{ text-decoration:none; background:var(--surface-2); }
.sb:active{ background:var(--surface); }
.sb .ic{ width:22px; height:22px; }
.sb-call{ background:var(--grad-hot); color:#fff; }
.sb-call:hover{ background:var(--grad-hot); filter:brightness(1.05); }
.sb-call:active{ filter:brightness(.95); }
@media (min-width:1024px){
  .stickybar{ display:none; }
  body{ padding-bottom:0; }
}

/* ---------- Модалка: нативный dialog, bottom-sheet на мобиле (К2) ---------- */
.modal{
  border:0; padding:0; background:transparent;
  width:100%; max-width:100%;
  margin:auto 0 0;                 /* bottom-sheet: прижата к низу */
  max-height:calc(100dvh - 24px);
}
.modal::backdrop{ background:rgba(5,7,10,.72); backdrop-filter:blur(4px); }
.modal-card{
  background:var(--surface); border:1px solid var(--line-2);
  border-radius:var(--r-xl) var(--r-xl) 0 0;          /* верхние углы скруглены */
  padding:var(--s4) var(--s3) calc(var(--s3) + env(safe-area-inset-bottom, 0px));
  box-shadow:var(--shadow-3);
  position:relative; overflow:auto; max-height:calc(100dvh - 24px);
}
@media (min-width:600px){
  .modal{ margin:auto; width:min(460px, calc(100% - 32px)); }
  .modal-card{ border-radius:var(--r-xl); padding-bottom:var(--s3); }
}
.modal-close{
  position:absolute; top:var(--s2); right:var(--s2);
  width:44px; height:44px; display:grid; place-items:center;  /* крестик >= 44px */
  background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-s);
  color:var(--ink-2); cursor:pointer; transition:color .15s ease, border-color .15s ease;
}
.modal-close:hover{ color:var(--ink); border-color:var(--line-2); }
.modal-card h3{ font-size:21px; font-weight:800; margin-bottom:4px; padding-right:var(--s6); }
.modal-card .form-sub{ font-size:14px; color:var(--ink-2); margin-bottom:var(--s2); }
.modal-fear{
  display:flex; gap:10px; align-items:flex-start;
  background:var(--hot-soft); border:1px solid var(--hot-line); border-radius:var(--r-s);
  padding:10px 14px; margin-bottom:var(--s3);
  font-size:13px; color:var(--ink-2);
}
.modal-fear .ic-s{ width:16px; height:16px; color:var(--hot-2); margin-top:2px; }
.modal-alt{ margin-top:var(--s2); text-align:center; font-size:13.5px; color:var(--ink-3); }
.modal-alt a{ font-weight:700; }
body.modal-open{ overflow:hidden; }

/* ============================================================
   УТИЛИТЫ ВНУТРЕННИХ СТРАНИЦ
   Добавлено при разбиении сайта на PHP-инклюды.
   Правила эталонной главной выше НЕ менялись — только вынесены
   из <style> в этот файл.
   ============================================================ */

/* ---------- Хлебные крошки (inc/breadcrumbs.php) ---------- */
.breadcrumbs{ padding-block:var(--s2) 0; font-size:13px; }
.breadcrumbs ol{ display:flex; flex-wrap:wrap; align-items:center; row-gap:4px; }
.breadcrumbs li{ display:inline-flex; align-items:center; color:var(--ink-3); }
.breadcrumbs li + li::before{ content:"/"; margin-inline:8px; color:var(--line-3); }
.breadcrumbs a{ color:var(--ink-3); }
.breadcrumbs a:hover{ color:var(--hot-2); text-decoration:none; }
.breadcrumbs [aria-current="page"]{ color:var(--ink-2); }

/* ---------- Компактный hero внутренней страницы ----------
   H1 + сабтайтл + бейджи. Без гигантского телефона и прайс-карты.
   Разметка:
   <section class="page-hero">
     <div class="container">
       <p class="hero-kicker">…</p>
       <h1>…</h1>
       <p class="page-hero-sub">…</p>
       <ul class="hero-badges">…</ul>
     </div>
   </section> */
.page-hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(640px 360px at 85% -20%, rgba(255,74,23,.14), transparent 65%),
    var(--bg-0);
  padding-block:var(--s3) var(--s5);
  border-bottom:1px solid var(--line);
}
.page-hero h1{
  font-size:clamp(26px,5.4vw,40px); font-weight:800; letter-spacing:-.02em;
  margin-bottom:var(--s2); max-width:840px;
}
.page-hero h1 em{ font-style:normal; color:var(--hot); }
.page-hero-sub{ color:var(--ink-2); font-size:15.5px; max-width:640px; margin-bottom:var(--s2); }
.page-hero .hero-badges{ margin-bottom:var(--s3); } /* воздух до ряда CTA-кнопок */
@media (min-width:1024px){
  .page-hero{ padding-block:var(--s5) var(--s6); }
}

/* ---------- Типографика длинного текста ---------- */
.prose{ max-width:800px; }
.prose h2{ font-size:clamp(21px,3.6vw,28px); font-weight:800; margin:var(--s5) 0 var(--s2); }
.prose h3{ font-size:18px; font-weight:800; margin:var(--s4) 0 var(--s1); }
.prose h2:first-child,
.prose h3:first-child{ margin-top:0; }
.prose p{ color:var(--ink-2); margin-bottom:var(--s2); }
.prose p b, .prose p strong,
.prose li b, .prose li strong{ color:var(--ink); font-weight:600; }
.prose ul, .prose ol{ margin:0 0 var(--s2); padding-left:var(--s3); display:grid; gap:var(--s1); }
.prose ul{ list-style:disc; }
.prose ol{ list-style:decimal; }
.prose li{ color:var(--ink-2); }
.prose li::marker{ color:var(--hot-2); }
.prose img{ height:auto; border-radius:var(--r-m); border:1px solid var(--line); margin-block:var(--s3); }
.prose hr{ border:0; border-top:1px solid var(--line); margin:var(--s4) 0; }

/* Таблицы: оборачивать в .table-wrap, чтобы на мобиле скроллились сами,
   а не вся страница */
.prose .table-wrap{
  overflow-x:auto; margin-bottom:var(--s2);
  border:1px solid var(--line); border-radius:var(--r-m);
  -webkit-overflow-scrolling:touch;
}
.prose table{ width:100%; min-width:480px; border-collapse:collapse; font-size:14.5px; background:var(--surface); }
.prose th, .prose td{ padding:12px 14px; text-align:left; border-bottom:1px solid var(--line); vertical-align:top; }
.prose th{
  font-size:12.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); background:var(--surface-2); white-space:nowrap;
}
.prose td{ color:var(--ink-2); }
.prose td b{ color:var(--ink); font-weight:700; font-variant-numeric:tabular-nums; white-space:nowrap; }
.prose tr:last-child td{ border-bottom:0; }
