/* ============================================
   SECTIONS — Секции страницы
   ============================================
   Каждая секция определяет локальные переменные
   на своём корневом селекторе. Дочерние элементы
   ссылаются только на них. Глобальные токены
   используются как значения по умолчанию.
   ============================================ */


/* ────────────────────────────────────────────
   Header — Шапка
   ──────────────────────────────────────────── */
.header {
  /* — Локальные переменные — */
  --header-bg: var(--color-grey-light);
  --header-padding-top: 30px;
  --header-divider-color: var(--color-grey);
  --nav-link-size: 13px;
  --nav-link-weight: var(--font-weight-normal);
  --nav-link-color: var(--color-text-muted);
  --nav-link-hover-color: var(--color-link-hover);

  /* — Стили — */
  width: 100%;
  background-color: var(--header-bg);
  padding-top: var(--header-padding-top);
  padding-bottom: 0;
  
  /* Sticky позиционирование */
  position: sticky;
  top: 0;
  z-index: 100;
  transition: box-shadow 0.3s ease;
}

/* Тень при скролле (добавляется через JS) */
.header--scrolled {
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-lg);
  position: relative; /* Для позиционирования логотипа по центру на мобилке */
}

.header__bullets {
  /* Контейнер для буллетов - всегда справа */
  flex-shrink: 0;
}

.header__divider {
  width: 100%;
  height: 1px;
  background-color: var(--header-divider-color);
  margin-top: var(--spacing-lg);
}


/* ────────────────────────────────────────────
   Hero — Главный экран
   ──────────────────────────────────────────── */
.hero {
  /* — Фон и геометрия секции — */
  --hero-bg: var(--color-grey-light);
  --hero-max-height: 770px;
  --hero-radius: 0 0 70px 70px;
  --hero-padding-top: var(--spacing-2xl);
  --hero-padding-bottom: var(--spacing-4xl);
  --hero-margin-bottom: var(--spacing-zero);

  /* — Контент — */
  --hero-content-min-height: 600px;

  /* — Заголовок — */
  --hero-title-font: var(--font-heading);
  --hero-title-size: var(--font-size-6xl);
  --hero-title-weight: var(--font-weight-semibold);
  --hero-title-color: var(--color-black);
  --hero-title-line-height: 1.1;

  /* — Модель (правый верхний угол) — */
  --hero-model-size: var(--font-size-base);
  --hero-model-weight: var(--font-weight-bold);
  --hero-model-color: var(--color-black);
  --hero-model-padding-top: 23px;

  /* — Лейбл — */
  --hero-label-size: var(--font-size-sm);
  --hero-label-weight: var(--font-weight-bold);
  --hero-label-color: var(--color-black);
  --hero-label-padding-left: 7px;

  /* — Блок info (справа: подзаголовок + описание + кнопка) — */
  --hero-info-top: 125px;
  --hero-info-margin-end: 130px;
  --hero-info-max-width: 450px;
  --hero-info-gap: var(--spacing-xl);

  /* — Подзаголовок — */
  --hero-subtitle-font: var(--font-heading);
  --hero-subtitle-size: var(--font-size-4xl-plus);
  --hero-subtitle-weight: var(--font-weight-light);
  --hero-subtitle-color: var(--color-black);
  --hero-subtitle-margin-top: 50px;

  /* — Описание — */
  --hero-desc-size: var(--font-size-base);
  --hero-desc-color: var(--color-text);

  /* — Ёмкость — */
  --hero-capacity-size: var(--font-size-base);
  --hero-capacity-weight: var(--font-weight-bold);
  --hero-capacity-color: var(--color-black);

  /* — Батарейка (круг + изображение) — */
  --hero-battery-top: 130px;
  --hero-battery-left: 22%;
  --hero-battery-size: 480px;
  --hero-battery-image-max-width: 110px;
  --hero-battery-circle-bg: rgba(217, 217, 217, 0.3);

  /* — Форма ввода кода — */
  --hero-form-bg: var(--color-white);
  --hero-form-radius: var(--radius-xl);
  --hero-form-shadow: var(--shadow-lg);
  --hero-form-margin-top: 20px;
  --hero-form-padding-y: 45px;
  --hero-form-padding-x: 45px;
  --hero-form-title-size: var(--font-size-lg);
  --hero-form-title-weight: var(--font-weight-semibold);
  --hero-form-title-color: var(--color-text);
  --hero-form-input-max-width: 500px;

  /* — Стили секции — */
  width: 100%;
  max-height: var(--hero-max-height);
  background-color: var(--hero-bg);
  border-radius: var(--hero-radius);
  padding: var(--hero-padding-top) 0 var(--hero-padding-bottom);
  margin-bottom: var(--hero-margin-bottom);
  position: relative;
}

.hero__content {
  position: relative;
  min-height: var(--hero-content-min-height);
  display: flex;
  flex-direction: column;
}

.hero__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  gap: var(--spacing-lg);
}

.hero__title {
  font-family: var(--hero-title-font);
  font-size: var(--hero-title-size);
  font-weight: var(--hero-title-weight);
  color: var(--hero-title-color);
  line-height: var(--hero-title-line-height);
  margin: 0;
  white-space: nowrap;
}

.hero__model {
  font-size: var(--hero-model-size);
  font-weight: var(--hero-model-weight);
  color: var(--hero-model-color);
  white-space: nowrap;
  padding-top: var(--hero-model-padding-top);
  flex-shrink: 0;
}

.hero__label {
  font-size: var(--hero-label-size);
  font-weight: var(--hero-label-weight);
  color: var(--hero-label-color);
  margin-top: var(--spacing-xs);
  padding-left: var(--hero-label-padding-left);
}

.hero__info {
  position: absolute;
  right: 60px;
  margin-inline-end: var(--hero-info-margin-end);
  top: var(--hero-info-top);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--hero-info-gap);
  max-width: var(--hero-info-max-width);
}

.hero__subtitle {
  font-family: var(--hero-subtitle-font);
  font-size: var(--hero-subtitle-size);
  font-weight: var(--hero-subtitle-weight);
  color: var(--hero-subtitle-color);
  line-height: var(--hero-title-line-height);
  margin: var(--hero-subtitle-margin-top) 0 0;
  white-space: nowrap;
}

.hero__description {
  font-size: var(--hero-desc-size);
  line-height: var(--line-height-relaxed);
  color: var(--hero-desc-color);
  margin: 0;
}

.hero__capacity {
  font-size: var(--hero-capacity-size);
  font-weight: var(--hero-capacity-weight);
  color: var(--hero-capacity-color);
  margin-top: auto;
  align-self: flex-end;
}

.hero__battery {
  position: absolute;
  top: var(--hero-battery-top);
  left: var(--hero-battery-left);
  transform: translateX(-50%);
  width: var(--hero-battery-size);
  height: var(--hero-battery-size);
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero__battery::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: var(--hero-battery-circle-bg);
  border-radius: 50%;
  z-index: 0;
  display: none; /* Скрываем круг, так как он не нужен в дизайне */
}

.hero__battery-image {
  position: relative;
  max-width: var(--hero-battery-image-max-width);
  height: auto;
  z-index: 2;
}

.hero__lightning {
  position: absolute;
  width: 95%;
  height: 95%;
  top: 10px;
  left: 10px;
  z-index: 1;
  pointer-events: none;
}

