/* ==========================================
   ЭТАП 1 — статичный каркас, desktop only
   Анимации и responsive — Этап 2+
   ========================================== */

/* ==========================================
   CUSTOM PROPERTIES — портальная специфика.
   КАНОН (палитра/нейтрали/радиусы/тени/glass/
   шрифты/motion) подключается ПЕРЕД этим файлом:
   design/tokens.css. Здесь только то, чего нет
   в каноне, и алиасы легаси-имён портала.
   ========================================== */
:root {
  /* Алиасы легаси-имён → канон (Р4: нейтрали зелёно-серые SaaS) */
  --ink-muted: var(--muted);
  --ink-faint: var(--faint);
  --font:      var(--font-ui);

  /* Borders (портальная специфика) */
  --border:       rgba(28, 28, 26, 0.10);
  --border-mid:   rgba(28, 28, 26, 0.15);

  /* Glass навбара: фон — канонный --glass-cream; blur портальный
     (16px мягче канонных 20px — под кремовое стекло поверх hero) */
  --glass-bg:   var(--glass-cream);
  --glass-blur: blur(16px) saturate(1.1);

  /* Layout */
  --max-w:        1200px;
  --nav-h:        64px;
  --ticker-h:     34px;
  --section-pad:  5rem;

  /* Ticker — длительность хода перезаписывается из JS под постоянную скорость */
  --ticker-dur:   60s;
}

/* ==========================================
   RESET
   ========================================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  /* Якоря не подныривают под фикс-навбар; с тикером — под навбар + тикер */
  scroll-padding-top: var(--nav-h);
  /* full-bleed декор (.hero::before свечение, left:-330px) пробивает overflow-x:hidden
     на body — он не доходит до documentElement. clip обрезает на уровне html и
     убирает 12px горизонтального скролла на mobile/tablet, не создавая скролл-контейнер
     (в отличие от hidden — sticky-навбар продолжает работать). */
  overflow-x: clip;
}
html.has-ticker {
  scroll-padding-top: calc(var(--nav-h) + var(--ticker-h));
}

body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
svg { display: block; }

/* ==========================================
   FOCUS VISIBLE — keyboard navigation a11y
   :focus-visible срабатывает только при клавиатуре, не мыши
   ========================================== */

/* Снимаем дефолтный outline со всех интерактивных */
:is(.btn, .navbar__link, .portal-card, .link-arrow, .footer__link) {
  outline: none;
}

/* Единый focus-ring: forest, 2px, аккуратный отступ */
:is(.btn, .navbar__link, .portal-card, .link-arrow, .footer__link):focus-visible {
  outline: 2px solid var(--forest);
  outline-offset: 3px;
}

/* На тёмном фоне (final-cta) — forest плохо читается → sage */
.final-cta .btn--outline:focus-visible {
  outline-color: var(--sage);
}

/* ==========================================
   REDUCED MOTION — контент сразу виден,
   никаких transform/opacity-заморозок
   ========================================== */
@media (prefers-reduced-motion: reduce) {
  .reveal-line {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important; /* shimmer тоже отключён */
  }
  .hero .section-label,
  .hero__sub,
  .hero__actions {
    opacity: 1 !important;
    transform: none !important;
  }
  .final-cta .btn--outline::after {
    animation: none !important;
  }
  /* Hover: убираем движение, оставляем цвет/тень */
  .btn--primary:hover       { transform: none; }
  .btn--primary:active      { transform: none; }
  .btn--outline:hover       { transform: none; }
  .btn--ghost:hover svg     { transform: none; }
  /* Блок 5 П3: лифт карточек и сдвиг стрелок без движения */
  .article-card:hover,
  .term-card:hover          { transform: none; }
  .article-card:hover .article-card__arrow,
  .portal-card:hover .portal-card__arrow { transform: none; }
}

/* ==========================================
   UTILITIES
   ========================================== */
.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 2.5rem;
}

.section-label {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sage);
  margin-bottom: 1.5rem;
}

.section-heading {
  font-size: clamp(1.875rem, 3vw, 2.625rem);
  font-weight: 300;
  letter-spacing: -0.028em;
  line-height: 1.12;
  color: var(--ink);
  margin-bottom: 1rem;
}

/* Каждая строка заголовка — блок со градиентом.
   background-clip:text на самом спане избегает конфликта с GSAP opacity */
.hero__heading .reveal-line {
  display: block;
  /* Градиент forest → sage → forest */
  background: linear-gradient(
    90deg,
    var(--forest)  0%,
    var(--sage)   50%,
    var(--forest) 100%
  );
  background-size: 200% auto;
  background-position: 0% 50%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  /* Shimmer — запускается после reveal (~1.0s), медленно */
  animation: hero-shimmer 3.5s ease-in-out infinite;
  animation-delay: 1.0s;
}

@keyframes hero-shimmer {
  0%   { background-position: 0%   50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0%   50%; }
}

.link-arrow {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--forest);
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
  transition: gap var(--dur) var(--ease-out), text-decoration-color var(--dur) var(--ease-out);
}
.link-arrow:hover {
  gap: 0.625rem;
  text-decoration-color: currentColor;
}

/* ==========================================
   BUTTONS
   ========================================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font);
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1;
  border-radius: var(--r-btn); /* Р3: канон 10px (был 6px) */
  padding: 0.875rem 1.375rem;  /* канон 14px 22px (COMPONENTS.md §1; было 14/28) */
  cursor: pointer;
  border: none;
  transition: opacity var(--dur) var(--ease-out), background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out), transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
  white-space: nowrap;
}

/* Primary — forest fill */
.btn--primary {
  background: var(--forest);
  color: var(--cream);
}
.btn--primary:hover {
  background: var(--forest-hover);
  transform: translateY(-2px);
  box-shadow: var(--glow-forest);
}
/* Блок 5 П6: тактильный отклик нажатия — как .btn.primary:active в SaaS.
   Строго ПОСЛЕ :hover (одинаковая специфичность — побеждает поздний). */
.btn--primary:active {
  transform: translateY(0) scale(0.99);
}

/* Ghost — plain text link, desktop visual weight much lower than primary */
.btn--ghost {
  background: transparent;
  color: var(--ink-muted);
  padding-left: 0;
  padding-right: 0;
  border-radius: 0;
}
.btn--ghost:hover { color: var(--forest); }

