.navbar {
  position: sticky;      /* прилипает к верху */
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(8px, 2vw, 24px);
  padding: 10px clamp(12px, 3vw, 24px);
  background: color-mix(in oklab, var(--card-bg) 85%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid color-mix(in oklab, var(--fg) 8%, transparent);
  box-shadow: 0 2px 10px rgba(0,0,0,0.04);
}

/* Логотип */
.logo {
  color: var(--fg);
  font-size: clamp(1.1rem, 2.4vw, 1.5rem);
  font-weight: 800;
  letter-spacing: 0.2px;
  white-space: nowrap;
  user-select: none;
}

/* Ссылки */
.nav-links {
  list-style: none;
  display: flex;
  align-items: center;
  gap: clamp(14px, 2.8vw, 28px);
  margin: 0;
  padding: 0;
  transition: transform .3s ease, opacity .3s ease;
}

.nav-links li a {
  position: relative;
  color: var(--fg);
  text-decoration: none;
  font-size: clamp(0.95rem, 1.6vw, 1rem);
  padding: 8px 0;
  display: block;
  transition: color .2s ease;
  outline: none;
}

/* Акцент при ховере/активе — "подчеркивание" снизу */
.nav-links li a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 0%;
  height: 2px;
  background: #6366f1; /* можно заменить на брендовый */
  transition: width .25s ease;
  border-radius: 2px;
}
.nav-links li a:hover { color: color-mix(in oklab, var(--fg) 85%, #6366f1 15%); }
.nav-links li a:hover::after,
.nav-links li a.active::after { width: 100%; }

/* Иконка-бургер (по умолчанию скрыта на десктопе) */
.menu-icon {
  display: none;
  font-size: clamp(1.4rem, 4.8vw, 2rem);
  color: var(--fg);
  cursor: pointer;
  user-select: none;
}

/* Чекбокс-хак */
.menu-toggle { display: none; }

/* ====== Мобильная навигация ====== */
@media (max-width: 860px) {
  .navbar {
    flex-wrap: wrap;
  }

  .menu-icon {
    display: block;
    z-index: 2;
    line-height: 1;
  }

  /* Меню превращаем в панель-аккордеон под шапкой */
  .nav-links {
    position: relative;
    width: 100%;
    order: 3;                /* увести под логотип/бургер */
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    margin-top: 6px;

    /* анимация раскрытия без layout jumps */
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transform: translateY(-8px);
    background: var(--card-bg);
    border: 1px solid color-mix(in oklab, var(--fg) 8%, transparent);
    border-radius: 12px;
    box-shadow: var(--shadow);
    padding: 0; /* появится при открытии */
  }

  /* открытое состояние — когда чекбокс включен */
  .menu-toggle:checked ~ .nav-links {
    max-height: 60vh;
    opacity: 1;
    transform: translateY(0);
    padding: 8px;
  }

  .nav-links li a {
    padding: 10px 12px;
    border-radius: 10px;
  }

  .nav-links li a::after { display: none; } /* убираем линию, оставим подсветку блока */
  .nav-links li a:hover,
  .nav-links li a.active {
    background: color-mix(in oklab, #6366f1 12%, transparent);
  }

  /* Ария-состояние для label (необязательно, но полезно) */
  .menu-toggle:checked + .menu-icon {
    /* можно добавить лёгкий поворот иконки, если захочешь поменять символ на × */
    /* transform: rotate(90deg); */
  }
}

/* Фокус-видимость — наследуется из общего блока, но добавим для ссылок */
.nav-links a:focus-visible {
  outline: 2px solid #6366f1;
  outline-offset: 3px;
  border-radius: 8px;
}

/* Поддержка очень широких экранов — слегка увеличим расстояние */
@media (min-width: 1400px) {
  .nav-links { gap: clamp(20px, 2vw, 36px); }
}

/* Тёмная тема — прозрачности уже считаются от var(--card-bg)/var(--fg) */
@media (prefers-color-scheme: dark) {
  .navbar {
    box-shadow: 0 2px 16px rgba(0,0,0,0.35);
  }
}

/* ========== Крупнее секция (#main) ========== */
#main {
  max-width: 1400px;                           /* было 1200px */
  width: min(98vw, 1400px);                    /* было min(96vw, 1200px) */
  margin: clamp(24px, 5vw, 48px) auto;         /* слегка больше верх/низ */
  font-family: Arial, sans-serif;
  line-height: 1.6;
  color: #333;
  background-color: #f9f9f9;
  padding: 0;
  box-shadow: 0 0 12px rgba(0,0,0,0.08);
  border-radius: 12px;
}

/* Контент: больше «воздуха» + ощутимая высота секции */
.main-content {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: clamp(20px, 5vw, 56px);                 /* было clamp(16px, 4vw, 40px) */
  width: 100%;
  padding: clamp(24px, 5vw, 64px) clamp(20px, 5vw, 64px); /* было 16–40px */
  box-sizing: border-box;
  flex-wrap: nowrap;
  min-height: clamp(420px, 52svh, 720px);      /* добавлено: визуально выше секция */
}
.main-content button,
.main-info button {
  display: inline-block;
  padding: 0.7em 2.2em;
  font-size: 1.08em;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(90deg, #6366f1 0%, #4f46e5 100%);
  border: none;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(99,102,241,0.10);
  cursor: pointer;
  transition: background .25s, transform .18s, box-shadow .25s;
  margin-top: 10px;
  letter-spacing: 0.02em;
  outline: none;
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.main-content button:hover,
.main-info button:hover,
.main-content button:focus-visible,
.main-info button:focus-visible {
  background: linear-gradient(90deg, #4f46e5 0%, #6366f1 100%);
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 6px 24px rgba(99,102,241,0.18);
}

.main-content button:active,
.main-info button:active {
  transform: scale(0.98);
  box-shadow: 0 2px 8px rgba(99,102,241,0.10);
}

.main-content button a,
.main-info button a {
  color: inherit;
  text-decoration: none;
  display: block;
  width: 100%;
  height: 100%;
}
/* Текстовая колонка */
.main-info {
  flex: 1 1 0;
  min-width: 0;
}

/* ====== Заголовок с анимациями ====== */
.main-content h1 {
  position: relative;
  margin: 0 0 12px 0;
  font-size: clamp(1.4rem, 3.2vw, 2.4rem);     /* чуть крупнее */
  color: #222;
  word-break: break-word;
  animation: fadeSlideUp .8s ease both;        /* анимация входа */
}

/* Мягкое подчёркивание при ховере */
.main-content h1::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  height: 3px;
  width: 0%;
  background: #6366f1;
  border-radius: 2px;
  transition: width .6s ease;
}
.main-content h1:hover::after {
  width: 100%;
}

/* (Опционально) лёгкий "блик" по тексту при ховере */
.main-content h1:hover {
  background-image: linear-gradient(90deg, #222 0%, #6366f1 50%, #222 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: textShimmer 1.2s linear 1;
}

/* Дата/подзаголовок */
.date {
  color: #888;
  font-size: clamp(0.95rem, 1.5vw, 1.05rem);
  margin-bottom: 10px;
}

.subtitle {
  color: #555;
  font-size: clamp(1rem, 1.9vw, 1.2rem);
  margin-bottom: clamp(16px, 3.5vw, 28px);
}

/* Картинка — колонка без фикс-жёсткости */
.main-image {
  flex: 0 1 clamp(220px, 32vw, 380px);         /* стала крупнее в верхнем пределе */
  display: flex;
  align-items: center;
  justify-content: center;
}
.main-image img {
  width: 100%;
  height: auto;
  max-width: 100%;
  border-radius: 12px;
  box-shadow: 0 3px 14px rgba(0,0,0,0.1);
  object-fit: cover;
  transition: transform .25s ease, box-shadow .25s ease;
}
.main-image img:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,0.14);
}

/* ====== Планшеты (≤ 900px) ====== */
@media (max-width: 900px) {
  .main-content {
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(14px, 4vw, 28px);
    padding: clamp(16px, 4.5vw, 28px) clamp(14px, 4vw, 24px);
    min-height: clamp(360px, 48svh, 640px);
  }
  .main-image {
    flex-basis: clamp(200px, 44vw, 320px);
  }
  .main-content h1 {
    font-size: clamp(1.2rem, 4.4vw, 1.8rem);
  }
}

/* ====== Мобилки (≤ 600px) ====== */
@media (max-width: 600px) {
  #main {
    margin: clamp(12px, 3.5vw, 18px) auto;
    border-radius: 10px;
    box-shadow: 0 0 8px rgba(0,0,0,0.07);
  }
  .main-content {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: clamp(12px, 3.5vw, 18px);
    padding: clamp(14px, 5vw, 20px) 3vw;
    min-height: unset; /* на мобиле высота пусть определяется контентом */
  }
  .main-info { width: 100%; }
  .main-image {
    width: min(92vw, 380px);                   /* стала чуть шире на мобиле */
    flex: 0 0 auto;
    margin-top: 12px;
  }
  .main-content h1 {
    font-size: clamp(1.05rem, 5.5vw, 1.35rem);
  }
  .main-content button,
  .main-info button {
    width: 100%;
    font-size: 1em;
    padding: 0.7em 0;
  }
}

/* ====== Очень маленькие экраны (≤ 400px) ====== */
@media (max-width: 400px) {
  .main-content { padding: 10px 0; }
  .main-image { width: 96vw; }
  .main-image img { width: 100%; }
}

/* Системное "меньше анимаций" — отключаем динамику */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
}

/* ====== Keyframes ====== */
@keyframes fadeSlideUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes textShimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: 0% 0; }
}

