/* Hide Made on Tilda badge */
#tildabadge,
.tilda-badge,
[class*="tilda-made"],
.t-tildalаbеl,
a[href*="tilda.cc"]:not(.t-menu-base__logo a):not(.t-menu-base__logo):not(.t-menu-base__logowrapper a),
a[href*="tilda.ws"]:not(.t-menu-base__logo a):not(.t-menu-base__logo):not(.t-menu-base__logowrapper a) {
  display: none !important;
}

/* Menu items color in header */
.t-menu__link-item,
.t-menu__list a,
#allrecords .t-menu .t-menu__link-item {
  color: #064d2b !important;
}
.t-menu__link-item:hover,
.t-menu__list a:hover {
  color: #0a7040 !important;
}


/* === ScolioFitness · Slovar === */
/* ============================================================
     Токены — точно из бренд-гайда ScolioFitness
     ============================================================ */
  :root {
    --bg:           #fbfaf7;
    --bg-alt:       #f3f0ea;
    --ink:          #1a1a1a;
    --ink-soft:     #3a3a3a;
    --ink-muted:    #6b6b6b;
    --line:         #e4e0d7;
    --line-soft:    #eae6dd;
    --accent:       #8b1a1a;
    --accent-soft:  #b85454;
    --brand-green:      #1a6e4e;
    --brand-green-soft: #e8f0eb;
    --warn-bg:    #fdf6e3;
    --warn-line:  #e8d98a;
    --code-bg:    #f0ece2;

    /* Layout */
    --max-w:      760px;
    --sidebar-w:  240px;
    --grid-gap:   56px;
    --layout-w:   calc(var(--max-w) + var(--sidebar-w) + var(--grid-gap));

    /* Подсветка карточки при переходе по якорю */
    --highlight: rgba(139, 26, 26, 0.08);
  }

  /* Глобальные правила (* { box-sizing }, body { font }, :focus-visible)
     перенесены внутрь .sf-glossary, чтобы не влиять на другие страницы Tilda. */

  /* ============================================================
     ОСНОВНОЙ LAYOUT: двухколоночный grid (sidebar + main)
     ============================================================ */
  /* Tilda-обёртка: одна колонка, своя ширина и базовая типографика.
     Внутри блока T123 Tilda не трогает контент, поэтому сбрасываем
     шрифт/цвет/фон явно через .sf-glossary, чтобы стили не наследовались
     от темы Tilda и наоборот. */
  .sf-glossary {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 24px;
    color: var(--ink);
    background: var(--bg);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 17px;
    line-height: 1.65;
  }
  .sf-glossary * { box-sizing: border-box; }
  .sf-glossary :focus { outline: none; }
  .sf-glossary :focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-radius: 3px;
  }
  .sf-glossary h1,
  .sf-glossary h2,
  .sf-glossary h3 { scroll-margin-top: 80px; }

  @media (max-width: 640px) {
    .sf-glossary { padding: 0 20px; }
  }

  h1, h2, h3 { scroll-margin-top: 100px; }

  /* ----- Шапка статьи ----- */
  .kicker {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-muted);
    margin-bottom: 28px;
    font-weight: 500;
  }
  .kicker .num { color: var(--accent); font-weight: 600; }
  .kicker .sep { width: 24px; height: 1px; background: var(--line); }

  h1 {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(34px, 5.5vw, 52px);
    line-height: 1.12;
    font-weight: 600;
    letter-spacing: -0.01em;
    margin: 0 0 20px;
  }
  h1 em { font-style: italic; color: var(--accent); }

  .lead {
    font-size: 19px;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0 0 40px;
  }

  .meta {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    padding: 16px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    margin-bottom: 48px;
    font-size: 14px;
    color: var(--ink-muted);
  }
  .meta strong { color: var(--ink); font-weight: 500; }

  h2 {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 32px;
    line-height: 1.2;
    font-weight: 600;
    margin: 64px 0 20px;
    letter-spacing: -0.005em;
  }
  h2 .section-num {
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: var(--accent);
    letter-spacing: 0.1em;
    margin-right: 12px;
    vertical-align: middle;
    position: relative;
    top: -4px;
  }
  h3 {
    font-family: 'Inter', sans-serif;
    font-size: 18px;
    font-weight: 600;
    margin: 32px 0 12px;
  }

  p { margin: 0 0 18px; }
  ul, ol { padding-left: 22px; margin: 0 0 20px; }
  li { margin-bottom: 8px; }
  ul li::marker { color: var(--accent-soft); }
  strong { font-weight: 600; }
  em { font-style: italic; color: var(--ink-soft); }
  code {
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 0.9em;
    background: var(--code-bg);
    padding: 1px 6px;
    border-radius: 3px;
  }

  /* ============================================================
     УНИКАЛЬНОЕ ДЛЯ СПРАВОЧНИКА
     ============================================================ */

  /* ============================================================
     MAIN — основная колонка с категориями и карточками
     ============================================================ */ /* для overflow поведения внутри grid */

  .cat {
    margin: 0 0 64px;
    scroll-margin-top: 24px;
  }
  .cat:first-child { margin-top: 0; }
  .cat:last-child { margin-bottom: 0; }
  .cat-intro {
    font-size: 15px;
    color: var(--ink-soft);
    margin: 0 0 32px;
    padding-left: 16px;
    border-left: 2px solid var(--line);
  }

  /* Когда нет результатов поиска */
  .empty-state {
    display: none;
    margin: 32px 0;
    padding: 32px;
    background: var(--bg-alt);
    border-radius: 4px;
    text-align: center;
    color: var(--ink-soft);
  }
  .empty-state strong { color: var(--ink); }
  .sf-glossary.searching .empty-state.visible { display: block; }

  /* Скрываем секцию категории, если в ней нет видимых терминов (поиск) */
  .cat.hidden { display: none; }

  /* ============================================================
     КАРТОЧКА ТЕРМИНА — теперь с поддержкой аккордеона
     ============================================================ */
  .term {
    margin: 0 0 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 4px;
    scroll-margin-top: 24px;
    transition: background 0.4s, border-color 0.2s, box-shadow 0.2s;
  }
  .term.hidden { display: none; }

  /* Подсветка карточки при переходе по якорю */
  .term:target,
  .term.flash {
    border-color: var(--accent);
    background: linear-gradient(0deg, var(--highlight), var(--highlight)), #fff;
    box-shadow: 0 0 0 3px rgba(139, 26, 26, 0.08);
  }

  /* Кликабельная шапка-аккордеон */
  .term-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 24px;
    background: transparent;
    border: none;
    text-align: left;
    cursor: pointer;
    font: inherit;
    color: inherit;
    border-radius: 4px;
  }
  .term-toggle:hover { background: var(--bg); }
  .term-toggle:hover .chevron { color: var(--accent); }

  /* Когда открыто — низ шапки имеет тонкую разделительную */
  .term.open > .term-toggle {
    border-bottom: 1px solid var(--line-soft);
    border-radius: 4px 4px 0 0;
  }

  .term-summary {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 10px 12px;
  }
  .term-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px;
    line-height: 1.15;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -0.005em;
    margin: 0;
  }
  .term-en {
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    color: var(--ink-muted);
    font-style: italic;
    letter-spacing: 0.01em;
  }
  .term-en::before { content: "/ "; opacity: 0.5; font-style: normal; }

  .term-aka {
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent);
    font-weight: 600;
    padding: 2px 7px;
    background: var(--bg-alt);
    border-radius: 2px;
  }

  .term-meta-row {
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-muted);
    flex-basis: 100%;
  }
  .term-cat-link {
    color: var(--ink-muted);
    text-decoration: none;
    border-bottom: 1px dashed var(--line);
    transition: color 0.15s, border-color 0.15s;
  }
  .term-cat-link:hover {
    color: var(--accent);
    border-bottom-color: var(--accent-soft);
  }

  /* Шеврон */
  .chevron {
    flex-shrink: 0;
    color: var(--ink-muted);
    font-size: 14px;
    line-height: 1;
    transition: transform 0.2s, color 0.2s;
    margin-left: 8px;
  }
  .term.open > .term-toggle > .chevron { transform: rotate(180deg); color: var(--accent); }

  /* Тело карточки — сворачивается */
  .term-body {
    display: none;
    padding: 0 24px 24px;
  }
  .term.open > .term-body { display: block; }

  .term-def {
    font-size: 16px;
    line-height: 1.6;
    color: var(--ink);
    margin: 16px 0 18px;
  }
  .term-def:last-child { margin-bottom: 0; }
  .term-def strong { color: var(--ink); }

  /* Доп. поля термина */
  .term-extras {
    margin-top: 16px;
    display: grid;
    gap: 12px;
  }
  .term-field {
    padding: 14px 16px;
    border-radius: 3px;
    font-size: 14px;
    line-height: 1.55;
  }
  .term-field-label {
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 6px;
    display: block;
  }
  .term-field.explain {
    background: var(--brand-green-soft);
  }
  .term-field.explain .term-field-label { color: var(--brand-green); }
  .term-field.example {
    background: var(--bg-alt);
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 13px;
    line-height: 1.6;
    color: var(--ink-soft);
  }
  .term-field.example .term-field-label {
    color: var(--ink-muted);
    font-family: 'Inter', sans-serif;
  }
  .term-field.example .quote {
    display: block;
    color: var(--ink);
  }
  .term-field.example .gloss {
    display: block;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed var(--line);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    color: var(--ink-muted);
    font-style: italic;
  }

  /* На мобильном — компактнее */
  @media (max-width: 640px) {
    .term-toggle { padding: 16px 18px; gap: 10px; }
    .term-body { padding: 0 18px 20px; }
    .term-name { font-size: 21px; }
  }

  /* ============================================================
     УТИЛИТЫ: подсветка совпадения в поисске, кнопка наверх
     ============================================================ */
  .hit-mark {
    background: rgba(139, 26, 26, 0.18);
    color: var(--ink);
    padding: 0 2px;
    border-radius: 2px;
    font-weight: 600;
  }

  .to-top {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: var(--ink);
    border: 1px solid var(--line);
    border-radius: 50%;
    font-size: 18px;
    font-family: 'Cormorant Garamond', serif;
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s, transform 0.2s, border-color 0.15s, color 0.15s;
    z-index: 20;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  }
  .to-top.visible { opacity: 1; pointer-events: auto; }
  .to-top:hover { color: var(--accent); border-color: var(--accent); transform: translateY(-2px); }
  @media (max-width: 640px) {
    .to-top { bottom: 16px; right: 16px; width: 40px; height: 40px; }
  }

  /* ----- Tool-карточка (ссылка на калькулятор, из брендбука) ----- */
  .tool {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    margin: 20px 0 0;
    padding: 18px 20px;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: 4px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.2s, transform 0.2s;
  }
  .tool:hover {
    border-color: var(--brand-green);
    transform: translateX(2px);
  }
  .tool-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--brand-green-soft);
    border-radius: 50%;
    font-family: 'Cormorant Garamond', serif;
    font-weight: 600;
    color: var(--brand-green);
    font-size: 18px;
  }
  .tool-body { flex: 1; }
  .tool-label {
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-muted);
    font-weight: 600;
    margin-bottom: 4px;
  }
  .tool-title { font-weight: 600; font-size: 16px; margin-bottom: 4px; }
  .tool-desc  { font-size: 13.5px; color: var(--ink-muted); line-height: 1.5; }
  .tool-arrow {
    align-self: center;
    color: var(--brand-green);
    font-size: 20px;
    transition: transform 0.2s;
  }
  .tool:hover .tool-arrow { transform: translateX(4px); }

  /* ----- Article-link (компактная ссылка на статью; родственник tool, но нейтральный) ----- */
  .sf-glossary-link {
    display: flex;
    gap: 14px;
    align-items: center;
    margin: 10px 0 0;
    padding: 14px 18px;
    background: var(--bg-alt);
    border-radius: 4px;
    text-decoration: none;
    color: inherit;
    transition: background 0.2s, transform 0.2s;
  }
  .sf-glossary-link:hover {
    background: var(--bg);
    transform: translateX(2px);
  }
  .sf-glossary-link-icon {
    flex-shrink: 0;
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px;
    font-weight: 600;
    color: var(--accent);
    line-height: 1;
  }
  .sf-glossary-link-body { flex: 1; }
  .sf-glossary-link-label {
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-muted);
    font-weight: 600;
    margin-bottom: 2px;
  }
  .sf-glossary-link-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 17px;
    font-weight: 600;
    line-height: 1.25;
    color: var(--ink);
  }
  .sf-glossary-link-arrow {
    color: var(--accent);
    font-size: 16px;
    transition: transform 0.2s;
    opacity: 0.6;
  }
  .sf-glossary-link:hover .sf-glossary-link-arrow {
    transform: translateX(3px);
    opacity: 1;
  }

  /* «См. также» — компактная полоска со ссылками */
  .term-seealso {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--line-soft);
    font-size: 13px;
    color: var(--ink-muted);
  }
  .term-seealso .label {
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--ink-muted);
    margin-right: 8px;
  }
  .term-seealso a {
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px dashed var(--accent-soft);
    margin-right: 4px;
    white-space: nowrap;
  }
  .term-seealso a:hover {
    border-bottom-style: solid;
  }
  .term-seealso a + a::before { content: " · "; color: var(--ink-muted); border: none; margin-right: 4px; }

  /* Дисклеймер */
  .disclaimer {
    margin-top: 56px;
    padding: 20px 24px;
    background: var(--warn-bg);
    border-left: 3px solid var(--warn-line);
    font-size: 14px;
    line-height: 1.55;
    color: var(--ink-soft);
  }
  .disclaimer strong { color: var(--ink); }

  /* ============================================================
     PRINT — раскрыть всё, убрать sidebar и кнопки
     ============================================================ */
  @media print {
    .sf-glossary { background: #fff; font-size: 11pt; }
    .sf-glossary {
      display: block;
      max-width: 100%;
      padding: 0;
    }
    .sidebar, .to-top, .empty-state { display: none !important; }
    .term {
      page-break-inside: avoid;
      break-inside: avoid;
      box-shadow: none;
      border: 1px solid #ccc;
      margin-bottom: 12pt;
    }
    .term .term-body { display: block !important; padding: 0 16pt 14pt; }
    .term .chevron { display: none; }
    .term-toggle {
      cursor: default;
      padding: 12pt 16pt 8pt;
    }
    .cat { page-break-before: auto; margin-bottom: 24pt; }
    .term-field.example { font-size: 9.5pt; }
    a { color: inherit; text-decoration: none; }
    .term-seealso a, .tool, .sf-glossary-link { border-color: #ccc; }
    h1 { font-size: 22pt; }
    h2 { font-size: 18pt; }
  }


  /* ============================================================
     TOP-NAV: поиск + чипы категорий (заменяет sidebar)
     ============================================================ */
  .sf-glossary .top-nav {
    margin: 0 0 56px;
    padding: 24px;
    background: var(--bg-alt);
    border-radius: 4px;
  }
  .sf-glossary .top-nav-title {
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-muted);
    font-weight: 600;
    margin: 0 0 12px;
  }
  .sf-glossary .top-nav .search-box {
    position: relative;
    margin-bottom: 0;
  }
  .sf-glossary .top-nav .search-input {
    width: 100%;
    padding: 12px 36px 12px 14px;
    font: inherit;
    font-size: 16px;
    color: var(--ink);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 4px;
    transition: border-color 0.15s;
  }
  .sf-glossary .top-nav .search-input::placeholder { color: var(--ink-muted); }
  .sf-glossary .top-nav .search-input:focus { border-color: var(--accent); }
  .sf-glossary .top-nav .search-clear {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 26px; height: 26px;
    border: none;
    background: transparent;
    color: var(--ink-muted);
    font-size: 22px;
    cursor: pointer;
    line-height: 1;
    border-radius: 50%;
    display: none;
  }
  .sf-glossary .top-nav .search-clear.visible {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .sf-glossary .top-nav .search-clear:hover {
    background: var(--line);
    color: var(--ink);
  }
  .sf-glossary .top-nav .search-meta {
    margin-top: 8px;
    font-size: 13px;
    color: var(--ink-muted);
    min-height: 18px;
  }

  .sf-glossary .top-nav-cats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .sf-glossary .top-nav-cats a {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    padding: 7px 14px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 999px;
    text-decoration: none;
    color: var(--ink);
    font-size: 13px;
    font-weight: 500;
    transition: border-color 0.15s, color 0.15s;
  }
  .sf-glossary .top-nav-cats a:hover {
    border-color: var(--accent);
    color: var(--accent);
  }
  .sf-glossary .top-nav-cats .num {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 600;
    color: var(--accent);
  }
  .sf-glossary .top-nav-cats .count {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--ink-muted);
  }

  /* Кнопка «наверх» — fixed, инжектится через JS */
  .sf-glossary-totop {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--accent);
    color: #fff;
    border: none;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(0,0,0,0.14);
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity 0.2s, transform 0.2s;
    z-index: 100;
  }
  .sf-glossary-totop.visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  .sf-glossary-totop:hover { background: #6e1313; }

  /* ============================================================
   PATCH 27.04.2026: верхний отступ + стили .article-link
   ============================================================ */

/* 1. Отступ под фиксированное меню Tilda (70px высотой) */
.sf-glossary {
  padding-top: 80px;
}
@media (max-width: 640px) {
  .sf-glossary {
    padding-top: 60px;
  }
}

/* 2. Стили .article-link (компактная ссылка на статью внутри карточки) */
.sf-glossary .article-link {
  display: flex;
  gap: 14px;
  align-items: center;
  margin: 10px 0 0;
  padding: 14px 18px;
  background: var(--bg-alt);
  border-radius: 4px;
  text-decoration: none;
  color: inherit;
  transition: background 0.2s, transform 0.2s;
}
.sf-glossary .article-link:hover {
  background: var(--bg);
  transform: translateX(2px);
}
.sf-glossary .article-link-icon {
  flex-shrink: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--accent);
  line-height: 1;
}
.sf-glossary .article-link-body { flex: 1; }
.sf-glossary .article-link-label {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
  margin-bottom: 2px;
}
.sf-glossary .article-link-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px;
  font-weight: 600;
  line-height: 1.25;
  color: var(--ink);
}
.sf-glossary .article-link-arrow {
  color: var(--accent);
  font-size: 16px;
  transition: transform 0.2s;
  opacity: 0.6;
}
.sf-glossary .article-link:hover .article-link-arrow {
  transform: translateX(3px);
  opacity: 1;
}

/* ============================================================
   PATCH 27.04.2026: фон секций словаря в цвет статьи
   ============================================================
   Tilda по умолчанию рендерит секции (.t-rec) на белом фоне body,
   а сама .sf-glossary ограничена шириной 760px по центру.
   В результате слева/справа от текста — белые поля.
   
   Решение: красим любую t-rec, внутри которой есть .sf-glossary,
   в фон --bg (#fbfaf7) — тёплый off-white из брендбука.
   
   :has() поддерживается всеми актуальными браузерами (Chrome 105+,
   Safari 15.4+, Firefox 121+). На случай старых браузеров —
   дублирующие правила с явными ID секций.
   ============================================================ */

.t-rec:has(.sf-glossary) {
  background-color: #fbfaf7 !important;
}

/* Fallback для браузеров без :has() — явные ID секций словаря */
#rec2209978601,
#rec2210266081,
#rec2210266761,
#rec2210268111 {
  background-color: #fbfaf7 !important;
}