/* Форма ввода кода */
.battery-code-form {
    background-color: var(--hero-form-bg);
    border-radius: var(--hero-form-radius);
    padding: var(--hero-form-padding-y) var(--hero-form-padding-x);
    box-shadow: var(--hero-form-shadow);
    margin-top: var(--hero-form-margin-top);
    position: relative;
    z-index: 10;

}

.battery-code-form__title {
  font-size: var(--hero-form-title-size);
  font-weight: var(--hero-form-title-weight);
  color: var(--hero-form-title-color);
  margin: 0 0 var(--spacing-lg);
  text-align: center;
}

.battery-code-form__input-group {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
  justify-content: center;
}

.battery-code-form__input-group .input {
  flex: 1 1 0%;
  max-width: var(--hero-form-input-max-width);
}

/* Спиннер в кнопке */
.btn__spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: btn-spin 0.8s linear infinite;
}

.btn__spinner[hidden] {
  display: none;
}

@keyframes btn-spin {
  to { transform: rotate(360deg); }
}

/* Сообщение под формой */
.battery-code-form__message {
  margin-top: var(--spacing-md);
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  text-align: center;
}

.battery-code-form__message[hidden] {
  display: none;
}

.battery-code-form__message--error {
  background-color: #fef2f2;
  color: #dc2626;
  border: 1px solid #fecaca;
}

.battery-code-form__message--success {
  background-color: #f0fdf4;
  color: #16a34a;
  border: 1px solid #bbf7d0;
}

/* Карточка результата валидации (стиль feature-item) */
/* ────────────────────────────────────────────
   Battery Code Result — Карточка подтверждения кода
   ──────────────────────────────────────────── */
.battery-code-result {
  margin-top: var(--spacing-xl);
  max-width: 480px;
  padding: var(--spacing-xl);
  border-radius: var(--radius-xl);
  background: var(--color-primary-light);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
  transition: all var(--transition-fast);
  border: 1px solid var(--color-grey);
}

.battery-code-result[hidden] {
  display: none;
}

.battery-code-result__header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid var(--color-grey-light);
}

.battery-code-result__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  color: var(--color-white);
  flex-shrink: 0;
}

.battery-code-result__icon svg {
  width: 18px;
  height: 18px;
}

.battery-code-result__status {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0;
}

.battery-code-result__body {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-md) var(--spacing-xl);
}

.battery-code-result__row {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.battery-code-result__label {
  font-size: var(--font-size-xs);
  color: var(--color-text-light);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.battery-code-result__value {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
}

/* ────────────────────────────────────────────
   Product Info — Информация о продукте
   ──────────────────────────────────────────── */
.product-info {
  /* — Секция — */
  --pi-padding-y: var(--spacing-5xl);
  --pi-margin-top: var(--spacing-4xl);
  --pi-grid-gap: var(--spacing-5xl);

  /* — Лейбл — */
  --pi-label-size: var(--font-size-sm);
  --pi-label-weight: var(--font-weight-semibold);
  --pi-label-color: var(--color-text);
  --pi-label-letter-spacing: 0.5px;

  /* — Заголовок — */
  --pi-title-font: var(--font-heading);
  --pi-title-size: var(--font-size-2xl);
  --pi-title-weight: var(--font-weight-semibold);
  --pi-title-color: var(--color-black);
  --pi-capacity-size: var(--font-size-2xl);

  /* — Блок описания характеристики — */
  --pi-desc-bg: var(--color-grey-light);
  --pi-desc-radius: var(--radius-lg);
  --pi-desc-border-color: var(--color-border-accent);
  --pi-desc-border-width: 4px;
  --pi-desc-min-height: 80px;
  --pi-desc-padding: var(--spacing-lg);

  /* — Текст — */
  --pi-text-size: var(--font-size-base);
  --pi-text-color: var(--color-text);

  /* — Content box (карточка под галереей) — */
  --pi-box-bg: var(--color-white);
  --pi-box-radius: var(--radius-xl);
  --pi-box-shadow: var(--shadow-lg);
  --pi-box-padding-y: var(--spacing-xl);
  --pi-box-padding-x: var(--spacing-2xl);
  --pi-box-margin-top: var(--spacing-3xl);
  --pi-text-gap: var(--spacing-3xl);

  /* — Слоган — */
  --pi-slogan-size: var(--font-size-lg);
  --pi-slogan-color: var(--color-text);
  --pi-slogan-border-color: var(--color-grey-light);
  --pi-slogan-strong-color: var(--color-black);

  /* — Галерея — */
  --pi-gallery-gap: var(--spacing-xl);
  --pi-gallery-margin-top: var(--spacing-3xl);
  --pi-gallery-radius: var(--radius-lg);

  /* — Стили секции — */
  padding: var(--pi-padding-y) 0;
  margin-top: var(--pi-margin-top);

  /* — цвет Hover для feature — */
  --fi-active-bg: var(--color-feature-hover);
}

.product-info__grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--pi-grid-gap);
}

.product-info__header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.product-info__label {
  font-size: var(--pi-label-size);
  font-weight: var(--pi-label-weight);
  color: var(--pi-label-color);
  text-transform: uppercase;
  letter-spacing: var(--pi-label-letter-spacing);
}

.product-info__title {
  font-family: var(--pi-title-font);
  font-size: var(--pi-title-size);
  font-weight: var(--pi-title-weight);
  color: var(--pi-title-color);
  line-height: var(--line-height-tight);
  margin: 0;
  font-style: italic;
}

.product-info__capacity {
  display: block;
  font-size: var(--pi-capacity-size);
  margin-top: var(--spacing-sm);
}

.product-info__description {
  margin-top: var(--spacing-xl);
  padding: var(--pi-desc-padding);
  background-color: var(--pi-desc-bg);
  border-radius: var(--pi-desc-radius);
  border-left: var(--pi-desc-border-width) solid var(--pi-desc-border-color);
  min-height: var(--pi-desc-min-height);
  display: flex;
  align-items: center;
}

.product-info__description p {
  margin: 0;
  font-size: var(--pi-text-size);
  line-height: var(--line-height-relaxed);
  color: var(--pi-text-color);
}

.product-info__features {
  display: flex;
  flex-direction: column;
}

.product-info__content-box {
  background-color: var(--pi-box-bg);
  border-radius: var(--pi-box-radius);
  box-shadow: var(--pi-box-shadow);
  padding: var(--pi-box-padding-y) var(--pi-box-padding-x);
  margin-top: var(--pi-box-margin-top);
}

.product-info__text-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--pi-text-gap);
  margin-bottom: var(--spacing-xl);
}

.product-info__text-column p {
  margin: 0;
  font-size: var(--pi-text-size);
  line-height: var(--line-height-relaxed);
  color: var(--pi-text-color);
}

.product-info__slogan {
  text-align: center;
  font-size: var(--pi-slogan-size);
  line-height: var(--line-height-relaxed);
  color: var(--pi-slogan-color);
  margin: 0;
  padding-top: var(--spacing-xl);
  border-top: 1px solid var(--pi-slogan-border-color);
  font-style: italic;
}

.product-info__slogan strong {
  font-weight: var(--font-weight-bold);
  color: var(--pi-slogan-strong-color);
}

/* ────────────────────────────────────────────
   Specifications — Технические характеристики
   ──────────────────────────────────────────── */
