/* =====================================================================
   ПМК Парк — брендовый перестиль поверх Aspro Allcorp2 (шаблон karneev-prod)
   Эталон: брендбук. Подключается ТОЛЬКО для karneev-prod (init.php).
   Перестиль существующей структуры Aspro, не переверстка.
   Токены --pmk-* приходят из design-system.css (грузится раньше).
   ===================================================================== */

/* ============ SCOPED-RESET для кастомных блоков (меньше боёв с глобальным CSS Aspro) ============
   Гасит самые «протекающие» правила темы ВНУТРИ наших блоков (любые .pmk-*: шапка,
   подвал, .pmk-service, .pmk-project и т.д.). Контент-HTML (теория/FAQ/описания) НЕ трогаем
   (там нужны штатные list-style/заголовки). Идёт ПЕРВЫМ — конкретные правила ниже перекрывают. */
.pmk-brand [class^="pmk-"], .pmk-brand [class*=" pmk-"] { box-sizing: border-box; }
/* наши заголовки (с pmk-классом) берут цвет КОНТЕКСТА: тёмная плашка → белый, светлая
   секция → тёмный. Снимает повторяющийся бой «тёмный h2 на тёмном фоне» без per-block !important. */
.pmk-brand h1[class*="pmk-"], .pmk-brand h2[class*="pmk-"],
.pmk-brand h3[class*="pmk-"], .pmk-brand h4[class*="pmk-"] { color: inherit; }

/* --------------------------- Шрифт бренда ---------------------------- */
body,
.maxwidth-theme,
.wrapper_inner,
.top-block,
.menu-row .menu a,
.bottom-menu,
.btn, .button, input, button, select, textarea,
h1, h2, h3, h4, h5, h6,
.footer, footer {
  font-family: var(--pmk-font) !important;
}

/* ----------------------- Тёмная utility-строка ----------------------- */
.top-block {
  background: var(--pmk-ink) !important;
  border-bottom: none !important;
}
/* у Aspro внутренний контейнер .maxwidth-theme имеет светлый фон и
   перекрывает тёмный .top-block — делаем его прозрачным (только в шапке-строке) */
