/* =========================================================
   IT-System Solution — styles.css

   В этом файле находятся:
   - CSS-переменные сайта
   - тёмная и светлая тема
   - базовые глобальные стили
   - прелоадер
   - логотип
   - popup-галерея
   - верхняя панель topbar
   - шапка сайта header
   - кнопки
   - hero-блок
   - общие карточки
   - блок "О компании"
   - блок "Услуги"
   - блок "Кейсы"
   - блок "Калькулятор / Прайс"
   - блок "Контакты"
   - footer
   - плавающие соцсети
   - адаптивность
   - canvas-эффект пепла
   ========================================================= */


/* =========================================================
   :root
   Глобальные CSS-переменные, которые доступны по всему сайту.
   Здесь задаются размеры, радиусы, тени и скорость анимаций.
   ========================================================= */
:root {
  --container: 1240px;
  /* Максимальная ширина основного контейнера сайта */

  --radius-xl: 30px;
  /* Очень крупный скруглённый угол */

  --radius-lg: 28px;
  /* Крупный радиус для больших карточек */

  --radius-md: 22px;
  /* Средний радиус для карточек и блоков */

  --radius-sm: 16px;
  /* Небольшой радиус */

  --shadow: 0 20px 60px rgba(0, 0, 0, 0.22);
  /* Основная тень карточек */

  --transition: .25s ease;
  /* Универсальная скорость анимации/переходов */
}


/* =========================================================
   ТЁМНАЯ ТЕМА
   Все цветовые переменные для body[data-theme="dark"]
   ========================================================= */
body[data-theme="dark"] {
  --bg: #07111f;
  /* Основной тёмный фон */

  --bg-soft: #0b1728;
  /* Более мягкий дополнительный фон */

  --surface: rgba(15, 27, 45, 0.60);
  /* Полупрозрачная поверхность карточек */

  --surface-2: rgba(10, 20, 36, 0.42);
  /* Второй слой поверхности */

  --surface-3: rgba(255, 255, 255, 0.09);
  /* Светлая стеклянная поверхность */

  --surface-4: rgba(255, 255, 255, 0.12);
  /* Чуть более заметная стеклянная поверхность */

  --line: rgba(255, 255, 255, 0.08);
  /* Тонкие границы */

  --line-strong: rgba(64, 183, 255, 0.26);
  /* Усиленная синяя граница */

  --text: #f4f8ff;
  /* Основной цвет текста */

  --muted: #a9b8cf;
  /* Приглушённый текст */

  --primary: #40b7ff;
  /* Основной синий акцент */

  --primary-2: #7f5cff;
  /* Второй акцентный цвет — фиолетовый */

  --green: #2ad86f;
  /* Основной зелёный */

  --green-2: #7bf09e;
  /* Светло-зелёный для градиентов */

  --btn-text-dark: #06121f;
  /* Цвет текста на светлых ярких кнопках */

  --hero-overlay-left: rgba(3, 10, 20, 0.90);
  /* Затемнение hero слева */

  --hero-overlay-mid: rgba(3, 10, 20, 0.70);
  /* Затемнение hero в центре */

  --hero-overlay-right: rgba(3, 10, 20, 0.36);
  /* Затемнение hero справа */
}


/* =========================================================
   СВЕТЛАЯ ТЕМА
   Все цветовые переменные для body[data-theme="light"]
   ========================================================= */
body[data-theme="light"] {
  --bg: #eef5fb;
  /* Основной светлый фон */

  --bg-soft: #f7fbff;
  /* Мягкий дополнительный фон */

  --surface: rgba(255, 255, 255, 0.72);
  /* Полупрозрачная белая поверхность */

  --surface-2: rgba(248, 251, 255, 0.52);
  /* Второй слой поверхности */

  --surface-3: rgba(255, 255, 255, 0.36);
  /* Светлый стеклянный слой */

  --surface-4: rgba(255, 255, 255, 0.44);
  /* Более плотный стеклянный слой */

  --line: rgba(8, 25, 45, 0.10);
  /* Тонкие линии на светлой теме */

  --line-strong: rgba(64, 183, 255, 0.24);
  /* Усиленная граница */

  --text: #081321;
  /* Основной тёмный текст */

  --muted: #5c6f85;
  /* Приглушённый текст */

  --primary: #1686ff;
  /* Основной синий */

  --primary-2: #6e5cff;
  /* Второй акцент */

  --green: #22c55e;
  /* Зелёный */

  --green-2: #86efac;
  /* Светло-зелёный */

  --btn-text-dark: #04101b;
  /* Цвет текста на ярких кнопках */

  --hero-overlay-left: rgba(238, 245, 251, 0.90);
  /* Осветляющий overlay hero слева */

  --hero-overlay-mid: rgba(238, 245, 251, 0.68);
  /* Осветляющий overlay hero по центру */

  --hero-overlay-right: rgba(238, 245, 251, 0.18);
  /* Осветляющий overlay hero справа */
}


/* =========================================================
   ГЛОБАЛЬНЫЙ RESET / БАЗА
   ========================================================= */
* {
  box-sizing: border-box;
  /* Чтобы padding и border входили в размеры элемента */
}

html {
  scroll-behavior: smooth;
  /* Плавная прокрутка по якорям */
}