.specs {
    --specs-bg: var(--color-grey-light);
    --specs-padding-y: var(--spacing-4xl);
    --specs-margin-top: var(--spacing-zero);
    --specs-title-font: var(--font-heading);
    --specs-title-size: var(--font-size-3xl);
    --specs-title-weight: var(--font-weight-semibold);
    --specs-title-color: var(--color-black);
    --specs-title-margin-bottom: var(--spacing-lg);
    --specs-note-bg: var(--color-white);
    --specs-note-radius: var(--radius-lg);
    --specs-note-padding: var(--spacing-xl);
    --specs-note-margin-top: var(--spacing-2xl);
    --specs-note-title-weight: var(--font-weight-bold);
    --specs-note-title-color: var(--color-text);
    --specs-note-text-size: var(--font-size-sm);
    --specs-note-text-color: var(--color-text);
    --accordion-item-bg: #f1f1f1;
    --accordion-item-border: var(--color-grey);
    --accordion-header-padding-y: var(--spacing-xl);
    --accordion-header-padding-x: var(--spacing-2xl);
    --accordion-content-padding-y: var(--spacing-lg);
    --accordion-content-padding-x: var(--spacing-2xl);
    width: 100%;
    background-color: var(--specs-bg);
    padding: var(--specs-padding-y) 0;
    margin-top: var(--specs-margin-top);

}

.specs__title {
  font-family: var(--specs-title-font);
  font-size: var(--specs-title-size);
  font-weight: var(--specs-title-weight);
  color: var(--specs-title-color);
  text-align: center;
  margin: 0 0 var(--specs-title-margin-bottom);
  letter-spacing: 2px;
}

.specs__note {
    background-color: var(--specs-note-bg);
    border-radius: var(--specs-note-radius);
    padding: var(--specs-note-padding);
    margin-top: var(--specs-note-margin-top);
    box-shadow: var(--shadow-lg);

}

.specs__note-title {
  font-weight: var(--specs-note-title-weight);
  color: var(--specs-note-title-color);
  margin: 0 0 var(--spacing-sm);
}

.specs__note-list {
  list-style: disc;
  padding-left: var(--spacing-lg);
  margin: 0;
}

.specs__note-list li {
  font-size: var(--specs-note-text-size);
  color: var(--specs-note-text-color);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-xs);
}

.specs__note-list li:last-child {
  margin-bottom: 0;
}

/* ────────────────────────────────────────────
   Manual — Руководство по эксплуатации
   (использует стили .specs + дополнительные)
   ──────────────────────────────────────────── */

.specs__kicker {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-light);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 var(--spacing-sm);
  text-align: center;
}

.specs__subtitle {
  font-size: var(--font-size-base);
  color: var(--color-text-light);
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-lg);
}

.specs__note-footer {
  font-size: var(--font-size-base);
  font-style: italic;
  color: var(--color-text-muted);
  text-align: center;
  margin: 0;
}

/* Список внутри accordion manual */
.manual__list {
  list-style: none;
  margin: 0;
  padding-left: var(--spacing-lg); /* общий отступ списка от края */
}

.manual__list li {
  position: relative;
  text-indent: 1.2em;              /* сдвигает ТОЛЬКО первую строку вправо */
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-sm);
  color: var(--color-text);
  font-size: var(--font-size-base);
}

.manual__list li::before {
  content: "•";
  position: absolute;
  left: -0.765em;                         /* буллет стоит там, где начинается 2-я строка */
  top: -0.06em;                     /* подстройка по вертикали */
  font-size: 1.8em;                /* размер буллета */
  line-height: 1;                  /* чтобы не раздувал межстрочный */
  color: var(--color-primary);
}

.manual__list li:last-child {
  margin-bottom: 0;
}

/* ────────────────────────────────────────────
   FAQ — Часто задаваемые вопросы
   (светлый вариант .specs)
   ──────────────────────────────────────────── */

.faq {
  --specs-bg: var(--color-white);
  --accordion-item-bg: var(--color-white);
  --accordion-item-border: var(--color-grey);
}

.faq__question {
  margin-bottom: var(--spacing-lg);
}

.faq__question:last-child {
  margin-bottom: 0;
}

.faq__question-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--spacing-sm);
  line-height: var(--line-height-base);
  padding-left: var(--spacing-md);
  position: relative;
}

.faq__question-title::before {
  content: '•';
  position: absolute;
  left: -2px;
  color: var(--color-primary);
  font-size: 1.8em;
  top: -12px;
}

.faq__answer {
  font-size: var(--font-size-base);
  color: var(--color-text);
  line-height: var(--line-height-relaxed);
  margin: 0;
}

/* Ссылки на другие модели */
.manual__link {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: var(--font-weight-medium);
  transition: color var(--transition-fast);
}

.manual__link:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

/* ────────────────────────────────────────────
   Footer — Подвал
   ──────────────────────────────────────────── */
.footer {
  /* — Локальные переменные — */
  --footer-bg: var(--color-grey-light);
  --footer-margin-top: 150px;
  --footer-padding-top: var(--spacing-3xl);
  --footer-padding-bottom: var(--spacing-lg);
  --footer-divider-color: var(--color-grey);
  --footer-title-size: var(--font-size-sm);
  --footer-title-weight: var(--font-weight-semibold);
  --footer-title-color: var(--color-text);
  --footer-title-margin-bottom: var(--spacing-sm);
  --footer-title-transform: none;
  --footer-link-size: var(--font-size-sm);
  --footer-link-weight: var(--font-weight-normal);
  --footer-link-color: var(--color-text-muted);
  --footer-link-hover-color: var(--color-link-hover);
  --footer-contact-weight: var(--font-weight-medium);
  --footer-contact-color: var(--color-text);
  --footer-bottom-size: var(--font-size-xs);
  --footer-bottom-color: var(--color-text-muted);

  /* — Стили — */
  padding: var(--footer-padding-top) 0 var(--footer-padding-bottom);
  background-color: var(--footer-bg);
  margin-top: var(--footer-margin-top);
}

.footer__main {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--spacing-3xl);
  margin-bottom: var(--spacing-xl);
}

.footer__col {
  /* display: flex; */
  flex-direction: column;
  gap: var(--spacing-md);
}

.footer__col--brand {
  gap: var(--spacing-lg);
}

.footer__company {
  font-size: var(--footer-link-size);
  color: var(--footer-link-color);
  margin-top: var(--spacing-sm);
}

.footer__battery-selector {
  margin-top: var(--spacing-lg);
}

.footer__title {
  font-size: var(--footer-title-size);
  font-weight: var(--footer-title-weight);
  color: var(--footer-title-color);
  margin-bottom: var(--footer-title-margin-bottom);
  text-transform: var(--footer-title-transform);
}

.footer__subtitle {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  margin-bottom: var(--spacing-xs);
  margin-top: var(--spacing-md);
}

.footer__subtitle:first-of-type {
  margin-top: 0;
}

/* ═══════════════════════════════════════════
   АККОРДЕОН ФУТЕРА (мобильные)
   Простой, быстрый, как основной аккордеон
   ═══════════════════════════════════════════ */

/* Футер в режиме аккордеона */
.footer--accordion .footer__col {
  border-bottom: 1px solid var(--color-border-light, #e5e5e5);
  padding: 0;
  margin-bottom: 0;
}

.footer--accordion .footer__col:last-child {
  border-bottom: none;
}

/* Заголовок-кнопка аккордеона */
.footer--accordion .footer__title {
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  transition: color var(--transition-fast);
}

.footer--accordion .footer__title:hover {
  color: var(--color-primary);
}

/* Иконка стрелки */
.footer--accordion .footer__title::after {
  content: '';
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9L12 15L18 9' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  transition: transform var(--transition-base);
}

/* Активный блок: стрелка повёрнута */
.footer--accordion .footer__col.active .footer__title::after {
  transform: rotate(180deg);
}

.footer--accordion .footer__col.active .footer__title {
  color: var(--color-primary);
}

/* Контент аккордеона — скрыт по умолчанию */
.footer--accordion .footer__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}

