/* ===== tokens.css ===== */
/* ============================================================
   TobiPaczka — tokens.css
   Единый источник дизайн-токенов (этап 1).
   Меняешь значение здесь — меняется на всём сайте.
   ============================================================ */

:root {
  /* ---------- Цвет (бриф фиксирует 4 базовых) ---------- */
  --paper:        #FAFAF8; /* фон страницы (тёплый off-white) */
  --tint:         #FFF7F7; /* плашки и инфо-поля (бриф)       */
  --brand:        #E21515; /* акцент: рубрики, крупные заголовки, signature */
  --ink:          #383838; /* основной текст                 */

  /* ---------- Производные (выведены из базовых, под контраст) ---------- */
  --brand-ink:    #B11010; /* красный для ссылок/мелкого текста (контраст ≥4.5:1 на --paper) */
  --brand-dark:   #8E0C0C; /* нажатие/hover для красных кнопок */
  --ink-soft:     #6A6660; /* вторичный/мета-текст (тёплый серый) */
  --line:         #E7E3DD; /* тонкие границы (тёплый серый)   */
  --line-strong:  #D8D3CB; /* акцентированная граница         */
  --surface:      #FFFFFF; /* белые поверхности (использовать сдержанно) */
  --code-bg:      rgba(56, 56, 56, .065); /* фон для кодов/терминов */
  --brand-wash:   rgba(226, 21, 21, .08); /* лёгкая красная подложка под hover */

  --focus:        #1769C4; /* кольцо фокуса (синее — заметно на красном и на бумаге) */

  /* ---------- Типографика ---------- */
  /* Системный шрифтовой стек — 0 байт загрузки, покрывает все 26 языков.
     Явный стек (не system-ui) — безопаснее для кириллицы/греческого. */
  --font-sans: -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
               Arial, "Noto Sans", sans-serif;
  /* Моноширинный — для логистических кодов: EUR.1, EORI, Incoterms, EX-1 */
  --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo,
               Consolas, "Liberation Mono", monospace;

  /* Шкала кеглей (фон 18px для удобного чтения длинных текстов).
     Заголовки — fluid через clamp(), чтобы меньше брейкпоинтов. */
  --fs-meta:    .8125rem;  /* 13px — мета, подписи            */
  --fs-label:   .75rem;    /* 12px — рубрики-eyebrow (uppercase) */
  --fs-small:   .9375rem;  /* 15px — мелкий текст             */
  --fs-body:    1.125rem;  /* 18px — основной текст           */
  --fs-lead:    1.25rem;   /* 20px — лид-абзац                */
  --fs-h5:      1.0625rem; /* 17px                            */
  --fs-h4:      1.25rem;   /* 20px                            */
  --fs-h3:      clamp(1.375rem, 1.2rem + .9vw, 1.625rem);   /* ~22–26px */
  --fs-h2:      clamp(1.625rem, 1.35rem + 1.4vw, 2.125rem); /* ~26–34px */
  --fs-h1:      clamp(2.125rem, 1.6rem + 2.6vw, 3.125rem);  /* ~34–50px */

  --lh-tight:   1.15;  /* заголовки      */
  --lh-snug:    1.35;  /* подзаголовки   */
  --lh-body:    1.7;   /* основной текст */

  --tracking-tight: -.02em; /* плотный трекинг крупных заголовков */
  --tracking-label:  .1em;  /* разрядка рубрик                   */

  /* ---------- Отступы (шаг 4px) ---------- */
  --sp-1:  .25rem;  /* 4  */
  --sp-2:  .5rem;   /* 8  */
  --sp-3:  .75rem;  /* 12 */
  --sp-4:  1rem;    /* 16 */
  --sp-5:  1.5rem;  /* 24 */
  --sp-6:  2rem;    /* 32 */
  --sp-7:  3rem;    /* 48 */
  --sp-8:  4rem;    /* 64 */
  --sp-9:  6rem;    /* 96 */

  /* ---------- Ширины контейнеров ---------- */
  --measure:    42rem;   /* ~672px — колонка чтения статей (≈68 символов) */
  --container:  70rem;   /* ~1120px — широкие секции (сервисные страницы) */
  --gutter:     1.25rem; /* боковые поля на мобильном */

  /* ---------- Радиусы ---------- */
  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   16px;
  --r-pill: 999px;

  /* ---------- Тени (мягкие, тёплые) ---------- */
  --shadow-1: 0 1px 2px rgba(56, 40, 40, .06),
              0 2px 6px rgba(56, 40, 40, .05);
  --shadow-2: 0 4px 14px rgba(56, 40, 40, .08),
              0 2px 4px rgba(56, 40, 40, .05);

  /* ---------- Движение ---------- */
  --ease:      cubic-bezier(.22, .61, .36, 1);
  --dur-fast:  130ms;
  --dur:       200ms;

  /* ---------- z-index (шкала на будущее: меню > кнопка наверх > контент) ---------- */
  --z-base:       1;
  --z-scrolltop:  50;
  --z-header:     100;
  --z-menu:       200;
  --z-banner:     300;
}