body {
  margin: 0;
  /* Убираем стандартный внешний отступ браузера */

  font-family: 'Inter', sans-serif;
  /* Основной шрифт сайта */

  color: var(--text);
  /* Основной цвет текста берётся из темы */

  background:
    radial-gradient(circle at top right, rgba(64, 183, 255, 0.16), transparent 24%),
    radial-gradient(circle at left center, rgba(127, 92, 255, 0.12), transparent 20%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);
  /*
    Фон body состоит из:
    1) синего свечения справа сверху
    2) фиолетового свечения слева
    3) основного вертикального градиента
  */

  overflow-x: hidden;
  /* Запрещаем горизонтальную прокрутку */

  transition: background var(--transition), color var(--transition);
  /* Плавный переход фона и цвета при смене темы */
}

body.is-loading {
  overflow: hidden;
  /* Пока идёт загрузка — блокируем прокрутку страницы */
}

img {
  display: block;
  /* Убирает лишние пробелы под картинками */

  max-width: 100%;
  /* Картинка не вылезет за ширину контейнера */
}

a {
  color: inherit;
  /* Ссылки наследуют цвет текста от родителя */

  text-decoration: none;
  /* Убираем подчёркивание */
}

button,
input,
textarea {
  font: inherit;
  /* Наследуем шрифт, чтобы форма выглядела в одном стиле */
}

textarea {
  resize: vertical;
  /* Разрешаем изменять размер textarea только по высоте */
}

.container {
  width: min(var(--container), calc(100% - 32px));
  /* Контейнер либо 1240px, либо ширина экрана минус отступы */

  margin: 0 auto;
  /* Выравнивание контейнера по центру */
}

section {
  padding: 90px 0;
  /* Вертикальные отступы для каждой секции */
}

.block-title {
  margin: 0 0 6px;
  /* Отступ снизу */

  font-size: 26px;
  /* Размер заголовка блока */

  font-family: 'Manrope', sans-serif;
  /* Более выразительный шрифт заголовка */
}

.calc-desc,
.about-text-full {
  max-width: none !important;
  /* Отменяем ограничение ширины */

  margin-top: 0 !important;
  /* Убираем верхний отступ */
}


/* =========================================================
   АНИМАЦИЯ ПОЯВЛЕНИЯ reveal
   Элементы сначала скрыты, а потом через JS получают .active
   ========================================================= */
.reveal {
  opacity: 0;
  /* Элемент скрыт */

  transform: translateY(28px);
  /* Сдвинут чуть вниз */

  transition: opacity .7s ease, transform .7s ease;
  /* Плавное появление */
}

.reveal.active {
  opacity: 1;
  /* Показываем элемент */

  transform: translateY(0);
  /* Возвращаем на место */
}


/* =========================================================
   PRELOADER
   Полноэкранный загрузочный экран
   ========================================================= */
#preloader {
  position: fixed;
  /* Фиксируем поверх всей страницы */

  inset: 0;
  /* top/right/bottom/left = 0 */

  z-index: 9999;
  /* Очень высокий слой */

  display: flex;
  align-items: center;
  justify-content: center;
  /* Центрируем содержимое */

  background: linear-gradient(180deg, #06101e 0%, #0a1730 100%);
  /* Тёмный градиент фона */

  transition: opacity .45s ease, visibility .45s ease;
  /* Плавное скрытие */
}

#preloader.is-hidden {
  opacity: 0;
  /* Делаем прозрачным */

  visibility: hidden;
  /* Скрываем */

  pointer-events: none;
  /* Запрещаем взаимодействие */
}

.preloader-box {
  display: flex;
  flex-direction: column;
  /* Элементы в колонку */

  align-items: center;
  /* По центру по горизонтали */

  gap: 16px;
  /* Расстояние между элементами */

  text-align: center;
  /* Центрирование текста */
}

.loader-ring {
  width: 62px;
  height: 62px;
  /* Размер кольца */

  border-radius: 50%;
  /* Делаем круг */

  border: 5px solid rgba(255, 255, 255, .08);
  /* Основная полупрозрачная обводка */

  border-top-color: var(--primary);
  /* Верхняя часть кольца синяя */

  animation: spin 1s linear infinite;
  /* Бесконечное вращение */
}

.preloader-box p {
  color: #dbe8ff;
  /* Светлый текст */

  margin: 0;
  /* Убираем лишние отступы */
}

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

  /* Поворот на полный круг */
}


/* =========================================================
   ВСТРОЕННЫЙ ЛОГОТИП
   ========================================================= */
.logo-mark {
  width: 64px;
  height: 64px;
  /* Стандартный размер логотипа */

  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* Центровка SVG */

  flex-shrink: 0;
  /* Не сжимать логотип */
}

.logo-mark.big {
  width: 120px;
  height: 120px;
  /* Увеличенный логотип для прелоадера */
}


.logo-mark img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 10px 26px rgba(64, 183, 255, .28));
}

.brand-text strong {
  letter-spacing: .2px;
}

.logo-mark svg {
  width: 100%;
  height: 100%;
  display: block;
  /* SVG занимает весь контейнер */

  filter: drop-shadow(0 10px 26px rgba(64, 183, 255, .22));
  /* Голубое свечение под логотипом */
}


/* =========================================================
   POPUP ГАЛЕРЕЯ
   Полноэкранный просмотр кейсов / картинок
   ========================================================= */
.gallery-popup {
  position: fixed;
  inset: 0;
  z-index: 9998;
  /* Слой чуть ниже прелоадера */

  display: none;
  /* По умолчанию скрыто */

  align-items: center;
  justify-content: center;
  /* Центровка содержимого */

  background: rgba(3, 10, 20, .92);
  /* Тёмная подложка */

  padding: 30px;
  /* Внутренние отступы */
}