/* ====== CASES: THEME ====== */
:root {
  --cases-bg: #0f1216;
  --cases-card: #151a21;
  --cases-fg: #e9eef5;
  --cases-muted: #a8b3c7;
  --cases-accent: #7c8cff;       /* фиолетовый акцент */
  --cases-success: #16a34a;
  --cases-radius: 16px;
  --cases-shadow: 0 8px 28px rgba(0,0,0,.25);
  --cases-gap: clamp(16px, 3.6vw, 32px);
  --cases-max: 1200px;
}

/* Светлая тема (если нужна) */
@media (prefers-color-scheme: light) {
  :root {
    --cases-bg: #f7f9fc;
    --cases-card: #ffffff;
    --cases-fg: #1a1f2b;
    --cases-muted: #5b677a;
    --cases-accent: #6366f1;
    --cases-shadow: 0 8px 20px rgba(25,30,45,.08);
  }
}

/* ====== BASE ====== */
.cases {
  background:
    radial-gradient(900px 540px at 85% -240px, color-mix(in oklab, var(--cases-accent) 20%, transparent), transparent 60%),
    var(--cases-bg);
  color: var(--cases-fg);
}

.cases__inner {
  width: min(92vw, var(--cases-max));
  margin-inline: auto;
  padding: clamp(24px, 5vw, 56px) 0 clamp(32px, 6vw, 80px);
}