/* ===== base.css ===== */
/* ============================================================
   TobiPaczka — base.css
   Сброс, базовая типографика, сетка, компоненты, доступность.
   Зависит от tokens.css (подключать после него).
   ============================================================ */

/* ---------- Сброс ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
  tab-size: 4;
}

body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--ink);
  background: var(--paper);
  min-height: 100svh;
  text-rendering: optimizeLegibility;
}

/* Картинки и медиа не выходят за пределы экрана */
img, picture, svg, video, canvas {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Формы наследуют шрифт */
input, button, textarea, select { font: inherit; color: inherit; }

/* Перенос длинных слов/URL, чтобы не ломать вёрстку (важно для 26 языков) */
p, li, h1, h2, h3, h4, h5, figcaption, blockquote { overflow-wrap: break-word; }

/* ---------- Типографика ---------- */
h1, h2, h3, h4, h5 {
  line-height: var(--lh-tight);
  font-weight: 700;
  color: var(--ink);
  text-wrap: balance; /* аккуратные переносы в заголовках */
}

h1 {
  font-size: var(--fs-h1);
  font-weight: 800;
  letter-spacing: var(--tracking-tight);
}
h2 {
  font-size: var(--fs-h2);
  letter-spacing: -.01em;
  line-height: var(--lh-snug);
}
h3 { font-size: var(--fs-h3); line-height: var(--lh-snug); }
h4 { font-size: var(--fs-h4); }
h5 { font-size: var(--fs-h5); }

p  { font-size: var(--fs-body); }

/* Лид-абзац (первый абзац статьи) */
.lead { font-size: var(--fs-lead); color: var(--ink); }

/* Мета / вторичный текст */
.meta { font-size: var(--fs-meta); color: var(--ink-soft); }
.small { font-size: var(--fs-small); }

/* Ссылки в тексте: тёмно-красные + подчёркивание (2 признака, не только цвет) */
a {
  color: var(--brand-ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  transition: color var(--dur-fast) var(--ease),
              text-decoration-thickness var(--dur-fast) var(--ease);
}
a:hover {
  color: var(--brand);
  text-decoration-thickness: 2px;
}

/* Списки */
ul, ol { padding-left: 1.35em; }
li + li { margin-top: .35em; }

/* Цитата / выноска */
blockquote {
  font-size: var(--fs-lead);
  line-height: var(--lh-snug);
  color: var(--ink);
  border-left: 3px solid var(--brand);
  padding: var(--sp-1) 0 var(--sp-1) var(--sp-4);
}

/* Код / логистический термин (EUR.1, EORI, Incoterms) */
code, .term {
  font-family: var(--font-mono);
  font-size: .92em;
  background: var(--code-bg);
  padding: .12em .42em;
  border-radius: var(--r-sm);
  white-space: nowrap;
}

hr {
  border: 0;
  border-top: 1px solid var(--line);
  margin: var(--sp-6) 0;
}

/* ---------- Раскладка ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.measure {
  width: 100%;
  max-width: var(--measure);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* Вертикальный ритм текста внутри статьи: интервалы задаются «потоком» */
.prose > * + * { margin-top: var(--sp-4); }
.prose > h2 { margin-top: var(--sp-7); }
.prose > h3 { margin-top: var(--sp-6); }
.prose > h2 + *, .prose > h3 + * { margin-top: var(--sp-3); }

/* ---------- Signature: speed-mark (штрихи скорости из логотипа) ---------- */
.mark {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  flex: none;
}
.mark i {
  display: block;
  height: 2px;
  background: var(--brand);
  border-radius: 1px;
  transform: skewX(-22deg);
  transform-origin: left center;
}
.mark i:nth-child(1) { width: 16px; }
.mark i:nth-child(2) { width: 11px; opacity: .8; }
.mark i:nth-child(3) { width: 6px;  opacity: .55; }

/* Крупный вариант для героя/масштабных акцентов */
.mark--lg i { height: 4px; border-radius: 2px; }
.mark--lg i:nth-child(1) { width: 34px; }
.mark--lg i:nth-child(2) { width: 23px; }
.mark--lg i:nth-child(3) { width: 12px; }

/* ---------- Рубрика-eyebrow ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--brand);
}

/* ---------- Кнопки ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  min-height: 44px;            /* зона нажатия на мобильном */
  padding: .65rem 1.25rem;
  font-size: var(--fs-small);
  font-weight: 700;
  line-height: 1;
  border-radius: var(--r-md);
  border: 1.5px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease),
              background var(--dur) var(--ease),
              border-color var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease);
}
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--brand);
  color: #fff;
  box-shadow: var(--shadow-1);
}
.btn--primary:hover {
  background: var(--brand-dark);
  color: #fff;
  text-decoration: none;
  box-shadow: var(--shadow-2);
  transform: translateY(-1px);
}

