/* =========================================================================
   THERMOSMOKE / DESIGN LAB — page.css
   Дизайн-система внутренних страниц (каталог/категория/товар/контент/…).
   Тёмная премиум-тема, когерентная с главной. Satoshi + General Sans + JetBrains.
   ========================================================================= */

:root {
  /* «Сталь и Сигнал» — графит + ОДИН красный хью; смягчённый контраст (bg приподнят, off-white вместо чистого белого) */
  --bg:#15171B; --bg-2:#0F1114; --surf:#1E2127; --surf-2:rgba(245,246,247,.05);
  --ink:#EAECEF; --ink-2:#A4A9B1; --ink-3:#767B83;
  --accent:#E1000A; --accent-2:#FF5049; --accent-3:#C20009; --accent-deep:#B00007; --accent-ink:#FF5049;
  --line:rgba(244,245,247,.09); --line-2:rgba(244,245,247,.16); --line-3:rgba(244,245,247,.27);
  --heat:linear-gradient(90deg,#1E2127 0%,#5A1116 55%,#B00007 82%,#E1000A 100%);
  --f-display:"Satoshi","Inter Display",-apple-system,sans-serif;
  --f-body:"General Sans","Satoshi",-apple-system,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,SF Mono,monospace;
  --pad-x:clamp(18px,5vw,80px);
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:28px;
  --ease:cubic-bezier(.2,.9,.25,1); --ease-in:cubic-bezier(.7,0,.85,.2);
  --d-fast:.22s; --d-med:.4s;
  --maxw:1280px;
  --hd-h:66px;
}

/* «Паспорт изделия» — премиальная светлая тема (по умолчанию). Тёплая бумага,
   графитовые чернила (не чистый чёрный), тот же красный сигнал, мягкие тени. */
[data-theme="light"] {
  --bg:#F3F2EF; --bg-2:#EAE9E5; --surf:#FFFFFF; --surf-2:rgba(20,22,26,.028);
  --ink:#191B1F; --ink-2:#585C63; --ink-3:#70747B; /* был #8C9098 — mono-подписи читались еле-еле */
  --accent:#D80710; --accent-2:#B00007; --accent-3:#9E0006; --accent-deep:#9E0006; --accent-ink:#B00007;
  --line:rgba(20,22,26,.10); --line-2:rgba(20,22,26,.15); --line-3:rgba(20,22,26,.24);
  --heat:linear-gradient(90deg,#EAE9E5 0%,#E7B9BB 45%,#C20009 78%,#E1000A 100%);
}

* { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--f-body); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before { /* атмосферный градиент */
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(70% 50% at 85% -8%, rgba(225,0,10,.05), transparent 62%),
    var(--bg);
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4 { margin:0; font-family:var(--f-display); font-weight:700; letter-spacing:-.02em; line-height:1.05; }
p { margin:0; }
button { font:inherit; color:inherit; cursor:pointer; }
:focus-visible { outline:2px solid var(--accent-2); outline-offset:3px; border-radius:4px; }

.container { width:100%; max-width:var(--maxw); margin:0 auto; padding-left:var(--pad-x); padding-right:var(--pad-x); }
.skip { position:absolute; left:-9999px; top:0; background:var(--accent); color:#fff; padding:10px 16px; border-radius:0 0 8px 0; z-index:200; }
.skip:focus { left:0; }
.eyebrow { display:inline-flex; align-items:center; font-family:var(--f-mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); }
/* красный тик перед eyebrow — единственный сигнал в заголовке секции */
.eyebrow::before { content:""; width:14px; height:2px; background:var(--accent); margin-right:9px; }

/* ---------- КНОПКИ ---------- */
.btn {
  --bg-btn:transparent; position:relative; display:inline-flex; align-items:center; gap:10px;
  padding:14px 24px; border-radius:999px; font-family:var(--f-body); font-weight:600; font-size:15px;
  border:1px solid transparent; background:var(--bg-btn); color:var(--ink);
  transition:transform var(--d-fast) var(--ease), background var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);
  will-change:transform;
}
.btn:active { transform:translateY(1px) scale(.99); }
.btn--sm { padding:10px 18px; font-size:13.5px; }
.btn--block { width:100%; justify-content:center; }
.btn--primary { background:var(--accent); color:#fff; box-shadow:0 10px 26px -14px rgba(0,0,0,.55); }
.btn--primary:hover { background:var(--accent-deep); transform:translateY(-2px); box-shadow:0 16px 34px -14px rgba(0,0,0,.6); }
.btn--ghost { border-color:var(--line-2); color:var(--ink); }
.btn--ghost:hover { border-color:var(--accent-2); background:color-mix(in srgb,var(--accent) 12%,transparent); transform:translateY(-2px); }
.ico-arr { width:20px; height:9px; transition:transform var(--d-fast) var(--ease); }
.btn:hover .ico-arr, .pc__go:hover .ico-arr { transform:translateX(4px); }
.linkbtn { background:none; border:none; color:var(--accent-2); text-decoration:underline; text-underline-offset:3px; padding:0; }

/* ---------- TOPBAR / UTIL ---------- */
.topbar { height:3px; background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent)); }
.util { border-bottom:1px solid var(--line); background:color-mix(in srgb,var(--bg-2) 82%,transparent); font-size:12.5px; }
.util__row { display:flex; align-items:center; justify-content:space-between; height:38px; }
.util__hours { font-family:var(--f-mono); font-size:11px; letter-spacing:.04em; color:var(--ink-3); }
.util__contacts { display:flex; gap:22px; }
.util__phone { color:var(--ink-2); transition:color var(--d-fast); font-variant-numeric:tabular-nums; }
.util__phone i { color:var(--ink-3); font-style:normal; margin-right:5px; font-size:11px; }
.util__phone:hover { color:var(--ink); }

/* ---------- HEADER ---------- */
.hd {
  position:sticky; top:0; z-index:100; height:var(--hd-h);
  background:color-mix(in srgb,var(--bg-2) 90%,transparent);
  backdrop-filter:blur(18px) saturate(1.15); -webkit-backdrop-filter:blur(18px) saturate(1.15);
  border-bottom:1px solid var(--line-2);
  transition:height var(--d-med) var(--ease), background var(--d-med), box-shadow var(--d-med), border-color var(--d-med);
}
.hd.is-scrolled { height:56px; background:color-mix(in srgb,var(--bg-2) 98%,transparent);
  border-bottom-color:var(--line-3); box-shadow:0 14px 38px -24px rgba(0,0,0,.95); }
.hd .container { max-width:1560px; padding-left:34px; padding-right:34px; }
.hd__row { display:flex; align-items:center; gap:20px; height:100%; }
.hd__brand { display:inline-flex; align-items:center; gap:9px; flex:none; }
.brand-mark { width:34px; height:34px; flex:none; }
.brand-mark svg { width:100%; height:100%; display:block; }
.brand-wm { display:flex; flex-direction:column; line-height:1; font-family:var(--f-display); font-weight:700; font-size:19px; letter-spacing:-.015em; color:var(--ink); }
.brand-wm i { font-family:var(--f-mono); font-weight:400; font-size:8.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); font-style:normal; margin-top:4px; }
.hd__mark { width:26px; height:26px; color:var(--accent-2); }
.hd__name { font-family:var(--f-display); font-weight:700; font-size:18px; letter-spacing:-.01em; }
.hd__sub { font-family:var(--f-mono); font-size:10.5px; color:var(--ink-3); letter-spacing:.02em; }
.hd__actions { margin-left:auto; display:flex; align-items:center; gap:16px; flex:none; }
.hd__phone { display:inline-flex; align-items:center; gap:8px; text-decoration:none; white-space:nowrap;
  font-family:var(--f-display); font-weight:600; font-size:16px; letter-spacing:-.01em; color:var(--ink);
  transition:color var(--d-fast) var(--ease); }
.hd__phone .ico-tel { width:16px; height:16px; color:var(--accent); flex:none; }
.hd__phone:hover { color:var(--accent); }
@media (max-width:1240px) { .hd__phone__num { display:none; } }

/* контакт-поповер: оба номера + часы по городам + email (при наведении/фокусе) */
.hd__contacts { position:relative; }
.hd__ccaret { width:10px; height:6px; margin-left:1px; color:var(--ink-3); transition:transform var(--d-fast) var(--ease), color var(--d-fast) var(--ease); }
.hd__contacts:hover .hd__ccaret, .hd__contacts:focus-within .hd__ccaret { transform:rotate(180deg); color:var(--accent); }
.hd__contacts::after { content:""; position:absolute; top:100%; left:0; right:0; height:12px; }
.hd__pop {
  position:absolute; top:calc(100% + 8px); right:0; min-width:266px;
  background:color-mix(in srgb,var(--bg-2) 97%,transparent); -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  border:1px solid var(--line-2); border-radius:var(--r-md); padding:8px;
  box-shadow:0 34px 76px -34px rgba(0,0,0,.55); z-index:130;
  opacity:0; visibility:hidden; transform:translateY(8px); pointer-events:none;
  transition:opacity var(--d-fast) var(--ease), transform var(--d-fast) var(--ease), visibility var(--d-fast);
}
.hd__contacts:hover .hd__pop, .hd__contacts:focus-within .hd__pop { opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; }
.hd__pop__ph { display:flex; flex-direction:column; gap:1px; padding:9px 11px; border-radius:9px; text-decoration:none; transition:background var(--d-fast); }
.hd__pop__ph:hover { background:var(--surf-2); }
.hd__pop__ph b { font-family:var(--f-mono); font-weight:500; font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.hd__pop__ph span { font-family:var(--f-display); font-weight:600; font-size:16px; color:var(--ink); letter-spacing:-.01em; }
.hd__pop__hours { display:flex; flex-direction:column; gap:3px; padding:10px 11px 6px; margin-top:4px; border-top:1px solid var(--line); }
.hd__pop__hours span { font-size:12px; color:var(--ink-2); }
.hd__pop__hours .hd__pop__k { font-family:var(--f-mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:2px; }
.hd__pop__mail { display:block; padding:9px 11px; margin-top:4px; border-top:1px solid var(--line); font-family:var(--f-mono); font-size:12px; color:var(--accent); text-decoration:none; }
.hd__pop__mail:hover { color:var(--accent-2); }
.hd__theme { width:38px; height:38px; flex:none; display:grid; place-items:center; cursor:pointer;
  border:1px solid var(--line-2); border-radius:10px; background:var(--surf-2); color:var(--ink-2);
  transition:color var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease), background var(--d-fast) var(--ease); }
.hd__theme:hover { color:var(--ink); border-color:var(--line-3); }
.hd__theme svg { width:18px; height:18px; }
.hd__theme .ico-moon { display:none; }
[data-theme="light"] .hd__theme .ico-sun { display:none; }
[data-theme="light"] .hd__theme .ico-moon { display:block; }

/* светлая тема: глубина — мягкими тенями (в тёмной остаётся hairline) */
[data-theme="light"] .pc,
[data-theme="light"] .cat-card,
[data-theme="light"] .bp__stage,
[data-theme="light"] .doc,
[data-theme="light"] .citycard,
[data-theme="light"] .stat-card,
[data-theme="light"] .feat,
[data-theme="light"] .lead__form { box-shadow:0 1px 2px rgba(20,22,26,.05), 0 16px 34px -20px rgba(20,22,26,.16); }
[data-theme="light"] .pc:hover,
[data-theme="light"] .cat-card:hover,
[data-theme="light"] .doc:hover { box-shadow:0 8px 18px rgba(20,22,26,.10), 0 34px 64px -30px rgba(20,22,26,.28); }

/* nav + mega */
.nav__list { list-style:none; margin:0; padding:0; display:flex; gap:0; }
.nav-item { position:relative; }
.nav-link { display:inline-flex; align-items:center; gap:5px; padding:9px 10px; font-size:13.5px; font-weight:500; white-space:nowrap; color:var(--ink-2); border-radius:8px; transition:color var(--d-fast), background var(--d-fast); }
.nav-item:hover > .nav-link, .nav-link:focus-visible { color:var(--ink); background:var(--surf-2); }
.nav-caret { font-size:9px; color:var(--ink-3); transition:transform var(--d-fast); }
.nav-item:hover .nav-caret { transform:rotate(180deg); color:var(--accent-2); }
.mega {
  position:absolute; top:calc(100% + 10px); left:0; transform:translateY(8px);
  opacity:0; visibility:hidden; pointer-events:none;
  background:color-mix(in srgb,var(--bg-2) 97%,transparent); backdrop-filter:blur(20px);
  border:1px solid var(--line-2); border-radius:var(--r-lg); padding:16px;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.9); z-index:120;
  transition:opacity var(--d-fast) var(--ease), transform var(--d-fast) var(--ease), visibility var(--d-fast);
}
.mega::before { content:""; position:absolute; top:-10px; left:0; right:0; height:10px; }
.nav-item:hover .mega, .mega:hover { opacity:1; visibility:visible; pointer-events:auto; transform:translateY(0); }
.nav-item--mega .mega { width:min(720px,90vw); }
/* дропдаун не должен вылезать за правый край: у крайне-правых пунктов крепим справа */
.nav-item:nth-last-child(-n+2) > .mega { left:auto; right:0; }
.mega__grid { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.mega__cell { display:flex; align-items:center; gap:12px; padding:11px 13px; border-radius:var(--r-md); transition:background var(--d-fast); }
.mega__cell:hover { background:color-mix(in srgb,var(--accent) 15%,transparent); }
.mega__ic { flex:none; width:48px; height:48px; display:grid; place-items:center; border-radius:12px;
  background:color-mix(in srgb,var(--ink) 8%,transparent); border:1px solid var(--line); color:var(--accent-2); overflow:hidden; }
.mega__cell:hover .mega__ic { border-color:var(--line-2); }
.mega__ic img { width:40px; height:40px; object-fit:contain; }
.mega__ic svg { width:24px; height:24px; }
.mega__t { display:flex; flex-direction:column; gap:2px; min-width:0; flex:1; }
.mega__t b { font-family:var(--f-body); font-weight:600; font-size:14px; color:var(--ink); }
.mega__t i { font-family:var(--f-mono); font-size:9.5px; color:var(--ink-3); font-style:normal; letter-spacing:.06em; }
.mega__n { flex:none; display:inline-flex; }
.mega__n .ico-arr { width:19px; height:9px; color:var(--ink-3); transition:color var(--d-fast) var(--ease), transform var(--d-fast) var(--ease); }
.mega__cell:hover .mega__n .ico-arr { color:var(--accent-2); transform:translateX(3px); }
.mega__all { display:inline-flex; align-items:center; gap:8px; margin-top:12px; padding:10px 13px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:.05em; color:var(--accent-2); border-top:1px solid var(--line); width:100%; }
.mega--compact { width:max-content; min-width:200px; padding:8px; display:flex; flex-direction:column; }
.mega--compact a { padding:9px 13px; border-radius:8px; font-size:13.5px; color:var(--ink-2); transition:background var(--d-fast),color var(--d-fast); }
.mega--compact a:hover { background:var(--surf-2); color:var(--ink); }

/* burger + mobile nav */
.burger { display:none; width:40px; height:40px; border:1px solid var(--line-2); border-radius:10px; background:var(--surf-2); flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.burger span { width:17px; height:1.6px; background:var(--ink); border-radius:2px; transition:transform var(--d-fast) var(--ease), opacity var(--d-fast); }
.burger[aria-expanded="true"] span:nth-child(1) { transform:translateY(5.6px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-5.6px) rotate(-45deg); }
.mnav {
  position:fixed; inset:0 0 0 auto; width:min(420px,88vw); z-index:99;
  background:color-mix(in srgb,var(--bg-2) 97%,transparent); backdrop-filter:blur(20px);
  border-left:1px solid var(--line-2); transform:translateX(100%);
  transition:transform var(--d-med) var(--ease); overflow-y:auto; padding:calc(var(--hd-h) + 20px) 0 30px;
}
.mnav.is-open { transform:none; }
.mnav__inner { padding:0 var(--pad-x); }
.mnav__list { list-style:none; margin:0; padding:0; }
.mnav__list > li { border-bottom:1px solid var(--line); }
.mnav__list > li > a { display:block; padding:15px 0; font-family:var(--f-display); font-weight:600; font-size:19px; }
.mnav__sub { display:flex; flex-direction:column; padding:0 0 12px 12px; }
.mnav__sub a { padding:7px 0; font-size:14px; color:var(--ink-2); }
.mnav__foot { margin-top:22px; display:flex; flex-direction:column; gap:8px; }
.mnav__foot a { font-family:var(--f-mono); font-size:14px; color:var(--accent-2); }
.mnav-open { overflow:hidden; }
.scrim { position:fixed; inset:0; z-index:98; background:rgba(2,6,16,.6); opacity:0; visibility:hidden; transition:opacity var(--d-med),visibility var(--d-med); }
.scrim.is-on { opacity:1; visibility:visible; }

/* ---------- BREADCRUMBS ---------- */
.crumbs { padding:18px 0 2px; font-size:12.5px; }
.crumbs .container { display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.crumbs a { color:var(--ink-3); transition:color var(--d-fast); }
.crumbs a:hover { color:var(--accent-2); }
.crumbs [aria-current] { color:var(--ink-2); }
.crumbs__sep { color:var(--ink-3); }

/* ---------- SECTION HERO (каталог-индекс) ---------- */
.sec-hero { padding:40px 0 22px; }
.sec-hero__title { font-size:clamp(30px,4.6vw,60px); letter-spacing:-.03em; margin:14px 0 0; max-width:16ch; }
.sec-hero__lead { margin-top:18px; max-width:62ch; color:var(--ink-2); font-size:clamp(15px,1.3vw,18px); line-height:1.6; }
.err404__cta { display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }

/* ---------- CAT GRID (карточки категорий) ---------- */
.cat-grid-sec { padding:28px 0 60px; }
.cat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.cat-card {
  display:flex; flex-direction:column; overflow:hidden;
  border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surf-2);
  transition:transform var(--d-fast) var(--ease), border-color var(--d-fast), box-shadow var(--d-fast);
}
.cat-card:hover { transform:translateY(-4px); border-color:var(--accent-2); box-shadow:0 30px 60px -34px rgba(0,0,0,.8); }
.cat-card__ph { height:172px; overflow:hidden; background:var(--bg-2); }
.cat-card__ph img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.cat-card:hover .cat-card__ph img { transform:scale(1.06); }
/* фолбэк-обложка из фото товара (изолят) — показываем целиком на «сцене» */
.cat-card__ph--contain { background:radial-gradient(120% 120% at 65% 12%,var(--surf),var(--bg-2) 78%); }
.cat-card__ph--contain img { object-fit:contain; padding:18px 26px; }
.cat-card__ic { height:100px; display:grid; place-items:center; color:var(--accent-2); background:radial-gradient(120% 120% at 50% 0,rgba(225,0,10,.10),transparent 70%); }
.cat-card__ic svg { width:40px; height:40px; }
.cat-card__body { padding:18px 20px 20px; display:flex; flex-direction:column; gap:8px; flex:1; }
.cat-card__t { font-family:var(--f-display); font-weight:700; font-size:19px; letter-spacing:-.01em; }
.cat-card__d { color:var(--ink-2); font-size:13.5px; line-height:1.5; flex:1; }
.cat-card__foot { display:flex; align-items:center; justify-content:space-between; margin-top:6px; }
.cat-card__n { font-family:var(--f-mono); font-size:11px; letter-spacing:.06em; color:var(--ink-3); text-transform:uppercase; }

/* ---------- CATEGORY HERO ---------- */
.cat-hero { position:relative; padding:44px 0 26px; overflow:hidden; }
/* кино-шапка: полноширинный цех-кадр, ЛОКАЛЬНО тёмная палитра — одинаково дорого
   в обеих темах; медленный кен-бёрнс придаёт кадру жизнь */
.cat-hero--cover { padding:0; min-height:480px; display:flex; align-items:center; background:#101114; color:#F4F5F7; }
.cat-hero__bg { position:absolute; inset:0; z-index:0; overflow:hidden; }
.cat-hero__bg img { width:100%; height:100%; object-fit:cover; animation:catKen 16s var(--ease) forwards; }
@keyframes catKen { from { transform:scale(1.07); } to { transform:scale(1); } }
@media (prefers-reduced-motion:reduce) { .cat-hero__bg img { animation:none; } }
.cat-hero--cover::after { /* направленный тёмный скрим под текст слева + низ */
  content:""; position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(90deg, rgba(12,13,15,.93) 0%, rgba(12,13,15,.72) 36%, rgba(12,13,15,.16) 66%, rgba(12,13,15,.04) 100%),
    linear-gradient(180deg, transparent 66%, rgba(12,13,15,.56) 100%);
}
.cat-hero__in { position:relative; z-index:2; padding:60px 0 46px; }
.cat-hero--cover .cat-hero__lead { color:#B9BEC6; }
.cat-hero--cover .eyebrow { color:#A9AEB6; }
/* приборная строка линейки: реальные диапазоны крупными tabular-числами */
.cat-hero__band { display:flex; flex-wrap:wrap; gap:16px clamp(30px,4.5vw,72px); margin-top:34px; padding-top:24px; border-top:1px solid rgba(244,245,247,.16); }
.cat-hero__band > div { display:flex; flex-direction:column; gap:6px; }
.cat-hero__band b { font-family:var(--f-display); font-weight:700; font-size:clamp(24px,2.6vw,40px); letter-spacing:-.025em; line-height:.95; font-variant-numeric:tabular-nums; }
.cat-hero__band b i { font-style:normal; font-size:.5em; letter-spacing:0; color:#9BA0A8; }
.cat-hero__band span { font-family:var(--f-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#9BA0A8; }
.cat-hero__title { font-size:clamp(28px,4.2vw,54px); letter-spacing:-.03em; margin:12px 0 0; max-width:18ch; }
.cat-hero__lead { margin-top:16px; max-width:64ch; color:var(--ink-2); }
.cat-hero__lead p { margin:0 0 8px; }
/* графит-шапка без цех-кадра (запчасти): тот же тёмный band, справа — реальный
   студийный изолят на «пластине». Локально тёмная в обеих темах, как --cover */
.cat-hero--ink { background:#101114; color:#F4F5F7; padding:0; }
.cat-hero--ink .cat-hero__in {
  padding:56px 0 48px; display:grid; align-items:center;
  grid-template-columns:minmax(0,1fr) clamp(280px,32vw,430px); gap:clamp(28px,5vw,76px);
}
.cat-hero--ink .eyebrow { color:#A9AEB6; }
.cat-hero--ink .cat-hero__lead { color:#B9BEC6; }
.cat-hero__plate { position:relative; aspect-ratio:4/3; border-radius:var(--r-md); overflow:hidden; border:1px solid rgba(244,245,247,.12); background:#E8EAED; }
.cat-hero__plate img { width:100%; height:100%; object-fit:cover; animation:catKen 16s var(--ease) forwards; }
@media (prefers-reduced-motion:reduce) { .cat-hero__plate img { animation:none; } }
@media (max-width:900px) {
  .cat-hero--ink .cat-hero__in { grid-template-columns:1fr; gap:26px; }
  .cat-hero__plate { max-width:440px; }
}

/* ---------- FILTER — заметный параметрический рельс ---------- */
.filt {
  position:sticky; top:var(--hd-h); z-index:40;
  background:color-mix(in srgb,var(--surf) 86%,transparent); backdrop-filter:blur(14px);
  border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2);
  box-shadow:0 14px 30px -26px rgba(10,12,16,.5);
}
/* прилипший фильтр сворачивается в узкую полосу; hover/фокус раскрывает обратно */
.filt__mini { display:none; align-items:baseline; gap:16px; padding:11px 0; cursor:pointer; }
.filt__mini b { font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); }
.filt__mini span { font-family:var(--f-mono); font-size:11px; color:var(--ink-2); flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.filt__mini i { font-style:normal; font-family:var(--f-mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); white-space:nowrap; }
.filt.is-slim:not(:hover):not(:focus-within) .filt__row { display:none; }
.filt.is-slim:not(:hover):not(:focus-within) .filt__mini { display:flex; }
/* сетка 2×2: [Загрузка | Рамы] / [Мощность | Цена] — симметрично, колонки выровнены
   фикс-шириной лейблов; счётчик и сброс — своей колонкой справа */
.filt__row { display:grid; grid-template-columns:max-content max-content 1fr; align-items:center; gap:10px clamp(28px,4vw,64px); padding:15px 0; }
.filt__group { display:flex; align-items:center; gap:12px; }
.filt__label { width:88px; flex:none; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); }
.filt__chips { display:flex; gap:6px; flex-wrap:wrap; }
.filt__meta { grid-column:3; grid-row:1 / span 2; justify-self:end; display:flex; align-items:center; gap:14px; }
.chip {
  padding:8px 13px; border-radius:999px; border:1px solid var(--line-3); background:var(--surf);
  color:var(--ink); font-size:12.5px; transition:all var(--d-fast) var(--ease);
}
.chip:hover { border-color:var(--ink-3); transform:translateY(-1px); }
.chip.is-on { background:var(--accent); border-color:var(--accent); color:#fff; }
.chip i { font-style:normal; font-family:var(--f-mono); font-size:9px; color:var(--ink-3); margin-left:5px; }
.chip.is-on i { color:rgba(255,255,255,.78); }
@media (max-width:1080px) {
  .filt__row { grid-template-columns:1fr; gap:10px; }
  .filt__meta { grid-column:1; grid-row:auto; justify-self:start; }
  .filt__label { width:auto; min-width:74px; }
}
.filt__reset { font-family:var(--f-mono); font-size:11px; color:var(--ink-3); background:none; border:none; text-decoration:underline; text-underline-offset:3px; }
.filt__reset:hover { color:var(--ink); }
.filt__count { margin-left:auto; font-family:var(--f-mono); font-size:11.5px; color:var(--ink-3); }

/* ---------- PRODUCT GRID + CARD ---------- */
.prod-sec { padding:30px 0 40px; }
.prod-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.prod-grid--4 { grid-template-columns:repeat(4,1fr); }
.prod-empty { text-align:center; color:var(--ink-2); padding:40px 0; }
.pc { display:flex; flex-direction:column; overflow:hidden; border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surf-2); transition:transform var(--d-fast) var(--ease), border-color var(--d-fast), box-shadow var(--d-fast); }
.pc:hover { transform:translateY(-4px); border-color:var(--accent-2); box-shadow:0 30px 60px -34px rgba(0,0,0,.8); }
.pc__media { display:block; height:210px; background:radial-gradient(120% 120% at 70% 15%,var(--surf),var(--bg-2) 76%); overflow:hidden; }
.pc__media img { width:100%; height:100%; object-fit:contain; padding:16px 20px; transition:transform .6s var(--ease); }
.pc:hover .pc__media img { transform:scale(1.05); }
.pc__body { padding:16px 18px 18px; display:flex; flex-direction:column; gap:9px; flex:1; }
.pc__kicker { font-family:var(--f-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.pc__name { font-size:17px; letter-spacing:-.01em; line-height:1.2; }
.pc__name a { transition:color var(--d-fast); }
.pc__name a:hover { color:var(--accent-2); }
.pc__specs { display:flex; gap:16px; margin:2px 0; flex-wrap:wrap; }
.pc__specs > div { display:flex; flex-direction:column; gap:2px; }
.pc__specs dt { font-family:var(--f-mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.pc__specs dd { margin:0; font-family:var(--f-display); font-weight:600; font-size:14px; color:var(--ink); font-variant-numeric:tabular-nums; }
.pc__foot { margin-top:auto; padding-top:12px; border-top:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; gap:10px; }
.pc__price { font-family:var(--f-display); font-weight:700; font-size:16px; letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.pc__price i { font-style:normal; font-family:var(--f-mono); font-size:10px; color:var(--ink-3); text-transform:uppercase; margin-right:4px; font-weight:400; }
.pc__go { display:inline-flex; align-items:center; gap:6px; font-family:var(--f-mono); font-size:11px; color:var(--accent-2); white-space:nowrap; }

/* --- «инженерный лист»: карточка в сетке категории --- */
.pc--sheet { position:relative; background:var(--surf); }
.pc--sheet::before { /* красная hairline растёт по верхней кромке на hover */
  content:""; position:absolute; top:0; left:0; right:0; height:2px; z-index:2;
  background:var(--accent); transform:scaleX(0); transform-origin:left center;
  transition:transform .35s var(--ease);
}
.pc--sheet:hover::before { transform:scaleX(1); }
.pc--sheet:hover { border-color:var(--line-3); }
.pc--sheet .pc__media { position:relative; }
.pc__no {
  position:absolute; top:10px; right:10px; z-index:1;
  font-family:var(--f-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2);
  padding:3px 8px; border-radius:5px;
  background:color-mix(in srgb,var(--surf) 74%,transparent); backdrop-filter:blur(5px);
}
.pc__kicker { display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.pc__art { font-style:normal; font-family:var(--f-mono); font-size:10px; letter-spacing:.08em; color:var(--ink-2); }
.pc__metric { display:flex; flex-direction:column; gap:6px; margin:4px 0 2px; }
.pc__metric b { font-family:var(--f-display); font-weight:700; font-size:26px; letter-spacing:-.025em; line-height:1; font-variant-numeric:tabular-nums; }
.pc__metric b i { font-style:normal; font-size:.55em; color:var(--ink-3); letter-spacing:0; }
.pc__bar { display:block; height:3px; border-radius:2px; background:var(--line); overflow:hidden; }
.pc__bar i { display:block; height:100%; border-radius:2px; background:color-mix(in srgb,var(--ink) 55%,transparent); }
.pc__metric em { font-style:normal; font-family:var(--f-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.pc__specs--minor { gap:14px; }

/* ---------- IX: конфигуратор поля инъекции (interaction-shell) ---------- */
.ix__sub { color:var(--ink-2); max-width:70ch; margin:-8px 0 24px; line-height:1.6; }
.ix__grid { display:grid; grid-template-columns:minmax(280px,380px) minmax(0,1fr); gap:clamp(24px,4vw,56px); align-items:start; }
.ix__row { margin-bottom:20px; }
.ix__lbl { display:block; font-family:var(--f-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:10px; }
.ix__opts { display:flex; gap:8px; }
.ix__opt {
  font-family:var(--f-mono); font-size:12.5px; padding:8px 15px; cursor:pointer;
  border:1px solid var(--line-2); border-radius:999px; background:var(--surf); color:var(--ink-2);
  transition:border-color .2s var(--ease), color .2s var(--ease);
}
.ix__opt:hover { border-color:var(--line-3); }
.ix__opt.is-on { border-color:var(--ink); color:var(--ink); }
.ix__slider { display:flex; align-items:center; gap:14px; }
.ix__slider input { flex:1; accent-color:var(--ink); }
.ix__slider output { font-family:var(--f-mono); font-size:14px; min-width:2.2ch; text-align:right; font-variant-numeric:tabular-nums; }
.ix__read { display:grid; grid-template-columns:1fr 1fr; gap:0 20px; margin:24px 0; border-top:1px solid var(--line); }
.ix__read > div { padding:12px 0 14px; border-bottom:1px solid var(--line); }
.ix__read dt { font-family:var(--f-mono); font-size:10px; letter-spacing:.09em; text-transform:uppercase; color:var(--ink-3); margin-bottom:6px; }
.ix__read dd { margin:0; }
.ix__read dd b { font-family:var(--f-display); font-weight:700; font-size:24px; letter-spacing:-.02em; font-variant-numeric:tabular-nums; }
.ix__read dd i { font-style:normal; font-family:var(--f-mono); font-size:10px; color:var(--ink-3); margin-left:5px; }
.ix__hero dt::before { content:""; display:inline-block; width:14px; height:2px; background:var(--accent); margin-right:8px; vertical-align:2px; } /* единственный красный модуля */
.ix__stage { position:relative; border:1px solid var(--line-2); border-radius:var(--r-md); background:var(--surf); padding:16px 16px 42px; }
.ix__stage svg { width:100%; height:auto; display:block; }
.ix__cap { position:absolute; left:18px; bottom:13px; right:18px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-3); }
.ix-belt { fill:var(--surf-2); }
.ix-edge { stroke:var(--line-3); stroke-width:1.2; }
.ix-dot { fill:color-mix(in srgb,var(--ink) 52%,transparent); }
.ix-house { fill:color-mix(in srgb,var(--ink) 5%,transparent); stroke:var(--line-3); stroke-width:1; }
.ix-needle { fill:var(--ink); }
.ix-dim { stroke:var(--ink-3); stroke-width:1; }
.ix-arrow { fill:var(--ink-3); }
.ix-t { font-family:var(--f-mono); font-size:10px; letter-spacing:.06em; fill:var(--ink-3); text-transform:uppercase; }
@media (max-width:900px) {
  .ix__grid { grid-template-columns:1fr; }
  .ix__stage { order:-1; }
}

/* ---------- ROI-МИНИ: окупаемость этой камеры (тёмный остров карточки) ---------- */
.roi-mini { position:relative; margin:38px 0; padding:52px 0 58px; background:#101114; color:#F4F5F7; overflow:hidden; }
.roi-mini .container { position:relative; }
.roi-mini .eyebrow { color:#A9AEB6; }
.roi-mini .psec__no { color:#A9AEB6; } .roi-mini .psec__art { color:#8A8F97; } .roi-mini .psec__rule { background:rgba(244,245,247,.12); }
.roi-mini .pghost { -webkit-text-stroke-color:rgba(244,245,247,.08); }
.roi-mini__h { position:relative; padding-top:14px; margin-top:10px; font-size:clamp(24px,2.6vw,38px); letter-spacing:-.02em; }
.roi-mini__h::before { content:""; position:absolute; top:0; left:2px; width:30px; height:3px; background:var(--accent); } /* единственный красный блока — CTA ниже тоже красный, но это и есть магнит */
.roi-mini__sub { margin-top:12px; color:#A9AEB6; max-width:62ch; line-height:1.6; }
.roi-mini__grid { display:grid; grid-template-columns:minmax(0,1.25fr) minmax(300px,1fr); gap:clamp(24px,4vw,60px); margin-top:32px; align-items:start; }
.roi-mini__groups { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.roi-g {
  display:flex; flex-direction:column; gap:8px; text-align:left; cursor:pointer; padding:12px;
  background:#17191E; border:1px solid rgba(244,245,247,.09); border-radius:var(--r-md); color:#F4F5F7;
  transition:border-color .2s var(--ease), transform .2s var(--ease);
}
.roi-g:hover { border-color:rgba(244,245,247,.24); transform:translateY(-2px); }
.roi-g.is-on { border-color:#F4F5F7; }
.roi-g__media { aspect-ratio:20/13; border-radius:8px; overflow:hidden; background:#101114; }
.roi-g__media img { width:100%; height:100%; object-fit:cover; display:block; }
.roi-g__l { font-family:var(--f-display); font-weight:700; font-size:14.5px; letter-spacing:-.01em; line-height:1.2; }
.roi-g__hint { font-family:var(--f-mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:#8A8F97; line-height:1.5; }
.roi-g--other { grid-column:1 / -1; flex-direction:row; align-items:center; justify-content:space-between; }
.roi-g--other .roi-g__hint { color:#A9AEB6; }
.roi-mini__res { border:1px solid rgba(244,245,247,.12); border-radius:var(--r-md); background:#17191E; padding:24px 24px 22px; }
.roi-mini__cap { display:block; font-family:var(--f-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#8A8F97; margin-bottom:10px; }
.roi-mini__num { display:block; font-family:var(--f-display); font-weight:700; font-size:clamp(34px,3.4vw,50px); letter-spacing:-.03em; line-height:1; font-variant-numeric:tabular-nums; }
.roi-mini__num--txt { font-size:clamp(22px,2.2vw,30px); }
.roi-mini__gauge { height:3px; margin:16px 0 6px; background:rgba(244,245,247,.12); border-radius:2px; overflow:hidden; }
.roi-mini__gauge i { display:block; height:100%; width:0; background:#F4F5F7; border-radius:2px; transition:width .5s var(--ease); }
.roi-mini__stats { display:grid; grid-template-columns:1fr 1fr; gap:0 18px; margin:14px 0 4px; }
.roi-mini__stats > div { padding:10px 0 12px; border-bottom:1px solid rgba(244,245,247,.09); }
.roi-mini__stats dt { font-family:var(--f-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:#8A8F97; margin-bottom:5px; }
.roi-mini__stats dd { margin:0; font-family:var(--f-mono); font-size:15px; font-variant-numeric:tabular-nums; color:#F4F5F7; }
.roi-mini__custom-p { margin-top:10px; color:#A9AEB6; font-size:14px; line-height:1.6; }
.roi-mini__res .btn { margin-top:18px; width:100%; justify-content:center; }
.roi-mini__note { margin-top:14px; font-size:11.5px; line-height:1.55; color:#8A8F97; }
@media (max-width:980px) {
  .roi-mini__grid { grid-template-columns:1fr; }
  .roi-mini__groups { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:560px) { .roi-mini__groups { grid-template-columns:1fr; } }

/* ---------- Тёмная медиа-зона: техособенности + видео (второй тёмный такт) ---------- */
.mz { position:relative; margin:38px 0; padding:52px 0 56px; background:#101114; color:#F4F5F7; overflow:hidden; }
.mz::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:repeating-linear-gradient(122deg, rgba(255,255,255,.022) 0 2px, transparent 2px 11px); }
.mz .container { position:relative; }
.mz .psec__no { color:#A9AEB6; } .mz .psec__art { color:#8A8F97; } .mz .psec__rule { background:rgba(244,245,247,.12); }
.mz .pghost { -webkit-text-stroke-color:rgba(244,245,247,.08); }
.mz__eyebrow { display:block; font-family:var(--f-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#8A8F97; margin-bottom:10px; }
.mz__h { position:relative; padding-top:14px; font-size:clamp(22px,2.4vw,34px); letter-spacing:-.02em; margin-bottom:18px; }
.mz__h::before { content:""; position:absolute; top:0; left:2px; width:30px; height:3px; background:var(--accent); } /* единственный красный полосы */
.mz__prose { max-width:74ch; color:#C3C7CD; }
.mz__prose h3, .mz__prose h2 { color:#F4F5F7; }
.mz__prose ul { padding-left:0; list-style:none; display:grid; gap:10px; margin:16px 0; }
.mz__prose ul li { position:relative; padding:13px 16px 13px 40px; border:1px solid rgba(244,245,247,.09); border-radius:10px; background:#17191E; line-height:1.55; }
.mz__prose ul li::before { content:""; position:absolute; left:16px; top:19px; width:10px; height:10px; border:1.5px solid #8A8F97; border-radius:3px; }
.mz__prose b, .mz__prose strong { color:#F4F5F7; }
.mz__vids--after { margin-top:34px; }
.mz__vid { position:relative; margin:0; }
.mz__vid video { width:100%; aspect-ratio:16/9; object-fit:cover; display:block; border-radius:var(--r-md); background:#000; border:1px solid rgba(244,245,247,.1); }
.mz__vid figcaption { display:flex; justify-content:space-between; gap:14px; padding:10px 2px 0; font-family:var(--f-mono); font-size:11px; letter-spacing:.08em; color:#8A8F97; }
.mz__vid figcaption i { font-style:normal; color:#6C7078; font-variant-numeric:tabular-nums; }
.mz__vgrid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:18px; }
@media (max-width:760px) { .mz__vgrid { grid-template-columns:1fr; } }

/* ---------- «Технические особенности»: светлый блок с чек-плашками ---------- */
.featp__eyebrow { display:block; font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px; }
.featp { max-width:none; }
/* интро/хвост — редакционные 2 колонки на всю ширину
   (.prose.featp__cols — перебиваем max-width:74ch у .prose, объявленного ниже) */
.prose.featp__cols { max-width:none; column-count:2; column-gap:clamp(36px,4.5vw,72px); }
.prose.featp__cols p { max-width:none; }
.featp__cols--outro { margin-top:20px; }
/* преимущества — строгие тезисы-строки «заголовок | текст» (без карточек) */
.tzn { margin:26px 0 4px; border-top:1px solid var(--line-3); }
.tzn__row {
  display:grid; grid-template-columns:minmax(220px,32%) 1fr;
  gap:8px clamp(28px,5vw,84px); padding:22px 0 24px; border-bottom:1px solid var(--line);
}
.tzn__row h3 { margin:0; font-family:var(--f-display); font-weight:700; font-size:clamp(17px,1.8vw,22px); letter-spacing:-.015em; line-height:1.25; }
.tzn__row p { margin:0; color:var(--ink-2); font-size:15px; line-height:1.65; max-width:72ch; }
@media (max-width:760px) { .tzn__row { grid-template-columns:1fr; } }
@media (max-width:900px) { .prose.featp__cols { column-count:1; } }

/* v4 «навигатор особенностей»: тезисы-вкладки слева, читальная панель справа */
.feat4 {
  display:grid; grid-template-columns:minmax(260px,38%) 1fr;
  gap:clamp(28px,4.5vw,72px);
  margin:30px 0 6px; padding-top:6px;
}
.feat4__nav { display:flex; flex-direction:column; border-top:1px solid var(--line-3); }
.feat4__tab {
  appearance:none; background:none; border:0; border-bottom:1px solid var(--line);
  padding:15px 26px 16px 18px; text-align:left; cursor:pointer;
  position:relative;
  font-family:var(--f-display); font-weight:600; font-size:clamp(15.5px,1.25vw,17.5px);
  letter-spacing:-.01em; line-height:1.3; color:var(--ink-3);
  transition:color var(--d-fast) var(--ease);
}
.feat4__tab:hover { color:var(--ink-2); }
.feat4__tab.is-on { color:var(--ink); }
/* красный тик активного тезиса — единственный красный блока */
.feat4__tab::before {
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%) scaleY(0);
  width:3px; height:56%; background:var(--accent);
  transition:transform var(--d-fast) var(--ease);
}
.feat4__tab.is-on::before { transform:translateY(-50%) scaleY(1); }
.feat4__tab::after {
  content:"→"; position:absolute; right:2px; top:50%; transform:translateY(-50%);
  font-family:var(--f-mono); font-size:13px; color:var(--ink-3);
  opacity:0; transition:opacity var(--d-fast) var(--ease);
}
.feat4__tab.is-on::after { opacity:1; }
.feat4__panes { min-height:220px; }
.feat4__pane { display:none; }
.feat4__pane.is-on { display:block; animation:feat4In .38s var(--ease); }
@keyframes feat4In { from { opacity:0; transform:translateY(10px); } }
.feat4__pt {
  margin:2px 0 0; font-family:var(--f-display); font-weight:700;
  font-size:clamp(22px,2.3vw,33px); letter-spacing:-.02em; line-height:1.12; max-width:22ch;
}
.feat4__px { margin:16px 0 0; color:var(--ink-2); font-size:clamp(15px,1.15vw,16.5px); line-height:1.7; max-width:64ch; }
@media (prefers-reduced-motion: reduce) { .feat4__pane.is-on { animation:none; } }
@media (max-width:860px) {
  /* мобайл: вкладки прячем, панели раскладываем стопкой строк */
  .feat4 { display:block; margin-top:22px; }
  .feat4__nav { display:none; }
  .feat4__pane { display:block; padding:20px 0 22px; border-bottom:1px solid var(--line); animation:none; }
  .feat4__panes > .feat4__pane:first-child { border-top:1px solid var(--line-3); }
  .feat4__pt { font-size:19px; }
  .feat4__px { margin-top:9px; font-size:14.5px; }
}

/* ---------- Full-bleed цеховой кадр-разделитель (только реальные live-кадры) ---------- */
.shopband { position:relative; height:clamp(320px,44vh,500px); overflow:hidden; }
.shopband img { width:100%; height:100%; object-fit:cover; display:block; }
.shopband::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(16,17,20,.35), rgba(16,17,20,.62)); }
.shopband__plate {
  position:absolute; left:50%; bottom:30px; transform:translateX(-50%); z-index:2;
  display:flex; align-items:baseline; gap:18px; flex-wrap:wrap; justify-content:center;
  padding:14px 22px; border:1px solid rgba(244,245,247,.25); border-radius:10px;
  background:rgba(16,17,20,.55); backdrop-filter:blur(8px); color:#F4F5F7;
}
.shopband__plate span { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:#B9BEC6; }
.shopband__plate b { font-family:var(--f-mono); font-size:16px; font-variant-numeric:tabular-nums; }

/* ---------- Запчасти и комплектующие: графитовый банер-«склад».
   Заголовок — главный и белый (жалоба «фраза не видна»); справа приборный
   циферблат: кольцо-риски + крестовина, доворачивается на hover ---------- */
.parts2 {
  position:relative; overflow:hidden;
  display:grid; grid-template-columns:minmax(0,1fr) auto auto; align-items:center;
  gap:20px clamp(24px,4vw,56px);
  padding:clamp(26px,3vw,38px) clamp(24px,3.4vw,44px);
  border-radius:var(--r-lg); background:#101114; color:#F4F5F7;
  border:1px solid rgba(244,245,247,.09);
  transition:border-color .25s var(--ease);
}
.parts2::before { /* чертёжная микросетка, гаснет к левому краю под текстом */
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image:linear-gradient(rgba(244,245,247,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(244,245,247,.045) 1px, transparent 1px);
  background-size:26px 26px;
  -webkit-mask:linear-gradient(90deg, transparent 6%, #000 55%);
  mask:linear-gradient(90deg, transparent 6%, #000 55%);
}
.parts2:hover { border-color:rgba(244,245,247,.26); }
.parts2__body { position:relative; display:flex; flex-direction:column; min-width:240px; }
.parts2__kicker { font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#B9BEC6; margin-bottom:12px; }
.parts2__t {
  position:relative; padding-top:14px; margin-bottom:10px;
  font-family:var(--f-display); font-weight:700; font-size:clamp(24px,2.6vw,36px); letter-spacing:-.02em; line-height:1.05; color:#F4F5F7;
}
.parts2__t::before { content:""; position:absolute; top:0; left:2px; width:30px; height:3px; background:var(--accent); } /* единственный красный плашки */
.parts2__d { color:#A9AEB6; font-size:14.5px; line-height:1.6; max-width:52ch; }
.parts2__dial { position:relative; width:clamp(84px,8vw,110px); height:clamp(84px,8vw,110px); color:#D9DCE1; }
.parts2__dial svg { width:100%; height:100%; display:block; }
.parts2__ring { transform-origin:48px 48px; transition:transform 1s var(--ease); color:#8A8F97; }
.parts2:hover .parts2__ring { transform:rotate(28deg); }
.parts2__btn {
  position:relative; display:inline-flex; align-items:center; gap:10px; white-space:nowrap;
  padding:13px 22px; border:1px solid rgba(244,245,247,.28); border-radius:999px;
  font-family:var(--f-mono); font-size:12px; letter-spacing:.05em; color:#F4F5F7;
  transition:background .2s var(--ease), border-color .2s var(--ease), transform .25s var(--ease);
}
.parts2:hover .parts2__btn { background:#F4F5F7; border-color:#F4F5F7; color:#101114; transform:translateX(3px); }
@media (max-width:900px) {
  .parts2 { grid-template-columns:1fr; }
  .parts2__dial { display:none; }
  .parts2__btn { justify-self:start; }
}

/* ---------- Третий тёмный такт: качество + отзывы на реальном цех-кадре ---------- */
.trustband { position:relative; margin-top:38px; padding:56px 0 60px; background:#101114; color:#F4F5F7; overflow:hidden; }
.trustband__bg { position:absolute; inset:0; z-index:0; }
.trustband__bg img { width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.05); }
.trustband__bg::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(16,17,20,.88), rgba(16,17,20,.94)); }
.trustband__in { position:relative; z-index:1; }
.trustband .psec__no { color:#A9AEB6; } .trustband .psec__art { color:#8A8F97; } .trustband .psec__rule { background:rgba(244,245,247,.12); }
.trustband .pghost { -webkit-text-stroke-color:rgba(244,245,247,.08); }
.trustband__h { position:relative; padding-top:14px; font-size:clamp(22px,2.4vw,34px); letter-spacing:-.02em; margin-bottom:24px; max-width:24ch; }
.trustband__h::before { content:""; position:absolute; top:0; left:2px; width:30px; height:3px; background:var(--accent); } /* единственный красный полосы */
.trustband__h2 { font-size:clamp(18px,1.8vw,24px); letter-spacing:-.015em; margin:0; }

.qly { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:14px; }
.qly__item { position:relative; padding:20px 20px 18px; border:1px solid rgba(244,245,247,.1); border-radius:var(--r-md); background:rgba(23,25,30,.82); }
.qly__ic { display:block; width:22px; height:22px; color:#8A8F97; margin-bottom:14px; }
.qly__t { font-family:var(--f-display); font-weight:700; font-size:16px; letter-spacing:-.01em; margin:0 0 6px; color:#F4F5F7; }
.qly__d { margin:0; font-size:13px; line-height:1.55; color:#A9AEB6; }

.tstm__head { display:flex; align-items:baseline; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:38px; }
.tstm__all { font-family:var(--f-mono); font-size:11px; letter-spacing:.06em; color:#B9BEC6; border-bottom:1px solid rgba(244,245,247,.3); padding-bottom:2px; }
.tstm__all:hover { color:#F4F5F7; border-color:#F4F5F7; }
.tstm { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:14px; margin-top:16px; }
.tstm__card { position:relative; margin:0; padding:26px 22px 20px; border:1px solid rgba(244,245,247,.1); border-radius:var(--r-md); background:rgba(23,25,30,.82); display:flex; flex-direction:column; gap:14px; }
.tstm__card::before { content:"«"; position:absolute; top:14px; left:20px; font-family:var(--f-display); font-weight:700; font-size:44px; line-height:.6; color:#3A3E46; pointer-events:none; }
.tstm__text { margin:0; padding-top:34px; font-size:14.5px; line-height:1.6; color:#D9DCE1; }
.tstm__who { display:flex; flex-direction:column; gap:3px; margin-top:auto; padding-top:12px; border-top:1px solid rgba(244,245,247,.1); }
.tstm__who b { font-family:var(--f-display); font-size:14px; letter-spacing:-.01em; color:#F4F5F7; }
.tstm__who span { font-family:var(--f-mono); font-size:10px; letter-spacing:.05em; text-transform:uppercase; color:#8A8F97; line-height:1.5; }

/* ---------- EDITORIAL (маркетинговые блоки категории) ---------- */
.editorial { padding:36px 0; border-top:1px solid var(--line); }
.editorial__h { font-size:clamp(22px,2.4vw,34px); letter-spacing:-.02em; margin-bottom:16px; max-width:22ch; }
.editorial__p { color:var(--ink-2); max-width:70ch; margin-bottom:12px; line-height:1.65; }
.stat-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-top:20px; }
.stat-card { padding:20px; border:1px solid var(--line-2); border-radius:var(--r-md); background:var(--surf-2); }
.stat-card b { display:block; font-family:var(--f-display); font-weight:700; font-size:30px; letter-spacing:-.02em; color:var(--ink); }
.stat-card span { display:block; margin-top:4px; font-size:13px; color:var(--ink-2); }
.stat-card i { display:block; margin-top:6px; font-family:var(--f-mono); font-size:10px; color:var(--ink-3); font-style:normal; }
/* --- «манифест»: тёмный full-bleed блок сервисных обещаний — контраст-ритм страницы --- */
.vband { padding:56px 0 62px; background:#101114; color:#F4F5F7; }
.vband__h { position:relative; padding-top:16px; font-size:clamp(24px,2.6vw,38px); letter-spacing:-.02em; max-width:22ch; }
.vband__h::before { content:""; position:absolute; top:0; left:2px; width:30px; height:3px; background:var(--accent); } /* единственный красный блока */
.vband__p { margin-top:14px; color:#A9AEB6; max-width:64ch; line-height:1.65; }
.vcards { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:30px; }
.vcard {
  overflow:hidden; border-radius:var(--r-md); background:#17191E; border:1px solid rgba(244,245,247,.09);
  transition:transform var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);
}
.vcard:hover { transform:translateY(-3px); border-color:rgba(244,245,247,.22); box-shadow:0 26px 48px -32px rgba(0,0,0,.85); }
.vcard__ph { display:block; aspect-ratio:2/1; background:#101114; }
.vcard__ph img { width:100%; height:100%; object-fit:cover; }
.vcard__body { padding:18px 22px 24px; }
.vcard__no { display:block; font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; color:#6C7078; }
.vcard__body b { display:block; margin-top:8px; font-family:var(--f-display); font-weight:700; font-size:18px; letter-spacing:-.015em; color:#F4F5F7; }
.vcard__body p { margin-top:9px; color:#A9AEB6; font-size:14px; line-height:1.6; }
@media (max-width:860px) { .vcards { grid-template-columns:1fr; } }

/* --- инженерные узлы: просторные медиа-ряды (зигзаг) --- */
.eng { display:flex; flex-direction:column; gap:14px; margin-top:34px; }
.eng__row {
  display:grid; grid-template-columns:400px 1fr; gap:clamp(24px,4vw,56px); align-items:center;
  padding:26px; border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surf);
}
.eng__row:nth-child(even) { grid-template-columns:1fr 400px; }
.eng__row:nth-child(even) .eng__ph { order:2; }
.eng__ph { display:block; aspect-ratio:4/3; border-radius:var(--r-md); overflow:hidden; background:radial-gradient(120% 120% at 60% 20%, var(--bg-2), var(--surf-2)); border:1px solid var(--line); }
.eng__ph img { width:100%; height:100%; object-fit:contain; padding:14px; }
.eng__k { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.eng__body h3 { margin:10px 0 0; font-size:clamp(19px,2vw,26px); letter-spacing:-.02em; }
.eng__body p { margin-top:12px; color:var(--ink-2); font-size:15px; line-height:1.65; max-width:62ch; }
@media (max-width:860px) {
  .eng__row, .eng__row:nth-child(even) { grid-template-columns:1fr; }
  .eng__row:nth-child(even) .eng__ph { order:0; }
}

.feat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(255px,1fr)); gap:16px; margin-top:24px; }
.feat {
  padding:20px; border:1px solid var(--line-2); border-radius:var(--r-md); background:var(--surf);
  transition:border-color var(--d-fast) var(--ease), transform var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);
}
.feat:hover { border-color:var(--line-3); transform:translateY(-3px); box-shadow:0 22px 40px -30px rgba(10,12,16,.35); }
.feat__ph { display:block; aspect-ratio:16/10; margin:-20px -20px 16px; overflow:hidden; border-radius:var(--r-md) var(--r-md) 0 0; border-bottom:1px solid var(--line); background:var(--bg-2); }
.feat__ph img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.feat:hover .feat__ph img { transform:scale(1.04); }
.feat b { display:block; font-family:var(--f-display); font-weight:700; font-size:16.5px; letter-spacing:-.015em; line-height:1.25; }
.feat__tag { display:block; margin-top:5px; font-family:var(--f-mono); font-size:10px; letter-spacing:.09em; text-transform:uppercase; color:var(--ink-3); }
.feat p { margin-top:9px; color:var(--ink-2); font-size:13.5px; line-height:1.55; }

/* --- шкала высот линейки: реальные мм в масштабе + человек 180 см --- */
.hviz { position:relative; display:flex; align-items:flex-end; gap:clamp(26px,5.5vw,70px); margin-top:34px; max-width:900px; }
.hviz::after { /* красная линия «пола» — единственный сигнал секции */
  content:""; position:absolute; left:-8px; right:-8px; bottom:48px; height:2px; background:var(--accent);
}
.hviz__item { flex:0 0 auto; display:flex; flex-direction:column; align-items:center; }
.hviz__scale { height:min(320px,38vw); display:flex; flex-direction:column; justify-content:flex-end; align-items:center; }
.hviz__mm { font-family:var(--f-mono); font-size:12px; letter-spacing:.05em; color:var(--ink); margin-bottom:9px; font-variant-numeric:tabular-nums; }
.hviz__cab {
  position:relative; width:clamp(88px,9vw,124px); border-radius:6px 6px 0 0;
  background:linear-gradient(180deg, color-mix(in srgb,var(--ink) 8%,var(--surf)), color-mix(in srgb,var(--ink) 18%,var(--surf)));
  border:1px solid var(--line-3); border-bottom:none;
}
.hviz__cab::before { /* дверной проём */
  content:""; position:absolute; top:7%; left:12%; right:12%; bottom:0;
  border:1px solid var(--line-3); border-bottom:none; border-radius:4px 4px 0 0;
}
.hviz__cab::after { /* ручка */
  content:""; position:absolute; right:21%; top:34%; width:3px; height:24%; border-radius:2px; background:var(--ink-3);
}
.hviz__cap { height:48px; padding-top:12px; display:flex; flex-direction:column; align-items:center; gap:3px; }
.hviz__cap b { font-family:var(--f-display); font-weight:700; font-size:15px; letter-spacing:-.01em; }
.hviz__cap span { font-family:var(--f-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.hviz__man { display:block; width:auto; fill:color-mix(in srgb,var(--ink) 32%,transparent); }
/* реальное фото камеры серии, высота = настоящие мм в масштабе; паспарту работает в обеих темах */
.hviz__ph { display:flex; align-items:flex-end; justify-content:center; background:#fff; border:1px solid var(--line-2); border-radius:8px; padding:6px; box-sizing:border-box; }
.hviz__ph img { height:100%; width:auto; max-width:clamp(110px,12vw,170px); object-fit:contain; display:block; }
@media (max-width:700px) { .hviz { overflow-x:auto; padding-bottom:4px; } }

/* ---------- PRODUCT PAGE ---------- */
.prod { padding:10px 0 20px; }
.prod__top { display:grid; grid-template-columns:1.05fr 1fr; gap:40px; padding-top:16px; }
.gal { position:sticky; top:calc(var(--hd-h) + 16px); align-self:start; }
/* «инженерный стенд»: микросетка, кроп-марки, чипы-показания на кадре,
   watermark-артикул stroke-only за изделием */
.gal__main {
  position:relative; border:1px solid var(--line-2); border-radius:var(--r-lg); overflow:hidden;
  background:linear-gradient(180deg,var(--bg-2),var(--surf)); aspect-ratio:4/3; display:grid; place-items:center;
}
.gal__main::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.6;
  background-image:linear-gradient(rgba(20,22,26,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(20,22,26,.05) 1px, transparent 1px);
  background-size:26px 26px;
  -webkit-mask:radial-gradient(90% 84% at 50% 46%, #000 46%, transparent);
  mask:radial-gradient(90% 84% at 50% 46%, #000 46%, transparent);
}
.gal__main img { position:relative; z-index:1; width:100%; height:100%; object-fit:contain; padding:30px 26px 44px; }
.gal__cm { position:absolute; width:15px; height:15px; z-index:2; pointer-events:none; border:0 solid var(--line-3); }
.gal__cm--tl { top:10px; left:10px; border-top-width:1px; border-left-width:1px; }
.gal__cm--tr { top:10px; right:10px; border-top-width:1px; border-right-width:1px; }
.gal__cm--bl { bottom:10px; left:10px; border-bottom-width:1px; border-left-width:1px; }
.gal__cm--br { bottom:10px; right:10px; border-bottom-width:1px; border-right-width:1px; }
.gal__chips { position:absolute; top:14px; left:14px; z-index:2; display:flex; flex-direction:column; gap:8px; align-items:flex-start; }
.gal__chip {
  display:flex; flex-direction:column; gap:2px; padding:7px 11px; border-radius:8px;
  background:color-mix(in srgb,var(--surf) 78%,transparent); backdrop-filter:blur(6px); border:1px solid var(--line-2);
}
.gal__chip i { font-style:normal; font-family:var(--f-mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.gal__chip b { font-family:var(--f-display); font-weight:700; font-size:15px; letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.gal__plate { position:absolute; left:14px; bottom:12px; z-index:2; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.12em; color:var(--ink-3); }
.gal__count { position:absolute; right:14px; bottom:12px; z-index:2; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; color:var(--ink-2); font-variant-numeric:tabular-nums; }
.gal__count em { font-style:normal; color:var(--ink-3); }
.gal__thumbs { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }
.gal__thumb { width:58px; height:50px; border:1px solid var(--line-2); border-radius:9px; overflow:hidden; background:var(--bg-2); padding:0; transition:border-color var(--d-fast); }
.gal__thumb img { width:100%; height:100%; object-fit:contain; padding:5px; }
.gal__thumb.is-on { border-color:var(--ink); }
.gal__thumb:hover { border-color:var(--ink-3); }
.prod__info { min-width:0; }
.prod__name { font-size:clamp(26px,3vw,42px); letter-spacing:-.025em; margin:12px 0 0; }
.prod__tagline { margin-top:12px; color:var(--ink-2); font-size:16px; line-height:1.55; max-width:48ch; }
.prod__art { display:inline-block; margin-top:14px; font-family:var(--f-mono); font-size:12px; color:var(--ink-3); }
.prod__art b { color:var(--ink-2); }
.prod__price { display:flex; align-items:baseline; gap:12px; margin:20px 0; }
.prod__price span { font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.prod__price b { font-family:var(--f-mono); font-weight:700; font-size:clamp(34px,3.6vw,48px); letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.prod__cta { display:flex; gap:12px; flex-wrap:wrap; margin:4px 0 20px; }
.prod__trust { list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px 20px; }
.prod__trust li { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-2); }
.prod__trust .pico { width:16px; height:16px; color:var(--ink-3); flex:none; }
.prod__block { position:relative; overflow:hidden; padding:38px 0 34px; border-top:1px solid var(--line); }
.block-h { font-size:clamp(20px,2.2vw,30px); letter-spacing:-.02em; margin-bottom:18px; }
/* шкала с рисками под заголовком секции — приборная деталь паспорта */
.prod__block .block-h { position:relative; padding-bottom:14px; }
.prod__block .block-h::after {
  content:""; position:absolute; left:0; bottom:0; width:min(280px,100%); height:7px;
  background:
    repeating-linear-gradient(90deg, var(--line-3) 0 1px, transparent 1px 60px),
    repeating-linear-gradient(90deg, var(--line-2) 0 1px, transparent 1px 12px);
}

/* базовый размер hairline-иконок спрайта */
.pico { width:20px; height:20px; }

/* --- сквозной каркас секций: «обзор ————— тк-1501» mono-линейка --- */
.psec { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.psec__no { font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; color:var(--ink-2); white-space:nowrap; }
.psec__rule { flex:1; height:1px; background:var(--line); }
.psec__art { font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; color:var(--ink-3); white-space:nowrap; }

/* --- паспортная лента гигантских цифр под hero --- */
.pass { margin-top:34px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--surf-2); }
.pass__row { display:flex; flex-wrap:wrap; }
.pass__cell { flex:1 1 200px; padding:26px 28px 24px; border-left:1px solid var(--line); display:flex; flex-direction:column; gap:8px; }
.pass__cell:first-child { border-left:0; padding-left:0; }
.pass__cell b { font-family:var(--f-mono); font-weight:700; font-size:clamp(30px,3.6vw,54px); letter-spacing:-.04em; line-height:.95; font-variant-numeric:tabular-nums; white-space:nowrap; }
.pass__cell b i { font-style:normal; font-size:.42em; letter-spacing:0; color:var(--ink-3); }
.pass__cell span { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.pass__cell--dim b { font-size:clamp(22px,2.2vw,34px); align-self:flex-start; padding-top:.35em; }
.pass__cell--lead { position:relative; }
.pass__cell--lead::before { content:""; position:absolute; top:0; left:0; width:30px; height:3px; background:var(--accent); } /* единственный красный экрана */

/* --- обзор: редакционный двухколонник с реальным кадром --- */
.osplit { display:grid; grid-template-columns:minmax(0,60ch) minmax(280px,1fr); gap:clamp(28px,4.5vw,64px); align-items:start; }
.ofig { position:relative; margin:0; border:1px solid var(--line-2); border-radius:var(--r-md); overflow:hidden; background:var(--surf); }
.ofig img { width:100%; height:auto; display:block; }
.ofig figcaption { padding:10px 14px; border-top:1px solid var(--line); font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
@media (max-width:960px) { .osplit { grid-template-columns:1fr; } .ofig { max-width:480px; } }

/* цена-калькулятор */
.calc { margin:20px 0; padding:20px; border:1px solid var(--line-2); border-radius:var(--r-md); background:var(--surf-2); }
.calc__row { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:14px; }
.calc__lbl { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); min-width:96px; }
.calc__opts { display:flex; gap:6px; flex-wrap:wrap; }
.calc__opt { display:inline-flex; align-items:center; gap:7px; padding:8px 14px; border-radius:999px; border:1px solid var(--line-2); background:transparent; color:var(--ink-2); font-size:13px; transition:all var(--d-fast) var(--ease); }
.calc__opt .pico { width:14px; height:14px; flex:none; opacity:.75; }
.calc__ic-img { width:18px; height:18px; flex:none; }
.calc__opt.is-on .calc__ic-img { background:#fff; border-radius:50%; } /* фирменная красная иконка на красной заливке — в белом кружке */
.calc__opt:hover { border-color:var(--ink-3); color:var(--ink); }
/* активный выбор калькулятора — красная заливка (по фидбэку «цветов не хватает»);
   осознанное локальное исключение из правила одного красного */
.calc__opt.is-on { background:var(--accent); border-color:var(--accent); color:#fff; }
.calc__opt.is-on:hover { border-color:var(--accent); color:#fff; }
.calc__opt.is-on .pico { opacity:1; }
.calc__price { display:flex; align-items:baseline; gap:10px; margin-top:6px; padding-top:14px; border-top:1px solid var(--line); }
.calc__price span { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.calc__price b { font-family:var(--f-display); font-weight:700; font-size:28px; letter-spacing:-.02em; font-variant-numeric:tabular-nums; }

/* --- характеристики: паспортные группы с mono-подзаголовками и иконками --- */
/* характеристики: «рельса» групп слева (в ритме навигатора особенностей),
   строки-техпаспорт справа */
.specs-groups { display:flex; flex-direction:column; }
.sgrp {
  display:grid; grid-template-columns:minmax(190px,24%) 1fr;
  gap:14px clamp(28px,4.5vw,72px);
  padding:24px 0 26px; border-top:1px solid var(--line);
}
.specs-groups .sgrp:first-child { border-top:1px solid var(--line-3); }
.sgrp__h { display:flex; align-items:flex-start; gap:10px; font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); margin:2px 0 0; line-height:1.6; }
.sgrp__ic { width:18px; height:18px; color:var(--ink-3); flex:none; }
@media (max-width:860px) { .sgrp { grid-template-columns:1fr; gap:10px; padding:18px 0 20px; } }

/* specs — техпаспорт: лидер-линии между параметром и значением (в тон чертежу) */
.specs { display:grid; grid-template-columns:1fr 1fr; gap:0 56px; margin:0; align-content:start; }
.specs dd b { font-weight:600; }
.specs dd i {
  font-style:normal; font-family:var(--f-mono); font-size:11.5px;
  color:var(--ink-3); margin-left:5px; letter-spacing:.02em;
}
.specs > div {
  display:flex; align-items:baseline; gap:0;
  padding:13px 10px; border-bottom:1px solid var(--line); border-radius:7px 7px 0 0;
  transition:background var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease);
}
.specs > div:hover { background:var(--surf-2); border-bottom-color:var(--line-3); }
.specs dt { order:0; flex:0 1 auto; color:var(--ink-2); font-size:14px; line-height:1.35; }
.specs > div::after {
  content:""; order:1; flex:1 1 auto; align-self:flex-end;
  min-width:22px; margin:0 12px 5px; border-bottom:1px dotted var(--line-2);
}
.specs dd {
  order:2; margin:0; text-align:right; white-space:nowrap;
  font-family:var(--f-display); font-weight:600; font-size:15px; color:var(--ink);
  font-variant-numeric:tabular-nums; letter-spacing:-.01em;
}

/* видео */
.vid-grid { display:grid; gap:16px; }
.vid-grid--1 { grid-template-columns:minmax(0,720px); }
.vid-grid--2 { grid-template-columns:1fr 1fr; }
.vid-grid--3 { grid-template-columns:repeat(3,1fr); }
.vid { border:1px solid var(--line-2); border-radius:var(--r-md); overflow:hidden; background:var(--bg-2); aspect-ratio:16/9; }
.vid video { width:100%; height:100%; object-fit:cover; display:block; }

/* docs — карточки документов с иконкой файла и кнопкой скачивания */
.docs { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:12px; }
.doc {
  display:flex; align-items:center; gap:16px; padding:18px 20px;
  border:1px solid var(--line-2); border-radius:var(--r-md);
  background:linear-gradient(180deg,var(--surf-2),transparent);
  transition:border-color var(--d-fast) var(--ease), transform var(--d-fast) var(--ease), background var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);
}
.doc:hover { border-color:var(--line-3); transform:translateY(-2px); }
.doc__ic {
  position:relative; flex:none; width:44px; height:52px; display:grid; place-items:center;
  border-radius:7px; background:var(--surf-2); border:1px solid var(--line-2); color:var(--ink-2);
}
.doc__ic svg { width:26px; height:26px; }
.doc__ic i {
  position:absolute; bottom:6px; left:50%; transform:translateX(-50%);
  font-family:var(--f-mono); font-size:7.5px; font-weight:500; letter-spacing:.06em;
  color:var(--bg); background:var(--ink); border-radius:3px; padding:1px 4px; font-style:normal;
}
.doc__body { flex:1; min-width:0; display:flex; flex-direction:column; gap:3px; }
.doc__name { font-family:var(--f-display); font-weight:600; font-size:14.5px; color:var(--ink); letter-spacing:-.01em; line-height:1.25; }
.doc__meta { font-family:var(--f-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.doc__dl { flex:none; width:36px; height:36px; display:grid; place-items:center; border-radius:50%; border:1px solid var(--line-2); color:var(--ink-3); transition:color var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease), transform var(--d-fast) var(--ease); }
.doc__dl svg { width:18px; height:18px; }
.doc:hover .doc__dl { color:var(--ink); border-color:var(--ink-3); transform:translateY(2px); }

/* fin modal */
.fin-modal { position:fixed; inset:0; z-index:150; display:grid; place-items:center; padding:20px; background:rgba(2,6,16,.7); backdrop-filter:blur(6px); }
.fin-modal[hidden] { display:none; }
.fin-modal__box { position:relative; max-width:440px; padding:34px 30px; border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--bg-2); }
.fin-modal__box h3 { font-size:24px; margin-bottom:12px; }
.fin-modal__box p { color:var(--ink-2); margin-bottom:20px; line-height:1.6; }
.fin-modal__x { position:absolute; top:14px; right:16px; width:32px; height:32px; border:none; background:none; color:var(--ink-3); font-size:24px; line-height:1; }
.fin-modal__x:hover { color:var(--ink); }

.related { padding:20px 0 60px; }

/* ---------- PROSE (редакционный HTML) ---------- */
.prose { color:var(--ink-2); font-size:15.5px; line-height:1.7; max-width:74ch; }
.prose h2 { color:var(--ink); font-size:clamp(20px,2.2vw,28px); margin:26px 0 12px; }
.prose h3 { color:var(--ink); font-size:19px; margin:22px 0 10px; }
.prose p { margin:0 0 14px; }
.prose ul, .prose ol { margin:0 0 16px; padding-left:22px; }
.prose li { margin-bottom:7px; }
.prose a { color:var(--accent-2); text-decoration:underline; text-underline-offset:3px; }
.prose b, .prose strong { color:var(--ink); }
.prose img { border-radius:var(--r-md); margin:16px 0; }
.prose table { width:100%; border-collapse:collapse; margin:16px 0; }
.prose td, .prose th { border:1px solid var(--line); padding:9px 12px; text-align:left; }

/* ---------- LEAD FORM ---------- */
.lead { padding:60px 0; border-top:1px solid var(--line); background:radial-gradient(80% 120% at 100% 0,rgba(225,0,10,.10),transparent 55%); }
.lead__grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.lead__title { font-size:clamp(24px,3vw,40px); letter-spacing:-.025em; margin:14px 0 0; }
.lead__text { margin-top:16px; color:var(--ink-2); max-width:48ch; line-height:1.6; }
.lead__pts { list-style:none; margin:22px 0 0; padding:0; display:flex; flex-direction:column; gap:10px; }
.lead__pts li { position:relative; padding-left:24px; color:var(--ink-2); font-size:14.5px; }
.lead__pts li::before { content:""; position:absolute; left:0; top:7px; width:11px; height:11px; border:2px solid var(--accent-2); border-radius:50%; }
.lead__form { padding:28px; border:1px solid var(--line-2); border-radius:var(--r-lg); background:color-mix(in srgb,var(--bg-2) 70%,transparent); backdrop-filter:blur(10px); display:flex; flex-direction:column; gap:14px; }
.fld { display:flex; flex-direction:column; gap:6px; }
.fld label { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.fld label i { font-style:normal; color:var(--ink-3); opacity:.7; }
.fld input, .fld textarea { padding:13px 15px; border:1px solid var(--line-2); border-radius:var(--r-sm); background:color-mix(in srgb,var(--bg) 40%,transparent); color:var(--ink); font-family:var(--f-body); font-size:15px; transition:border-color var(--d-fast); }
.fld input::placeholder, .fld textarea::placeholder { color:var(--ink-3); }
.fld input:focus, .fld textarea:focus { outline:none; border-color:var(--accent-2); }
.consent { display:flex; align-items:flex-start; gap:9px; font-size:12px; color:var(--ink-3); line-height:1.4; }
.consent input { margin-top:2px; accent-color:var(--accent-2); }
.lead__err { color:var(--accent-2); font-size:13px; margin-top:4px; line-height:1.45; }
.lead__err a { color:inherit; text-decoration:underline; text-underline-offset:2px; }
.lead__ok { padding:24px; text-align:center; }
.lead__ok b { color:var(--accent-2); font-size:19px; font-family:var(--f-display); }

/* honeypot против ботов — визуально и для скринридеров скрыто */
.hp-field { position:absolute !important; left:-9999px !important; width:1px; height:1px; opacity:0; pointer-events:none; }
/* состояние отправки: кнопка со спиннером, клики заблокированы */
.btn.is-loading { position:relative; color:transparent !important; pointer-events:none; }
.btn.is-loading::after { content:""; position:absolute; top:50%; left:50%; width:16px; height:16px; margin:-8px 0 0 -8px; border:2px solid rgba(255,255,255,.45); border-top-color:#fff; border-radius:50%; animation:btnspin .6s linear infinite; }
@keyframes btnspin { to { transform:rotate(360deg); } }

/* ---------- КЕЙСЫ ---------- */
.cases-sec { padding:20px 0 50px; }
.cases-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.case { display:flex; flex-direction:column; overflow:hidden; border:1px solid var(--line-2); border-radius:var(--r-xl); background:var(--surf-2); transition:transform var(--d-fast) var(--ease),border-color var(--d-fast),box-shadow var(--d-fast); }
.case:hover { transform:translateY(-4px); border-color:var(--accent-2); box-shadow:0 34px 70px -36px rgba(0,0,0,.8); }
.case__media { position:relative; display:block; height:240px; overflow:hidden; background:var(--bg-2); }
.case__media img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.case:hover .case__media img { transform:scale(1.05); }
.case__num { position:absolute; top:14px; left:14px; font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); background:rgba(20,22,26,.9); padding:5px 11px; border-radius:999px; }
.case__body { padding:22px 24px 24px; display:flex; flex-direction:column; gap:10px; }
.case__metric { display:flex; align-items:baseline; gap:10px; }
.case__metric b { font-family:var(--f-display); font-weight:700; font-size:34px; letter-spacing:-.02em; color:var(--accent-2); }
.case__metric span { color:var(--ink-2); font-size:13px; }
.case__meta { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.case__title { font-size:21px; letter-spacing:-.015em; line-height:1.2; }
.case__sum { color:var(--ink-2); font-size:14px; line-height:1.55; }
.case__stats { display:flex; flex-wrap:wrap; gap:14px 24px; margin:4px 0; padding:14px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.case__stats > div { display:flex; flex-direction:column; gap:3px; }
.case__stats dt { font-family:var(--f-mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.case__stats dd { margin:0; font-family:var(--f-display); font-weight:600; font-size:15px; font-variant-numeric:tabular-nums; }
.case__models { display:flex; flex-wrap:wrap; gap:8px; }
.case__models a { display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:var(--accent-2); border:1px solid var(--line-2); border-radius:999px; padding:6px 12px; transition:border-color var(--d-fast); }
.case__models a:hover { border-color:var(--accent-2); }
.case__link { display:inline-flex; align-items:center; gap:8px; margin-top:4px; font-family:var(--f-mono); font-size:12px; color:var(--accent-2); }

/* ---------- ГОРОДА / КОНТАКТЫ ---------- */
.cities-sec { padding:20px 0 40px; }
.cities-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.citycard { padding:24px; border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surf-2); display:flex; flex-direction:column; gap:8px; transition:border-color var(--d-fast); }
.citycard:hover { border-color:var(--accent-2); }
.citycard__head { display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; }
.citycard__head b { font-family:var(--f-display); font-weight:700; font-size:21px; }
.citycard__head i { font-family:var(--f-mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-2); font-style:normal; }
.citycard__addr { color:var(--ink-2); font-size:13.5px; line-height:1.5; }
.citycard__contacts { display:flex; flex-wrap:wrap; gap:6px 18px; margin-top:4px; }
.citycard__contacts a { font-variant-numeric:tabular-nums; color:var(--ink); font-size:14.5px; transition:color var(--d-fast); }
.citycard__contacts a:hover { color:var(--accent-2); }
.citycard__map { display:inline-flex; align-items:center; gap:8px; margin-top:8px; font-family:var(--f-mono); font-size:11.5px; color:var(--accent-2); }
.contact-info { padding:20px 0 60px; border-top:1px solid var(--line); }
.contact-info__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:34px; padding-top:36px; }
.ci-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; color:var(--ink-2); font-size:14.5px; }
.ci-req li { font-family:var(--f-mono); font-size:12.5px; }
.ci-socials { display:flex; flex-direction:column; gap:10px; }
.ci-socials a { display:inline-flex; align-items:center; gap:10px; color:var(--ink-2); text-transform:capitalize; transition:color var(--d-fast); }
.ci-socials a:hover { color:var(--accent-2); }

/* ---------- КОНТЕНТ-СТРАНИЦЫ ---------- */
.content { padding:20px 0 20px; }
.content__head { padding:20px 0 8px; }
.content__title { font-size:clamp(28px,4vw,52px); letter-spacing:-.03em; margin:12px 0 0; max-width:20ch; }
.content__lead { margin-top:16px; color:var(--ink-2); max-width:64ch; font-size:clamp(15px,1.2vw,17px); }
.content__prose { margin-top:22px; }
.hub { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:26px 0; }
.hub__item { display:flex; flex-direction:column; gap:6px; padding:20px; border:1px solid var(--line-2); border-radius:var(--r-md); background:var(--surf-2); transition:transform var(--d-fast) var(--ease),border-color var(--d-fast); }
.hub__item:hover { transform:translateY(-3px); border-color:var(--accent-2); }
.hub__item b { font-family:var(--f-display); font-weight:600; font-size:16px; }
.hub__item span:not(.hub__go) { color:var(--ink-2); font-size:13px; line-height:1.5; }
.hub__go { color:var(--accent-2); margin-top:auto; }
.gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:12px; margin:24px 0; }
.gallery--wide { grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); }
/* одиночная иллюстрация контент-страницы */
.feature-img { margin:26px 0; border:1px solid var(--line-2); border-radius:var(--r-lg); overflow:hidden; background:var(--bg-2); }
.feature-img img { display:block; width:100%; height:auto; max-height:480px; object-fit:cover; }
.gallery__it { display:block; aspect-ratio:4/3; overflow:hidden; border-radius:var(--r-md); border:1px solid var(--line); background:var(--bg-2); }
.gallery__it img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.gallery__it:hover img { transform:scale(1.06); }
/* «Мясоруб в цифрах» на контент-страницах (готовая разметка приходит из bodyHtml) */
.about-figures {
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(18px,2vw,28px); margin:28px 0 40px;
}
.about-figures__item { border-top:1px solid var(--line-2); padding-top:16px; }
.about-figures__n {
  display:block; font-family:var(--f-display); font-weight:700;
  font-size:clamp(27px,2.8vw,42px); line-height:1; letter-spacing:-.02em;
  font-variant-numeric:tabular-nums; white-space:nowrap;
}
.about-figures__l {
  display:block; margin-top:10px; font-family:var(--f-mono); font-size:10.5px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3);
  max-width:24ch; line-height:1.6;
}
@media (max-width:860px){ .about-figures { grid-template-columns:repeat(2,1fr); } }

/* таймлайн «История развития» */
.timeline {
  margin:28px 0 40px; padding-left:28px;
  border-left:1px solid var(--line-2);
  display:grid; gap:24px;
}
.timeline__item { position:relative; }
.timeline__item::before {
  content:""; position:absolute; left:-32px; top:5px;
  width:7px; height:7px; border-radius:50%;
  background:var(--ink-3);
}
.timeline__year {
  display:block; font-family:var(--f-mono); font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2);
  font-variant-numeric:tabular-nums;
}
.timeline__event { display:block; margin-top:5px; font-size:15.5px; line-height:1.5; max-width:60ch; }

.acc { margin:24px 0; border-top:1px solid var(--line); }
.acc__it { border-bottom:1px solid var(--line); }
.acc__it summary { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:18px 0; font-family:var(--f-display); font-weight:600; font-size:17px; cursor:pointer; list-style:none; }
.acc__it summary::-webkit-details-marker { display:none; }
.acc__chev { color:var(--accent-2); transition:transform var(--d-fast); }
.acc__it[open] .acc__chev { transform:rotate(180deg); }
.acc__it .prose { padding:0 0 18px; }
.content__docs { margin:24px 0; }

/* ---------- НОВОСТИ / СТАТЬИ ---------- */
.media-tabs { display:flex; gap:8px; margin-top:22px; }
.media-tabs a { padding:9px 18px; border-radius:999px; border:1px solid var(--line-2); font-size:13.5px; color:var(--ink-2); transition:all var(--d-fast) var(--ease); }
.media-tabs a:hover { border-color:var(--ink-3); color:var(--ink); }
.media-tabs a.is-on { background:var(--accent); border-color:var(--accent); color:#fff; }
.news-sec { padding:28px 0 60px; }
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.ncard { display:flex; flex-direction:column; overflow:hidden; border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surf-2); transition:transform var(--d-fast) var(--ease),border-color var(--d-fast),box-shadow var(--d-fast); }
.ncard:hover { transform:translateY(-4px); border-color:var(--accent-2); box-shadow:0 30px 60px -34px rgba(0,0,0,.8); }
.ncard__media { position:relative; display:block; height:184px; overflow:hidden; background:var(--bg-2); }
.ncard__media img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.ncard:hover .ncard__media img { transform:scale(1.05); }
.ncard__tag { position:absolute; top:12px; left:12px; font-family:var(--f-mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); background:rgba(20,22,26,.9); padding:4px 10px; border-radius:999px; }
.ncard__body { padding:18px 20px 20px; display:flex; flex-direction:column; gap:9px; flex:1; }
.ncard__title { font-size:17px; letter-spacing:-.01em; line-height:1.25; }
.ncard__title a:hover { color:var(--accent-2); }
.ncard__sum { color:var(--ink-2); font-size:13px; line-height:1.5; flex:1; }
.article__wrap { max-width:820px; margin:0 auto; }
.article__head { padding:16px 0 8px; }
.article__title { font-size:clamp(26px,3.4vw,44px); letter-spacing:-.025em; margin-top:12px; }
.article__cover { margin:24px 0; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line-2); }
.article__cover img { width:100%; height:auto; display:block; }
.article__body { max-width:none; }
.article__back { display:inline-block; margin-top:30px; font-family:var(--f-mono); font-size:13px; color:var(--accent-2); }

/* ---------- STICKY MOBILE CTA ---------- */
.sticky-cta { display:none; position:fixed; left:14px; right:14px; bottom:14px; z-index:70; justify-content:center; align-items:center; gap:10px; padding:15px; border-radius:999px; background:var(--accent); color:#fff; font-family:var(--f-body); font-weight:600; font-size:15px; box-shadow:0 18px 44px -12px rgba(0,0,0,.95); transition:transform .34s var(--ease), opacity .34s; }
.sticky-cta.hide { transform:translateY(150%); opacity:0; pointer-events:none; }
.sticky-cta .ico-arr { color:#fff; }
@media (max-width:860px) { .sticky-cta { display:flex; } }

/* ---------- FOOTER ---------- */
.ft { border-top:1px solid var(--line); padding:56px 0 28px; background:var(--bg-2); }
.ft__grid { display:grid; grid-template-columns:1.7fr 1fr 1fr 1.2fr; gap:40px; }
.ft__brand { max-width:360px; }
.ft__desc { margin-top:16px; color:var(--ink-3); font-size:13.5px; line-height:1.6; }
.ft__socials { display:flex; gap:10px; margin-top:18px; }
.ft__socials a { width:38px; height:38px; display:grid; place-items:center; border:1px solid var(--line-2); border-radius:10px; transition:border-color var(--d-fast),transform var(--d-fast); }
.ft__socials a:hover { border-color:var(--accent-2); transform:translateY(-2px); }
.ft__socials img { width:20px; height:20px; object-fit:contain; }
.ft__col h4 { font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin:0 0 14px; font-weight:500; }
.ft__col a { display:block; padding:6px 0; color:var(--ink-2); font-size:14px; transition:color var(--d-fast); }
.ft__col a:hover { color:var(--accent-2); }
.ft__col--contacts a { font-variant-numeric:tabular-nums; }
.ft__col--contacts a i { display:block; font-style:normal; font-size:11px; color:var(--ink-3); margin-top:1px; }
.ft__legal { display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:40px; padding-top:20px; border-top:1px solid var(--line); font-family:var(--f-mono); font-size:11px; color:var(--ink-3); letter-spacing:.02em; }

/* ---------- MOTION ----------
   reveal никогда не прячет контент полностью (быстрый скролл/сбой JS не
   оставляют пустую страницу): старт от .25, подъём короткий */
html.has-motion [data-reveal] { opacity:.25; transform:translateY(12px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
html.has-motion [data-reveal].in { opacity:1; transform:none; }
[data-stagger] > * { transition-delay:calc(var(--i,0) * 55ms); }
@media (prefers-reduced-motion:reduce) {
  [data-reveal] { opacity:1 !important; transform:none !important; transition:none; }
  html { scroll-behavior:auto; }
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1080px) {
  .cat-grid, .prod-grid, .prod-grid--4, .news-grid { grid-template-columns:repeat(2,1fr); }
  .prod__top { grid-template-columns:1fr; gap:28px; }
  .gal { position:static; }
  .lead__grid { grid-template-columns:1fr; gap:28px; }
  .hub { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:980px) {
  .ft__grid { grid-template-columns:1fr 1fr; gap:28px; }
  .ft__brand { grid-column:1 / -1; max-width:none; }
}
/* бренд-подпись прячем раньше, чтобы освободить строку под меню */
@media (max-width:1400px) { .hd__sub { display:none; } }
/* nav → бургер до 1240px: 8 мега-пунктов + бренд + CTA не помещаются в строку */
@media (max-width:1240px) {
  .nav, .util, .hd__cta { display:none; }
  .burger { display:flex; }
  .hd__actions { gap:8px; }
}
@media (max-width:860px) {
  .specs { grid-template-columns:1fr; }
  .vid-grid--2, .vid-grid--3 { grid-template-columns:1fr; }
  .prod__specs-hi { gap:20px; }
  .cases-grid, .cities-grid { grid-template-columns:1fr; }
  .contact-info__grid { grid-template-columns:1fr; gap:24px; }
}
@media (max-width:560px) {
  .ft__grid { grid-template-columns:1fr; }
  .ft__legal { flex-direction:column; gap:6px; }
}
@media (max-width:560px) {
  .cat-grid, .prod-grid, .prod-grid--4, .news-grid, .hub { grid-template-columns:1fr; }
  .sec-hero, .cat-hero__in { padding-top:26px; }
  .prod__price b { font-size:28px; }
  .lead { padding:44px 0; }
}

/* =========================================================================
   ЭЛЕВАЦИЯ — прогресс прокрутки, spotlight, лайтбокс, липкий бар, лоск
   ========================================================================= */

/* индикатор прокрутки */
.scroll-prog {
  position:fixed; top:0; left:0; right:0; height:2px; z-index:130;
  background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent-3));
  transform:scaleX(0); transform-origin:left center; will-change:transform;
}

/* spotlight на карточках (курсор-follow, через --mx/--my из site.js) */
.has-spot { position:relative; isolation:isolate; }
.has-spot::before {
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:0; pointer-events:none;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%), color-mix(in srgb,var(--accent-2) 15%,transparent), transparent 62%);
  opacity:0; transition:opacity .35s var(--ease);
}
.has-spot:hover::before { opacity:1; }
.has-spot > * { position:relative; z-index:1; }

/* галерея — зум-курсор + иконка увеличения */
.gal--zoom .gal__main { cursor:zoom-in; position:relative; }
.gal--zoom .gal__main::after {
  content:""; position:absolute; top:14px; right:14px; width:36px; height:36px; border-radius:9px; z-index:2;
  background:color-mix(in srgb,var(--bg) 62%,transparent) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239BA0A8' stroke-width='1.6'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.3-4.3M11 8v6M8 11h6' stroke-linecap='round'/%3E%3C/svg%3E") center/18px no-repeat;
  border:1px solid var(--line-2); opacity:0; transition:opacity var(--d-fast) var(--ease); pointer-events:none;
}
.gal--zoom .gal__main:hover::after { opacity:1; }

/* лайтбокс */
.lightbox { position:fixed; inset:0; z-index:200; display:grid; place-items:center; padding:40px;
  background:rgba(2,6,16,.93); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.lightbox[hidden] { display:none; }
.lightbox__img { max-width:92vw; max-height:86vh; object-fit:contain; border-radius:var(--r-md); box-shadow:0 40px 100px -30px rgba(0,0,0,.9); animation:lbIn .3s var(--ease); }
@keyframes lbIn { from { opacity:0; transform:scale(.97); } to { opacity:1; transform:none; } }
.lightbox__x, .lightbox__nav {
  position:absolute; display:grid; place-items:center; border:1px solid var(--line-2); color:var(--ink);
  background:color-mix(in srgb,var(--bg-2) 74%,transparent); backdrop-filter:blur(8px); border-radius:50%; line-height:1;
  transition:border-color var(--d-fast) var(--ease), color var(--d-fast) var(--ease), transform var(--d-fast) var(--ease);
}
.lightbox__x { top:20px; right:24px; width:44px; height:44px; font-size:26px; }
.lightbox__nav { top:50%; transform:translateY(-50%); width:54px; height:54px; font-size:30px; }
.lightbox__x:hover { border-color:var(--accent-2); color:var(--accent-2); }
.lightbox__nav:hover { border-color:var(--accent-2); color:var(--accent-2); }
.lightbox__nav--prev { left:24px; } .lightbox__nav--next { right:24px; }
.lightbox__nav[hidden] { display:none; }
.lightbox__count { position:absolute; bottom:22px; left:50%; transform:translateX(-50%); font-family:var(--f-mono); font-size:12px; letter-spacing:.12em; color:var(--ink-2); }
@media (max-width:620px){ .lightbox{padding:16px} .lightbox__nav{width:44px;height:44px;font-size:24px} .lightbox__nav--prev{left:10px} .lightbox__nav--next{right:10px} .lightbox__x{top:12px;right:14px} }

/* липкий бар товара (десктоп) */
.pbar {
  position:fixed; left:0; right:0; bottom:0; z-index:75;
  background:color-mix(in srgb,var(--bg-2) 92%,transparent); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--line-2); box-shadow:0 -18px 44px -30px rgba(0,0,0,.8);
  transform:translateY(105%); transition:transform var(--d-med) var(--ease);
}
.pbar.show { transform:none; }
.pbar__row { display:flex; align-items:center; gap:20px; padding:12px 0; }
.pbar__name { font-family:var(--f-display); font-weight:700; font-size:16px; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; }
.pbar__price { font-family:var(--f-display); font-weight:700; font-size:18px; color:var(--accent-2); font-variant-numeric:tabular-nums; white-space:nowrap; margin-left:auto; }
[data-theme="light"] .pbar__price { color:var(--accent); }
.pbar__price i { font-family:var(--f-mono); font-size:10px; color:var(--ink-3); text-transform:uppercase; margin-right:5px; font-weight:400; }
.pbar .btn { flex:none; }
@media (max-width:860px){ .pbar { display:none; } }

/* primary-кнопка — диагональный блик на hover */
.btn--primary { overflow:hidden; }
.btn--primary::after {
  content:""; position:absolute; top:0; left:-45%; width:35%; height:100%; z-index:0;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.30), transparent);
  transform:skewX(-18deg); pointer-events:none; opacity:0;
}
.btn--primary:hover::after { animation:btnSheen .75s var(--ease); }
@keyframes btnSheen { 0% { left:-45%; opacity:1; } 100% { left:135%; opacity:1; } }
.btn--primary > * { position:relative; z-index:1; }

/* глобальный лоск: выделение, скроллбар */
::selection { background:color-mix(in srgb,var(--accent-2) 85%,transparent); color:#04121f; }
* { scrollbar-width:thin; scrollbar-color:var(--line-2) transparent; }
::-webkit-scrollbar { width:12px; height:12px; }
::-webkit-scrollbar-thumb { background:var(--line-2); border-radius:7px; border:3px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background:var(--line-3); }
::-webkit-scrollbar-track { background:transparent; }

@media (prefers-reduced-motion:reduce) {
  .lightbox__img { animation:none; }
  .btn--primary:hover::after { animation:none; }
}

/* =========================================================================
   ГАБАРИТНЫЙ ЧЕРТЁЖ (.bp) — флагманский инженерный модуль карточки товара
   Cabinet-проекция реальных габаритов в масштабе + силуэт 180 см.
   Единственный красный сигнал — линия «земли». Draw-on + count-up в site.js.
   ========================================================================= */
/* «лист»: компактный чертёж (не шире 880px) + штамп по мотивам ГОСТ внизу */
.bp { max-width:880px; }
.bp__stamp {
  display:flex; flex-wrap:wrap; align-items:baseline; margin-top:14px; border:1px solid var(--line-2); border-radius:6px; overflow:hidden;
  font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
}
.bp__stamp span { padding:8px 12px; color:var(--ink-3); background:var(--surf-2); border-right:1px solid var(--line); }
.bp__stamp b { padding:8px 14px 8px 10px; color:var(--ink); font-weight:500; border-right:1px solid var(--line); }
.bp__stamp b:last-child { border-right:0; }
.bp__head { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:18px; }
.bp__head .block-h { margin:0; }
.bp__unit { display:inline-flex; gap:2px; padding:3px; border:1px solid var(--line-2); border-radius:999px; background:var(--surf); }
.bp__u { font:500 12px/1 var(--f-mono); letter-spacing:.04em; color:var(--ink-2); padding:8px 15px; border:0; border-radius:999px; background:none; cursor:pointer; transition:color .2s, background .2s; }
.bp__u.is-on { color:var(--bg); background:var(--ink); } /* красный листа — линия «земли» на чертеже */
.bp__u:not(.is-on):hover { color:var(--ink); }

.bp__stage { position:relative; border:1px solid var(--line-2); border-radius:var(--r-lg);
  background:radial-gradient(120% 130% at 50% 0, rgba(244,245,247,.035), transparent 62%), var(--bg-2);
  padding:clamp(12px,2.6vw,26px); overflow:hidden; }
.bp__stage::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.55;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:34px 34px; -webkit-mask:radial-gradient(88% 80% at 50% 42%, #000 52%, transparent);
  mask:radial-gradient(88% 80% at 50% 42%, #000 52%, transparent); }

.bp-drawing { position:relative; width:100%; height:auto; display:block; }

.bp-front { fill:rgba(244,245,247,.028); }
.bp-face--r { fill:rgba(8,9,11,.55); }
.bp-face--t { fill:rgba(244,245,247,.05); }
.bp-edge { fill:none; stroke:var(--ink-2); stroke-width:1.5; stroke-linejoin:round; stroke-linecap:round; }
.bp-hid  { fill:none; stroke:var(--ink-3); stroke-width:1; stroke-dasharray:5 6; opacity:.5; }
.bp-ground { stroke:var(--accent); stroke-width:2.6; stroke-linecap:round; }
.bp-human { fill:rgba(155,160,168,.22); }

.bp-ext { stroke:var(--ink-3); stroke-width:1; opacity:.65; }
.bp-dim { stroke:var(--ink-2); stroke-width:1.2; }
.bp-arw { fill:var(--ink-2); }
text.bp-num { fill:var(--ink); font:500 18px/1 var(--f-mono); letter-spacing:.01em; text-anchor:middle; dominant-baseline:middle; }
.bp-cap { fill:var(--ink-3); font:500 13px/1 var(--f-mono); letter-spacing:.08em; text-anchor:middle; dominant-baseline:hanging; text-transform:uppercase; }

/* readout-полоса (HTML, читаема на мобиле, где svg-подписи мельчают) */
.bp__read { display:flex; flex-wrap:wrap; gap:12px 30px; margin-top:20px; padding-top:18px; border-top:1px solid var(--line); }
.bp__read div { display:flex; flex-direction:column; gap:4px; }
.bp__read dt { font:500 10px/1 var(--f-mono); letter-spacing:.11em; text-transform:uppercase; color:var(--ink-3); }
.bp__read dd { margin:0; font:500 18px/1 var(--f-mono); color:var(--ink); font-variant-numeric:tabular-nums; }
.bp__tag { position:absolute; right:clamp(12px,2.6vw,26px); top:clamp(12px,2.6vw,26px);
  font:500 10px/1 var(--f-mono); letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3); }
.bp__foot { margin:15px 2px 0; max-width:62ch; font:400 13px/1.55 var(--f-body); color:var(--ink-2); }

/* draw-on / count-up — только когда JS+моушен активны (иначе всё видно сразу) */
.has-motion .bp-dim, .has-motion .bp-edge, .has-motion .bp-ground { stroke-dasharray:1; stroke-dashoffset:1; }
.has-motion .bp__stage .bp-num,
.has-motion .bp-arw, .has-motion .bp-hid, .has-motion .bp-front, .has-motion .bp-face, .has-motion .bp-human, .has-motion .bp-cap { opacity:0; }
.has-motion .bp__stage.is-drawn .bp-front, .has-motion .bp__stage.is-drawn .bp-face,
.has-motion .bp__stage.is-drawn .bp-hid { opacity:1; transition:opacity .8s ease .2s; }
.has-motion .bp__stage.is-drawn .bp-human { opacity:1; transition:opacity .8s ease .3s; }
.has-motion .bp__stage.is-drawn .bp-edge { stroke-dashoffset:0; transition:stroke-dashoffset 1s var(--ease) .1s; }
.has-motion .bp__stage.is-drawn .bp-ground { stroke-dashoffset:0; transition:stroke-dashoffset .7s var(--ease) .55s; }
.has-motion .bp__stage.is-drawn .bp-dim--w { stroke-dashoffset:0; transition:stroke-dashoffset .55s var(--ease) .7s; }
.has-motion .bp__stage.is-drawn .bp-dim--h { stroke-dashoffset:0; transition:stroke-dashoffset .55s var(--ease) .9s; }
.has-motion .bp__stage.is-drawn .bp-dim--d { stroke-dashoffset:0; transition:stroke-dashoffset .55s var(--ease) 1.1s; }
.has-motion .bp__stage.is-drawn .bp-arw, .has-motion .bp__stage.is-drawn .bp-num,
.has-motion .bp__stage.is-drawn .bp-cap { opacity:1; transition:opacity .5s ease 1s; }

/* fallback-«техпаспорт» (машины без полной тройки габаритов) */
.bp__stage--frame { padding:clamp(18px,3.4vw,40px); }
.bp-frame { position:relative; border:1px solid var(--line-2); border-radius:4px;
  padding:clamp(22px,4vw,42px); min-height:260px; display:flex; flex-direction:column; justify-content:center; }
.bp-frame__c { position:absolute; width:15px; height:15px; border:2px solid var(--accent); opacity:.85; }
.bp-frame__c--tl { top:-1px; left:-1px; border-right:0; border-bottom:0; }
.bp-frame__c--tr { top:-1px; right:-1px; border-left:0; border-bottom:0; }
.bp-frame__c--bl { bottom:-1px; left:-1px; border-right:0; border-top:0; }
.bp-frame__c--br { bottom:-1px; right:-1px; border-left:0; border-top:0; }
.bp-frame__k { font:500 10px/1 var(--f-mono); letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); }
.bp-frame__specs { display:flex; flex-wrap:wrap; gap:16px 42px; margin:20px 0 22px; }
.bp-frame__specs dt { font:500 10px/1 var(--f-mono); letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:6px; }
.bp-frame__specs dd { margin:0; font:500 25px/1 var(--f-mono); color:var(--ink); }
.bp-frame__note { margin:0; max-width:54ch; font:400 14px/1.6 var(--f-body); color:var(--ink-2); }
.bp-frame__title { position:absolute; right:16px; bottom:11px; font:500 11px/1 var(--f-mono); letter-spacing:.14em; color:var(--ink-3); }

@media (max-width:640px) {
  text.bp-num { font-size:26px; }
  .bp-cap { font-size:20px; }
  .bp__read dd { font-size:16px; }
}