/* Header */
.cases__eyebrow {
  display: inline-block;
  font-size: clamp(.75rem, 1.6vw, .9rem);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cases-muted);
  margin: 0 0 8px 0;
}

.cases__title {
  position: relative;
  margin: 0 0 10px 0;
  font-size: clamp(1.25rem, 3.2vw, 2.1rem);
  line-height: 1.25;
  animation: casesFadeUp .7s ease both;
}

.cases__title::after {
  content: "";
  position: absolute;
  left: 0; bottom: -8px;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, var(--cases-accent), transparent 70%);
  border-radius: 2px;
  animation: casesUnderline 1.1s .2s ease both;
}

.cases__subtitle {
  margin: 16px 0 0;
  color: var(--cases-muted);
  font-size: clamp(.95rem, 1.8vw, 1.05rem);
}

/* Grid */
.cases__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--cases-gap);
  margin-top: clamp(18px, 4vw, 28px);
}

/* Cards */
/* ===== THEME TOKENS ===== */
:root{
  --cases-max: 1200px;
  --bg: #0f1216;
  --card: #151a21;
  --fg: #e9eef5;
  --muted: #a8b3c7;
  --accent: #6366f1;
  --success: #16a34a;
  --radius: 16px;
  --gap: clamp(16px, 3.6vw, 32px);
  --shadow: 0 8px 28px rgba(0,0,0,.25);
}
@media (prefers-color-scheme: light){
  :root{
    --bg:#f7f9fc; --card:#fff; --fg:#111827; --muted:#5b677a;
    --shadow: 0 8px 22px rgba(25,30,45,.08);
  }
}