.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--line-strong);
}
.btn--ghost:hover {
  background: var(--brand-wash);
  border-color: var(--brand);
  color: var(--brand-ink);
  text-decoration: none;
}

/* ---------- Инфо-карточка / плашка (бриф: фон --tint) ---------- */
.card {
  background: var(--tint);
  border: 1px solid var(--line);
  border-left: 3px solid var(--brand);
  border-radius: var(--r-md);
  padding: var(--sp-5);
}
.card > * + * { margin-top: var(--sp-3); }
.card__title {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--fs-h5);
  font-weight: 700;
}

/* ---------- Хлебные крошки ---------- */
.crumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-meta);
  color: var(--ink-soft);
  list-style: none;
  padding: 0;
}
.crumbs li { margin: 0; display: flex; align-items: center; gap: var(--sp-2); }
.crumbs li::after { content: "›"; color: var(--line-strong); }
.crumbs li:last-child::after { content: none; }
.crumbs a { color: var(--ink-soft); text-decoration: none; }
.crumbs a:hover { color: var(--brand-ink); text-decoration: underline; }
.crumbs [aria-current="page"] { color: var(--ink); }

/* ---------- Доступность ---------- */
:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
  border-radius: 3px;
}
:focus:not(:focus-visible) { outline: none; }

/* Ссылка «перейти к содержимому» для клавиатуры/скринридеров.
   Полностью скрыта (сдвинута вверх на свою высоту), видна только при фокусе с Tab. */
.skip-link {
  position: fixed;
  left: var(--sp-3);
  top: var(--sp-3);
  z-index: var(--z-banner);
  background: var(--ink);
  color: #fff;
  padding: .6rem 1rem;
  border-radius: var(--r-md);
  text-decoration: none;
  transform: translateY(calc(-100% - var(--sp-4)));
  transition: transform var(--dur) var(--ease);
}
.skip-link:focus { transform: translateY(0); color: #fff; }

/* Видно только скринридерам */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

/* Уважение к prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
}


/* ===== components.css ===== */
/* ============================================================
   TobiPaczka — components.css
   Хедер, навигация, переключатель языка, футер, cookie-баннер,
   кнопка «Наверх». Общие для всех языковых версий.
   Зависит от tokens.css + base.css. Брейкпоинт десктоп/мобайл: 1024px.
   ============================================================ */

/* ============================================================
   ХЕДЕР
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.site-header__bar {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  min-height: 64px;
}

/* Бренд-локап: эмблема + название + слоган */
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  text-decoration: none;
  flex: none;
  margin-right: auto; /* толкает остальное вправо */
}
.brand:hover { text-decoration: none; }
.brand__mark { width: 44px; height: 44px; flex: none; }
.brand__text { display: flex; flex-direction: column; line-height: 1.05; }
.brand__name {
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -.02em;
  color: var(--ink);
}
.brand__slogan {
  font-size: .72rem;
  font-style: italic;
  color: var(--ink-soft);
  letter-spacing: .01em;
}