/* Активный блок: контент раскрыт */
.footer--accordion .footer__col.active .footer__content {
  max-height: 500px; /* достаточно для любого контента */
}

/* Внутренний отступ контента */
.footer--accordion .footer__content-inner {
  padding: 0 0 16px 0;
  margin-left: 12px;
}

/* Списки в аккордеоне */
.footer--accordion .footer__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer--accordion .footer__list li {
  margin: 0;
}

.footer--accordion .footer__list .footer__link {
  display: block;
  padding: 10px 0;
  color: var(--color-text-light);
  transition: color var(--transition-fast);
}

.footer--accordion .footer__list .footer__link:hover {
  color: var(--color-primary);
}

/* Контакты */
.footer--accordion .footer__contact {
  padding: 8px 0;
  margin-bottom: 0;
}

/* Нижний блок — не аккордеон */
.footer--accordion .footer__divider {
  margin: var(--spacing-lg) 0;
}

.footer--accordion .footer__bottom {
  padding: var(--spacing-md) 0;
  border: none;
}

/* Соцсети */
.footer--accordion .footer__social-link {
  display: flex;
  align-items: center;
  padding: 10px 0;
  transition: color var(--transition-fast);
}

.footer--accordion .footer__social-link:hover {
  color: var(--color-primary);
}

/* Батарейки */
.footer--accordion .footer__battery-selector {
  margin-top: 0;
}

.footer--accordion .battery-bullets__item {
  padding: 10px 0;
  margin: 0;
}

/* Подзаголовки */
.footer--accordion .footer__subtitle {
  margin-top: var(--spacing-sm);
  margin-bottom: var(--spacing-xs);
}

.footer__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.footer__link {
  display: inline-block;
  font-size: var(--footer-link-size);
  font-weight: var(--footer-link-weight);
  color: var(--footer-link-color);
  transition: color var(--transition-fast);
}

.footer__link:hover {
  color: var(--footer-link-hover-color);
}

.footer__link--contact {
  font-weight: var(--footer-contact-weight);
  color: var(--footer-contact-color);
}

.footer__link--secondary {
  color: var(--color-text-light);
}

.footer__contact {
    margin-bottom: var(--spacing-xs);

}

.footer__contact--company {
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-lg);
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);

}

.footer__contact:last-child {
  margin-bottom: 0;
}

