/* =============================================================================
   npd/public/style.css — Калькулятор НПД
   Design: Friendly SaaS · Inter · Indigo/Cyan · Light mode
   Stack: Vanilla CSS · Mobile-first · 375px baseline · 2026 CSS features
   ============================================================================= */

@layer base, tokens, components, utilities;

/* Fonts loaded via /fonts/inter.css (self-hosted, no external request) */

/* ═══════════════════════════════════════════════════════════════════════════
   LAYER: tokens — единый источник истины для всех цветов и размеров
   ═══════════════════════════════════════════════════════════════════════════ */
@layer tokens {
  :root {
    /* ── Цвета ── */
    --color-primary:        #6366f1;
    --color-primary-hover:  #4f46e5;
    --color-primary-light:  #eef2ff;
    --color-primary-muted:  rgba(99, 102, 241, 0.12);
    --color-accent:         #06b6d4;
    --color-accent-light:   #ecfeff;

    --color-success:        #10b981;
    --color-success-light:  #ecfdf5;
    --color-warning:        #f59e0b;
    --color-warning-light:  #fffbeb;
    --color-danger:         #ef4444;
    --color-danger-light:   #fef2f2;

    --color-text:           #0f172a;
    --color-text-muted:     #64748b;
    --color-text-dim:       #94a3b8;

    --color-bg:             #ffffff;
    --color-surface:        #f8fafc;
    --color-surface-2:      #f1f5f9;
    --color-border:         #e2e8f0;
    --color-border-focus:   #6366f1;

    /* ── Градиенты ── */
    --gradient-brand:       linear-gradient(135deg, #6366f1 0%, #06b6d4 100%);
    --gradient-brand-soft:  linear-gradient(135deg, rgba(99,102,241,0.08) 0%, rgba(6,182,212,0.08) 100%);

    /* ── Тени ── */
    --shadow-sm:    0 1px 2px rgba(15, 23, 42, 0.06);
    --shadow:       0 1px 3px rgba(15, 23, 42, 0.08), 0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-md:    0 4px 6px rgba(15, 23, 42, 0.07), 0 2px 4px rgba(15, 23, 42, 0.04);
    --shadow-focus: 0 0 0 3px rgba(99, 102, 241, 0.2);
    --shadow-card:  0 4px 24px rgba(99, 102, 241, 0.08);

    /* ── Геометрия ── */
    --radius-sm:  0.375rem;
    --radius:     0.625rem;
    --radius-lg:  0.875rem;
    --radius-xl:  1.25rem;
    --radius-pill: 9999px;

    /* ── Отступы (4px-шкала) ── */
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-5:  1.25rem;
    --space-6:  1.5rem;
    --space-8:  2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;

    /* ── Типографика ── */
    --font: 'Inter', system-ui, -apple-system, sans-serif;
    --font-xs:   0.75rem;
    --font-sm:   0.875rem;
    --font-base: 1rem;
    --font-lg:   1.125rem;
    --font-xl:   1.25rem;
    --font-2xl:  1.5rem;
    --font-3xl:  1.875rem;

    /* ── Анимация ── */
    --trans-fast: 120ms ease;
    --trans:      200ms ease;
    --trans-slow: 350ms cubic-bezier(0.16, 1, 0.3, 1);

    /* ── z-index шкала ── */
    --z-sticky: 10;
    --z-toast:  1000;
    --z-cookie: 200;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   LAYER: base — сброс и базовые стили
   ═══════════════════════════════════════════════════════════════════════════ */
@layer base {
  *, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  }

  html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    scroll-padding-top: 5rem;
  }

  body {
    font-family: var(--font);
    font-size: var(--font-base);
    color: var(--color-text);
    background: var(--color-bg);
    line-height: 1.6;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }

  a { color: var(--color-primary); text-decoration: none; }
  a:hover { color: var(--color-primary-hover); text-decoration: underline; }

  img, svg { display: block; max-width: 100%; }

  /* Только keyboard-focus — не убираем кольцо */
  :focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
  }
  :focus:not(:focus-visible) { outline: none; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   LAYER: components
   ═══════════════════════════════════════════════════════════════════════════ */
@layer components {

/* ── Контейнер ───────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: 1120px;
  margin-inline: auto;
  padding-inline: var(--space-4);
}
@media (min-width: 640px) {
  .container { padding-inline: var(--space-6); }
}
.container--narrow { max-width: 760px; }

/* ═══════════════════════════════════════════════════════════════════════════
   1. ШАПКА — белая, с gradient-accent снизу, логотип + breadcrumb
   ═══════════════════════════════════════════════════════════════════════════ */
.site-header {
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-6) 0 var(--space-8);
  position: relative;
}

/* Тонкая gradient-полоска сверху — брендовый маркер */
.site-header::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gradient-brand);
}