/* ============================================================
   ЯРУС 2: ЛЕНТА МЕНЮ
   ============================================================ */
.site-header__nav { border-top: 1px solid var(--line); }

.primary-nav__list {
  display: flex;
  flex-wrap: wrap;            /* два ряда на десктопе */
  justify-content: center;
  align-items: center;
  gap: 2px 4px;
  list-style: none;
  margin: 0 auto;
  padding: 5px var(--gutter);
  max-width: var(--container);
}
.primary-nav__list > li { margin: 0; position: relative; }
.has-sub { display: flex; align-items: center; }

.primary-nav a {
  display: inline-flex;
  align-items: center;
  height: 38px;
  padding: 0 .65rem;
  font-size: .9rem;
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  border-radius: var(--r-sm);
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.primary-nav a:hover { color: var(--brand-ink); background: var(--brand-wash); }
.primary-nav a[aria-current="page"] { color: var(--brand-ink); }

/* приглушённый суффикс-уточнение: (импорт) (экспорт) (VAT) */
.nav-tag { font-size: .8em; font-weight: 500; color: var(--ink-soft); margin-left: 4px; }
.primary-nav a:hover .nav-tag { color: var(--brand-ink); }

/* Кнопка-каретка для подменю */
.sub-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 38px;
  padding: 0;
  background: none;
  border: 0;
  color: var(--ink-soft);
  cursor: pointer;
  border-radius: var(--r-sm);
}
.sub-toggle svg { width: 13px; height: 13px; transition: transform var(--dur) var(--ease); }
.has-sub.open > .sub-toggle svg { transform: rotate(180deg); }
.sub-toggle:hover { color: var(--brand-ink); background: var(--brand-wash); }

/* Подменю */
.subnav {
  list-style: none;
  margin: 0;
  padding: var(--sp-2);
  display: none;
}
.subnav li { margin: 0; }
.subnav a {
  height: auto;
  min-height: 40px;
  width: 100%;
  padding: .5rem .7rem;
}
.has-sub.open > .subnav { display: block; }

/* ---------- Десктоп (≥1024px) ---------- */
@media (min-width: 1024px) {
  .subnav {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 230px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-2);
    z-index: var(--z-menu);
  }
  /* Открытие по наведению и по фокусу с клавиатуры */
  .has-sub:hover > .subnav,
  .has-sub:focus-within > .subnav { display: block; }
  .hamburger { display: none !important; }
}

/* ---------- Мобайл (<1024px): второй ярус → выезжающая панель ---------- */
@media (max-width: 1023.98px) {
  .site-header__nav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--surface);
    border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow-2);
    max-height: calc(100svh - 60px);
    overflow-y: auto;
  }
  .site-header.nav-open .site-header__nav { display: block; }
  .primary-nav__list {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    max-width: none;
    padding: var(--sp-2) var(--gutter) var(--sp-4);
  }
  .primary-nav__list > li { border-bottom: 1px solid var(--line); }
  .primary-nav__list > li:last-child { border-bottom: 0; }
  .primary-nav a { height: 48px; font-size: 1rem; padding: 0 var(--sp-2); }

  /* строка с парентом: ссылка + каретка в один ряд */
  .has-sub { display: grid; grid-template-columns: 1fr auto; align-items: center; }
  .has-sub > .subnav { grid-column: 1 / -1; }
  .sub-toggle { height: 48px; width: 48px; }
  .subnav { padding: 0 0 var(--sp-2) var(--sp-4); }
  .subnav a { min-height: 44px; color: var(--ink-soft); }
}

/* ============================================================
   ДЕЙСТВИЯ В ШАПКЕ (язык + гамбургер)
   ============================================================ */
.header-actions { display: flex; align-items: center; gap: var(--sp-2); flex: none; }

/* ---------- Переключатель языка ---------- */
.lang { position: relative; }
.lang__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 40px;
  padding: 0 .6rem;
  background: transparent;
  border: 1.5px solid var(--line-strong);
  border-radius: var(--r-md);
  color: var(--ink);
  font-weight: 700;
  font-size: .875rem;
  cursor: pointer;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.lang__btn:hover { border-color: var(--brand); background: var(--brand-wash); }