.footer__social-link {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.footer__social-icon {
  width: 20px;
  height: 20px;
  display: inline-block;
  vertical-align: middle;
  transition: transform var(--transition-fast);
  margin-right: 5px;
}

.footer__social-link:hover .footer__social-icon {
  transform: scale(1.1);
}

/* Неактивные соцсети (active: false) */
.footer__social-link--inactive {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.footer__social-link--inactive .footer__social-icon {
  filter: grayscale(100%);
}

.footer__social-text {
  display: inline-block;
}

.footer__divider {
  width: 100%;
  height: 1px;
  background-color: var(--footer-divider-color);
  margin-bottom: var(--spacing-lg);
}

.footer__bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
  font-size: var(--footer-bottom-size);
  color: var(--footer-bottom-color);
  text-align: center;
}

.footer__copyright,
.footer__credits {
  margin: 0;
}


/* ────────────────────────────────────────────
   Charts — Графики разряда
   ──────────────────────────────────────────── */
.charts {
  /* — Локальные переменные — */
  --charts-padding-y: var(--spacing-4xl);
  --charts-bg: var(--color-white);
  
  /* — Заголовок секции — */
  --charts-header-margin-bottom: 24px;
  --charts-header-gap-kicker-title: 16px;
  
  --charts-kicker-font: var(--font-primary);
  --charts-kicker-size: var(--font-size-lg);
  --charts-kicker-weight: var(--font-weight-normal);
  --charts-kicker-color: var(--color-text-light);
  --charts-kicker-letter-spacing: 0.1em;
  
  --charts-title-font: var(--font-heading);
  --charts-title-size: 40px;
  --charts-title-weight: var(--font-weight-bold);
  --charts-title-color: var(--color-black);
  
  --charts-description-font: var(--font-primary);
  --charts-description-size: var(--font-size-base);
  --charts-description-weight: var(--font-weight-normal);
  --charts-description-color: var(--color-text-light);
  --charts-description-margin-top: 12px;
  --charts-description-padding-bottom: 12px;

  /* — Стили — */
  padding: var(--charts-padding-y) 0;
  background-color: var(--charts-bg);
}

.charts__header {
  text-align: center;
  margin-bottom: var(--charts-header-margin-bottom);
}

.charts__header:empty {
  display: none;
}

.charts__kicker {
  font-family: var(--charts-kicker-font);
  font-size: var(--charts-kicker-size);
  font-weight: var(--charts-kicker-weight);
  color: var(--charts-kicker-color);
  letter-spacing: var(--charts-kicker-letter-spacing);
  text-transform: uppercase;
  margin-bottom: var(--charts-header-gap-kicker-title);
}

.charts__title {
  font-family: var(--charts-title-font);
  font-size: var(--charts-title-size);
  font-weight: var(--charts-title-weight);
  color: var(--charts-title-color);
  margin: 0;
  text-transform: uppercase;
}

.charts__description {
  font-family: var(--charts-description-font);
  font-size: var(--charts-description-size);
  font-weight: var(--charts-description-weight);
  color: var(--charts-description-color);
  margin: var(--charts-description-margin-top) 0 0;
  padding-bottom: var(--charts-description-padding-bottom);
}

.charts__wrapper {
  width: 100%;
  max-width: var(--container-max-width);
  margin: 0 auto;
  position: relative;
  padding-top: 40px; /* Отступ для переключателя */
  
  /* ━━━ Настройка позиции tooltip координат ━━━ */
  /* По умолчанию: по центру под графиком, раскомментируй для настройки */
  
  /* --chart-tooltip-top: 100%; */          /* 100% = под графиком */
  /* --chart-tooltip-left: 50%; */          /* 50% = по центру */
  /* --chart-tooltip-translate-x: -50%; */  /* -50% = центрирование */
  /* --chart-tooltip-margin-top: 16px; */   /* отступ вниз */
  
  /* Примеры: */
  /* Слева под графиком: */
  /* --chart-tooltip-left: 0; --chart-tooltip-translate-x: 0; */
  
  /* Справа под графиком: */
  /* --chart-tooltip-left: 100%; --chart-tooltip-translate-x: -100%; */
}

.charts__discharge {
  width: 100%;
  justify-content: center;
  display: flex;
  /* box-shadow: var(--shadow-lg);
  padding: 30px 0 30px 0; */
}

.charts__discharge svg {
  width: 85%;
  height: auto;
  display: block;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Chart Mode Toggle — Переключатель режимов
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.chart-mode-toggle {
  /* — Локальные переменные — */
  --toggle-bg: var(--color-grey-light);
  --toggle-active-bg: var(--color-white);
  --toggle-text: var(--color-text-light);
  --toggle-text-active: var(--color-text);
  --toggle-padding: 4px;
  --toggle-gap: 4px;
  --toggle-radius: var(--radius-md);
  --toggle-font-size: 15px;
  --toggle-font-weight: 700;
  --toggle-btn-padding: 8px 20px;
  
  /* — Позиционирование — */
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  
  /* — Стили — */
  display: inline-flex;
  gap: var(--toggle-gap);
  background: var(--toggle-bg);
  border-radius: var(--toggle-radius);
  padding: var(--toggle-padding);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05);
}

.chart-mode-toggle__btn {
  /* font-family: 'JetBrains Mono', 'Roboto Mono', monospace; */
  font-size: var(--toggle-font-size);
  font-weight: var(--toggle-font-weight);
  padding: var(--toggle-btn-padding);
  border: none;
  background: transparent;
  color: var(--toggle-text);
  border-radius: calc(var(--toggle-radius) - var(--toggle-padding));
  cursor: pointer;
  transition: all var(--transition-base);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  min-width: 48px;
  text-align: center;
}

.chart-mode-toggle__btn:hover:not(.chart-mode-toggle__btn--active) {
  color: var(--toggle-text-active);
  background: rgba(255, 255, 255, 0.4);
}

.chart-mode-toggle__btn--active {
  background: var(--toggle-active-bg);
  color: var(--toggle-text-active);
  box-shadow: var(--shadow-sm);
  cursor: default;
}

.chart-mode-toggle__btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Адаптивность */
@media (max-width: 768px) {
  .chart-mode-toggle {
    top: -25px;
    --toggle-font-size: 14px;
    --toggle-btn-padding: 6px 16px;
  }
}

/* Адаптивность заголовков секции графиков */
@media (max-width: 1024px) {
  .charts {
    --charts-title-size: 32px;
  }
}

@media (max-width: 768px) {
  .charts {
    --charts-header-margin-bottom: 32px;
    --charts-title-size: 28px;
    --charts-description-size: var(--font-size-sm);
  }
}

@media (max-width: 480px) {
  .charts {
    --charts-header-margin-bottom: 24px;
    --charts-title-size: 24px;
    --charts-kicker-size: var(--font-size-base);
    --charts-description-size: var(--font-size-xs-plus);
    --charts-description-margin-top: 8px;
  }
}



/* ══════════════════════════════════════════════
   Devices V2 — Поддерживаемые устройства (меню + карточка)
   ══════════════════════════════════════════════ */
.devices-v2 {
  /* — Общие — */
  --dv2-padding-y: var(--spacing-4xl);
  --dv2-bg: var(--color-grey-light);
  
  /* — Заголовок секции — */
  --dv2-header-margin-bottom: 48px;
  --dv2-header-gap-kicker-title: 16px;
  --dv2-header-gap-title-description: 24px;
  
  --dv2-kicker-font: var(--font-primary);
  --dv2-kicker-size: var(--font-size-lg);
  --dv2-kicker-weight: var(--font-weight-normal);
  --dv2-kicker-color: var(--color-text-light);
  --dv2-kicker-letter-spacing: 0.1em;
  
  --dv2-title-font: var(--font-heading);
  --dv2-title-size: 40px;
  --dv2-title-weight: var(--font-weight-bold);
  --dv2-title-color: var(--color-black);
  
  --dv2-description-font: var(--font-primary);
  --dv2-description-size: var(--font-size-lg);
  --dv2-description-weight: var(--font-weight-normal);
  --dv2-description-color: var(--color-text-light);
  --dv2-description-line-height: 1.6;
  --dv2-description-max-width: 800px;
  
  /* — Wrapper (меню + карточка) — */
  --dv2-gap: 40px;
  --dv2-menu-width: 280px;
  
  /* — Меню категорий — */
  --dv2-menu-bg: transparent;
  --dv2-menu-item-padding: 14px 20px;
  --dv2-menu-item-font: var(--font-primary);
  --dv2-menu-item-size: var(--font-size-base);
  --dv2-menu-item-weight: var(--font-weight-medium);
  --dv2-menu-item-color: var(--color-text);
  --dv2-menu-item-radius: var(--radius-md);
  --dv2-menu-item-hover-bg: var(--color-white);
  --dv2-menu-active-bg: var(--color-white);
  --dv2-menu-active-color: var(--color-primary);
  --dv2-menu-active-border: var(--color-primary);
  --dv2-menu-gap: 8px;
  
  /* — Карточка контента — */
  --dv2-card-bg: var(--color-white);
  --dv2-card-radius: var(--radius-lg);
  --dv2-card-padding: 40px;
  --dv2-card-shadow: -2px 0px 28.2px -11px rgba(0, 0, 0, 0.3);
  
  /* — Сетка плиток — */
  --dv2-grid-columns: 3;
  --dv2-grid-gap-x: 24px;
  --dv2-grid-gap-y: 32px;
  
  /* — Плитка — */
  --dv2-tile-padding: 24px 16px;
  --dv2-tile-bg: var(--color-grey-light);
  --dv2-tile-radius: var(--radius-md);
  --dv2-tile-gap: 12px;
  --dv2-tile-hover-bg: var(--color-white);
  --dv2-tile-hover-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  
  /* — Иконка в плитке — */
  --dv2-icon-size: 48px;
  --dv2-icon-color: var(--color-primary);
  
  /* — Заголовок плитки — */
  --dv2-tile-title-font: var(--font-primary);
  --dv2-tile-title-size: var(--font-size-base);
  --dv2-tile-title-weight: var(--font-weight-semibold);
  --dv2-tile-title-color: var(--color-text);
  
  /* — Описание плитки — */
  --dv2-tile-desc-font: var(--font-primary);
  --dv2-tile-desc-size: var(--font-size-sm);
  --dv2-tile-desc-weight: var(--font-weight-normal);
  --dv2-tile-desc-color: var(--color-text-light);
  --dv2-tile-desc-line-height: 1.4;
  
  /* — Применяем стили — */
  padding: var(--dv2-padding-y) 0;
  background-color: var(--dv2-bg);
}

/* Скрываем секцию если пустая или нет данных */
.devices-v2:empty,
.devices-v2[hidden],
.devices-v2 .container:empty {
  display: none;
}

/* ── Заголовок секции ───────────────────── */
.devices-v2__header {
  text-align: center;
  margin-bottom: var(--dv2-header-margin-bottom);
}

.devices-v2__header:empty {
  display: none;
}

.devices-v2__kicker {
  font-family: var(--dv2-kicker-font);
  font-size: var(--dv2-kicker-size);
  font-weight: var(--dv2-kicker-weight);
  color: var(--dv2-kicker-color);
  letter-spacing: var(--dv2-kicker-letter-spacing);
  text-transform: uppercase;
  margin-bottom: var(--dv2-header-gap-kicker-title);
}

.devices-v2__title {
  font-family: var(--dv2-title-font);
  font-size: var(--dv2-title-size);
  font-weight: var(--dv2-title-weight);
  color: var(--dv2-title-color);
  margin: 0 0 var(--dv2-header-gap-title-description) 0;
  text-transform: uppercase;
}

.devices-v2__description {
  font-family: var(--dv2-description-font);
  font-size: var(--dv2-description-size);
  font-weight: var(--dv2-description-weight);
  color: var(--dv2-description-color);
  line-height: var(--dv2-description-line-height);
  max-width: var(--dv2-description-max-width);
  margin: 0 auto;
}

/* ── Обёртка: меню слева, карточка справа ─── */
.devices-v2__wrapper {
  display: flex;
  gap: var(--dv2-gap);
  align-items: flex-start;
}

/* ── Меню категорий (левая колонка) ───────── */
.devices-v2__menu {
  flex-shrink: 0;
  width: var(--dv2-menu-width);
  display: flex;
  flex-direction: column;
  gap: var(--dv2-menu-gap);
  background: var(--dv2-menu-bg);
}

.devices-v2__menu-item {
  display: block;
  padding: var(--dv2-menu-item-padding);
  font-family: var(--dv2-menu-item-font);
  font-size: var(--dv2-menu-item-size);
  font-weight: var(--dv2-menu-item-weight);
  color: var(--dv2-menu-item-color);
  text-decoration: none;
  border-radius: var(--dv2-menu-item-radius);
  border: 2px solid transparent;
  background: transparent;
  cursor: pointer;
  text-align: left;
  transition: 
    background-color var(--transition-base),
    color var(--transition-base),
    border-color var(--transition-base);
}

.devices-v2__menu-item:hover {
  background: var(--dv2-menu-item-hover-bg);
}

.devices-v2__menu-item.is-active {
  background: var(--dv2-menu-active-bg);
  color: var(--dv2-menu-active-color);
  border-color: var(--dv2-menu-active-border);
}

/* ── Карточка контента (правая колонка) ───── */
.devices-v2__content {
  flex: 1;
  min-width: 0;
  background: var(--dv2-card-bg);
  border-radius: var(--dv2-card-radius);
  padding: var(--dv2-card-padding);
  box-shadow: var(--dv2-card-shadow);
}

/* ── Сетка плиток ─────────────────────────── */
.devices-v2__grid {
  display: grid;
  grid-template-columns: repeat(var(--dv2-grid-columns), 1fr);
  gap: var(--dv2-grid-gap-y) var(--dv2-grid-gap-x);
}

/* ── Плитка устройства ────────────────────── */
.devices-v2__tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--dv2-tile-gap);
  padding: var(--dv2-tile-padding);
  background: var(--dv2-tile-bg);
  border-radius: var(--dv2-tile-radius);
  /* Плавная анимация без дёргания */
  transform: translateY(0);
  will-change: transform, box-shadow;
  transition: 
    background-color 200ms ease-out,
    box-shadow 200ms ease-out,
    transform 200ms ease-out;
}