.gallery-popup.open {
  display: flex;
  /* Когда добавляется .open — показываем окно */
}

.gallery-popup-inner {
  max-width: min(1200px, 92vw);
  /* Максимальная ширина картинки */

  max-height: 86vh;
  /* Максимальная высота */

  text-align: center;
}

.gallery-popup-inner img {
  max-width: 100%;
  max-height: 76vh;
  /* Ограничиваем размер картинки */

  border-radius: 20px;
  /* Скругляем углы */

  box-shadow: 0 30px 80px rgba(0, 0, 0, .36);
  /* Глубокая тень */
}

.gallery-popup-caption {
  margin-top: 14px;
  /* Отступ сверху */

  color: #dce7f7;
  /* Цвет подписи */

  font-size: 18px;
}

.gallery-close,
.gallery-nav {
  position: absolute;
  /* Плавающие кнопки поверх popup */

  width: 54px;
  height: 54px;
  border-radius: 50%;
  /* Круглые */

  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .08);
  color: #fff;

  display: grid;
  place-items: center;
  /* Центровка иконки */

  cursor: pointer;

  transition: transform var(--transition), background var(--transition);
}

.gallery-close:hover,
.gallery-nav:hover {
  transform: scale(1.06);
  /* Лёгкое увеличение */

  background: rgba(255, 255, 255, .14);
  /* Подсветка при наведении */
}

.gallery-close {
  top: 20px;
  right: 20px;
}

/* Кнопка закрытия в правом верхнем углу */

.gallery-prev {
  left: 24px;
}

/* Стрелка влево */

.gallery-next {
  right: 24px;
}

/* Стрелка вправо */


/* =========================================================
   TOPBAR
   Верхняя тонкая панель с контактами и соцсетями
   ========================================================= */
.topbar {
  position: relative;
  z-index: 20;
  /* Слой выше обычного контента */

  border-bottom: 1px solid var(--line);
  /* Нижняя линия */

  background: color-mix(in srgb, var(--bg) 62%, transparent);
  /* Полупрозрачный фон */

  backdrop-filter: blur(12px);
  /* Стеклянный blur-эффект */
}

.topbar-inner {
  min-height: 48px;
  /* Минимальная высота панели */

  display: flex;
  align-items: center;
  justify-content: space-between;
  /* Контент слева и справа */

  gap: 16px;
  flex-wrap: wrap;
  /* Если не помещается — перенос */

  padding: 8px 0;
}

.topbar-list {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  /* Расстояние между контактами */

  color: var(--muted);
  font-size: 14px;
}

.topbar-list a:hover {
  color: var(--primary);
  /* Подсветка ссылки при наведении */
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
  /* Правая группа элементов */
}

.topbar-social {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  /* Центровка иконки */

  border-radius: 50%;
  background: var(--surface-3);
  border: 1px solid var(--line);
  color: var(--text);

  transition: transform var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
}

.topbar-social:hover {
  transform: translateY(-3px) scale(1.06);
  /* Иконка слегка поднимается */

  border-color: var(--line-strong);
  color: var(--primary);

  box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
}

.topbar-wa {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  /* Иконка и текст с промежутком */

  padding: 9px 14px;
  border-radius: 999px;
  /* Пилюля */

  background: linear-gradient(135deg, var(--green), var(--green-2));
  color: #04110b;
  /* Тёмный текст на зелёном */

  font-weight: 800;

  box-shadow: 0 10px 24px rgba(43, 214, 111, 0.22);
}


/* =========================================================
   HEADER
   Основная шапка сайта
   ========================================================= */
.header {
  position: sticky;
  top: 0;
  /* Прилипает к верху экрана при прокрутке */

  z-index: 30;
  /* Выше topbar */

  background: color-mix(in srgb, var(--bg) 58%, transparent);
  backdrop-filter: blur(16px);
  /* Стеклянный полупрозрачный header */

  border-bottom: 1px solid var(--line);

  box-shadow: 0 10px 30px rgba(2, 15, 30, .10);
  /* Лёгкая тень под шапкой */
}

.header-inner {
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  /* Расстояние между логотипом и текстом */

  min-width: 0;
  flex: 0 1 auto;

  padding: 8px 10px;
  border-radius: 18px;

  transition: transform .25s ease, background .25s ease, box-shadow .25s ease;
}

.brand:hover {
  transform: translateY(-3px);
  /* Блок бренда слегка поднимается */

  background: color-mix(in srgb, var(--surface-3) 72%, transparent);

  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.16);
}

.brand-logo-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* Обёртка логотипа */
  flex-shrink: 0;
}

.brand:hover .logo-mark {
  transform: translateY(-2px) scale(1.03);
  /* Логотип слегка оживает при наведении */
}

.brand .logo-mark {
  transition: transform .25s ease, filter .25s ease;
}

.brand-text {
  min-width: 0;
  max-width: 210px;
  /* Ограничиваем ширину текста бренда */
}

.brand-text strong {
  display: block;
  font-family: 'Manrope', sans-serif;
  font-size: 18px;
  line-height: 1.05;
  color: var(--text);
  /* Название компании */
}

.brand-text span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
  /* Подзаголовок */
}

.nav {
  display: flex;
  align-items: center;
  gap: 22px;
  /* Расстояние между пунктами меню */

  margin-left: auto;
  /* Меню уходит вправо */

  font-weight: 600;
  color: color-mix(in srgb, var(--text) 86%, transparent);
}

.nav a {
  position: relative;
  font-size: 15px;
  /* Пункты меню */
}

.nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -8px;
  /* Линия под пунктом меню */

  width: 0;
  height: 2px;
  border-radius: 2px;

  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  transition: width var(--transition);
}

.nav a:hover::after,
.nav a.active::after {
  width: 100%;
  /* Линия выезжает при hover и active */
}

.header-social {
  display: flex;
  align-items: center;
  gap: 10px;
  /* Иконки соцсетей в header */
}

.header-social a {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 50%;

  background: var(--surface-3);
  border: 1px solid var(--line);
  color: var(--text);

  transition: transform var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
}

.header-social a:hover {
  transform: translateY(-3px) scale(1.06);
  border-color: var(--line-strong);
  color: var(--primary);
  box-shadow: 0 16px 30px rgba(0, 0, 0, .18);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  /* Группа справа: соцсети, тема, кнопка, бургер */
}

.theme-toggle,
.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  min-height: 48px;
  padding: 0 16px;

  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-3);
  color: var(--text);

  cursor: pointer;

  transition: transform var(--transition), background var(--transition), border-color var(--transition);
}

.theme-toggle:hover,
.menu-toggle:hover {
  transform: translateY(-2px);
  border-color: var(--line-strong);
}

.menu-toggle {
  display: none;
  /* На десктопе бургер скрыт */

  width: 52px;
  height: 48px;
  padding: 0;

  position: relative;
}

.menu-toggle span {
  position: absolute;
  width: 22px;
  height: 2px;
  background: currentColor;
  /* Линии берут текущий цвет кнопки */

  border-radius: 2px;

  transition: transform var(--transition), opacity var(--transition), top var(--transition);
}

.menu-toggle span:nth-child(1) {
  top: 16px;
}

/* Верхняя полоска */

.menu-toggle span:nth-child(2) {
  top: 23px;
}

/* Средняя полоска */

.menu-toggle span:nth-child(3) {
  top: 30px;
}

/* Нижняя полоска */

.menu-toggle.active span:nth-child(1) {
  top: 23px;
  transform: rotate(45deg);
  /* Превращаем в часть крестика */
}

.menu-toggle.active span:nth-child(2) {
  opacity: 0;
  /* Прячем среднюю полоску */
}

.menu-toggle.active span:nth-child(3) {
  top: 23px;
  transform: rotate(-45deg);
  /* Вторая часть крестика */
}


/* =========================================================
   BUTTONS
   Универсальные стили кнопок
   ========================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;

  min-height: 50px;
  padding: 0 22px;

  border-radius: 14px;
  border: 0;
  cursor: pointer;

  transition: transform var(--transition), box-shadow var(--transition), background var(--transition);

  font-weight: 800;
}

.btn:hover {
  transform: translateY(-2px);
  /* Кнопка слегка приподнимается */
}

.btn-primary {
  color: var(--btn-text-dark);
  background: linear-gradient(135deg, var(--primary), #88d9ff);
  box-shadow: 0 16px 30px rgba(64, 183, 255, 0.24);
  /* Главная синяя кнопка */
}

.btn-secondary {
  color: var(--text);
  background: var(--surface-3);
  border: 1px solid var(--line);
  /* Вторичная стеклянная кнопка */
}

.btn-whatsapp {
  color: #031108;
  background: linear-gradient(135deg, var(--green), var(--green-2));
  box-shadow: 0 14px 28px rgba(42, 216, 111, 0.22);
  /* WhatsApp-кнопка */
}


/* =========================================================
   HERO
   Первый экран сайта
   ========================================================= */
.hero {
  position: relative;
  isolation: isolate;
  /* Создаём независимый стек слоёв */

  min-height: 100svh;
  /* Высота на весь экран */

  display: flex;
  align-items: center;
  /* Вертикальное центрирование */

  padding: 42px 0 60px;
  overflow: clip;
  /* Обрезаем всё, что вылезает */
}

#webCanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;

  z-index: -2;
  /* Позади текста и поверх фонового слайдера */

  opacity: .92;
  filter: saturate(1.15) brightness(1.05);
  /* Подкручиваем насыщенность и яркость */

  pointer-events: auto;
  /* canvas может принимать взаимодействие мыши */
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;

  background:
    linear-gradient(90deg, var(--hero-overlay-left) 0%, var(--hero-overlay-mid) 42%, var(--hero-overlay-right) 100%),
    radial-gradient(circle at 78% 30%, rgba(64, 183, 255, 0.18), transparent 26%),
    radial-gradient(circle at 88% 72%, rgba(127, 92, 255, 0.16), transparent 22%);
  /*
    Слой затемнения/осветления + декоративные свечения
  */

  z-index: -1;
}

.hero-slider {
  position: absolute;
  inset: 0;
  z-index: -3;
  /* Самый задний слой — фоновый слайдер */
}

.hero-slide {
  position: absolute;
  inset: 0;

  background-size: cover;
  background-position: center;

  opacity: 0;
  /* Неактивный слайд скрыт */

  transform: scale(1.12);
  /* Чуть увеличен для эффекта плавного наезда */

  filter: brightness(.78) saturate(1.08);

  transition: opacity 1.25s ease, transform 7s ease, filter 1.25s ease;
}

.hero-slide.active {
  opacity: 1;
  /* Активный слайд показан */

  transform: scale(1);
  /* Плавно приходит к нормальному масштабу */

  filter: brightness(.96) saturate(1.12);
}