.site-header .container {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* Брендовая строка: логотип + lang */
.site-header__brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.site-header__logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  color: var(--color-text);
  font-weight: 700;
  font-size: var(--font-sm);
  transition: opacity var(--trans-fast);
}
.site-header__logo:hover { opacity: 0.75; text-decoration: none; }

.site-header__logo-mark {
  width: 28px;
  height: 28px;
  background: var(--gradient-brand);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.3);
}

/* Breadcrumb */
.site-header__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-dim);
}
.site-header__eyebrow a {
  color: var(--color-primary);
  text-decoration: none;
}
.site-header__eyebrow a:hover { text-decoration: underline; }
.site-header__eyebrow-sep { color: var(--color-border); }

/* H1 с gradient-текстом */
.site-header__title {
  font-size: clamp(1.5rem, 5vw, 2.25rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-text);
}

.site-header__sub {
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  max-width: 520px;
  line-height: 1.55;
}

/* Lang switcher — pill-стиль как на хабе */
.site-header__lang {
  display: flex;
  gap: var(--space-1);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  padding: 3px;
  flex-shrink: 0;
}
.lang-btn {
  padding: 0.2rem 0.625rem;
  border-radius: var(--radius-pill);
  font-size: var(--font-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: background var(--trans-fast), color var(--trans-fast);
  min-height: 28px;
  display: flex;
  align-items: center;
}
.lang-btn:hover { color: var(--color-text); text-decoration: none; }
.lang-btn--active {
  background: var(--color-bg);
  color: var(--color-text);
  box-shadow: var(--shadow-sm);
}

/* ═══════════════════════════════════════════════════════════════════════════
   2. ОСНОВНОЙ LAYOUT (2 колонки на десктопе)
   ═══════════════════════════════════════════════════════════════════════════ */
.calc-layout {
  flex: 1;
  padding: var(--space-8) 0 var(--space-16);
}
.calc-layout .container {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .calc-layout .container {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   3. ФОРМА ВВОДА
   ═══════════════════════════════════════════════════════════════════════════ */
.calc-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.form-section__title {
  font-size: var(--font-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}

/* ── Поле ввода ── */
.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.field__label {
  font-size: var(--font-sm);
  font-weight: 600;
  color: var(--color-text);
}
.field__input {
  width: 100%;
  padding: 0.75rem var(--space-4);
  font-size: var(--font-lg);
  font-weight: 500;
  font-family: var(--font);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
  color: var(--color-text);
  transition: border-color var(--trans-fast), box-shadow var(--trans-fast);
  -moz-appearance: textfield;
}
.field__input::-webkit-outer-spin-button,
.field__input::-webkit-inner-spin-button { -webkit-appearance: none; }
.field__input::placeholder { color: var(--color-text-dim); }
.field__input:hover { border-color: #c7d2fe; }
.field__input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}
.field__hint {
  font-size: var(--font-xs);
  color: var(--color-text-dim);
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   4. TOGGLE-ГРУППА
   ═══════════════════════════════════════════════════════════════════════════ */
.toggle-group {
  display: flex;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 4px;
  gap: 4px;
}
.toggle-group__btn {
  flex: 1;
  padding: 0.5rem var(--space-3);
  font-size: var(--font-sm);
  font-weight: 600;
  font-family: var(--font);
  background: transparent;
  color: var(--color-text-muted);
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--trans-fast), color var(--trans-fast), box-shadow var(--trans-fast);
  line-height: 1.2;
  text-align: center;
  min-height: 40px;
}
.toggle-group__btn:hover {
  background: var(--color-primary-light);
  color: var(--color-primary);
}
.toggle-group__btn--active {
  background: var(--color-bg);
  color: var(--color-primary);
  box-shadow: var(--shadow);
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════════════════
   5. КНОПКИ
   ═══════════════════════════════════════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font);
  font-weight: 600;
  border-radius: var(--radius-lg);
  cursor: pointer;
  border: none;
  transition: background var(--trans-fast), transform var(--trans-fast), box-shadow var(--trans-fast), opacity var(--trans-fast);
  white-space: nowrap;
  min-height: 44px;
  text-decoration: none;
}
.btn--primary {
  background: var(--gradient-brand);
  color: #fff;
  padding: 0.75rem var(--space-6);
  font-size: var(--font-base);
  width: 100%;
  box-shadow: 0 4px 16px rgba(99, 102, 241, 0.3);
}
.btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(99, 102, 241, 0.4);
  text-decoration: none;
  color: #fff;
}
.btn--primary:active { transform: translateY(0); }
.btn--primary:disabled { opacity: 0.45; cursor: not-allowed; transform: none; box-shadow: none; }

.btn--ghost {
  background: transparent;
  color: var(--color-text-muted);
  padding: 0.5rem var(--space-4);
  font-size: var(--font-sm);
  border: 1.5px solid var(--color-border);
  min-height: 40px;
}
.btn--ghost:hover {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-primary);
  text-decoration: none;
}

.btn--sm {
  padding: 0.375rem var(--space-4);
  font-size: var(--font-sm);
  min-height: 36px;
  border-radius: var(--radius);
}

/* ═══════════════════════════════════════════════════════════════════════════
   6. ПРАВАЯ КОЛОНКА — результат + трекеры
   ═══════════════════════════════════════════════════════════════════════════ */
.calc-result {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* ── Карточка результата ── */
.result-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
}

/* Тонкий gradient-border слева */
.result-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 4px;
  background: var(--gradient-brand);
  border-radius: var(--radius-xl) 0 0 var(--radius-xl);
}

