/* ===================================================================
   profi-clean — Я-вариант. Плиточный «портальный» интерфейс в духе Яндекса,
   голубо-белая гамма. Принципы taste-skill, адаптированные под ваниль:
   bento-сетка, диффузные тени, тактильный :active, SVG вместо эмодзи,
   выверенная типографика (Golos Text), голубой акцент < 80% насыщенности.
   =================================================================== */
:root{
  --accent:#2f6fe0;
  --accent-d:#2155bd;
  --accent-soft:#e7f0fe;
  --ink:#16202e;          /* off-black, не #000 */
  --ink-2:#5a6678;
  --ink-3:#8a93a4;
  --bg:#eef3fb;           /* голубовато-белый фон портала */
  --card:#ffffff;
  --line:#e4ebf5;
  --r:22px;               /* радиус карточек */
  --r-sm:14px;
  --r-lg:28px;
  --shadow:0 20px 40px -22px rgba(28,52,99,.18);   /* диффузная тень с тинтом фона */
  --shadow-sm:0 8px 22px -16px rgba(28,52,99,.30);
  --wrap:1240px;
  --pad:24px;
  --ease:cubic-bezier(.16,1,.3,1);
  --font:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-head:'Unbounded','Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html,body{overflow-x:clip;max-width:100%}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3{margin:0;line-height:1.08;font-weight:700;letter-spacing:-.02em}
/* крупные «брендовые» заголовки — Unbounded; мелкие (карточки) остаются Inter для читаемости */
.hero2__h1,.sec__title,.modal__title,.logo__text,.utype__t,.rsum__score b{font-family:var(--font-head);letter-spacing:-.03em}
.hero2__h1{letter-spacing:-.04em}
p{margin:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:8px}
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.vh,.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed;top:10px;left:10px;width:auto;height:auto;clip:auto;background:var(--accent);color:#fff;padding:10px 16px;border-radius:10px;z-index:1000}

/* ---------- Кнопки ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:100px;font-weight:600;font-size:16px;border:0;transition:background .2s var(--ease),transform .12s var(--ease),box-shadow .2s var(--ease);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{background:var(--accent-d)}
.btn--accent:active{transform:translateY(1px) scale(.99)}
.btn--ghost{background:var(--card);color:var(--accent);border:1.5px solid var(--line)}
.btn--ghost:hover{background:var(--accent-soft);border-color:var(--accent)}
.btn--ghost:active{transform:translateY(1px) scale(.99)}
.btn--lg{padding:15px 28px;font-size:16px}
/* адаптивная подпись кнопки: на десктопе полный текст, на мобиле короткий */
.btn-resp--short{display:none}
@media(max-width:680px){.btn-resp--full{display:none}.btn-resp--short{display:inline}}

/* ===================== HEADER ===================== */
.hd{position:sticky;top:0;z-index:200;background:rgba(238,243,251,.86);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line)}
.hd__inner{display:flex;align-items:center;gap:14px;min-height:70px}
.burger{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);padding:10px 15px;border-radius:100px;color:var(--ink);font-weight:600;font-size:16px;transition:background .2s,transform .12s var(--ease)}
.burger:hover{background:var(--accent-soft)}
.burger:active{transform:scale(.97)}
.burger svg{color:var(--accent)}
.logo{display:inline-flex;align-items:center;gap:9px;font-size:20px;font-weight:700;letter-spacing:-.02em;flex-shrink:0}
.logo__text b{color:var(--accent)}
.logo__mark{display:inline-flex;border-radius:9px;box-shadow:var(--shadow-sm)}

/* Поиск — компактная, лёгкая плашка.
   ВАЖНО: селектор ограничен тегом form — WordPress вешает class="search" на <body>
   на странице результатов поиска (is_search), и без form. эти правила ломали бы всю
   раскладку body (height:42px + flex). НЕ менять на голый .search. */
form.search{flex:1;min-width:0;display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:100px;padding:4px 4px 4px 14px;max-width:440px;height:42px;transition:border-color .2s,box-shadow .2s}
form.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.search__ico{color:var(--ink-3);flex-shrink:0}
.search__in{flex:1;min-width:0;border:0;background:transparent;font:inherit;font-size:16px;color:var(--ink);padding:6px 0}
.search__in:focus{outline:none}
.search__in::placeholder{color:var(--ink-3)}
.search__go{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--accent);color:#fff;border:0;border-radius:50%;transition:background .2s,transform .12s var(--ease)}
.search__go:hover{background:var(--accent-d)}
.search__go:active{transform:scale(.92)}

/* Живые подсказки поиска (выпадающий список услуг) */
.search__sugg{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px -18px rgba(42,49,66,.45);padding:6px;z-index:80;max-height:64vh;overflow:auto}
.search__sug{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--ink);text-decoration:none;font-size:16px;line-height:1.3}
.search__sug svg{color:var(--ink-3);flex-shrink:0}
.search__sug b{color:var(--accent);font-weight:700}
.search__sug:hover,.search__sug.is-active{background:var(--accent-soft)}

.hd__tools{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto}
.burger{order:0}
.city__btn,.lang__btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;padding:9px 11px;border-radius:100px;color:var(--ink);font-weight:600;font-size:16px;transition:background .2s,border-color .2s}
.city__btn:hover,.lang__btn:hover{background:var(--card);border-color:var(--line)}
.city__btn svg:first-child{color:var(--accent)}
.caret{color:var(--ink-3);transition:transform .2s}
[aria-expanded="true"] .caret{transform:rotate(180deg)}
.phone{font-weight:700;font-size:16px;color:var(--ink);white-space:nowrap}
.phone:hover{color:var(--accent)}
.city,.lang{position:relative}
.pop{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;max-height:340px;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow);padding:6px;margin:0;list-style:none;z-index:50}
.pop--right{right:0;left:auto;min-width:180px}
.pop li{padding:0}
.pop button,.pop a{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;background:transparent;border:0;padding:10px 12px;border-radius:10px;font-size:16px;color:var(--ink);transition:background .15s}
.pop button:hover,.pop a:hover{background:var(--bg)}
.pop button[aria-selected="true"],.pop [aria-selected="true"] a{color:var(--accent);font-weight:700;background:var(--accent-soft)}
.pop .soon{color:var(--ink-3);cursor:not-allowed;justify-content:space-between;padding:10px 12px;font-size:16px;display:flex}
.pop .soon small{font-size:16px;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-3)}

@media(max-width:1080px){form.search{max-width:380px}}
@media(max-width:920px){.phone,.city span:not(.soon),.lang span{display:none}.burger span{display:none}form.search{max-width:none}}
@media(max-width:560px){.hd__inner{gap:8px}}

/* ===================== MEGA ===================== */
.drawer[hidden]{display:none}
.drawer{position:fixed;inset:0;z-index:300}
.drawer__backdrop{position:absolute;inset:0;background:rgba(16,32,46,.42);border:0;backdrop-filter:blur(2px);animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(430px,100%);background:var(--bg);display:flex;flex-direction:column;box-shadow:-30px 0 80px -30px rgba(16,32,46,.5);animation:slideInRight .28s var(--ease)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);flex-shrink:0}
.drawer__close{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--card);border:1px solid var(--line);color:var(--ink);transition:background .2s,transform .2s var(--ease)}
.drawer__close:hover{background:var(--accent-soft);transform:rotate(90deg)}
.drawer__tools{flex-shrink:0;padding:0 16px}
.drawer__tools:empty{display:none}
.mega__cat-ic{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:11px;background:var(--accent-soft);color:var(--accent)}
/* viewport + слои drill-in */
.drawer__viewport{position:relative;flex:1;overflow:hidden}
.drawer__level{position:absolute;inset:0;overflow-y:auto;overscroll-behavior:contain;background:var(--bg);transform:translateX(100%);visibility:hidden;transition:transform .28s var(--ease),visibility .28s}
.drawer__level--root{transform:translateX(0);visibility:visible}
.drawer__level.is-active{transform:translateX(0);visibility:visible}
.drawer__list{list-style:none;margin:0;padding:0}
.drawer__row{display:flex;align-items:stretch;border-bottom:1px solid var(--line)}
.drawer__cat{flex:1;min-width:0;display:flex;align-items:center;gap:12px;padding:13px 8px 13px 20px;font-size:17px;font-weight:600;color:var(--ink)}
.drawer__cat:hover{color:var(--accent)}
.drawer__cat-t{min-width:0}
.drawer__expand{flex-shrink:0;width:54px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;border-left:1px solid var(--line);color:var(--ink-3);cursor:pointer;transition:background .2s,color .2s}
.drawer__expand:hover{background:var(--accent-soft);color:var(--accent)}
.drawer__groupbtn{width:100%;background:transparent;border:0;cursor:pointer;text-align:left;font-family:inherit;padding-right:0}
.drawer__groupbtn:hover{color:var(--accent)}
.drawer__rowchev{margin-left:auto;flex-shrink:0;align-self:stretch;display:flex;align-items:center;justify-content:center;width:54px;border-left:1px solid var(--line);color:var(--ink-3)}
.drawer__groupbtn:hover .drawer__rowchev{background:var(--accent-soft);color:var(--accent)}
.drawer__subhead--plain{color:var(--ink-3);text-transform:uppercase;letter-spacing:.5px;font-size:16px}
.drawer__link{display:flex;align-items:center;gap:10px;padding:13px 20px;font-size:16px;color:var(--ink-2);border-bottom:1px solid var(--line);transition:background .15s,color .15s}
.drawer__link:hover{color:var(--accent);background:var(--accent-soft)}
.drawer__sec{padding:18px 20px 8px;font-size:16px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);font-weight:700}
.drawer__back{display:flex;align-items:center;gap:6px;width:100%;padding:13px 20px;background:var(--accent-soft);border:0;border-bottom:1px solid var(--line);color:var(--accent);font-weight:600;font-size:16px;cursor:pointer;position:sticky;top:0;z-index:2}
.drawer__subhead{display:flex;align-items:center;gap:6px;padding:14px 20px;font-weight:700;font-size:16px;color:var(--ink);border-bottom:1px solid var(--line)}
.drawer__subhead:hover{color:var(--accent)}
.drawer__subhead svg{margin-left:auto}
.drawer__foot{display:flex;flex-direction:column;gap:10px;padding:16px 20px;border-top:1px solid var(--line);flex-shrink:0}
.drawer__phone{font-size:19px;font-weight:700;color:var(--accent);text-align:center}
.drawer__foot .btn{width:100%;padding-block:14px}
/* авто-перелинковка SEO-текста (контекстные внутренние ссылки) */
.clink{color:var(--accent);text-decoration:underline;text-decoration-color:rgba(47,111,224,.32);text-underline-offset:2px;transition:text-decoration-color .15s}
.clink:hover{text-decoration-color:var(--accent)}

