/* === Шрифт ===
   Manrope — humanist geometric sans с отличной поддержкой кириллицы.
   Variable font (один файл, веса 200-800). Self-hosted ради PWA-offline,
   приватности (никаких запросов к Google) и стабильности под строгим CSP.
   Split на Cyrillic + Latin через unicode-range — браузер качает только нужный сабсет. */
@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("./fonts/manrope-cyrillic.woff2") format("woff2-variations"),
       url("./fonts/manrope-cyrillic.woff2") format("woff2");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("./fonts/manrope-latin.woff2") format("woff2-variations"),
       url("./fonts/manrope-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* color-scheme: говорим браузеру, какая у нас тема — он подстраивает
   полосы прокрутки, дефолтные поля форм и подсветку фокуса.
   Без этого Chrome рендерит form-элементы по теме ОС, что ломает контраст
   в светлом режиме на тёмной системе (и наоборот). */
:root { color-scheme: light; }
html[data-theme="dark"] { color-scheme: dark; }

/* Атрибут [hidden] должен всегда скрывать — иначе любой display: flex/grid
   на элементе перебивает UA-стиль `[hidden] { display: none }`. Грабли для
   модалок, баннеров, всего что переключается через `el.hidden = true`. */
[hidden] { display: none !important; }

:root {
  /* === Палитра — тёплая «бумажная» эстетика ===
     Холодные сине-серые (#f1f2f5) звучали как dashboard SaaS-приложения,
     что не подходит теме. Тёплая бумажная база (off-white #faf9f7) делает
     карточки осязаемыми, спокойнее визуально, лучше читается длинным
     текстом. Бел-чырвоны акцент остаётся (#c41e3a — чуть насыщенней). */
  --bg: #faf9f7;
  --card: #ffffff;
  --card-soft: #f5f3ee;
  --ink: #1a1815;
  --ink-soft: #3d3a35;
  --muted: #6a655c;
  --line: #e8e4dc;
  --line-soft: #efebe3;
  --accent: #c41e3a;
  --accent-dark: #8e0e1e;
  --accent-soft: #fdf0f2;

  /* === Категории — слегка приглушены и сдвинуты в WCAG AA на белом ===
     Каждый цвет даёт контраст ≥4.5:1 с белым фоном бейджа. */
  --cat-education: #1e4dba;
  --cat-financial: #b91c1c;
  --cat-relocation: #0f766e;
  --cat-prisoners: #6d28d9;
  --cat-professional: #15803d;
  --cat-legal: #4338ca;
  --cat-social: #be185d;

  /* === Modular type scale (1.25 ratio, base = 1rem = 16px) ===
     В rem чтобы юзеры с увеличенным шрифтом ОС/браузера видели всё крупнее.
     fluid-display использует clamp для адаптива без media query. */
  --fs-micro:   0.6875rem;  /* 11px — micro labels, dl-note, atag */
  --fs-caption: 0.75rem;    /* 12px — filter-label, channels */
  --fs-small:   0.8125rem;  /* 13px — meta, src-link */
  --fs-base:    0.9375rem;  /* 15px — body small (tab, search) */
  --fs-body:    1rem;       /* 16px — body */
  --fs-h5:      1.0625rem;  /* 17px — card-title */
  --fs-h4:      1.1875rem;  /* 19px — org-name */
  --fs-h3:      1.5rem;     /* 24px — stat-num */
  --fs-h2:      1.75rem;    /* 28px — brand-mark */
  --fs-display: clamp(2.25rem, 5vw, 2.75rem); /* 36-44px — будущие H1 */

  /* === Spacing scale (8-pt grid) === */
  --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-12: 3rem;

  /* === Радиусы === */
  --radius:     14px;
  --radius-sm:  8px;
  --radius-lg:  18px;
  --radius-pill: 999px;

  /* === Тени — мягче, тёплый коричневый оттенок вместо холодного синего === */
  --shadow: 0 1px 2px rgba(60, 45, 30, 0.05), 0 4px 12px rgba(60, 45, 30, 0.06);
  --shadow-hover: 0 2px 6px rgba(60, 45, 30, 0.08), 0 12px 28px rgba(60, 45, 30, 0.10);

  /* === «Мой кейс» === */
  --mycase-bg: #fdf6e3;
  --mycase-border: #e8d8a8;

  /* === Анимации === */
  --motion-fast: 0.12s ease;
  --motion: 0.18s ease;
}

/* === Dark theme — applied via [data-theme="dark"] on <html> ===
   Тёплая dark-палитра вместо холодной сине-серой: визуально мягче
   глазам, лучше совмещается с акцентным красным. */
html[data-theme="dark"] {
  --bg: #14110d;
  --card: #1c1814;
  --card-soft: #221d18;
  --ink: #f0eadf;
  --ink-soft: #c9c1b3;
  --muted: #8a8174;
  --line: #2d2820;
  --line-soft: #24201b;
  --accent-soft: #2e1a14;
  --shadow: 0 1px 3px rgba(0, 0, 0, 0.5), 0 6px 18px rgba(0, 0, 0, 0.45);
  --shadow-hover: 0 2px 6px rgba(0, 0, 0, 0.6), 0 12px 28px rgba(0, 0, 0, 0.55);
  --mycase-bg: #2a2316;
  --mycase-border: #6b5618;
}
html[data-theme="dark"] body { background: var(--bg); color: var(--ink); }
/* В dark mode чисто-белые полосы флага бьют по глазам — заменяем на тёплый
   cream, который читается как «белый» на тёмном бумажном фоне. */
html[data-theme="dark"] .flag-bar {
  background: linear-gradient(
    to bottom,
    #f0e4cd 0 33.33%,
    var(--accent) 33.33% 66.66%,
    #f0e4cd 66.66% 100%
  );
}
html[data-theme="dark"] .site-header { background: var(--card); border-bottom-color: var(--line); }
html[data-theme="dark"] .search,
html[data-theme="dark"] .select,
html[data-theme="dark"] .chip { background: var(--card-soft); color: var(--ink); border-color: var(--line); }
html[data-theme="dark"] .chip[aria-pressed="true"] { background: var(--ink); color: var(--card); border-color: var(--ink); }
html[data-theme="dark"] .badge-status.status-open    { background: #0f3a1d; color: #6cd690; border-color: #1d6b35; }
html[data-theme="dark"] .badge-status.status-rolling { background: #1a2c5e; color: #9cb8f5; border-color: #2747b8; }
html[data-theme="dark"] .badge-status.status-upcoming{ background: #3a2a0a; color: #ecc579; border-color: #98620a; }
html[data-theme="dark"] .badge-status.status-closed  { background: #25282e; color: #9ca3af; border-color: #3a3f4a; }
html[data-theme="dark"] .badge-status.status-unknown { background: #25282e; color: #9ca3af; border-color: #3a3f4a; }
html[data-theme="dark"] .dl-open    { background: #0f3a1d; color: #6cd690; }
html[data-theme="dark"] .dl-soon    { background: #3a2a0a; color: #ecc579; }
html[data-theme="dark"] .dl-urgent  { background: #4a1818; color: #ff7e7e; }
html[data-theme="dark"] .dl-upcoming{ background: #3a2a0a; color: #ecc579; }
html[data-theme="dark"] .dl-closed  { background: #25282e; color: #9ca3af; }
html[data-theme="dark"] .deadline.dl-note { border-color: var(--line); color: var(--muted); }
html[data-theme="dark"] .program-block { background: var(--card-soft); }
html[data-theme="dark"] .program-block.is-featured {
  background: linear-gradient(135deg, #3a2e10 0%, var(--card-soft) 35%);
  box-shadow: inset 0 0 0 1.5px #c79938, 0 2px 10px rgba(201, 153, 56, 0.25);
}
html[data-theme="dark"] .stat-card { background: var(--card); border-color: var(--line); }
html[data-theme="dark"] .controls,
html[data-theme="dark"] .org-card { background: var(--card); border-color: var(--line); }
html[data-theme="dark"] .urgent-label,
html[data-theme="dark"] .urgent-days { color: #ff9e7e; }
html[data-theme="dark"] .urgent-link { color: var(--ink); }
html[data-theme="dark"] .urgent-link:hover { color: #ff9e7e; }
html[data-theme="dark"] .tabs { background: #25282e; }
html[data-theme="dark"] .tab[aria-selected="true"] { background: var(--card); color: var(--ink); }
html[data-theme="dark"] .org-kind { background: #2d313a; color: #c7cad2; }
html[data-theme="dark"] .org-verified,
html[data-theme="dark"] .prog-verified { background: #25282e; color: #9ca3af; }
html[data-theme="dark"] .atag { background: #2d313a; color: #c7cad2; }
html[data-theme="dark"] .prog-conditions, html[data-theme="dark"] .card-conditions { color: var(--ink-soft); }
html[data-theme="dark"] .row-val { color: var(--ink); }
html[data-theme="dark"] .amount-val { color: #ff7e7e; }
html[data-theme="dark"] .org-about { color: var(--ink-soft); }
html[data-theme="dark"] .chip-cash, html[data-theme="dark"] .chip-featured { background: #3a2e10; color: #ecc579; border-color: #c79938; }
html[data-theme="dark"] .chip-featured[aria-pressed="true"] { background: #c79938; color: #14161b; }
html[data-theme="dark"] .chip-case { background: var(--card-soft); }
html[data-theme="dark"] .mycase { background: var(--mycase-bg); border-color: var(--mycase-border); color: #f5d99f; }
html[data-theme="dark"] .mycase-title { color: #f5d99f; }
html[data-theme="dark"] .mycase-toggle { color: #f5d99f; }
html[data-theme="dark"] .mycase-toggle:hover { color: #ffe89b; }
html[data-theme="dark"] .mycase-chevron { color: #c79938; }
html[data-theme="dark"] .mycase-label { color: #c79938; }
html[data-theme="dark"] .mycase-reset { color: #f5d99f; border-color: #6b5618; }
html[data-theme="dark"] .mycase-reset:hover { color: #ffe89b; border-color: #c79938; }

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }

/* Form/button elements в браузерах не наследуют font-family —
   принудительно подтягиваем, иначе у buttons/inputs/selects будет system font. */
button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

body {
  background: var(--bg);
  color: var(--ink);
  /* Manrope первым; system fallback каскадом — пока шрифт грузится (font-display: swap)
     виден system UI, который тоже хорош. Никакого FOIT. */
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI",
               Roboto, "Helvetica Neue", system-ui, sans-serif;
  font-size: var(--fs-body);
  font-weight: 400;
  line-height: 1.55;
  /* Включаем кёрнинг, лигатуры, контекстные альтернативы — оживляет текст,
     делает его менее «механическим». ss01 — стилистический сет Manrope для
     более humanist форм некоторых глифов. */
  font-feature-settings: "kern", "liga", "calt", "ss01";
  font-variant-ligatures: common-ligatures contextual;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  /* Балансируем переносы заголовков чтобы не было сирот — современный браузер. */
  text-wrap: pretty;
}

/* Заголовки получают tighter line-height и tracking — крупный текст должен дышать,
   но не разваливаться. */
h1, h2, h3, h4, h5,
.brand-mark, .org-name, .card-title, .stat-num,
.mycase-title, .onboarding-card h2 {
  line-height: 1.2;
  letter-spacing: -0.01em;
  text-wrap: balance;
}

.wrap {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 18px;
}

/* === Distinctive details ===
   Мелочи, которые превращают «generic AI-сгенерированный layout» в продукт
   с характером. Каждая мелочь сама по себе невидима, но в сумме они
   отличают сайт от шаблона. */

/* Выделение текста — бел-чырвоны акцент, не дефолтный синий браузера. */
::selection {
  background: var(--accent);
  color: #fff;
  text-shadow: none;
}

/* Tabular numerals для статистики, дат, счётчиков — цифры одинаковой
   ширины не «прыгают» при обновлении. Slashed zero отличает 0 от O. */
.stat-num,
.chip-count,
.urgent-more,
.result-count,
.deadline,
.amount-val,
.row-val,
.updated,
.org-verified,
.prog-verified,
.dl-note {
  font-variant-numeric: tabular-nums slashed-zero;
}

/* Ссылки — тоньше дефолтного, со смещённым подчёркиванием, чтобы хвосты
   букв (р, у, ц) не сливались с линией. */
a {
  color: var(--accent-dark);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
  transition: color var(--motion-fast);
}
a:hover { color: var(--accent); }

/* === Keyboard focus ===
   Кольцо видимо только при tab-навигации (focus-visible), не на клик мышью.
   Yелтоватый offset делает кольцо контрастным на любом фоне. */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 4px;
}
.chip:focus-visible,
.tab:focus-visible,
.btn-link:focus-visible,
.btn-link-small:focus-visible,
.onboarding-btn:focus-visible,
.reset-btn:focus-visible,
.theme-toggle:focus-visible,
.mycase-toggle:focus-visible {
  outline-offset: 3px;
}
.search:focus-visible,
.select:focus-visible {
  outline-offset: 0;
  outline-width: 2.5px;
}

/* ---------- Header — masthead pattern ----------
   Архитектура наполненной шапки: каждый пиксель несёт информацию.

   Структура:
     Row 0: бел-чырвона-белая горизонтальная полоса флага (6px) — brand identity
     Row 1: wordmark + tagline (что это за сайт) + theme toggle
     Row 2: meta-line — счётчик + дата + дисклеймер-подсказка одной строкой

   Дисклеймер интегрирован в шапку (раньше отдельный bar тратил +40px).
   Tagline объясняет цель сайта новичкам. Шапка теперь = identity + status,
   а не decorative chrome.

   Высота: 6px флаг + 1px line + ~46px row1 + ~22px row2 = ~75px desktop.
   На мобиле ~80-95px (зависит от переноса tagline). Это плата за integrated
   disclaimer + tagline — но в сумме это меньше чем header+disclaimer-bar+
   tab-desc раньше. */
.site-header {
  background: var(--card);
  color: var(--ink);
  border-bottom: 1px solid var(--line);
}
.flag-bar {
  height: 6px;
  background: linear-gradient(
    to bottom,
    #ffffff 0 33.33%,
    var(--accent) 33.33% 66.66%,
    #ffffff 66.66% 100%
  );
  border-bottom: 1px solid var(--line);
}

/* Row 1: masthead (brand+tagline) + header-side (count+toggle) */
.site-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px 18px;
  padding: 12px 0 6px;
}
/* Grid для masthead: brand auto-width слева, tagline растягивается рядом
   на одной baseline-линии. На узких экранах схлопывается в одну колонку. */
.masthead {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2px 14px;
  align-items: baseline;
  flex: 1;
  min-width: 0;
}
.brand {
  margin: 0;
  font-size: 1.625rem;  /* 26px */
  font-weight: 800;
  letter-spacing: -0.028em;
  line-height: 1;
}
.brand a {
  color: var(--ink);
  text-decoration: none;
}
.brand-tagline {
  margin: 0;
  font-size: 0.875rem;  /* 14px */
  color: var(--muted);
  font-weight: 400;
  line-height: 1.3;
  min-width: 0;
}

/* Правая часть шапки: счётчик + theme toggle.
   Видимый count даёт «весомость» сайта и видимое наполнение шапки. */
.header-side {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.header-status {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  color: var(--muted);
  font-size: var(--fs-caption);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.header-status strong {
  color: var(--ink);
  font-weight: 700;
  font-size: var(--fs-base);
  font-variant-numeric: tabular-nums slashed-zero;
}
.header-status-label { color: var(--muted); }

/* Row 2: meta-line (десктоп only) — дата + integrated disclaimer.
   Скрывается на мобильном (тогда count в Row 1 несёт основной status). */
.site-header-meta {
  padding: 0 0 10px;
}
.meta-line {
  margin: 0;
  font-size: var(--fs-caption);
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  line-height: 1.5;
}
.meta-line .meta-dot {
  opacity: 0.4;
  margin: 0 5px;
  font-weight: 700;
}
.meta-updated time { font-variant-numeric: tabular-nums; }
.meta-advice {
  font-style: italic;
  color: var(--muted);
}

/* .disclaimer-wrap удалён — текст переехал в header meta-line. */

/* ---------- Tabs ---------- */
.tabs {
  display: flex;
  gap: 4px;
  margin: 18px 0 0;
  background: var(--card-soft);
  padding: 3px;
  border-radius: 10px;
  border: 1px solid var(--line);
}
.tab {
  flex: 1;
  border: none;
  background: transparent;
  padding: 9px 14px;
  font-size: var(--fs-base);
  font-weight: 600;
  line-height: 1.25;
  color: var(--muted);
  border-radius: 8px;
  cursor: pointer;
  transition: background var(--motion-fast), color var(--motion-fast);
  letter-spacing: -0.005em;
}
.tab:hover { color: var(--ink); }
.tab[aria-selected="true"] {
  background: var(--card);
  color: var(--ink);
  box-shadow: var(--shadow);
  font-weight: 700;
}

/* .stats section удалён — счётчик переехал в header.
   .stat-card classes сохранены пустыми на случай старого кэша SW. */

/* ---------- Controls ----------
   Компактный фильтр-блок: top-row (поиск + geo) + один ряд чипов
   (рекомендуемые + категории) + footer с count и reset. Без лишних подписей
   и групп. */
.controls {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px 14px;
  margin: 12px 0 18px;
  box-shadow: var(--shadow);
}
.controls-top {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-bottom: 10px;
}
.search {
  width: 100%;
  padding: 9px 13px;
  font-size: var(--fs-base);
  background: var(--card);
  color: var(--ink);
  border: 1.5px solid var(--line);
  border-radius: 9px;
  outline: none;
  transition: border-color var(--motion-fast);
}
.search::placeholder { color: var(--muted); }
.search:focus { border-color: var(--accent); }

.filter-group { margin-bottom: 8px; }
.filter-group-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.filter-group-inline .chips { display: contents; }
.filter-label {
  display: none;  /* eyebrow-лейблы удалены — фильтры сами по себе понятны */
}

.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  border: 1.5px solid var(--line);
  background: #fff;
  color: var(--ink);
  padding: 5px 11px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-small);
  font-weight: 500;
  cursor: pointer;
  transition: background var(--motion-fast), border-color var(--motion-fast), color var(--motion-fast);
  user-select: none;
  white-space: nowrap;
}
.chip:hover { border-color: #bcc0ca; }
.chip[aria-pressed="true"] {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.chip[data-on-color][aria-pressed="true"] {
  background: var(--on-color);
  border-color: var(--on-color);
}
.chip .chip-count { opacity: 0.6; font-size: var(--fs-micro); margin-left: 4px; }

.select {
  padding: 8px 28px 8px 12px;
  font-size: var(--fs-small);
  background: var(--card);
  color: var(--ink);
  border: 1.5px solid var(--line);
  border-radius: 9px;
  outline: none;
  transition: border-color var(--motion-fast);
  /* Кастомная стрелка вместо нативной — единообразный вид через темы */
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%236a655c' stroke-width='1.5' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  min-width: 130px;
}
.select option { background: var(--card); color: var(--ink); }
.select:focus { border-color: var(--accent); }

.controls-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 8px;
}
.controls-footer:empty { display: none; }
.result-count { font-size: var(--fs-caption); color: var(--muted); }
.result-count[hidden] { display: none; }
.reset-btn {
  background: none;
  border: 1px solid var(--line);
  color: var(--muted);
  padding: 5px 12px;
  border-radius: 8px;
  font-size: var(--fs-caption);
  cursor: pointer;
  margin-left: auto;
  transition: border-color var(--motion-fast), color var(--motion-fast);
}
.reset-btn:hover { border-color: var(--accent); color: var(--accent); }

/* ---------- Toggle для closed-программ ---------- */
.show-closed-toggle {
  background: none;
  border: 1px dashed var(--line);
  color: var(--muted);
  padding: 4px 11px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-caption);
  cursor: pointer;
  transition: border-color var(--motion-fast), color var(--motion-fast);
  white-space: nowrap;
}
.show-closed-toggle:hover { border-color: var(--accent); color: var(--accent-dark); }
.show-closed-toggle[aria-pressed="true"] {
  background: var(--card-soft);
  border-style: solid;
  color: var(--ink);
}

/* ---------- Stale-data warning banner ----------
   Показывается когда meta.updated > 60 дней назад. Защита от silent decay
   данных — без сигнала юзер не знает что справочник заброшен.
   60-90 дней: жёлтое предупреждение. 90+ дней: красное жёсткое. */
.stale-warning {
  padding: 9px 14px;
  margin: 14px 0 0;
  font-size: var(--fs-small);
  line-height: 1.4;
  border-radius: 8px;
  border-left: 3px solid #c79938;
  background: #fdf6e3;
  color: #6b5618;
}
.stale-warning.stale-critical {
  border-left-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent-dark);
  font-weight: 600;
}
html[data-theme="dark"] .stale-warning {
  background: #2a2316;
  color: #f5d99f;
  border-left-color: #c79938;
}
html[data-theme="dark"] .stale-warning.stale-critical {
  background: #2e1a14;
  color: #ff9e7e;
  border-left-color: var(--accent);
}

/* ---------- Load error (если data.js не загрузился) ---------- */
.load-error {
  padding: 16px 18px;
  margin: 18px 0;
  background: var(--accent-soft);
  color: var(--accent-dark);
  border: 1px solid var(--accent);
  border-radius: 10px;
  font-size: var(--fs-base);
  line-height: 1.5;
}
.load-error a { color: var(--accent-dark); font-weight: 600; }

.chip-featured {
  background: #fff8e6;
  border-color: #efc77a;
  color: #8a6500;
  font-weight: 700;
}
.chip-featured:hover { border-color: #c79938; }
.chip-featured[aria-pressed="true"] {
  background: #f9c84b;
  color: #1a1d23;
  border-color: #c79938;
}

/* ---------- Program grid — JS masonry (row-first packing) ----------
   Чистого CSS-решения для row-first + no-gaps одновременно не существует:
   - Grid auto-fill row-first → но gap'ы под короткими карточками
   - CSS columns no-gaps → но column-first порядок чтения
   - grid-template-rows: masonry → только Firefox

   Решение: JS-masonry (shortest-column-first). Каждая новая карточка
   ставится в колонку с наименьшей текущей высотой. Для 4 карточек примерно
   равной высоты: 1 в col1, 2 в col2, 3 в col3, 4 в col1 (== row 2).
   Это даёт row-first для подобной высоты + masonry packing для разных.

   .programs.is-masonry-ready активируется когда JS отработал. Без JS
   (fallback) — Grid auto-fill row-first с ragged-bottom. */
.programs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
  margin-bottom: 32px;
  align-items: start;
  position: relative;
}
.programs.is-masonry-ready {
  display: block;
  /* высота задаётся inline через JS */
}
.programs.is-masonry-ready > .org-card {
  position: absolute;
  /* width / top / left задаются inline через JS */
  margin: 0;
}

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 16px 14px;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow);
  transition: box-shadow 0.15s ease, transform 0.15s ease;
  border-top: 4px solid var(--cat, #bcc0ca);
}
.card:hover { box-shadow: var(--shadow-hover); transform: translateY(-2px); }

.card-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 9px;
}
.badge {
  font-size: var(--fs-micro);
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 999px;
  white-space: nowrap;
}
.badge-cat { color: #fff; }

.badge-status { border: 1.5px solid; background: #fff; }
.status-open    { color: #15803d; border-color: #86d6a3; background: #effaf2; }
.status-rolling { color: #1d4ed8; border-color: #9cb8f5; background: #eef2fe; }
.status-upcoming{ color: #b45309; border-color: #ecc579; background: #fdf6e7; }
.status-closed  { color: #6b7280; border-color: #d6d8dd; background: #f4f5f6; }
.status-unknown { color: #6b7280; border-color: #d6d8dd; background: #f4f5f6; }

.card-title {
  font-size: var(--fs-h5);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.01em;
  margin: 0 0 2px;
}
.card-title-orig {
  font-size: var(--fs-caption);
  color: var(--muted);
  margin: 0 0 8px;
  font-style: italic;
}
.card-org { font-size: var(--fs-small); color: var(--muted); margin: 0 0 10px; }

.card-row {
  display: flex;
  gap: 8px;
  font-size: var(--fs-small);
  padding: 6px 0;
  border-top: 1px dashed var(--line);
}
.card-row .row-key {
  color: var(--muted);
  flex: 0 0 78px;
  font-size: var(--fs-caption);
  padding-top: 1px;
}
.card-row .row-val { flex: 1; }
.amount-val { font-weight: 700; color: var(--accent-dark); }

.deadline {
  margin: 10px 0 4px;
  font-size: var(--fs-small);
  font-weight: 600;
  padding: 7px 10px;
  border-radius: 8px;
}
/* Цветные дедлайны — только когда реально есть дата (open programs). */
.dl-urgent  { background: #fdeaea; color: #b3261e; }
.dl-soon    { background: #fdf3e3; color: #98620a; }
.dl-open    { background: #eaf7ee; color: #1d6b35; }
.dl-closed  { background: #f1f2f4; color: #6b7280; }
.dl-upcoming{ background: #fdf6e7; color: #98620a; }

/* dl-note — для rolling-программ с note или unknown-статусов.
   Не цветная плашка (это не дедлайн как событие), а subtle italic note —
   «приём по запросу через X». Прозрачный фон + dashed border = «информация»,
   а не «срочность». */
.deadline.dl-note {
  background: transparent;
  border: 1px dashed var(--line);
  color: var(--muted);
  font-weight: 400;
  font-size: var(--fs-caption);
  padding: 5px 9px;
  font-style: italic;
}
/* Старый .dl-note для <p>-элемента под open-deadline (рекомендация) — оставлен */
p.dl-note {
  font-size: var(--fs-caption);
  color: var(--muted);
  margin: 6px 0 0;
  padding-left: 2px;
}

.card-conditions { font-size: var(--fs-small); color: #3a3f4a; margin: 8px 0 0; }

.audience-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.atag {
  font-size: var(--fs-micro);
  background: #eef0f3;
  color: #4a4f5a;
  padding: 2px 8px;
  border-radius: 6px;
}

.card-foot {
  margin-top: auto;
  padding-top: 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.btn-link {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  text-decoration: none;
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: -0.005em;
  padding: 8px 14px;
  border-radius: 9px;
  transition: background var(--motion-fast);
  font-family: inherit;
}
.btn-link:hover { background: var(--accent-dark); }
.src-link { font-size: var(--fs-caption); color: var(--muted); }

.channels { font-size: var(--fs-caption); color: var(--muted); margin-top: 9px; }
.channels b { color: #4a4f5a; font-weight: 600; }

.empty {
  text-align: center;
  color: var(--muted);
  padding: 40px 20px;
  font-size: var(--fs-base);
}
.empty-text { margin: 0 0 14px; color: var(--ink-soft); font-size: var(--fs-base); }
.empty-chips { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 18px; }
.empty-chip {
  background: var(--card);
  border: 1.5px solid var(--accent);
  color: var(--accent-dark);
  cursor: pointer;
  padding: 5px 11px;
  border-radius: 999px;
  font-size: var(--fs-small);
}
.empty-chip:hover { background: var(--accent); color: #fff; }
.empty-reset { margin: 0 auto; display: inline-block; }

/* «Ещё типы» — кнопка-чип для прогрессивного раскрытия */
.chip-more {
  background: transparent;
  border: 1.5px dashed var(--line);
  color: var(--muted);
  font-style: italic;
}
.chip-more:hover { border-color: var(--accent); color: var(--accent); border-style: solid; }

/* «Мой кейс» — toggle для раскрытия body (Кто я / Где я / Что нужно).
   Presets-row остаётся видимым всегда. */
.mycase-toggle {
  background: none;
  border: 1px solid #cdb27e;
  color: #6b5618;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 9px;
  border-radius: 6px;
  font-size: var(--fs-caption);
  font-weight: 600;
  margin-left: auto;
  transition: background var(--motion-fast), border-color var(--motion-fast);
}
.mycase-toggle:hover { background: rgba(255,255,255,0.6); border-color: #c79938; }
.mycase-chevron {
  display: inline-block;
  font-size: 10px;
  transition: transform var(--motion);
}
.mycase-collapsed .mycase-chevron { transform: rotate(-90deg); }
.mycase-collapsed .mycase-body { display: none; }
html[data-theme="dark"] .mycase-toggle { color: #f5d99f; border-color: #6b5618; }
html[data-theme="dark"] .mycase-toggle:hover { color: #ffe89b; background: rgba(255,255,255,0.05); }
html[data-theme="dark"] .mycase-eyebrow { color: #c79938; }
html[data-theme="dark"] .mycase-body { border-top-color: #6b5618; }

/* ---------- Org cards ----------
   display: block — раньше был flex column ради margin-top:auto на foot
   (чтобы прижимать к низу при grid stretching). С CSS columns карточка
   берёт натуральную высоту, foot ложится естественно. */
.org-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 16px 13px;
  display: block;
  box-shadow: var(--shadow);
  transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.org-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-2px); }

.org-header { margin-bottom: 12px; }
.org-top {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 4px;
}
.org-name {
  font-size: var(--fs-h4);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--ink);
}
.org-kind {
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: #6b7280;
  background: #eef0f3;
  padding: 2px 8px;
  border-radius: 6px;
  white-space: nowrap;
}
.org-orig {
  font-size: var(--fs-caption);
  color: var(--muted);
  margin: 0 0 6px;
  font-style: italic;
}
.org-about {
  font-size: var(--fs-small);
  color: #3a3f4a;
  margin: 4px 0 8px;
  line-height: 1.45;
}
.org-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  font-size: var(--fs-caption);
  color: var(--muted);
}
.org-verified {
  background: #f1f2f4;
  padding: 1px 8px;
  border-radius: 6px;
  font-size: var(--fs-micro);
}

/* Contacts (Вясна и т.п.) ---------------
   ВАЖНО: цвета только через CSS-переменные, иначе в dark mode label-ы
   становились невидимы (был hardcoded #3a3f4a на тёмном фоне — баг). */
.org-contacts {
  background: var(--card-soft);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px;
}
.contacts-title {
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  margin-bottom: 6px;
}
.contacts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.contact-item {
  font-size: var(--fs-small);
  line-height: 1.45;
}
.contact-label { color: var(--ink-soft); }
.contact-value { color: var(--accent-dark); font-weight: 600; }
.contact-value a, .channels a {
  color: var(--accent-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
}
.contact-value a:hover, .channels a:hover { color: var(--accent); }
/* Dark mode — стрелка → должна быть тоже видимой */
html[data-theme="dark"] .contact-item { color: var(--ink-soft); }
html[data-theme="dark"] .contact-value a,
html[data-theme="dark"] .channels a { color: #ff9e8e; }
html[data-theme="dark"] .contact-value a:hover,
html[data-theme="dark"] .channels a:hover { color: #ffbf9e; }

/* Programs list inside org card */
.org-programs {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 12px;
}

.program-block {
  position: relative;
  border-left: 4px solid var(--ptype, #bcc0ca);
  background: #fafbfc;
  border-radius: 0 8px 8px 0;
  padding: 10px 12px 12px;
  transition: opacity 0.15s ease, box-shadow 0.15s ease;
}

/* ★ Рекомендуемые программы — золотистая обводка + угловая звезда */
.program-block.is-featured {
  background: linear-gradient(135deg, #fff8e6 0%, #fafbfc 35%);
  box-shadow: inset 0 0 0 1.5px #efc77a, 0 2px 10px rgba(201, 153, 56, 0.15);
}
.program-block.is-featured::after {
  content: "★";
  position: absolute;
  top: 6px;
  right: 10px;
  color: #c79938;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
  pointer-events: none;
}
.program-block.is-featured .prog-head { padding-right: 24px; }

/* Закрытые программы — приглушены постоянно, без hover-боста
   (раньше hover поднимал opacity до 0.95 — сбивало с толку). */
.program-block.is-closed {
  opacity: 0.55;
  filter: saturate(0.4);
}

/* Если у организации ВСЕ видимые программы закрыты — гасим всю карточку */
.org-card.is-closed {
  opacity: 0.7;
  filter: saturate(0.5);
}

.prog-head {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 6px;
}

.badge-type {
  color: #fff;
}
.badge-featured {
  background: #f9c84b;
  color: #5a4200;
  border: 1px solid #c79938;
  font-weight: 700;
}

.prog-title {
  font-size: var(--fs-base);
  font-weight: 700;
  margin: 0 0 6px;
  line-height: 1.3;
  letter-spacing: -0.005em;
  color: var(--ink);
}

.prog-conditions {
  font-size: var(--fs-small);
  color: #3a3f4a;
  margin: 6px 0 0;
  line-height: 1.45;
}

.prog-foot {
  margin-top: 10px;
}

.btn-link-small {
  display: inline-block;
  background: #1c1f26;
  color: #fff;
  text-decoration: none;
  font-size: var(--fs-caption);
  font-weight: 600;
  letter-spacing: -0.003em;
  padding: 6px 12px;
  border-radius: 7px;
  font-family: inherit;
  transition: background var(--motion-fast);
}
.btn-link-small:hover { background: #2d313a; }

/* Org footer */
.org-foot {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.org-foot .channels { margin-top: 0; }

/* ---------- Footer (минимальный one-liner) ---------- */
.site-footer {
  background: transparent;
  border-top: 1px solid var(--line);
  color: var(--muted);
  padding: 14px 0;
  font-size: var(--fs-caption);
  text-align: center;
  margin-top: 24px;
}
.site-footer .wrap { padding: 0 18px; }

/* ---------- «Мой кейс» ----------
   Новая структура: presets-row — одна строка с горизонтальным скроллом
   (нет wrap), toggle inline справа фиксированной позицией. Body (Кто я /
   Где я / Что нужно) collapsed by default. */
.mycase {
  background: #fdf6e3;
  border: 1px solid #e8d8a8;
  border-radius: var(--radius);
  padding: 8px 12px;
  margin: 12px 0;
}
.mycase-presets-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mycase-eyebrow {
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #6b5618;
  flex-shrink: 0;
}
/* Pресеты — одна строка, горизонтальный скролл при overflow.
   Тонкая scrollbar чтобы не съедала визуальную высоту. */
.mycase .mycase-chips {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  gap: 6px;
  flex: 1;
  min-width: 0;
  /* Безопасный bottom-padding чтобы скроллбар не обрезал hover-эффект */
  padding-bottom: 2px;
  scrollbar-width: thin;
  scrollbar-color: #c79938 transparent;
  /* Затухание справа сигналит «можно скроллить» */
  mask-image: linear-gradient(to right, #000 calc(100% - 24px), transparent 100%);
  -webkit-mask-image: linear-gradient(to right, #000 calc(100% - 24px), transparent 100%);
}
.mycase .mycase-chips::-webkit-scrollbar { height: 4px; }
.mycase .mycase-chips::-webkit-scrollbar-thumb { background: #c79938; border-radius: 2px; }
.mycase .mycase-chips::-webkit-scrollbar-track { background: transparent; }
.mycase-body {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed #e8d8a8;
}
/* Body внутренние chips — обычный wrap (не horizontal scroll), это
   правильное поведение для деталей. */
.mycase-body .mycase-chips {
  display: flex;
  flex-wrap: wrap;
  overflow: visible;
  mask-image: none;
  -webkit-mask-image: none;
  padding-bottom: 0;
}
.mycase-row {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 6px 12px;
  align-items: center;
  padding: 5px 0;
}
.mycase-label {
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #6b5618;
}
.mycase-foot { margin-top: 6px; text-align: right; }
.mycase-reset {
  background: none;
  border: 1px solid #cdb27e;
  color: #6b5618;
  font-size: var(--fs-caption);
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
}
.mycase-reset:hover { background: rgba(255,255,255,0.6); }
.chip-case {
  background: #fff;
  border-color: #e0cea0;
  color: var(--ink);
  font-size: var(--fs-caption);
}
.chip-case:hover { border-color: #c79938; }
.chip-case[aria-pressed="true"] {
  background: #f9c84b;
  border-color: #c79938;
  color: #1a1d23;
}

/* ---------- Срочно (компактный one-liner, без эмодзи) ----------
   Тонкая полоска вверху, минимум визуального веса. Только текст +
   ссылка + дней. Не баннер, а уведомление. */
.urgent {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px 10px;
  background: transparent;
  border-left: 3px solid var(--accent);
  padding: 6px 10px;
  margin: 0 0 10px;
  font-size: var(--fs-small);
}
.urgent-label {
  font-weight: 700;
  color: var(--accent-dark);
  text-transform: uppercase;
  font-size: var(--fs-micro);
  letter-spacing: 0.08em;
  flex-shrink: 0;
}
.urgent-link {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  font-weight: 500;
}
.urgent-link:hover { color: var(--accent-dark); }
.urgent-days {
  color: var(--accent-dark);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-caption);
}
.urgent-more {
  color: var(--muted);
  font-size: var(--fs-caption);
  font-variant-numeric: tabular-nums;
}

/* ---------- Сообщить о проблеме ---------- */
.prog-foot {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.report-btn {
  background: none;
  border: none;
  color: var(--muted);
  font-size: var(--fs-micro);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  padding: 4px 0;
}
.report-btn:hover { color: var(--accent-dark); }

/* ---------- Toast ---------- */
.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translate(-50%, 12px);
  background: #1c1f26;
  color: #fff;
  padding: 11px 18px;
  border-radius: 10px;
  font-size: var(--fs-small);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
  max-width: calc(100vw - 32px);
  opacity: 0;
  transition: opacity 0.22s ease, transform 0.22s ease;
  z-index: 9999;
}
.toast.toast-show { opacity: 1; transform: translate(-50%, 0); }
.toast { display: flex; align-items: center; gap: 10px; }
.toast-text { flex: 1; min-width: 0; }
.toast-close {
  background: none;
  border: none;
  color: #fff;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  padding: 2px 6px;
  margin: -2px -6px -2px 0;
  opacity: 0.7;
  border-radius: 4px;
}
.toast-close:hover { opacity: 1; background: rgba(255,255,255,0.1); }

/* ---------- Theme toggle button ----------
   A11y: минимум 36px на десктопе, 38-40px на мобиле (соответствует
   рекомендации Apple HIG 44pt и Material Design 48dp для touch targets).
   Заметный фон + border делают кнопку явно кликабельной, не «голым» эмодзи. */
.theme-toggle {
  background: var(--card-soft);
  border: 1px solid var(--line);
  color: var(--ink);
  width: 36px;
  height: 36px;
  border-radius: 10px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--motion-fast), border-color var(--motion-fast), color var(--motion-fast);
  flex-shrink: 0;
  padding: 0;
  /* Слегка приподнимаем чтобы оптически выровнять с brand baseline */
  margin-top: 2px;
}
.theme-toggle:hover {
  background: var(--bg);
  border-color: var(--muted);
  color: var(--accent-dark);
}
.theme-toggle:active { transform: scale(0.96); }
.theme-toggle-icon {
  font-size: 1.05rem;
  line-height: 1;
  display: inline-block;
}
html[data-theme="dark"] .theme-toggle {
  background: var(--card-soft);
  border-color: var(--line);
}
html[data-theme="dark"] .theme-toggle:hover {
  background: var(--bg);
  border-color: var(--muted);
  color: #ff9e7e;
}

/* ---------- Presets ---------- */
.mycase-row-presets .mycase-label { color: #8a6500; font-weight: 800; }
.chip-preset {
  background: #fff;
  border: 1.5px dashed #c79938;
  color: #5a4200;
  font-weight: 600;
}
.chip-preset:hover { border-style: solid; background: #fff8e6; }
.chip-preset[aria-pressed="true"] {
  background: #c79938;
  color: #fff;
  border-color: #c79938;
  border-style: solid;
}
html[data-theme="dark"] .chip-preset { background: var(--card-soft); color: #ecc579; }
html[data-theme="dark"] .chip-preset[aria-pressed="true"] { background: #c79938; color: #14161b; }

/* ---------- Per-program verified badge ---------- */
.prog-verified {
  display: inline-block;
  font-size: var(--fs-micro);
  color: var(--muted);
  background: #f1f2f4;
  padding: 1px 7px;
  border-radius: 5px;
  margin-bottom: 6px;
}

/* ---------- Onboarding modal ---------- */
.onboarding[hidden] { display: none; }
.onboarding {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 16px;
  animation: onbFadeIn 0.18s ease;
}
@keyframes onbFadeIn { from { opacity: 0; } to { opacity: 1; } }
.onboarding-card {
  background: var(--card);
  color: var(--ink);
  border-radius: 14px;
  max-width: 480px;
  width: 100%;
  padding: 22px 22px 18px;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.3);
  max-height: 90vh;
  overflow-y: auto;
}
.onboarding-card h2 {
  margin: 0 0 10px;
  font-size: var(--fs-h3);
  font-weight: 800;
  letter-spacing: -0.02em;
}
.onboarding-card p {
  margin: 0 0 10px;
  line-height: 1.5;
  font-size: var(--fs-base);
  color: var(--ink-soft);
}
.onboarding-list {
  margin: 6px 0 12px;
  padding-left: 20px;
  font-size: var(--fs-small);
  color: var(--ink-soft);
}
.onboarding-list li { margin: 4px 0; line-height: 1.5; }
.onboarding-list strong { color: var(--ink); font-weight: 700; }
.onboarding-meta {
  font-size: var(--fs-small);
  color: var(--muted);
  font-style: italic;
  margin: 8px 0 0;
  line-height: 1.45;
}
.onboarding-btn {
  display: block;
  width: 100%;
  background: var(--accent);
  color: #fff;
  border: none;
  font-size: var(--fs-base);
  font-weight: 700;
  padding: 11px;
  border-radius: 10px;
  cursor: pointer;
  margin-top: 6px;
  letter-spacing: -0.005em;
  transition: background var(--motion-fast);
}
.onboarding-btn:hover { background: var(--accent-dark); }

/* ---------- Responsive ----------
   .programs использует JS masonry — кол-во колонок и позиции вычисляются
   в JS (см. relayoutPrograms в app.js) на основе container.clientWidth.
   CSS fallback (Grid auto-fill) при не-JS среде использует minmax(340px). */

/* Промежуточный брейкпойнт: tagline начинает сжиматься / переноситься.
   Здесь убираем grid → block чтобы tagline шла под brand без выламывания
   row-структуры. */
@media (max-width: 880px) {
  .masthead { grid-template-columns: 1fr; gap: 2px; }
  .brand { font-size: 1.5rem; }
  .brand-tagline { font-size: 0.8125rem; line-height: 1.35; }
}

/* Mobile: радикальное упрощение шапки до 1 строки.
   Brand + count + theme = ВСЁ что нужно на мобиле. Tagline и meta-line
   убираются — tagline дублирует onboarding modal + page title, meta уходит
   в footer. Это паттерн «utility bar» из Twitter/Reddit mobile. */
@media (max-width: 620px) {
  .site-header-inner {
    padding: 9px 0;
    gap: 10px 12px;
    align-items: center;
  }
  .brand { font-size: 1.25rem; letter-spacing: -0.02em; }
  .brand-tagline { display: none; }   /* уходит в onboarding (первый визит) */
  .site-header-meta { display: none; } /* дата/disclaimer уходят в footer */
  .masthead { display: block; }        /* нет нужды в grid, brand один */
  .header-side { gap: 10px; }
  .header-status { font-size: var(--fs-micro); }
  .header-status strong { font-size: var(--fs-small); }
  .tab { padding: 8px 10px; font-size: var(--fs-small); }
  .controls-top { grid-template-columns: 1fr; }
  .controls { padding: 10px 12px; }
  .urgent { padding: 5px 10px; }
  /* Mycase полностью убираем с телефона — на маленьком экране это шум.
     Юзер фильтрует через категории/поиск, presets ему не помогают
     (они занимают 3-4 строки чипов). */
  .mycase { display: none; }

  /* Card density tuning — на узком экране каждая карточка занимает полную
     ширину, поэтому уплотняем внутренние paddings и убираем мелкие декоры. */
  .org-card { padding: 13px 13px 11px; border-radius: 12px; }
  .programs > .org-card { margin-bottom: 11px; }
  .org-header { margin-bottom: 9px; }
  .org-name { font-size: var(--fs-h5); }
  .org-about { font-size: var(--fs-small); margin: 3px 0 6px; line-height: 1.4; }
  .org-contacts { padding: 8px 10px; margin-bottom: 9px; }
  .org-programs { gap: 9px; }
  .program-block { padding: 8px 10px 10px; }
  .prog-title { font-size: var(--fs-small); margin-bottom: 5px; }
  .prog-conditions { font-size: var(--fs-caption); line-height: 1.4; }
  .card-row { padding: 4px 0; font-size: var(--fs-caption); }
  .card-row .row-key { flex: 0 0 64px; font-size: var(--fs-micro); }
  .deadline { margin: 7px 0 3px; padding: 5px 8px; font-size: var(--fs-caption); }
  .btn-link-small { font-size: var(--fs-micro); padding: 5px 10px; }
  .report-btn { font-size: var(--fs-micro); }
  .org-foot { padding-top: 9px; }
  .channels { font-size: var(--fs-micro); }
}
@media (max-width: 400px) {
  .wrap { padding: 0 12px; }
  .tab { padding: 8px 6px; }
  .brand { font-size: 1.125rem; }
  .flag-bar { height: 5px; }
  .header-status-label { display: none; }  /* совсем узко — оставляем «47» без подписи */
  .theme-toggle { width: 38px; height: 38px; }
  .theme-toggle-icon { font-size: 1.1rem; }
}

/* ===========================================================================
   Accessibility — preference-driven overrides
   =========================================================================== */

/* Уважаем prefers-reduced-motion: гасим transform-эффекты и сокращаем
   все transitions/animations до неощутимых. Не выключаем opacity-переходы
   полностью — иначе UI начинает «прыгать» (toast, модалка). */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .card:hover,
  .org-card:hover,
  .theme-toggle:hover {
    transform: none;
  }
  .toast.toast-show {
    transform: translate(-50%, 0);
  }
}

/* prefers-contrast: more — пользователю нужен больше контраст (low-vision,
   яркое солнце). Затемняем muted, делаем границы заметнее. */
@media (prefers-contrast: more) {
  :root {
    --line: #999;
    --line-soft: #aaa;
    --muted: #444;
    --ink-soft: #222;
  }
  html[data-theme="dark"] {
    --line: #666;
    --line-soft: #555;
    --muted: #c0bdb6;
    --ink-soft: #f5f0e6;
  }
  .chip, .search, .select {
    border-width: 2px;
  }
  .btn-link, .btn-link-small {
    outline: 2px solid currentColor;
    outline-offset: -2px;
  }
}

/* Тачскрин — гасим hover-эффекты (на мобиле hover «залипает» после тапа). */
@media (hover: none) {
  .card:hover,
  .org-card:hover {
    transform: none;
    box-shadow: var(--shadow);
  }
}

/* Печать — оставляем содержимое читаемым, прячем интерактив. */
@media print {
  .controls, .tabs, .mycase, .urgent,
  .theme-toggle, .report-btn, .reset-btn,
  .onboarding, .toast {
    display: none !important;
  }
  body { background: #fff; color: #000; }
  .card, .org-card { break-inside: avoid; box-shadow: none; border: 1px solid #999; }
  a { color: #000; text-decoration: underline; }
  a::after { content: " (" attr(href) ")"; font-size: 0.85em; color: #555; }
}