.devices-v2__tile:hover {
  background: var(--dv2-tile-hover-bg);
  box-shadow: var(--dv2-tile-hover-shadow);
  transform: translateY(-2px);
}

/* ── Иконка ───────────────────────────────── */
.devices-v2__icon {
  width: var(--dv2-icon-size);
  height: var(--dv2-icon-size);
  color: var(--dv2-icon-color);
  display: flex;
  align-items: center;
  justify-content: center;
}

.devices-v2__icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor !important;
}

.devices-v2__icon svg path,
.devices-v2__icon svg g,
.devices-v2__icon svg circle,
.devices-v2__icon svg rect,
.devices-v2__icon svg polygon {
  fill: inherit !important;
}

/* ── Текст плитки ─────────────────────────── */
.devices-v2__tile-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.devices-v2__tile-title {
  font-family: var(--dv2-tile-title-font);
  font-size: var(--dv2-tile-title-size);
  font-weight: var(--dv2-tile-title-weight);
  color: var(--dv2-tile-title-color);
  margin: 0;
}

.devices-v2__tile-desc {
  font-family: var(--dv2-tile-desc-font);
  font-size: var(--dv2-tile-desc-size);
  font-weight: var(--dv2-tile-desc-weight);
  color: var(--dv2-tile-desc-color);
  line-height: var(--dv2-tile-desc-line-height);
  margin: 0;
}

/* ── Предупреждение (Warning) ──────────────── */
.devices-v2__tile.has-warning {
  position: relative;
}

.devices-v2__warning {
  position: absolute;
  top: 8px;
  right: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  z-index: 2;
}

.devices-v2__warning-icon {
  width: 100%;
  height: 100%;
  color: #FFC800;
  filter: drop-shadow(0 3px 3px rgba(0, 0, 0, 0.3));
  transition: transform 200ms ease-out;
}

.devices-v2__tile:hover .devices-v2__warning-icon {
  transform: scale(1.1);
}

/* ── Tooltip (Подсказка) ───────────────────── */
.devices-v2__tooltip {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-tooltip-bg);
  color: #fff;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 13px;
  line-height: 1.4;
  max-width: 350px;
  width: max-content;
  text-align: left;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 200ms ease-out, visibility 200ms ease-out;
  z-index: 10;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Стрелка tooltip */
.devices-v2__tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: rgba(0, 0, 0, 0.9);
}

/* Показываем tooltip при наведении */
.devices-v2__tile.has-warning:hover .devices-v2__tooltip {
  opacity: 1;
  visibility: visible;
}

/* ══════════════════════════════════════════════
   Devices V2 — Адаптивность
   ══════════════════════════════════════════════ */

/* Планшет (landscape) — меню уже сверху */
@media (max-width: 1200px) {
  .devices-v2 {
    --dv2-gap: 24px;
    --dv2-card-padding: 32px;
    --dv2-grid-columns: 3;
    --dv2-title-size: 36px;
  }
  
  /* Меню сверху */
  .devices-v2__wrapper {
    flex-direction: column;
    gap: 24px;
  }
  
  /* ВАРИАНТ 2: Меню плиткой (все видны) */
  .devices-v2__menu {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 12px;
  }
  
  .devices-v2__menu-item {
    text-align: center;
    padding: 12px 16px;
    white-space: nowrap;
  }
  
  /* ВАРИАНТ 1: Горизонтальный скролл с градиентом (закомментирован)
  .devices-v2__menu {
    position: relative;
    width: 100%;
    flex-direction: row;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    gap: 8px;
    mask-image: linear-gradient(
      to right, 
      black 0%, 
      black calc(100% - 60px), 
      transparent 100%
    );
    -webkit-mask-image: linear-gradient(
      to right, 
      black 0%, 
      black calc(100% - 60px), 
      transparent 100%
    );
  }
  
  .devices-v2__menu::-webkit-scrollbar {
    height: 4px;
  }
  
  .devices-v2__menu::-webkit-scrollbar-track {
    background: transparent;
  }
  
  .devices-v2__menu::-webkit-scrollbar-thumb {
    background: var(--color-primary);
    border-radius: 2px;
    opacity: 0.5;
  }
  
  .devices-v2__menu-item {
    flex-shrink: 0;
    white-space: nowrap;
    padding: 12px 20px;
  }
  */
}

/* Планшет (portrait) */
@media (max-width: 1024px) {
  .devices-v2 {
    --dv2-card-padding: 28px;
    --dv2-grid-columns: 3;
    --dv2-title-size: 32px;
  }
}

