@charset "UTF-8";
/* @use — строго наверху */
@import "@splidejs/splide/dist/css/splide.min.css";
/* vite\src\styles\abstracts\_variables.scss */
/* === variables (rem-based) ================================================== */
/* px -> rem (без slash-division) */
/* Брейкпоинты в rem (mobile-first) */
/* Стандартные контейнеры оставляем как есть */
/* «Широкие» теперь растут до 1920 */
/* Палитра */
/* Easing tokens */
/* Универсальный alias */
/* Типографика */
/* Радиусы/тени */
/* Анимации */
/* Контейнеры */
/* Шкала отступов (rem) */
/* Z-index */
/* Высота шапки */
/* --- helpers to read maps (module syntax) ---------------------------------- */
/* CSS Custom Properties (опционально) */
:root {
  --c-primary: #0d3b66;
  --c-accent: #2880FD;
  --c-text: #1e1e1e;
  --c-muted: #f6f7f9;
  --c-border: #e5e7eb;
  --radius: 0.75rem;
  --container-width: 72.5rem;
  --container-padding-x: 2.5rem;
  --container-padding-x-mobile: 1.25rem;
}

/* @use — строго наверху */
/* ===== Breakpoints ===== */
/* ===== Container (auto widths with --page-gutter) ===== */
/* ===== Generic helpers ===== */
/* ===== Fluid type ===== */
/* ===== NEW: Section / Head / Card / Panel / Grid-table ===== */
/* 1) Секция (быстрый отступ + необязательный фон) */
/* 2) Заголовок секции — единый стиль */
/* 3) Базовая карточка */
/* 4) Панель (как большие белые блоки с overflow:hidden) */
/* 5) Табличная сетка с разделителями */
/* базовые и дополнительные */
/* @use — строго наверху */
/* vite\src\styles\base\_base.scss */
/* ===== BASE / RESET ======================================================= */
/* Бокс-модель */
*, *::before, *::after {
  box-sizing: border-box;
}

/* Убираем дефолтные отступы «вообще» */
* {
  margin: 0;
}

/* Базовые улучшения типографики/рендеринга */
html {
  height: 100%;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
  font-variant-ligatures: common-ligatures;
  scroll-behavior: smooth;
  /* якоря не прячутся под fixed header */
  scroll-padding-top: calc(var(--header-h) + env(safe-area-inset-top));
}

body {
  min-height: 100%;
  margin: 0;
  font-family: "Proxima Nova", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
  color: #1e1e1e;
  background: #ffffff;
  /* не прятать контент под fixed header + safe area */
  padding-top: calc(var(--header-h) + env(safe-area-inset-top));
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: transparent;
}

/* Система CSS-переменных страницы */
:root {
  --header-h: 4rem;
  /* ГЛОБАЛЬНЫЕ ПОЛЯ СТРАНИЦЫ (резиновые):
     min 16px → растём до 200px на широких */
  --page-gutter: clamp(0.625rem, 8vw, 12.5rem);
}

/* шапка ниже на мобилке */
@media (max-width: calc(48rem - 0.02px)) {
  :root {
    --header-h: 3.5rem;
  }
}
/* Списки: убираем маркеры и внутренние отступы */
ul, ol {
  list-style: none;
  padding-left: 0;
}

/* Картинки и медиа: отзывчивые по умолчанию */
img, svg, video, canvas, audio, iframe, embed, object, picture {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Таблицы без странных межъячеечных зазоров */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Формы: наследуем шрифты/цвета, сбрасываем margin */
input, button, textarea, select {
  font: inherit;
  color: inherit;
  background: transparent;
  border: 0;
  margin: 0;
}

button, [type=button], [type=submit], [role=button] {
  cursor: pointer;
}

textarea {
  resize: vertical;
}

:disabled {
  cursor: not-allowed;
}

/* Ссылки по умолчанию без подчёркивания (контролируй сам) */
a {
  color: inherit;
  text-decoration: none;
}

/* Заголовки, параграфы и прочее без встроенных margin */
h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd {
  margin: 0;
}

/* Selection */
::selection {
  background: rgba(40, 128, 253, 0.24);
  color: inherit;
}

/* Фокус по умолчанию — аккуратный, управляемый */
:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}

/* Предпочтение «меньше анимаций» — выключаем транзишны/анимации */
@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}
/* ===== Утилиты ============================================================ */
/* утилита-контейнер (обычный) */
.container {
  max-width: calc(var(--container-width) + var(--container-padding-x) * 2);
  margin-inline: auto;
  padding-inline: var(--container-padding-x);
}
@media (max-width: calc(36rem - 0.02px)) {
  .container {
    max-width: calc(var(--container-width) + var(--container-padding-x-mobile) * 2);
    padding-inline: var(--container-padding-x-mobile);
  }
}