.btn--ghost svg {
  transition: transform var(--dur) var(--ease-out);
}
.btn--ghost:hover svg {
  transform: translateX(4px);
}

/* Outline — for dark backgrounds */
.btn--outline {
  background: transparent;
  color: var(--cream);
  border: 1.5px solid rgba(245, 242, 236, 0.45);
}
.btn--outline:hover {
  border-color: var(--cream);
  background: rgba(245, 242, 236, 0.08);
  transform: translateY(-2px);
  box-shadow: var(--glow-sage);
}

/* Size variants */
.btn--sm  { font-size: 0.8125rem; padding: 0.625rem 1.25rem; }
.btn--lg  { font-size: 1rem; padding: 1.125rem 2.25rem; }

/* ==========================================
   NAVBAR
   ========================================== */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: var(--nav-h);
  /* Glass — works here because hero content scrolls beneath it */
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--border);
  transition: background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}

/* Scroll state — слегка плотнее когда под навбаром проезжает контент */
.navbar--scrolled {
  background: rgba(245, 242, 236, 0.86);
  border-bottom-color: rgba(28, 28, 26, 0.12);
  box-shadow: var(--shadow-1);
}

.navbar__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 2.5rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Burger + mobile CTA hidden on desktop, shown via media query below */
.navbar__burger,
.navbar__mobile-cta {
  display: none;
}

.navbar__logo {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
}

/* Бренд-знак рядом с текстом лого. Размер в em → масштабируется от font-size
   родителя. Цвет НЕ наследуется: слитки залиты хардкодом прямо в
   <symbol id="brand-mark"> (sage → #458066 → forest), см. index.html. */
.brand-mark {
  flex: none;
  width: 1.15em;
  height: 1.15em;
}

.navbar__links {
  display: flex;
  align-items: center;
  gap: 2.5rem;
}

.navbar__link {
  font-size: 0.875rem;
  color: var(--ink-muted);
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
  transition: color var(--dur) var(--ease-out), text-decoration-color var(--dur) var(--ease-out);
}
.navbar__link:hover {
  color: var(--forest);
  text-decoration-color: currentColor;
}
.navbar__link:focus-visible {
  color: var(--forest);
  text-decoration-color: currentColor;
}

/* ==========================================
   PRICE TICKER — фикс-полоса под навбаром.
   Чистая плашка (НЕ стекло): мелкие моноцифры читаются по плоскому фону,
   и над тикером уже стеклянный навбар — два блюра подряд дали бы «грязь».
   Marquee — чистый CSS @keyframes на transform (compositor, без main-thread).
   ========================================== */
.ticker {
  position: fixed;
  top: var(--nav-h);
  left: 0; right: 0;
  z-index: 99;                 /* под навбаром (100) — тень scroll-state ложится сверху */
  height: var(--ticker-h);
  display: flex;
  align-items: stretch;
  overflow: hidden;            /* клипует уезжающий трек */
  background: var(--forest);   /* forest-плашка (дефолт) */
  color: var(--cream);
  border-bottom: 1px solid rgba(28, 28, 26, 0.14);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  user-select: none;
  --ticker-edge: var(--forest); /* цвет растворения краёв (под вариант плашки) */
}

/* Скрыт до загрузки данных (класс .ticker перебивает UA-правило [hidden]) */
.ticker[hidden] { display: none; }

/* Левый пиннованный лейбл — не едет, честная подпись + дата */
.ticker__label {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  padding: 0 1.1rem;
  background: var(--forest);
  color: rgba(245, 242, 236, 0.58);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  border-right: 1px solid rgba(245, 242, 236, 0.16);
}

/* Окно прокрутки */
.ticker__viewport {
  position: relative;
  flex: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* Мягкое растворение на краях: полуслова на въезде/съезде гаснут в цвет полосы,
   а не обрезаются резко (marquee-клип читался бы как «текст вылез за слот»). */
.ticker__viewport::before,
.ticker__viewport::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 38px;
  z-index: 2;
  pointer-events: none;
}
.ticker__viewport::before {
  left: 0;
  background: linear-gradient(90deg,  var(--ticker-edge), transparent);
}
.ticker__viewport::after {
  right: 0;
  background: linear-gradient(270deg, var(--ticker-edge), transparent);
}

/* Трек = два идентичных набора подряд; едет на -50% → бесшовная склейка.
   linear (НЕ --ease: --ease == ease, для биржевого хода нужна равномерность). */
.ticker__track {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  white-space: nowrap;
  will-change: transform;
  animation: ticker-scroll var(--ticker-dur) linear infinite;
}

/* Пауза по hover — чистый CSS, 0 JS */
.ticker:hover .ticker__track {
  animation-play-state: paused;
}

@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.ticker__set {
  display: flex;
  align-items: center;
}

.ticker__item {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
  padding: 0 1.5rem;
  border-right: 1px solid rgba(245, 242, 236, 0.12);
  cursor: default;
}
.ticker__name  { color: rgba(245, 242, 236, 0.80); font-weight: 400; }
.ticker__price { color: var(--cream); font-weight: 500; }
.ticker__unit  { color: rgba(245, 242, 236, 0.45); font-size: 0.6875rem; }

/* ── Кремовый вариант плашки ─────────────────────────────────────────────
   Переключить глазами: добавить класс ticker--cream на <div class="ticker">. */
.ticker--cream {
  background: var(--cream);
  color: var(--ink);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border-mid);
  --ticker-edge: var(--cream);
}
.ticker--cream .ticker__label {
  background: var(--cream);
  color: var(--ink-faint);
  border-right-color: var(--border);
}
.ticker--cream .ticker__item  { border-right-color: var(--border); }
.ticker--cream .ticker__name  { color: var(--ink-muted); }
.ticker--cream .ticker__price { color: var(--ink); }
.ticker--cream .ticker__unit  { color: var(--ink-faint); }

/* ── Стеклянный вариант плашки (для сравнения) ───────────────────────────
   Переключить: добавить класс ticker--glass на <div class="ticker">.
   ⚠️ Читаемость: на rgba(forest,0.6)+blur светлые .ticker__name (cream 80%) и
   .ticker__unit (45%) теряют контраст против плотного forest — цифры .ticker__price
   держатся, но строка в целом «мягче». Над тикером уже стеклянный навбар, но они
   НЕ перекрываются по пикселям (навбар 0–64px, тикер 64–98px) → двойного блюра нет.
   В покое размывать почти нечего (под полосой кремовый отступ Hero) — стекло здесь
   оживает только при скролле. Решение — глазами. */