.hero-slide::after {
  content: "";
  position: absolute;
  inset: 0;

  background:
    linear-gradient(180deg, rgba(3, 10, 20, 0.10), rgba(3, 10, 20, 0.42)),
    radial-gradient(circle at center, rgba(64, 183, 255, 0.10), transparent 45%);
  /* Дополнительный overlay для фото */
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
  /* Левая колонка шире, правая чуть уже */

  gap: 32px;
  align-items: center;
}

.hero-badge,
.section-kicker,
.panel-chip,
.case-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 10px 14px;
  border-radius: 999px;

  background: var(--surface-3);
  border: 1px solid var(--line);

  color: color-mix(in srgb, var(--text) 92%, transparent);

  font-size: 13px;
  font-weight: 700;

  backdrop-filter: blur(10px);
  /* Общий стиль маленьких бейджей/чипов */
}

.hero-title {
  margin: 18px 0 16px;

  font-family: 'Manrope', sans-serif;

  font-size: clamp(40px, 7vw, 74px);
  /* Адаптивный размер заголовка */

  line-height: .98;
  letter-spacing: -1.8px;
}

.hero-title span {
  display: block;
  margin-top: 10px;

  background: linear-gradient(135deg, #ffffff, #8ddbff 42%, #8f7dff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  /* Градиентный текст */
}

body[data-theme="light"] .hero-title span {
  background: linear-gradient(135deg, #05213c, #167dff 42%, #6f54ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  /* Для светлой темы свой градиент */
}

.hero-text {
  max-width: 720px;
  color: var(--muted);

  font-size: clamp(16px, 2vw, 19px);
  line-height: 1.72;

  margin-bottom: 26px;
}

.hero-copy>* {
  animation: heroFadeUp .9s ease both;
  /* Все прямые элементы hero-copy плавно появляются */
}

.hero-copy>*:nth-child(1) {
  animation-delay: .10s;
}

.hero-copy>*:nth-child(2) {
  animation-delay: .20s;
}

.hero-copy>*:nth-child(3) {
  animation-delay: .35s;
}

.hero-copy>*:nth-child(4) {
  animation-delay: .50s;
}

.hero-copy>*:nth-child(5) {
  animation-delay: .65s;
}

/* Задержка по очереди — красивое каскадное появление */

@keyframes heroFadeUp {
  from {
    opacity: 0;
    transform: translateY(22px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 26px;
  /* Кнопки в hero */
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  max-width: 760px;
  /* Блок статистики в 3 колонки */
}

.stat {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-3);
  backdrop-filter: blur(10px);
}

.stat strong {
  display: block;
  font-size: 28px;
  font-family: 'Manrope', sans-serif;
  margin-bottom: 6px;
  /* Крупное число */
}

.stat span {
  color: var(--muted);
  font-size: 14px;
}


/* =========================================================
   ОБЩИЕ КАРТОЧКИ
   Базовая общая стилистика для разных карточек сайта
   ========================================================= */
.hero-panel,
.about-card,
.approach-card,
.service-card,
.server-card,
.calc-card,
.price-card,
.contacts-card,
.map-card {
  background: linear-gradient(180deg, var(--surface), var(--surface-2));
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.hero-panel {
  position: relative;
  padding: 22px;
  border-radius: var(--radius-lg);
  backdrop-filter: blur(14px);

  background: linear-gradient(180deg,
      color-mix(in srgb, var(--surface) 86%, transparent),
      color-mix(in srgb, var(--surface-2) 86%, transparent));

  box-shadow: 0 24px 70px rgba(0, 0, 0, .20);

  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
}

.hero-panel:hover {
  transform: translateY(-8px);
  box-shadow: 0 34px 90px rgba(0, 0, 0, .28);
  border-color: var(--line-strong);
  /* Hero-панель при наведении приподнимается */
}

.hero-panel::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: var(--radius-lg);

  background: linear-gradient(135deg, rgba(64, 183, 255, 0.32), rgba(127, 92, 255, 0.18), transparent 38%);
  z-index: -1;
  opacity: .75;
  /* Дополнительное внутреннее свечение */
}

.panel-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
  /* Верх hero-панели */
}

.panel-top strong {
  font-size: 16px;
}

.service-preview {
  display: grid;
  gap: 12px;
  /* Список мини-карточек в hero */
}

.service-preview-item,
.contact-row {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 14px;
  align-items: start;

  padding: 14px;
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 18px;
}

.service-preview-item {
  background: color-mix(in srgb, var(--surface-3) 82%, transparent);
  backdrop-filter: blur(10px);

  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
}

.service-preview-item:hover {
  transform: translateY(-7px);
  box-shadow: 0 20px 44px rgba(0, 0, 0, .18);
  border-color: var(--line-strong);
  background: color-mix(in srgb, var(--surface-4) 80%, transparent);
}

.service-preview-item i,
.contact-row i,
.service-icon {
  width: 54px;
  height: 54px;

  display: grid;
  place-items: center;

  border-radius: 16px;
  font-size: 22px;

  background: linear-gradient(135deg, rgba(64, 183, 255, 0.22), rgba(127, 92, 255, 0.16));
  color: #8ddbff;
  /* Общий стиль иконок */
}

body[data-theme="light"] .service-preview-item i,
body[data-theme="light"] .contact-row i,
body[data-theme="light"] .service-icon {
  color: #0e7df0;
  /* На светлой теме цвет иконок насыщеннее */
}

.service-preview-item strong,
.contact-row strong {
  display: block;
  margin-bottom: 5px;
  font-size: 16px;
}

.service-preview-item span,
.contact-row span,
.contact-row a {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.contact-row a:hover {
  color: var(--primary);
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 28px;
  flex-wrap: wrap;
  /* Универсальная шапка секции */
}

.section-kicker {
  margin-bottom: 14px;
  text-transform: uppercase;
  letter-spacing: .8px;
}

.section-title {
  margin: 0;
  font-family: 'Manrope', sans-serif;
  font-size: clamp(30px, 4.3vw, 52px);
  line-height: 1.03;
  letter-spacing: -1.2px;
}

.section-desc {
  max-width: 680px;
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.75;
  font-size: 16px;
}


/* =========================================================
   ABOUT
   Блок "О компании"
   ========================================================= */
.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr);
  gap: 28px;
  align-items: center;
  /* Текст слева, картинка справа */
}

.about-card {
  padding: 26px;
  border-radius: var(--radius-lg);
}

.about-points {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
  /* Сетка преимуществ */
}

.point {
  padding: 16px;
  border-radius: 18px;
  background: var(--surface-3);
  border: 1px solid var(--line);
}

.point i {
  color: #8ddbff;
  margin-bottom: 12px;
  font-size: 22px;
}

body[data-theme="light"] .point i {
  color: var(--primary);
}

.point strong {
  display: block;
  margin-bottom: 6px;
}

.point span {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
}

.about-visual {
  position: relative;
  min-height: 560px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background: #091727;
  /* Визуальный блок с фото */
}

.about-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Картинка заполняет блок без искажений */
}