/* модификаторы контейнера при необходимости */
.container--wide {
  width: calc(100% - var(--page-gutter) * 2);
  margin-inline: auto;
}
@media (min-width: 48rem) {
  .container--wide {
    width: min(60rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 62rem) {
  .container--wide {
    width: min(75rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 75rem) {
  .container--wide {
    width: min(90rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 87.5rem) {
  .container--wide {
    width: min(100rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 120rem) {
  .container--wide {
    width: min(120rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 160rem) {
  .container--wide {
    width: min(120rem, 100% - var(--page-gutter) * 2);
  }
}

.container--fluid {
  width: calc(100% - var(--page-gutter) * 2);
  margin-inline: auto;
}

/* якоря корректно «прилипают» */
[id] {
  scroll-margin-top: calc(var(--header-h) + 1rem);
}

/* Скрыть визуально, но оставить доступным (утилита) */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  border: 0;
  padding: 0;
  white-space: nowrap;
  clip-path: inset(100%);
  clip: rect(0 0 0 0);
  overflow: hidden;
}

@media (max-width: calc(62rem - 0.02px)) {
  .hidden-tablet {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    border: 0;
    padding: 0;
    white-space: nowrap;
    clip-path: inset(100%);
    clip: rect(0 0 0 0);
    overflow: hidden;
  }
}

@media (max-width: calc(48rem - 0.02px)) {
  .hidden-mobile {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    border: 0;
    padding: 0;
    white-space: nowrap;
    clip-path: inset(100%);
    clip: rect(0 0 0 0);
    overflow: hidden;
  }
}

.hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  border: 0;
  padding: 0;
  white-space: nowrap;
  clip-path: inset(100%);
  clip: rect(0 0 0 0);
  overflow: hidden;
}

/* vite/src/styles/base/_fonts.scss */
@font-face {
  font-family: "Proxima Nova";
  src: local("Proxima Nova Light"), local("ProximaNova-Light"), url("/static/main/fonts/ProximaNova-Light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Proxima Nova";
  src: local("Proxima Nova Regular"), local("ProximaNova-Regular"), url("/static/main/fonts/ProximaNova-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Proxima Nova";
  src: local("Proxima Nova Bold"), local("ProximaNova-Bold"), url("/static/main/fonts/ProximaNova-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Proxima Nova";
  src: local("Proxima Nova Black"), local("ProximaNova-Black"), url("/static/main/fonts/ProximaNova-Black.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
/* компоненты */
/* @use — строго наверху */
/* vite/src/styles/components/_header.scss */
/* =============================
   Accessibility: Skip-link
   ============================= */
.skip-link {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  border: 0;
  padding: 0;
  white-space: nowrap;
  clip-path: inset(100%);
  clip: rect(0 0 0 0);
  overflow: hidden;
}
.skip-link:focus {
  position: fixed !important;
  clip: auto;
  clip-path: none;
  inset: 0.5rem auto auto 0.5rem;
  z-index: 900;
  background: #fff;
  color: #1e1e1e;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.site-header {
  --hdr-bg: transparent;
  --hdr-fg: #ffffff;
  --hdr-link: var(--hdr-fg);
  --hdr-sep: rgba(255, 255, 255, .35);
  --hdr-logo-main: #2880FD;
  --hdr-logo-sec: #fff;
  --hdr-burger-border: rgba(255, 255, 255, .35);
  --hdr-mail: #ffffff; /* почта в прозрачной шапке — максимально читаемая (белая) */
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  background: var(--hdr-bg);
  color: var(--hdr-fg);
  transition: background-color 0.25s cubic-bezier(0.16, 1, 0.3, 1), color 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.site-header::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 0.125rem;
  background: #f3c44b;
  pointer-events: none;
}
.site-header .header__wrapper {
  position: relative;
  display: flex;
  padding: 1rem 0;
  align-items: center;
  gap: 4rem;
  min-height: var(--header-h);
}
.site-header .header__wrapper.open-menu {
  flex-direction: column;
  align-items: flex-start;
  background: var(--hdr-bg);
}
.site-header .header__wrapper {
  /* Нижняя линия — ВИДНА по умолчанию, скрывается при скролле (is-solid) */
}
.site-header .header__wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--hdr-sep);
  opacity: 1;
  transition: opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}
.site-header .header__row {
  position: relative;
}
.site-header .header__logo {
  line-height: 0;
  display: inline-flex;
  align-items: center;
}
.site-header .header__logo .logo-img {
  display: block;
  height: clamp(1.125rem, 2.6vw, 1.75rem);
  width: auto;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.12));
  transition: filter 0.25s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.site-header {
  /* --------------------------------
     NAV
     -------------------------------- */
}
.site-header .header__nav {
  flex: 1 1 auto;
  min-width: 0;
}
.site-header .header__actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-style: normal;
  line-height: 1;
}
.site-header .header__actions-phone {
  color: #2880FD;
  text-decoration: none;
  white-space: nowrap;
  font-weight: 700;
  letter-spacing: 0.01em;
  font-size: clamp(0.875rem, 2vw, 1.125rem);
}
.site-header .header__actions-phone:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.site-header .header__actions-mail {
  text-decoration: none;
  white-space: nowrap;
  font-size: clamp(0.875rem, 2vw, 1.125rem);
  color: var(--hdr-mail);
}
.site-header .header__actions-mail:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.site-header .header__actions-wrapper {
  display: flex;
  gap: 0.9375rem;
  align-items: center;
}
.site-header .header__actions-button {
  padding: 0.3125rem;
}
.site-header .header__actions-button:hover {
  transform: translateY(-1px);
}
.site-header .header__actions-button svg {
  max-width: 0.9375rem;
}
.site-header .nav {
  display: flex;
  align-items: center;
  gap: 2.5rem;
  list-style: none;
  font-weight: 300;
  justify-content: center;
  font-size: 1.125rem;
}
.site-header .nav.open-menu {
  flex-direction: column;
  align-items: flex-start;
  gap: 1.25rem;
}
.site-header .nav__link {
  color: var(--hdr-link);
  text-decoration: none;
  opacity: 0.95;
  border-radius: 0.5rem;
  transition: opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1), color 0.25s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  white-space: nowrap; /* не переносить пункты */
}
.site-header .nav__link:hover {
  opacity: 1;
}
.site-header .nav__link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.site-header .nav__link.is-active, .site-header .nav__link[aria-current] {
  color: #2880FD;
  font-weight: 700;
}
.site-header .nav .nav__copy {
  line-height: 0;
  display: block;
  align-items: center;
  justify-content: center;
  padding: 0.25rem;
  border-radius: 0.375rem;
  border: 1px solid transparent;
  background: transparent;
  color: #2880FD;
  cursor: pointer;
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.site-header .nav .nav__copy:hover {
  transform: translateY(-1px);
}
.site-header .nav .nav__copy:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.site-header .nav .nav__copy.is-copied {
  border-color: rgba(40, 128, 253, 0.35);
  box-shadow: 0 0 0 0.1875rem rgba(40, 128, 253, 0.18);
}
.site-header {
  /* --------------------------------
     BURGER
     -------------------------------- */
}
.site-header .header__burger {
  position: absolute;
  right: 2.5rem;
  top: 1rem;
  display: none;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 0.75rem;
  border: 1px solid var(--hdr-burger-border);
  background: transparent;
  color: var(--hdr-fg);
  cursor: pointer;
  transition: border-color 0.25s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.site-header .header__burger span {
  display: block;
  width: 1.375rem;
  height: 0.125rem;
  background: currentColor;
  margin: 0.3125rem auto;
}
.site-header .header__burger:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
@media (max-width: calc(62rem - 0.02px)) {
  .site-header .header__burger {
    display: block;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .site-header .header__burger {
    right: 1.25rem;
  }
}
.site-header {
  /* --------------------------------
     SOLID on scroll
     -------------------------------- */
}
.site-header.is-solid {
  --hdr-bg: #1e1e1e;
  --hdr-fg: #ffffff;
  --hdr-link: #ffffff;
  --hdr-sep: #e5e7eb;
  --hdr-logo-sec: #ffffff;
  --hdr-burger-border: #e5e7eb;
  --hdr-mail: #ffffff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.site-header.is-solid .header__row::after {
  background: linear-gradient(90deg, transparent 0 6%, rgba(255, 255, 255, 0.22) 6% 94%, transparent 94% 100%);
  opacity: 0;
}
.site-header.is-solid .header__logo .logo-img {
  filter: none;
}
.site-header {
  /* --------------------------------
     MOBILE OVERLAY (<= md)
     -------------------------------- */
}
@media (max-width: calc(62rem - 0.02px)) {
  .site-header .header__row {
    height: 4.9375rem;
  }
  .site-header .header__wrapper {
    height: 4.9375rem;
    justify-content: space-between;
  }
  .site-header .header__actions {
    margin-right: 5rem;
  }
  .site-header .header__nav {
    position: fixed;
    display: none;
    top: 0;
    left: -100%;
    transform: translateX(-100%);
    align-items: flex-start;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background: #1e1e1e;
    transition: transform 0.4s ease-out, opacity 0.4s ease-out, visibility 0s linear 0.4s;
    overflow: auto;
    overscroll-behavior: contain;
    will-change: transform, opacity;
    contain: paint;
    backface-visibility: hidden;
    border-top: 2px solid #f3c44b;
    z-index: 900;
  }
  .site-header .header__nav.is-open {
    display: flex;
    top: 0;
    left: 0;
    width: 60dvw;
    height: 100dvh;
    transform: translateX(0%);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    border-bottom: 2px solid #f3c44b;
  }
  .site-header .nav {
    flex-direction: column;
    align-items: center;
    gap: 2.5rem;
    justify-content: center;
    padding-block: 5rem;
    font-size: 1.25rem;
  }
  .site-header .nav__link {
    color: white;
    opacity: 1;
    background: transparent;
    padding-block: 0.5rem;
  }
  .site-header .nav {
    /* Контакты первыми, выравнивание слева */
  }
  .site-header .nav__actions {
    order: -1;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    margin-left: 0;
    padding-bottom: 0.5rem;
  }
  .site-header .nav__actions .nav__phone {
    font-size: 1.375rem;
  }
  .site-header .nav__actions .nav__mail {
    color: #1e1e1e;
    font-size: 1.25rem;
  }
  .site-header .nav__actions .nav__mail-row {
    justify-content: flex-start;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .site-header .header__logo .logo-img {
    max-width: none;
  }
}
@media (max-width: calc(75rem - 0.02px)) {
  .site-header .nav {
    font-size: 1rem;
  }
}
@media (min-width: 36rem) {
  .site-header .nav {
    gap: 2.5rem;
  }
}
.site-header {
  /* ≥ md: центрируем получше и даём запас по строке */
}
@media (min-width: 48rem) {
  .site-header .header__row {
    gap: 1rem;
  }
  .site-header .nav {
    justify-content: center;
  }
}
.site-header {
  /* ≥ lg: больше «воздуха» в меню и запас после логотипа */
}
@media (min-width: 62rem) {
  .site-header .nav {
    gap: 0.9375rem;
  }
}
.site-header {
  /* ≥ xl: базовые интервалы */
}
@media (min-width: 75rem) {
  .site-header .header__row {
    gap: 1.25rem;
  }
  .site-header .nav {
    gap: 3.5rem;
  }
}
.site-header {
  /* ≥ xxl: воздуха больше по умолчанию */
}
@media (min-width: 87.5rem) {
  .site-header .nav {
    gap: 4rem;
  }
}
.site-header {
  /* Reduced Motion */
}
@media (prefers-reduced-motion: reduce) {
  .site-header {
    transition: none;
  }
  .site-header .header__row::after, .site-header .nav__link, .site-header .header__nav, .site-header .header__burger {
    transition: none;
  }
}

/* =============================
   Cross-scope utilities
   ============================= */
body.nav-open {
  overflow: hidden;
}

:where(#pumps, #help, #benefits, #contacts, #main) {
  scroll-margin-top: calc(var(--header-h) + 1.5rem);
}

/* =============================
   COMPACT PROFILE: XL–XXL (1200–1600)
   чтобы не было переноса и контакты не уезжали
   ============================= */
/* базовые гарантии флексов */
.site-header .header__nav {
  min-width: 0;
}

.site-header .nav {
  min-width: 0;
  flex: 1 1 auto;
}

.site-header .nav__actions {
  flex: 0 0 auto;
  white-space: nowrap;
}

/* убираем прежние дополнительные отступы перед контактами, если были */
@media (min-width: 48rem) {
  .site-header .nav__actions {
    margin-left: 0;
  }
}
/* адресная компактизация */
@media (min-width: 75rem) and (max-width: calc(87.5rem - 0.02px)) {
  .site-header .header__nav {
    padding-inline: 2rem;
  }
  .site-header {
    /* компактные поля у контейнера навигации */
  }
  .site-header .nav {
    gap: 1.5rem;
  }
  .site-header {
    /* меньше промежутки между пунктами */
  }
  .site-header .nav__link {
    padding: 0.5rem 0.5rem;
  }
  .site-header {
    /* чуть уже кликабельная зона */
  }
  .site-header .nav__phone {
    font-size: 1.375rem;
  }
  .site-header {
    /* аккуратно уменьшаем контакты */
  }
  .site-header .nav__mail {
    font-size: 1.125rem;
  }
  .site-header .nav__actions {
    margin-left: 3rem;
  }
  .site-header {
    /* гарантированный просвет перед контактами */
  }
}
/* подстраховка для 1200–1280, где особенно тесно */
@media (min-width: 75rem) and (max-width: 1280px) {
  .site-header .header__nav {
    padding-inline: 1.5rem;
  }
  .site-header .nav {
    gap: 1.25rem;
  }
  .site-header .nav__actions {
    margin-left: 2.5rem;
  }
}
/* на очень широких возвращаем «воздух», но контакты не растягиваем */
@media (min-width: 87.5rem) {
  .site-header .header__nav {
    padding-inline: 3rem;
  }
  .site-header .nav {
    gap: 3rem;
  }
  .site-header .nav__phone {
    font-size: 1.5rem;
  }
  .site-header .nav__mail {
    font-size: 1.25rem;
  }
  .site-header .nav__actions {
    margin-left: 3rem;
  }
}
@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

/* @use — строго наверху */
.agreement {
  position: fixed;
  bottom: 2.5rem;
  right: 2.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.9375rem 1.5625rem;
  background-color: #ebebeb;
  border-radius: 0.3125rem;
  box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.1);
  z-index: 1000;
}
@media (max-width: calc(48rem - 0.02px)) {
  .agreement {
    right: 0;
    bottom: 0;
    justify-content: space-between;
    width: 100%;
  }
}
.agreement__text {
  font-weight: 300;
  font-size: clamp(0.875rem, 2vw, 1rem);
  color: #333333;
}
.agreement__link {
  color: #2880FD;
}
.agreement__button {
  padding-inline: 1.25rem;
  color: #555555;
  font-weight: 500;
  border-radius: 0.3125rem;
  border: 0.0625rem solid #999999;
  user-select: none;
}
@media (max-width: calc(36rem - 0.02px)) {
  .agreement__transfer {
    display: none;
  }
}

/* @use — строго наверху */
/* Локальный потолок 1600px + «умные» внешние гаттеры */
/* ================== FOOTER ================== */
.footer {
  background: #0d1014;
  color: rgba(255, 255, 255, 0.88);
  padding-block: clamp(2rem, 3vw, 2.5rem);
  font-size: 1rem;
  /* переопределяем системный контейнер только внутри футера */
}
.footer > .container.container--wide {
  --target: 100rem; /* 1600px */
  --gutter: clamp(0px, 2vw, max(0px, calc((100vw - var(--target)) / 2)));
  width: min(var(--target), 100% - var(--gutter) * 2);
  margin-inline: auto;
  /* внутренние «сеточные» отступы только на десктопах */
}
@media (min-width: 75rem) {
  .footer > .container.container--wide {
    padding-inline: 1.5rem;
  }
}
.footer a {
  color: inherit;
  text-decoration: none;
}
.footer {
  /* верхняя часть */
}
.footer__top {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  align-items: start;
  gap: 1.5rem;
}
@media (max-width: 1000px) {
  .footer__top {
    grid-template-columns: 1fr 1fr;
    row-gap: 2rem;
  }
  .footer__top .footer__contacts {
    justify-self: end;
  }
}
@media (max-width: 680px) {
  .footer__top {
    grid-template-columns: 1fr;
  }
  .footer__top .footer__contacts {
    justify-self: start;
  }
}
.footer {
  /* логотип */
}
.footer__brand {
  display: inline-flex;
  align-items: center;
}
.footer__brand picture, .footer__brand img {
  display: block;
}
.footer__brand img {
  width: auto;
}
.footer {
  /* меню */
}
.footer__menu {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.75rem;
  align-content: start;
}
.footer__link {
  opacity: 0.92;
  transition: color 0.25s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.footer__link:hover {
  color: #2880FD;
  opacity: 1;
}
.footer__link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.footer {
  /* телефон */
}
.footer__contacts {
  justify-self: end;
  text-align: right;
}
@media (max-width: 680px) {
  .footer__contacts {
    justify-self: start;
    text-align: left;
  }
}
.footer__caption {
  display: block;
  font-size: 0.875rem;
  line-height: 1.2;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 0.25rem;
}
.footer__phone {
  display: inline-block;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: #2880FD;
  font-size: clamp(1.25rem, 2.7vw, 2.25rem);
  line-height: 1.1;
  white-space: nowrap;
}
.footer__phone:hover {
  text-decoration: underline;
}
.footer__phone:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.footer {
  /* разделитель */
}
.footer__divider {
  margin: 1.5rem 0;
  border: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.footer {
  /* нижняя часть */
}
.footer__legal {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}
.footer__legal-link {
  display: inline-block;
  padding: 0.125rem 0;
  color: rgba(255, 255, 255, 0.8);
  transition: color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.footer__legal-link:hover {
  color: #fff;
}
.footer__legal-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}

/* Вспомогательный класс для скрытых заголовков (a11y) */
.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* страницы */
/* @use — строго наверху */
/* vite\src\styles\pages\_hero.scss */
/* локальные токены */
.hero {
  position: relative;
  isolation: isolate;
  /* под фикс-хедер */
  margin-top: calc(var(--header-h) * -1);
  --hero-offset-add: 0px; /* ручка для тонкой подстройки из HTML, если нужно */
  padding-top: calc(var(--header-h) + 4rem + var(--hero-offset-add));
  padding-bottom: 6.6875rem;
  min-height: clamp(560px, 78vh, 680px);
  /* фон: мягкий радиальный + затемнённая фотоподложка */
  background: radial-gradient(120% 120% at 85% 20%, rgba(13, 59, 102, 0.08) 0%, rgba(13, 59, 102, 0) 60%), #0f0f10;
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero {
    padding-bottom: 5rem;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero {
    padding-bottom: 3.75rem;
  }
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  /* Safari фолбэк + стандартный image-set */
  background-image: -webkit-image-set(url("/static/main/image/hero/hero-bg.avif") type("image/avif") 1x, url("/static/main/image/hero/hero-bg@2x.avif") type("image/avif") 2x, url("/static/main/image/hero/hero-bg.webp") type("image/webp") 1x, url("/static/main/image/hero/hero-bg@2x.webp") type("image/webp") 2x, url("/static/main/image/hero/hero-bg.png") type("image/png") 1x, url("/static/main/image/hero/hero-bg@2x.png") type("image/png") 2x);
  background-image: image-set(url("/static/main/image/hero/hero-bg.avif") type("image/avif") 1x, url("/static/main/image/hero/hero-bg@2x.avif") type("image/avif") 2x, url("/static/main/image/hero/hero-bg.webp") type("image/webp") 1x, url("/static/main/image/hero/hero-bg@2x.webp") type("image/webp") 2x, url("/static/main/image/hero/hero-bg.png") type("image/png") 1x, url("/static/main/image/hero/hero-bg@2x.png") type("image/png") 2x);
  background-position: center right;
  background-size: cover;
  background-repeat: no-repeat;
  /* лёгкое затемнение */
  box-shadow: inset 0 0 0 100vmax rgba(0, 0, 0, 0.42);
}
.hero .hero__subtitle,
.hero .hero__descriptor {
  margin: 0 0 1.5rem;
  font-size: clamp(1.125rem, 1.1vw + 0.75rem, 1.375rem);
  line-height: 1.55;
  color: #fff; /* без прозрачности, чтобы не «терялся» */
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35); /* мягкий контур на любом фоне */
  max-width: clamp(35rem, 52vw, 47.5rem);
  /* если картинка геро справа перекрывает — поднимаем только дискриптер */
  position: relative;
  z-index: 2;
}
.hero {
  /* ===== сетка ===== */
}
.hero .hero__grid {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
}
@media (max-width: calc(75rem - 0.02px)) {
  .hero .hero__grid {
    grid-template-columns: 6.5fr 5.5fr;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero .hero__grid {
    grid-template-columns: 1fr;
  }
}
.hero .hero__content {
  display: flex;
  flex-direction: column;
}
.hero .hero__media {
  position: relative;
  min-height: 56.25rem;
}
.hero {
  /* картинка прибита к правому краю */
}
.hero .hero__img {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: -1;
  max-width: none;
  width: clamp(26.25rem, 50vw, 43.75rem);
  height: auto;
  display: block;
  pointer-events: none;
  user-select: none;
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero .hero__img {
    filter: brightness(0.6);
  }
}
.hero {
  /* вариант: прилипание к ПРАВОМУ КРАЮ ЭКРАНА (за пределы контейнера) */
}
.hero .hero__media.is-viewport .hero__img {
  right: calc(var(--page-gutter) * -1); /* выносим на величину боковых полей */
}
.hero {
  /* ===== заголовок ===== */
}
.hero .hero__title {
  margin: 0 0 6rem;
  width: 65%;
  color: #fff;
  font-size: clamp(1.75rem, 4.5vw, 4.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.1;
  font-size: clamp(2rem, 2 + (1.5) * (100vw - 22.5px) / 67.5, 3.5rem);
}
@media (max-width: calc(75rem - 0.02px)) {
  .hero .hero__title {
    width: 100%;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero .hero__title {
    margin: 0 0 3rem;
  }
}
.hero__accent {
  color: #2880FD;
}
.hero {
  /* ===== список-буллеты ===== */
}
.hero .hero__bullets {
  margin: 0 0 1.5rem;
  padding-left: 0;
  list-style: none;
  color: rgba(255, 255, 255, 0.72);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.hero .hero__bullets li {
  margin: 0;
}
@media (max-width: calc(48rem - 0.02px)) {
  .hero .hero__bullets {
    grid-template-columns: 1fr;
  }
}
.hero {
  /* === HERO FEATURES (две карточки как на макете) ========================= */
}
.hero .hero__features {
  list-style: none;
  display: flex;
  gap: 1.5rem;
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero .hero__features {
    flex-direction: column;
  }
}
.hero .feature {
  display: flex;
  align-items: center;
  gap: 2rem; /* расстояние между иконкой и текстом */
  padding: 0.8125rem 1.25rem 0.8125rem 0; /* 🟦 слева 0 — иконка прилипает к краю */
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  overflow: hidden; /* 🟦 чтобы фон иконки аккуратно обрезался по радиусу карточки */
}
@media (max-width: calc(75rem - 0.02px)) {
  .hero .feature {
    padding: 0.625rem 0.9375rem 0.625rem 0;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero .feature {
    width: 70%;
    gap: 0;
    padding: 0;
  }
}
@media (max-width: calc(48rem - 0.02px)) {
  .hero .feature {
    padding: 1rem 1rem 1rem 0; /* 🟦 на мобилке чуть меньше справа */
    border-radius: 0.75rem;
    width: 100%;
  }
}
.hero {
  /* текст тянется, иконка «прилипает» справа */
}
.hero .feature__text {
  flex: 1 1 auto; /* текст занимает оставшееся пространство */
  min-width: 0;
}
.hero .feature__title {
  font-weight: 500;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  line-height: 1.25;
  color: #fff;
  margin: 0 0 0.25rem;
}
.hero .feature__desc {
  font-size: clamp(1rem, 2vw, 1.125rem);
  line-height: 1.28;
  color: rgba(255, 255, 255, 0.8);
}
.hero .feature__icon {
  margin-left: 0;
  flex: 0 0 5rem;
  width: 7.5rem;
  height: 7.5rem;
  border-radius: 0.875rem;
  position: relative; /* ← ключ: делаем якорь для абсолютного img */
  overflow: hidden; /* аккуратная обрезка по радиусу */
}
@media (max-width: calc(75rem - 0.02px)) {
  .hero .feature__icon {
    width: 6.25rem;
    height: 6.25rem;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .hero .feature__icon {
    width: 5rem;
    height: 5rem;
  }
}
.hero .feature__icon {
  /* ручки тонкой подстройки (по желанию) */
  --icon-shift-x: 0; /* отрицательные значения сдвигают влево */
  --icon-shift-y: 0; /* отрицательные поднимают вверх */
}
.hero .feature__icon img {
  position: absolute; /* ← фиксируем в контейнере */
  inset: 0; /* прилипает ко всем краям, без зазоров */
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain; /* сохраняем пропорции */
  object-position: left top; /* прижимаем к левому ВЕРХНЕМУ углу */
  transform: translate(var(--icon-shift-x), var(--icon-shift-y));
}
@media (max-width: calc(48rem - 0.02px)) {
  .hero .feature__icon {
    flex-basis: 4rem;
    width: 4rem;
    height: 4rem;
    border-radius: 0.75rem;
  }
}
.hero {
  /* ===== CTA ===== */
}
.hero .hero__cta {
  margin-top: 1.5rem;
}
.hero .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding-inline: 1.25rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(42, 86, 163, 0.6);
  background: #1f6fff;
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.hero .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.hero .btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.hero .btn + .btn {
  margin-left: 0.75rem;
}
.hero .btn.btn--outline {
  background: transparent;
  color: #a6c2ff;
  border-color: #335db0;
}
.hero {
  /* декоративные элементы, если нужны */
}
.hero .hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
}
.hero .hero__word {
  position: absolute;
  right: 6%;
  bottom: 10%;
  color: transparent;
  -webkit-text-stroke: 2px rgba(255, 255, 255, 0.25);
  text-stroke: 2px rgba(255, 255, 255, 0.25);
  font-weight: 900;
  letter-spacing: 0.1em;
  white-space: nowrap;
  line-height: 1;
  opacity: 0.55;
  font-size: clamp(4.5rem, 4.5 + (4.25) * (100vw - 22.5px) / 97.5, 8.75rem);
}
@media (max-width: calc(48rem - 0.02px)) {
  .hero .hero__word {
    right: auto;
    left: 4%;
    bottom: 2%;
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.3);
  }
}

/* утилита для жёсткого запрета переноса */
.nowrap {
  white-space: nowrap;
}

/* @use — строго наверху */
/* vite/src/styles/components/_series.scss */
.series {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
  background: #ffffff;
  display: flex;
  flex-direction: column;
  gap: 3.75rem;
  /* общий зазор для стыка липкого CTA с хедером */
  --series-sticky-gap: 8rem;
}
.series .series__kicker {
  margin: 0 0 0.5rem;
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
}
.series .series__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.5rem, 2.2vw + 0.375rem, 3.5rem);
}
.series .series__title .series__accent {
  color: #2880FD;
}
.series {
  /* ===== GRID ===== */
}
.series__grid {
  display: flex;
  gap: 2rem;
  align-items: start;
}
@media (max-width: calc(62rem - 0.02px)) {
  .series__grid {
    flex-direction: column;
  }
}
.series__left {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  grid-column: 1/2;
}
@media (max-width: calc(62rem - 0.02px)) {
  .series__cta {
    width: 100%;
  }
}
.series__cta {
  /* sticky на десктопе с учётом фикс-хедера */
}
@media (min-width: 62rem) {
  .series__cta {
    position: sticky;
    z-index: 1;
    /* var(--header-h) может приходить из JS/хедера; если нет — берём $header-h-d */
    top: calc(var(--header-h, 4rem) + env(safe-area-inset-top) + var(--series-sticky-gap));
    align-self: start;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .series__cta {
    position: static; /* на мобиле — обычный поток */
  }
}
.series {
  /* ===== GROUPS ===== */
}
.series__group-title {
  margin: 0 0 1rem;
  font-weight: 700;
  font-size: clamp(1.375rem, 2.2vw + 0.375rem, 1.75rem);
  line-height: 1.2;
}

/* ===== CHIPS ===== */
.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 0;
  list-style: none;
  align-content: flex-start;
}

.chips__item {
  flex: 0 0 auto;
}

.chip {
  --chip-bg: #fff;
  --chip-fg: #0d3b66;
  --chip-br: rgb(167.4130434783, 206.9130434783, 243.8369565217);
  --chip-br-hover: rgb(132.3782608696, 187.6782608696, 239.3717391304);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding-inline: 1.25rem;
  height: 3.5rem;
  border-radius: 1rem;
  background: var(--chip-bg);
  border: 1px solid var(--chip-br);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
  color: var(--chip-fg);
  text-decoration: none;
  font-weight: 700;
  white-space: nowrap;
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  touch-action: manipulation;
}
@media (max-width: calc(48rem - 0.02px)) {
  .chip {
    height: 2.5rem;
    padding-inline: 1rem;
  }
}
.chip:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem #2880FD;
}
@media (hover: hover) {
  .chip:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    border-color: var(--chip-br-hover);
  }
}
.chip:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.chip__name {
  color: #1e1e1e;
  font-size: clamp(1.125rem, 2.2vw + 0.375rem, 1.375rem);
  font-weight: 600;
  line-height: 1;
}

/* ===== CTA ===== */
.cta {
  position: relative;
  overflow: visible;
  isolation: isolate;
  background: #2880FD;
  color: #fff;
  border-radius: 1rem;
  padding: 3rem;
  min-height: 22.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}
@media (max-width: calc(36rem - 0.02px)) {
  .cta {
    padding: 1.5rem;
    min-height: 16.875rem;
  }
}
.cta__title {
  margin: 0 8rem 0.5rem 0;
  font-weight: 700;
  font-size: clamp(1.375rem, 2.2vw + 0.375rem, 1.75rem);
  line-height: 1.2;
  max-width: 26ch;
}
@media (max-width: calc(75rem - 0.02px)) {
  .cta__title {
    margin: 0;
    width: 70%;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .cta__title {
    width: 100%;
  }
}
.cta__desc {
  margin: 0 0 5rem;
  opacity: 0.92;
  font-size: 1.125rem;
}
@media (max-width: calc(75rem - 0.02px)) {
  .cta__desc {
    margin-bottom: 3.75rem;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .cta__desc {
    margin-bottom: 2.5rem;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .cta__desc {
    margin-bottom: 1.5625rem;
  }
}
.cta__button {
  display: block;
  width: 100%;
  min-height: 3.5rem;
  line-height: 3.5rem;
  font-size: 1.25rem;
  font-weight: 600;
  border-radius: 0.75rem;
  background: #1f6fff;
  color: #fff;
  text-decoration: none;
  text-align: center;
}
.cta__note {
  margin-top: 1rem;
  font-size: 1rem;
  opacity: 0.85;
  position: relative;
  z-index: 1;
}
.cta__img {
  position: absolute;
  right: 0.625rem;
  top: 2.5rem;
  transform: translateY(-50%);
  width: 9.375rem;
  height: auto;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
@media (max-width: calc(75rem - 0.02px)) {
  .cta__img {
    top: 1.875rem;
    width: 7.5rem;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .cta__img {
    top: 0;
    width: 6.25rem;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .cta {
    padding: 2.5rem;
  }
  .cta__button {
    min-height: 3.25rem;
    line-height: 3.25rem;
    font-size: 1.125rem;
  }
}

/* Доп. страховка для якоря секции: попадание ниже фикс-хедера */
:where(#pumps) {
  scroll-margin-top: calc(var(--header-h, 4rem) + 1.5rem);
}

@media (prefers-reduced-motion: reduce) {
  .chip, .cta__button {
    transition: none;
  }
}
/* @use — строго наверху */
/* @use — строго наверху */
/* placeholders для экономии итогового CSS */
.stat-card, .benefit-card, .card {
  background: #fff;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.contacts__frame, .panel {
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04), 0 12px 28px rgba(13, 59, 102, 0.08);
  overflow: hidden;
}

/* публичные классы на случай, если надо в разметке */
.card--muted {
  background: #f6f7f9;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.card--primary {
  background: #0d3b66;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 10px 26px rgba(13, 59, 102, 0.25);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  color: #ffffff;
}

.assist {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
  background-color: #0a0d10;
  color: #fff;
}
.assist__stack {
  display: grid;
  gap: 2rem;
}
.assist__header {
  margin-bottom: clamp(1.25rem, 2vw, 3rem);
}
.assist__header .section-head__kicker {
  font-size: 0.8125rem;
  line-height: 1.25;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.assist__header .section-head__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.75rem);
}
.assist__header .section-head__accent {
  color: #2880FD;
}
.assist__tips-grid {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: 2rem;
  align-items: center;
}
@media (max-width: calc(62rem - 0.02px)) {
  .assist__tips-grid {
    grid-template-columns: 1fr;
  }
}
.assist__lead {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.4;
}
.assist__contacts-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.5rem;
}
.assist__contacts-list a {
  color: #0d3b66;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
.assist__media {
  position: relative;
}
.assist__img {
  position: absolute;
  right: -0.625rem;
  bottom: -0.625rem;
  width: clamp(11.25rem, 40%, 20rem);
  pointer-events: none;
  user-select: none;
}
@media (max-width: calc(62rem - 0.02px)) {
  .assist__img {
    position: static;
    width: 13.75rem;
    margin-left: auto;
    display: block;
  }
}

/* универсальные карточки */
.card--red {
  background: #e53935;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  color: #fff;
}

.card--white {
  background: #fff;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  color: #1e1e1e;
}

.card--blue {
  background: #2880FD;
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  color: #fff;
  background-image: radial-gradient(120% 100% at 80% 0%, rgb(25.4850230415, 119.4260368664, 252.8649769585) 0%, #2880FD 60%);
}

/* форма */
.assist-form {
  display: grid;
  gap: 2rem;
}
.assist-form__grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: calc(62rem - 0.02px)) {
  .assist-form__grid {
    grid-template-columns: 1fr;
  }
}
.assist-form__col {
  display: grid;
  gap: 1rem;
}
.assist-form .field {
  display: grid;
  gap: 0.5rem;
}
.assist-form .field__label {
  font-size: 0.875rem;
  opacity: 0.9;
}
.assist-form .field__control {
  appearance: none;
  width: 100%;
  height: 3.5rem;
  padding: 0 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
  background: #fff;
  color: #1e1e1e;
  box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.04);
  transition: border-color 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1), transform 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.assist-form .field__control:focus {
  outline: none;
  box-shadow: 0 0 0 0.1875rem #0d3b66;
}
.assist-form .field__control--area {
  height: auto;
  padding: 0.75rem 1rem;
  resize: vertical;
  min-height: 7.5rem;
}
.assist-form .field--file .field__control {
  padding: 0.75rem 1rem;
  height: auto;
}
.assist-form__submit {
  display: block;
  width: 100%;
  height: 4rem;
  line-height: 4rem;
  text-align: center;
  font-weight: 800;
  border-radius: 1rem;
  background: #fff;
  color: #0d3b66;
  border: 0;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  touch-action: manipulation;
}
@media (hover: hover) {
  .assist-form__submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.16);
  }
}
.assist-form__submit:active {
  transform: translateY(0);
}
.assist-form__note {
  margin: 0;
  font-size: 0.75rem;
  opacity: 0.85;
}

@media (prefers-reduced-motion: reduce) {
  .assist-form__submit, .field__control {
    transition: none;
  }
}
/* @use — строго наверху */
/* src/styles/pages/_brands.scss */
/* @use — строго наверху */
/* src/styles/patterns/_grid-table.scss */
/* МИКСИН: сетка как «таблица» с верхним/левым сепаратором */
/* Утилитные классы — применять ТОЛЬКО в HTML (НЕ @extend в SCSS) */
.grid-table--1 {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 0;
  --sep: rgba(0, 0, 0, .08);
  /* рисуем верх/лево у сетки — низ/право у ячеек */
  box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
  background: #ffffff;
}

.grid-table--2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  --sep: rgba(0, 0, 0, .08);
  /* рисуем верх/лево у сетки — низ/право у ячеек */
  box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
  background: #ffffff;
}

.grid-table--3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  --sep: rgba(0, 0, 0, .08);
  /* рисуем верх/лево у сетки — низ/право у ячеек */
  box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
  background: #ffffff;
}

.grid-table--4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  --sep: rgba(0, 0, 0, .08);
  /* рисуем верх/лево у сетки — низ/право у ячеек */
  box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
  background: #ffffff;
}

/* <— добавили */
.brands {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
}
.brands__header {
  margin-bottom: clamp(1.5rem, 2vw, 3rem);
}
.brands__kicker {
  font-size: 0.8125rem;
  line-height: 1.25;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.brands__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.15;
  font-size: clamp(1.5rem, 2.2vw + 0.5rem, 2.75rem);
}
.brands__accent {
  color: #2880FD;
}
.brands {
  /* Сетка с разделителями как на макете */
}
.brands__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  --sep: rgba(0, 0, 0, .08);
  /* рисуем верх/лево у сетки — низ/право у ячеек */
  box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
  background: #ffffff;
  /* ПК: 4 колонки */
}
@media (max-width: 1100px) {
  .brands__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    --sep: rgba(0, 0, 0, .08);
    /* рисуем верх/лево у сетки — низ/право у ячеек */
    box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
    background: #ffffff;
  }
}
@media (max-width: 720px) {
  .brands__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    --sep: rgba(0, 0, 0, .08);
    /* рисуем верх/лево у сетки — низ/право у ячеек */
    box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
    background: #ffffff;
  }
}

/* Ячейка логотипа + разделители снизу/справа (одинарные линии) */
.brand {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(5.5rem, 7vw, 7.5rem);
  padding: 2rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
  background: #fff;
}
@media (max-width: calc(75rem - 0.02px)) {
  .brand {
    padding: 0;
  }
}

.brand__img {
  max-width: min(320px, 70%);
  width: 100%;
  height: auto;
  object-fit: contain;
  filter: none;
  opacity: 1;
}
@media (max-width: calc(48rem - 0.02px)) {
  .brand__img {
    max-width: none;
  }
}

/* @use — строго наверху */
/* ================================================================ */
/* Products Section (визуальные правки + локальный max 1600px)      */
/* ================================================================ */
.products {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
  background: #f5f6f8;
  --img-w: 220px;
  --img-h: 180px;
  /* ---------- HEADER ---------- */
}
.products {
  /* H2 (капс) — комфортная читаемость */
}
.products .section-head__title {
  text-transform: uppercase;
  line-height: 1.12;
  letter-spacing: 0.01em;
}
.products {
  /* Lead — кегль, контраст, ширина строки */
}
.products__lead {
  margin: 0.75rem 0 0;
  font-size: clamp(1rem, 0.3vw + 1rem, 1.125rem);
  color: #2a2a2a;
  max-width: 68ch;
}
.products {
  /* ---------- GRID WRAPPER ---------- */
}
.products > .container.container--wide {
  width: calc(100% - var(--page-gutter) * 2);
  margin-inline: auto;
}
@media (min-width: 48rem) {
  .products > .container.container--wide {
    width: min(60rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 62rem) {
  .products > .container.container--wide {
    width: min(75rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 75rem) {
  .products > .container.container--wide {
    width: min(90rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 87.5rem) {
  .products > .container.container--wide {
    width: min(100rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 120rem) {
  .products > .container.container--wide {
    width: min(120rem, 100% - var(--page-gutter) * 2);
  }
}
@media (min-width: 160rem) {
  .products > .container.container--wide {
    width: min(120rem, 100% - var(--page-gutter) * 2);
  }
}
.products > .container.container--wide {
  width: min(100rem, 100% - var(--page-gutter) * 2);
  margin-inline: auto;
}
.products {
  /* собственно грид */
}
.products__grid {
  gap: 1.5rem;
}
.products {
  /* на широких — ряд чуть плотнее */
}
@media (min-width: 75rem) {
  .products .products__grid {
    gap: 1.25rem;
  }
}
.products {
  /* «последняя строка по три» для 12-колонки */
}
.products__grid > :nth-last-child(3):nth-child(4n+1), .products__grid > :nth-last-child(2):nth-child(4n+2), .products__grid > :nth-last-child(1):nth-child(4n+3) {
  grid-column: span 4;
}
.products {
  /* ---------- RESPONSIVE ---------- */
}
@media (max-width: calc(75rem - 0.02px)) {
  .products .u-grid-12 {
    grid-template-columns: repeat(3, 1fr);
  }
  .products .products__item {
    grid-column: auto;
  }
  .products__grid > :nth-last-child(3):nth-child(4n+1), .products__grid > :nth-last-child(2):nth-child(4n+2), .products__grid > :nth-last-child(1):nth-child(4n+3) {
    grid-column: auto;
  }
}
@media (max-width: calc(62rem - 0.02px)) {
  .products .u-grid-12 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .products .u-grid-12 {
    grid-template-columns: 1fr;
  }
}

/* ------------------------------------------------ */
/* Presets (можно повесить на .products или .prod-card) */
.products--sm, .prod-card--sm {
  --img-w: 160px;
  --img-h: 160px;
}

.products--md, .prod-card--md {
  --img-w: 200px;
  --img-h: 200px;
}

.products--lg, .prod-card--lg {
  --img-w: 260px;
  --img-h: 220px;
}

.products--xl, .prod-card--xl {
  --img-w: 320px;
  --img-h: 260px;
}

/* ================================================================ */
/* Card (вся карточка — ссылка)                                     */
/* ================================================================ */
.prod-card {
  background: #fff;
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  height: 100%;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  will-change: transform;
}
@media (max-width: calc(62rem - 0.02px)) {
  .prod-card {
    padding: 1.25rem;
    gap: 0.9375rem;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .prod-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0.9375rem;
  }
}
.prod-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(13, 59, 102, 0.12);
}
.prod-card:active {
  transform: translateY(0);
}
.prod-card:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.prod-card__media {
  margin-inline: auto;
  display: grid;
  place-items: center;
  /* единая визуальная «масса» */
  aspect-ratio: 11/9;
}
@media (max-width: calc(36rem - 0.02px)) {
  .prod-card__media {
    margin: 0;
  }
}
.prod-card__img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
  display: block;
  max-width: 88%;
  max-height: 88%;
  transition: transform 0.18s ease;
}
@media (max-width: calc(36rem - 0.02px)) {
  .prod-card__img {
    width: 5.625rem;
    height: 5.625rem;
    max-width: none;
  }
}
.prod-card:hover .prod-card__img {
  transform: scale(1.03);
}
.prod-card__title {
  margin: 0;
  text-align: center;
  font-weight: 800;
  line-height: 1.25;
  font-size: clamp(1.125rem, 1.125 + (0.25) * (100vw - 360px) / 1080, 1.375rem);
  min-height: 2.5em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
@media (max-width: calc(62rem - 0.02px)) {
  .prod-card__title {
    min-height: auto;
  }
}
@media (max-width: calc(36rem - 0.02px)) {
  .prod-card__title {
    text-align: left;
  }
}
.prod-card__sub {
  margin: -0.25rem 0 0;
  text-align: center;
  color: rgba(30, 30, 30, 0.85);
  font-size: 1rem;
}
.prod-card:hover .prod-card__cta {
  transform: translateY(-1px);
}
.prod-card:hover .prod-card__cta::after {
  transform: translateY(1px) translateX(2px);
}

/* ================================================================ */
/* Buttons (CTA)                                                     */
/* ================================================================ */
.btn {
  appearance: none;
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  border-radius: 1rem;
  padding: 0.75rem 1.25rem;
  font-weight: 700;
  line-height: 1;
  border: 1px solid transparent;
  transition: background-color 0.2s cubic-bezier(0.16, 1, 0.3, 1), color 0.2s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

/* @use — строго наверху */
/* @use — строго наверху */
/* универсальные гриды */
.u-grid-12, .benefits__list {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--gap, 1.5rem);
}

.u-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap, 1.5rem);
}

.u-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap, 1.5rem);
}

.u-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--gap, 1.5rem);
}

/* кол-спаны для 12-колонки */
.u-span-1 {
  grid-column: span 1;
}

.u-span-2 {
  grid-column: span 2;
}

.u-span-3 {
  grid-column: span 3;
}

.u-span-4 {
  grid-column: span 4;
}

.u-span-5 {
  grid-column: span 5;
}

.u-span-6 {
  grid-column: span 6;
}

.u-span-7 {
  grid-column: span 7;
}

.u-span-8 {
  grid-column: span 8;
}

.u-span-9 {
  grid-column: span 9;
}

.u-span-10 {
  grid-column: span 10;
}

.u-span-11 {
  grid-column: span 11;
}

.u-span-12 {
  grid-column: span 12;
}

/* ─────────────────────────────────────────────────────────────── */
/* Локальный контейнер: цель 1600px + десктопный «гуттер»         */
/* ─────────────────────────────────────────────────────────────── */
/* ================================================================ */
/* Benefits                                                         */
/* ================================================================ */
.benefits {
  padding-block: clamp(2.5rem, 3vw, 4rem);
  position: relative;
  isolation: isolate;
  /* HEADER */
}
.benefits__header {
  /* целевая ширина */
  --target: 100rem; /* 1600px */
  /* автополя, чтобы target влезал на узких экранах */
  --gutter: clamp(0px, 2vw, max(0px, calc((100vw - var(--target)) / 2)));
  width: min(var(--target), 100% - var(--gutter) * 2);
  /* «сеточный» внутренний отступ только на ПК (можешь поменять space(6) -> space(8)) */
  margin-bottom: clamp(0.75rem, 1.6vw, 3rem);
}
.benefits__kicker {
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.benefits__title {
  margin: 0 0 0.5rem;
  font-weight: 900;
  line-height: 1.12;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.5rem);
}
.benefits__lead {
  margin: 0.25rem 0 0;
  font-size: clamp(1rem, 0.3vw + 1rem, 1.125rem);
  color: #2a2a2a;
  max-width: 68ch;
}
.benefits {
  /* GRID-LAYOUT (12 колонок) */
}
.benefits__layout {
  /* целевая ширина */
  --target: 100rem; /* 1600px */
  /* автополя, чтобы target влезал на узких экранах */
  --gutter: clamp(0px, 2vw, max(0px, calc((100vw - var(--target)) / 2)));
  width: min(var(--target), 100% - var(--gutter) * 2);
  /* «сеточный» внутренний отступ только на ПК (можешь поменять space(6) -> space(8)) */
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1.5rem;
  align-items: start;
  position: relative;
  z-index: 1;
}
.benefits {
  /* Список карточек — своя 12-колоночная сетка */
}
.benefits__list {
  grid-column: 1/-1;
  --gap: 1rem;
}
.benefits {
  /* MEDIA: прибито к правому краю вьюпорта */
}
.benefits__media {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: clamp(720px, 42vw, 1078px);
  pointer-events: none;
  z-index: 0;
  filter: drop-shadow(0 12px 28px rgba(13, 59, 102, 0.16));
}
.benefits__img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}
.benefits {
  /* RESPONSIVE */
}
@media (max-width: 1100px) {
  .benefits__media {
    position: static;
    transform: none;
    width: 100%;
    margin: 2rem auto 0;
    max-width: 920px;
  }
}
@media (max-width: 900px) {
  .benefits__list > .benefit-card {
    grid-column: span 12;
  }
}

/* ================================================================ */
/* Benefit Card                                                     */
/* ================================================================ */
.benefit-card {
  background: #f6f7f9;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.75rem;
  align-items: start;
  padding: 1.25rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.benefit-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(13, 59, 102, 0.1);
}
.benefit-card__badge {
  --badge-size: 42px;
  --icon-size: 22px;
  inline-size: var(--badge-size);
  block-size: var(--badge-size);
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: rgba(40, 128, 253, 0.12);
  color: #0d3b66;
}
.benefit-card__badge > img {
  display: block;
  inline-size: var(--icon-size);
  block-size: var(--icon-size);
  object-fit: contain;
}
.benefit-card__title {
  margin: 0;
  font-weight: 800;
  line-height: 1.25;
  font-size: clamp(0.95rem, 0.4vw + 0.75rem, 1.0625rem);
}
.benefit-card__text {
  grid-column: 2;
  margin: 0.25rem 0 0;
  font-size: 1rem;
  line-height: 1.45;
  color: rgba(30, 30, 30, 0.9);
}
.benefit-card--primary {
  background: #0d3b66;
  color: #fff;
  box-shadow: 0 10px 26px rgba(13, 59, 102, 0.25);
}
.benefit-card--primary .benefit-card__badge {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}
.benefit-card--primary .benefit-card__text {
  color: rgba(255, 255, 255, 0.95);
}

/* @use — строго наверху */
/* ===== Reviews (без внешних миксинов) ============================ */
.reviews {
  background: #2a2a2a;
  /* вертикальные поля секции */
  padding-block: clamp(32px, 6vw, 96px);
}

.reviews__kicker {
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
  color: #fff;
}

.reviews__title {
  margin: 0 0 0.5rem;
  font-weight: 900;
  line-height: 1.12;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.5rem);
  color: #fff;
}

.reviews__lead {
  margin: 0.25rem 0 0;
  font-size: clamp(1rem, 0.3vw + 1rem, 1.0625rem);
  color: #eee;
  max-width: 68ch;
}

/* Грид на 5 колонок */
.reviews__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* ===== Карточка отзыва ========================================== */
.review-card {
  background: #f6f7f9;
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04), 0 8px 22px rgba(13, 59, 102, 0.08);
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.review-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(13, 59, 102, 0.12);
}

/* Вся карточка кликабельная */
.review-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
  outline: none;
}
.review-card__link:focus-visible {
  outline: 3px solid rgba(40, 128, 253, 0.35);
  outline-offset: 2px;
  border-radius: 14px;
}

/* Медиа-контейнер фиксированной пропорции, чтобы все карточки были ровными */
.review-card__media {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Картинка вписывается целиком внутрь, не обрезаясь и не вылазит за край */
.review-card__img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

/* Подпись под картинкой */
.review-card__meta {
  padding: 16px;
  color: #ffffff;
  text-align: center;
}

.review-card__caption {
  font-weight: 800;
  line-height: 1.25;
}

.review-card__company {
  font-size: 0.9375rem;
  opacity: 0.85;
}

.review-slider__arrows {
  display: flex;
  gap: 16px;
  margin-bottom: 16px;
  justify-content: flex-end;
}
.review-slider__arrow {
  border-radius: 0.5rem;
  border: 0.125rem solid grey;
  padding: 0.3125rem;
  background: gray;
}
@media (max-width: calc(36rem - 0.02px)) {
  .review-slider__arrow {
    width: 2.5rem;
  }
}
.review-slider__arrow-prev {
  rotate: 180deg;
}

/* ===== Адаптивная сетка: 4 / 3 / 2 / 1 ========================== */
@media (max-width: 1400px) {
  .reviews__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 1100px) {
  .reviews__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 820px) {
  .reviews__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 520px) {
  .reviews__grid {
    grid-template-columns: 1fr;
  }
}
/* @use — строго наверху */
/* src/styles/pages/_brands.scss */
/* ================== CLIENTS ================== */
.clients {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
  /* отступы секции из миксина */
  background: #f5f6f8;
  /* ===== Header ===== */
}
.clients__head {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: 2rem;
  margin-bottom: clamp(1.25rem, 2vw, 3rem);
}
@media (max-width: calc(62rem - 0.02px)) {
  .clients__head {
    grid-template-columns: 1fr;
  }
}
.clients__kicker {
  font-size: 0.8125rem;
  line-height: 1.25;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.clients__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.75rem);
}
.clients__accent {
  color: #2880FD;
}
.clients__aside {
  align-self: end;
  font-size: 0.95rem;
  line-height: 1.45;
  opacity: 0.85;
}
.clients {
  /* ===== Панель с логотипами ===== */
}
.clients__panel {
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04), 0 12px 28px rgba(13, 59, 102, 0.08);
  overflow: hidden;
  margin-bottom: 2rem;
}
.clients {
  /* ===== Сетка логотипов (без @extend в media) ===== */
}
.clients__grid {
  --sep: rgba(0, 0, 0, .08);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0; /* линии рисуем бордерами ячеек */
  box-shadow: inset 0 1px 0 var(--sep), inset 1px 0 0 var(--sep);
  background: #fff;
}
@media (max-width: 1200px) {
  .clients__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: calc(48rem - 0.02px)) {
  .clients__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.clients__cell {
  display: grid;
  place-items: center;
  min-height: clamp(90px, 12vw, 130px);
  padding: 1.5rem;
  border-right: 1px solid rgba(0, 0, 0, 0.08);
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  background: #fff;
}
@media (max-width: calc(62rem - 0.02px)) {
  .clients__cell {
    padding: 0;
  }
}
.clients__logo {
  max-width: min(240px, 80%);
  max-height: 140px;
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  filter: none;
  opacity: 1;
}
@media (max-width: calc(48rem - 0.02px)) {
  .clients__logo {
    max-width: none;
    max-height: none;
  }
}
.clients {
  /* ===== Баннер «Референс-лист» ===== */
}
.clients__note {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.5rem;
  padding: 1.5rem;
  background: #0d3b66;
  color: #fff;
  border-radius: 1rem;
  box-shadow: 0 10px 26px rgba(13, 59, 102, 0.18);
}
@media (max-width: 720px) {
  .clients__note {
    grid-template-columns: 1fr;
    text-align: left;
  }
}
.clients__note-title {
  font-weight: 800;
  font-size: clamp(1rem, 0.5vw + 0.9rem, 1.125rem);
  white-space: nowrap;
}
.clients__note-text {
  font-size: 0.95rem;
  line-height: 1.45;
  opacity: 0.95;
}

/* @use — строго наверху */
/* -----------------------------------------------------------
   STATS
----------------------------------------------------------- */
.stats {
  position: relative;
  isolation: isolate;
  color: #fff;
  background: #111;
  padding-block: clamp(3.5rem, 6vw, 8.75rem);
  /* Fallback (JPEG) */
  --stats-bg: url("/static/main/image/bg.jpg");
  /* Современные браузеры — AVIF/WebP/JPEG через image-set */
}
@supports (background-image: image-set(url("x") 1x)) {
  .stats {
    --stats-bg: image-set(
      url("/static/main/image/bg.avif") 1x,
      url("/static/main/image/bg.webp") 1x,
      url("/static/main/image/bg.png") 1x
    );
  }
}
.stats::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: radial-gradient(120% 120% at 85% 20%, rgba(40, 128, 253, 0.18) 0%, rgba(40, 128, 253, 0) 60%), var(--stats-bg);
  background-size: cover;
  background-position: center;
  filter: saturate(0.9);
}
.stats::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: rgba(0, 0, 0, 0.55);
}
.stats > .container.container--wide {
  --target: 100rem; /* 1600px */
  --gutter: clamp(0px, 2vw, max(0px, calc((100vw - var(--target)) / 2)));
  width: min(var(--target), 100% - var(--gutter) * 2);
  margin-inline: auto;
}
@media (min-width: 75rem) {
  .stats > .container.container--wide {
    padding-inline: 1.5rem;
  }
}
.stats__header {
  margin-bottom: clamp(1rem, 2vw, 2.5rem);
}
.stats__kicker {
  margin: 0 0 0.5rem;
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.75;
}
.stats__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.12;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.5rem);
}
.stats__title .stats__accent {
  color: #2880FD;
}
.stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
@media (max-width: 1100px) {
  .stats__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .stats__grid {
    grid-template-columns: 1fr;
  }
}

.stat-card {
  background: #fff;
  color: #0f1222;
  border-radius: 1.125rem;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  min-height: 6.875rem;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05), 0 18px 38px rgba(13, 59, 102, 0.2);
  display: grid;
  align-content: start;
  gap: 0.5rem;
}
.stat-card__value {
  font-weight: 900;
  color: #2880FD;
  line-height: 1;
  letter-spacing: 0.02em;
  font-size: clamp(2rem, 3.8vw, 3.25rem);
}
.stat-card__label {
  font-size: 0.9375rem;
  line-height: 1.35;
  color: rgba(15, 18, 34, 0.85);
  max-width: 24ch;
}