.result-card__title {
  font-size: var(--font-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-dim);
  margin-bottom: var(--space-4);
  padding-left: var(--space-2);
}

.result-card__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--space-2) var(--space-2);
  border-bottom: 1px solid var(--color-surface-2);
}
.result-card__row:last-child { border-bottom: none; }

.result-card__label {
  font-size: var(--font-sm);
  color: var(--color-text-muted);
}
.result-card__value {
  font-size: var(--font-xl);
  font-weight: 700;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}
.result-card__value--success { color: var(--color-success); }
.result-card__value--danger  { color: var(--color-danger);  }
.result-card__value--primary { color: var(--color-primary); }

/* ═══════════════════════════════════════════════════════════════════════════
   7. ПРОГРЕСС-БАР (BonusTracker + LimitBar)
   ═══════════════════════════════════════════════════════════════════════════ */
.tracker {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-sm);
}
.tracker__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-3);
}
.tracker__title {
  font-size: var(--font-sm);
  font-weight: 700;
  color: var(--color-text);
}
.tracker__value {
  font-size: var(--font-sm);
  font-weight: 600;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.progress-bar {
  height: 8px;
  background: var(--color-surface-2);
  border-radius: var(--radius-pill);
  overflow: hidden;
  margin-bottom: var(--space-2);
}
.progress-bar__fill {
  height: 100%;
  background: var(--gradient-brand);
  border-radius: var(--radius-pill);
  transition: width 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  width: 0%;
}
.progress-bar__fill--warning { background: linear-gradient(90deg, var(--color-warning), #fbbf24); }
.progress-bar__fill--danger  { background: linear-gradient(90deg, var(--color-danger), #f87171); }
.tracker__sub {
  font-size: var(--font-xs);
  color: var(--color-text-dim);
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   8. SHARE BAR
   ═══════════════════════════════════════════════════════════════════════════ */
.share-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  flex-wrap: wrap;
}
.share-bar__label {
  font-size: var(--font-sm);
  font-weight: 600;
  color: var(--color-text-dim);
  margin-right: var(--space-1);
}

.share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius);
  border: 1.5px solid var(--color-border);
  background: var(--color-bg);
  cursor: pointer;
  transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease, border-color 150ms ease, color 150ms ease;
  flex-shrink: 0;
}
.share-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}
.share-btn:active { transform: translateY(0); }

.share-btn--vk   { color: #0077FF; }
.share-btn--vk:hover   { background: #0077FF; border-color: #0077FF; color: #fff; }

.share-btn--tg   { color: #26A5E4; }
.share-btn--tg:hover   { background: #26A5E4; border-color: #26A5E4; color: #fff; }

.share-btn--wa   { color: #25D366; }
.share-btn--wa:hover   { background: #25D366; border-color: #25D366; color: #fff; }

.share-btn--copy { color: var(--color-text-muted); }
.share-btn--copy:hover { background: var(--color-primary-light); border-color: var(--color-primary); color: var(--color-primary); }

/* Баннер «расчёт восстановлен из ссылки» */
.share-restore-banner {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: #f0fdf4;
  border: 1px solid #86efac;
  border-radius: var(--radius-lg);
  font-size: var(--font-sm);
  color: #166534;
  margin-top: var(--space-2);
}
.share-restore-banner[hidden] { display: none; }

/* ═══════════════════════════════════════════════════════════════════════════
   9. AD SLOT — скрыт до появления реальной рекламы
   ═══════════════════════════════════════════════════════════════════════════ */
.ad-slot { display: none; }

/* ═══════════════════════════════════════════════════════════════════════════
   10. FAQ — нативный details/summary, анимация через CSS
   ═══════════════════════════════════════════════════════════════════════════ */
.faq {
  padding: var(--space-12) 0 var(--space-8);
  border-top: 1px solid var(--color-border);
}
.faq__title {
  font-size: clamp(var(--font-xl), 3vw, var(--font-2xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-6);
  color: var(--color-text);
}

.faq__item {
  border-bottom: 1px solid var(--color-border);
}

.faq__item summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) 0;
  font-size: var(--font-base);
  font-weight: 600;
  cursor: pointer;
  list-style: none;
  gap: var(--space-4);
  color: var(--color-text);
  transition: color var(--trans-fast);
  user-select: none;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary:hover { color: var(--color-primary); }

/* Шеврон через CSS — без JS */
.faq__item summary::after {
  content: '';
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236366f1'%3E%3Cpath fill-rule='evenodd' d='M5.22 8.22a.75.75 0 0 1 1.06 0L10 11.94l3.72-3.72a.75.75 0 1 1 1.06 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L5.22 9.28a.75.75 0 0 1 0-1.06z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  transition: transform var(--trans);
}
.faq__item[open] summary::after { transform: rotate(180deg); }

.faq__answer {
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  line-height: 1.75;
  padding-bottom: var(--space-5);
}
.faq__answer p + p { margin-top: var(--space-3); }

/* CSS-анимация раскрытия через @starting-style (Baseline 2024) */
.faq__answer {
  overflow: hidden;
}
@supports (interpolate-size: allow-keywords) {
  .faq__item[open] .faq__answer {
    interpolate-size: allow-keywords;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   11. SEO-КОНТЕНТ
   ═══════════════════════════════════════════════════════════════════════════ */
.seo-content {
  padding: var(--space-8) 0 var(--space-16);
  border-top: 1px solid var(--color-border);
}
.seo-content h2 {
  font-size: var(--font-xl);
  font-weight: 700;
  letter-spacing: -0.015em;
  margin-bottom: var(--space-3);
  color: var(--color-text);
}
.seo-content p {
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  line-height: 1.75;
  margin-bottom: var(--space-4);
  max-width: 800px;
}
.seo-content h3 {
  font-size: var(--font-lg);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: var(--space-8) 0 var(--space-3);
  color: var(--color-text);
  max-width: 800px;
}
.seo-content h3:first-of-type { margin-top: var(--space-6); }
.seo-content .seo-list,
.seo-content .seo-examples {
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  line-height: 1.75;
  margin: 0 0 var(--space-4) var(--space-5);
  max-width: 800px;
}
.seo-content .seo-list li,
.seo-content .seo-examples li { margin-bottom: var(--space-2); }
.seo-content .seo-examples li strong:first-child { color: var(--color-text); }
.seo-table-wrap {
  max-width: 800px;
  margin: 0 0 var(--space-4);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.seo-table {
  width: 100%;
  min-width: 560px;
  border-collapse: collapse;
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.seo-table caption {
  caption-side: bottom;
  text-align: left;
  font-size: var(--font-xs);
  color: var(--color-text-dim);
  padding-top: var(--space-2);
}
.seo-table th,
.seo-table td {
  padding: var(--space-2) var(--space-3);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}
.seo-table thead th {
  background: var(--color-surface-2);
  color: var(--color-text);
  font-weight: 600;
  font-size: var(--font-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.seo-table tbody th {
  color: var(--color-text);
  font-weight: 600;
}
.seo-table tbody tr:last-child th,
.seo-table tbody tr:last-child td { border-bottom: 0; }

/* ═══════════════════════════════════════════════════════════════════════════
   12. ФУТЕР
   ═══════════════════════════════════════════════════════════════════════════ */
.site-footer {
  margin-top: auto;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding: var(--space-8) 0 var(--space-6);
}
.site-footer__top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-4);
}
.site-footer__brand {
  flex: 1 1 200px;
  min-width: 160px;
}
.site-footer__logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  color: var(--color-text);
  font-weight: 700;
  font-size: var(--font-sm);
  margin-bottom: var(--space-2);
}
.site-footer__logo:hover { color: var(--color-primary); }
.site-footer__logo-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.site-footer__logo-text { font-weight: 700; }
.site-footer__slogan {
  font-size: var(--font-xs);
  color: var(--color-text-dim);
  line-height: 1.4;
  margin: 0;
}
.site-footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-6);
  align-items: center;
  flex: 1 1 auto;
}
.site-footer__nav a {
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--trans-fast);
}
.site-footer__nav a:hover { color: var(--color-primary); }
.site-footer__social {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  flex-shrink: 0;
}
.site-footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius);
  background: var(--color-surface-2);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: background var(--trans-fast), color var(--trans-fast);
  border: 1px solid var(--color-border);
}
.site-footer__social-link:hover {
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-color: rgba(99, 102, 241, 0.3);
}
.site-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-6);
  align-items: center;
}
.site-footer__copy {
  font-size: var(--font-xs);
  color: var(--color-text-dim);
}
.site-footer__disclaimer {
  font-size: var(--font-xs);
  color: var(--color-text-dim);
  opacity: 0.7;
}

/* ═══════════════════════════════════════════════════════════════════════════
   13. COOKIE BANNER — compact strip on mobile, card on desktop
   ═══════════════════════════════════════════════════════════════════════════ */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(255, 255, 255, 0.97);
  border-top: 1px solid var(--color-border);
  padding: var(--space-3) var(--space-4);
  z-index: var(--z-cookie);
  box-shadow: 0 -4px 24px rgba(15, 23, 42, 0.08);
}
@media (min-width: 640px) {
  .cookie-banner {
    bottom: var(--space-6);
    left: auto;
    right: var(--space-6);
    max-width: 420px;
    border-top: none;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    box-shadow: 0 8px 40px rgba(15, 23, 42, 0.12);
    backdrop-filter: blur(12px);
    padding: var(--space-4) var(--space-5);
  }
}
.cookie-banner[hidden] { display: none; }

.cookie-banner__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}
.cookie-banner__text {
  flex: 1;
  font-size: var(--font-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}
.cookie-banner__text a { color: var(--color-primary); }

/* ═══════════════════════════════════════════════════════════════════════════
   14. TOAST
   ═══════════════════════════════════════════════════════════════════════════ */
.toast {
  position: fixed;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%) translateY(0.75rem);
  background: var(--color-text);
  color: #fff;
  padding: 0.625rem 1.25rem;
  border-radius: var(--radius-lg);
  font-size: var(--font-sm);
  font-weight: 500;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
  z-index: var(--z-toast);
  white-space: nowrap;
}
.toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ═══════════════════════════════════════════════════════════════════════════
   15. FORM ACTIONS (кнопки Зафиксировать + Сбросить)
   ═══════════════════════════════════════════════════════════════════════════ */
.form-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.form-actions .btn { flex: 1; min-width: 140px; }

@media (max-width: 480px) {
  .form-actions { flex-direction: column; }
  .form-actions .btn { width: 100%; min-width: 0; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   16. RESULT SOURCE — ссылка на ФЗ под результатом
   ═══════════════════════════════════════════════════════════════════════════ */
.result-source {
  font-size: var(--font-xs);
  color: var(--color-text-dim);
  line-height: 1.5;
  padding: var(--space-2) 0;
}
.result-source a { color: var(--color-text-muted); }
.result-source a:hover { color: var(--color-primary); }

/* ═══════════════════════════════════════════════════════════════════════════
   17. TOOLTIPS — подсказки к полям и результатам
   ═══════════════════════════════════════════════════════════════════════════ */
.tooltip-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.tooltip-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  color: var(--color-text-dim);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  cursor: help;
  flex-shrink: 0;
  transition: background var(--trans-fast), color var(--trans-fast);
  font-style: normal;
  user-select: none;
  margin-left: 4px;
}
.tooltip-trigger:hover,
.tooltip-trigger:focus-visible {
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-color: rgba(99, 102, 241, 0.3);
  outline: none;
}
.tooltip-wrap::before {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--color-text);
  color: #fff;
  font-size: var(--font-size-xs, 0.7rem);
  font-weight: 500;
  line-height: 1.4;
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius);
  white-space: normal;
  width: max-content;
  max-width: 220px;
  text-align: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--trans-fast), transform var(--trans-fast);
  z-index: 50;
}
.tooltip-wrap::after {
  content: '';
  position: absolute;
  bottom: calc(100% + 2px);
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--color-text);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--trans-fast);
  z-index: 50;
}
.tooltip-wrap:hover::before,
.tooltip-wrap:hover::after,
.tooltip-wrap:focus-within::before,
.tooltip-wrap:focus-within::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
@media (max-width: 639px) {
  .tooltip-wrap::before { max-width: 180px; }
}