/* ===== BASE ===== */
.cases{
  color:var(--fg);
  background:
    radial-gradient(900px 540px at 85% -240px,
      color-mix(in oklab, var(--accent) 18%, transparent), transparent 60%),
    var(--bg);
  isolation:isolate;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
}
.cases__inner{
  width:min(92vw, var(--cases-max));
  margin-inline:auto;
  padding: clamp(24px, 5vw, 56px) 0 clamp(32px, 6vw, 80px);
}

/* Header */
.cases__eyebrow{
  display:inline-block; margin:0 0 8px 0;
  font-size:clamp(.75rem, 1.6vw, .9rem);
  letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
}
.cases__title{
  margin:0 0 12px 0; line-height:1.25;
  font-size:clamp(1.25rem, 3.2vw, 2.1rem);
  position:relative; animation:fadeUp .7s ease both;
}
.cases__title::after{
  content:""; position:absolute; left:0; bottom:-8px; height:3px; width:0;
  border-radius:2px; background:linear-gradient(90deg, var(--accent), transparent 70%);
  animation:underlineGrow 1s .2s ease both;
}
.cases__subtitle{ margin:16px 0 0; color:var(--muted); font-size:clamp(.95rem,1.8vw,1.05rem); }

/* ===== GRID ===== */
.cases__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--cases-gap);
  margin-top: clamp(18px, 4vw, 28px);
}
/* ===== CARD ===== */
.cases__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--cases-gap);
  margin-top: clamp(18px, 4vw, 28px);
}

.case-card {
  grid-column: span 1;
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(16px, 3.2vw, 24px);
  border: 1px solid color-mix(in oklab, var(--fg) 8%, transparent);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  animation: cardIn .6s ease both;
}
.case-card:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 40px rgba(0,0,0,.32);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
}
.case-card--accent {
  grid-column: 1 / -1;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--accent) 10%, transparent), transparent 38%),
    var(--card);
}
.case-card__head{display:grid; gap:10px; margin-bottom:8px;}
.case-card__title{margin:0; font-size:clamp(1.05rem, 2.2vw, 1.25rem);}
.case-card__text{margin:0 0 10px 0; color:var(--muted);}

/* Chips */
.case-chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px; border-radius:999px; font-size:.85rem;
  color:var(--fg);
  background: color-mix(in oklab, var(--fg) 6%, transparent);
  border:1px solid color-mix(in oklab, var(--fg) 10%, transparent);
  user-select:none;
}
.case-chip::before{
  content:""; inline-size:8px; block-size:8px; border-radius:50%;
  background:var(--accent);
}
.case-chip--result::before{ background:var(--success); }

/* Lists (сохраняем исходный текст) */
.case-list, .case-steps, .case-checklist, .results-list{
  margin:8px 0 0; padding:0 0 0 18px;
}
.case-list li, .case-steps li, .case-checklist li, .results-list li{ margin:6px 0; }
.case-checklist{ list-style:none; padding-left:0; }
.case-checklist li{ position:relative; padding-left:24px; }
.case-checklist li::before{
  content:""; position:absolute; left:0; top:.45em;
  inline-size:14px; block-size:14px; border-radius:4px;
  background: color-mix(in oklab, var(--accent) 26%, transparent);
  border:1px solid color-mix(in oklab, var(--accent) 48%, transparent);
  box-shadow: inset 0 0 0 2px var(--card);
}

/* ===== THEME TOKENS ===== */
:root{
  --cases-max: 1200px;
  --bg: #0f1216;
  --card: #151a21;
  --fg: #e9eef5;
  --muted: #a8b3c7;
  --accent: #6366f1;
  --success: #16a34a;
  --radius: 16px;
  --gap: clamp(16px, 3.6vw, 32px);
  --shadow: 0 8px 28px rgba(0,0,0,.25);
}
@media (prefers-color-scheme: light){
  :root{
    --bg:#f7f9fc; --card:#fff; --fg:#111827; --muted:#5b677a;
    --shadow: 0 8px 22px rgba(25,30,45,.08);
  }
}

/* ===== BASE ===== */
.cases{
  color:var(--fg);
  background:
    radial-gradient(900px 540px at 85% -240px,
      color-mix(in oklab, var(--accent) 18%, transparent), transparent 60%),
    var(--bg);
  isolation:isolate;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
}
.cases__inner{
  width:min(92vw, var(--cases-max));
  margin-inline:auto;
  padding: clamp(24px, 5vw, 56px) 0 clamp(32px, 6vw, 80px);
}