/* @use — строго наверху */
/* Локальный контейнер 1600px + десктопные гаттеры */
/* ===================================================== */
/* Contacts                                              */
/* ===================================================== */
.contacts {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
  background: #f5f6f8;
  /* локально ограничиваем ширину container--wide до 1600px */
}
.contacts > .container.container--wide {
  --target: 100rem; /* 1600px */
  --gutter: clamp(0px, 2vw, max(0px, calc((100vw - var(--target)) / 2)));
  width: min(var(--target), 100% - var(--gutter) * 2);
  margin-inline: auto;
}
@media (min-width: 75rem) {
  .contacts > .container.container--wide {
    padding-inline: 1.5rem; /* сеточный внутренний отступ */
  }
}
.contacts {
  /* высота карты на разных экранах */
  --map-h: clamp(320px, 36vh, 420px);
}
.contacts__header {
  margin-bottom: clamp(1rem, 2vw, 2.5rem);
}
.contacts__header .section-head__kicker {
  font-size: 0.8125rem;
  line-height: 1.25;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.contacts__header .section-head__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.75rem);
}
.contacts__header .section-head__accent {
  color: #2880FD;
}
.contacts__map {
  position: relative;
  inline-size: 100%;
  block-size: var(--map-h); /* карта подстраивается под эту высоту */
  overflow: hidden;
  background: #e9edf2; /* приятный плейсхолдер до загрузки */
  /* Конструктор вставляет <iframe>. На всякий случай страхуем 100% */
}
.contacts__map iframe {
  inline-size: 100% !important;
  block-size: 100% !important;
  border: 0;
  display: block;
}
@media (max-width: 720px) {
  .contacts {
    --map-h: clamp(340px, 48vh, 520px);
  }
}
.contacts__kicker {
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.contacts__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.12;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.5rem);
}
.contacts__title .contacts__accent {
  color: #2880FD;
}
.contacts {
  /* каркас: 2 колонки на десктопе, одна — на мобильных */
}
.contacts__frame {
  /* если у тебя есть панельный паттерн; иначе можно убрать */
  display: grid;
  grid-template-columns: 7fr 5fr; /* карта 7/12, карточка 5/12 */
  gap: 0;
  align-items: stretch;
}
@media (max-width: 1024px) {
  .contacts__frame {
    grid-template-columns: 1fr;
  }
}
.contacts {
  /* карта без фильтров и обрезки */
}
.contacts__map {
  overflow: hidden;
}
.contacts__map iframe {
  display: block;
  inline-size: 100%;
  block-size: var(--map-h);
  border: 0;
  filter: none;
  background: #e9edf2; /* приятный плейсхолдер на загрузке */
}
.contacts {
  /* карточка с контактами */
}
.contacts__card {
  background: #fff;
  border-radius: 0;
  box-shadow: none;
  padding: clamp(1rem, 2vw, 1.5rem);
  display: grid;
  align-content: start;
  gap: 1rem;
}
@media (max-width: 1024px) {
  .contacts__card {
    border-top: 1px solid rgba(0, 16, 32, 0.06);
  }
}
.contacts__list {
  margin: 0;
}
.contacts__row {
  display: grid;
  grid-template-columns: minmax(120px, 160px) 1fr;
  gap: 0.75rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(0, 16, 32, 0.08);
}
.contacts__row:first-child {
  padding-top: 0;
}
.contacts__row:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}
@media (max-width: 560px) {
  .contacts__row {
    grid-template-columns: 1fr;
    gap: 0.35rem;
  }
}
.contacts__row dt {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.2;
  color: rgba(0, 16, 32, 0.6);
}
.contacts__row dd {
  margin: 0;
  font-size: 1rem;
  line-height: 1.45;
  color: #0f1222;
  word-break: break-word;
}
.contacts__link {
  color: #2880FD;
  text-decoration: none;
  font-weight: 700;
}
.contacts__link:hover {
  text-decoration: underline;
}
.contacts__link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}