.lang__btn svg { width: 16px; height: 16px; }
.lang__cur { letter-spacing: .03em; }
.lang__caret { width: 12px !important; height: 12px !important; color: var(--ink-soft); transition: transform var(--dur) var(--ease); }
.lang__btn[aria-expanded="true"] .lang__caret { transform: rotate(180deg); }

.lang__menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 180px;
  list-style: none;
  margin: 0;
  padding: var(--sp-2);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-2);
  z-index: var(--z-menu);
  display: none;
}
.lang__menu.open { display: block; }
.lang__menu li { margin: 0; }
.lang__menu a {
  display: block;
  padding: .55rem .7rem;
  border-radius: var(--r-sm);
  color: var(--ink);
  text-decoration: none;
  font-size: .9375rem;
}
.lang__menu a:hover { background: var(--brand-wash); color: var(--brand-ink); }
.lang__menu a[aria-current="true"] { color: var(--brand-ink); font-weight: 700; }

/* ---------- Гамбургер ---------- */
.hamburger {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 0 10px;
  background: transparent;
  border: 1.5px solid var(--line-strong);
  border-radius: var(--r-md);
  cursor: pointer;
}
.hamburger span {
  display: block;
  height: 2px;
  width: 100%;
  background: var(--ink);
  border-radius: 2px;
  transition: transform var(--dur) var(--ease), opacity var(--dur-fast) var(--ease);
}
.site-header.nav-open .hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.site-header.nav-open .hamburger span:nth-child(2) { opacity: 0; }
.site-header.nav-open .hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   ФУТЕР
   ============================================================ */
.site-footer {
  margin-top: var(--sp-9);
  background: var(--surface);
  border-top: 3px solid var(--brand);
}
.site-footer__top {
  display: grid;
  gap: var(--sp-6);
  grid-template-columns: 1fr;
  padding-top: var(--sp-7);
  padding-bottom: var(--sp-6);
}
@media (min-width: 680px)  { .site-footer__top { grid-template-columns: 1.4fr 1fr 1fr; } }
@media (min-width: 1000px) { .site-footer__top { grid-template-columns: 1.6fr 1fr 1fr 1.2fr; } }

.site-footer__brand { display: flex; flex-direction: column; gap: var(--sp-3); }
.site-footer__brand .brand { margin-right: 0; }
.site-footer__brand p { max-width: 30ch; }

.footer-col__title {
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: var(--sp-4);
}

.footer-links { list-style: none; margin: 0; padding: 0; }
.footer-links li { margin: 0 0 var(--sp-3); }
.footer-links a {
  color: var(--ink);
  text-decoration: none;
  font-size: var(--fs-small);
}
.footer-links a:hover { color: var(--brand-ink); text-decoration: underline; }

/* соцсети */
.social { list-style: none; display: flex; flex-wrap: wrap; gap: var(--sp-3); margin: 0; padding: 0; }
.social li { margin: 0; }
.social a {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: var(--r-md);
  background: var(--paper);
  border: 1px solid var(--line);
  transition: transform var(--dur-fast) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.social a:hover { transform: translateY(-2px); border-color: var(--line-strong); box-shadow: var(--shadow-1); }
.social img { width: 22px; height: 22px; }

/* контакты */
.contacts { font-style: normal; display: flex; flex-direction: column; gap: var(--sp-3); }
.contact {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  color: var(--ink);
  text-decoration: none;
  font-size: var(--fs-small);
}
.contact img { width: 20px; height: 20px; flex: none; }
.contact:hover { color: var(--brand-ink); }
.contact:hover span { text-decoration: underline; }

.site-footer__top { padding-bottom: var(--sp-7); }

/* ============================================================
   COOKIE-БАННЕР
   ============================================================ */
.cookie {
  position: fixed;
  left: var(--gutter);
  right: var(--gutter);
  bottom: var(--gutter);
  z-index: var(--z-banner);
  max-width: 760px;
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--line);
  border-left: 3px solid var(--brand);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-2);
  transform: translateY(140%);
  opacity: 0;
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.cookie.is-visible { transform: translateY(0); opacity: 1; }
.cookie[hidden] { display: none; }
.cookie__text { flex: 1 1 300px; font-size: var(--fs-small); margin: 0; }
.cookie__actions { display: flex; gap: var(--sp-3); flex: none; }
@media (max-width: 520px) {
  .cookie__actions { width: 100%; }
  .cookie__actions .btn { flex: 1; }
}