.ticker--glass {
  background: rgba(46, 87, 66, 0.60);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-bottom: 1px solid rgba(245, 242, 236, 0.18);
  --ticker-edge: rgba(46, 87, 66, 0.60);
}
.ticker--glass .ticker__label {
  background: rgba(46, 87, 66, 0.60);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
}

/* Тултип источника — отдельный элемент в <body>, вне overflow тикера */
.ticker-tip {
  position: fixed;
  z-index: 200;                /* выше навбара */
  /* left/top задаёт JS, уже с учётом ширины плашки → не вылезает за вьюпорт */
  padding: 0.4rem 0.65rem;
  background: var(--forest);
  color: var(--cream);
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  line-height: 1.35;
  border-radius: var(--r-sm); /* схлопнуто 6→8 (Р3) */
  /* Мягкая тень: отделяет forest-плашку от кремового фона и полосы.
     Схлопнуто в --shadow-2 (было двухслойное 0 8px 22px .22 / 0 2px 6px .14 — чуть плотнее) */
  box-shadow: var(--shadow-2);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur) var(--ease-out); /* микро-канон 0.22s (был 0.16s) */
  white-space: normal;         /* длинный источник переносится в пределах max-width */
  max-width: 280px;
}
.ticker-tip--show { opacity: 1; }
.ticker-tip__src  { color: var(--sage); }

/* prefers-reduced-motion: строка НЕ едет, но данные доступны прокруткой рукой */
@media (prefers-reduced-motion: reduce) {
  .ticker__track {
    animation: none;
    transform: none;
  }
  .ticker__viewport { overflow-x: auto; }
  .ticker__set--dup { display: none; } /* дубль не нужен без анимации */
}

/* Мобильный: тикер бежит как на десктопе, чуть плотнее */
@media (max-width: 640px) {
  .ticker__item  { padding: 0 1.1rem; }
  .ticker__label { padding: 0 0.8rem; }
}

/* ==========================================
   READ-PROGRESS (Блок 5 П5) — прогресс чтения статьи.
   Элемент создаёт js/main.js ТОЛЬКО на страницах статей и только при
   разрешённом motion (gsap.matchMedia) — при reduced-motion полосы нет вовсе.
   ========================================== */
.read-progress {
  position: fixed;
  top: var(--nav-h);
  left: 0; right: 0;
  height: 2px;
  z-index: 98;                 /* под тикером (99) и навбаром (100) */
  background: var(--forest);
  transform: scaleX(0);
  transform-origin: left center;
  pointer-events: none;
}
html.has-ticker .read-progress {
  top: calc(var(--nav-h) + var(--ticker-h));
}

/* ==========================================
   HERO
   ========================================== */
.hero {
  position: relative;
  display: flex;
  align-items: flex-start;
  overflow: hidden;
}

/* Ambient glow — barely visible depth accent */
.hero::before {
  content: '';
  position: absolute;
  width: 900px;
  height: 900px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(46, 87, 66, 0.07) 0%,
    transparent 62%
  );
  top: -260px;
  right: -180px;
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: 1;
  padding-top:    calc(var(--nav-h) + 5rem);
  padding-bottom: 4.5rem;
}

/* Тикер активен → освобождаем место под полосу. Класс вешает JS только после
   успешной загрузки данных: при сбое fetch полосы нет и отступ не растёт. */
html.has-ticker .hero__inner {
  padding-top: calc(var(--nav-h) + var(--ticker-h) + 5rem);
}

.hero__heading {
  font-size: clamp(3rem, 7.5vw, 6rem);
  font-weight: 300;
  line-height: 1.04;
  letter-spacing: -0.038em;
  max-width: 700px;
  margin-bottom: 2rem;
  /* Цвет задаётся через .reveal-line (background-clip:text + gradient) */
}

.hero__sub {
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.65;
  color: var(--ink-muted);
  max-width: 440px;
  margin-bottom: 3rem;
}

.hero__actions {
  display: flex;
  align-items: center;
  gap: 2rem;
}

/* ==========================================
   PORTAL
   ========================================== */
.portal {
  padding: var(--section-pad) 0;
}

.portal__header {
  max-width: 560px;
  margin-bottom: 3.5rem;
}

.portal__sub {
  font-size: 1rem;
  color: var(--ink-muted);
  line-height: 1.6;
  margin-top: 0.75rem;
}

/* 4-column card grid with hairline dividers */
.portal__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  /* gap убран: разделители теперь border-right на карточках,
     чтобы серый фон сетки не просвечивал при GSAP initial state (y:24) */
  background: var(--cream);
  border: 1px solid var(--border-mid);
  border-radius: var(--r-lg); /* схлопнуто 14→16 (Р3) */
  overflow: hidden;
}

.portal-card:not(:last-child) {
  border-right: 1px solid var(--border-mid);
}

.portal-card {
  background: var(--cream);
  padding: 2.75rem 2rem 2.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  transition: background var(--dur) var(--ease-out);
  cursor: pointer;
}
.portal-card:hover {
  background: rgba(46, 87, 66, 0.05);
}

.portal-card__name {
  font-size: 1rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
}

.portal-card__desc {
  font-size: 0.875rem;
  color: var(--ink-muted);
  line-height: 1.55;
  flex: 1;
}

.portal-card__arrow {
  font-size: 1.125rem;
  color: var(--sage);
  display: inline-block;
  margin-top: 0.75rem;
  transition: transform var(--dur) var(--ease-out);
}
.portal-card:hover .portal-card__arrow {
  transform: translateX(4px); /* П3: единый сдвиг акцента 4px. Лифт карточки
    намеренно НЕ применён: .portal__grid — сплошной бордер-бокс с overflow:hidden,
    подъём обрезался бы (перестройка сетки = редизайн, не полировка). */
}

.portal__footer {
  margin-top: 2.25rem;
  display: flex;
  justify-content: flex-end;
}

/* ==========================================
   BRIDGE (placeholder)
   ========================================== */