.about-badge {
  position: absolute;
  right: 20px;
  bottom: 20px;
  max-width: 260px;

  padding: 18px;
  border-radius: 18px;

  background: color-mix(in srgb, var(--bg) 86%, transparent);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);

  box-shadow: 0 20px 40px rgba(0, 0, 0, .26);
}

.about-badge strong {
  display: block;
  font-size: 28px;
  margin-bottom: 6px;
}

.about-badge span {
  color: var(--muted);
  line-height: 1.6;
}


/* =========================================================
   SERVICES
   Блок "Услуги"
   ========================================================= */
.services-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  /* 4 карточки в ряд */
}

.service-card,
.server-card,
.approach-card {
  position: relative;
  padding: 24px;
  border-radius: var(--radius-md);
  overflow: hidden;

  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.service-card:hover,
.server-card:hover,
.approach-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.26);
  border-color: var(--line-strong);
  /* Карточки при наведении приподнимаются */
}

.service-card::before {
  content: "";
  position: absolute;
  inset: -30% auto auto -30%;
  width: 180px;
  height: 180px;

  background: radial-gradient(circle, rgba(64, 183, 255, 0.15), transparent 65%);
  pointer-events: none;
  /* Декоративное голубое свечение в углу */
}

.service-card h3,
.server-card h3,
.approach-card h3 {
  margin: 0 0 10px;
  font-size: 20px;
  line-height: 1.25;
}

.service-card p,
.server-card p,
.approach-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.7;
}

.service-card p {
  margin-bottom: 16px;
  /* В service-card снизу отступ до ссылки */
}

.service-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;

  color: #8ddbff;
  font-weight: 700;
  font-size: 14px;
}

body[data-theme="light"] .service-link {
  color: var(--primary);
}

.approach-grid,
.server-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  /* 3 карточки в ряд */
}


/* =========================================================
   CASES
   Блок кейсов / проектов
   ========================================================= */
.cases-layout {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items: stretch;
  /* Большой кейс слева, два маленьких справа */
}

.case-feature,
.case-mini {
  position: relative;
  overflow: hidden;

  box-shadow: var(--shadow);
  border: 1px solid var(--line);
  background: #0b1626;

  cursor: pointer;
}

.case-feature {
  min-height: 560px;
  padding: 30px;
  border-radius: 30px;
  /* Большой кейс */
}

.case-mini {
  min-height: 268px;
  border-radius: 26px;
  /* Маленькие кейсы */
}

.case-feature img,
.case-mini img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;

  transition: transform .5s ease;
}

.case-feature:hover img,
.case-mini:hover img {
  transform: scale(1.04);
  /* Картинка слегка приближается */
}

.case-feature::after,
.case-mini::after {
  content: "";
  position: absolute;
  inset: 0;

  background: linear-gradient(180deg, rgba(4, 10, 19, 0.08) 10%, rgba(4, 10, 19, 0.8) 100%);
  /* Затемняющий градиент поверх фото */
}

.case-content {
  position: relative;
  z-index: 1;
  /* Текст поверх затемнения */

  margin-top: auto;
  display: flex;
  flex-direction: column;
  justify-content: end;
  height: 100%;
}

.case-content h3 {
  margin: 0 0 12px;
  font-size: clamp(24px, 3vw, 38px);
  font-family: 'Manrope', sans-serif;
  line-height: 1.05;
}

.case-content p {
  max-width: 560px;
  margin: 0 0 18px;
  color: #dce7f7;
  line-height: 1.72;
}

.case-side {
  display: grid;
  gap: 22px;
  /* Колонка из двух кейсов */
}

.case-mini .case-content {
  padding: 24px;
}

.case-mini .case-content h3 {
  font-size: 24px;
}


/* =========================================================
   CALC
   Калькулятор и прайс
   ========================================================= */
.calc-wrap {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 24px;
  align-items: start;
  /* Калькулятор слева, прайс справа */
}

.calc-card,
.price-card,
.contacts-card,
.map-card {
  padding: 26px;
  border-radius: var(--radius-lg);
}