.top-block > .maxwidth-theme,
.top-block .maxwidth-theme {
  background: transparent !important;
}
.top-block,
.top-block .twosmallfont,
.top-block .address,
.top-block .more_phone,
.top-block a,
.top-block .callback-block {
  color: #cfd5db !important;
}
.top-block a:hover,
.top-block .callback-block:hover {
  color: #fff !important;
}
/* телефон — белый, акцент-иконка телефона — лайм */
.top-block .phone a,
.top-block .phone .value,
.top-block .phone-block .phone {
  color: #fff !important;
  font-weight: 700 !important;
}
.top-block .svg .cls-1 { fill: #aab2bb !important; }
.top-block .svg-inline-phone.colored .cls-1 { fill: var(--pmk-accent) !important; }
.top-block .social-icons a:hover .svg .cls-1 { fill: #fff !important; }
/* выпадашка телефонов на тёмном фоне — оставляем светлой плашкой */
.top-block .phone .dropdown,
.top-block .phone .dropdown .wrap {
  background: var(--pmk-surface) !important;
  color: var(--pmk-ink) !important;
}
.top-block .phone .dropdown .more_phone,
.top-block .phone .dropdown a { color: var(--pmk-ink) !important; }

/* ------------------------------ Кнопки ------------------------------- */
/* primary-CTA Aspro -> лайм + тёмный текст, скругление бренда.
   Исключаем поиск и иконочные кнопки. */
.btn.btn-default:not(.btn-search):not(.search-button):not([class*="search"]):not(.btn-link),
a.btn-default.button-default,
input[type="submit"].btn-default {
  background: var(--pmk-accent) !important;
  border-color: var(--pmk-accent) !important;
  color: var(--pmk-accent-ink) !important;
  border-radius: var(--pmk-radius-btn) !important;
  font-weight: 700 !important;
}
.btn.btn-default:not(.btn-search):hover {
  box-shadow: 0 8px 20px rgba(200,240,0,.35) !important;
  color: var(--pmk-accent-ink) !important;
}

/* === Компактные пропорции шапки (по эталону header-footer-pmkpark.html) === */
/* высоту основного ряда у Aspro задаёт line-height логотипа -> через неё ужимаем */
.pmk-brand { --pmk-header-row: 74px; }      /* основной ряд 70–76px */
.pmk-brand .header_5 .logo-block .logo {
  line-height: var(--pmk-header-row) !important;
  height: var(--pmk-header-row) !important;
}
.pmk-brand .header_5 .logo img,
.pmk-brand .header_5 .logo a img {
  height: 30px !important;                   /* логотип 28–32px */
  width: auto !important;
}
/* меню-ряд и его дети у Aspro тоже держат 100px — ужимаем до высоты строки */
.pmk-brand .header_5 .menu-row,
.pmk-brand .header_5 .menu-only,
.pmk-brand .header_5 .mega-menu,
.pmk-brand .header_5 .mega-menu > .table-menu,
.pmk-brand .header_5 .right-icons,
.pmk-brand .header_5 .right-icons .inner-table-block {
  height: var(--pmk-header-row) !important;
}
/* утилити-строка компактнее (36–40px) */
.pmk-brand .pmk-header .top-block { padding-top: 0 !important; padding-bottom: 0 !important; }
.pmk-brand .pmk-header .top-block .maxwidth-theme { line-height: 38px !important; padding-top: 0 !important; padding-bottom: 0 !important; }
/* соцсети из шапки убрать (по ТЗ — только в подвале) */
.pmk-brand .pmk-header .top-block .social,
.pmk-brand .mobileheader-v1 .social { display: none !important; }

/* === Утилити-строка по макету: ЛЕВО город+адрес, ПРАВО телефон+почта === */
.pmk-brand .pmk-header .top-block .pmk-utility {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 44px; /* высота тёмной строки — контент по центру по вертикали */
  /* совпадение краёв с контентом (как .pmk-header__row): 24px + 16px gutter */
  padding-left: 40px !important; padding-right: 40px !important;
}
/* .pmk-utility = Aspro .maxwidth-theme с clearfix ::before/::after (display:table).
   Во флексе они блокифицируются в флекс-айтемы и занимают крайние слоты
   space-between → адрес/почта стягиваются к центру (3 равных зазора). Убираем. */
.pmk-brand .pmk-header .top-block .pmk-utility::before,
.pmk-brand .pmk-header .top-block .pmk-utility::after { content: none !important; display: none !important; }
.pmk-brand .pmk-utility__left { display: flex; align-items: center; gap: 18px; }
.pmk-brand .pmk-utility__right { display: flex; align-items: center; gap: 18px; }
.pmk-brand .pmk-utility .inline-block { display: inline-flex !important; align-items: center; }
/* убрать лишний отступ после шеврона выпадашки телефона */
/* padding-right резервирует место под абсолютный шеврон выпадашки (svg 5px у
   правого края). Был занулён → стрелка наезжала на последнюю цифру номера. */
.pmk-brand .pmk-utility__phone .phone.with_dropdown { margin: 0 !important; padding-right: 18px !important; }
/* телефон и почта справа — текст белый 13/700, симметрично; иконки лайм */
.pmk-brand .top-block .pmk-utility__right a,
.pmk-brand .top-block .pmk-utility__phone .value,
.pmk-brand .top-block .pmk-utility__phone .phone,
.pmk-brand .top-block .pmk-utility__email .email a {
  color: #fff !important; font-weight: 700 !important; font-size: 13px !important;
}
/* иконки телефона (.cls-1) и почты (.ecls-1) — одного лаймового цвета */
.pmk-brand .top-block .pmk-utility__right .svg .cls-1,
.pmk-brand .top-block .pmk-utility__right .svg .ecls-1,
.pmk-brand .top-block .pmk-utility__email .svg .ecls-1 {
  fill: var(--pmk-accent) !important; opacity: 1 !important;
}
.pmk-brand .top-block .pmk-utility__email { display: flex; align-items: center; line-height: 1; }
/* телефон и город (.pmk-geo) — центрировать кнопку по вертикали (была прижата к верху → на 2px выше почты) */
.pmk-brand .top-block .pmk-utility__phone, .pmk-brand .top-block .pmk-utility__left .pmk-geo { display: flex; align-items: center; }
.pmk-brand .top-block .pmk-utility__email .email { display: inline-flex !important; align-items: center; gap: 7px; cursor: pointer; line-height: 1 !important; }
.pmk-brand .top-block .pmk-utility__email .email a, .pmk-brand .top-block .pmk-utility__email .value { line-height: 1 !important; }
/* город+адрес слева — светло-серые, пин/шеврон лайм */
.pmk-brand .top-block .pmk-utility__left,
.pmk-brand .top-block .pmk-utility__left a,
.pmk-brand .top-block .pmk-utility__left .address { color: #cfd5db !important; font-size: 13px !important; }
.pmk-brand .top-block .pmk-utility__left .svg .cls-1 { fill: var(--pmk-accent) !important; }
.pmk-brand .top-block .pmk-utility__addr .address { display: inline-flex !important; align-items: center; gap: 7px; font-weight: 600 !important; }
/* подтверждение копирования e-mail — подмена текста в том же узле (без сдвигов) */
.pmk-brand .pmk-copied-on { color: var(--pmk-accent) !important; }
.pmk-brand .pmk-copied { color: var(--pmk-accent) !important; font-weight: 700; font-size: 13px; margin-left: 8px; white-space: nowrap; }

/* === Селектор города (визуальный задел под мультирегиональность) === */
.pmk-brand .pmk-geo { position: relative; }
.pmk-brand .pmk-geo__btn {
  display: inline-flex; align-items: center; gap: 7px;
  background: none; border: none; cursor: pointer; padding: 0;
  font: 700 13px/1 var(--pmk-font); color: #cfd5db;
}
.pmk-brand .pmk-geo__pin { color: var(--pmk-accent); flex: 0 0 auto; }
.pmk-brand .pmk-geo__label { color: #8b95a1; font-weight: 600; }
.pmk-brand .pmk-geo__current { color: #fff; }
/* адрес как единый триггер выпадашки городов */
.pmk-brand .pmk-uaddr__text { color: #fff; font-weight: 600; white-space: nowrap; }
.pmk-brand .pmk-uaddr__text * { color: #fff !important; }
.pmk-brand .pmk-geo__chev {
  width: 7px; height: 7px; border-right: 2px solid #8b95a1; border-bottom: 2px solid #8b95a1;
  transform: rotate(45deg); margin-left: 2px; margin-top: -3px; transition: transform .15s;
}
.pmk-brand .pmk-geo.is-open .pmk-geo__chev { transform: rotate(-135deg); margin-top: 1px; }
.pmk-brand .pmk-geo__menu {
  position: absolute; top: 100%; left: 0; margin-top: 10px; z-index: 60;
  background: var(--pmk-surface); color: var(--pmk-ink);
  border-radius: 12px; box-shadow: 0 12px 34px rgba(0,0,0,.28);
  padding: 8px; min-width: 230px;
}
.pmk-brand .pmk-geo__menu[hidden] { display: none; }
.pmk-brand .pmk-geo__item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 9px 12px; border-radius: 8px; text-decoration: none;
  font: 600 14px/1.2 var(--pmk-font); color: var(--pmk-ink);
}
.pmk-brand .pmk-geo__item.is-active { background: var(--pmk-bg); }
.pmk-brand .pmk-geo__item.is-soon { color: #9aa3ad; cursor: default; }
.pmk-brand .pmk-geo__item.is-soon i { font-style: normal; font-size: 11px; color: #b8c0c8; }

/* ============== Чистая шапка header_11 (.pmk-header) — основной ряд + меню ============== */
.pmk-brand .pmk-header__main { background: var(--pmk-surface); border-bottom: 1px solid var(--pmk-line); }
.pmk-brand .pmk-header__row {
  display: flex; align-items: center;
  height: var(--pmk-header-row, 74px);
  /* контент страниц сидит в .maxwidth-theme > .col-md-12 (gutter 16px). Шапка —
     прямо в .maxwidth-theme (padding 24px). +16px => левый/правый край совпадают. */
  padding-left: 40px !important; padding-right: 40px !important;
}
.pmk-brand .pmk-header__logo { flex: 0 0 auto; margin-right: 40px; display: inline-flex; align-items: center; }
.pmk-brand .pmk-header__logo a, .pmk-brand .pmk-header__logo { line-height: 1 !important; }
/* лого крупнее под рендер прототипа (~131px шириной). Картинка Aspro «тоньше»
   с внутр. полями, поэтому h=36 даёт ширину ~128 ≈ макет. margin-right 40 (макет). */
.pmk-brand .pmk-header__logo img { height: 36px !important; width: auto !important; display: block; }
.pmk-brand .pmk-header__nav { flex: 0 1 auto; display: flex; align-items: center; height: var(--pmk-header-row, 74px); }
.pmk-brand .pmk-header__actions { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.pmk-brand .pmk-header__search { background: none; border: none; cursor: pointer; padding: 6px; display: inline-flex; align-items: center; }
.pmk-brand .pmk-header__search .svg .cls-1 { fill: var(--pmk-ink) !important; }
.pmk-brand .pmk-header__actions .pmk-header-cta { padding: 12px 22px !important; white-space: nowrap; line-height: 1 !important; }

/* меню .pmk-nav — своё, без слайсера. Высота всей цепочки = высота ряда,
   align-items:center на каждом уровне → центр пунктов на оси логотипа (не верх). */
.pmk-brand .pmk-nav { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 28px; height: var(--pmk-header-row, 74px); }
/* margin:0 — у Aspro li есть margin-bottom:8px (margin-box центрируется → текст
   выше оси на 4px). padding:0 — у Aspro li есть padding-left:20px, из-за него
   реальный зазор пунктов = gap+20 (≈46px), меню разрежено. Сбрасываем оба. */
.pmk-brand .pmk-nav__item { position: relative; display: flex; align-items: center; height: 100%; margin: 0 !important; padding: 0 !important; }
.pmk-brand .pmk-nav__link {
  display: inline-flex; align-items: center; gap: 6px;
  height: var(--pmk-header-row, 74px);
  font: 600 15px/1 var(--pmk-font); color: #2c333b; text-decoration: none; white-space: nowrap;
}
.pmk-brand .pmk-nav__item:hover > .pmk-nav__link,
.pmk-brand .pmk-nav__item.is-active > .pmk-nav__link { color: var(--pmk-ink); }
.pmk-brand .pmk-nav__caret {
  width: 6px; height: 6px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg); margin-top: -3px; opacity: .5;
}
.pmk-brand .pmk-nav__drop {
  position: absolute; top: 100%; left: 0; min-width: 240px; z-index: 60;
  background: var(--pmk-surface); border-radius: 12px; box-shadow: 0 12px 34px rgba(0,0,0,.16);
  padding: 8px; opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity .15s, transform .15s, visibility .15s;
}
.pmk-brand .pmk-nav__item.has-sub:hover .pmk-nav__drop { opacity: 1; visibility: visible; transform: translateY(0); }
.pmk-brand .pmk-nav__sub { list-style: none; margin: 0; padding: 0; }
.pmk-brand .pmk-nav__sub a {
  display: block; padding: 9px 12px; border-radius: 8px;
  font: 600 14px/1.3 var(--pmk-font); color: var(--pmk-ink); text-decoration: none;
}
.pmk-brand .pmk-nav__sub a:hover { background: var(--pmk-bg); }

/* мега-меню «Каталог» — 2 колонки */
.pmk-brand .pmk-nav__drop--mega { min-width: 500px; }
.pmk-brand .pmk-nav__drop--mega .pmk-nav__sub {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2px 14px;
}

/* === Телефон-выпадашка (десктоп) — чистый список номеров, как на мобайле.
   Ушли от штатного ShowHeaderPhones (двойной шеврон + telegram/max + почта). === */
.pmk-brand .pmk-utility__phone.pmk-geo { position: relative; }
.pmk-brand .pmk-uphone-btn {
  display: inline-flex; align-items: center; gap: 7px;
  background: none; border: 0; cursor: pointer; padding: 0;
  font: 700 13px/1 var(--pmk-font); color: #fff; white-space: nowrap;
}
.pmk-brand .pmk-uphone-ico { color: var(--pmk-accent); flex: 0 0 auto; }
/* шеврон — общий .pmk-geo__chev (как у адреса), виден на тёмном; ничего не добавляем */
/* меню номеров: телефон справа в утилити → выравниваем по правому краю */
.pmk-brand .pmk-uphone-menu { left: auto; right: 0; min-width: 250px; }
.pmk-brand .pmk-header .top-block .pmk-uphone-menu a {
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
  padding: 11px 12px; border-radius: 8px; text-decoration: none;
  font: 700 14px/1.1 var(--pmk-font); color: var(--pmk-ink) !important;
}
.pmk-brand .pmk-header .top-block .pmk-uphone-menu a:hover { background: var(--pmk-bg); }
.pmk-brand .pmk-header .top-block .pmk-uphone-menu a i {
  font-style: normal; font-size: 11px; font-weight: 700; color: #9aa3ad;
  text-transform: uppercase; letter-spacing: .03em;
}

/* === Основной ряд: единая ось + группировка [лого][меню] … [поиск][CTA] === */
.pmk-brand .header_5 .logo-row > .maxwidth-theme {
  display: flex !important;
  align-items: center !important;        /* всё на одной горизонтальной линии */
}
.pmk-brand .header_5 .logo-block {
  width: auto !important; flex: 0 0 auto !important; float: none !important;
  margin-right: 30px !important;
}
.pmk-brand .header_5 .menu-row {
  width: auto !important; flex: 1 1 auto !important; float: none !important;
  display: flex !important; align-items: center !important;
}
/* меню — группой слева, по содержимому (не растягивать). Слайсер отключён в разметке. */
.pmk-brand .header_5 .menu-only { order: 1; flex: 0 1 auto !important; }
.pmk-brand .header_5 .mega-menu > .table-menu { width: auto !important; }
.pmk-brand .header_5 .mega-menu > .table-menu > li { float: none !important; padding: 0 13px !important; }
.pmk-brand .header_5 .mega-menu > .table-menu > li:first-child { padding-left: 0 !important; }
.pmk-brand .header_5 .right-icons {
  order: 2; margin-left: auto !important; float: none !important; width: auto !important;
  display: flex !important; align-items: center !important; gap: 10px;
}
.pmk-brand .header_5 .right-icons .pull-right { float: none !important; }

/* CTA «Получить расчёт» — flex-элемент, центрируется родителем .right-icons */
.pmk-brand .menu-row .right-icons .pmk-header-cta-wrap {
  display: flex !important;
  align-items: center;
  float: none !important;
  margin-left: 8px;
}
.pmk-brand .pmk-header-cta { margin: 0 !important; }   /* убрать .btn margin-bottom Aspro */
.pmk-header-cta {
  padding: 12px 22px !important;
  white-space: nowrap;
  line-height: 1 !important;
}

/* акцент телефона — лайм-иконка в мобильной шапке и меню */
.mobileheader-v1 .svg-inline-phone .cls-1,
.dropdown.show .svg-inline-phone .cls-1,
.mobileheader-v1 .wrap_phones .svg .cls-1 {
  fill: var(--pmk-accent) !important;
}

/* ------------------------------- Меню -------------------------------- */
.menu-row .menu > li > a,
.menu-row .menu a {
  font-weight: 600 !important;
}
/* акцент активного/ховера пункта — тёмный ink (не синий Aspro) */
.menu-row .menu > li:hover > a,
.menu-row .menu > li.active > a {
  color: var(--pmk-ink) !important;
}

/* ------------------------------ Подвал ------------------------------- */
/* лаймовый акцент на заголовках колонок и ховере ссылок (дозированно) */
.footer .bottom-menu .item-link .title:hover,
.footer .bottom-menu a:hover {
  color: var(--pmk-accent) !important;
}

/* --------------------------- Mobile-first ---------------------------- */
/* ВНИМАНИЕ: не клипуем html/body overflow-x глобально — это ломает
   IntersectionObserver lazy-load Aspro (картинки выше сгиба не грузятся).
   Горизонтальный скролл лечим по контейнерам при появлении (см. мобайл-тест). */
/* тач-эргономика: телефон/иконки в utility-строке — комфортная зона */
@media (max-width: 640px) {
  .top-block .phone a,
  .top-block .callback-block { min-height: 44px; display: inline-flex; align-items: center; }
}

/* ============ Мобильная шапка (.pmk-mheader / .pmk-mpanel) по макету ============ */
/* ВИДИМОСТЬ десктоп↔мобайл НЕ трогаем: Aspro сам переключает через Bootstrap-
   обёртки — десктоп-шапка в .visible-lg.visible-md (≥992), мобильная в
   .visible-xs.visible-sm (≤991). Свой брейкпоинт здесь = 991px (sm), чтобы
   совпадал с обёртками (иначе «дыра» без шапки в 981–991px). Тут — ТОЛЬКО стиль. */

@media (max-width: 991px) {
  .pmk-brand .pmk-mheader { position: relative; z-index: 50; }
  /* Наша моб-шапка 2-рядная (утилити+лого) выше стандартной → контейнеру #mobileheader
     даём реальную высоту, иначе штатный height:63px обрезает и шапка наезжает на
     контент (крошки «за шапкой» на всех страницах). */
  .pmk-brand #mobileheader { height: auto !important; }

  /* --- тёмная утилити: 2 колонки (телефон | e-mail) --- */
  .pmk-brand .pmk-mutility {
    display: grid; grid-template-columns: 1fr 1fr;
    background: var(--pmk-ink, #16191c); color: #fff;
  }
  /* e-mail-кнопка и кнопка-триггер телефона — одинаковая посадка в ячейках */
  .pmk-brand .pmk-mutility__email,
  .pmk-brand .pmk-mutility .pmk-mu-btn {
    display: flex; align-items: center; justify-content: center; gap: 7px;
    width: 100%; min-height: 44px; padding: 11px 8px; margin: 0;
    background: transparent; border: 0; cursor: pointer;
    font: 700 13px/1 var(--pmk-font); color: #fff; text-decoration: none;
    -webkit-tap-highlight-color: transparent;
  }
  .pmk-brand .pmk-mutility__phone { position: relative; border-right: 1px solid rgba(255,255,255,.12); }
  .pmk-brand .pmk-mutility svg { color: var(--pmk-accent); flex: 0 0 auto; }
  .pmk-brand .pmk-mutility .pmk-copied-on { color: var(--pmk-accent); }
  /* шеврон телефона в тёмной утилити — светлый */
  .pmk-brand .pmk-mutility .pmk-geo__chev { border-color: #aeb6bf; }
  /* выпадашка номеров (выбор: город/сотовый) — телефон в ЛЕВОЙ колонке, поэтому
     якорим к левому краю (не центрируем, иначе уезжает за экран влево),
     ширину ограничиваем вьюпортом */
  .pmk-brand .pmk-mu-menu { left: 8px; right: auto; transform: none; min-width: 240px; max-width: calc(100vw - 16px); }
  .pmk-brand .pmk-mu-menu a {
    display: flex; justify-content: space-between; align-items: center; gap: 12px;
    padding: 12px 14px; border-radius: 8px; text-decoration: none;
    font: 700 15px/1.1 var(--pmk-font); color: var(--pmk-ink, #16191c);
  }
  .pmk-brand .pmk-mu-menu a:hover { background: var(--pmk-bg, #f4f5f7); }
  .pmk-brand .pmk-mu-menu a i { font-style: normal; font-size: 11px; font-weight: 700; color: #9aa3ad; text-transform: uppercase; letter-spacing: .03em; }

  /* --- ряд: лого слева + бургер справа --- */
  .pmk-brand .pmk-mrow {
    display: flex; align-items: center; justify-content: space-between;
    height: 60px; padding: 0 16px;
    background: var(--pmk-surface, #fff); border-bottom: 1px solid var(--pmk-line, #e6e8eb);
  }
  .pmk-brand .pmk-mlogo { display: inline-flex; align-items: center; line-height: 1 !important; }
  .pmk-brand .pmk-mlogo img { height: 30px !important; width: auto !important; display: block; }

  /* бургер 44×44, 3 линии → X при открытии */
  .pmk-brand .pmk-burger {
    width: 44px; height: 44px; flex: 0 0 auto;
    display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px;
    background: none; border: 0; padding: 0; cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }
  .pmk-brand .pmk-burger span {
    display: block; width: 22px; height: 2px; border-radius: 2px;
    background: var(--pmk-ink, #16191c); transition: transform .2s, opacity .2s;
  }
  .pmk-brand .pmk-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .pmk-brand .pmk-burger.is-open span:nth-child(2) { opacity: 0; }
  .pmk-brand .pmk-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* --- панель бургер-меню (поверх, под шапкой) --- */
  .pmk-brand .pmk-mpanel {
    position: fixed; inset: 0; z-index: 49;
    background: var(--pmk-surface, #fff); overflow-y: auto;
    padding-top: 104px; /* утилити 44 + ряд 60 — контент панели под шапкой */
    -webkit-overflow-scrolling: touch;
  }
  .pmk-brand .pmk-mpanel.is-open { display: block; }
  .pmk-brand .pmk-mpanel__in { padding: 8px 16px 40px; }

  /* пункты меню */
  .pmk-brand .pmk-mmenu { display: block; }
  .pmk-brand .pmk-mi {
    display: block; width: 100%; text-align: left;
    font: 600 17px/1.2 var(--pmk-font); color: var(--pmk-ink, #16191c); text-decoration: none;
    padding: 14px 0; border: 0; border-bottom: 1px solid var(--pmk-line, #e6e8eb);
    background: none; cursor: pointer;
  }
  .pmk-brand .pmk-mi--search { color: var(--pmk-muted, #5a6470); }

  /* CTA «Получить расчёт» — на всю ширину */
  .pmk-brand .pmk-mpanel__cta { margin-top: 18px; }
  .pmk-brand .pmk-mcta {
    display: block; width: 100%; text-align: center;
    padding: 15px !important; margin: 0 !important;
    font: 700 16px/1 var(--pmk-font);
  }

  /* контакты */
  .pmk-brand .pmk-mpanel__contacts {
    margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--pmk-line, #e6e8eb);
    display: flex; flex-direction: column;
  }
  .pmk-brand .pmk-mphone,
  .pmk-brand .pmk-mmail {
    text-align: left; background: none; border: 0; cursor: pointer;
    font: 700 16px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); text-decoration: none;
    padding: 11px 0; min-height: 44px; display: flex; align-items: center;
  }
  .pmk-brand .pmk-mmail .pmk-copied-on { color: var(--pmk-accent); }
  .pmk-brand .pmk-maddr {
    font: 500 13.5px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); padding-top: 8px;
  }
  /* адрес = выбор города (шеврон + выпадашка городов), как на десктопе */
  .pmk-brand .pmk-maddr-geo { position: relative; }
  .pmk-brand .pmk-maddr-btn {
    display: flex; align-items: center; gap: 8px; width: 100%; text-align: left;
    background: none; border: 0; cursor: pointer; padding: 11px 0; min-height: 44px;
    font: 600 14px/1.3 var(--pmk-font); color: var(--pmk-muted, #5a6470);
    -webkit-tap-highlight-color: transparent;
  }
  .pmk-brand .pmk-maddr-btn .pmk-geo__pin { color: var(--pmk-accent); flex: 0 0 auto; }
  .pmk-brand .pmk-maddr-btn .pmk-geo__chev { border-color: #5a6470; }
  .pmk-brand .pmk-maddr-text { flex: 1 1 auto; }
  .pmk-brand .pmk-mhours { font: 500 13px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); padding-top: 2px; }

  /* слот мультирегиональности (зарезервирован) */
  .pmk-brand .pmk-mgeo { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--pmk-line, #e6e8eb); }
  .pmk-brand .pmk-mgeo label { display: block; font: 700 12px/1 var(--pmk-font); text-transform: uppercase; letter-spacing: .05em; color: var(--pmk-muted, #5a6470); margin-bottom: 8px; }
  .pmk-brand .pmk-mgeo select { width: 100%; font: 600 16px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); background: var(--pmk-bg, #f4f5f7); border: 1px solid var(--pmk-line, #e6e8eb); border-radius: 11px; padding: 13px 14px; }
}

/* блокировка прокрутки фона при открытой панели (body == .pmk-brand) */
.pmk-brand.pmk-mlocked { overflow: hidden; }

/* ===================== СТРАНИЦА УСЛУГИ (.pmk-service) ===================== */
.pmk-brand .pmk-service { color: var(--pmk-ink, #16191c); font-family: var(--pmk-font); }
/* ширина услуги = контент-контейнер сайта (.detail.services уже 178..1614 = как шапка);
   свой max-width/padding НЕ навязываем, адаптив даёт родительский .maxwidth-theme */
.pmk-brand .pmk-s-wrap { max-width: none; margin: 0; padding: 0; }
.pmk-brand .pmk-s-sec { padding-bottom: 54px; }
.pmk-brand .pmk-s-h2 { font: 800 28px/1.15 var(--pmk-font); margin: 0 0 8px; }
.pmk-brand .pmk-s-h3 { font: 800 17px/1.2 var(--pmk-font); margin: 0 0 12px; }
.pmk-brand .pmk-s-h2row { margin-bottom: 24px; }
.pmk-brand .pmk-s-h2row p { color: var(--pmk-muted, #5a6470); margin: 6px 0 0; font-size: 15px; }
/* кнопки */
.pmk-brand .pmk-s-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font: 700 15px/1 var(--pmk-font); border: none; cursor: pointer; padding: 14px 26px; border-radius: 11px; text-decoration: none; white-space: nowrap; transition: box-shadow .15s, border-color .15s, transform .1s; }
.pmk-brand .pmk-s-btn:active { transform: translateY(1px); }
.pmk-brand .pmk-s-btn--primary { background: var(--pmk-accent, #C8F000); color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-btn--primary:hover { box-shadow: 0 8px 20px rgba(200,240,0,.35); color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-btn--ghost { background: transparent; color: var(--pmk-ink, #16191c); border: 1.5px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-s-btn--ghost:hover { border-color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-btn--ghost-d { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.25); }
.pmk-brand .pmk-s-btn--ghost-d:hover { border-color: #fff; }
.pmk-brand .pmk-s-btn--full { width: 100%; }

/* --- HERO --- */
.pmk-brand .pmk-s-hero { padding: 30px 0 54px; }
.pmk-brand .pmk-s-hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; }
.pmk-brand .pmk-s-pill { display: inline-flex; align-items: center; gap: 9px; background: var(--pmk-ink, #16191c); color: #fff; font: 700 13px/1 var(--pmk-font); padding: 8px 15px; border-radius: 999px; margin-bottom: 20px; }
.pmk-brand .pmk-s-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-s-h1 { font: 800 clamp(30px,4vw,46px)/1.08 var(--pmk-font); margin: 0 0 18px; }
.pmk-brand .pmk-s-hero__sub { font-size: 17px; color: var(--pmk-muted, #5a6470); margin: 0 0 24px; max-width: 560px; }
.pmk-brand .pmk-s-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
.pmk-brand .pmk-s-hero__trust { display: flex; gap: 20px; flex-wrap: wrap; }
.pmk-brand .pmk-s-trust { display: flex; gap: 10px; align-items: flex-start; max-width: 220px; }
.pmk-brand .pmk-s-trust svg { flex: 0 0 auto; margin-top: 1px; color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-s-trust b { display: block; font-size: 14.5px; }
.pmk-brand .pmk-s-trust span { font-size: 13px; color: var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-s-hero__media { border-radius: 16px; overflow: hidden; box-shadow: 0 18px 50px rgba(22,25,28,.16); aspect-ratio: 4/3; }
.pmk-brand .pmk-s-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* --- CALC (тёмная плашка) --- */
.pmk-brand .pmk-s-calc { background: var(--pmk-ink, #16191c); color: #fff; border-radius: 20px; padding: 38px; position: relative; overflow: hidden; display: grid; grid-template-columns: 1.1fr .9fr; gap: 36px; align-items: center; }
.pmk-brand .pmk-s-calc::after { content: ""; position: absolute; right: -50px; top: -50px; width: 200px; height: 200px; background: var(--pmk-accent, #C8F000); opacity: .14; border-radius: 50%; filter: blur(10px); }
.pmk-brand .pmk-s-calc__l, .pmk-brand .pmk-s-calc__r { position: relative; }
.pmk-brand .pmk-s-calc .pmk-s-h2 { font-size: 26px; }
.pmk-brand .pmk-s-calc__lead { color: #aab2bb; margin: 0 0 20px; }
.pmk-brand .pmk-s-csteps { display: flex; flex-direction: column; gap: 14px; }
.pmk-brand .pmk-s-cstep { display: flex; align-items: flex-start; gap: 12px; font-size: 15px; color: #dfe3e8; }
.pmk-brand .pmk-s-cstep b { color: #fff; }
.pmk-brand .pmk-s-n { width: 26px; height: 26px; border-radius: 50%; background: rgba(200,240,0,.16); color: var(--pmk-accent, #C8F000); font: 800 13px/1 var(--pmk-font); display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pmk-brand .pmk-s-or { color: #aab2bb; font-size: 13px; text-align: center; margin: 14px 0 10px; }
.pmk-brand .pmk-s-copy { width: 100%; background: transparent; border: 1.5px solid rgba(255,255,255,.25); border-radius: 11px; color: #fff; font: 700 14px/1 var(--pmk-font); padding: 13px; cursor: pointer; }
.pmk-brand .pmk-s-copy:hover { border-color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-s-copy .pmk-copied-on { color: var(--pmk-accent, #C8F000); }

/* --- ЧТО РЕЖЕМ --- */
.pmk-brand .pmk-s-cut { display: grid; grid-template-columns: 1.1fr .9fr; gap: 28px; align-items: start; }
.pmk-brand .pmk-s-cut__table table { width: 100%; border-collapse: collapse; background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; overflow: hidden; }
.pmk-brand .pmk-s-cut__table th { background: var(--pmk-ink, #16191c); color: #fff; text-align: left; font: 700 13px/1.2 var(--pmk-font); text-transform: uppercase; letter-spacing: .03em; padding: 13px 16px; }
.pmk-brand .pmk-s-cut__table td { padding: 12px 16px; border-top: 1px solid var(--pmk-line, #e3e6ea); font-size: 14.5px; }
.pmk-brand .pmk-s-cut__table tbody tr:nth-child(even) { background: var(--pmk-bg, #f4f5f7); }
.pmk-brand .pmk-s-cut__card { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; padding: 18px 20px; }
.pmk-brand .pmk-s-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.pmk-brand .pmk-s-chip { background: var(--pmk-bg, #f4f5f7); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 999px; padding: 7px 13px; font: 600 13.5px/1 var(--pmk-font); color: #39414a; }

/* --- КАК ЗАКАЗАТЬ --- */
.pmk-brand .pmk-s-steps4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.pmk-brand .pmk-s-s4 { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; padding: 24px; }
.pmk-brand .pmk-s-num { font: 800 30px/1 var(--pmk-font); color: var(--pmk-accent, #C8F000); -webkit-text-stroke: 1px #c2d100; margin-bottom: 14px; }
.pmk-brand .pmk-s-s4 h3 { font-size: 16px; margin: 0 0 6px; }
.pmk-brand .pmk-s-s4 p { font-size: 14px; color: var(--pmk-muted, #5a6470); margin: 0; }

/* --- ПОЧЕМУ ЗАВОД --- */
.pmk-brand .pmk-s-adv { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.pmk-brand .pmk-s-acard { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; padding: 24px; display: flex; gap: 16px; }
.pmk-brand .pmk-s-badge { width: 44px; height: 44px; flex: 0 0 auto; border-radius: 12px; background: var(--pmk-accent, #C8F000); display: flex; align-items: center; justify-content: center; color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-acard h3 { font-size: 16px; margin: 0 0 5px; }
.pmk-brand .pmk-s-acard p { font-size: 14px; color: var(--pmk-muted, #5a6470); margin: 0; }

/* --- ПРОЕКТЫ --- */
.pmk-brand .pmk-s-projgrid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.pmk-brand .pmk-s-projc { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; overflow: hidden; text-decoration: none; color: inherit; transition: transform .18s, box-shadow .18s; }
.pmk-brand .pmk-s-projc:hover { transform: translateY(-4px); box-shadow: 0 14px 34px rgba(22,25,28,.10); }
.pmk-brand .pmk-s-projc__img { height: 160px; background-size: cover; background-position: center; }
.pmk-brand .pmk-s-projc__img--ph { background: linear-gradient(135deg,#2b3340,#454f5e); }
.pmk-brand .pmk-s-projc__in { padding: 16px 18px; }
.pmk-brand .pmk-s-projc__in h3 { font-size: 15.5px; margin: 0 0 6px; }
.pmk-brand .pmk-s-projc__in p { font-size: 13px; color: var(--pmk-muted, #5a6470); margin: 0; }

/* --- СВЯЗАННЫЕ УСЛУГИ --- */
.pmk-brand .pmk-s-relserv { display: flex; flex-wrap: wrap; gap: 10px; }
.pmk-brand .pmk-s-relserv a { display: inline-flex; align-items: center; gap: 8px; background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 999px; padding: 10px 16px; font: 600 14px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); text-decoration: none; }
.pmk-brand .pmk-s-relserv a:hover { border-color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-reldot { width: 7px; height: 7px; border-radius: 50%; background: var(--pmk-accent, #C8F000); }

/* --- CTA полоса --- */
.pmk-brand .pmk-s-ctaband { background: var(--pmk-ink, #16191c); color: #fff; border-radius: 20px; padding: 40px; text-align: center; position: relative; overflow: hidden; }
.pmk-brand .pmk-s-ctaband::after { content: ""; position: absolute; right: -40px; top: -40px; width: 170px; height: 170px; background: var(--pmk-accent, #C8F000); opacity: .16; border-radius: 50%; filter: blur(8px); }
.pmk-brand .pmk-s-ctaband h2 { font-size: 28px; margin: 0 0 8px; position: relative; }
.pmk-brand .pmk-s-ctaband p { color: #aab2bb; margin: 0 0 22px; position: relative; }
.pmk-brand .pmk-s-ctaband__row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; position: relative; }

/* --- ТЕОРИЯ (DETAIL_TEXT, читаемая статья) --- */
/* SEO-текст услуги — Вариант C: единый блок-карточка, оформленные H3 (лаймовый маркер) +
   разделители. Оформление на ПРЯМЫХ потомках .pmk-s-theory__in — структура h3/p из DETAIL_TEXT
   сохранена (SEO не тронут). Переиспользуется на всех услугах. */
.pmk-brand .pmk-s-theory { padding: 12px 0 50px; }
.pmk-brand .pmk-s-theory__eb { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--pmk-muted, #5a6470); margin-bottom: 14px; }
.pmk-brand .pmk-s-theory__eb::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent, #C8F000); border-radius: 3px; }
.pmk-brand .pmk-s-theory__h2 { font-size: clamp(23px,2.8vw,28px); font-weight: 800; letter-spacing: -.02em; margin: 0 0 22px; color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-theory__in { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 18px; padding: 34px 38px; max-width: none; color: #39414a; }
.pmk-brand .pmk-s-theory__in > h3 { display: flex; align-items: center; gap: 11px; font-size: 19px; font-weight: 800; line-height: 1.25; color: var(--pmk-ink, #16191c); margin: 0 0 12px; padding-top: 22px; border-top: 1px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-s-theory__in > h3::before { content: ""; width: 9px; height: 9px; background: var(--pmk-accent, #C8F000); border-radius: 2px; flex: 0 0 auto; }
.pmk-brand .pmk-s-theory__in > h3:first-child { padding-top: 0; border-top: none; }
.pmk-brand .pmk-s-theory__in p { font-size: 15px; line-height: 1.65; color: #39414a; margin: 0 0 12px; }
.pmk-brand .pmk-s-theory__in ul, .pmk-brand .pmk-s-theory__in ol { margin: 0 0 12px; padding-left: 20px; }
.pmk-brand .pmk-s-theory__in li { font-size: 15px; line-height: 1.6; color: #39414a; margin-bottom: 4px; }
.pmk-brand .pmk-s-theory__in a { color: #5a6b00; text-decoration: underline; text-underline-offset: 2px; }
.pmk-brand .pmk-s-theory__in a:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-theory__in > *:last-child { margin-bottom: 0; }
.pmk-brand .pmk-s-theory__in img { max-width: 100%; height: auto; border-radius: 12px; }
@media (max-width: 760px) { .pmk-brand .pmk-s-theory__in { padding: 24px; } .pmk-brand .pmk-s-theory__in > h3 { font-size: 18px; } }

/* --- FAQ --- */
.pmk-brand .pmk-s-faq { max-width: 860px; }
.pmk-brand .pmk-s-qa { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 14px; margin-bottom: 10px; overflow: hidden; }
.pmk-brand .pmk-s-qa summary { list-style: none; cursor: pointer; padding: 18px 22px; font: 700 16px/1.3 var(--pmk-font); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.pmk-brand .pmk-s-qa summary::-webkit-details-marker { display: none; }
.pmk-brand .pmk-s-qa summary::after { content: "+"; font-size: 22px; color: var(--pmk-muted, #5a6470); font-weight: 600; flex: 0 0 auto; }
.pmk-brand .pmk-s-qa[open] summary::after { content: "–"; }
.pmk-brand .pmk-s-qa__a { padding: 0 22px 18px; color: #39414a; font-size: 15px; line-height: 1.6; }

/* --- адаптив --- */
@media (max-width: 980px) {
  .pmk-brand .pmk-s-hero__grid,
  .pmk-brand .pmk-s-calc,
  .pmk-brand .pmk-s-cut { grid-template-columns: 1fr; }
  .pmk-brand .pmk-s-steps4,
  .pmk-brand .pmk-s-adv,
  .pmk-brand .pmk-s-projgrid { grid-template-columns: 1fr 1fr; }
  .pmk-brand .pmk-s-hero__media { order: -1; }
}
@media (max-width: 640px) {
  .pmk-brand .pmk-s-wrap { padding: 0; }
  .pmk-brand .pmk-s-sec { padding-bottom: 40px; }
  .pmk-brand .pmk-s-steps4,
  .pmk-brand .pmk-s-adv,
  .pmk-brand .pmk-s-projgrid { grid-template-columns: 1fr; }
  .pmk-brand .pmk-s-calc,
  .pmk-brand .pmk-s-ctaband { padding: 26px; }
  .pmk-brand .pmk-s-hero__cta .pmk-s-btn,
  .pmk-brand .pmk-s-ctaband__row .pmk-s-btn { flex: 1 1 100%; }
}

/* ===================== Подвал (.pmk-footer) по макету ===================== */
/* Селекторы с #footer — чтобы перебить ID-специфичность штатных правил Aspro (#footer ...). */
.pmk-brand #footer.pmk-footer {
  background: var(--pmk-ink, #16191c) !important; color: #aab2bb !important;
  padding: 54px 0 28px !important; margin: 0 !important; border: 0 !important;
}
/* совпадение краёв с контентом (как у шапки): maxwidth 24 + gutter 16 = 40 */
.pmk-brand #footer .pmk-footer__in { padding-left: 40px; padding-right: 40px; }
.pmk-brand #footer .pmk-fgrid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; }
.pmk-brand #footer .pmk-flogo img { height: 30px !important; width: auto !important; margin-bottom: 16px; display: block; filter: brightness(0) invert(1); }
.pmk-brand #footer .pmk-fabout, .pmk-brand #footer .pmk-faddr {
  font: 400 14px/1.6 var(--pmk-font); color: #aab2bb; margin: 0 0 14px;
}
.pmk-brand #footer .pmk-faddr { margin-bottom: 0; }
.pmk-brand #footer .pmk-fcol b {
  color: #fff; display: block; font: 700 14px/1 var(--pmk-font);
  margin-bottom: 14px; letter-spacing: .02em;
}
.pmk-brand #footer .pmk-fcol a,
.pmk-brand #footer .pmk-fmail {
  display: block; color: #aab2bb !important; font: 400 14.5px/1.4 var(--pmk-font);
  padding: 4px 0; text-decoration: none; background: none; border: 0; cursor: pointer;
  text-align: left; white-space: normal;
}
.pmk-brand #footer .pmk-fcol a:hover,
.pmk-brand #footer .pmk-fmail:hover { color: #fff !important; }
/* заголовки-ссылки Услуги/Каталог с иконкой (лайм) */
.pmk-brand #footer .pmk-fcol a.pmk-fhead {
  display: inline-flex; align-items: center; gap: 8px; padding: 0;
  color: #fff !important; font: 700 14px/1 var(--pmk-font);
  margin-bottom: 14px; letter-spacing: .02em;
}
.pmk-brand #footer .pmk-fcol a.pmk-fhead:hover { color: var(--pmk-accent) !important; }
.pmk-brand #footer .pmk-fhico { color: var(--pmk-accent); flex: 0 0 auto; }
/* контакты с иконками (телефон/почта): flex, иконка лайм */
.pmk-brand #footer .pmk-fcol a.pmk-fph,
.pmk-brand #footer .pmk-fcol a.pmk-fphone,
.pmk-brand #footer .pmk-fcol .pmk-fmail { display: flex; align-items: center; gap: 8px; }
.pmk-brand #footer .pmk-fico { color: var(--pmk-accent); flex: 0 0 auto; }
.pmk-brand #footer .pmk-fcol a.pmk-fph { font-size: 17px !important; font-weight: 800 !important; color: #fff !important; padding: 2px 0 6px; }
.pmk-brand #footer .pmk-fall { color: #fff !important; font-weight: 700; margin-top: 6px; }
.pmk-brand #footer .pmk-fcta { color: var(--pmk-accent) !important; font-weight: 700; margin-top: 6px; }
.pmk-brand #footer .pmk-fmail .pmk-copied-on { color: var(--pmk-accent) !important; }
.pmk-brand #footer .pmk-fbar {
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px;
  margin-top: 40px; padding-top: 22px; border-top: 1px solid #272c31;
  font: 400 13px/1.5 var(--pmk-font); color: #717b85;
}
.pmk-brand #footer .pmk-fbar a { color: #717b85 !important; text-decoration: none; }
.pmk-brand #footer .pmk-fbar a:hover { color: #aab2bb !important; }
.pmk-brand #footer .pmk-fbar__dot { margin: 0 6px; color: #4a525b; }
@media (max-width: 991px) {
  .pmk-brand #footer .pmk-fgrid { grid-template-columns: 1fr 1fr; gap: 26px; }
  .pmk-brand #footer .pmk-fcol--about { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .pmk-brand #footer .pmk-fgrid { grid-template-columns: 1fr; }
}

/* === Финал услуги: лайм-подчёркивание H1, светлые заголовки тёмных плашек, крошки === */
.pmk-brand .pmk-s-h1 .hl { box-shadow: inset 0 -.30em 0 var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-s-calc .pmk-s-h2 { color: #fff !important; }
.pmk-brand .pmk-s-ctaband h2, .pmk-brand .pmk-s-ctaband .pmk-s-h2 { color: #fff !important; }
.pmk-brand .pmk-s-crumbs { padding: 18px 0 0; font: 400 13px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-s-crumbs a { color: var(--pmk-muted, #5a6470); text-decoration: none; }
.pmk-brand .pmk-s-crumbs a:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-s-crumbs__sep { margin: 0 8px; color: #c5cbd2; }

/* ===================== СТРАНИЦА ПРОЕКТА (.pmk-project) ===================== */
/* Макет project-koltsa-etalon.html. Ширина = контейнер сайта (.pmk-p-wrap нейтрален). */
.pmk-brand .pmk-project { color: var(--pmk-ink, #16191c); font-family: var(--pmk-font); }
.pmk-brand .pmk-p-wrap { max-width: none; margin: 0; padding: 0; }
.pmk-brand .pmk-p-sec { padding: 54px 0; }
.pmk-brand .pmk-p-h2row { margin-bottom: 26px; }
.pmk-brand .pmk-p-h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 800; letter-spacing: -.02em; margin: 0; }
.pmk-brand .pmk-p-h2row p { color: var(--pmk-muted, #5a6470); margin: 8px 0 0; }

/* кнопки */
.pmk-brand .pmk-p-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font: 700 15px/1 var(--pmk-font); border: none; cursor: pointer; padding: 14px 26px; border-radius: var(--pmk-radius-btn, 11px); text-decoration: none; transition: transform .15s, box-shadow .15s; }
.pmk-brand .pmk-p-btn--primary { background: var(--pmk-accent, #C8F000); color: var(--pmk-accent-ink, #16191c); }
.pmk-brand .pmk-p-btn--primary:hover { box-shadow: 0 8px 20px rgba(200,240,0,.35); transform: translateY(-1px); color: var(--pmk-accent-ink, #16191c); }
.pmk-brand .pmk-p-btn--ghost-d { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.25); }
.pmk-brand .pmk-p-btn--ghost-d:hover { border-color: rgba(255,255,255,.55); }

/* крошки */
.pmk-brand .pmk-p-crumbs { padding: 18px 0 0; font: 400 13px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-p-crumbs a { color: var(--pmk-muted, #5a6470); text-decoration: none; }
.pmk-brand .pmk-p-crumbs a:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-p-crumbs__sep { margin: 0 8px; color: #c5cbd2; }

/* hero */
.pmk-brand .pmk-p-hero { padding: 26px 0 50px; }
.pmk-brand .pmk-p-hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; }
.pmk-brand .pmk-p-pill { display: inline-flex; align-items: center; gap: 8px; background: var(--pmk-ink, #16191c); color: #fff; font-weight: 700; font-size: 13px; padding: 8px 15px; border-radius: 999px; margin-bottom: 18px; }
.pmk-brand .pmk-p-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--pmk-accent, #C8F000); flex: 0 0 auto; }
.pmk-brand .pmk-p-sep { opacity: .4; }
.pmk-brand .pmk-p-h1 { font-size: clamp(28px, 3.6vw, 42px); line-height: 1.1; font-weight: 800; letter-spacing: -.02em; margin: 0 0 16px; }
.pmk-brand .pmk-p-hero__sub { font-size: 17px; color: var(--pmk-muted, #5a6470); margin: 0 0 24px; max-width: 560px; }
.pmk-brand .pmk-p-stats { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 24px; }
.pmk-brand .pmk-p-stat { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 14px; padding: 14px 18px; }
.pmk-brand .pmk-p-stat__v { font-size: 26px; font-weight: 800; letter-spacing: -.02em; line-height: 1; }
.pmk-brand .pmk-p-stat__l { font-size: 12.5px; color: var(--pmk-muted, #5a6470); font-weight: 600; margin-top: 5px; }
.pmk-brand .pmk-p-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.pmk-brand .pmk-p-hero__media { border-radius: 20px; overflow: hidden; border: 1px solid var(--pmk-line, #e3e6ea); box-shadow: 0 18px 50px rgba(22,25,28,.16); aspect-ratio: 4/3; }
.pmk-brand .pmk-p-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* что сделали */
.pmk-brand .pmk-p-two { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.pmk-brand .pmk-p-prose p { color: #39414a; margin: 0 0 14px; }
.pmk-brand .pmk-p-prose .accent { background: rgba(200,240,0,.16); padding: 2px 6px; border-radius: 5px; font-weight: 600; }
.pmk-brand .pmk-p-mediacard { border-radius: 18px; overflow: hidden; border: 1px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-p-mediacard img { width: 100%; height: 340px; object-fit: cover; display: block; }

/* выгоды (тёмная плашка) */
.pmk-brand .pmk-p-benefits { background: var(--pmk-ink, #16191c); color: #fff; border-radius: 20px; padding: 38px; }
.pmk-brand .pmk-p-benefits .pmk-p-h2 { margin: 0 0 24px; }
.pmk-brand .pmk-p-bgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.pmk-brand .pmk-p-bcard { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 14px; padding: 20px; }
.pmk-brand .pmk-p-bic { width: 40px; height: 40px; border-radius: 11px; background: var(--pmk-accent, #C8F000); color: var(--pmk-accent-ink, #16191c); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.pmk-brand .pmk-p-bcard h3 { font-size: 16px; margin: 0 0 5px; color: #fff; }
.pmk-brand .pmk-p-bcard p { font-size: 13.5px; color: #aab2bb; margin: 0; }

/* характеристики */
.pmk-brand .pmk-p-specs-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: start; }
.pmk-brand .pmk-p-specs { width: 100%; border-collapse: collapse; background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: var(--pmk-radius-card, 16px); overflow: hidden; }
.pmk-brand .pmk-p-specs tr + tr { border-top: 1px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-p-specs th, .pmk-brand .pmk-p-specs td { text-align: left; padding: 13px 18px; font-size: 14.5px; }
.pmk-brand .pmk-p-specs th { color: var(--pmk-muted, #5a6470); font-weight: 600; width: 48%; }
.pmk-brand .pmk-p-specs td { color: var(--pmk-ink, #16191c); font-weight: 700; }

/* галерея */
.pmk-brand .pmk-p-gal { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.pmk-brand .pmk-p-g { border-radius: 14px; overflow: hidden; border: 1px solid var(--pmk-line, #e3e6ea); aspect-ratio: 4/3; display: block; }
.pmk-brand .pmk-p-g img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; display: block; }
.pmk-brand .pmk-p-g:hover img { transform: scale(1.05); }

/* услуги в проекте */
.pmk-brand .pmk-p-linkserv { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: var(--pmk-radius-card, 16px); padding: 8px; display: flex; flex-wrap: wrap; gap: 8px; }
.pmk-brand .pmk-p-ls { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border-radius: 12px; transition: background .15s; flex: 1; min-width: 260px; text-decoration: none; color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-p-ls:hover { background: var(--pmk-bg, #f4f5f7); }
.pmk-brand .pmk-p-ls__ic { width: 46px; height: 46px; border-radius: 12px; background: rgba(200,240,0,.16); color: var(--pmk-ink, #16191c); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pmk-brand .pmk-p-ls__b { display: flex; flex-direction: column; min-width: 0; }
.pmk-brand .pmk-p-ls__t { font-size: 16px; font-weight: 800; }
.pmk-brand .pmk-p-ls__d { font-size: 13px; color: var(--pmk-muted, #5a6470); margin-top: 2px; }
.pmk-brand .pmk-p-ls__arr { margin-left: auto; color: var(--pmk-muted, #5a6470); flex: 0 0 auto; }

/* изделие в каталоге (тёмная плашка) */
.pmk-brand .pmk-p-catlink { background: linear-gradient(120deg, #1c2024, #16191c); color: #fff; border-radius: var(--pmk-radius-card, 16px); padding: 28px 32px; display: flex; align-items: center; gap: 26px; position: relative; overflow: hidden; }
.pmk-brand .pmk-p-catlink::after { content: ""; position: absolute; right: -30px; bottom: -40px; width: 160px; height: 160px; background: var(--pmk-accent, #C8F000); opacity: .12; border-radius: 50%; filter: blur(6px); }
.pmk-brand .pmk-p-catlink__ic { width: 64px; height: 64px; border-radius: 15px; background: var(--pmk-accent, #C8F000); color: var(--pmk-accent-ink, #16191c); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; position: relative; }
.pmk-brand .pmk-p-catlink__b { position: relative; flex: 1; min-width: 0; }
.pmk-brand .pmk-p-catlink__lbl { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--pmk-accent, #C8F000); margin-bottom: 6px; }
.pmk-brand .pmk-p-catlink__t { font-size: 20px; font-weight: 800; margin: 0 0 4px; }
.pmk-brand .pmk-p-catlink__d { font-size: 14px; color: #aab2bb; margin: 0; }
.pmk-brand .pmk-p-catlink__btn { position: relative; flex: 0 0 auto; background: var(--pmk-accent, #C8F000); color: var(--pmk-accent-ink, #16191c); font-weight: 700; font-size: 15px; padding: 13px 24px; border-radius: var(--pmk-radius-btn, 11px); display: inline-flex; align-items: center; gap: 8px; text-decoration: none; transition: box-shadow .15s, transform .15s; }
.pmk-brand .pmk-p-catlink__btn:hover { box-shadow: 0 8px 20px rgba(200,240,0,.35); transform: translateY(-2px); }

/* другие проекты */
.pmk-brand .pmk-p-pgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pmk-brand .pmk-p-pc { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; overflow: hidden; transition: transform .18s, box-shadow .18s; text-decoration: none; color: var(--pmk-ink, #16191c); display: block; }
.pmk-brand .pmk-p-pc:hover { transform: translateY(-4px); box-shadow: 0 14px 34px rgba(22,25,28,.10); }
.pmk-brand .pmk-p-pc__ph { height: 150px; background-size: cover; background-position: center; }
.pmk-brand .pmk-p-pc__ph--empty { background: linear-gradient(135deg, #2b3340, #454f5e); }
.pmk-brand .pmk-p-pc__in { padding: 16px 18px; }
.pmk-brand .pmk-p-pc__meta { font-size: 12.5px; color: var(--pmk-muted, #5a6470); font-weight: 600; margin-bottom: 5px; }
.pmk-brand .pmk-p-pc h3 { font-size: 15.5px; margin: 0; }

/* CTA (тёмная плашка) */
.pmk-brand .pmk-p-ctaband { background: var(--pmk-ink, #16191c); color: #fff; border-radius: 20px; padding: 40px; text-align: center; position: relative; overflow: hidden; }
.pmk-brand .pmk-p-ctaband::after { content: ""; position: absolute; right: -40px; top: -40px; width: 170px; height: 170px; background: var(--pmk-accent, #C8F000); opacity: .16; border-radius: 50%; filter: blur(8px); }
.pmk-brand .pmk-p-ctaband .pmk-p-h2 { margin: 0 0 8px; position: relative; }
.pmk-brand .pmk-p-ctaband p { color: #aab2bb; margin: 0 0 22px; position: relative; }
.pmk-brand .pmk-p-ctaband__row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; position: relative; }

/* адаптив проекта */
@media (max-width: 980px) {
  .pmk-brand .pmk-p-hero__grid, .pmk-brand .pmk-p-two, .pmk-brand .pmk-p-specs-wrap { grid-template-columns: 1fr; gap: 28px; }
  .pmk-brand .pmk-p-hero__media { order: -1; }
  .pmk-brand .pmk-p-bgrid { grid-template-columns: 1fr 1fr; }
  .pmk-brand .pmk-p-gal, .pmk-brand .pmk-p-pgrid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .pmk-brand .pmk-p-sec { padding: 40px 0; }
  .pmk-brand .pmk-p-bgrid, .pmk-brand .pmk-p-gal, .pmk-brand .pmk-p-pgrid { grid-template-columns: 1fr; }
  .pmk-brand .pmk-p-benefits, .pmk-brand .pmk-p-ctaband { padding: 26px; }
  .pmk-brand .pmk-p-catlink { flex-direction: column; text-align: center; padding: 24px; }
  .pmk-brand .pmk-p-catlink__btn { width: 100%; justify-content: center; }
}

/* === Богатая карточка проекта (proj-card-final) — блок «наши работы» на услуге === */
.pmk-brand .pmk-pcard { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 18px; overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: transform .18s, box-shadow .18s; }
.pmk-brand .pmk-pcard:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(22,25,28,.12); }
.pmk-brand .pmk-pcard__img { position: relative; height: 190px; overflow: hidden; background: linear-gradient(135deg, #2b3340, #454f5e); }
.pmk-brand .pmk-pcard__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; display: block; }
.pmk-brand .pmk-pcard:hover .pmk-pcard__img img { transform: scale(1.05); }
.pmk-brand .pmk-pcard__date { position: absolute; top: 12px; right: 12px; background: rgba(22,25,28,.78); backdrop-filter: blur(4px); color: #fff; font-size: 12px; font-weight: 700; padding: 5px 10px; border-radius: 8px; }
.pmk-brand .pmk-pcard__body { padding: 18px 20px 20px; display: flex; flex-direction: column; flex: 1; }
.pmk-brand .pmk-pcard__meta { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--pmk-muted, #5a6470); font-weight: 600; margin-bottom: 8px; }
.pmk-brand .pmk-pcard__meta svg { flex: 0 0 auto; color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-pcard__meta b { color: var(--pmk-ink, #16191c); font-weight: 700; }
.pmk-brand .pmk-pcard__title { font-size: 17px; font-weight: 800; line-height: 1.25; letter-spacing: -.01em; margin: 0 0 14px; }
.pmk-brand .pmk-pcard__nums { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.pmk-brand .pmk-pcard__num { background: var(--pmk-bg, #f4f5f7); border-radius: 11px; padding: 11px 13px; }
.pmk-brand .pmk-pcard__num .v { font-size: 19px; font-weight: 800; letter-spacing: -.02em; line-height: 1; }
.pmk-brand .pmk-pcard__num .l { font-size: 11.5px; color: var(--pmk-muted, #5a6470); font-weight: 600; margin-top: 4px; line-height: 1.2; }
.pmk-brand .pmk-pcard__res { font-size: 13.5px; color: #39414a; line-height: 1.4; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--pmk-line, #e3e6ea); display: flex; gap: 8px; }
.pmk-brand .pmk-pcard__res svg { flex: 0 0 auto; color: var(--pmk-accent, #C8F000); margin-top: 1px; }
.pmk-brand .pmk-pcardgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 980px) { .pmk-brand .pmk-pcardgrid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .pmk-brand .pmk-pcardgrid { grid-template-columns: 1fr; } }

/* ===================== СПИСОК ПРОЕКТОВ (.pmk-projects) ===================== */
.pmk-brand .pmk-projects { color: var(--pmk-ink, #16191c); font-family: var(--pmk-font); }
.pmk-brand .pmk-pl-crumbs { padding: 16px 0 0; font: 400 13px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-pl-crumbs a { color: var(--pmk-muted, #5a6470); text-decoration: none; }
.pmk-brand .pmk-pl-crumbs a:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-pl-crumbs__sep { margin: 0 8px; color: #c5cbd2; }
.pmk-brand .pmk-pl-head { padding: 20px 0 18px; }
.pmk-brand .pmk-pl-h1 { font-size: clamp(30px, 4vw, 46px); font-weight: 800; letter-spacing: -.02em; line-height: 1.1; margin: 0 0 14px; }
.pmk-brand .pmk-pl-head p { color: var(--pmk-muted, #5a6470); font-size: 17px; line-height: 1.5; max-width: 62ch; margin: 0; }

/* панель фильтров */
.pmk-brand .pmk-pf-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 6px 0 18px; margin-bottom: 22px; border-bottom: 1px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-pf-dd { position: relative; }
.pmk-brand .pmk-pf-btn { display: inline-flex; align-items: center; gap: 9px; background: var(--pmk-surface, #fff); border: 1.5px solid var(--pmk-line, #e3e6ea); border-radius: 11px; padding: 11px 16px; font: 700 14px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); cursor: pointer; transition: border-color .15s; }
.pmk-brand .pmk-pf-btn:hover { border-color: #c0c8cf; }
.pmk-brand .pmk-pf-btn.active { border-color: var(--pmk-accent, #C8F000); background: rgba(200,240,0,.08); }
.pmk-brand .pmk-pf-cnt { display: none; min-width: 19px; height: 19px; padding: 0 5px; align-items: center; justify-content: center; background: var(--pmk-accent, #C8F000); color: var(--pmk-accent-ink, #16191c); border-radius: 999px; font-size: 12px; font-weight: 800; }
.pmk-brand .pmk-pf-btn.active .pmk-pf-cnt { display: inline-flex; }
.pmk-brand .pmk-pf-car { width: 7px; height: 7px; border-right: 2px solid var(--pmk-muted, #5a6470); border-bottom: 2px solid var(--pmk-muted, #5a6470); transform: rotate(45deg) translateY(-1px); transition: transform .2s; }
.pmk-brand .pmk-pf-dd.open .pmk-pf-car { transform: rotate(-135deg); }
.pmk-brand .pmk-pf-panel { position: absolute; top: calc(100% + 8px); left: 0; z-index: 20; background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 14px; box-shadow: 0 16px 40px rgba(22,25,28,.16); padding: 10px; min-width: 240px; max-height: 360px; overflow: auto; display: none; }
.pmk-brand .pmk-pf-dd.open .pmk-pf-panel { display: block; }
.pmk-brand .pmk-pf-opt { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: 9px; font-size: 14.5px; font-weight: 600; cursor: pointer; }
.pmk-brand .pmk-pf-opt:hover { background: var(--pmk-bg, #f4f5f7); }
.pmk-brand .pmk-pf-opt input { position: absolute; opacity: 0; width: 0; height: 0; }
.pmk-brand .pmk-pf-box { width: 19px; height: 19px; border: 2px solid var(--pmk-line, #e3e6ea); border-radius: 6px; flex: 0 0 auto; position: relative; transition: .15s; }
.pmk-brand .pmk-pf-opt input:checked + .pmk-pf-box { background: var(--pmk-accent, #C8F000); border-color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-pf-opt input:checked + .pmk-pf-box::after { content: ""; position: absolute; left: 5px; top: 1px; width: 5px; height: 10px; border: solid var(--pmk-accent-ink, #16191c); border-width: 0 2.5px 2.5px 0; transform: rotate(45deg); }
.pmk-brand .pmk-pf-otext { flex: 1; }
.pmk-brand .pmk-pf-ocnt { color: #9aa3ad; font-size: 12.5px; font-weight: 700; flex: 0 0 auto; }
.pmk-brand .pmk-pf-grp { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; color: #9aa3ad; padding: 8px 11px 4px; }
.pmk-brand .pmk-pf-city { border-top: 1px solid var(--pmk-line, #e3e6ea); margin-top: 6px; padding-top: 6px; }
.pmk-brand .pmk-pf-count { font: 600 13.5px/1 var(--pmk-font); color: var(--pmk-muted, #5a6470); margin-left: auto; }
.pmk-brand .pmk-pf-count b { color: var(--pmk-ink, #16191c); font-weight: 800; }
.pmk-brand .pmk-pf-reset { background: none; border: none; color: var(--pmk-muted, #5a6470); font: 700 13.5px/1 var(--pmk-font); cursor: pointer; text-decoration: underline; padding: 6px 8px; }
.pmk-brand .pmk-pf-reset:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-pf-empty { grid-column: 1 / -1; text-align: center; padding: 60px 20px; color: var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-pf-empty a { color: var(--pmk-ink, #16191c); text-decoration: underline; font-weight: 700; }
.pmk-brand .pmk-projects .pmk-pcardgrid { padding-bottom: 28px; }
.pmk-brand .pmk-pf-more-wrap { display: flex; justify-content: center; padding-bottom: 56px; }
.pmk-brand .pmk-pf-more { background: var(--pmk-surface, #fff); border: 1.5px solid var(--pmk-line, #e3e6ea); border-radius: var(--pmk-radius-btn, 11px); padding: 13px 30px; font: 700 15px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); cursor: pointer; transition: border-color .15s, box-shadow .15s; }
.pmk-brand .pmk-pf-more:hover { border-color: var(--pmk-accent, #C8F000); box-shadow: 0 6px 18px rgba(22,25,28,.08); }

/* фильтры — мобайл */
@media (max-width: 640px) {
  .pmk-brand .pmk-pf-dd { flex: 1; }
  .pmk-brand .pmk-pf-btn { width: 100%; justify-content: space-between; }
  .pmk-brand .pmk-pf-panel { left: 0; right: 0; }
  .pmk-brand .pmk-pf-reset { margin-left: 0; }
}

/* ===================== ВИТРИНА УСЛУГ (.pmk-services) ===================== */
.pmk-brand .pmk-services { color: var(--pmk-ink, #16191c); font-family: var(--pmk-font); }
.pmk-brand .pmk-sl-crumbs { padding: 16px 0 0; font: 400 13px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-sl-crumbs a { color: var(--pmk-muted, #5a6470); text-decoration: none; }
.pmk-brand .pmk-sl-crumbs a:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-sl-crumbs__sep { margin: 0 8px; color: #c5cbd2; }
.pmk-brand .pmk-sl-head { padding: 22px 0 30px; }
.pmk-brand .pmk-sl-h1 { font-size: clamp(30px, 4vw, 46px); font-weight: 800; letter-spacing: -.025em; line-height: 1.1; margin: 0 0 12px; }
.pmk-brand .pmk-sl-head p { color: var(--pmk-muted, #5a6470); font-size: 17px; line-height: 1.5; max-width: 64ch; margin: 0; }

.pmk-brand .pmk-sgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; padding-bottom: 20px; }
.pmk-brand .pmk-sc { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 18px; overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: var(--pmk-ink, #16191c); transition: transform .18s, box-shadow .18s, border-color .18s; }
.pmk-brand .pmk-sc:hover { transform: translateY(-5px); box-shadow: 0 20px 44px rgba(22,25,28,.13); border-color: rgba(200,240,0,.5); }
.pmk-brand .pmk-sc__i { position: relative; height: 200px; overflow: hidden; }
.pmk-brand .pmk-sc__i img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .45s; }
.pmk-brand .pmk-sc:hover .pmk-sc__i img { transform: scale(1.06); }
.pmk-brand .pmk-sc__b { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.pmk-brand .pmk-sc__t { font-size: 20px; font-weight: 800; letter-spacing: -.01em; margin: 0 0 8px; }
.pmk-brand .pmk-sc__d { font-size: 14.5px; color: var(--pmk-muted, #5a6470); margin: 0 0 18px; line-height: 1.45; flex: 1; }
.pmk-brand .pmk-sc__more { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 700; color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-sc__more svg { transition: transform .2s; }
.pmk-brand .pmk-sc:hover .pmk-sc__more svg { transform: translateX(4px); }
@media (max-width: 980px) { .pmk-brand .pmk-sgrid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .pmk-brand .pmk-sgrid { grid-template-columns: 1fr; } }

/* ============ БЛОК contact_cta (контактный CTA, тёмная плашка) ============ */
.pmk-brand .pmk-cta-sec { padding: 26px 0 60px; }
.pmk-brand .pmk-cta { background: var(--pmk-ink, #16191c); color: #fff; border-radius: 24px; padding: 44px; position: relative; overflow: hidden; }
.pmk-brand .pmk-cta::after { content: ""; position: absolute; right: -50px; bottom: -60px; width: 230px; height: 230px; background: var(--pmk-accent, #C8F000); opacity: .1; border-radius: 50%; filter: blur(12px); }
.pmk-brand .pmk-cta__head { position: relative; margin-bottom: 26px; }
.pmk-brand .pmk-cta__eb { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-cta__eb::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent, #C8F000); border-radius: 3px; }
.pmk-brand .pmk-cta__h2 { color: #fff; font-size: clamp(24px, 3vw, 34px); font-weight: 800; letter-spacing: -.02em; margin: 14px 0 8px; }
.pmk-brand .pmk-cta__sub { color: #aab2bb; margin: 0; max-width: 56ch; }
.pmk-brand .pmk-cta__ways { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.pmk-brand .pmk-cta__way { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 16px; padding: 22px; text-decoration: none; color: #fff; display: flex; flex-direction: column; gap: 10px; transition: transform .15s, border-color .15s, background .15s; cursor: pointer; }
.pmk-brand .pmk-cta__way:hover { transform: translateY(-3px); border-color: var(--pmk-accent, #C8F000); background: rgba(255,255,255,.09); }
.pmk-brand .pmk-cta__ic { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pmk-brand .pmk-cta__ic--mail { background: var(--pmk-accent, #C8F000); color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-cta__ic--call { background: rgba(200,240,0,.16); color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-cta__t { font-size: 17px; font-weight: 700; }
.pmk-brand .pmk-cta__v { font-size: 15px; color: #dfe3e8; font-weight: 600; }
.pmk-brand .pmk-cta__copyic { vertical-align: -2px; margin-left: 4px; opacity: .7; }
.pmk-brand .pmk-cta__note { font-size: 13px; color: #8b95a1; }
.pmk-brand .pmk-cta__hint { font-size: 12px; color: var(--pmk-accent, #C8F000); font-weight: 700; opacity: 0; transition: opacity .15s; }
.pmk-brand .pmk-cta__way--mail:hover .pmk-cta__hint { opacity: 1; }
.pmk-brand .pmk-cta__btns { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 2px; }
.pmk-brand .pmk-cta__mbtn { min-width: 0; }
.pmk-brand .pmk-cta__btns > .pmk-cta__mbtn { flex: 1 1 60px; }
.pmk-brand .pmk-cta__mbtn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 6px; border-radius: 10px; font-size: 13px; font-weight: 700; text-decoration: none; border: 1px solid rgba(255,255,255,.16); color: #fff; background: rgba(255,255,255,.05); transition: transform .12s, background .12s, border-color .12s; }
.pmk-brand .pmk-cta__mbtn:hover { transform: translateY(-2px); }
.pmk-brand .pmk-cta__mbtn--mx:hover { background: #6E3CE6; border-color: #6E3CE6; }
.pmk-brand .pmk-cta__mbtn--tg:hover { background: #229ED9; border-color: #229ED9; }
.pmk-brand .pmk-cta__mbtn--wa:hover { background: #25D366; border-color: #25D366; color: var(--pmk-ink, #16191c); }
@media (max-width: 760px) { .pmk-brand .pmk-cta__ways { grid-template-columns: 1fr; } .pmk-brand .pmk-cta { padding: 26px; } }

/* ============ ЛИПКАЯ ШАПКА при скролле (#headerfixed → наш .pmk-fixed) ============ */
/* Показ/позиционирование (#headerfixed.fixed: position:fixed;top:0) — штатное Aspro.
   Состав (Вариант B): лого + меню + телефон-выпадашка + почта. Без поиска/CTA. */
/* Выравнивание контента липкой по границе сайта: убираем штатные #headerfixed 16px
   (у верхней шапки .maxwidth-theme padding:0) — иначе логотип уезжает вправо. */
.pmk-brand #headerfixed .maxwidth-theme.pmk-fixed { padding-left: 0; padding-right: 0; }
.pmk-brand #headerfixed .pmk-fixed { display: flex; align-items: center; gap: 24px; min-height: 64px; }
.pmk-brand #headerfixed .pmk-fixed__logo { flex: 0 0 auto; line-height: 0; }
.pmk-brand #headerfixed .pmk-fixed__logo img { height: 30px !important; width: auto !important; max-width: none; }
.pmk-brand #headerfixed .pmk-fixed__nav { flex: 1 1 auto; min-width: 0; }
.pmk-brand #headerfixed .pmk-fixed__nav .pmk-nav { margin: 0; }

/* контакты справа */
.pmk-brand #headerfixed .pmk-fx-contacts { flex: 0 0 auto; margin-left: auto; display: flex; align-items: center; gap: 22px; }
.pmk-brand #headerfixed .pmk-fx-phone { position: relative; }
.pmk-brand #headerfixed .pmk-fx-phone__btn { display: inline-flex; align-items: center; gap: 7px; background: none; border: 0; cursor: pointer; padding: 0; font: 700 14px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); white-space: nowrap; }
.pmk-brand #headerfixed .pmk-fx-phone__btn svg { color: var(--pmk-ink, #16191c); flex: 0 0 auto; }
.pmk-brand #headerfixed .pmk-fx-phone__btn:hover { color: #000; }
.pmk-brand #headerfixed .pmk-fx-phone .pmk-geo__chev { border-color: var(--pmk-muted, #5a6470); }
.pmk-brand #headerfixed .pmk-fx-phone__menu { left: auto; right: 0; min-width: 250px; }
.pmk-brand #headerfixed .pmk-fx-phone__menu a { display: flex; justify-content: space-between; align-items: center; gap: 14px; padding: 9px 12px; border-radius: 8px; font: 700 14px/1.2 var(--pmk-font); color: var(--pmk-ink, #16191c); text-decoration: none; white-space: nowrap; }
.pmk-brand #headerfixed .pmk-fx-phone__menu a:hover { background: var(--pmk-bg, #f4f5f7); }
.pmk-brand #headerfixed .pmk-fx-phone__menu a i { font-style: normal; font-size: 12px; font-weight: 600; color: #9aa3ad; }
.pmk-brand #headerfixed .pmk-fx-email { display: inline-flex; align-items: center; gap: 7px; font: 700 14px/1 var(--pmk-font); color: var(--pmk-ink, #16191c); text-decoration: none; white-space: nowrap; }
.pmk-brand #headerfixed .pmk-fx-email svg { color: var(--pmk-ink, #16191c); flex: 0 0 auto; }
.pmk-brand #headerfixed .pmk-fx-email:hover { color: #000; }
.pmk-brand #headerfixed .pmk-fx-email .pmk-copied-on { color: var(--pmk-accent, #C8F000); }

/* выравнивание телефона/почты по пунктам меню: тот же кегль 15px; убираем
   нудж шеврона (margin-top:-3px нужен только в тёмной утилити-строке) */
/* единый кегль телефона и почты (на самих текстах !important — перебиваем
   возможное глобальное правило Aspro для ссылок: телефон=button, почта=a) */
.pmk-brand #headerfixed .pmk-fx-phone__btn,
.pmk-brand #headerfixed .pmk-fx-email,
.pmk-brand #headerfixed .pmk-fx-phone__btn > span,
.pmk-brand #headerfixed .pmk-fx-email > span { font-size: 15px !important; }
.pmk-brand #headerfixed .pmk-fx-phone .pmk-geo__chev { margin-top: 0; }
/* иконки — без лайма: чистый тёмный контур (color:ink задан выше у svg) */

@media (max-width: 980px) { .pmk-brand #headerfixed { display: none !important; } } /* на мобайле своя моб-шапка */

/* ===================== КАТАЛОГ — страница направления (.pmk-catalog) ===================== */
.pmk-brand .pmk-catalog { color: var(--pmk-ink, #16191c); font-family: var(--pmk-font); }
.pmk-brand .pmk-cat-wrap { max-width: none; margin: 0; padding: 0; }
.pmk-brand .pmk-cat-crumbs { font: 400 13px/1.4 var(--pmk-font); color: var(--pmk-muted, #5a6470); padding: 16px 0 18px; }
.pmk-brand .pmk-cat-crumbs a { color: var(--pmk-muted, #5a6470); text-decoration: none; }
.pmk-brand .pmk-cat-crumbs a:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-cat-crumbs__sep { margin: 0 8px; color: #c5cbd2; }
.pmk-brand .pmk-cat-grid { display: grid; grid-template-columns: 300px minmax(0, 1fr); gap: 30px; padding-bottom: 60px; align-items: start; }

/* сайдбар-аккордеон */
.pmk-brand .pmk-cat-snav { position: sticky; top: 20px; background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; padding: 8px; }
.pmk-brand .pmk-cat-snav__h { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: #9aa3ad; padding: 12px 14px 10px; }
.pmk-brand .pmk-cat-acc + .pmk-cat-acc { border-top: 1px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-cat-acc__h { width: 100%; display: flex; align-items: center; gap: 11px; padding: 12px 13px; background: none; border: 0; cursor: pointer; text-align: left; border-radius: 10px; transition: background .14s; }
.pmk-brand .pmk-cat-acc__h:hover { background: var(--pmk-bg, #f4f5f7); }
.pmk-brand .pmk-cat-acc__ic { flex: 0 0 auto; color: var(--pmk-muted, #5a6470); display: flex; }
.pmk-brand .pmk-cat-acc__name { flex: 1; font-size: 14px; font-weight: 700; color: #2c333b; line-height: 1.25; text-decoration: none; }
.pmk-brand .pmk-cat-acc__chev { flex: 0 0 auto; opacity: .5; transition: transform .2s; color: var(--pmk-muted, #5a6470); transform: rotate(-90deg); }
.pmk-brand .pmk-cat-acc__body { display: none; padding: 2px 0 8px; }
.pmk-brand .pmk-cat-acc.is-open > .pmk-cat-acc__body { display: block; }
.pmk-brand .pmk-cat-acc.is-open > .pmk-cat-acc__h .pmk-cat-acc__name { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-cat-acc.is-open > .pmk-cat-acc__h .pmk-cat-acc__chev { opacity: 1; color: var(--pmk-accent, #C8F000); transform: rotate(0deg); }
.pmk-brand .pmk-cat-acc.is-active > .pmk-cat-acc__h { background: var(--pmk-ink, #16191c); border-radius: 10px; }
.pmk-brand .pmk-cat-acc.is-active > .pmk-cat-acc__h .pmk-cat-acc__name { color: #fff; }
.pmk-brand .pmk-cat-acc.is-active > .pmk-cat-acc__h .pmk-cat-acc__ic { color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-cat-acc.is-active > .pmk-cat-acc__h .pmk-cat-acc__chev { color: var(--pmk-accent, #C8F000); opacity: 1; }
.pmk-brand .pmk-cat-acc__sub { display: block; padding: 8px 13px 8px 44px; font-size: 13.5px; font-weight: 600; color: var(--pmk-muted, #5a6470); text-decoration: none; border-radius: 8px; }
.pmk-brand .pmk-cat-acc__sub:hover { background: var(--pmk-bg, #f4f5f7); color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-cat-acc__sub.is-cur { background: var(--pmk-bg, #f4f5f7); color: var(--pmk-ink, #16191c); font-weight: 800; }

/* фото-полоса hero */
.pmk-brand .pmk-cat-hero { position: relative; border-radius: 18px; overflow: hidden; min-height: 230px; display: flex; align-items: flex-end; background: linear-gradient(120deg, #2b3340, #16191c); }
.pmk-brand .pmk-cat-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.pmk-brand .pmk-cat-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(15,17,19,.88) 0%, rgba(15,17,19,.6) 45%, rgba(15,17,19,.2) 100%); }
.pmk-brand .pmk-cat-hero__c { position: relative; z-index: 2; padding: 28px 32px; max-width: 62%; }
.pmk-brand .pmk-cat-hero .pmk-cat-hero__h1 { color: #fff; font-size: clamp(26px, 3.2vw, 38px); font-weight: 800; letter-spacing: -.025em; margin: 0 0 10px; }
.pmk-brand .pmk-cat-hero__c p { color: #d4dae0; font-size: 15.5px; margin: 0 0 14px; }
.pmk-brand .pmk-cat-tags { display: flex; gap: 7px; flex-wrap: wrap; }
.pmk-brand .pmk-cat-tag { background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); color: #fff; border-radius: 999px; padding: 6px 13px; font-size: 12.5px; font-weight: 600; }

/* заголовок секции + сетка изделий */
.pmk-brand .pmk-cat-secttl { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--pmk-muted, #5a6470); margin: 30px 0 16px; display: flex; align-items: center; gap: 10px; }
.pmk-brand .pmk-cat-secttl::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent, #C8F000); border-radius: 3px; }
.pmk-brand .pmk-cat-igrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pmk-brand .pmk-cat-ic { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: var(--pmk-ink, #16191c); transition: transform .18s, box-shadow .18s, border-color .18s; }
.pmk-brand .pmk-cat-ic:hover { transform: translateY(-5px); box-shadow: 0 18px 40px rgba(22,25,28,.13); border-color: rgba(200,240,0,.5); }
.pmk-brand .pmk-cat-ic__i { height: 165px; overflow: hidden; background: linear-gradient(135deg, #2b3340, #454f5e); }
.pmk-brand .pmk-cat-ic__i img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .45s; }
.pmk-brand .pmk-cat-ic:hover .pmk-cat-ic__i img { transform: scale(1.06); }
.pmk-brand .pmk-cat-ic__b { padding: 17px 18px; display: flex; flex-direction: column; flex: 1; }
.pmk-brand .pmk-cat-ic__t { font-size: 17px; font-weight: 800; letter-spacing: -.01em; margin: 0 0 6px; }
.pmk-brand .pmk-cat-ic__d { font-size: 13.5px; color: var(--pmk-muted, #5a6470); margin: 0 0 14px; line-height: 1.45; flex: 1; }
.pmk-brand .pmk-cat-ic__m { display: inline-flex; align-items: center; gap: 6px; font-size: 13.5px; font-weight: 700; color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-cat-ic__m svg { transition: transform .2s; }
.pmk-brand .pmk-cat-ic:hover .pmk-cat-ic__m svg { transform: translateX(4px); }

/* о направлении */
.pmk-brand .pmk-cat-about { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; padding: 28px; margin-top: 26px; }
.pmk-brand .pmk-cat-about h2 { font-size: 22px; font-weight: 800; margin: 0 0 12px; }
.pmk-brand .pmk-cat-about__txt { color: #39414a; line-height: 1.6; }
.pmk-brand .pmk-cat-about__txt p { margin: 0 0 12px; }
.pmk-brand .pmk-cat-about__txt p:last-child { margin: 0; }

/* CTA */
.pmk-brand .pmk-cat-cta { background: var(--pmk-ink, #16191c); color: #fff; border-radius: 18px; padding: 32px; text-align: center; position: relative; overflow: hidden; margin-top: 26px; }
.pmk-brand .pmk-cat-cta::after { content: ""; position: absolute; right: -40px; top: -40px; width: 160px; height: 160px; background: var(--pmk-accent, #C8F000); opacity: .14; border-radius: 50%; filter: blur(8px); }
.pmk-brand .pmk-cat-cta h2 { color: #fff; font-size: 24px; font-weight: 800; margin: 0 0 8px; position: relative; }
.pmk-brand .pmk-cat-cta p { color: #aab2bb; margin: 0 0 18px; position: relative; }
.pmk-brand .pmk-cat-cta__row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; position: relative; }
.pmk-brand .pmk-cat-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 700; font-size: 15px; border: none; cursor: pointer; padding: 13px 24px; border-radius: var(--pmk-radius-btn, 11px); text-decoration: none; }
.pmk-brand .pmk-cat-btn--p { background: var(--pmk-accent, #C8F000); color: var(--pmk-accent-ink, #16191c); }
.pmk-brand .pmk-cat-btn--g { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.28); }

/* адаптив каталога */
@media (max-width: 980px) {
  .pmk-brand .pmk-catalog { overflow-x: hidden; } /* без сайдбара sticky нет — клипать безопасно */
  .pmk-brand .pmk-cat-grid { grid-template-columns: minmax(0, 1fr); }
  .pmk-brand .pmk-cat-snav { display: none; }
  .pmk-brand .pmk-cat-igrid { grid-template-columns: 1fr 1fr; }
  .pmk-brand .pmk-cat-hero__c { max-width: 100%; }
  .pmk-brand .pmk-cat-crumbs { overflow-wrap: anywhere; }
}
@media (max-width: 640px) {
  .pmk-brand .pmk-cat-igrid { grid-template-columns: 1fr; }
  .pmk-brand .pmk-cat-hero__c { padding: 20px; }
}

/* ===================== ПОСАДОЧНАЯ ИЗДЕЛИЯ (.pmk-izd-*) ===================== */
/* кнопка-призрак на белом (hero посадочной) */
.pmk-brand .pmk-cat-btn--gd { background: transparent; color: var(--pmk-ink, #16191c); border: 1.5px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-cat-btn--gd:hover { border-color: var(--pmk-ink, #16191c); }

/* hero изделия */
.pmk-brand .pmk-izd-hero { display: grid; grid-template-columns: 1.1fr .9fr; gap: 34px; align-items: center; margin-bottom: 4px; }
.pmk-brand .pmk-izd-h1 { font-size: clamp(27px, 3.4vw, 40px); font-weight: 800; letter-spacing: -.02em; line-height: 1.08; margin: 0 0 14px; }
.pmk-brand .pmk-izd-hero__sub { color: var(--pmk-muted, #5a6470); font-size: 16.5px; line-height: 1.5; margin: 0 0 20px; }
.pmk-brand .pmk-izd-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 22px; }
.pmk-brand .pmk-izd-tag { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 999px; padding: 8px 15px; font-size: 13px; font-weight: 600; color: #39414a; }
.pmk-brand .pmk-izd-acts { display: flex; gap: 12px; flex-wrap: wrap; }
.pmk-brand .pmk-izd-hero__img { border-radius: 18px; overflow: hidden; border: 1px solid var(--pmk-line, #e3e6ea); aspect-ratio: 4/3; box-shadow: 0 16px 40px rgba(22,25,28,.12); }
.pmk-brand .pmk-izd-hero__img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* описание */
.pmk-brand .pmk-izd-prose { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 16px; padding: 26px; color: #39414a; line-height: 1.6; }
.pmk-brand .pmk-izd-prose p { margin: 0 0 12px; }
.pmk-brand .pmk-izd-prose p:last-child { margin: 0; }
.pmk-brand .pmk-izd-prose .hl { background: rgba(200,240,0,.18); padding: 1px 6px; border-radius: 5px; font-weight: 600; }

/* применение */
.pmk-brand .pmk-izd-use { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.pmk-brand .pmk-izd-uc { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 14px; padding: 18px; }
.pmk-brand .pmk-izd-uc__i { width: 40px; height: 40px; border-radius: 11px; background: rgba(200,240,0,.16); color: var(--pmk-ink, #16191c); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 11px; }
.pmk-brand .pmk-izd-uc h3 { font-size: 15.5px; font-weight: 800; margin: 0 0 5px; }
.pmk-brand .pmk-izd-uc p { font-size: 13.5px; color: var(--pmk-muted, #5a6470); margin: 0; }

/* таблица типоразмеров (режим А) — стилизуем любую table внутри обёртки */
.pmk-brand .pmk-izd-sizes-wrap { overflow-x: auto; border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 14px; -webkit-overflow-scrolling: touch; }
.pmk-brand .pmk-izd-sizes-wrap table { width: 100%; min-width: 560px; border-collapse: collapse; background: var(--pmk-surface, #fff); }
.pmk-brand .pmk-izd-sizes-wrap thead th, .pmk-brand .pmk-izd-sizes-wrap tr:first-child th { background: var(--pmk-ink, #16191c); color: #fff; font: 700 13px/1.2 var(--pmk-font); text-transform: uppercase; letter-spacing: .03em; padding: 13px 16px; text-align: left; white-space: nowrap; }
.pmk-brand .pmk-izd-sizes-wrap td { padding: 12px 16px; font-size: 14px; border-top: 1px solid var(--pmk-line, #e3e6ea); white-space: nowrap; }
.pmk-brand .pmk-izd-sizes-wrap tbody tr:nth-child(even) { background: var(--pmk-bg, #f4f5f7); }
.pmk-brand .pmk-izd-sizes-wrap td:first-child { font-weight: 700; }
.pmk-brand .pmk-izd-note { font-size: 13px; color: var(--pmk-muted, #5a6470); margin-top: 10px; }

/* характеристики key-value (режим Б) */
.pmk-brand .pmk-izd-specs { width: 100%; border-collapse: collapse; background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 14px; overflow: hidden; }
.pmk-brand .pmk-izd-specs tr + tr { border-top: 1px solid var(--pmk-line, #e3e6ea); }
.pmk-brand .pmk-izd-specs th, .pmk-brand .pmk-izd-specs td { text-align: left; padding: 13px 18px; font-size: 14.5px; }
.pmk-brand .pmk-izd-specs th { color: var(--pmk-muted, #5a6470); font-weight: 600; width: 48%; }
.pmk-brand .pmk-izd-specs td { color: var(--pmk-ink, #16191c); font-weight: 700; }

/* SEO-блок «О изделии» */
.pmk-brand .pmk-izd-seo { margin-top: 36px; color: #39414a; line-height: 1.6; }
.pmk-brand .pmk-izd-seo h2 { font-size: clamp(20px, 2.4vw, 26px); font-weight: 800; letter-spacing: -.02em; color: var(--pmk-ink, #16191c); margin: 0 0 12px; }
.pmk-brand .pmk-izd-seo p { margin: 0 0 12px; }

@media (max-width: 980px) {
  .pmk-brand .pmk-izd-hero { grid-template-columns: 1fr; gap: 22px; }
  .pmk-brand .pmk-izd-hero__img { order: -1; }
  .pmk-brand .pmk-izd-use { grid-template-columns: 1fr; }
}

/* ===================== КАТАЛОГ — ВИТРИНА (Ур.0, .pmk-vit-*) ===================== */
.pmk-brand .pmk-vit-head { padding: 0 0 26px; max-width: 820px; }
.pmk-brand .pmk-vit-eb { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--pmk-muted, #5a6470); margin-bottom: 14px; }
.pmk-brand .pmk-vit-eb::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent, #C8F000); border-radius: 3px; }
.pmk-brand .pmk-vit-h1 { font-size: clamp(30px, 4vw, 46px); font-weight: 800; letter-spacing: -.025em; line-height: 1.05; margin: 0 0 12px; }
.pmk-brand .pmk-vit-head p { color: var(--pmk-muted, #5a6470); font-size: 17px; line-height: 1.5; margin: 0; }
.pmk-brand .pmk-vit-fullcycle { display: inline-flex; align-items: center; gap: 9px; margin-top: 14px; font-size: 15px; font-weight: 700; color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-vit-fullcycle svg { color: var(--pmk-accent, #C8F000); flex: 0 0 auto; }
.pmk-brand .pmk-vit-dim { color: var(--pmk-muted, #5a6470); font-weight: 600; }

.pmk-brand .pmk-vit-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; padding-bottom: 4px; }
.pmk-brand .pmk-vit-tile { background: var(--pmk-surface, #fff); border: 1px solid var(--pmk-line, #e3e6ea); border-radius: 18px; overflow: hidden; display: flex; flex-direction: column; transition: box-shadow .2s, border-color .2s; }
.pmk-brand .pmk-vit-tile:hover { box-shadow: 0 18px 40px rgba(22,25,28,.12); border-color: rgba(200,240,0,.5); }
.pmk-brand .pmk-vit-tile__i { display: block; height: 170px; overflow: hidden; background: linear-gradient(135deg, #2b3340, #454f5e); }
.pmk-brand .pmk-vit-tile__i img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s; }
.pmk-brand .pmk-vit-tile:hover .pmk-vit-tile__i img { transform: scale(1.05); }
.pmk-brand .pmk-vit-tile__b { padding: 20px 22px 22px; }
.pmk-brand .pmk-vit-tile__t { display: inline-flex; align-items: center; gap: 8px; font-size: 20px; font-weight: 800; letter-spacing: -.01em; color: var(--pmk-ink, #16191c); text-decoration: none; margin-bottom: 14px; }
.pmk-brand .pmk-vit-tile__t svg { color: var(--pmk-muted, #5a6470); transition: transform .2s, color .2s; }
.pmk-brand .pmk-vit-tile:hover .pmk-vit-tile__t svg { transform: translateX(4px); color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-vit-tile__subs { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 14px; }
.pmk-brand .pmk-vit-tile__sub { display: flex; align-items: flex-start; gap: 7px; padding: 6px 0; font-size: 14px; color: var(--pmk-muted, #5a6470); text-decoration: none; line-height: 1.3; }
.pmk-brand .pmk-vit-tile__sub:hover { color: var(--pmk-ink, #16191c); }
.pmk-brand .pmk-vit-tile__sub::before { content: "›"; color: var(--pmk-accent, #C8F000); font-weight: 800; flex: 0 0 auto; }

@media (max-width: 980px) { .pmk-brand .pmk-vit-grid { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .pmk-brand .pmk-vit-tile__subs { grid-template-columns: 1fr 1fr; } }

/* ===================== ГЛАВНАЯ (плиточная, .pmk-h-*) ===================== */
.pmk-brand .pmk-home { color: var(--pmk-ink, #16191c); font-family: var(--pmk-font); }
/* index рендерится ВНЕ Aspro-колонки (на всю ширину) → свой жёлоб под край шапки:
   max-width и padding как у header .maxwidth-theme, чтобы контент шёл ровно по логотипу. */
.pmk-brand .pmk-h-wrap { max-width: 1516px; margin: 0 auto; padding: 0 40px; }
.pmk-brand .pmk-h-sec { padding: 54px 0; }
.pmk-brand .pmk-h-sec--t0 { padding-top: 0; }
/* плавный скролл по якорям hero + отступ под sticky-шапку (чтобы секция не пряталась) */
html { scroll-behavior: smooth; }
.pmk-brand .pmk-h-sec[id] { scroll-margin-top: 96px; }
.pmk-brand .pmk-h-sec__h { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 26px; }
.pmk-brand .pmk-h-sec h2 { font-size: clamp(25px,3.2vw,36px); font-weight: 800; line-height: 1.1; letter-spacing: -.02em; margin: 0; }
.pmk-brand .pmk-h-sec__sub { color: var(--pmk-muted, #5a6470); font-size: 16px; margin-top: 8px; max-width: 60ch; }
.pmk-brand .pmk-h-eb { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--pmk-muted, #5a6470); margin-bottom: 12px; }
.pmk-brand .pmk-h-eb::before { content:""; width:12px; height:12px; background: var(--pmk-accent, #C8F000); border-radius:3px; }
.pmk-brand .pmk-h-cnt { display:inline-flex; align-items:center; justify-content:center; min-width:34px; height:26px; padding:0 9px; margin-left:8px; background:var(--pmk-accent, #C8F000); color:var(--pmk-accent-ink, #16191c); border-radius:999px; font-size:15px; font-weight:800; vertical-align:middle; }
.pmk-brand .pmk-h-seclink { display:inline-flex; align-items:center; gap:7px; font-size:14.5px; font-weight:700; color:var(--pmk-ink, #16191c); text-decoration:none; white-space:nowrap; }
.pmk-brand .pmk-h-seclink svg { transition:transform .2s; }
.pmk-brand .pmk-h-seclink:hover svg { transform:translateX(4px); }
.pmk-brand .pmk-cat-btn--gw { background: transparent; color:#fff; border:1.5px solid rgba(255,255,255,.28); }
.pmk-brand .pmk-cat-btn--gw:hover { border-color: rgba(255,255,255,.6); }

.pmk-brand .pmk-h-hero { padding: 20px 0 0; }
.pmk-brand .pmk-h-hero__in { position:relative; border-radius:22px; overflow:hidden; background:var(--pmk-ink, #16191c); display:flex; align-items:stretch; }
.pmk-brand .pmk-h-hero__bg { position:absolute; inset:0; }
.pmk-brand .pmk-h-hero__bg img { width:100%; height:100%; object-fit:cover; opacity:.42; }
.pmk-brand .pmk-h-hero__in::after { content:""; position:absolute; inset:0; background:linear-gradient(100deg,rgba(15,17,19,.92) 0%,rgba(15,17,19,.7) 45%,rgba(15,17,19,.25) 100%); }
.pmk-brand .pmk-h-hero__c { position:relative; z-index:2; padding:32px; display:grid; grid-template-columns:1.3fr .9fr; gap:30px; align-items:center; width:100%; }
.pmk-brand .pmk-h-hero__c .pmk-h-eb { color: var(--pmk-accent, #C8F000); margin-bottom:10px; }
.pmk-brand .pmk-h-hero__left h1 { color:#fff; font-size:clamp(26px,3.2vw,40px); font-weight:800; line-height:1.06; letter-spacing:-.02em; margin:0 0 12px; }
.pmk-brand .pmk-h-lime { color: var(--pmk-accent, #C8F000); }
.pmk-brand .pmk-h-hero__left p { color:#cfd5db; font-size:15.5px; line-height:1.5; margin:0; max-width:52ch; }
/* hero: навигация-якоря по странице (вместо кнопок CTA — CTA живёт в sticky-шапке) */
.pmk-brand .pmk-h-hero__nav { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.13); border-radius:18px; padding:16px 22px; }
.pmk-brand .pmk-h-hero__nav-h { font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#aab2bb; margin-bottom:6px; }
.pmk-brand .pmk-h-hero__navlist { display:grid; grid-template-columns:1fr 1fr; gap:0 22px; }
.pmk-brand .pmk-h-hero__navi { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:9px 2px; min-height:44px; color:#fff; text-decoration:none; font-size:15.5px; font-weight:600; border-bottom:1px solid rgba(255,255,255,.08); transition:color .15s; }
.pmk-brand .pmk-h-hero__navi svg { color:var(--pmk-accent,#C8F000); flex:none; transition:transform .2s; }
.pmk-brand .pmk-h-hero__navi:hover { color:var(--pmk-accent,#C8F000); }
.pmk-brand .pmk-h-hero__navi:hover svg { transform:translateX(4px); }

.pmk-brand .pmk-h-cycle { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.pmk-brand .pmk-h-cstep { background:var(--pmk-surface, #fff); border:1px solid var(--pmk-line, #e3e6ea); border-radius:14px; padding:20px 18px; }
.pmk-brand .pmk-h-cstep__n { width:30px; height:30px; border-radius:9px; background:var(--pmk-ink, #16191c); color:var(--pmk-accent, #C8F000); font-weight:800; font-size:14px; display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.pmk-brand .pmk-h-cstep__t { font-size:15.5px; font-weight:800; margin-bottom:5px; }
.pmk-brand .pmk-h-cstep__d { font-size:13px; color:var(--pmk-muted, #5a6470); line-height:1.4; }
.pmk-brand .pmk-h-cycle__note { text-align:center; margin-top:18px; font-size:14.5px; color:var(--pmk-muted, #5a6470); }
.pmk-brand .pmk-h-cycle__note b { color:var(--pmk-ink, #16191c); }
/* компактный мобильный степпер цикла (виден только ≤640, см. медиа-запрос) */
.pmk-brand .pmk-h-cycle-m { display:none; flex-direction:column; background:var(--pmk-surface,#fff); border:1px solid var(--pmk-line,#e3e6ea); border-radius:14px; overflow:hidden; }
.pmk-brand .pmk-h-mcstep { display:flex; align-items:center; gap:12px; padding:13px 16px; }
.pmk-brand .pmk-h-mcstep + .pmk-h-mcstep { border-top:1px solid var(--pmk-line,#e3e6ea); }
.pmk-brand .pmk-h-mcstep__n { width:26px; height:26px; border-radius:7px; background:var(--pmk-ink,#16191c); color:var(--pmk-accent,#C8F000); font-weight:800; font-size:13px; display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.pmk-brand .pmk-h-mcstep__t { font-size:15px; font-weight:700; }

.pmk-brand .pmk-h-dirs { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.pmk-brand .pmk-h-dirtile { background:var(--pmk-surface,#fff); border:1px solid var(--pmk-line,#e3e6ea); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .18s, border-color .18s; }
.pmk-brand .pmk-h-dirtile:hover { box-shadow:0 14px 34px rgba(22,25,28,.12); border-color:rgba(200,240,0,.5); }
.pmk-brand .pmk-h-dirtile__top { position:relative; display:block; height:150px; overflow:hidden; background:linear-gradient(135deg,#2b3340,#454f5e); }
.pmk-brand .pmk-h-dirtile__top img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.pmk-brand .pmk-h-dirtile:hover .pmk-h-dirtile__top img { transform:scale(1.06); }
.pmk-brand .pmk-h-dirtile__top::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(15,17,19,0) 45%,rgba(15,17,19,.8) 100%); }
.pmk-brand .pmk-h-dirtile__t { position:absolute; left:16px; bottom:13px; z-index:2; color:#fff; font-size:18px; font-weight:800; }
.pmk-brand .pmk-h-dirtile__subs { display:grid; grid-template-columns:1fr 1fr; gap:1px 14px; padding:14px 16px 16px; }
.pmk-brand .pmk-h-dirtile__sub { display:flex; align-items:flex-start; gap:6px; font-size:13px; color:var(--pmk-muted,#5a6470); padding:5px 0; line-height:1.3; text-decoration:none; transition:color .12s; }
.pmk-brand .pmk-h-dirtile__sub::before { content:"›"; color:var(--pmk-accent,#C8F000); font-weight:800; flex:0 0 auto; }
.pmk-brand .pmk-h-dirtile__sub:hover { color:var(--pmk-ink,#16191c); }
/* мобильные чипсы подпунктов (нормальным потоком под фото; видны только ≤640) */
.pmk-brand .pmk-h-dirtile__mchips { display:none; }
.pmk-brand .pmk-h-dirtile__mchip { background:var(--pmk-bg,#f4f5f7); border:1px solid var(--pmk-line,#e3e6ea); color:#39414a; font-size:13px; font-weight:600; padding:7px 13px; border-radius:999px; text-decoration:none; }

.pmk-brand .pmk-h-svcs { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.pmk-brand .pmk-h-svc { background:var(--pmk-surface, #fff); border:1px solid var(--pmk-line, #e3e6ea); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; text-decoration:none; color:var(--pmk-ink, #16191c); transition:transform .18s,box-shadow .18s,border-color .18s; }
.pmk-brand .pmk-h-svc:hover { transform:translateY(-5px); box-shadow:0 18px 40px rgba(22,25,28,.12); border-color:rgba(200,240,0,.5); }
.pmk-brand .pmk-h-svc__i { height:170px; overflow:hidden; }
.pmk-brand .pmk-h-svc__i img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.pmk-brand .pmk-h-svc:hover .pmk-h-svc__i img { transform:scale(1.05); }
.pmk-brand .pmk-h-svc__b { padding:20px; display:flex; flex-direction:column; flex:1; }
.pmk-brand .pmk-h-svc__t { font-size:18px; font-weight:800; margin-bottom:7px; }
.pmk-brand .pmk-h-svc__d { font-size:14px; color:var(--pmk-muted, #5a6470); line-height:1.45; margin-bottom:16px; flex:1; }
.pmk-brand .pmk-h-svc__m { display:inline-flex; align-items:center; gap:6px; font-size:14px; font-weight:700; color:var(--pmk-ink, #16191c); }
.pmk-brand .pmk-h-svc__m svg { transition:transform .2s; }
.pmk-brand .pmk-h-svc:hover .pmk-h-svc__m svg { transform:translateX(4px); }

.pmk-brand .pmk-h-equip { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.pmk-brand .pmk-h-ecard { background:var(--pmk-surface, #fff); border:1px solid var(--pmk-line, #e3e6ea); border-radius:16px; overflow:hidden; }
.pmk-brand .pmk-h-ecard__b { padding:18px 20px; }
.pmk-brand .pmk-h-ecard__t { font-size:16px; font-weight:800; margin-bottom:5px; }
.pmk-brand .pmk-h-ecard__d { font-size:13px; color:var(--pmk-muted, #5a6470); line-height:1.4; }

.pmk-brand .pmk-h-projs { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.pmk-brand .pmk-h-pcard { background:var(--pmk-surface, #fff); border:1px solid var(--pmk-line, #e3e6ea); border-radius:16px; overflow:hidden; text-decoration:none; color:var(--pmk-ink, #16191c); display:block; transition:transform .18s, box-shadow .18s; }
.pmk-brand .pmk-h-pcard:hover { transform:translateY(-4px); box-shadow:0 14px 34px rgba(22,25,28,.1); }
.pmk-brand .pmk-h-pcard__i { position:relative; height:200px; overflow:hidden; background:linear-gradient(135deg,#2b3340,#454f5e); }
.pmk-brand .pmk-h-pcard__i img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.pmk-brand .pmk-h-pcard:hover .pmk-h-pcard__i img { transform:scale(1.05); }
.pmk-brand .pmk-h-pcard__badge { position:absolute; left:12px; top:12px; background:var(--pmk-accent, #C8F000); color:var(--pmk-accent-ink, #16191c); font-weight:800; font-size:14px; padding:5px 10px; border-radius:8px; }
.pmk-brand .pmk-h-pcard__badge i { font-style:normal; font-weight:600; font-size:11px; }
.pmk-brand .pmk-h-pcard__b { padding:16px 18px; }
.pmk-brand .pmk-h-pcard__m { font-size:13px; color:var(--pmk-muted, #5a6470); font-weight:600; margin-bottom:5px; }
.pmk-brand .pmk-h-pcard__t { font-size:17px; font-weight:800; }

.pmk-brand .pmk-h-news { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.pmk-brand .pmk-h-ncard { background:var(--pmk-surface, #fff); border:1px solid var(--pmk-line, #e3e6ea); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; text-decoration:none; color:var(--pmk-ink, #16191c); transition:transform .18s,box-shadow .18s; }
.pmk-brand .pmk-h-ncard:hover { transform:translateY(-4px); box-shadow:0 14px 34px rgba(22,25,28,.1); }
.pmk-brand .pmk-h-ncard__i { height:165px; overflow:hidden; }
.pmk-brand .pmk-h-ncard__i img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.pmk-brand .pmk-h-ncard:hover .pmk-h-ncard__i img { transform:scale(1.05); }
.pmk-brand .pmk-h-ncard__b { padding:18px; display:flex; flex-direction:column; flex:1; }
.pmk-brand .pmk-h-ncard__date { font-size:12.5px; font-weight:700; color:#8a9410; text-transform:uppercase; letter-spacing:.03em; margin-bottom:8px; }
.pmk-brand .pmk-h-ncard__t { font-size:16.5px; font-weight:800; margin-bottom:7px; line-height:1.25; }
.pmk-brand .pmk-h-ncard__d { font-size:13.5px; color:var(--pmk-muted, #5a6470); line-height:1.45; }

.pmk-brand .pmk-h-licwrap { background:var(--pmk-ink, #16191c); border-radius:22px; padding:40px; position:relative; overflow:hidden; }
.pmk-brand .pmk-h-licwrap::after { content:""; position:absolute; right:-50px; top:-50px; width:200px; height:200px; background:var(--pmk-accent, #C8F000); opacity:.1; border-radius:50%; filter:blur(10px); }
.pmk-brand .pmk-h-licwrap .pmk-h-eb { color:var(--pmk-accent, #C8F000); position:relative; }
.pmk-brand .pmk-h-licwrap h2 { color:#fff; position:relative; }
.pmk-brand .pmk-h-licwrap .pmk-h-sec__sub { color:#aab2bb; position:relative; }
.pmk-brand .pmk-h-lics { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:24px; position:relative; }
.pmk-brand .pmk-h-lcard { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:20px; }
.pmk-brand .pmk-h-lcard__ic { width:46px; height:46px; border-radius:12px; background:rgba(200,240,0,.16); color:var(--pmk-accent, #C8F000); display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.pmk-brand .pmk-h-lcard__t { color:#fff; font-size:15.5px; font-weight:800; margin-bottom:5px; }
.pmk-brand .pmk-h-lcard__d { color:#aab2bb; font-size:12.5px; line-height:1.4; }
.pmk-brand .pmk-h-licbtn { position:relative; display:inline-flex; align-items:center; gap:10px; margin-top:26px; padding:14px 26px; background:var(--pmk-accent, #C8F000); color:var(--pmk-ink, #16191c); border-radius:12px; font-size:15px; font-weight:800; text-decoration:none; transition:transform .15s, box-shadow .15s; }
.pmk-brand .pmk-h-licbtn:hover { transform:translateY(-2px); box-shadow:0 12px 28px rgba(200,240,0,.25); }
.pmk-brand .pmk-h-licbtn svg { flex:0 0 auto; }

/* ===================== СТРАНИЦЫ КОМПАНИИ (.pmk-cpage: О компании, Сертификаты) ===================== */
.pmk-brand.pmk-cpage { padding:6px 0 60px; color:var(--pmk-ink,#16191c); font-family:var(--pmk-font); }
.pmk-brand .pmk-cpage__eb { display:inline-flex; align-items:center; gap:10px; font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--pmk-muted,#5a6470); margin-bottom:14px; }
.pmk-brand .pmk-cpage__eb::before { content:""; width:12px; height:12px; background:var(--pmk-accent,#C8F000); border-radius:3px; }
.pmk-brand .pmk-cpage__h1 { font-size:clamp(28px,3.6vw,42px); font-weight:800; letter-spacing:-.025em; line-height:1.08; margin:0 0 16px; }
.pmk-brand .pmk-cpage__lead { color:var(--pmk-muted,#5a6470); font-size:17px; line-height:1.55; max-width:760px; margin:0 0 32px; }
.pmk-brand .pmk-cpage__note { color:var(--pmk-muted,#5a6470); font-size:14px; margin-top:28px; }
.pmk-brand .pmk-cpage__grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px; }
.pmk-brand .pmk-cpage__card { display:flex; flex-direction:column; gap:6px; padding:22px; border:1px solid var(--pmk-line,#e3e6ea); border-radius:16px; background:var(--pmk-surface,#fff); text-decoration:none; transition:transform .15s,border-color .15s,box-shadow .15s; }
.pmk-brand .pmk-cpage__card:hover { transform:translateY(-3px); border-color:rgba(200,240,0,.55); box-shadow:0 14px 30px rgba(22,25,28,.08); }
.pmk-brand .pmk-cpage__card-t { font-size:18px; font-weight:800; color:var(--pmk-ink,#16191c); }
.pmk-brand .pmk-cpage__card-d { font-size:13.5px; color:var(--pmk-muted,#5a6470); }
.pmk-brand .pmk-lic-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px; }
.pmk-brand .pmk-lic-card { display:flex; flex-direction:column; text-decoration:none; border:1px solid var(--pmk-line,#e3e6ea); border-radius:16px; overflow:hidden; background:var(--pmk-surface,#fff); transition:transform .15s,box-shadow .15s,border-color .15s; }
.pmk-brand .pmk-lic-card:hover { transform:translateY(-3px); border-color:rgba(200,240,0,.55); box-shadow:0 16px 34px rgba(22,25,28,.12); }
.pmk-brand .pmk-lic-card__img { display:block; aspect-ratio:3/4; background:var(--pmk-bg,#f4f5f7); overflow:hidden; }
.pmk-brand .pmk-lic-card__img img { width:100%; height:100%; object-fit:contain; display:block; padding:10px; }
.pmk-brand .pmk-lic-card__t { padding:14px 16px; font-size:14.5px; font-weight:700; color:var(--pmk-ink,#16191c); border-top:1px solid var(--pmk-line,#e3e6ea); }
@media (max-width:980px){ .pmk-brand .pmk-cpage__grid, .pmk-brand .pmk-lic-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:560px){ .pmk-brand .pmk-cpage__grid, .pmk-brand .pmk-lic-grid { grid-template-columns:1fr; } }

.pmk-brand .pmk-h-why { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.pmk-brand .pmk-h-wcard { background:var(--pmk-surface, #fff); border:1px solid var(--pmk-line, #e3e6ea); border-radius:16px; padding:24px; }
.pmk-brand .pmk-h-wcard__ic { width:44px; height:44px; border-radius:11px; background:rgba(200,240,0,.16); color:var(--pmk-ink, #16191c); display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.pmk-brand .pmk-h-wcard__t { font-size:17px; font-weight:800; margin-bottom:6px; }
.pmk-brand .pmk-h-wcard__d { font-size:14px; color:var(--pmk-muted, #5a6470); line-height:1.5; }

@media (max-width:1080px) { .pmk-brand .pmk-h-cycle { grid-template-columns:repeat(3,1fr); } .pmk-brand .pmk-h-equip, .pmk-brand .pmk-h-lics { grid-template-columns:repeat(2,1fr); } }
@media (max-width:900px) { .pmk-brand .pmk-h-dirs, .pmk-brand .pmk-h-projs, .pmk-brand .pmk-h-news, .pmk-brand .pmk-h-why, .pmk-brand .pmk-h-svcs { grid-template-columns:1fr 1fr; } .pmk-brand .pmk-h-hero__c { grid-template-columns:1fr; gap:22px; padding:28px; } }
@media (max-width:600px) { .pmk-brand .pmk-h-wrap { padding:0 16px; } .pmk-brand .pmk-h-cycle, .pmk-brand .pmk-h-dirs, .pmk-brand .pmk-h-svcs, .pmk-brand .pmk-h-equip, .pmk-brand .pmk-h-projs, .pmk-brand .pmk-h-news, .pmk-brand .pmk-h-why, .pmk-brand .pmk-h-lics { grid-template-columns:1fr; } .pmk-brand .pmk-h-sec { padding:40px 0; } .pmk-brand .pmk-h-licwrap { padding:24px; } .pmk-brand .pmk-h-hero__c { padding:24px; } .pmk-brand .pmk-h-hero__navlist { grid-template-columns:1fr; } .pmk-brand .pmk-h-sec[id] { scroll-margin-top:80px; } }
/* мобайл: компактный степпер вместо крупных карточек цикла; подпункты направлений скрыты */
@media (max-width:640px) {
	.pmk-brand .pmk-h-cycle { display:none; }
	.pmk-brand .pmk-h-cycle-m { display:flex; }
	.pmk-brand .pmk-h-dirtile__subs { display:none; }
	.pmk-brand .pmk-h-dirtile__mchips { display:flex; flex-wrap:wrap; gap:7px; padding:14px 16px 16px; }
	.pmk-brand .pmk-h-dirtile__top { height:170px; }
}

/* ===================== КОНТАКТНЫЙ БЛОК — СВЕТЛАЯ ТЕМА (.pmk-cta--light) ===================== */
.pmk-brand .pmk-cta--light { background: var(--pmk-surface,#fff); color: var(--pmk-ink,#16191c); border: 1px solid var(--pmk-line,#e3e6ea); }
.pmk-brand .pmk-cta--light::after { display: none; }
.pmk-brand .pmk-cta--light .pmk-cta__h2 { color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-cta--light .pmk-cta__sub { color: var(--pmk-muted,#5a6470); }
.pmk-brand .pmk-cta--light .pmk-cta__way { background: var(--pmk-bg,#f4f5f7); border-color: var(--pmk-line,#e3e6ea); color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-cta--light .pmk-cta__way:hover { border-color: rgba(200,240,0,.55); background: var(--pmk-surface,#fff); box-shadow: 0 12px 28px rgba(22,25,28,.08); }
.pmk-brand .pmk-cta--light .pmk-cta__ic--call { background: rgba(200,240,0,.18); color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-cta--light .pmk-cta__v { color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-cta--light .pmk-cta__note { color: var(--pmk-muted,#5a6470); }
.pmk-brand .pmk-cta--light .pmk-cta__hint { color: #8a9410; }
.pmk-brand .pmk-cta--light .pmk-cta__mbtn { border-color: var(--pmk-line,#e3e6ea); color: var(--pmk-ink,#16191c); background: var(--pmk-surface,#fff); }
.pmk-brand .pmk-cta--light .pmk-cta__mbtn--mx:hover { background:#6E3CE6; border-color:#6E3CE6; color:#fff; }
.pmk-brand .pmk-cta--light .pmk-cta__mbtn--tg:hover { background:#229ED9; border-color:#229ED9; color:#fff; }
.pmk-brand .pmk-cta--light .pmk-cta__mbtn--wa:hover { background:#25D366; border-color:#25D366; color:var(--pmk-ink,#16191c); }

/* ===================== СТРАНИЦА «КОНТАКТЫ» (.pmk-c-*) ===================== */
.pmk-brand .pmk-contacts { color: var(--pmk-ink,#16191c); font-family: var(--pmk-font); padding-bottom: 10px; }
/* без своего бокового padding: отступ даёт Aspro-колонка (ровно по краю логотипа) */
.pmk-brand .pmk-c-wrap { max-width: 1500px; margin: 0 auto; padding: 0; }
.pmk-brand .pmk-c-crumbs { font-size: 13px; color: var(--pmk-muted,#5a6470); padding: 18px 0 0; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.pmk-brand .pmk-c-crumbs a { color: var(--pmk-muted,#5a6470); text-decoration: none; }
.pmk-brand .pmk-c-crumbs a:hover { color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-c-head { padding: 22px 0 30px; }
.pmk-brand .pmk-c-eb { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--pmk-muted,#5a6470); margin-bottom: 14px; }
.pmk-brand .pmk-c-eb::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent,#C8F000); border-radius: 3px; }
.pmk-brand .pmk-c-head h1 { font-size: clamp(30px,4vw,46px); font-weight: 800; letter-spacing: -.025em; margin: 0 0 10px; }
.pmk-brand .pmk-c-head p { color: var(--pmk-muted,#5a6470); font-size: 17px; max-width: 64ch; margin: 0; }
.pmk-brand .pmk-c-sec { margin-bottom: 42px; }
.pmk-brand .pmk-c-secttl { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--pmk-muted,#5a6470); margin: 0 0 16px; display: flex; align-items: center; gap: 10px; }
.pmk-brand .pmk-c-secttl::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent,#C8F000); border-radius: 3px; }
.pmk-brand .pmk-c-addrmap { display: grid; grid-template-columns: .85fr 1.15fr; gap: 24px; align-items: stretch; }
.pmk-brand .pmk-c-addrbox { background: var(--pmk-surface,#fff); border: 1px solid var(--pmk-line,#e3e6ea); border-radius: 16px; padding: 26px; display: flex; flex-direction: column; gap: 16px; }
.pmk-brand .pmk-c-airow { display: flex; gap: 13px; align-items: flex-start; }
.pmk-brand .pmk-c-ai { width: 40px; height: 40px; border-radius: 11px; background: rgba(200,240,0,.16); color: var(--pmk-ink,#16191c); display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pmk-brand .pmk-c-al { font-size: 12px; color: var(--pmk-muted,#5a6470); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 3px; }
.pmk-brand .pmk-c-av { font-size: 15.5px; font-weight: 700; line-height: 1.45; }
.pmk-brand .pmk-c-av a { color: var(--pmk-ink,#16191c); text-decoration: none; }
.pmk-brand .pmk-c-av a:hover { color: #6b7a00; }
.pmk-brand .pmk-c-map { border-radius: 16px; overflow: hidden; border: 1px solid var(--pmk-line,#e3e6ea); min-height: 360px; background: #e3e6ea; }
.pmk-brand .pmk-c-map iframe { display: block; width: 100%; height: 100%; min-height: 360px; border: 0; }
.pmk-brand .pmk-c-reqwrap { background: var(--pmk-surface,#fff); border: 1px solid var(--pmk-line,#e3e6ea); border-radius: 16px; padding: 28px; }
.pmk-brand .pmk-c-reqh { font-size: 20px; font-weight: 800; margin: 0 0 4px; letter-spacing: -.02em; }
.pmk-brand .pmk-c-reqorg { font-size: 14px; color: var(--pmk-muted,#5a6470); margin-bottom: 20px; }
.pmk-brand .pmk-c-reqgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 36px; }
.pmk-brand .pmk-c-reqrow { display: flex; justify-content: space-between; gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--pmk-line,#e3e6ea); font-size: 14px; align-items: baseline; }
.pmk-brand .pmk-c-reqrow--copy { cursor: pointer; border-radius: 8px; transition: background .14s; margin: 0 -8px; padding-left: 8px; padding-right: 8px; }
.pmk-brand .pmk-c-reqrow--copy:hover { background: var(--pmk-bg,#f4f5f7); }
.pmk-brand .pmk-c-reqk { color: var(--pmk-muted,#5a6470); font-weight: 600; flex: 0 0 auto; }
.pmk-brand .pmk-c-reqv { font-weight: 700; text-align: right; word-break: break-word; display: inline-flex; align-items: center; gap: 7px; justify-content: flex-end; }
.pmk-brand .pmk-c-reqcopy { color: var(--pmk-muted,#5a6470); opacity: 0; transition: opacity .14s; flex: 0 0 auto; }
.pmk-brand .pmk-c-reqrow--copy:hover .pmk-c-reqcopy { opacity: .8; }
.pmk-brand .pmk-c-reqnote { font-size: 12.5px; color: var(--pmk-muted,#5a6470); margin-top: 18px; line-height: 1.5; }
.pmk-brand .pmk-c-plashki { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.pmk-brand .pmk-c-plashka { position: relative; border-radius: 18px; overflow: hidden; padding: 28px; background: var(--pmk-ink,#16191c); color: #fff; display: flex; flex-direction: column; gap: 12px; min-height: 160px; text-decoration: none; transition: transform .18s; }
.pmk-brand .pmk-c-plashka:hover { transform: translateY(-4px); }
.pmk-brand .pmk-c-plashka::after { content: ""; position: absolute; right: -30px; top: -30px; width: 120px; height: 120px; background: var(--pmk-accent,#C8F000); opacity: .12; border-radius: 50%; filter: blur(8px); }
.pmk-brand .pmk-c-plpic { width: 46px; height: 46px; border-radius: 12px; background: rgba(200,240,0,.16); color: var(--pmk-accent,#C8F000); display: flex; align-items: center; justify-content: center; position: relative; }
.pmk-brand .pmk-c-plt { font-size: 19px; font-weight: 800; position: relative; }
.pmk-brand .pmk-c-pld { font-size: 13.5px; color: #aab2bb; position: relative; flex: 1; line-height: 1.45; }
.pmk-brand .pmk-c-plm { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 700; color: var(--pmk-accent,#C8F000); position: relative; }
.pmk-brand .pmk-c-plm svg { transition: transform .2s; }
.pmk-brand .pmk-c-plashka:hover .pmk-c-plm svg { transform: translateX(4px); }
@media (max-width: 980px) { .pmk-brand .pmk-c-addrmap { grid-template-columns: 1fr; } .pmk-brand .pmk-c-reqgrid { grid-template-columns: 1fr; } .pmk-brand .pmk-c-plashki { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .pmk-brand .pmk-c-reqwrap, .pmk-brand .pmk-c-addrbox { padding: 22px; } .pmk-brand .pmk-c-reqv { text-align: right; } }

/* ===================== СТРАНИЦА «НАШЕ ПРОИЗВОДСТВО» (.pmk-pr-*) ===================== */
.pmk-brand .pmk-proizv { color: var(--pmk-ink,#16191c); font-family: var(--pmk-font); padding-bottom: 10px; }
/* без своего бокового padding: отступ даёт Aspro-колонка (maxwidth 24 + col 16 = 40px),
   ровно по левому краю логотипа. Свой padding давал двойной отступ (контент уезжал на 32px). */
.pmk-brand .pmk-pr-wrap { max-width: 1500px; margin: 0 auto; padding: 0; }
.pmk-brand .pmk-pr-crumbs { font-size: 13px; color: var(--pmk-muted,#5a6470); padding: 18px 0 0; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.pmk-brand .pmk-pr-crumbs a { color: var(--pmk-muted,#5a6470); text-decoration: none; }
.pmk-brand .pmk-pr-crumbs a:hover { color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-pr-sec { margin-bottom: 46px; }
.pmk-brand .pmk-pr-secttl { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--pmk-muted,#5a6470); margin: 0 0 18px; display: flex; align-items: center; gap: 10px; }
.pmk-brand .pmk-pr-secttl::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent,#C8F000); border-radius: 3px; flex: 0 0 auto; }
.pmk-brand .pmk-pr-eb { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--pmk-accent,#C8F000); margin-bottom: 14px; }
.pmk-brand .pmk-pr-eb::before { content: ""; width: 12px; height: 12px; background: var(--pmk-accent,#C8F000); border-radius: 3px; }

/* hero */
.pmk-brand .pmk-pr-hero { padding: 20px 0 0; margin-bottom: 46px; }
.pmk-brand .pmk-pr-hero__in { position: relative; border-radius: 24px; overflow: hidden; background: var(--pmk-ink,#16191c); display: flex; align-items: stretch; }
.pmk-brand .pmk-pr-hero__bg { position: absolute; inset: 0; }
.pmk-brand .pmk-pr-hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: .4; }
.pmk-brand .pmk-pr-hero__in::after { content: ""; position: absolute; inset: 0; background: linear-gradient(100deg,rgba(15,17,19,.92) 0%,rgba(15,17,19,.68) 50%,rgba(15,17,19,.28) 100%); }
.pmk-brand .pmk-pr-hero__c { position: relative; z-index: 2; padding: 40px; display: grid; grid-template-columns: 1.1fr .9fr; gap: 34px; align-items: center; width: 100%; }
.pmk-brand .pmk-pr-hero__left h1 { color: #fff; font-size: clamp(26px,3vw,38px); font-weight: 800; line-height: 1.07; letter-spacing: -.02em; margin: 0 0 12px; }
.pmk-brand .pmk-pr-hero__left p { color: #cfd5db; font-size: 15.5px; line-height: 1.5; margin: 0; max-width: 52ch; }
/* hero: блок 4 цифр (2×2) на полупрозрачной подложке */
.pmk-brand .pmk-pr-hstats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pmk-brand .pmk-pr-hstat { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.13); border-radius: 14px; padding: 18px; }
.pmk-brand .pmk-pr-hstat__v { color: #fff; font-size: 26px; font-weight: 800; line-height: 1; letter-spacing: -.02em; }
.pmk-brand .pmk-pr-hstat__l { color: #aab2bb; font-size: 12.5px; margin-top: 7px; line-height: 1.35; }
.pmk-brand .pmk-pr-u { color: var(--pmk-accent,#C8F000); }

/* преимущества */
.pmk-brand .pmk-pr-adv { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.pmk-brand .pmk-pr-acard { background: var(--pmk-surface,#fff); border: 1px solid var(--pmk-line,#e3e6ea); border-radius: 16px; padding: 24px; }
.pmk-brand .pmk-pr-acard__ic { width: 46px; height: 46px; border-radius: 12px; background: rgba(200,240,0,.16); color: var(--pmk-ink,#16191c); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.pmk-brand .pmk-pr-acard__t { font-size: 17px; font-weight: 800; margin-bottom: 10px; }
.pmk-brand .pmk-pr-acard ul { margin: 0; padding: 0; list-style: none; }
.pmk-brand .pmk-pr-acard li { font-size: 14px; color: #39414a; padding: 6px 0 6px 22px; position: relative; line-height: 1.4; }
.pmk-brand .pmk-pr-acard li::before { content: ""; position: absolute; left: 0; top: 12px; width: 8px; height: 8px; background: var(--pmk-accent,#C8F000); border-radius: 2px; }

/* объекты */
.pmk-brand .pmk-pr-objects { background: var(--pmk-ink,#16191c); border-radius: 18px; padding: 30px 32px; color: #fff; position: relative; overflow: hidden; }
.pmk-brand .pmk-pr-objects::after { content: ""; position: absolute; right: -40px; top: -40px; width: 170px; height: 170px; background: var(--pmk-accent,#C8F000); opacity: .1; border-radius: 50%; filter: blur(10px); }
.pmk-brand .pmk-pr-objects h2 { font-size: 19px; font-weight: 800; margin: 0 0 16px; position: relative; letter-spacing: -.01em; }
.pmk-brand .pmk-pr-objects__row { display: flex; gap: 12px; flex-wrap: wrap; position: relative; }
.pmk-brand .pmk-pr-obj { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.13); border-radius: 12px; padding: 14px 18px; font-size: 14.5px; font-weight: 700; display: flex; align-items: center; gap: 10px; }
.pmk-brand .pmk-pr-obj svg { color: var(--pmk-accent,#C8F000); flex: 0 0 auto; }

/* оборудование */
.pmk-brand .pmk-pr-equip { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.pmk-brand .pmk-pr-ecard { background: var(--pmk-surface,#fff); border: 1px solid var(--pmk-line,#e3e6ea); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; transition: transform .18s, box-shadow .18s, border-color .18s; }
.pmk-brand .pmk-pr-ecard:hover { transform: translateY(-4px); box-shadow: 0 16px 38px rgba(22,25,28,.12); border-color: rgba(200,240,0,.5); }
.pmk-brand .pmk-pr-ecard__i { height: 200px; overflow: hidden; background: linear-gradient(135deg,#2b3340,#454f5e); }
.pmk-brand .pmk-pr-ecard__i img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.pmk-brand .pmk-pr-ecard:hover .pmk-pr-ecard__i img { transform: scale(1.05); }
.pmk-brand .pmk-pr-ecard__b { padding: 18px 20px; display: flex; flex-direction: column; flex: 1; }
.pmk-brand .pmk-pr-ecard__t { font-size: 16.5px; font-weight: 800; margin-bottom: 9px; line-height: 1.25; }
.pmk-brand .pmk-pr-ecard__spec { font-size: 13px; font-weight: 700; color: #7a8512; background: rgba(200,240,0,.14); border-radius: 7px; padding: 5px 10px; display: inline-block; margin-bottom: 10px; align-self: flex-start; }
.pmk-brand .pmk-pr-ecard__d { font-size: 13.5px; color: var(--pmk-muted,#5a6470); line-height: 1.45; }

/* CTA */
.pmk-brand .pmk-pr-cta { background: var(--pmk-ink,#16191c); color: #fff; border-radius: 20px; padding: 36px; text-align: center; position: relative; overflow: hidden; }
.pmk-brand .pmk-pr-cta::after { content: ""; position: absolute; right: -40px; top: -40px; width: 170px; height: 170px; background: var(--pmk-accent,#C8F000); opacity: .13; border-radius: 50%; filter: blur(9px); }
.pmk-brand .pmk-pr-cta h2 { color: #fff; font-size: 26px; font-weight: 800; margin: 0 0 8px; position: relative; letter-spacing: -.02em; }
.pmk-brand .pmk-pr-cta p { color: #aab2bb; margin: 0 0 20px; position: relative; }
.pmk-brand .pmk-pr-cta__row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; position: relative; }

@media (max-width: 1080px) { .pmk-brand .pmk-pr-adv, .pmk-brand .pmk-pr-equip { grid-template-columns: 1fr 1fr; } }
@media (max-width: 900px) { .pmk-brand .pmk-pr-hero__c { grid-template-columns: 1fr; gap: 22px; } }
@media (max-width: 640px) { .pmk-brand .pmk-pr-adv, .pmk-brand .pmk-pr-equip { grid-template-columns: 1fr; } .pmk-brand .pmk-pr-hero__c { padding: 28px; } .pmk-brand .pmk-pr-cta, .pmk-brand .pmk-pr-objects { padding: 24px; } }

/* ===================== МОДАЛКА «ПОЛУЧИТЬ РАСЧЁТ» (.pmk-rm-*) ===================== */
.pmk-noscroll { overflow: hidden !important; }
.pmk-brand .pmk-rm-overlay { position: fixed; inset: 0; z-index: 100000; background: rgba(15,17,19,.62); display: none; align-items: center; justify-content: center; padding: 20px; overflow-y: auto; }
.pmk-brand .pmk-rm-overlay.is-open { display: flex; }
.pmk-brand .pmk-rm { background: var(--pmk-surface,#fff); color: var(--pmk-ink,#16191c); border-radius: 20px; width: 100%; max-width: 560px; position: relative; box-shadow: 0 30px 80px rgba(0,0,0,.4); overflow: hidden; margin: auto; font-family: var(--pmk-font); }
.pmk-brand .pmk-rm__close { position: absolute; top: 16px; right: 16px; width: 38px; height: 38px; border-radius: 10px; border: none; background: var(--pmk-bg,#f4f5f7); color: var(--pmk-muted,#5a6470); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: .14s; z-index: 3; }
.pmk-brand .pmk-rm__close:hover { background: #e8ebee; color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-rm__head { padding: 32px 32px 0; }
.pmk-brand .pmk-rm__eb { display: inline-flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--pmk-muted,#5a6470); margin-bottom: 12px; }
.pmk-brand .pmk-rm__eb::before { content: ""; width: 11px; height: 11px; background: var(--pmk-accent,#C8F000); border-radius: 3px; }
.pmk-brand .pmk-rm__head h2 { margin: 0 0 8px; font-size: 24px; font-weight: 800; letter-spacing: -.02em; color: var(--pmk-ink,#16191c); }
.pmk-brand .pmk-rm__head p { margin: 0; color: var(--pmk-muted,#5a6470); font-size: 15px; line-height: 1.5; }
.pmk-brand .pmk-rm__body { padding: 22px 32px 32px; display: flex; flex-direction: column; gap: 12px; }
.pmk-brand .pmk-rm-way { display: flex; gap: 14px; align-items: center; padding: 16px 18px; border: 1px solid var(--pmk-line,#e3e6ea); border-radius: 14px; text-decoration: none; color: inherit; transition: transform .14s, border-color .14s, box-shadow .14s; cursor: pointer; background: var(--pmk-surface,#fff); text-align: left; width: 100%; font-family: inherit; }
.pmk-brand .pmk-rm-way:hover { transform: translateY(-2px); border-color: rgba(200,240,0,.6); box-shadow: 0 10px 24px rgba(22,25,28,.08); }
.pmk-brand .pmk-rm-way__ic { width: 46px; height: 46px; border-radius: 12px; background: rgba(200,240,0,.16); color: var(--pmk-ink,#16191c); display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pmk-brand .pmk-rm-way__main { flex: 1; display: flex; flex-direction: column; }
.pmk-brand .pmk-rm-way__t { font-size: 16px; font-weight: 800; }
.pmk-brand .pmk-rm-way__v { font-size: 14px; color: var(--pmk-ink,#16191c); font-weight: 700; }
.pmk-brand .pmk-rm-way__nt { font-size: 12.5px; color: var(--pmk-muted,#5a6470); margin-top: 2px; }
.pmk-brand .pmk-rm-way--phones { align-items: flex-start; cursor: default; }
.pmk-brand .pmk-rm-way--phones:hover { transform: none; border-color: var(--pmk-line,#e3e6ea); box-shadow: none; }
.pmk-brand .pmk-rm-phones { display: flex; flex-direction: column; gap: 2px; margin: 4px 0 2px; }
.pmk-brand .pmk-rm-phone { font-size: 15px; font-weight: 700; color: var(--pmk-ink,#16191c); text-decoration: none; padding: 4px 0; display: inline-flex; align-items: baseline; gap: 8px; transition: color .12s; }
.pmk-brand .pmk-rm-phone:hover { color: #7a8512; }
.pmk-brand .pmk-rm-phone i { font-style: normal; font-size: 11px; font-weight: 700; color: var(--pmk-muted,#5a6470); text-transform: uppercase; letter-spacing: .03em; }
.pmk-brand .pmk-rm-way--msg { flex-direction: column; align-items: stretch; gap: 12px; cursor: default; }
.pmk-brand .pmk-rm-way--msg:hover { transform: none; border-color: var(--pmk-line,#e3e6ea); box-shadow: none; }
.pmk-brand .pmk-rm-way__msghead { display: flex; gap: 14px; align-items: center; }
.pmk-brand .pmk-rm-msgs { display: flex; gap: 8px; }
.pmk-brand .pmk-rm-msg { flex: 1; text-align: center; padding: 11px 8px; border-radius: 11px; font-size: 13.5px; font-weight: 800; border: 1.5px solid var(--pmk-line,#e3e6ea); color: var(--pmk-ink,#16191c); text-decoration: none; transition: .14s; }
.pmk-brand .pmk-rm-msg--mx:hover { background: #6E3CE6; border-color: #6E3CE6; color: #fff; }
.pmk-brand .pmk-rm-msg--tg:hover { background: #229ED9; border-color: #229ED9; color: #fff; }
.pmk-brand .pmk-rm-msg--wa:hover { background: #25D366; border-color: #25D366; color: #16191c; }
.pmk-brand .pmk-rm__foot { padding: 0 32px 28px; font-size: 12.5px; color: var(--pmk-muted,#5a6470); text-align: center; }
@media (max-width: 520px) { .pmk-brand .pmk-rm__head { padding: 26px 20px 0; } .pmk-brand .pmk-rm__body { padding: 18px 20px 24px; } .pmk-brand .pmk-rm__head h2 { font-size: 21px; } .pmk-brand .pmk-rm__foot { padding: 0 20px 24px; } }

/* ===================== Контактный блок — КОМПАКТНЫЙ вид (.pmk-cta--compact) ===================== */
/* Карточки в ряд (иконка слева, текст справа), меньше паддинги, заголовок 24px. Прототип kontakt-blok-tovar_4. */
.pmk-brand .pmk-cta--compact { padding: 36px; }
.pmk-brand .pmk-cta--compact .pmk-cta__head { margin-bottom: 24px; }
.pmk-brand .pmk-cta--compact .pmk-cta__h2 { font-size: clamp(22px,2.4vw,26px); margin: 0 0 6px; }
.pmk-brand .pmk-cta--compact .pmk-cta__way { display: grid; grid-template-columns: auto 1fr; column-gap: 14px; row-gap: 2px; align-items: start; align-content: start; padding: 16px 18px; }
.pmk-brand .pmk-cta--compact .pmk-cta__ic { grid-column: 1; grid-row: 1 / span 3; align-self: start; width: 46px; height: 46px; }
.pmk-brand .pmk-cta--compact .pmk-cta__t,
.pmk-brand .pmk-cta--compact .pmk-cta__v,
.pmk-brand .pmk-cta--compact .pmk-cta__note,
.pmk-brand .pmk-cta--compact .pmk-cta__btns { grid-column: 2; min-width: 0; }
.pmk-brand .pmk-cta--compact .pmk-cta__hint { display: none; }
.pmk-brand .pmk-cta--compact .pmk-cta__btns { margin-top: 5px; }
@media (max-width: 760px) { .pmk-brand .pmk-cta--compact { padding: 24px; } }

/* ===================== ПОСАДОЧНАЯ «Металлические бордюры» (.pmk-lp-*) ===================== */
.pmk-cat-main .pmk-lp { padding-top:6px; }
.pmk-cat-main .pmk-lp-hero { padding:18px 0 10px; }
.pmk-cat-main .pmk-lp-hero__row { display:grid; grid-template-columns:minmax(0,1.15fr) minmax(0,0.85fr); gap:32px; align-items:stretch; }
.pmk-cat-main .pmk-lp-hero__img { border-radius:16px; overflow:hidden; min-height:300px; background:var(--pmk-line,#e3e6ea); }
.pmk-cat-main .pmk-lp-hero__img img { display:block; width:100%; height:100%; object-fit:cover; }
.pmk-cat-main .pmk-lp-projects { margin-top:36px; }
@media (max-width:880px){ .pmk-cat-main .pmk-lp-hero__row { grid-template-columns:1fr; gap:18px; } .pmk-cat-main .pmk-lp-hero__img { min-height:0; aspect-ratio:16/10; } }
.pmk-cat-main .pmk-lp-eb { display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--pmk-muted,#5a6470); margin-bottom:16px; }
.pmk-cat-main .pmk-lp-eb::before { content:""; width:11px; height:11px; background:var(--pmk-accent,#C8F000); border-radius:3px; }
.pmk-cat-main .pmk-lp-h1 { font-size:clamp(28px,3.6vw,40px); font-weight:800; letter-spacing:-.025em; line-height:1.1; margin:0 0 16px; max-width:820px; }
.pmk-cat-main .pmk-lp-h1 .hl { background:linear-gradient(transparent 62%, var(--pmk-accent,#C8F000) 62%); padding:0 2px; }
.pmk-cat-main .pmk-lp-lead { font-size:17px; line-height:1.55; color:var(--pmk-muted,#5a6470); max-width:720px; margin:0 0 22px; }
.pmk-cat-main .pmk-lp-cta { display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.pmk-cat-main .pmk-lp-btn { display:inline-block; background:var(--pmk-accent,#C8F000); color:var(--pmk-ink,#16191c); font-weight:700; padding:14px 26px; border-radius:11px; text-decoration:none; font-size:15px; transition:transform .15s; }
.pmk-cat-main .pmk-lp-btn:hover { transform:translateY(-2px); }
.pmk-cat-main .pmk-lp-btn--dark { background:var(--pmk-ink,#16191c); color:#fff; }
.pmk-cat-main .pmk-lp-contacts { display:flex; gap:18px; flex-wrap:wrap; margin:18px 0 0; font-size:15px; }
.pmk-cat-main .pmk-lp-contacts a { color:var(--pmk-ink,#16191c); font-weight:700; text-decoration:none; border-bottom:2px solid var(--pmk-accent,#C8F000); }
.pmk-cat-main .pmk-lp-opt { background:var(--pmk-ink,#16191c); color:#fff; border-radius:14px; padding:20px 24px; margin:26px 0 0; display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap; }
.pmk-cat-main .pmk-lp-opt b { font-size:17px; font-weight:800; color:#fff; }
.pmk-cat-main .pmk-lp-opt span { color:#b8c0c8; font-size:14px; display:block; margin-top:4px; }
.pmk-cat-main .pmk-lp-opt .pmk-lp-btn { white-space:nowrap; }
.pmk-cat-main .pmk-lp-usp { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin:30px 0 10px; }
.pmk-cat-main .pmk-lp-uc { background:var(--pmk-surface,#fff); border:1px solid var(--pmk-line,#e3e6ea); border-radius:14px; padding:18px 20px; }
.pmk-cat-main .pmk-lp-uc b { display:block; font-size:15px; font-weight:800; margin-bottom:5px; }
.pmk-cat-main .pmk-lp-uc b .d { width:9px; height:9px; background:var(--pmk-accent,#C8F000); border-radius:3px; display:inline-block; margin-right:7px; }
.pmk-cat-main .pmk-lp-uc span { font-size:13.5px; color:var(--pmk-muted,#5a6470); line-height:1.4; }
.pmk-cat-main .pmk-lp-lbl { font-size:12px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:#7a8512; margin:42px 0 6px; }
.pmk-cat-main .pmk-lp-h2 { font-size:clamp(22px,2.6vw,26px); font-weight:800; letter-spacing:-.02em; margin:0 0 8px; }
.pmk-cat-main .pmk-lp-sub { font-size:15px; color:var(--pmk-muted,#5a6470); margin:0 0 20px; max-width:720px; line-height:1.5; }
.pmk-cat-main .pmk-lp-acc { display:flex; flex-direction:column; gap:12px; }
.pmk-cat-main .pmk-lp-acc__item { background:var(--pmk-surface,#fff); border:1px solid var(--pmk-line,#e3e6ea); border-radius:14px; overflow:hidden; }
.pmk-cat-main .pmk-lp-acc__head { display:flex; align-items:center; justify-content:space-between; padding:17px 22px; cursor:pointer; user-select:none; gap:12px; }
.pmk-cat-main .pmk-lp-acc__head:hover { background:#fafbfc; }
.pmk-cat-main .pmk-lp-acc__t b { font-size:17px; font-weight:800; }
.pmk-cat-main .pmk-lp-acc__t span { font-size:13px; color:var(--pmk-muted,#5a6470); margin-left:10px; }
.pmk-cat-main .pmk-lp-acc__from { font-size:13px; color:var(--pmk-muted,#5a6470); white-space:nowrap; }
.pmk-cat-main .pmk-lp-acc__from b { color:var(--pmk-ink,#16191c); font-size:16px; }
.pmk-cat-main .pmk-lp-acc__chev { margin-left:14px; transition:transform .2s; color:var(--pmk-muted,#5a6470); display:inline-block; }
.pmk-cat-main .pmk-lp-acc__item.open .pmk-lp-acc__chev { transform:rotate(180deg); }
.pmk-cat-main .pmk-lp-acc__body { display:none; padding:0 22px 18px; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.pmk-cat-main .pmk-lp-acc__item.open .pmk-lp-acc__body { display:block; }
.pmk-cat-main .pmk-lp-tbl { width:100%; border-collapse:collapse; font-size:13px; min-width:560px; }
.pmk-cat-main .pmk-lp-tbl th { text-align:left; color:var(--pmk-muted,#5a6470); font-weight:600; padding:9px 10px; border-bottom:1px solid var(--pmk-line,#e3e6ea); font-size:11px; text-transform:uppercase; letter-spacing:.03em; white-space:nowrap; }
.pmk-cat-main .pmk-lp-tbl td { padding:9px 10px; border-bottom:1px solid var(--pmk-line,#e3e6ea); white-space:nowrap; }
.pmk-cat-main .pmk-lp-tbl tr:last-child td { border-bottom:none; }
.pmk-cat-main .pmk-lp-tbl td.pr { font-weight:700; text-align:right; }
.pmk-cat-main .pmk-lp-tbl th.pr { text-align:right; }
.pmk-cat-main .pmk-lp-note { font-size:13px; color:var(--pmk-muted,#5a6470); margin-top:16px; line-height:1.5; }
.pmk-cat-main .pmk-lp-custom { background:var(--pmk-ink,#16191c); color:#fff; border-radius:16px; padding:30px 32px; margin:40px 0; }
.pmk-cat-main .pmk-lp-custom h2 { font-size:22px; font-weight:800; margin:0 0 10px; color:#fff; }
.pmk-cat-main .pmk-lp-custom p { color:#b8c0c8; font-size:15px; line-height:1.55; margin:0 0 18px; max-width:620px; }
.pmk-cat-main .pmk-lp-seo { margin-top:36px; color:#39414a; line-height:1.6; max-width:820px; }
.pmk-cat-main .pmk-lp-seo h2 { font-size:clamp(20px,2.4vw,26px); font-weight:800; letter-spacing:-.02em; color:var(--pmk-ink,#16191c); margin:0 0 12px; }
.pmk-cat-main .pmk-lp-seo h3 { font-size:18px; font-weight:800; color:var(--pmk-ink,#16191c); margin:22px 0 8px; }
.pmk-cat-main .pmk-lp-seo p { margin:0 0 12px; }
.pmk-cat-main .pmk-lp-faq { margin-top:40px; max-width:820px; }
.pmk-cat-main .pmk-lp-faq h2 { font-size:clamp(20px,2.4vw,26px); font-weight:800; letter-spacing:-.02em; margin:0 0 18px; }
.pmk-cat-main .pmk-lp-faqlist { display:flex; flex-direction:column; gap:10px; }
.pmk-cat-main .pmk-lp-faq__i { background:var(--pmk-surface,#fff); border:1px solid var(--pmk-line,#e3e6ea); border-radius:14px; padding:16px 20px; cursor:pointer; }
.pmk-cat-main .pmk-lp-faq__q { display:flex; align-items:center; justify-content:space-between; gap:12px; font-size:15.5px; font-weight:800; color:var(--pmk-ink,#16191c); }
.pmk-cat-main .pmk-lp-faq__chev { flex:none; color:var(--pmk-muted,#5a6470); transition:transform .2s; }
.pmk-cat-main .pmk-lp-faq__i.open .pmk-lp-faq__chev { transform:rotate(180deg); }
.pmk-cat-main .pmk-lp-faq__a { display:none; font-size:14px; color:var(--pmk-muted,#5a6470); line-height:1.5; margin-top:10px; }
.pmk-cat-main .pmk-lp-faq__i.open .pmk-lp-faq__a { display:block; }
@media (max-width:780px){
  .pmk-cat-main .pmk-lp-usp { grid-template-columns:1fr; }
  .pmk-cat-main .pmk-lp-opt { flex-direction:column; align-items:flex-start; }
  .pmk-cat-main .pmk-lp-tbl { min-width:0; }
  .pmk-cat-main .pmk-lp-tbl thead { display:none; }
  .pmk-cat-main .pmk-lp-tbl tr { display:block; border-bottom:7px solid var(--pmk-bg,#f4f5f7); }
  .pmk-cat-main .pmk-lp-tbl tr:last-child { border-bottom:none; }
  .pmk-cat-main .pmk-lp-tbl td { display:flex; justify-content:space-between; border:none; padding:6px 4px; white-space:normal; }
  .pmk-cat-main .pmk-lp-tbl td::before { content:attr(data-l); color:var(--pmk-muted,#5a6470); font-weight:600; font-size:12px; }
  .pmk-cat-main .pmk-lp-tbl td.pr { text-align:right; }
}

/* ===================== Посадочная «Закладные детали» — доп. блоки ===================== */
.pmk-cat-main .pmk-lp-series { margin-top:38px; }
.pmk-cat-main .pmk-lp-quote { margin-top:20px; padding:14px 18px; border-left:3px solid var(--pmk-accent,#C8F000); background:#fafbf3; border-radius:8px; font-size:15px; font-style:italic; color:var(--pmk-ink,#16191c); line-height:1.5; }
.pmk-cat-main .pmk-lp-links { margin-top:34px; }
.pmk-cat-main .pmk-lp-linkrow { display:flex; flex-wrap:wrap; gap:10px; margin-top:6px; }
.pmk-cat-main .pmk-lp-linkrow a { display:inline-block; padding:9px 16px; border:1px solid var(--pmk-line,#e3e6ea); border-radius:10px; background:var(--pmk-surface,#fff); color:var(--pmk-ink,#16191c); text-decoration:none; font-weight:700; font-size:14px; transition:border-color .15s; }
.pmk-cat-main .pmk-lp-linkrow a:hover { border-color:var(--pmk-accent,#C8F000); }