/* Маленький планшет / большой телефон — АККОРДЕОН */
@media (max-width: 768px) {
  .devices-v2 {
    --dv2-padding-y: var(--spacing-3xl);
    --dv2-header-margin-bottom: 32px;
    --dv2-title-size: 28px;
    --dv2-card-padding: 24px;
    --dv2-grid-columns: 2;
    --dv2-grid-gap-x: 16px;
    --dv2-grid-gap-y: 24px;
    --dv2-tile-padding: 20px 12px;
    --dv2-icon-size: 40px;
  }
  
  /* Меню становится вертикальным списком */
  .devices-v2__menu {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  
  .devices-v2__menu-item {
    padding: 16px 20px;
    font-size: var(--font-size-base);
    text-align: left;
    border-bottom: 1px solid var(--color-border, #eee);
  }
  
  .devices-v2__menu-item.is-active {
    border-bottom: none;
  }
  
  /* Карточка-аккордеон — "раскрытая кнопка" */
  .devices-v2__accordion-content {
    background: var(--dv2-card-bg);
    border-radius: var(--dv2-card-radius);
    padding: var(--dv2-card-padding);
    margin-bottom: 8px;
    box-shadow: var(--dv2-card-shadow);
    border: 2px solid var(--color-primary);
  }
  
  /* Заголовок аккордеона (название категории) */
  .devices-v2__accordion-header {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    padding-bottom: 16px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--color-border, #eee);
  }
  
  /* Адаптация tooltip для планшета */
  .devices-v2__tooltip {
    max-width: 240px;
    font-size: 11px;
  }
}

/* Мобильный */
@media (max-width: 480px) {
  .devices-v2 {
    --dv2-padding-y: var(--spacing-2xl);
    --dv2-header-margin-bottom: 24px;
    --dv2-title-size: 24px;
    --dv2-kicker-size: var(--font-size-base);
    --dv2-card-padding: 16px;
    --dv2-card-radius: var(--radius-md);
    --dv2-grid-columns: 2;
    --dv2-grid-gap-x: 12px;
    --dv2-grid-gap-y: 16px;
    --dv2-tile-padding: 16px 8px;
    --dv2-tile-radius: var(--radius-sm);
    --dv2-icon-size: 36px;
    --dv2-tile-title-size: var(--font-size-sm);
    --dv2-tile-desc-size: var(--font-size-xs);
  }
  
  .devices-v2__menu-item {
    padding: 14px 16px;
  }
  
  .devices-v2__accordion-content {
    padding: var(--dv2-card-padding);
  }
  
  .devices-v2__accordion-header {
    padding-bottom: 12px;
    margin-bottom: 12px;
    font-size: var(--font-size-sm);
  }
  
  /* Адаптация tooltip для мобильных */
  .devices-v2__tooltip {
    max-width: 200px;
    font-size: 10px;
    padding: 6px 8px;
    left: 8px;
    right: 8px;
    transform: none;
  }
  
  .devices-v2__tooltip::after {
    left: 50%;
    transform: translateX(-50%);
  }
}

/* Очень маленький экран */
@media (max-width: 360px) {
  .devices-v2 {
    --dv2-card-padding: 12px;
    --dv2-grid-gap-x: 8px;
    --dv2-grid-gap-y: 12px;
    --dv2-tile-padding: 12px 6px;
    --dv2-icon-size: 32px;
  }
  
  .devices-v2__tile-desc {
    display: none; /* Скрываем описание на очень маленьких экранах */
  }
  
  /* Адаптация tooltip для очень маленьких экранов */
  .devices-v2__tooltip {
    max-width: 180px;
    font-size: 9px;
    padding: 4px 6px;
  }
}


/* ============================================
   OTHER MODELS — Другие модели LIPOWER
   ============================================ */

.other-models {
  /* Секционные переменные */
  --om-padding-y: var(--spacing-4xl);
  --om-header-gap: var(--spacing-sm);
  --om-header-margin-bottom: var(--spacing-3xl);
  --om-title-size: var(--font-title-size);
  --om-title-weight: var(--font-weight-bold);
  --om-subtitle-size: var(--font-size-lg);
  --om-subtitle-color: var(--color-text-muted);
  
  /* Grid */
  --om-grid-gap: var(--spacing-xl);
  --om-grid-columns: 2;
  
  /* Card */
  --om-card-radius: var(--radius-xl);
  --om-card-bg: var(--color-white);
  --om-card-border: 1px solid var(--color-border);
  --om-card-shadow: var(--shadow-md);
  
  /* Image wrapper */
  --om-image-height: 280px;
  --om-image-bg: var(--color-grey-light);
  --om-image-radius: var(--radius-lg);
  
  /* Content */
  --om-content-padding: var(--spacing-lg);
  --om-card-title-size: var(--font-size-xl);
  --om-card-title-weight: var(--font-weight-semibold);
  --om-card-desc-size: var(--font-size-base);
  --om-card-desc-color: var(--color-text-muted);
  --om-card-desc-line-height: 1.6;
  
  /* Buttons */
  --om-actions-gap: var(--spacing-md);
  --om-btn-height: 48px;
  --om-btn-padding-x: var(--spacing-xl);
  --om-btn-radius: var(--radius-full);
  --om-btn-font-size: var(--font-size-base);
  
  padding: var(--om-padding-y) 0;
  padding-bottom: var(--spacing-md);
  background: var(--color-bg);
}

.other-models__header {
  text-align: center;
  margin-bottom: var(--om-header-margin-bottom);
}

.other-models__title {
  font-size: var(--om-title-size);
  font-weight: var(--om-title-weight);
  color: var(--color-text);
  margin: 0 0 var(--om-header-gap);
  line-height: 1.2;
  text-transform: uppercase;
}

.other-models__subtitle {
  font-size: var(--om-subtitle-size);
  color: var(--om-subtitle-color);
  margin: 0;
  line-height: 1.5;
}

.other-models__grid {
  display: grid;
  grid-template-columns: repeat(var(--om-grid-columns), 1fr);
  gap: var(--om-grid-gap);
}

.other-models__card {
  background: var(--om-card-bg);
  border-radius: var(--om-card-radius);
  border: var(--om-card-border);
  box-shadow: var(--om-card-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.other-models__card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

.other-models__image-wrapper {
  position: relative;
  height: var(--om-image-height);
  background: var(--om-image-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.other-models__bg-vector {
  /* position: absolute; */
  inset: 0;
  /* width: 70%; */
  height: 120%;
  object-fit: cover;
  /* opacity: 0.3; */
  pointer-events: none;
}

.other-models__image {
  position: absolute;
  /* max-width: 90%; */
  max-height: 80%;
  object-fit: contain;
  z-index: 1;
  /* image-rendering: pixelated;
  transform: rotate(-45deg); */
}

.other-models__content {
  padding: var(--om-content-padding);
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.other-models__card-title {
  font-size: var(--om-card-title-size);
  font-weight: var(--om-card-title-weight);
  color: var(--color-text);
  margin: 0 0 var(--spacing-sm);
  line-height: 1.3;
}

.other-models__card-desc {
  font-size: var(--om-card-desc-size);
  color: var(--om-card-desc-color);
  line-height: var(--om-card-desc-line-height);
  margin: 0 0 var(--spacing-lg);
  flex-grow: 1;
}

.other-models__actions {
  display: flex;
  gap: var(--om-actions-gap);
  margin-top: auto;
  min-height: var(--om-btn-height);
}

.other-models__btn {
  height: var(--om-btn-height);
  padding: 0 var(--om-btn-padding-x);
  border-radius: var(--om-btn-radius);
  font-size: var(--om-btn-font-size);
  font-weight: var(--font-weight-semibold);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.other-models__btn.btn--primary {
  background: var(--color-button-bg, var(--color-primary));
  color: var(--color-white);
  border: none;
  flex: 1;
}

.other-models__btn.btn--primary:hover {
  background: var(--color-button-hover, var(--color-primary-hover));
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.other-models__btn.btn--primary:active {
  transform: translateY(0);
}

.other-models__btn.btn--secondary {
  background: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  padding: 0 calc(var(--om-btn-padding-x) * 0.7);
  flex: 1;
}

.other-models__btn.btn--secondary:hover {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* ----------------------------------------
   Other Models: Responsive
   ---------------------------------------- */

/* Планшет */
@media (max-width: 1024px) {
  .other-models {
    --om-padding-y: var(--spacing-3xl);
    --om-title-size: var(--font-size-2xl);
    --om-image-height: 240px;
    --om-grid-gap: var(--spacing-lg);
  }
}

/* Мобильный */
@media (max-width: 768px) {
  .other-models {
    --om-padding-y: var(--spacing-md);
    --om-header-margin-bottom: var(--spacing-xl);
    --om-title-size: var(--font-size-xl);
    --om-subtitle-size: var(--font-size-base);
    --om-grid-columns: 1;
    --om-grid-gap: var(--spacing-lg);
    --om-image-height: 220px;
    --om-content-padding: var(--spacing-md);
    --om-card-title-size: var(--font-size-lg);
    --om-card-desc-size: var(--font-size-sm);
  }
  
  .other-models__actions {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .other-models__btn {
    width: 100%;
  }
}

/* Маленький мобильный */
@media (max-width: 480px) {
  .other-models {
    --om-padding-y: var(--spacing-md);
    --om-title-size: var(--font-size-xl);
    --om-image-height: 180px;
    --om-card-radius: var(--radius-lg);
    --om-btn-height: 44px;
  }
}


/* ============================================
   COMPARISON - Таблица сравнения моделей
   ============================================ */
.comparison {
  /* Секционные переменные */
  --cmp-padding-y: var(--spacing-2xl);
  --cmp-header-margin-bottom: var(--spacing-lg);
  --cmp-title-size: var(--font-size-xl);
  --cmp-column-radius: var(--radius-xl);
  --cmp-column-shadow: 0px 0px 10px 3px rgba(0, 0, 0, 0.1);;
  --cmp-header-padding: var(--spacing-lg) var(--spacing-md);
  --cmp-cell-padding: var(--spacing-sm) var(--spacing-md);
  --cmp-cell-font-size: var(--font-size-sm);
  --cmp-footer-padding: var(--spacing-md);
  --cmp-labels-width: 275px;
  --cmp-model-min-width: 180px;
  --cmp-margin-between-columns: 10px 20px 10px 0px;
  --cmp-margin-after-footer: var(--spacing-5xl);
  
  padding: var(--cmp-padding-y) 0;
  background-color: var(--color-white);
  margin-bottom: var(--cmp-margin-after-footer);
}

/* Заголовок секции */
.comparison__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--cmp-header-margin-bottom);
  gap: var(--spacing-md);
}

.comparison__title {
  font-size: var(--cmp-title-size);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0;
  font-style: italic;
  text-transform: uppercase;
}

/* Кнопка скрыть/показать */
.comparison__toggle {
  display: none; /* Кнопка больше не используется */
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  transition: color var(--transition-fast);
}

.comparison__toggle:hover {
  color: var(--color-text);
}

.comparison__toggle-icon {
  transition: transform var(--transition-base);
}

.comparison__toggle--collapsed .comparison__toggle-icon {
  transform: rotate(180deg);
}

/* Контент (сворачиваемый) */
.comparison__content {
  overflow: hidden;
  transition: max-height var(--transition-base), opacity var(--transition-base);
  max-height: 2000px;
  opacity: 1;
}

.comparison__content--collapsed {
  max-height: 0;
  opacity: 0;
}

/* Таблица */
.comparison__table {
  display: flex;
  gap: var(--spacing-md);
  overflow-x: auto;
  padding-bottom: var(--spacing-sm);
}

/* Колонка с названиями параметров */
.comparison__labels-column {
  flex-shrink: 0;
  width: var(--cmp-labels-width);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--color-grey);
  border-radius: var(--cmp-column-radius);
  margin: var(--cmp-margin-between-columns);
}

.comparison__labels-header {
  padding: var(--cmp-header-padding);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-base);
  color: var(--color-text);
  background-color: var(--color-grey-light);
  border-radius: var(--cmp-column-radius) var(--cmp-column-radius) 0 0;
  text-align: center;
  border-bottom: 1px solid var(--color-grey);
}

.comparison__label {
  padding: var(--cmp-cell-padding);
  font-size: var(--cmp-cell-font-size);
  color: var(--color-text);
  background-color: var(--color-grey-light);
  border-bottom: 1px solid var(--color-grey);
  display: flex;
  align-items: center;
  min-height: 48px;
}

.comparison__labels-footer {
  flex-grow: 1;
  background-color: var(--color-grey-light);
  border-radius: 0 0 var(--cmp-column-radius) var(--cmp-column-radius);
  min-height: 80px;
  padding: var(--cmp-header-padding);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-base);
  color: var(--color-text);
  text-align: center;
}

/* Колонка модели */
.comparison__model-column {
  flex-shrink: 0;
  min-width: var(--cmp-model-min-width);
  flex: 1;
  display: flex;
  flex-direction: column;
  border-radius: var(--cmp-column-radius);
  box-shadow: var(--cmp-column-shadow);
  background-color: var(--color-bg);
  overflow: hidden;
  margin: var(--cmp-margin-between-columns);
  border: 1px solid var(--color-grey);
}

.comparison__model-header {
  padding: var(--cmp-header-padding);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-base);
  color: var(--color-white);
  text-align: center;
}

.comparison__cell {
  padding: var(--cmp-cell-padding);
  font-size: var(--cmp-cell-font-size);
  color: var(--color-text);
  background-color: var(--color-white);
  border-bottom: 1px solid var(--color-grey);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
}

.comparison__cell:nth-child(even) {
  background-color: var(--color-grey-light);
}

.comparison__model-footer {
  flex-grow: 1;
  padding: var(--cmp-footer-padding);
  background-color: var(--color-white);
  display: flex;
  align-items: flex-start;
}

.comparison__model-desc {
  font-size: var(--font-size-xs);
  color: var(--color-text-light);
  line-height: 1.5;
  margin: 0;
}

/* Адаптив: планшет */
@media (max-width: 1024px) {
  .comparison {
    --cmp-padding-y: var(--spacing-3xl);
    --cmp-title-size: var(--font-size-lg);
    --cmp-labels-width: 160px;
    --cmp-model-min-width: 160px;
  }
}

/* Адаптив: мобильный */
@media (max-width: 768px) {
  .comparison {
    --cmp-padding-y: var(--spacing-2xl);
    --cmp-title-size: var(--font-size-base);
    --cmp-header-margin-bottom: var(--spacing-md);
    --cmp-labels-width: 140px;
    --cmp-model-min-width: 140px;
    --cmp-cell-font-size: var(--font-size-xs);
    --cmp-cell-padding: var(--spacing-xs) var(--spacing-sm);
  }
  
  .comparison__header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
  }
  
  .comparison__toggle {
    align-self: flex-end;
  }
}

/* Адаптив: маленький мобильный */
@media (max-width: 480px) {
  .comparison {
    --cmp-padding-y: var(--spacing-xl);
    --cmp-labels-width: 110px;
    --cmp-model-min-width: 120px;
  }
  
  .comparison__label {
    font-size: 10px;
  }
}