.calc-list,
.price-list,
.contact-list {
  display: grid;
  gap: 14px;
  margin-top: 18px;
  /* Универсальный список блоков */
}

.calc-item {
  display: grid;
  grid-template-columns: 34px 1fr auto;
  gap: 16px;
  align-items: center;

  padding: 16px 18px;
  border-radius: 18px;

  background: var(--surface-3);
  border: 1px solid var(--line);
}

.calc-item input[type="checkbox"] {
  width: 22px;
  height: 22px;
  accent-color: var(--primary);
  /* Цвет checkbox */
}

.calc-item strong {
  display: block;
  margin-bottom: 5px;
  font-size: 16px;
}

.calc-item span {
  color: var(--muted);
  font-size: 14px;
}

.qty {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 14px;
  /* Блок количества */
}

.qty input {
  width: 84px;
  height: 44px;
  padding: 0 10px;

  border-radius: 12px;
  border: 1px solid var(--line);

  background: var(--surface-3);
  color: var(--text);

  text-align: center;
}

.calc-total {
  margin-top: 20px;
  padding: 22px;
  border-radius: 22px;

  background: linear-gradient(135deg, rgba(64, 183, 255, 0.18), rgba(127, 92, 255, 0.14));
  border: 1px solid var(--line);
  /* Блок итога */
}

.calc-total strong {
  display: block;
  margin-bottom: 8px;
  font-size: 34px;
  font-family: 'Manrope', sans-serif;
  /* Крупный итог */
}

.calc-total span {
  color: color-mix(in srgb, var(--text) 90%, transparent);
  line-height: 1.7;
}

.price-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  padding: 14px 0;
  border-bottom: 1px dashed var(--line);
  /* Строка прайса */
}

.price-line:last-child {
  border-bottom: 0;
  /* У последней строки убираем линию */
}

.price-line span {
  color: var(--muted);
}

.price-line strong {
  color: var(--text);
}


/* =========================================================
   CONTACTS
   Контакты и форма
   ========================================================= */
.contacts-wrap {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 24px;
  align-items: start;
  /* Контакты слева, карта справа */
}

.map-card iframe {
  width: 100%;
  height: 100%;
  min-height: 480px;
  border: 0;
  border-radius: 20px;
  background: #0b1626;
  /* Встроенная карта */
}

.contact-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
  /* Кнопки под контактами */
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 20px;
  /* Форма в колонку */
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  /* Два поля в ряд */
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 14px 16px;

  border-radius: 14px;
  border: 1px solid var(--line);

  background: var(--surface-3);
  color: var(--text);

  outline: none;

  transition: border-color var(--transition), box-shadow var(--transition);
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--line-strong);
  box-shadow: 0 0 0 4px rgba(64, 183, 255, .08);
  /* Подсветка поля в фокусе */
}

.contact-form textarea {
  min-height: 140px;
}

.form-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}


/* =========================================================
   FOOTER
   Подвал сайта
   ========================================================= */
.footer {
  padding: 26px 0 32px;
  border-top: 1px solid var(--line);

  background: color-mix(in srgb, var(--bg) 76%, transparent);
  backdrop-filter: blur(10px);
}

.footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  /* Элементы футера могут переноситься */
}

.footer-copy {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.7;
}

.footer-social {
  display: flex;
  align-items: center;
  gap: 12px;
  /* Иконки футера */
}

.footer-social a {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--surface-3);
  border: 1px solid var(--line);
  color: color-mix(in srgb, var(--text) 92%, transparent);

  transition: transform var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
}

.footer-social a:hover {
  transform: translateY(-3px) scale(1.06);
  border-color: var(--line-strong);
  color: var(--primary);
  box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
}


/* =========================================================
   FLOAT SOCIALS
   Плавающие круглые соцкнопки справа снизу
   ========================================================= */
.social-float {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 40;

  display: flex;
  flex-direction: column;
  gap: 10px;
  /* Вертикальная колонка кнопок */
}

.social-float-link {
  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;
  padding: 0;

  border-radius: 50%;
  color: #fff;
  font-weight: 800;

  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);

  transition: transform var(--transition), box-shadow var(--transition), opacity var(--transition), filter var(--transition);
}

.social-float-link span {
  display: none;
  /* Текст скрыт, видна только иконка */
}

.social-float-link i {
  font-size: 22px;
}

.social-float-link:hover {
  transform: translateY(-3px) scale(1.07);
  box-shadow: 0 22px 42px rgba(0, 0, 0, .22);
}