/* @use — строго наверху */
.section {
  padding: clamp(2.5rem, 3vw, 4rem) 0;
}

.section--dark {
  padding: 0;
  background: #2e2f31;
  color: #ffffff;
}

.section-head {
  margin-bottom: clamp(1.25rem, 2vw, 3rem);
}
.section-head .section-head__kicker {
  font-size: 0.8125rem;
  line-height: 1.25;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  margin: 0 0 0.5rem;
}
.section-head .section-head__title {
  margin: 0;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.6rem, 2.2vw + 0.6rem, 2.75rem);
}
.section-head .section-head__accent {
  color: #2880FD;
}

/* src/styles/pages/_brands.scss */
/* @use — строго наверху */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding-inline: 1.25rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(42, 86, 163, 0.6);
  background: #ffffff;
  color: #1e1e1e;
  text-align: center;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.1875rem rgba(13, 59, 102, 0.35);
}
.btn--outline {
  background: transparent;
  color: #a6c2ff;
  border-color: #335db0;
}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9tYWluLnNjc3MiLCIuLi8uLi8uLi8uLi8uLi8uLi92aXRlL3NyYy9zdHlsZXMvYWJzdHJhY3RzL192YXJpYWJsZXMuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9hYnN0cmFjdHMvX21peGlucy5zY3NzIiwiLi4vLi4vLi4vLi4vLi4vLi4vdml0ZS9zcmMvc3R5bGVzL2Jhc2UvX2Jhc2Uuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9iYXNlL19mb250cy5zY3NzIiwiLi4vLi4vLi4vLi4vLi4vLi4vdml0ZS9zcmMvc3R5bGVzL2NvbXBvbmVudHMvX2hlYWRlci5zY3NzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbm9kZV9tb2R1bGVzL0BzcGxpZGVqcy9zcGxpZGUvZGlzdC9jc3Mvc3BsaWRlLWNvcmUubWluLmNzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9jb21wb25lbnRzL19hZ3JlZW1lbnQuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9jb21wb25lbnRzL19mb290ZXIuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYWdlcy9faGVyby5zY3NzIiwiLi4vLi4vLi4vLi4vLi4vLi4vdml0ZS9zcmMvc3R5bGVzL3BhZ2VzL19zZXJpZXMuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYXR0ZXJucy9fY2FyZC5zY3NzIiwiLi4vLi4vLi4vLi4vLi4vLi4vdml0ZS9zcmMvc3R5bGVzL3BhZ2VzL19hc3Npc3Quc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYWdlcy9fYnJhbmRzLnNjc3MiLCIuLi8uLi8uLi8uLi8uLi8uLi92aXRlL3NyYy9zdHlsZXMvcGF0dGVybnMvX2dyaWQtdGFibGUuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYWdlcy9fcHJvZHVjdHMuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy91dGlsaXRpZXMvX2dyaWQuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYWdlcy9fYmVuZWZpdHMuc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYWdlcy9fcmV2aWV3cy5zY3NzIiwiLi4vLi4vLi4vLi4vLi4vLi4vdml0ZS9zcmMvc3R5bGVzL3BhZ2VzL19jbGllbnRzLnNjc3MiLCIuLi8uLi8uLi8uLi8uLi8uLi92aXRlL3NyYy9zdHlsZXMvcGFnZXMvX3N0YXRzLnNjc3MiLCIuLi8uLi8uLi8uLi8uLi8uLi92aXRlL3NyYy9zdHlsZXMvcGFnZXMvX2NvbnRhY3RzLnNjc3MiLCIuLi8uLi8uLi8uLi8uLi8uLi92aXRlL3NyYy9zdHlsZXMvcGF0dGVybnMvX3NlY3Rpb24uc2NzcyIsIi4uLy4uLy4uLy4uLy4uLy4uL3ZpdGUvc3JjL3N0eWxlcy9wYXR0ZXJucy9fYnV0dG9uLnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBaUNRO0FDakNSO0FBQ0E7QUFNQTtBQUtBO0FBYUE7QUFTQTtBQVVBO0FBU0E7QUFLQTtBQUdBO0FBS0E7QUFRQTtBQUlBO0FBS0E7QUFnQ0E7QUFTQTtBQUlBO0FBYUE7QUFDQTtFQUNFO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTs7O0FEdkpGO0FFS0E7QUFtQkE7QUFtQkE7QUErQ0E7QUFxQkE7QUFFQTtBQVFBO0FBdUJBO0FBU0E7QUFRQTtBRjdKQTtBQUpBO0FHQUE7QUFJQTtBQUNBO0FBQ0E7RUFDRTs7O0FBR0Y7QUFDQTtFQUNFOzs7QUFHRjtBQUNBO0VBQ0U7RUFDQTtFQUNBO0VBQ0E7RUFDQTtBQUNBO0VBQ0E7OztBQUdGO0VBQ0U7RUFDQTtFQUNBLGFGaUNpQjtFRWhDakIsV0ZpQ2U7RUVoQ2YsYUZpQ2lC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 */