.bridge {
  background: var(--forest);
  padding: 5rem 0;
}

.bridge__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.75rem;
}

/* Hook — крупная провокационная строка */
.bridge__text {
  font-size: clamp(1.5rem, 4vw, 2.75rem);
  font-weight: 300;
  font-style: italic;
  letter-spacing: -0.02em;
  line-height: 1.18;
  color: var(--cream);
  max-width: 680px;
}

/* Вторая часть хука — держится в одну строку на десктопе */
.bridge__nowrap {
  white-space: nowrap;
}

/* Pivot — тихий разворот к продукту */
.bridge__sub {
  font-size: clamp(0.9375rem, 1.5vw, 1.125rem);
  font-weight: 400;
  color: rgba(245, 242, 236, 0.65);
  line-height: 1.65;
  max-width: 520px;
}

/* ==========================================
   SYSTEM
   ========================================== */
.system {
  padding: var(--section-pad) 0;
}

.system__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5.5rem;
  align-items: center;
}

.system__content .section-heading {
  margin-bottom: 2.75rem;
}

/* Feature list */
.system__features {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-bottom: 3rem;
}

.system__feature {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
}

.system__feature-num {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--sage);
  padding-top: 0.2rem;
  flex-shrink: 0;
  min-width: 1.75rem;
}

.system__feature strong {
  display: block;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 0.3rem;
}

.system__feature p {
  font-size: 0.875rem;
  color: var(--ink-muted);
  line-height: 1.6;
}

/* ---- Mockup shell ---- */
.mockup {
  background: var(--white);
  border-radius: var(--r-lg); /* схлопнуто 14→16 (Р3) */
  border: 1px solid var(--border-mid);
  overflow: hidden;
  box-shadow: var(--shadow-3);
}

.mockup__bar {
  height: 38px;
  background: var(--bg-alt);
  display: flex;
  align-items: center;
  padding: 0 1rem;
  gap: 6px;
  border-bottom: 1px solid var(--border);
}

.mockup__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(28, 28, 26, 0.14);
}

.mockup__body {
  display: flex;
  height: 360px;
}

.mockup__sidebar {
  width: 68px;
  background: var(--bg-2);
  border-right: 1px solid var(--border);
  padding: 1.25rem 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mockup__nav-item {
  height: 30px;
  border-radius: var(--r-sm); /* схлопнуто 6→8 (Р3) */
  background: rgba(28, 28, 26, 0.08);
}

.mockup__nav-item--active {
  background: rgba(46, 87, 66, 0.18);
}

.mockup__content {
  flex: 1;
  padding: 1.5rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  overflow: hidden;
}

.mockup__row {
  height: 12px;
  border-radius: var(--r-xs);
  background: rgba(28, 28, 26, 0.08);
}

.mockup__row--heading {
  width: 42%;
  height: 16px;
  background: rgba(28, 28, 26, 0.16);
}

.mockup__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.mockup__stat {
  height: 58px;
  border-radius: var(--r-sm);
  background: rgba(28, 28, 26, 0.06);
  border: 1px solid var(--border);
}

/* Chart area — sage tint to suggest data viz */
.mockup__chart {
  flex: 1;
  border-radius: var(--r-sm);
  background: linear-gradient(
    180deg,
    rgba(95, 169, 131, 0.14) 0%,
    rgba(95, 169, 131, 0.03) 100%
  );
  border: 1px solid rgba(95, 169, 131, 0.18);
  min-height: 70px;
}

.mockup__table {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.mockup__table-row {
  height: 26px;
  border-radius: var(--r-xs);
  background: rgba(28, 28, 26, 0.06);
}

.mockup__table-row--header {
  background: rgba(28, 28, 26, 0.11);
}

/* ==========================================
   FINAL CTA
   ========================================== */
.final-cta {
  background: var(--forest);
  padding: 7rem 0;
}

.final-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2.75rem;
}

.final-cta__heading {
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 300;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--cream);
}

/* Стартовое состояние reveal — ТОЛЬКО пока висит класс .cta-prep (его вешает
   JS синхронно при разрешённом motion). Без класса элементы видимы по дефолту:
   любой сбой JS/GSAP/CDN или reduced-motion → reveal не прячет ничего.
   Анимация снимает inline opacity/transform поверх и затем снимает класс. */
.final-cta.cta-prep .final-cta__heading {
  opacity: 0;
  transform: translateY(var(--reveal-y)); /* канон y:16 (был 18px) */
}
.final-cta.cta-prep .btn--outline {
  opacity: 0;
  transform: translateY(var(--reveal-y));
}

/* Idle pulse-glow — единственная idle-анимация на странице.
   Псевдо-элемент с фиксированным box-shadow; дышит только opacity → compositor only. */
.final-cta .btn--outline {
  position: relative;
}

.final-cta .btn--outline::after {
  content: '';
  position: absolute;
  inset: -8px;
  border-radius: calc(var(--r-btn) + 8px); /* радиус кнопки + 8px inset */
  box-shadow:
    0 0 18px 4px  rgba(95, 169, 131, 0.48),
    0 0 38px 10px rgba(95, 169, 131, 0.16);
  opacity: 0;
  pointer-events: none;
  animation: cta-pulse 2.8s ease-in-out infinite;
}

/* Во время входного reveal секции пульс выключен (класс навешивает JS только
   при разрешённом motion); после reveal класс снят → пульс стартует с 0% и
   плавно разгорается. При reduced-motion класс не ставится → правило не
   срабатывает, пульс крутится как раньше. */
.final-cta.cta-revealing .btn--outline::after {
  animation: none;
  opacity: 0;
}

@keyframes cta-pulse {
  0%, 100% { opacity: 0;    }
  50%      { opacity: 1;    }
}

/* ==========================================
   FOOTER
   ========================================== */
.footer {
  border-top: 1px solid var(--border-mid);
  padding: 2rem 0;
}

.footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.footer__logo {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
}

.footer__nav {
  display: flex;
  gap: 2.25rem;
}

.footer__link {
  font-size: 0.875rem;
  color: var(--ink-muted);
  transition: color var(--dur) var(--ease-out);
}
.footer__link:hover { color: var(--ink); }

.footer__copy {
  font-size: 0.8125rem;
  color: var(--ink-faint);
}