/* ============================================================
   КНОПКА «НАВЕРХ»
   ============================================================ */
.to-top {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: var(--z-scrolltop); /* над контентом, под открытым меню */
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  padding: 0;
  background: color-mix(in srgb, var(--ink) 72%, transparent);
  color: #fff;
  border: 0;
  border-radius: var(--r-pill);
  cursor: pointer;
  box-shadow: var(--shadow-1);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease),
              visibility var(--dur) var(--ease), background var(--dur) var(--ease);
}
.to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.to-top:hover { background: var(--brand); }
.to-top svg { width: 20px; height: 20px; }


/* ===== content.css ===== */
/* ============================================================
   TobiPaczka — content.css
   Переиспользуемые блоки контентных и посадочных страниц:
   секции, hero, карточки услуг/клиентов, соцсети, контакты.
   Зависит от tokens.css + base.css.
   ============================================================ */

/* ---------- Секции и ритм ---------- */
.section { padding-block: var(--sp-7); }
.section--alt { background: var(--tint); }

/* Якорные секции не должны прятаться под липкой шапкой */
section[id] { scroll-margin-top: 84px; }
@media (min-width: 1024px) { section[id] { scroll-margin-top: 170px; } }

.section__head { margin-bottom: var(--sp-5); }
.section__head .mark { margin-bottom: var(--sp-3); }
.section__head h2 { max-width: 26ch; }

/* ---------- Hero (секция 1) ---------- */
.hero .mark { margin-bottom: var(--sp-4); }
.hero h1 { margin-bottom: var(--sp-5); max-width: 18ch; }
.hero p { max-width: 64ch; }
.hero p + p { margin-top: var(--sp-4); }
.clients-intro { margin-top: var(--sp-5); margin-bottom: var(--sp-4); }

/* Карточки категорий клиентов */
.client-grid { display: grid; gap: var(--sp-4); grid-template-columns: 1fr; }
@media (min-width: 680px) { .client-grid { grid-template-columns: repeat(3, 1fr); } }
.client-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-left: 3px solid var(--brand);
  border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-5);
}
.client-card strong { color: var(--ink); }

/* ---------- Медиа-фигура (секция 2) ---------- */
.media-figure { margin: 0; display: flex; justify-content: center; }
.media-figure img {
  width: 480px; max-width: 100%; height: auto;
  border-radius: var(--r-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-1);
}

/* ---------- Карточки услуг (секция 3) ---------- */
.services { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; }
@media (min-width: 760px) { .services { grid-template-columns: repeat(2, 1fr); } }
.service {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-5) var(--sp-6);
}
.service h3 { font-size: var(--fs-h4); margin-bottom: var(--sp-3); line-height: var(--lh-snug); }
.service h3 a {
  color: var(--brand-ink); text-decoration: none;
}
.service h3 a:hover { color: var(--brand); }
.service__arrow { display: inline-block; margin-left: .15em; transition: transform var(--dur) var(--ease); }
.service h3 a:hover .service__arrow { transform: translateX(3px); }
.service p { margin-bottom: var(--sp-3); }
.service p:last-child { margin-bottom: 0; }
.service ul { margin-top: var(--sp-3); margin-bottom: 0; }

/* ---------- Соцсети (секция 4) ---------- */
.social-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--sp-5); }
.social-list li { display: flex; gap: var(--sp-4); align-items: flex-start; }
.social-list__icon {
  flex: none; width: 44px; height: 44px; display: grid; place-items: center;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md);
}
.social-list__icon img { width: 24px; height: 24px; }
.social-list__body { max-width: 70ch; }
.social-list__body a { text-decoration: none; }
.social-list__body a strong { color: var(--brand-ink); }
.social-list__body a:hover strong { text-decoration: underline; color: var(--brand); }

/* ---------- Контакты (секция 5) ---------- */
.contacts-block { font-style: normal; display: flex; flex-direction: column; gap: var(--sp-4); max-width: 72ch; }
.contacts-block a { font-weight: 600; }
.msg-buttons { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin: var(--sp-1) 0; }