/* Header */
.cases__eyebrow{
  display:inline-block; margin:0 0 8px 0;
  font-size:clamp(.75rem, 1.6vw, .9rem);
  letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
}
.cases__title{
  margin:0 0 12px 0; line-height:1.25;
  font-size:clamp(1.25rem, 3.2vw, 2.1rem);
  position:relative; animation:fadeUp .7s ease both;
}
.cases__title::after{
  content:""; position:absolute; left:0; bottom:-8px; height:3px; width:0;
  border-radius:2px; background:linear-gradient(90deg, var(--accent), transparent 70%);
  animation:underlineGrow 1s .2s ease both;
}
.cases__subtitle{ margin:16px 0 0; color:var(--muted); font-size:clamp(.95rem,1.8vw,1.05rem); }

/* ===== GRID ===== */
.cases__grid{
  display:grid; grid-template-columns:repeat(12,minmax(0,1fr));
  gap:var(--gap); margin-top:clamp(18px,4vw,28px);
}

/* ===== CARD ===== */
.case-card{
  grid-column:span 6;
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:clamp(16px, 3.2vw, 24px);
  border:1px solid color-mix(in oklab, var(--fg) 8%, transparent);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  animation:cardIn .6s ease both;
}
.case-card:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 40px rgba(0,0,0,.32);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
}
.case-card--accent{
  grid-column:span 12;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--accent) 10%, transparent), transparent 38%),
    var(--card);
}

.case-card__head{display:grid; gap:10px; margin-bottom:8px;}
.case-card__title{margin:0; font-size:clamp(1.05rem, 2.2vw, 1.25rem);}
.case-card__text{margin:0 0 10px 0; color:var(--muted);}

/* Chips */
.case-chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px; border-radius:999px; font-size:.85rem;
  color:var(--fg);
  background: color-mix(in oklab, var(--fg) 6%, transparent);
  border:1px solid color-mix(in oklab, var(--fg) 10%, transparent);
  user-select:none;
}
.case-chip::before{
  content:""; inline-size:8px; block-size:8px; border-radius:50%;
  background:var(--accent);
}
.case-chip--result::before{ background:var(--success); }

/* Lists (сохраняем исходный текст) */
.case-list, .case-steps, .case-checklist, .results-list{
  margin:8px 0 0; padding:0 0 0 18px;
}
.case-list li, .case-steps li, .case-checklist li, .results-list li{ margin:6px 0; }
.case-checklist{ list-style:none; padding-left:0; }
.case-checklist li{ position:relative; padding-left:24px; }
.case-checklist li::before{
  content:""; position:absolute; left:0; top:.45em;
  inline-size:14px; block-size:14px; border-radius:4px;
  background: color-mix(in oklab, var(--accent) 26%, transparent);
  border:1px solid color-mix(in oklab, var(--accent) 48%, transparent);
  box-shadow: inset 0 0 0 2px var(--card);
}

/* Responsive */
@media (max-width: 900px) {
  .cases__grid {
    grid-template-columns: 1fr;
  }
  .case-card,
  .case-card--accent {
    grid-column: span 1;
  }
}

/* Animations */
@keyframes fadeUp{ from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:translateY(0)} }
@keyframes underlineGrow{ from{width:0} to{width:56%} }
@keyframes cardIn{ from{opacity:0; transform:translateY(12px) scale(.98)} to{opacity:1; transform:translateY(0) scale(1)} }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .cases__title, .cases__title::after, .case-card{ animation:none !important; }
  *{ transition:none !important; }
}

/* ...existing code... */