/* ==========================================
   RESPONSIVE — mobile / narrow viewport
   ========================================== */

/* ── 768px: планшет и ниже ─────────────── */
@media (max-width: 768px) {

  :root {
    --section-pad: 4rem;
  }

  .container {
    padding: 0 1.5rem;
  }

  /* Navbar burger — visible on mobile */
  .navbar__burger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px 4px;
    outline: none;
  }
  .navbar__burger:focus-visible {
    outline: 2px solid var(--forest);
    outline-offset: 3px;
    border-radius: var(--r-xs); /* схлопнуто 3→4 (Р3) */
  }
  .navbar__burger span {
    display: block;
    width: 20px;
    height: 1.5px;
    background: var(--ink);
    transition: transform var(--dur) var(--ease-out), opacity var(--dur) var(--ease-out);
  }

  /* Animate burger → X when open */
  .navbar--open .navbar__burger span:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
  }
  .navbar--open .navbar__burger span:nth-child(2) {
    opacity: 0;
  }
  .navbar--open .navbar__burger span:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
  }

  /* Links dropdown — opacity+transform, не display:none, чтобы анимировать */
  .navbar__links {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    position: absolute;
    top: var(--nav-h);
    left: 0; right: 0;
    background: rgba(245, 242, 236, 0.96);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-bottom: 1px solid var(--border-mid);
    padding: 0.5rem 0;
    /* Closed state */
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
    transition: opacity var(--dur-md) var(--ease-out), transform var(--dur-md) var(--ease-out); /* мобильное меню — средний канон 0.25s */
  }
  .navbar--open .navbar__links {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .navbar__link {
    padding: 0.875rem 1.5rem;
    font-size: 0.9375rem;
    text-decoration: none;
  }
  .navbar__link:hover {
    text-decoration-color: transparent;
    color: var(--forest);
  }

  /* Hide desktop CTA button in navbar on mobile */
  .navbar__cta {
    display: none;
  }

  /* Mobile CTA — primary кнопка в дропдауне */
  .navbar__mobile-cta {
    display: inline-flex;
    margin: 0.75rem 1.5rem 1rem;
  }

  /* System: stack columns */
  .system__inner {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
}

/* ── 640px: телефон (широкий) ──────────── */
@media (max-width: 640px) {

  :root {
    --section-pad: 3.25rem;
  }

  /* Bridge: снимаем жёсткий перенос и nowrap — текст течёт свободно */
  .bridge__br     { display: none; }
  .bridge__nowrap { white-space: normal; }

  /* Hero heading: smaller clamp range */
  .hero__heading {
    font-size: clamp(2.25rem, 9vw, 3.25rem);
  }

  /* Hero actions: wrap on small screens */
  .hero__actions {
    flex-wrap: wrap;
    gap: 1rem;
  }

  /* Portal grid: 2 columns */
  .portal__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Reset desktop right-border rule, set 2-col dividers */
  .portal-card:not(:last-child) {
    border-right: none;
  }
  .portal-card:nth-child(odd) {
    border-right: 1px solid var(--border-mid);
  }
  /* Row 1 bottom border */
  .portal-card:nth-child(-n+2) {
    border-bottom: 1px solid var(--border-mid);
  }

  /* Tighter card padding in 2-col */
  .portal-card {
    padding: 1.75rem 1.25rem 1.5rem;
  }

  /* Footer: stack vertically */
  .footer__inner {
    flex-direction: column;
    gap: 1.25rem;
    text-align: center;
  }
  .footer__nav {
    gap: 1.5rem;
  }
}

/* ==========================================
   ARTICLES LIST — страница articles.html
   Воздушная сетка карточек: НЕ плотный .portal__grid
   (тот бордер-бокс без gap), а индивидуальная рамка
   на каждой карточке + gap = воздух. Визуальный язык
   карточки (hover-залив, sage-стрелка, типографика,
   токены) — тот же, что у .portal-card.
   ========================================== */

/* Первая секция вместо hero: сама держит отступ под
   фикс-навбар (+ тикер, когда html.has-ticker от JS). */
.articles {
  padding: calc(var(--nav-h) + 3.5rem) 0 var(--section-pad);
}
html.has-ticker .articles {
  padding-top: calc(var(--nav-h) + var(--ticker-h) + 3.5rem);
}

.articles__head {
  max-width: 600px;
  margin-bottom: 2.5rem;
}
.articles__sub {
  font-size: 1rem;
  color: var(--ink-muted);
  line-height: 1.6;
  margin-top: 0.75rem;
}

/* Фильтр — один горизонтальный ряд пилюль */
.filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 2.5rem;
}
/* Рецепт .pill из SaaS (COMPONENTS.md §3): мягкий фон + цвет, без рамки.
   Радиус остаётся капсульным --r-pill — контекст фильтра (зафиксировано). */
.filter-pill {
  font-family: var(--font);
  font-size: 0.8125rem;
  color: var(--accent);
  background: var(--accent-soft);
  border: none;
  border-radius: var(--r-pill);
  padding: 0.5rem 1.1rem;
  cursor: pointer;
  transition: color var(--dur) var(--ease-out),
              background var(--dur) var(--ease-out);
}
.filter-pill:hover {
  background: rgba(46, 87, 66, 0.16);
}
.filter-pill--active {
  color: var(--cream);
  background: var(--forest);
}

/* Воздушная сетка 3 → 2 → 1 */
.articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.article-card {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-lg); /* схлопнуто 14→16 (Р3) */
  padding: 1.75rem;
  text-decoration: none;
  transition: background var(--dur) var(--ease-out),
              border-color var(--dur) var(--ease-out),
              transform var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
/* Блок 5 П3: единый hover-характер карточек — лифт -2px + --shadow-2 (канон) */
.article-card:hover {
  background: rgba(46, 87, 66, 0.05);
  border-color: var(--border-mid);
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}
.article-card[hidden] { display: none; }

.article-card__tag {
  font-size: 0.75rem;
  letter-spacing: 0.01em;
  color: var(--sage);
}
.article-card__name {
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.article-card__desc {
  font-size: 0.875rem;
  color: var(--ink-muted);
  line-height: 1.55;
  flex: 1;
}

/* Подвал карточки: время чтения (моноцифры) + sage-стрелка */
.article-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.75rem;
}
.article-card__meta {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--ink-faint);
}
.article-card__arrow {
  font-size: 1.125rem;
  color: var(--sage);
  transition: transform var(--dur) var(--ease-out);
}
.article-card:hover .article-card__arrow {
  transform: translateX(4px); /* П3: единый сдвиг акцента 4px */
}