/* Метка поля с tooltip inline */
.field__label { display: flex; align-items: center; gap: 4px; }
.form-section__title { display: flex; align-items: center; gap: 4px; }
.result-card__label { display: flex; align-items: center; gap: 4px; }

  /* ── Contact Form ─────────────────────────────────────── */
  .contact-intro {
    font-size: var(--font-base);
    color: var(--color-text-muted);
    margin-bottom: var(--space-6);
    line-height: 1.6;
  }
  .contact-intro strong { color: var(--color-text); font-weight: 600; }

  .contact-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
  }
  .contact-form__row {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }
  .contact-form__label {
    font-weight: 600;
    font-size: var(--font-sm);
    color: var(--color-text);
  }
  .contact-form__hint {
    font-size: var(--font-xs);
    color: var(--color-text-dim);
    font-weight: 400;
  }
  .contact-form input[type="text"],
  .contact-form input[type="email"],
  .contact-form textarea {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font: inherit;
    font-size: var(--font-base);
    background: var(--color-bg);
    color: var(--color-text);
    transition: border-color 0.15s, box-shadow 0.15s;
  }
  .contact-form input:focus,
  .contact-form textarea:focus {
    outline: none;
    border-color: var(--color-border-focus);
    box-shadow: var(--shadow-focus);
  }
  .contact-form textarea {
    resize: vertical;
    min-height: 140px;
    font-family: var(--font);
  }
  .contact-form__hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
  }
  .contact-form__captcha {
    display: flex;
    justify-content: center;
  }
  .contact-form__submit {
    align-self: flex-start;
    min-width: 200px;
  }
  .contact-form__status {
    min-height: 1.5em;
    font-size: var(--font-sm);
    color: var(--color-text-muted);
    padding: var(--space-2) 0;
  }
  .contact-form__status.is-error {
    color: var(--color-danger);
  }
  .contact-form__status.is-success {
    color: var(--color-success);
    padding: var(--space-3) var(--space-4);
    background: var(--color-success-light);
    border-radius: var(--radius);
    font-weight: 500;
  }

  .contact-socials {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    margin-top: var(--space-8);
  }
  @media (min-width: 560px) {
    .contact-socials { grid-template-columns: 1fr 1fr; }
  }
  .contact-social {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--color-text);
    transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
  }
  .contact-social:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
  }
  .contact-social__icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .contact-social__icon--tg { background: #e8f4fd; color: #2AABEE; }
  .contact-social__icon--vk { background: #e8efff; color: #0077FF; }
  .contact-social__title {
    font-weight: 600;
    margin: 0 0 2px;
    font-size: var(--font-base);
  }
  .contact-social__handle {
    margin: 0;
    font-size: var(--font-sm);
    color: var(--color-text-muted);
  }

  /* Footer CTA — "Нашли ошибку?" */
  .site-footer__cta {
    background: var(--color-primary-light);
    color: var(--color-text);
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius-lg);
    margin-top: var(--space-6);
    margin-bottom: var(--space-6);
    font-size: var(--font-sm);
    text-align: center;
  }
  .site-footer__cta a {
    color: var(--color-primary);
    font-weight: 600;
    text-decoration: none;
  }
  .site-footer__cta a:hover { text-decoration: underline; }

} /* end @layer components */