/* ===================== FOOTER BLACK & WHITE STYLE ===================== */
.site-footer {
  background: #181818;
  color: #fff;
  border-top: 1px solid #222;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.10);
  padding: 32px 0 18px 0;
  margin-top: 48px;
  font-family: inherit;
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 4vw;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 1.2em;
  letter-spacing: 0.5px;
  transition: color .2s;
}
.brand-mark {
  background: #fff;
  color: #181818;
  border-radius: 6px;
  padding: 2px 10px;
  font-weight: 800;
  font-size: 1.1em;
  letter-spacing: 1px;
  margin-right: 6px;
  transition: background .2s, color .2s;
}
.brand-text {
  color: #fff;
  font-weight: 700;
  font-size: 1em;
  transition: color .2s;
}
.brand:hover .brand-mark,
.brand:focus-visible .brand-mark {
  background: #222;
  color: #fff;
}
.brand:hover,
.brand:focus-visible {
  color: #fff;
}
.brand:hover .brand-text,
.brand:focus-visible .brand-text {
  color: #bbb;
}

.footer-contact {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-end;
}

.phone,
.fx-link {
  color: #fff;
  font-weight: 600;
  font-size: 1.08em;
  text-decoration: none;
  transition: color .2s, text-decoration .2s;
  position: relative;
  outline: none;
  letter-spacing: 0.01em;
}
.phone:hover,
.phone:focus-visible,
.fx-link:hover,
.fx-link:focus-visible {
  color: #fff;
  text-decoration: underline;
}

.footer-bottom {
  max-width: 1200px;
  margin: 18px auto 0 auto;
  padding: 0 4vw;
  text-align: center;
  color: #bbb;
  font-size: 0.98em;
  letter-spacing: 0.02em;
}

/* Адаптивность футера */
@media (max-width: 700px) {
  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    padding: 0 3vw;
  }
  .footer-contact {
    align-items: flex-start;
    width: 100%;
    gap: 4px;
  }
  .brand {
    margin-bottom: 4px;
  }
  .footer-bottom {
    padding: 0 3vw;
    font-size: 0.93em;
  }
}

@media (max-width: 400px) {
  .footer-inner,
  .footer-bottom {
    padding: 0 1vw;
  }
  .brand-mark {
    font-size: 1em;
    padding: 2px 6px;
  }
}

/* ===================== END
/* Секция галереи */
.gallery-slider {
  max-width: 880px;
  margin: 0 auto;
  user-select: none;
}

/* Общие стили для вьюпорта */
.gallery-slider__viewport {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: #000; /* фон для contain */
}

.gallery-slider__track {
  display: flex;
  width: 100%;
  transition: transform 400ms ease-in-out;
  will-change: transform;
  align-items: center;
}

.gallery-slider__img {
  width: 100%;
  flex: 0 0 100%;
  object-position: center;

  /* Новая высота */
  height: auto;                /* фото растягивается пропорционально */
  max-height: 80vh;            /* не выше 80% экрана */
  min-height: 240px;           /* не меньше на мобильных */
}


/* === Режим 1: Полный кадр (всё видно) === */
.gallery-slider--contain .gallery-slider__img {
  height: auto;
  object-fit: contain;
}

/* === Режим 2: Без полей (на весь экран) === */
.gallery-slider--cover .gallery-slider__img {
  height: 100%;
  object-fit: cover;
}

/* Стрелки */
.gallery-slider__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: rgba(0,0,0,.45);
  color: #fff;
  border: none;
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
}
.gallery-slider__arrow--left { left: 10px; }
.gallery-slider__arrow--right { right: 10px; }

/* Точки */
.gallery-slider__dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  padding: 12px 0;
}
.gallery-slider__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  border: none;
  background: #c9c9c9;
  cursor: pointer;
}
.gallery-slider__dot.active,
.gallery-slider__dot[aria-current="true"] {
  background: #111;
}

/* Кнопка стоп */
.gallery-slider__stop {
  display: block;
  margin: 8px auto 0;
  padding: 8px 14px;
  border-radius: 10px;
  border: 1px solid #ddd;
  background: #fafafa;
  cursor: pointer;
}
.gallery-slider__title {
  text-align: center;
  font-size: 1.6rem;
  font-weight: 600;
  margin-bottom: 16px;
  color: #222;
}

/* Мобильная адаптация */
@media (max-width: 640px) {
  .gallery-slider__img {
    max-height: 60vh;   /* поменьше высота на телефонах */
    min-height: 200px;
  }
  .gallery-slider__arrow {
    padding: 8px 10px;
    border-radius: 8px;
  }
}

/* Для людей с reduce-motion */
@media (prefers-reduced-motion: reduce) {
  .gallery-slider__track { transition: none; }
}