/* Сетка: планшет → 2 колонки, телефон → 1 */
@media (max-width: 768px) {
  .articles-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .articles-grid { grid-template-columns: 1fr; }
  .filters { gap: 0.4rem; }
}

/* ── 400px: телефон (узкий) ────────────── */
@media (max-width: 400px) {

  .hero__heading {
    font-size: clamp(1.875rem, 9vw, 2.25rem);
  }

  /* Portal grid: 1 column */
  .portal__grid {
    grid-template-columns: 1fr;
  }

  /* Reset 2-col borders, single-col dividers */
  .portal-card:nth-child(odd)     { border-right: none; }
  .portal-card:nth-child(-n+2)    { border-bottom: none; }
  .portal-card:not(:last-child)   { border-bottom: 1px solid var(--border-mid); }
}

/* ==========================================
   ARTICLE PAGE — страница одной статьи
   Узкая центр-колонка (~720px) для комфортного
   чтения лонгрида. TOC сверху, без JS (якоря +
   scroll-padding уже есть). Аддитивно к токенам,
   существующее НЕ тронуто. См. articles/<slug>.html
   ========================================== */

/* Узкая колонка чтения. Сама держит отступ под фикс-навбар
   (+ тикер, когда html.has-ticker вешает JS), как .articles. */
.article {
  max-width: 760px;            /* колонка текста ~720px + поля */
  margin: 0 auto;
  padding: calc(var(--nav-h) + 3.25rem) 1.5rem var(--section-pad);
}
html.has-ticker .article {
  padding-top: calc(var(--nav-h) + var(--ticker-h) + 3.25rem);
}

/* ── Шапка статьи ── */
.article__header { margin-bottom: 2.5rem; }

.article__title {
  font-size: clamp(1.875rem, 3.6vw, 2.75rem);
  font-weight: 300;
  letter-spacing: -0.03em;
  line-height: 1.16;
  color: var(--ink);
  margin: 0.25rem 0 1.1rem;
}

.article__meta {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.02em;
  color: var(--ink-faint);
}

/* ── Лид (вводный абзац) ── */
.article__lead {
  font-size: 1.1875rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink-muted);
  margin-bottom: 2.25rem;
}

/* ── Дисклеймер — сдержанный, тонкая sage-линейка слева, на доверие ── */
.article__note {
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--ink-muted);
  border-left: 2px solid var(--sage);
  padding: 0.15rem 0 0.15rem 1.15rem;
  margin-bottom: 2.75rem;
}
.article__note strong { color: var(--ink); font-weight: 600; }

/* ── Оглавление (TOC) — сверху, тихая карточка, моно-индексы ── */
.article__toc {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: rgba(46, 87, 66, 0.025);
  padding: 1.5rem 1.75rem;
  margin-bottom: 3rem;
}
.article__toc-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sage);
  margin-bottom: 1rem;
}
.article__toc-list {
  counter-reset: toc;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.article__toc-list li { display: flex; gap: 0.8rem; }
.article__toc-list li::before {
  counter-increment: toc;
  content: counter(toc, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  line-height: 1.5;
  color: var(--sage);
  flex: none;
}
.article__toc-list a {
  font-size: 0.9375rem;
  line-height: 1.45;
  color: var(--ink-muted);
  transition: color var(--dur) var(--ease-out);
}
.article__toc-list a:hover { color: var(--forest); }

/* ── Тело статьи: типографика лонгрида ── */
.article-section { margin-bottom: 2.75rem; }

.article-section h2 {
  font-size: clamp(1.35rem, 2.4vw, 1.625rem);
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.28;
  color: var(--ink);
  margin-bottom: 1.1rem;
}
.article-section h3 {
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 1.75rem 0 0.75rem;
}

.article__body p {
  font-size: 1.0625rem;
  line-height: 1.75;
  color: var(--ink);
  margin-bottom: 1.15rem;
}
.article__body strong { font-weight: 600; color: var(--ink); }
.article__body em { font-style: italic; }

.article__body a {
  color: var(--forest);
  text-decoration: underline;
  text-decoration-color: rgba(46, 87, 66, 0.35);
  text-underline-offset: 2px;
  transition: text-decoration-color var(--dur) var(--ease-out);
}
.article__body a:hover { text-decoration-color: currentColor; }

.article__body code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  background: rgba(46, 87, 66, 0.07);
  padding: 0.12em 0.38em;
  border-radius: var(--r-xs);
}

/* Списки: sage-точка, как маркеры портала; gap = воздух */
.article-list,
.article-checklist {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin: 0 0 1.5rem;
}
.article-list li,
.article-checklist li {
  position: relative;
  padding-left: 1.4rem;
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--ink);
}
.article-list li::before,
.article-checklist li::before {
  content: '';
  position: absolute;
  left: 0.1rem;
  top: 0.7em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--sage);
}

/* Выноска ключевой мысли — мягкий sage-блок */
.article-callout {
  background: rgba(46, 87, 66, 0.05);
  border: 1px solid var(--border);
  border-radius: var(--r-md); /* схлопнуто 10→12 (Р3) */
  padding: 1.1rem 1.35rem;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 1.5rem;
}

/* Таблицы — редки, но держим стиль (для будущих статей) */
.article__body table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
  margin: 0 0 1.5rem;
}
.article__body th,
.article__body td {
  border: 1px solid var(--border-mid);
  padding: 0.6rem 0.8rem;
  text-align: left;
  line-height: 1.5;
}
.article__body th {
  background: rgba(46, 87, 66, 0.05);
  font-weight: 500;
}