.social-float-link.wa {
  background: linear-gradient(135deg, #25D366, #7bf09e);
  color: #031108;
  /* WhatsApp */
}

.social-float-link.inst {
  background: linear-gradient(135deg, #E4405F, #FCAF45);
  /* Instagram */
}

.social-float-link.fb {
  background: linear-gradient(135deg, #1877F2, #4ea1ff);
  /* Facebook */
}


/* =========================================================
   ADAPT
   Адаптивность сайта под планшеты и телефоны
   ========================================================= */
@media (max-width: 1200px) {

  .hero-grid,
  .about-grid,
  .cases-layout {
    grid-template-columns: 1fr;
    /* Переводим в одну колонку */
  }

  .services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    /* Услуги по 2 в ряд */
  }

  .server-grid,
  .approach-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    /* Карточки по 2 в ряд */
  }

  .header-inner {
    gap: 16px;
  }
}

@media (max-width: 900px) {
  .nav {
    gap: 16px;
    /* Уменьшаем расстояние между пунктами меню */
  }

  .brand-text {
    max-width: 170px;
  }

  .brand-text strong {
    font-size: 16px;
  }

  .brand-text span {
    font-size: 12px;
  }
}

@media (max-width: 860px) {
  .topbar-right {
    width: 100%;
    justify-content: space-between;
    /* Правая часть topbar занимает всю ширину */
  }
}

@media (max-width: 768px) {
  .container {
    width: min(100% - 24px, 100%);
    /* Меньше боковые отступы */
  }

  section {
    padding: 70px 0;
    /* Чуть меньше вертикальные отступы */
  }

  .topbar {
    display: none;
    /* На мобильных верхняя полоса скрывается */
  }

  .header-inner {
    min-height: 74px;
    gap: 12px;
  }

  .brand {
    gap: 10px;
    padding: 6px 8px;
  }

  .logo-mark {
    width: 54px;
    height: 54px;
  }

  .brand-text {
    max-width: 120px;
  }

  .brand-text strong {
    font-size: 14px;
  }

  .brand-text span {
    display: none;
    /* Подзаголовок бренда скрываем */
  }

  .desktop-cta,
  .header-social {
    display: none;
    /* На мобильных скрываем лишние элементы */
  }

  .menu-toggle {
    display: inline-flex;
    /* Показываем бургер */
  }

  .nav {
    position: absolute;
    top: calc(100% + 10px);
    left: 12px;
    right: 12px;

    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;

    padding: 10px;
    border-radius: 20px;

    background: var(--bg-soft);
    border: 1px solid var(--line);
    box-shadow: 0 20px 50px rgba(0, 0, 0, .22);
    /* Выпадающее мобильное меню */
  }

  .nav.open {
    display: flex;
    /* Открываем мобильное меню */
  }

  .nav a {
    padding: 14px 12px;
    border-radius: 12px;
  }

  .nav a:hover {
    background: var(--surface-3);
  }

  .hero {
    min-height: auto;
    padding: 36px 0 50px;
  }

  .hero-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .hero-title {
    font-size: 34px;
    line-height: 1.02;
    letter-spacing: -1px;
  }

  .hero-text {
    font-size: 15px;
    line-height: 1.65;
  }

  .hero-actions {
    flex-direction: column;
    align-items: stretch;
    /* Кнопки hero становятся в столбик */
  }

  .hero-actions .btn {
    width: 100%;
  }

  .hero-stats,
  .services-grid,
  .server-grid,
  .approach-grid,
  .about-points,
  .form-grid {
    grid-template-columns: 1fr;
    /* Почти всё в 1 колонку */
  }

  .case-feature,
  .case-mini,
  .about-visual {
    min-height: auto;
  }

  .gallery-prev,
  .gallery-next {
    width: 46px;
    height: 46px;
    /* Уменьшаем кнопки галереи */
  }

  .gallery-prev {
    left: 10px;
  }

  .gallery-next {
    right: 10px;
  }

  .contacts-wrap,
  .calc-wrap {
    grid-template-columns: 1fr;
    /* Контакты и калькулятор — в столбик */
  }

  .map-card iframe {
    min-height: 360px;
  }
}

@media (max-width: 480px) {
  .logo-mark {
    width: 48px;
    height: 48px;
  }

  .brand-text strong {
    font-size: 13px;
  }

  .theme-toggle {
    min-height: 44px;
    padding: 0 12px;
  }

  .theme-toggle span {
    display: none;
    /* На очень маленьком экране оставляем только иконку */
  }

  .hero-badge,
  .section-kicker,
  .panel-chip,
  .case-tag {
    font-size: 12px;
    padding: 8px 12px;
    /* Уменьшаем бейджи */
  }

  .hero-title {
    font-size: 28px;
  }

  .block-title,
  .section-title {
    word-break: break-word;
    /* Чтобы длинные слова не ломали верстку */
  }

  .service-card,
  .server-card,
  .approach-card,
  .about-card,
  .hero-panel,
  .calc-card,
  .price-card,
  .contacts-card,
  .map-card {
    padding: 18px;
    /* Уменьшаем внутренние отступы */
  }

  .social-float {
    right: 12px;
    bottom: 12px;
  }

  .social-float-link {
    width: 54px;
    height: 54px;
  }
}


/* =========================================================
   ЭФФЕКТ ПЕПЛА В БЛОКЕ КАЛЬКУЛЯТОРА
   canvas с частицами поверх блока
   ========================================================= */

.price-calc {
  position: relative;
  /* Родитель для абсолютного canvas */
  overflow: hidden;
  /* Чтобы частицы не вылезали за пределы блока */
}

/* canvas эффект */
#ashCanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  /* canvas накрывает весь блок */

  pointer-events: none;
  /* Не мешает кликам по контенту */

  opacity: .6;
  /* Полупрозрачный декоративный эффект */
}

/* SEO-блок услуг: видимый текст для поисковиков и пользователей */
.seo-service-text{
  margin-top:28px;
  padding:24px;
  border:1px solid var(--border);
  border-radius:24px;
  background:linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow:var(--shadow-soft);
}
.seo-service-text h3{margin:0 0 10px;font-size:clamp(1.15rem,2vw,1.55rem);}
.seo-service-text p{margin:8px 0;color:var(--muted);line-height:1.7;}
.seo-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;}
.seo-tags span{padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(96,165,250,.10);font-size:.92rem;color:var(--text);}

#webCanvas{
  opacity:.82;
  filter:saturate(1.08) brightness(1.02);
}