/* ═══════════════════════════════════════════════════════════════════════════
   LAYER: utilities
   ═══════════════════════════════════════════════════════════════════════════ */
@layer utilities {
  .sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border-width: 0;
  }
  [hidden] { display: none !important; }

  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
      animation-duration: 0.01ms !important;
      transition-duration: 0.01ms !important;
    }
  }
}

/* ── Кнопка «Наверх» ───────────────────────────────────────────── */
.scroll-to-top {
  position: fixed; bottom: 1.5rem; right: 1.25rem; z-index: 500;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--color-primary); color: #fff; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md);
  opacity: 0; pointer-events: none; transform: translateY(8px);
  transition: opacity 250ms ease, transform 250ms ease;
}
.scroll-to-top--visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.scroll-to-top:hover { background: var(--color-primary-hover); }
.scroll-to-top:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) {
  .scroll-to-top { transition: opacity 0.01ms; transform: none !important; }
}
/* ─── Bottom Nav (mobile only, brand-tinted) ──────────────────────────────────
   Цвет берётся из --bnav-color (fallback --color-primary, затем --primary).
   Каждый инструмент окрашивает меню в свой brand-токен.
   ──────────────────────────────────────────────────────────────────────────── */

.bnav { display: none; }

@media (max-width: 767px) {
  .bnav {
    --bnav-color: var(--color-primary, var(--primary, #1F5FFF));
    --bnav-ink: #0f172a;
    --bnav-bg: color-mix(in srgb, var(--bnav-color) 6%, #ffffff 94%);
    --bnav-border: color-mix(in srgb, var(--bnav-color) 22%, transparent);
    --bnav-shadow: color-mix(in srgb, var(--bnav-color) 28%, transparent);
    --bnav-muted: color-mix(in srgb, var(--bnav-ink) 62%, transparent);
    --bnav-active-bg: color-mix(in srgb, var(--bnav-color) 12%, transparent);

    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 90;
    padding: 6px 6px calc(6px + env(safe-area-inset-bottom));
    background: var(--bnav-bg);
    -webkit-backdrop-filter: saturate(180%) blur(16px);
            backdrop-filter: saturate(180%) blur(16px);
    border-top: 1px solid var(--bnav-border);
    box-shadow: 0 -8px 24px -12px var(--bnav-shadow);
    transform: translateY(110%);
    transition: transform .28s cubic-bezier(.32, .72, .24, 1);
    will-change: transform;
  }

  /* Тонкая цветная линия-акцент сверху */
  .bnav::before {
    content: "";
    position: absolute;
    top: 0;
    left: 12%;
    right: 12%;
    height: 2px;
    border-radius: 2px;
    background: linear-gradient(90deg,
      transparent,
      var(--bnav-color) 30%,
      var(--bnav-color) 70%,
      transparent);
    opacity: .55;
  }

  .bnav[data-state="visible"] { transform: translateY(0); }

  @media (prefers-color-scheme: dark) {
    .bnav {
      --bnav-ink: #e6edf3;
      --bnav-bg: color-mix(in srgb, var(--bnav-color) 10%, #11151c 90%);
      --bnav-border: color-mix(in srgb, var(--bnav-color) 32%, transparent);
      --bnav-shadow: rgba(0, 0, 0, .45);
      --bnav-muted: color-mix(in srgb, var(--bnav-ink) 60%, transparent);
      --bnav-active-bg: color-mix(in srgb, var(--bnav-color) 22%, transparent);
    }
  }

  /* Fallback без backdrop-filter: плотный тонированный фон */
  @supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
    .bnav {
      background: color-mix(in srgb, var(--bnav-color) 8%, #ffffff 92%);
    }
    @media (prefers-color-scheme: dark) {
      .bnav {
        background: color-mix(in srgb, var(--bnav-color) 14%, #11151c 86%);
      }
    }
  }

  .bnav__link {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    padding: 6px 2px;
    min-height: 52px;
    border-radius: 12px;
    text-decoration: none;
    color: var(--bnav-muted);
    transition: color .15s ease, background-color .2s ease, transform .15s ease;
  }

  .bnav__link:hover { color: var(--bnav-ink); }
  .bnav__link:active { transform: scale(.96); }
  .bnav__link:focus-visible {
    outline: 2px solid var(--bnav-color);
    outline-offset: -2px;
  }

  .bnav__link[aria-current="page"] {
    color: var(--bnav-color);
    background: var(--bnav-active-bg);
    font-weight: 600;
  }
  .bnav__link[aria-current="page"] .bnav__icon {
    transform: translateY(-1px);
  }

  .bnav__icon {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    transition: transform .2s ease;
  }

  .bnav__label {
    font-size: 11px;
    line-height: 1.1;
    font-weight: 500;
    letter-spacing: -0.01em;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  @media (max-width: 380px) {
    .bnav__label { font-size: 10px; }
    .bnav__link { gap: 2px; padding: 6px 1px; }
  }

  /* Защита от перекрытия контента нижним меню */
  body { padding-bottom: calc(60px + env(safe-area-inset-bottom)); }

  /* Кнопка «Наверх» поднимается над меню */
  .scroll-to-top {
    bottom: calc(72px + env(safe-area-inset-bottom)) !important;
  }

  @media (prefers-reduced-motion: reduce) {
    .bnav { transition: none; }
    .bnav__link, .bnav__icon { transition: none; }
  }
}

#faq { scroll-margin-top: 80px; }