/* ── SaaS-promo — наш forest-блок, одна кнопка (воронка портал → система) ── */
.article__promo {
  background: var(--forest);
  color: var(--cream);
  border-radius: var(--r-lg);
  padding: 2.5rem 2.25rem;
  margin-top: 3.5rem;
}
.article__promo-label {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sage);
  margin-bottom: 0.9rem;
}
.article__promo-title {
  font-size: clamp(1.25rem, 2.2vw, 1.5rem);
  font-weight: 400;
  line-height: 1.3;
  color: var(--cream);
  margin-bottom: 0.85rem;
}
.article__promo-text {
  font-size: 0.9375rem;
  line-height: 1.65;
  color: rgba(245, 242, 236, 0.72);
  margin-bottom: 1.6rem;
  max-width: 54ch;
}
/* Кнопка на forest-фоне → outline-вариант (cream), фокус sage для контраста */
.article__promo .btn--outline:focus-visible { outline-color: var(--sage); }

/* ── Назад к списку ── */
.article__back {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 3rem;
  font-size: 0.9375rem;
  color: var(--ink-muted);
  transition: color var(--dur) var(--ease-out), gap var(--dur) var(--ease-out);
}
.article__back:hover { color: var(--forest); gap: 0.65rem; }

/* ── Мобильный ── */
@media (max-width: 640px) {
  .article { padding-left: 1.25rem; padding-right: 1.25rem; }
  .article__toc { padding: 1.25rem 1.35rem; }
  .article__promo { padding: 2rem 1.5rem; }
  .article__lead { font-size: 1.0625rem; }
}

/* ==========================================================================
   GLOSSARY  (аддитивный блок — хаб «Глоссарий», стиль v4)
   Карточка термина наследует язык .article-card (cream, border, radius, tokens).
   Категорийные пилюли — переиспользуют .filters / .filter-pill (выше).
   ========================================================================== */

/* Первая секция вместо hero — сама держит отступ под фикс-навбар (+тикер). */
.glossary {
  padding: calc(var(--nav-h) + 3.5rem) 0 var(--section-pad);
}
html.has-ticker .glossary {
  padding-top: calc(var(--nav-h) + var(--ticker-h) + 3.5rem);
}

.glossary__head {
  max-width: 620px;
  margin-bottom: 2rem;
}
.glossary__sub {
  font-size: 1rem;
  color: var(--ink-muted);
  line-height: 1.6;
  margin-top: 0.75rem;
}

/* Тулбар: поиск тянется, счётчик справа моноцифрами. */
.glossary__toolbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.glossary__search {
  flex: 1;
  min-width: 0;
  font-family: var(--font);
  font-size: 0.9375rem;
  color: var(--ink);
  background: var(--cream);
  border: 1px solid var(--border-mid);
  border-radius: var(--r-md); /* схлопнуто 10→12 (Р3) */
  padding: 0.8rem 1.1rem;
  transition: border-color var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out),
              background var(--dur) var(--ease-out), transform var(--dur) var(--ease-out);
}
.glossary__search::placeholder { color: var(--ph); }
/* Фокус — рецепт .input из SaaS (COMPONENTS.md §4): accent-ринг 4px + белый фон + лифт */
.glossary__search:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--white);
  box-shadow: 0 0 0 4px var(--accent-ring);
  transform: translateY(-1px);
}
.glossary__count {
  flex: none;
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--ink-faint);
  white-space: nowrap;
}

/* Сетка карточек: авто-подгон, мин. 280px → сама раскладывается 3/2/1. */
.glossary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.25rem;
  align-items: start;
}

.term-card {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-lg); /* схлопнуто 14→16 (Р3) */
  padding: 1.5rem;
  scroll-margin-top: calc(var(--nav-h) + var(--ticker-h) + 1.5rem);
  transition: background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out),
              transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}
/* Блок 5 П3: единый hover-характер карточек — лифт -2px + --shadow-2 (канон) */
.term-card:hover {
  background: rgba(46, 87, 66, 0.05);
  border-color: var(--border-mid);
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}
.term-card[hidden] { display: none; }
.term-card:target { border-color: var(--sage); box-shadow: 0 0 0 3px rgba(95, 169, 131, 0.18); }

.term-card__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}
.term-card__name {
  font-size: 1.0625rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.term-card__cat {
  flex: none;
  font-family: var(--font-mono);  /* типографика хаба — портальная (COMPONENTS.md §3) */
  font-size: 0.625rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  /* Материал — рецепт .pill.neutral из SaaS: мягкий фон + цвет, без рамки */
  color: var(--accent);
  background: var(--accent-soft);
  border: none;
  border-radius: var(--r-pill);
  padding: 0.25rem 0.6rem;
}
.term-card__full {
  font-size: 0.8125rem;
  color: var(--ink-faint);
  line-height: 1.4;
  margin-top: -0.15rem;
}
.term-card__def {
  font-size: 0.875rem;
  color: var(--ink-muted);
  line-height: 1.6;
}
.term-card__src {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--ink-faint);
}
.term-card__rel {
  font-size: 0.8125rem;
  color: var(--ink-muted);
  padding-top: 0.5rem;
  border-top: 1px solid var(--border);
}
.term-card__rel-label { color: var(--ink-faint); }
.term-card__rel-link {
  color: var(--forest);
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 2px;
  transition: text-decoration-color var(--dur) var(--ease-out);
}
.term-card__rel-link:hover { text-decoration-color: currentColor; }

.glossary-empty {
  color: var(--ink-muted);
  font-size: 0.9375rem;
  padding: 2rem 0;
}

/* ── Блок 5 П2: живой отклик фильтра/поиска ─────────────────────────────────
   Карточки, ставшие видимыми, проявляются каскадом (шаг 0.04s, первые ~12 —
   JS, хвост виден сразу). Только transform/opacity, канон-кривая и токены.
   animation-fill backwards держит карточку невидимой до её слота в каскаде. */
.term-card--in {
  animation: term-card-in var(--dur-md) var(--ease-out) backwards;
}
@keyframes term-card-in {
  from { opacity: 0; transform: translateY(calc(var(--reveal-y) / 2)); }
  to   { opacity: 1; transform: none; }
}