/* ===================== HERO — сплит-экран с изображением ===================== */
.hero2{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-top:40px}
.hero2__badge{display:inline-block;background:var(--accent-soft);color:var(--accent-d);font-size:16px;font-weight:700;padding:7px 14px;border-radius:100px;margin-bottom:18px}
.hero2__h1{font-size:clamp(32px,4.4vw,54px);font-weight:800;letter-spacing:-.03em;line-height:1.02}
.hero2__h1 span{color:var(--accent)}
.hero2__sub{margin-top:16px;font-size:17px;color:var(--ink-2);max-width:540px;line-height:1.6}
.hero2__sub--m{display:none}/* AIDA-подзаголовок — только в мобильной версии */
.hero2__cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.hero2__stats{display:grid;grid-template-columns:repeat(4,auto);gap:24px 30px;list-style:none;margin:30px 0 0;padding:0}
.hero2__stats b{display:block;font-size:23px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.hero2__stats span{font-size:16px;color:var(--ink-3)}
.hero2__pay{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:22px 0 0;padding:0}
.hero2__pay li{font-size:16px;font-weight:600;color:var(--ink-2);background:var(--card);border:1px solid var(--line);padding:5px 12px;border-radius:100px}
.hero2__media{position:relative;display:flex;align-items:flex-end;justify-content:center}
/* мягкое голубое «пятно» позади человека для глубины */
.hero2__media::before{content:"";position:absolute;left:50%;top:50%;width:86%;aspect-ratio:1;background:radial-gradient(circle,rgba(47,111,224,.2),rgba(47,111,224,0) 72%);transform:translate(-50%,-46%);z-index:0}
.hero2__img{position:relative;z-index:1;width:100%;max-width:520px;height:auto;object-fit:contain}
.hero2__chip{position:absolute;display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);padding:13px 17px;border-radius:16px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.6)}
.hero2__chip b{display:block;font-size:16px;font-weight:700}
.hero2__chip small{font-size:16px;color:var(--ink-2)}
.hero2__chip--top{top:26px;left:-18px}
.hero2__chip--bot{bottom:26px;right:-18px}
.hero2__chip-ic{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:11px;background:var(--accent-soft);flex-shrink:0}
.hero2__avs{display:flex}
.hero2__avs img{width:34px;height:34px;border-radius:50%;border:2px solid #fff;object-fit:cover;margin-left:-10px}
.hero2__avs img:first-child{margin-left:0}
/* десктоп (>920px): изображение в hero на 30% меньше — только десктоп */
@media(min-width:921px){.hero2__img{max-width:370px}}
/* hero услуги (GPT-4o, портрет 2:3) — ограничиваем по ВЫСОТЕ, чтобы совпадало с главной +15% */
@media(min-width:921px){
  body.single-service .hero2{grid-template-columns:1.05fr .95fr}
  body.single-service .hero2__img{max-width:100%;max-height:660px;width:auto}
}
/* мягкая тень силуэта: вырезанная (прозрачная) фигура со светлыми инструментами не сливается
   со светло-голубым фоном; не обрезает — даёт контур по краю. Касается всех страниц услуг. */
body.single-service .hero2__img{filter:drop-shadow(0 16px 26px rgba(20,40,80,.16))}
/* блок «Виды» (объекты услуги) */
.vtypes{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:980px){.vtypes{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.vtypes{grid-template-columns:1fr}}
.vtype{background:#fff;border:1px solid #e8edf5;border-radius:16px;padding:20px 22px;box-shadow:0 2px 14px rgba(20,40,80,.04)}
.vtype__t{margin:0 0 6px;font-size:18px;font-weight:700;color:#1b2436}
.vtype__d{margin:0;font-size:16px;line-height:1.5;color:#5a6478}
/* под-пункты этапа (слитое «что входит») */
.step4__list{margin:10px 0 0;padding:0 0 0 18px;list-style:disc}
.step4__list li{font-size:16px;line-height:1.45;color:#5a6478;margin:2px 0}
/* факты в преимуществах */
.adv__facts{margin:10px 0 0;padding:0 0 0 18px;list-style:disc}
.adv__facts li{font-size:16px;line-height:1.45;color:#5a6478;margin:3px 0}
.adv__facts li::marker{color:var(--accent,#2f6fe0)}
/* слайдер «до/после» */
.slider__track--ba{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:6px;scrollbar-width:none}
.slider__track--ba::-webkit-scrollbar{display:none}
/* ровно 3 карточки на экран (4-я полностью скрыта; прокрутка — стрелками/точками) */
.slider__track--ba .ba2__card{flex:0 0 calc((100% - 40px)/3);scroll-snap-align:start}
@media(max-width:900px){.slider__track--ba .ba2__card{flex:0 0 calc((100% - 20px)/2)}}
@media(max-width:600px){.slider__track--ba .ba2__card{flex:0 0 100%}}
.ba2__row{margin:5px 0 0;font-size:16px;line-height:1.45;color:#5a6478}
.ba2__row b{color:#2a3142;font-weight:700}
/* одинаковая высота карточек: тянем по высоте (длину текста задаёт генерация, без обрезки) */
.slider__track--ba{align-items:stretch}
.slider__track--ba .ba2__body{display:flex;flex-direction:column}
/* правило заказчика: минимальный шрифт 16px */
.step4__d{font-size:16px}
.step4__meta{font-size:16px}
.ba2__tag{font-size:16px}
.rsum__bar-n,.rsum__bar-v{font-size:16px}
.rv__like,.rv__photolink{font-size:16px}
.rsum__src small,.rsum__src-val small,.rv__meta{font-size:16px}
/* таблицы в статье не выходят за экран — горизонтальная прокрутка внутри */
.expert__body{max-width:100%;overflow-wrap:break-word}
.expert__body table{display:block;width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-collapse:collapse}
.expert__body table th,.expert__body table td{white-space:normal}
@media(max-width:600px){.expert__body table th,.expert__body table td{font-size:16px;padding:8px 10px}}
/* мобильная компактность кнопок hero/калькулятора (чтобы влезали в экран) */
@media(max-width:560px){
  .hero2__cta{flex-wrap:wrap}
  .hero2__cta .btn--lg{flex:1 1 auto;padding:13px 14px;font-size:16px;text-align:center}
  .calc__cta{padding:14px 16px;font-size:16px}
  .calc__card{padding:18px 16px}
  .calc__opt{padding:9px 12px;font-size:16px}
}
/* мобайл: компактный hero-CTA и калькулятор на странице услуги — влезают в один экран */
@media(max-width:680px){
  body.single-service .hero2__cta{margin-top:6px;gap:8px}
  body.single-service .hero2__cta .btn{padding-top:12px;padding-bottom:12px}
  body.single-service #calc{padding-block:22px}
  body.single-service .calc__form{padding:18px 16px}
  body.single-service .calc__result{padding:18px 16px}
  body.single-service .calc__group{margin-bottom:13px}
  body.single-service .calc__lead{margin:6px 0 13px}
  body.single-service .calc__incl{gap:7px}
  body.single-service .calc__cta{margin-top:16px}
  body.single-service .calc__price b{font-size:26px}
}
/* подвал отзыва: лайк + ссылка «Смотреть фото» (карточки одинаковой высоты) */
.rv__foot{display:flex;align-items:center;gap:16px;margin:12px 0 0;padding-top:10px;border-top:1px solid #eef1f6}
.rv__like{display:inline-flex;align-items:center;gap:6px;background:none;border:0;padding:2px 0;cursor:pointer;color:#6b7280;font:inherit;font-size:16px}
.rv__like b{font-weight:700}
.rv__like:hover,.rv__like[aria-pressed="true"]{color:var(--accent,#2f6fe0)}
.rv__photolink{font-size:16px;color:var(--accent,#2f6fe0);text-decoration:underline;text-underline-offset:2px;cursor:pointer}
.rv__photolink:hover{text-decoration:none}
@media(max-width:920px){
  /* мобайл: заголовок → подзаголовок → картинка → статистика → кнопки */
  .hero2{display:flex;flex-direction:column;align-items:stretch;gap:18px;padding-top:24px}
  .hero2__copy{display:contents}
  .hero2__badge{order:1;align-self:flex-start;margin-bottom:0}
  .hero2__h1{order:2}
  .hero2__sub{order:3;margin-top:0;max-width:none}
  .hero2__media{order:4;max-width:380px;margin:0 auto}
  .hero2__stats{order:5;margin-top:2px;grid-template-columns:repeat(2,1fr);gap:20px 24px}
  .hero2__cta{order:6;margin-top:8px;flex-wrap:nowrap;gap:10px}
  .hero2__cta .btn{flex:1 1 0;min-width:0;padding-left:14px;padding-right:14px;white-space:nowrap}
}
@media(max-width:680px){.hero2{gap:16px;padding-top:20px}}
@media(max-width:480px){.hero2__chip{display:none}}
.quick{display:flex;flex-wrap:wrap;gap:10px;list-style:none;margin:26px 0 0;padding:0}
.quick a{display:inline-block;background:var(--card);border:1px solid var(--line);padding:9px 16px;border-radius:100px;font-size:16px;font-weight:500;color:var(--ink);transition:background .2s,border-color .2s,transform .12s var(--ease)}
.quick a:hover{background:var(--accent-soft);border-color:var(--accent)}
.quick a:active{transform:scale(.97)}

/* ===================== SECTION ===================== */
.sec{padding-block:46px}
.sec--narrow{max-width:880px}
.sec__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.sec__eyebrow{display:block;font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--accent);margin-bottom:8px}
.sec__title{font-size:clamp(22px,2.6vw,32px);font-weight:800;letter-spacing:-.03em}
.sec__link{font-size:16px;font-weight:600;color:var(--accent);white-space:nowrap}
.sec__link:hover{color:var(--accent-d)}
.sec__info{font-size:16px;font-weight:500;color:var(--ink-3);max-width:340px;text-align:right}
@media(max-width:600px){.sec__info{text-align:left}}
.sec__note{font-size:16px;color:var(--ink-2);max-width:340px}
.sec__rate,.sec__rate b{font-size:16px;color:var(--ink-2)}
.sec__rate b{font-weight:800;color:var(--ink)}

/* ===================== УСЛУГИ — ровная сетка 4 колонки ===================== */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.scard{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;min-height:210px;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .2s}
.scard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.scard:active{transform:translateY(-1px) scale(.995)}
.scard__ic{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:13px;background:var(--accent-soft);color:var(--accent);margin-bottom:16px}
.scard__t{font-size:18px;font-weight:700}
.scard__d{font-size:16px;color:var(--ink-2);margin-top:6px;line-height:1.5}
.scard__p{margin-top:auto;padding-top:14px;font-size:16px;font-weight:700;color:var(--accent)}
.scard--cta{background:var(--accent);border-color:var(--accent)}
.scard--cta .scard__t{color:#fff}
.scard--cta .scard__d{color:rgba(255,255,255,.85)}
.scard__ic--cta{background:rgba(255,255,255,.18);color:#fff}
.scard__p--cta{color:#fff}
@media(max-width:980px){.grid4{grid-template-columns:repeat(2,1fr)}.grid3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid4{grid-template-columns:1fr}.grid3{grid-template-columns:1fr}.scard{min-height:0}}

/* ===================== ЭТАПЫ — развёрнуто ===================== */
.steps2{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(5,1fr);gap:14px;counter-reset:s}
.step2{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 20px;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s var(--ease)}
.step2:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.step2__n{font-size:26px;font-weight:800;color:var(--accent);letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:10px}
.step2__t{font-size:16.5px;font-weight:700;margin-bottom:8px}
.step2__d{font-size:16px;color:var(--ink-2);line-height:1.55;flex:1}
.step2__meta{margin-top:14px;font-size:16px;font-weight:600;color:var(--accent);background:var(--accent-soft);padding:5px 11px;border-radius:100px;align-self:flex-start}
@media(max-width:980px){.steps2{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.steps2{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.steps2{grid-template-columns:1fr}}

/* ===================== ПРЕИМУЩЕСТВА — развёрнуто ===================== */
.adv{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;transition:box-shadow .2s,transform .2s var(--ease)}
.adv:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.adv__top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.adv__num{font-family:var(--font-head);font-size:34px;font-weight:700;color:var(--accent);letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.adv__num small{font-family:var(--font);font-size:16px;font-weight:600;color:var(--ink-3);letter-spacing:0;margin-left:3px}
.adv__ic{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:13px;background:var(--accent-soft);color:var(--accent);flex-shrink:0}
.adv__t{font-size:17px;font-weight:700;margin-bottom:8px}
.adv__d{font-size:16px;color:var(--ink-2);line-height:1.55}

/* ===================== ДО / ПОСЛЕ — кейсы ===================== */
.cases{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:760px){.cases{grid-template-columns:1fr}}
.case{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .2s,transform .2s var(--ease)}
.case:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.ba{position:relative;aspect-ratio:760/520;overflow:hidden;user-select:none;touch-action:pan-y}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ba__after{z-index:0}
.ba__before{position:absolute;inset:0;z-index:1;overflow:hidden;clip-path:inset(0 50% 0 0)}
.ba__before img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba__tag{position:absolute;top:12px;z-index:3;font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;background:rgba(16,32,46,.6);padding:4px 10px;border-radius:100px}
.ba__tag--b{left:12px}.ba__tag--a{right:12px;background:rgba(47,111,224,.85)}
.ba__range{position:absolute;inset:0;z-index:4;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize}
.ba__handle{position:absolute;top:50%;left:50%;z-index:3;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;pointer-events:none}
.case__body{padding:20px 22px}
.case__cat{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent)}
.case__t{font-size:18px;font-weight:700;margin:7px 0 14px}
.case__meta{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.case__meta dt{font-size:16px;color:var(--ink-3);margin-bottom:3px}
.case__meta dd{margin:0;font-size:16px;font-weight:700}
.case__price{color:var(--accent)!important}
.case__geo{display:inline-block;margin-top:13px;font-size:16px;color:var(--ink-2)}
@media(max-width:420px){.case__meta{grid-template-columns:repeat(2,1fr)}}

/* ===================== ОТЗЫВЫ — полноценный модуль ===================== */
.rsum{display:grid;grid-template-columns:auto 1fr auto;gap:34px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px 30px;margin-bottom:20px}
.rsum__score{text-align:center}
.rsum__score b{display:block;font-size:46px;font-weight:800;letter-spacing:-.03em;line-height:1}
.rsum__stars{color:#f5a623;font-size:18px;letter-spacing:2px;margin:6px 0 4px}
.rsum__score span{font-size:16px;color:var(--ink-3)}
.rsum__bars{display:grid;gap:7px;min-width:0}
.bar{display:flex;align-items:center;gap:10px;font-size:16px}
.bar__n{width:24px;color:var(--ink-2);font-weight:600}
.bar__track{flex:1;height:7px;background:var(--bg);border-radius:100px;overflow:hidden}
.bar__fill{display:block;height:100%;background:#f5a623;border-radius:100px}
.bar__p{width:34px;text-align:right;color:var(--ink-3);font-variant-numeric:tabular-nums}
.rsum__src{list-style:none;margin:0;padding:0 0 0 30px;border-left:1px solid var(--line);display:grid;gap:10px}
.rsum__src b{font-size:16px;font-weight:700}
.rsum__src span{font-size:16px;color:var(--ink-2)}
@media(max-width:840px){.rsum{grid-template-columns:1fr;gap:22px;text-align:center}.rsum__src{padding:18px 0 0;border-left:0;border-top:1px solid var(--line);grid-template-columns:repeat(3,1fr)}}

.rfilter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.rfilter__b{background:var(--card);border:1px solid var(--line);padding:8px 16px;border-radius:100px;font-size:16px;font-weight:600;color:var(--ink-2);transition:background .2s,color .2s,border-color .2s}
.rfilter__b:hover{background:var(--accent-soft)}
.rfilter__b.is-on{background:var(--accent);color:#fff;border-color:var(--accent)}

.revs2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:760px){.revs2{grid-template-columns:1fr}}
.revs2__empty{grid-column:1/-1;text-align:center;color:var(--ink-3);padding:30px}
.revs2__more{text-align:center;margin-top:22px}
.rv{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px;display:flex;flex-direction:column}
.rv__head{display:flex;align-items:center;gap:12px}
.rv__av{width:46px;height:46px;border-radius:50%;object-fit:cover;background:var(--bg);flex-shrink:0}
.rv__id{flex:1;min-width:0}
.rv__id b{display:block;font-size:16px;font-weight:700}
.rv__meta{font-size:16px;color:var(--ink-3)}
.rv__stars{color:#f5a623;font-size:16px;letter-spacing:1px;flex-shrink:0}
.rv__svc{display:inline-block;align-self:flex-start;margin:13px 0 10px;font-size:16px;font-weight:600;color:var(--accent);background:var(--accent-soft);padding:4px 11px;border-radius:100px}
.rv__text{font-size:16px;color:var(--ink-2);line-height:1.6;margin:0}
.rv__photos{display:flex;gap:8px;margin-top:13px;flex-wrap:wrap}
.rv__photo{width:74px;height:74px;border-radius:11px;overflow:hidden;border:0;padding:0;cursor:zoom-in;background:var(--bg)}
.rv__photo img{width:100%;height:100%;object-fit:cover;transition:transform .3s var(--ease)}
.rv__photo:hover img{transform:scale(1.08)}
.rv__reply{margin-top:14px;background:var(--bg);border-radius:13px;padding:14px 16px;border-left:3px solid var(--accent)}
.rv__reply--user{border-left-color:var(--ink-3)}
.rv__reply-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.rv__reply-logo{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:7px;background:var(--accent);color:#fff;font-size:16px;font-weight:800}
.rv__reply-head b{font-size:16px;font-weight:700}
.rv__reply p{margin:0;font-size:16px;color:var(--ink-2);line-height:1.55}
.rv__foot{display:flex;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.rv__like,.rv__reply-btn{display:inline-flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--line);padding:8px 14px;border-radius:100px;font-size:16px;font-weight:600;color:var(--ink-2);transition:background .2s,color .2s,border-color .2s}
.rv__like:hover,.rv__reply-btn:hover{background:var(--accent-soft);color:var(--accent)}
.rv__like.is-on{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}
.rv__replyform{display:flex;gap:8px;margin-top:12px}
.rv__replyform input{flex:1;min-width:0;padding:11px 14px;border:1.5px solid var(--line);border-radius:11px;font:inherit;font-size:16px}
.rv__replyform input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.rv__replyform .btn{padding:10px 16px}

/* ===================== КОМАНДА ===================== */
.team__lead{font-size:16px;color:var(--ink-2);max-width:760px;line-height:1.6;margin-bottom:24px}
.team{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
@media(max-width:980px){.team{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.team{grid-template-columns:repeat(2,1fr)}}
.tmember{margin:0;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .2s,transform .2s var(--ease)}
.tmember:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.tmember__ph{position:relative;aspect-ratio:36/42;background:var(--bg)}
.tmember__ph img{width:100%;height:100%;object-fit:cover}
.tmember__tag{position:absolute;bottom:10px;left:10px;right:10px;font-size:16px;font-weight:700;color:#fff;background:rgba(16,32,46,.62);backdrop-filter:blur(4px);padding:5px 10px;border-radius:100px;text-align:center}
.tmember figcaption{padding:15px 16px}
.tmember figcaption b{display:block;font-size:16px;font-weight:700}
.tmember__role{display:block;font-size:16px;color:var(--accent);font-weight:600;margin-top:3px}
.tmember__exp{display:block;font-size:16px;color:var(--ink-3);margin-top:3px}

/* ===================== БЛОГ ===================== */
/* scope под #main: иначе совпадает с body-классом WP `.blog` (главная) и ломает раскладку */
#main .blog{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:980px){#main .blog{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){#main .blog{grid-template-columns:1fr}}
.post{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .2s,transform .2s var(--ease)}
.post:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.post__img{position:relative;aspect-ratio:16/10;background:var(--bg)}
.post__img img{width:100%;height:100%;object-fit:cover}
.post__cat{position:absolute;top:12px;left:12px;font-size:16px;font-weight:700;color:var(--accent);background:rgba(255,255,255,.92);padding:5px 11px;border-radius:100px}
.post__body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.post__t{font-size:16px;font-weight:700;line-height:1.3}
.post__ex{font-size:16px;color:var(--ink-2);margin-top:8px;line-height:1.5;flex:1}
.post__meta{margin-top:14px;font-size:16px;color:var(--ink-3)}

/* ===================== МОДАЛКА / ЛАЙТБОКС ===================== */
.modal[hidden],.lbox[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:20px}
.modal__backdrop{position:absolute;inset:0;background:rgba(16,32,46,.5);border:0;backdrop-filter:blur(2px);animation:fade .25s ease}
.modal__box{position:relative;z-index:1;background:var(--card);border-radius:var(--r-lg);padding:32px;max-width:480px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 40px 90px -30px rgba(16,32,46,.5);animation:pop .3s var(--ease)}
@keyframes pop{from{transform:scale(.96) translateY(10px);opacity:0}to{transform:none;opacity:1}}
.modal__close{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;background:var(--bg);border:0;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .2s}
.modal__close:hover{background:var(--accent-soft)}
.modal__title{font-size:24px;font-weight:800;letter-spacing:-.02em}
.modal__sub{font-size:16px;color:var(--ink-2);margin:8px 0 20px;line-height:1.5}
/* модал выбора города */
.modal__box--city{max-width:560px}
.citygrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:4px}
.citygrid__b{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:15px 16px;border:1.5px solid var(--line);border-radius:14px;background:var(--card);font-size:16px;font-weight:600;color:var(--ink);text-align:left;cursor:pointer;transition:border-color .18s,background .18s}
.citygrid__b:hover{border-color:var(--accent);background:var(--accent-soft)}
.citygrid__b[aria-selected="true"]{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.citygrid__b[aria-selected="true"]::after{content:"✓";font-weight:800;color:var(--accent)}
.citygrid__soon{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:15px 16px;border:1.5px dashed var(--line);border-radius:14px;background:var(--bg);color:var(--ink-3);font-size:16px;font-weight:600;cursor:not-allowed}
.citygrid__badge{font-size:16px;font-weight:600;color:var(--accent);background:var(--accent-soft);padding:2px 11px;border-radius:100px;white-space:nowrap}
@media(max-width:520px){.citygrid{grid-template-columns:1fr}}
.rform{display:grid;gap:15px}
.rform textarea{padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font:inherit;font-size:16px;resize:vertical;min-height:90px}
.rform textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.rform input[type=file]{font-size:16px;color:var(--ink-3);width:100%;padding:12px 14px;border:1.5px dashed var(--line);border-radius:12px;background:var(--bg);cursor:pointer;transition:border-color .2s,background .2s}
.rform input[type=file]:hover{border-color:var(--accent);background:var(--accent-soft)}
.rform input[type=file]::file-selector-button{margin-right:12px;font:inherit;font-size:16px;font-weight:700;border:0;background:var(--accent);color:#fff;padding:8px 16px;border-radius:100px;cursor:pointer;transition:background .2s}
.rform input[type=file]::file-selector-button:hover{background:var(--accent-d)}
.rstars{display:flex;gap:4px}
.rstars button{background:0;border:0;font-size:30px;line-height:1;color:#d6deea;padding:0 2px;transition:color .15s,transform .12s var(--ease)}
.rstars button:hover,.rstars button.is-on{color:#f5a623}
.rstars button:active{transform:scale(.85)}
.rstars.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.rform__ok{background:var(--accent-soft);color:var(--accent-d);font-weight:600;padding:12px;border-radius:12px;text-align:center;font-size:16px}
.lbox{position:fixed;inset:0;z-index:500;background:rgba(10,18,30,.9);display:flex;align-items:center;justify-content:center;padding:30px;cursor:zoom-out}
.lbox img{max-width:100%;max-height:100%;border-radius:14px;box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.lbox__close{position:absolute;top:20px;right:24px;background:0;border:0;color:#fff;font-size:38px;line-height:1;cursor:pointer}

/* ===================== FLOW (процесс) ===================== */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;list-style:none;margin:0;padding:0}
.flow__i{display:flex;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px;transition:box-shadow .2s,transform .2s var(--ease)}
.flow__i:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.flow__n{flex-shrink:0;width:36px;height:36px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.flow__i h3{font-size:16px;font-weight:700;margin-bottom:4px}
.flow__i p{font-size:16px;color:var(--ink-2)}
@media(max-width:820px){.flow{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.flow{grid-template-columns:1fr}}

/* ===================== USP ===================== */
.usp{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.usp__i{display:flex;gap:13px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;transition:box-shadow .2s,transform .2s var(--ease)}
.usp__i:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.usp__ic{flex-shrink:0;width:40px;height:40px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center}
.usp__i b{display:block;font-size:16px;font-weight:700}
.usp__i span{font-size:16px;color:var(--ink-2)}
@media(max-width:820px){.usp{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.usp{grid-template-columns:1fr}}

/* ===================== PRICE строки ===================== */
.price{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.price__row{display:grid;grid-template-columns:1.1fr 1.4fr auto;align-items:center;gap:16px;padding:17px 24px;border-bottom:1px solid var(--line);transition:background .15s}
.price__row:last-child{border-bottom:0}
.price__row:hover{background:var(--bg)}
.price__n{font-weight:700;font-size:16px}
.price__m{font-size:16px;color:var(--ink-2)}
.price__v{font-weight:800;font-size:16px;color:var(--accent);white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums}
@media(max-width:640px){.price__row{grid-template-columns:1fr auto;gap:6px 16px}.price__m{grid-column:1;font-size:16px}.price__v{grid-row:1;grid-column:2}}

/* ===================== ОТЗЫВЫ ===================== */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rev{margin:0;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px;transition:box-shadow .2s,transform .2s var(--ease)}
.rev:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.rev__top{display:flex;align-items:center;gap:12px;margin-bottom:13px}
.rev__top img{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--bg)}
.rev__top b{display:block;font-size:16px;font-weight:700}
.rev__top small{font-size:16px;color:#f5a623;letter-spacing:.3px}
.rev blockquote{margin:0;font-size:16px;color:var(--ink-2);line-height:1.6}
@media(max-width:820px){.revs{grid-template-columns:1fr}}

/* ===================== CHIPS ===================== */
.chips{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-wrap:wrap;gap:10px}
.chips a{display:inline-block;background:var(--card);border:1px solid var(--line);padding:11px 20px;border-radius:100px;font-size:16px;font-weight:500;color:var(--ink);transition:background .2s,border-color .2s,color .2s,transform .12s var(--ease)}
.chips a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.chips a:active{transform:scale(.97)}
.areas__more{font-size:16px;color:var(--ink-2)}
.areas__more a{color:var(--accent);font-weight:600}

/* ===================== FAQ ===================== */
.faq{display:grid;gap:12px}
.faq__i{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;transition:border-color .2s}
.faq__i[open]{border-color:#cdd9ec}
.faq__i summary{list-style:none;cursor:pointer;padding:18px 52px 18px 22px;font-weight:700;font-size:16px;position:relative}
.faq__i summary::-webkit-details-marker{display:none}
.faq__i summary::after{content:"";position:absolute;right:24px;top:50%;width:11px;height:11px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:translateY(-70%) rotate(45deg);transition:transform .2s}
.faq__i[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.faq__i div{padding:0 22px 20px;color:var(--ink-2);font-size:16px;line-height:1.6}
.faq__i div b{color:var(--ink)}

/* ===================== LEAD ===================== */
.lead{display:grid;grid-template-columns:1fr 1fr;gap:32px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow)}
.lead__l{align-self:center}
.lead__l p{margin-top:12px;font-size:16px;color:var(--ink-2)}
.lead__points{list-style:none;margin:20px 0 0;padding:0;display:grid;gap:10px}
.lead__points li{position:relative;padding-left:28px;font-size:16px;font-weight:500}
.lead__points li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='%232f6fe0' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat}
.lead__form{display:grid;gap:14px;align-content:start}
.fld{display:grid;gap:6px}
.fld label{font-size:16px;font-weight:600;color:var(--ink-2)}
.fld input,.fld select{padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font:inherit;font-size:16px;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.fld input::placeholder{color:var(--ink-3)}
.lead__go{width:100%;margin-top:4px}
.lead__note{font-size:16px;color:var(--ink-3);text-align:center}
.lead__note a{color:var(--accent);text-decoration:underline}
.lead__ok{background:var(--accent-soft);color:var(--accent-d);font-weight:600;padding:12px;border-radius:12px;text-align:center;font-size:16px}
@media(max-width:760px){.lead{grid-template-columns:1fr;padding:26px 22px;gap:24px}}

/* ===================== FOOTER ===================== */
.ft{background:#16202e;color:#aeb9cc;margin-top:30px;padding-top:48px;font-size:16px}
.ft .logo__text{color:#fff}
.ft__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px}
.ft__about{margin:14px 0;color:#8b97ab;max-width:300px;font-size:16px;line-height:1.6}
.ft__nap{font-size:16px;line-height:1.9;color:#9fabc0}
.ft__nap a:hover{color:#fff}
.ft__nav h3{font-size:16px;text-transform:uppercase;letter-spacing:.6px;color:#fff;margin-bottom:15px;font-weight:700}
.ft__nav ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.ft__nav a{color:#9fabc0;font-size:16px;transition:color .15s}
.ft__nav a:hover{color:#fff}
.ft__nav a[aria-current="page"]{color:#fff;font-weight:700}
.soon{color:#6f7c93}
.soon em{font-style:normal;font-size:16px;text-transform:uppercase;letter-spacing:.4px;color:#cfe0ff;background:rgba(47,111,224,.22);padding:2px 7px;border-radius:100px;margin-left:6px}
.ft__bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;border-top:1px solid rgba(255,255,255,.08);font-size:16px;color:#7a8499}
.ft__legal{display:flex;gap:18px;flex-wrap:wrap}
.ft__legal a:hover{color:#fff}
@media(max-width:840px){.ft__grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:520px){.ft__grid{grid-template-columns:1fr}.ft__bottom{flex-direction:column;text-align:center}}

/* ===================== reveal + reduced motion ===================== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
body.menu-open{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}

/* ===================================================================
   ОБНОВЛЕНИЯ (2026-06-03): show-more, виды уборки, слайдеры, фиксы
   =================================================================== */

/* show-more кнопки по центру */
.sec__more{text-align:center;margin-top:24px}
.sec__link[aria-expanded]{background:none;border:0;cursor:pointer;font-family:inherit}

/* услуги: скрытые карточки */
.scard.is-hidden{display:none}

/* цены: скрытые строки + раскрытие */
.price__row.is-hidden{display:none}
.price.is-open .price__row.is-hidden{display:grid}

/* ===================== ВИДЫ УБОРКИ (сетка 3×2 с фото) ===================== */
.types{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.types{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.types{grid-template-columns:1fr}}
.utype{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .2s,transform .2s var(--ease);height:100%}
.utype:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.utype--hl{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.utype__ph{position:relative;aspect-ratio:16/9;background:var(--bg)}
.utype__ph img{width:100%;height:100%;object-fit:cover}
.utype__badge{position:absolute;top:12px;left:12px;font-size:16px;font-weight:700;color:#fff;background:var(--accent);padding:5px 12px;border-radius:100px}
.utype__body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.utype__head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:10px}
.utype__t{font-size:20px;font-weight:800;letter-spacing:-.02em}
.utype__p{font-size:16px;font-weight:800;color:var(--accent);white-space:nowrap}
.utype__d{font-size:16px;color:var(--ink-2);line-height:1.55;margin-bottom:14px}
.utype__list{list-style:none;margin:0 0 16px;padding:0;display:grid;gap:9px}
.utype__list li{position:relative;padding-left:26px;font-size:16px;color:var(--ink)}
.utype__list li::before{content:"";position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:50%;background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='%232f6fe0' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/11px no-repeat}
.utype__time{display:inline-block;align-self:flex-start;margin-top:auto;font-size:16px;font-weight:600;color:var(--ink-2);background:var(--bg);padding:6px 13px;border-radius:100px}

/* ===================== СЛАЙДЕР (универсальный) =====================
   Карточки не обрезаются: на экран помещается целое число карточек
   (--per), лишние уходят на следующую «страницу». Листание — по странице. */
.slider{position:relative}
.slider__track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:4px 2px 10px;-ms-overflow-style:none;scrollbar-width:none}
.slider__track::-webkit-scrollbar{display:none}
.slider__track>*{scroll-snap-align:start;flex:0 0 calc((100% - (var(--per,1) - 1) * 16px) / var(--per,1))}
.slider__track--cases{--per:3}
.slider__track--blog{--per:4}
.slider__track--team{--per:5}
@media(max-width:980px){.slider__track--cases{--per:2}.slider__track--blog{--per:2}.slider__track--team{--per:4}}
@media(max-width:680px){.slider__track--cases{--per:1}.slider__track--blog{--per:1}.slider__track--team{--per:1}}
/* команда: счётчик уборок — отдельной строкой под текстом */
.tmember__count{display:inline-block;align-self:flex-start;margin-top:8px;font-size:16px;font-weight:700;color:var(--accent);background:var(--accent-soft);padding:4px 11px;border-radius:100px}
.tmember figcaption{display:flex;flex-direction:column}
/* панель управления под слайдером — стрелки больше не заезжают на карточки */
.slider__ctrls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:20px}
.slider__ctrls[hidden]{display:none}
.slider__nav{flex-shrink:0;width:42px;height:42px;border-radius:50%;background:var(--card);border:1px solid var(--line);color:var(--ink);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:background .2s,opacity .2s,transform .12s var(--ease)}
.slider__nav:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.slider__nav:active{transform:scale(.92)}
.slider__nav:disabled{opacity:.35;pointer-events:none}

/* точки-пагинация */
.slider__dots{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap}
.slider__dots:empty{display:none}
.slider__dot{width:9px;height:9px;padding:0;border:0;border-radius:50%;background:var(--line);cursor:pointer;transition:background .2s,width .25s var(--ease)}
.slider__dot:hover{background:var(--ink-3)}
.slider__dot.is-on{background:var(--accent);width:26px;border-radius:100px}
/* вертикальная линия-разделитель у бегунка «до/после» */
.ba__handle::before{content:"";position:absolute;left:50%;top:-1000px;bottom:-1000px;width:3px;background:#fff;transform:translateX(-50%);box-shadow:0 0 6px rgba(16,32,46,.25);z-index:-1}

/* кейсы внутри слайдера */
.case{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ba{position:relative;aspect-ratio:760/520;overflow:hidden;user-select:none;touch-action:pan-y}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ba__after{z-index:0}
.ba__before{position:absolute;inset:0;z-index:1;overflow:hidden;clip-path:inset(0 50% 0 0)}
.ba__before img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba__tag{position:absolute;top:12px;z-index:3;font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;background:rgba(16,32,46,.6);padding:4px 10px;border-radius:100px}
.ba__tag--b{left:12px}.ba__tag--a{right:12px;background:rgba(47,111,224,.85)}
.ba__range{position:absolute;inset:0;z-index:4;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize}
.ba__handle{position:absolute;top:50%;left:50%;z-index:3;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;pointer-events:none}
.case__body{padding:20px 22px}
.case__cat{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent)}
.case__t{font-size:18px;font-weight:700;margin:7px 0 14px}
.case__meta{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.case__meta dt{font-size:16px;color:var(--ink-3);margin-bottom:3px}
.case__meta dd{margin:0;font-size:16px;font-weight:700}
.case__price{color:var(--accent)!important}
.case__geo{display:inline-block;margin-top:13px;font-size:16px;color:var(--ink-2)}
@media(max-width:480px){.case__meta{grid-template-columns:repeat(2,1fr)}}

/* команда внутри слайдера — компактная карточка */
.tmember{margin:0;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.tmember__ph{position:relative;aspect-ratio:36/42;background:var(--bg)}
.tmember__ph img{width:100%;height:100%;object-fit:cover;object-position:center top}
.tmember__tag{position:absolute;bottom:10px;left:10px;right:10px;font-size:16px;font-weight:700;color:#fff;background:rgba(16,32,46,.62);backdrop-filter:blur(4px);padding:5px 10px;border-radius:100px;text-align:center}
.tmember figcaption{padding:12px 14px;gap:3px}
.tmember figcaption b{font-size:16px;font-weight:700;line-height:1.25}
.tmember__role{font-size:16px;color:var(--accent);font-weight:600;line-height:1.3}
.tmember__exp{font-size:16px;color:var(--ink-3);line-height:1.3}
.tmember__stat{display:flex;align-items:center;gap:4px;margin-top:2px;font-size:16px;color:var(--ink-2)}
.tmember__stat b{font-weight:700;color:var(--ink)}
.tmember__stat span{color:var(--ink-3)}

/* блог внутри слайдера */
.post{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.post__img{position:relative;aspect-ratio:16/10;background:var(--bg)}
.post__img img{width:100%;height:100%;object-fit:cover}
.post__cat{position:absolute;top:12px;left:12px;font-size:16px;font-weight:700;color:var(--accent);background:rgba(255,255,255,.92);padding:5px 11px;border-radius:100px}
.post__body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.post__t{font-size:16px;font-weight:700;line-height:1.3}
.post__ex{font-size:16px;color:var(--ink-2);margin-top:8px;line-height:1.5;flex:1}
.post__meta{margin-top:14px;font-size:16px;color:var(--ink-3)}

/* ===================== ФИКС: рейтинг-сводка (источники) ===================== */
.rsum__src{list-style:none;margin:0;padding:0 0 0 30px;border-left:1px solid var(--line);display:grid;gap:12px;min-width:170px}
.rsum__src li{display:flex;align-items:center;justify-content:space-between;gap:14px}
.rsum__src-name{font-size:16px;font-weight:700}
.rsum__src-val{font-size:16px;font-weight:700;color:var(--accent);white-space:nowrap}
.rsum__src-val small{color:var(--ink-3);font-weight:500}
@media(max-width:840px){.rsum__src{padding:18px 0 0;border-left:0;border-top:1px solid var(--line);grid-template-columns:repeat(3,1fr);gap:14px}.rsum__src li{flex-direction:column;gap:3px;text-align:center}}

/* ===================== ФИКС: форма ответа скрыта до клика ===================== */
.rv__replyform[hidden]{display:none!important}

/* ===================== КАЛЬКУЛЯТОР СТОИМОСТИ ===================== */
.calc{padding-top:30px}
.calc__card{display:grid;grid-template-columns:1.35fr .9fr;gap:0;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.calc__form{padding:32px 34px}
.calc__lead{font-size:16px;color:var(--ink-2);line-height:1.55;margin:8px 0 22px;max-width:480px}
.calc__group{margin-bottom:20px}
.calc__group[hidden]{display:none}
.calc__label{display:block;font-size:16px;font-weight:700;color:var(--ink-2);margin-bottom:9px}
.calc__label b{color:var(--accent);font-variant-numeric:tabular-nums}
.calc__opts{display:flex;flex-wrap:wrap;gap:8px}
.calc__opt{background:var(--bg);border:1.5px solid var(--line);color:var(--ink);padding:10px 16px;border-radius:100px;font-size:16px;font-weight:600;transition:background .18s,border-color .18s,color .18s,transform .12s var(--ease)}
.calc__opt:hover{border-color:var(--accent)}
.calc__opt:active{transform:scale(.96)}
.calc__opt.is-on{background:var(--accent);border-color:var(--accent);color:#fff}
.calc__range{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:100px;background:var(--accent-soft);outline:none;margin-top:6px}
.calc__range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--accent);border:4px solid #fff;box-shadow:var(--shadow-sm);cursor:ew-resize}
.calc__range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);border:4px solid #fff;box-shadow:var(--shadow-sm);cursor:ew-resize}
/* кнопка открытия доп.услуг (открывает модалку) */
.calc__dd-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;background:var(--bg);border:1.5px solid var(--line);border-radius:14px;padding:13px 16px;font-size:16px;font-weight:600;color:var(--ink);transition:border-color .18s,background .18s}
.calc__dd-btn:hover{border-color:var(--accent);background:var(--accent-soft)}
.calc__dd-btn svg{color:var(--accent);flex-shrink:0}

/* модалка доп.услуг */
.calcmodal[hidden]{display:none}
.calcmodal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:20px}
.calcmodal__backdrop{position:absolute;inset:0;background:rgba(16,32,46,.5);border:0;backdrop-filter:blur(2px);animation:fade .25s ease}
.calcmodal__box{position:relative;z-index:1;display:flex;flex-direction:column;background:var(--card);border-radius:var(--r-lg);width:100%;max-width:460px;max-height:88vh;overflow:hidden;box-shadow:0 40px 90px -30px rgba(16,32,46,.5);animation:pop .3s var(--ease)}
.calcmodal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 22px;border-bottom:1px solid var(--line)}
.calcmodal__title{font-size:19px;font-weight:800}
.calcmodal__close{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--bg);border:0;color:var(--ink);flex-shrink:0;transition:background .2s}
.calcmodal__close:hover{background:var(--accent-soft)}
.calcmodal__body{overflow-y:auto;padding:18px 22px;display:grid;gap:8px}
.calcmodal__foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 22px;border-top:1px solid var(--line);background:var(--card)}
.calcmodal__sum{font-size:16px;color:var(--ink-2)}
.calcmodal__sum b{font-family:var(--font-head);font-size:18px;color:var(--ink);font-variant-numeric:tabular-nums;margin-left:4px}
.calcmodal__foot .btn{flex-shrink:0}
.calc__adds{display:grid;gap:8px}
.calc__add{display:flex;align-items:center;gap:10px;background:var(--bg);border:1.5px solid var(--line);border-radius:14px;padding:12px 15px;cursor:pointer;font-size:16px;font-weight:500;transition:border-color .18s,background .18s}
.calc__add:hover{border-color:var(--accent)}
.calc__add span{flex:1}
.calc__add b{font-weight:700;color:var(--ink-2);font-size:16px;white-space:nowrap}
.calc__add input{width:20px;height:20px;accent-color:var(--accent);flex-shrink:0;cursor:pointer}
.calc__add:has(input:checked){border-color:var(--accent);background:var(--accent-soft)}
.calc__add:has(input:checked) b{color:var(--accent)}

.calc__result{background:linear-gradient(160deg,#2f6fe0,#2155bd);color:#fff;padding:32px 30px;display:flex;flex-direction:column}
.calc__rlabel{font-size:16px;font-weight:600;opacity:.85;text-transform:uppercase;letter-spacing:.5px}
.calc__price{margin:6px 0 4px}
.calc__price b{font-family:var(--font-head);font-size:clamp(26px,3vw,34px);font-weight:700;letter-spacing:-.03em;line-height:1.1;font-variant-numeric:tabular-nums}
.calc__rmeta{font-size:16px;opacity:.9;margin-bottom:20px}
.calc__incl{list-style:none;margin:0 0 auto;padding:0;display:grid;gap:11px}
.calc__incl li{position:relative;padding-left:28px;font-size:16px;line-height:1.4}
.calc__incl li::before{content:"";position:absolute;left:0;top:1px;width:19px;height:19px;border-radius:50%;background:rgba(255,255,255,.18) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='white' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat}
.calc__cta{margin-top:24px;background:#fff;color:var(--accent-d);width:100%}
.calc__cta:hover{background:#eef3fb}
.calc__fine{font-size:16px;opacity:.78;margin-top:12px;line-height:1.45}
@media(max-width:860px){.calc__card{grid-template-columns:1fr}.calc__form{padding:26px 22px}.calc__result{padding:26px 22px}}

/* ===================== ПОШАГОВЫЙ МАСТЕР КАЛЬКУЛЯТОРА ===================== */
.calc-wiz{display:block;padding:0}
.calc-wiz__main{display:grid;grid-template-columns:minmax(0,1fr) 360px;align-items:stretch}
.calc-wiz__left{padding:34px 38px;min-width:0;display:flex;flex-direction:column}
.calc-wiz .sec__title{margin:4px 0 0}
.calc-wiz__head{margin-bottom:24px}
.calc-wiz__prog{display:flex;align-items:center;gap:14px;margin-top:18px}
.calc-wiz__count{font-size:16px;font-weight:600;color:var(--ink-2);white-space:nowrap}
.calc-wiz__count b{color:var(--accent);font-variant-numeric:tabular-nums}
.calc-wiz__bar{flex:1;height:8px;border-radius:100px;background:var(--accent-soft);overflow:hidden}
.calc-wiz__bar i{display:block;height:100%;width:20%;background:var(--accent);border-radius:100px;transition:width .35s var(--ease)}
.calc-wiz__body{position:relative;flex:1;display:flex;flex-direction:column;justify-content:center}
.calc-wiz__step{display:none}
.calc-wiz__step.is-active{display:block;animation:fade .28s ease}
.calc-wiz__q{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0 0 20px;line-height:1.25}
.calc-wiz .calc__opts{flex-direction:column;align-items:stretch;gap:10px}
.calc-wiz .calc__opt{text-align:left;padding:16px 18px;border-radius:14px;font-size:17px}
/* числовые шаги (комнаты/санузлы) — «таблетки» в ряд */
.calc-wiz [data-calc="rooms"],.calc-wiz [data-calc="baths"]{flex-direction:row;flex-wrap:wrap}
.calc-wiz [data-calc="rooms"] .calc__opt,.calc-wiz [data-calc="baths"] .calc__opt{flex:1 1 0;min-width:64px;text-align:center}
.calc-wiz__nav{display:flex;align-items:center;gap:12px;margin-top:26px}
.calc-wiz__back{background:transparent;border:0;color:var(--ink-2);font-size:16px;font-weight:600;padding:10px 6px;cursor:pointer;transition:color .2s}
.calc-wiz__back:hover{color:var(--accent)}
.calc-wiz__next{margin-left:auto;min-width:150px}
/* правая панель результата (десктоп — всегда видна) */
.calc-wiz .calc__result{margin:0;justify-content:center}
.calc-wiz .calc__result .calc__incl{margin:18px 0}
.calc-wiz .calc__result .calc__cta{background:#fff;color:var(--accent-d)}
.calc-wiz .scalc__stepper{margin-top:4px}
@media(max-width:860px){
  /* мобайл/планшет: один столбец, результат — финальный шаг (скрыт до конца) */
  .calc-wiz__main{grid-template-columns:1fr}
  .calc-wiz__left{padding:26px 20px;display:block}
  .calc-wiz__body{display:block;flex:none}   /* без растяжки/центрирования — иначе пустой провал на шаге-результате */
  .calc-wiz .calc__result{display:none;border-radius:0}
  .calc-wiz .calc__result.is-active{display:flex;flex-direction:column}
}
@media(max-width:680px){
  .calc-wiz__left{padding:22px 16px}
  .calc-wiz__q{font-size:19px}
  .calc-wiz .calc__result{padding:22px 18px}
  .calc-wiz__next{min-width:130px}
}

/* ===================== СТРЕЛКИ НА КЛИКАБЕЛЬНЫХ КАРТОЧКАХ ===================== */
.scard{position:relative}
.utype{position:relative;color:inherit;text-decoration:none}
.scard__go,.utype__go{position:absolute;bottom:18px;right:18px;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);transition:background .2s,color .2s,transform .2s var(--ease)}
.scard:hover .scard__go,.utype:hover .utype__go{background:var(--accent);color:#fff;transform:translateX(3px)}
.scard--cta .scard__go{background:rgba(255,255,255,.2);color:#fff}
.scard--cta:hover .scard__go{background:#fff;color:var(--accent)}

/* ===================== ЭКСПЕРТНАЯ СТАТЬЯ ===================== */
.expert{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:34px}
.expert .sec__head{margin-bottom:22px}
.expert__layout{display:grid;grid-template-columns:minmax(0,1fr) 304px;gap:44px;align-items:start}
.expert__main{min-width:0}
.expert__meta{display:flex;align-items:center;gap:14px;padding-bottom:20px;margin-bottom:26px;border-bottom:1px solid var(--line)}
.expert__ava{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-weight:800;font-size:16px;letter-spacing:.5px;flex-shrink:0}
.expert__byline{display:flex;flex-direction:column;min-width:0}
.expert__name{font-weight:700;font-size:16px}
.expert__role{font-size:16px;color:var(--ink-2);margin-top:1px}
.expert__date{font-size:16px;color:var(--ink-3);margin-top:6px}
/* липкая CTA-карточка справа — заполняет пространство и даёт конверсию */
.expert__aside{position:sticky;top:88px}
.expert__cta-card{background:linear-gradient(160deg,var(--accent),var(--accent-d));color:#fff;border-radius:18px;padding:24px 22px;box-shadow:0 22px 44px -22px rgba(47,111,224,.55)}
.expert__cta-eyebrow{display:block;font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:rgba(255,255,255,.85)}
.expert__cta-lead{margin:8px 0 16px;font-size:16px;line-height:1.5;color:rgba(255,255,255,.92)}
.expert__cta-phone{display:block;font-family:var(--font-head);font-size:23px;font-weight:700;letter-spacing:-.01em;color:#fff;margin-bottom:14px}
.expert__cta-phone:hover{opacity:.92}
.expert__cta-btn{width:100%;justify-content:center;background:#fff;color:var(--accent-d);border:0}
.expert__cta-btn:hover{background:#f3f7ff}
.expert__cta-feat{list-style:none;margin:18px 0 0;padding:16px 0 0;display:grid;gap:10px;border-top:1px solid rgba(255,255,255,.22)}
.expert__cta-feat li{position:relative;padding-left:26px;font-size:16px;color:rgba(255,255,255,.95);line-height:1.4}
.expert__cta-feat li::before{content:"";position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.18) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='%23ffffff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/11px no-repeat}
.expert__body{font-size:16px;line-height:1.7;color:var(--ink)}
@media(max-width:920px){.expert__layout{grid-template-columns:1fr;gap:28px}.expert__aside{position:static}.expert__cta-card{max-width:420px}}
.expert__body p{margin:0 0 14px}
.expert__body h3{font-family:var(--font-head);font-size:20px;font-weight:700;letter-spacing:-.02em;margin:30px 0 12px;padding-top:22px;border-top:1px solid var(--line)}
.expert__body h3:first-child{padding-top:0;border-top:0;margin-top:6px}
.expert__body h4{font-size:16px;font-weight:700;margin:20px 0 9px;color:var(--ink)}
.expert__body ul{margin:0 0 18px;padding:0;list-style:none;display:grid;gap:10px}
.expert__body li{position:relative;padding-left:28px;font-size:16px}
.expert__body li::before{content:"";position:absolute;left:0;top:2px;width:19px;height:19px;border-radius:50%;background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='%232f6fe0' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat}
.expert__cta{font-weight:700;color:var(--accent)}
.expert__cta:hover{color:var(--accent-d)}
/* SEO-статья: нумерованный список, таблица цен, цитата, TL;DR, keywords */
.expert__body ol{margin:0 0 18px;padding-left:22px;display:grid;gap:9px;list-style:decimal}
.expert__body ol li{padding-left:6px;font-size:16px}
.expert__body ol li::before{display:none}
.expert__body table{width:100%;border-collapse:collapse;margin:4px 0 20px;font-size:16px}
.expert__body caption{text-align:left;font-weight:700;font-size:16px;margin-bottom:10px}
.expert__body th,.expert__body td{border:1px solid var(--line);padding:9px 12px;text-align:left;vertical-align:top}
.expert__body thead th{background:var(--bg)}
.expert__body tbody th{font-weight:600}
.expert__body blockquote{margin:0 0 18px;padding:14px 18px;border-left:3px solid var(--accent);background:var(--accent-soft);border-radius:0 12px 12px 0}
.expert__body blockquote p{margin:0}
.expert__tldr{max-width:760px;margin:0 0 24px;padding:18px 20px;background:var(--bg);border:1px solid var(--line);border-radius:14px}
.expert__tldr b{display:block;font-size:16px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);margin-bottom:12px}
.expert__tldr ul{margin:0;padding:0;list-style:none;display:grid;gap:9px}
.expert__tldr li{position:relative;padding-left:27px;font-size:16px;line-height:1.5}
.expert__tldr li::before{content:"";position:absolute;left:0;top:2px;width:19px;height:19px;border-radius:50%;background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='%232f6fe0' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat}
.expert__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.expert__tag{font-size:16px;color:var(--ink-2);background:var(--bg);border:1px solid var(--line);padding:5px 12px;border-radius:100px}
@media(max-width:560px){.expert{padding:24px 20px}.expert__dates{gap:20px}.expert__body table{font-size:16px}.expert__body th,.expert__body td{padding:7px 9px}}

/* ===================== МОБИЛЬНЫЙ ХЕДЕР ===================== */
.phone-ic{display:none}
@media(max-width:920px){
  .phone-ic{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;flex-shrink:0;box-shadow:var(--shadow-sm);transition:background .2s,transform .12s var(--ease)}
  .phone-ic:active{transform:scale(.93)}
}
@media(max-width:680px){
  :root{--pad:16px}
  .hd__inner{flex-wrap:nowrap;gap:7px;min-height:0;padding-top:12px;padding-bottom:12px}
  /* логотип уступает место номеру: «profi» / «clean» в 2 строки, БЕЗ тире */
  .hd__inner .logo{order:1;font-size:18px;flex-shrink:1;min-width:0}
  .hd__inner .logo__text{white-space:normal;line-height:1.05}
  .hd__inner .logo__hy{display:none}            /* убираем тире после «profi» */
  .hd__inner .logo__text b{display:block}        /* «clean» — с новой строки */
  /* подзаголовок: AIDA вместо SEO-абзаца */
  .hero2__sub--d{display:none}
  .hero2__sub--m{display:block}
  .hd__tools{order:3;gap:7px;min-width:0;flex-shrink:0}
  .burger{order:4;padding:10px 11px;flex-shrink:0}
  /* вместо иконки — телефон цифрами, 16px (правило сайта) */
  .phone-ic{display:none}
  .phone{display:inline-block;font-size:16px;font-weight:700;line-height:1.15;white-space:nowrap;color:var(--ink)}
  /* город переезжает в бургер-меню (см. .mega__tools) — в шапке его нет */
  #langCurrent{display:inline}
}

/* ===================== МОБИЛЬНЫЕ СЛАЙДЕРЫ (услуги, виды, этапы, преимущества) ===================== */
@media(max-width:680px){
  .m-slider{display:flex !important;grid-template-columns:none !important;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;-ms-overflow-style:none;scrollbar-width:none;padding-bottom:10px}
  .m-slider::-webkit-scrollbar{display:none}
  .m-slider>*{scroll-snap-align:start;flex:0 0 100%;min-width:0}
  .m-slider.steps2{counter-reset:none}
  .m-ctrls{margin-top:20px}
}

/* ===================== ОТЗЫВЫ: свайп-табы на мобиле ===================== */
@media(max-width:680px){
  .rfilter{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:none;scrollbar-width:none;margin-left:calc(var(--pad)*-1);margin-right:calc(var(--pad)*-1);padding-left:var(--pad);padding-right:var(--pad)}
  .rfilter::-webkit-scrollbar{display:none}
  .rfilter__b{flex:0 0 auto;white-space:nowrap}
}

/* ===================== МОБАЙЛ: город + язык в одну строку, поиск под ними (бургер-меню) ===================== */
.mega__tools{display:none}
@media(max-width:680px){
  /* подстраховка: пока JS не перенёс — прячем в шапке поиск, город и язык */
  .hd__inner > .search,.hd__tools .city,.hd__tools .lang{display:none}
  .mega__tools{display:flex;flex-direction:column;gap:10px;margin:4px 0 18px}
  /* строка: город слева, язык справа — равные половины */
  .mega__tools-row{display:flex;gap:10px;align-items:stretch}
  .mega__tools-row .city,.mega__tools-row .lang{flex:1 1 0;min-width:0;position:relative}
  .mega__tools .city #cityCurrent,.mega__tools .city .caret,.mega__tools .lang span,.mega__tools .lang .caret{display:inline}
  .mega__tools .city__btn,.mega__tools .lang__btn{width:100%;justify-content:center;gap:8px;background:var(--card);border:1px solid var(--line);padding:12px 16px;border-radius:14px;white-space:nowrap}
  /* поиск на всю ширину под строкой */
  .mega__tools .search{display:flex;max-width:none;width:100%;height:50px;border-radius:14px}
  /* поп-апы выбора открываются внутри своей половины, не уезжая за край */
  .mega__tools .city .pop{left:0;right:auto;transform:none;min-width:170px}
  .mega__tools .lang .pop{right:0;left:auto;min-width:170px}
}

/* ===================== МОБАЙЛ: минимальный размер шрифта 16px ===================== */
@media(max-width:680px){
  .btn,.burger,.search__in,.city__btn,.lang__btn,.pop button,.pop a,.pop .soon,
  .mega__title,.mega__cat--tech,.mega__sub a,
  .hero2__badge,.hero2__stats span,.hero2__pay li,.quick a,
  .sec__eyebrow,.sec__link,.sec__info,.sec__note,.sec__rate,.sec__rate b,
  .scard__d,.scard__p,.step2__d,.step2__meta,.adv__num small,.adv__d,
  .case__cat,.case__meta dt,.case__meta dd,.case__geo,.ba__tag,
  .rsum__score span,.bar,.rsum__src b,.rsum__src span,.rsum__src-name,.rsum__src-val,
  .rfilter__b,
  .rv__id b,.rv__meta,.rv__stars,.rv__svc,.rv__text,.rv__reply-head b,.rv__reply p,.rv__like,.rv__reply-btn,.rv__replyform input,
  .team__lead,.tmember figcaption b,.tmember__role,.tmember__exp,.tmember__tag,.tmember__count,
  .post__ex,.post__meta,.post__cat,.utype__badge,.utype__p,.utype__d,.utype__list li,.utype__time,
  .modal__sub,.rform textarea,.rform input[type=file],.rform__ok,
  .flow__i p,.usp__i b,.usp__i span,.price__n,.price__m,
  .rev__top b,.rev__top small,.rev blockquote,.chips a,.areas__more,
  .faq__i div,.lead__points li,.fld label,.fld input,.fld select,.lead__note,.lead__ok,
  .ft,.ft__about,.ft__nap,.ft__nav h3,.ft__nav a,.ft__bottom,.soon em,
  .calc__lead,.calc__label,.calc__opt,.calc__dd-btn,.calc__select,.calc__dd-sum,.calcmodal__sum,.calc__add,.calc__add b,.calc__rlabel,.calc__rmeta,.calc__incl li,.calc__fine,
  .expert__role,.expert__dates dt,.expert__dates dd,.expert__body,.expert__body li{
    font-size:16px !important;
  }
}

/* ===================== МОБАЙЛ v2: доработки дизайна ===================== */
@media(max-width:680px){
  /* — счётчик вместо россыпи точек, когда карточек много (каталог услуг) — */
  .slider__dots--count{gap:0}
  .slider__counter{font-size:16px;font-weight:600;color:var(--ink-3);min-width:54px;text-align:center}
  .slider__counter b{color:var(--accent)}

  /* — услуги: показываем все карточки в слайдере, убираем кнопки «показать ещё» / «весь каталог» — */
  #svcGrid.m-slider .scard.is-hidden{display:flex}
  #services .sec__more,#svcToggleTop{display:none}

  /* — HERO: «фото-панель» формата 3:2; девушка уменьшена до 80% (отдалена), по центру, небольшой отступ сверху — */
  .hero2__media{max-width:none;width:100%;aspect-ratio:3/2;height:auto;max-height:none;margin:2px 0 0;border-radius:22px;overflow:hidden;background:linear-gradient(165deg,#fff 0%,var(--accent-soft) 100%);align-items:flex-start;justify-content:center}
  .hero2__media::before{display:none}
  .hero2__img{max-width:none;width:80%;height:auto;max-height:none;margin-top:3%;object-fit:contain}

  /* — ВИДЫ УБОРКИ: цена аккуратной плашкой под заголовком — */
  .utype__head{flex-direction:column;align-items:flex-start;gap:9px;margin-bottom:12px}
  .utype__p{background:var(--accent-soft);padding:6px 14px;border-radius:100px;line-height:1.1}

  /* — КОМАНДА: фото ниже, карточка не такая высокая — */
  .tmember__ph{aspect-ratio:10/9}
  .tmember__ph img{object-position:center 12%}

  /* — БУРГЕР-МЕНЮ: современный, «дышащий» вид — */
  .mega__panel{padding-bottom:6px}
  .mega__head{position:sticky;top:0;z-index:3;background:var(--bg);padding-block:14px}
  .mega__logo{font-size:20px}
  .mega__tools{margin:8px 0 4px}
  .mega__body{grid-template-columns:1fr;gap:0;padding-block:4px}
  .mega__col{padding:18px 0;border-top:1px solid var(--line)}
  .mega__col:first-child{border-top:0}
  .mega__cat{font-size:18px;margin-bottom:4px;font-weight:800;letter-spacing:-.01em}
  .mega__sub{gap:0}
  .mega__sub a{display:flex;align-items:center;justify-content:space-between;padding:13px 2px;color:var(--ink-2);border-bottom:1px solid var(--line)}
  .mega__sub li:last-child a{border-bottom:0}
  .mega__sub a::after{content:"";flex-shrink:0;width:7px;height:7px;margin-left:12px;border-top:2px solid var(--ink-3);border-right:2px solid var(--ink-3);transform:rotate(45deg);opacity:.45}
  .mega__sub--tech{columns:1}
  .mega__sub--tech li{margin-bottom:0}
  .mega__cat--tech{font-size:16px}
  .mega__foot{flex-direction:column;align-items:stretch;gap:12px;padding-block:20px}
  .mega__foot .btn{width:100%;padding-block:15px}
  .mega__phone{text-align:center;font-size:19px}
}

/* ===================== СКОЛЬЗЯЩИЕ ТОЧКИ (мобильные слайдеры с большим числом карточек) ===================== */
.m-ctrls .slider__dots{overflow:hidden;justify-content:flex-start;flex-wrap:nowrap}
.m-ctrls .slider__dotrail{display:flex;align-items:center;gap:8px;transition:transform .28s var(--ease)}
.m-ctrls .slider__dot{flex:0 0 auto;transform-origin:center;transition:background .2s,transform .25s var(--ease),width .25s var(--ease),opacity .25s var(--ease)}

/* ===================== КНОПКА WHATSAPP ПОД БЛОКАМИ ===================== */
.wa-cta{display:flex;justify-content:center;margin:-18px auto 26px}
.wa-btn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;font-weight:700;font-size:16px;padding:13px 26px;border-radius:100px;box-shadow:0 12px 26px -12px rgba(47,111,224,.7);transition:background .2s,transform .12s var(--ease)}
.wa-btn:hover{background:var(--accent-d)}
.wa-btn:active{transform:scale(.97)}
.wa-btn svg{flex-shrink:0}

/* ===================== РЕЙТИНГ В КАРТОЧКЕ СПЕЦИАЛИСТА ===================== */
.tmember__rating{display:inline-flex;align-items:center;gap:5px;margin-top:6px;font-size:16px;color:var(--ink-2)}
.tmember__rating svg{flex-shrink:0}
.tmember__rating b{font-weight:700;color:var(--ink)}
.tmember__rating small{font-size:16px;color:var(--ink-3)}

@media(max-width:680px){.tmember__rating,.tmember__rating small{font-size:16px}}

/* ===== Хлебные крошки (single-service) ===== */
.crumbs{margin:18px auto 6px}
.crumbs__list{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:0;font-size:16px;color:#6b7280}
.crumbs__i{display:flex;align-items:center;gap:6px}
.crumbs__i:not(:last-child)::after{content:"›";color:#9aa3b2}
.crumbs__i a{color:#2f6fe0;text-decoration:none}
.crumbs__i a:hover{text-decoration:underline}
.crumbs__i [aria-current="page"]{color:#2a3142}
.service .expert__body{margin-top:8px}

/* ===== Контакты (page-kontakty) ===== */
.contacts{display:grid;gap:14px;margin:20px 0;max-width:520px}
.contacts>div{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid #e6ebf3}
.contacts dt{color:#6b7280;font-size:16px}
.contacts dd{margin:0;font-weight:600;font-size:16px}
.contacts__note{color:#6b7280;font-size:16px;margin-top:8px}

/* ===== Карты на контактах (CSS-табы, без JS) ===== */
.maps{margin:22px 0}
.maps__rad{position:absolute;opacity:0;pointer-events:none}
.maps__tabs{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.maps__tab{cursor:pointer;padding:10px 16px;border:1px solid #d7deea;border-radius:10px;font-size:16px;font-weight:600;color:#2a3142;background:#fff;user-select:none}
.maps__tab:hover{border-color:#2f6fe0;color:#2f6fe0}
#cpmap-ya:checked~.maps__tabs label[for="cpmap-ya"],
#cpmap-gg:checked~.maps__tabs label[for="cpmap-gg"]{background:#2f6fe0;border-color:#2f6fe0;color:#fff}
.maps__panel{display:none;border-radius:14px;overflow:hidden;border:1px solid #e6ebf3}
.maps__panel iframe{display:block;width:100%;border:0}
#cpmap-ya:checked~.maps__panel--ya{display:block}
#cpmap-gg:checked~.maps__panel--gg{display:block}
.maps__links{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

/* ===== Результаты поиска ===== */
.search--page{display:flex;gap:10px;margin:8px 0 22px;max-width:640px}
.search--page .search__in{flex:1;padding:12px 14px;border:1px solid #d7deea;border-radius:10px;font-size:16px}
.srch{display:grid;gap:10px;margin-top:8px}
.srch__row{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid #e6ebf3;border-radius:12px;background:#fff;text-decoration:none;color:inherit}
.srch__row:hover{border-color:#2f6fe0;box-shadow:0 8px 30px -22px rgba(42,49,66,.4)}
.srch__tag{flex:none;font-size:16px;font-weight:600;color:#2f6fe0;background:#eef3fb;padding:4px 10px;border-radius:8px}
.srch__main{flex:1;display:flex;flex-direction:column;gap:3px}
.srch__t{font-size:18px;font-weight:700;color:#2a3142}
.srch__d{font-size:16px;color:#6b7280}
.srch__go{flex:none;color:#9aa3b2}
.srch__empty{font-size:18px;margin:16px 0}
.srch__sugg{display:flex;gap:10px;flex-wrap:wrap}

/* ===== 404 ===== */
.notfound__lead{font-size:18px;color:#4a5260;margin:8px 0 20px;max-width:560px}

/* ===== Cookie-баннер согласия ===== */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:1000;display:flex;justify-content:center;pointer-events:none}
.cookie__box{pointer-events:auto;max-width:760px;width:100%;background:#fff;border:1px solid #e6ebf3;border-radius:16px;box-shadow:0 20px 60px -24px rgba(42,49,66,.5);padding:18px 20px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cookie__text{flex:1;min-width:240px;font-size:16px;color:#4a5260;margin:0}
.cookie__text a{color:#2f6fe0}
.cookie__btns{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:560px){.cookie__box{flex-direction:column;align-items:stretch}.cookie__btns .btn{flex:1}}

/* ===== Сервис-калькулятор (страницы услуг) ===== */
.scalc__items{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.scalc__row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--line,#e2e8f3);border-radius:14px;background:#fff}
.scalc__info{display:flex;flex-direction:column;gap:2px}
.scalc__name{font-weight:600}
.scalc__price{font-size:16px;color:var(--ink-3,#8a93a6)}
.scalc__stepper{display:flex;align-items:center;gap:6px}
.scalc__stepper input,.scalc__qtywrap input{width:64px;text-align:center;padding:8px;border:1px solid var(--line,#e2e8f3);border-radius:10px;font:inherit}
.scalc__step{width:34px;height:34px;border:1px solid var(--line,#e2e8f3);border-radius:10px;background:#f4f8ff;font-size:18px;line-height:1;cursor:pointer}
.scalc__step:active{transform:scale(.94)}
.scalc__adds{display:grid;grid-template-columns:1fr;gap:6px}
@media(min-width:680px){.scalc__adds{grid-template-columns:1fr 1fr}}

/* ===== Сервис-калькулятор: «Тип» — выпадающий список, «Дополнительно» — раскрывашка (компактно на мобиле) ===== */
.calc__selwrap{position:relative}
.calc__select{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:100%;background:var(--bg);border:1.5px solid var(--line);border-radius:14px;padding:13px 44px 13px 16px;font:inherit;font-size:16px;font-weight:600;color:var(--ink);cursor:pointer;transition:border-color .18s,background .18s}
.calc__select:hover{border-color:var(--accent)}
.calc__select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.calc__selcar{position:absolute;right:18px;top:50%;width:9px;height:9px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.calc__dd{border:1.5px solid var(--line);border-radius:14px;background:var(--bg);overflow:hidden}
.calc__dd[open]{border-color:var(--accent)}
.calc__dd-sum{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 16px;font-size:16px;font-weight:600;color:var(--ink);cursor:pointer;list-style:none}
.calc__dd-sum::-webkit-details-marker{display:none}
.calc__dd-sum::marker{content:""}
.calc__dd-car{flex-shrink:0;width:9px;height:9px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:translateY(-2px) rotate(45deg);transition:transform .2s}
.calc__dd[open] .calc__dd-car{transform:translateY(2px) rotate(-135deg)}
.calc__dd-list{display:grid;gap:6px;padding:0 12px 12px}
@media(min-width:680px){.calc__dd-list{grid-template-columns:1fr 1fr}}

/* ===== До/после (страницы услуг) ===== */
.ba2{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:720px){.ba2{grid-template-columns:1fr 1fr 1fr}}
.ba2__card{border:1px solid var(--line,#e2e8f3);border-radius:18px;overflow:hidden;background:#fff}
.ba2__imgs{position:relative;aspect-ratio:3/2;overflow:hidden}
.ba2__imgs img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba2__after{clip-path:inset(0 0 0 var(--rev,50%))}
.ba2__range{position:absolute;left:0;right:0;bottom:8px;width:92%;margin:0 4%;z-index:3}
.ba2__tag{position:absolute;top:8px;z-index:2;font-size:16px;font-weight:700;padding:3px 8px;border-radius:999px;background:rgba(0,0,0,.55);color:#fff}
.ba2__tag--b{left:8px}.ba2__tag--a{right:8px;background:var(--accent,#2f6fe0)}
.ba2__body{padding:12px 14px}
.ba2__t{font-weight:700;margin:0 0 4px}
.ba2__d{font-size:16px;color:var(--ink-2,#56607a);margin:0}

/* ===== Отзывы услуги: инициалы-аватар + распределение ===== */
.rv__av--ini{display:flex;align-items:center;justify-content:center;background:var(--accent,#2f6fe0);color:#fff;font-weight:700;font-size:18px}
.rsum__bar{display:flex;align-items:center;gap:8px;margin:3px 0;font-size:16px}
.rsum__bar-n{width:24px;color:var(--ink-3,#8a93a6)}
.rsum__bar-track{flex:1;height:8px;background:#eef3fb;border-radius:999px;overflow:hidden}
.rsum__bar-fill{display:block;height:100%;background:#f5a623;border-radius:999px}
.rsum__bar-v{width:22px;text-align:right;color:var(--ink-3,#8a93a6)}

/* ===== Этапы услуги 4×2 ===== */
.steps4{align-items:stretch}
.step4{border:1px solid var(--line,#e2e8f3);border-radius:16px;padding:16px;background:#fff;display:flex;flex-direction:column;gap:6px}
.step4__n{font-family:Unbounded,Inter,sans-serif;font-weight:700;color:var(--accent,#2f6fe0);font-size:20px}
.step4__t{margin:0;font-size:19px;font-weight:700}
.step4__d{margin:0;font-size:16px;color:var(--ink-2,#56607a);line-height:1.5}
.step4__meta{margin-top:auto;font-size:16px;color:var(--ink-3,#8a93a6);background:#f4f8ff;border-radius:999px;padding:3px 10px;align-self:flex-start}

/* ===== Скрытые отзывы ===== */
.rv--hidden{display:none}

/* ===== Блок «Что входит в виды уборки» (block-cleaning-types) ===== */
#cleaning-types .ctypes{display:grid;gap:18px}
#cleaning-types .ctypes--4{grid-template-columns:repeat(2,1fr)}
#cleaning-types .ctypes--3{grid-template-columns:repeat(3,1fr)}
#cleaning-types .ctypes--2{grid-template-columns:repeat(2,1fr)}
#cleaning-types .ctypes--1{grid-template-columns:1fr;max-width:880px}
#cleaning-types .ctype{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;box-shadow:var(--shadow-sm)}
#cleaning-types .ctype__head{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
#cleaning-types .ctype__t{font-family:var(--font-head);font-size:19px;line-height:1.25;margin:0;color:var(--ink)}
#cleaning-types .ctype__sub{font-size:16px;color:#5b6b7f;margin:.35em 0 0}
#cleaning-types .ctype__list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
#cleaning-types .ctype__list li{position:relative;padding-left:30px;font-size:16px;line-height:1.45;color:var(--ink)}
#cleaning-types .ctype__list li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:var(--accent-soft)}
#cleaning-types .ctype__list li::after{content:"";position:absolute;left:6px;top:7px;width:8px;height:5px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}
/* одиночный вид — чек-лист в 2 колонки на десктопе */
#cleaning-types .ctypes--1 .ctype__list{grid-template-columns:repeat(2,1fr);gap:10px 28px}
@media(max-width:860px){#cleaning-types .ctypes--3{grid-template-columns:1fr}}
@media(max-width:680px){#cleaning-types .ctypes--4,#cleaning-types .ctypes--2,#cleaning-types .ctypes--1 .ctype__list{grid-template-columns:1fr}}

/* ===================== ТЕХ-СТРАНИЦЫ (о компании / гарантии / контакты) ===================== */
.about__stats{grid-template-columns:repeat(4,1fr);gap:18px;margin-top:26px}
.about__stats li{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px}
.about__stats b{font-size:26px}
/* гарантии — шаги приёмки */
.gsteps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.gstep{display:flex;gap:16px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px}
.gstep__n{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:var(--accent);color:#fff;font-weight:800;font-size:18px}
.gstep__t{font-size:18px;font-weight:700;margin:2px 0 6px}
.gstep__d{font-size:16px;color:var(--ink-2);line-height:1.55}
/* гарантии — что покрывает / не покрывает */
.gscope{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.gscope__col{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.gscope__col--yes{border-color:rgba(46,160,93,.4)}
.gscope__col--no{border-color:rgba(224,85,107,.35)}
.gscope__h{font-size:18px;font-weight:700;margin:0 0 14px;display:flex;align-items:center;gap:9px}
.gscope__h::before{content:"";width:22px;height:22px;border-radius:50%;flex-shrink:0}
.gscope__col--yes .gscope__h::before{background:rgba(46,160,93,.16) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m5 13 4 4 10-10' fill='none' stroke='%232ea05d' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/15px no-repeat}
.gscope__col--no .gscope__h::before{background:rgba(224,85,107,.16) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6 6 18 18M18 6 6 18' fill='none' stroke='%23e0556b' stroke-width='2.4' stroke-linecap='round'/%3E%3C/svg%3E") center/13px no-repeat}
.gscope__col ul{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.gscope__col li{position:relative;padding-left:26px;font-size:16px;color:var(--ink-2);line-height:1.55}
.gscope__col li::before{content:"";position:absolute;left:4px;top:8px;width:8px;height:8px;border-radius:50%;background:var(--ink-3)}
.gcta{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
/* контакты — нижние ссылки */
.kontakty__links{display:flex;flex-wrap:wrap;gap:10px 22px;margin:26px 0 0}
.kontakty__links a{font-size:16px;font-weight:600;color:var(--accent)}
.kontakty__links a:hover{text-decoration:underline}
@media(max-width:860px){.about__stats{grid-template-columns:repeat(2,1fr)}.gsteps,.gscope{grid-template-columns:1fr}}

/* ===================== ЗАГОЛОВОК-АНКОР В КАРТОЧКАХ (stretched-link) ===================== */
/* Чистый SEO-анкор = текст заголовка; кликабельна вся карточка через ::after. */
.scard__t a,.price__link{color:inherit;text-decoration:none}
.scard__t a::after,.price__link::after{content:"";position:absolute;inset:0;z-index:1}
.scard__t a:hover{color:var(--accent)}
.price__row{position:relative}
.price__link:hover{color:var(--accent)}

/* ===================== БЛОГ — статья (/blog/{slug}/) ===================== */
/* Тело статьи переиспользует .expert__body. H2-секции — крупный заголовок с верхней линией. */
.expert__body h2{font-family:var(--font-head);font-size:23px;font-weight:700;letter-spacing:-.02em;line-height:1.25;margin:34px 0 13px;padding-top:24px;border-top:1px solid var(--line)}
.expert__body h2:first-child{padding-top:0;border-top:0;margin-top:4px}
.blogpost__hero{margin:0 0 22px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;background:var(--bg)}
.blogpost__hero img{width:100%;height:100%;object-fit:cover;display:block}
.blogpost__faq{margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.blogpost__faq-h{font-family:var(--font-head);font-size:23px;font-weight:700;letter-spacing:-.02em;margin:0 0 14px}
@media(max-width:600px){.expert__body h2{font-size:20px}.blogpost__faq-h{font-size:20px}}