/* Счётчик «3 / 121» — мягкий tick прозрачностью при смене значения. */
.glossary__count--tick {
  animation: count-tick var(--dur) var(--ease-out);
}
@keyframes count-tick {
  from { opacity: 0.25; }
  to   { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .term-card--in,
  .glossary__count--tick { animation: none; }
}

/* ==========================================================================
   NAVBAR DROPDOWN  «База знаний ▾»  — чистый CSS (hover + focus-within), без JS.
   Сдержанно: стекло, мягкая тень, плавное раскрытие. Закрывается при уходе
   курсора/потере фокуса. Работает на любой странице с навбаром (нет JS-связи).
   ========================================================================== */
.navbar__dd { position: relative; display: inline-flex; }

.navbar__dd-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-family: var(--font);
  font-size: 0.875rem;
  color: var(--ink-muted);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: color var(--dur) var(--ease-out);
}
.navbar__dd:hover .navbar__dd-toggle,
.navbar__dd:focus-within .navbar__dd-toggle { color: var(--forest); }
.navbar__dd-toggle:focus-visible { outline: 2px solid var(--forest); outline-offset: 4px; border-radius: var(--r-xs); /* схлопнуто 3→4 (Р3) */ }

.navbar__dd-caret { transition: transform var(--dur) var(--ease-out); }
.navbar__dd:hover .navbar__dd-caret,
.navbar__dd:focus-within .navbar__dd-caret { transform: rotate(180deg); }

.navbar__dd-menu {
  position: absolute;
  top: calc(100% + 0.65rem);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  min-width: 200px;
  display: flex;
  flex-direction: column;
  padding: 0.4rem;
  /* Glass-материал канона (Блок 5 П1): под меню реально скроллится контент.
     --glass-2 + --blur + hairline — рецепт .glass-card из COMPONENTS.md §2. */
  background: var(--glass-2);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: var(--hair);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-2);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out);
}
/* Мостик, чтобы курсор не «проваливался» в зазоре между кнопкой и меню. */
.navbar__dd-menu::before {
  content: "";
  position: absolute;
  top: -0.65rem; left: 0; right: 0;
  height: 0.65rem;
}
.navbar__dd:hover .navbar__dd-menu,
.navbar__dd:focus-within .navbar__dd-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.navbar__dd-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  font-size: 0.875rem;
  color: var(--ink-muted);
  text-decoration: none;
  padding: 0.6rem 0.75rem;
  border-radius: var(--r-sm);
  transition: color var(--dur) var(--ease-out), background var(--dur) var(--ease-out);
}
.navbar__dd-item:hover { color: var(--forest); background: rgba(46, 87, 66, 0.06); }
.navbar__dd-item--soon {
  color: var(--ink-faint);
  cursor: default;
  pointer-events: none;
}
.navbar__dd-item--soon em {
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 0.5625rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-faint);
  border: 1px solid var(--border-mid);
  border-radius: var(--r-pill);
  padding: 0.12rem 0.4rem;
}

/* Мобайл (≤768px): дропдаун раскрыт статикой внутри бургер-панели. */
@media (max-width: 768px) {
  .navbar__dd { display: block; }
  .navbar__dd-toggle {
    width: 100%;
    padding: 0.875rem 1.5rem;
    font-size: 0.9375rem;
    justify-content: flex-start;
    color: var(--ink);
  }
  .navbar__dd-caret { display: none; }
  .navbar__dd-menu {
    position: static;
    transform: none;
    opacity: 1;
    pointer-events: auto;
    min-width: 0;
    background: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: none;
    box-shadow: none;
    padding: 0 0 0.5rem;
  }
  .navbar__dd-menu::before { display: none; }
  .navbar__dd-item { padding: 0.6rem 2.5rem; border-radius: 0; }
}


/* ==========================================================================
   FAQ-ХАБ  (faq.html) — третий раздел «Базы знаний».
   Тулбар/пилюли/счётчик/пустышка — переиспользуют классы глоссария.
   Своё: список-аккордеон. Вопрос = кнопка (aria-expanded), ответ раскрывается
   переходом grid-template-rows 0fr -> 1fr по канон-кривой (MOTION.md: --dur-md,
   --ease-out); reduced-motion — мгновенно. Каскад появления — как .term-card--in.
   ========================================================================== */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.faq-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  scroll-margin-top: calc(var(--nav-h) + var(--ticker-h) + 1.5rem);
  transition: background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
.faq-card:hover { border-color: var(--border-mid); box-shadow: var(--shadow-2); }
.faq-card[hidden] { display: none; }
.faq-card:target { border-color: var(--sage); box-shadow: 0 0 0 3px rgba(95, 169, 131, 0.18); }

.faq-card__q { margin: 0; }
.faq-card__toggle {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  text-align: left;
  font-family: var(--font);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
  background: none;
  border: none;
  border-radius: var(--r-lg);
  padding: 1.1rem 1.25rem;
  cursor: pointer;
}
.faq-card__toggle:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.faq-card__q-text { flex: 1; min-width: 0; }
.faq-card .faq-card__cat {
  flex: none;
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: var(--r-pill);
  padding: 0.25rem 0.6rem;
}
.faq-card__caret {
  flex: none;
  color: var(--ink-faint);
  transition: transform var(--dur-md) var(--ease-out);
}
.faq-card--open .faq-card__caret { transform: rotate(180deg); }

/* Раскрытие: grid-rows 0fr -> 1fr (compositor-friendly, без height-хаков). */
.faq-card__a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--dur-md) var(--ease-out);
}
.faq-card--open .faq-card__a { grid-template-rows: 1fr; }
.faq-card__a-inner {
  overflow: hidden;
  min-height: 0;
  padding: 0 1.25rem;
}
.faq-card--open .faq-card__a-inner { padding-bottom: 1.25rem; }

.faq-card__answer {
  font-size: 0.9375rem;
  color: var(--ink-muted);
  line-height: 1.65;
}
.faq-card__rel {
  font-size: 0.8125rem;
  color: var(--ink-muted);
  margin-top: 0.75rem;
  padding-top: 0.65rem;
  border-top: 1px solid var(--border);
}
.faq-card__rel-label { color: var(--ink-faint); }
.faq-card__ref {
  color: var(--forest);
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 2px;
  transition: text-decoration-color var(--dur) var(--ease-out);
}
.faq-card__ref:hover { text-decoration-color: currentColor; }
.faq-card__src {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--ink-faint);
  margin-top: 0.5rem;
}

/* Каскад появления при фильтре/поиске — канон глоссария (Блок 5 П2). */
.faq-card--in {
  animation: term-card-in var(--dur-md) var(--ease-out) backwards;
}

@media (prefers-reduced-motion: reduce) {
  .faq-card--in { animation: none; }
  .faq-card__a, .faq-card__caret { transition: none; }
}
