/* ============================================================
   base.css — reset + типографика + layout-примитивы

   Зависит от: tokens.css, themes.css
   ============================================================ */

/* OpenDyslexic — accessibility font для дислексии. Reference: reader-color-modes-v2.
   External CDN, кириллица ограниченная — fallback chain Andika → system sans. */
@font-face {
  font-family: 'OpenDyslexic';
  src: url('https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/woff/OpenDyslexic-Regular.woff') format('woff');
  font-weight: 400;
  font-display: swap;
}

/* Font presets (.font-lora / .font-inter / …) — каноническое место: themes.css.
   Копии отсюда удалены 2026-05-15 (были дублем из 3 файлов с разной специфичностью
   → непредсказуемый каскад). themes.css грузится всеми страницами. */

/* ===== Per-language font fallback chains =====
   При body.lang-X переопределяется --font-body с приоритетом системных шрифтов
   для нужного script. Noto Sans подгружается из Google Fonts если доступен,
   иначе fallback chain дотягивается до system CJK / Devanagari / Hebrew / Arabic шрифтов. */
body.lang-zh { --font-body: 'Noto Sans SC', 'Noto Sans CJK SC', 'PingFang SC', 'Microsoft YaHei', sans-serif; }
body.lang-hi { --font-body: 'Noto Sans Devanagari', 'Noto Serif Devanagari', 'Mangal', system-ui, sans-serif; }
body.lang-he { --font-body: 'Noto Sans Hebrew', 'Noto Serif Hebrew', 'David', 'Times New Roman', system-ui, sans-serif; }
body.lang-ar { --font-body: 'Noto Naskh Arabic', 'Noto Sans Arabic', 'Traditional Arabic', 'Tahoma', system-ui, sans-serif; }
/* body.lang-en / lang-ru / lang-fr / lang-es — используют user's chosen font (Lora/Source/Inter/etc.) */

/* ===== Kicker-hint — маленькая italic подпись внутри kicker'а
   (для "auto-detected language" hint в settings panel) ===== */
.kicker-hint {
  font-style: italic;
  font-size: 9px;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
  margin-left: 8px;
  text-transform: none;
}

/* ===== Reset ===== */
*, *::before, *::after {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  /* 2026-05-15: clip horizontal overflow от off-canvas элементов
     (.menu-panel position:absolute left:100%, .words-panel slide-in и т.п.) —
     иначе на 1400px viewport появляется фантомный 260px scroll. */
  overflow-x: hidden;
}

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Убираем дефолтные margins у заголовков и параграфов — управляем явно */
h1, h2, h3, h4, h5, h6, p {
  margin: 0;
}

ul, ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

button {
  font-family: inherit;
  color: inherit;
  cursor: pointer;
}

a {
  color: inherit;
  text-decoration: none;
}

img, svg {
  display: block;
  max-width: 100%;
}

/* ===== Типографические дефолты ===== */
.kicker {
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 8px;
}

.title {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ink);
}

/* ============================================================
   Page header (canonical kicker + title pattern из v3-base.jsx)
   Reusable component для всех page entry-points: index, reader,
   word, mywords. Композирует .kicker (10px ui uppercase) +
   .title (display 22-32px fluid).
   ============================================================ */
.page-header {
  margin-bottom: 32px;
  /* span all columns если parent = grid (body.reading грид-2-кол на reader.html) */
  grid-column: 1 / -1;
}
/* Kicker как horizontal row с dot-разделителями (canonical v3-base) */
.page-header > .kicker {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}
.page-header > .kicker a {
  color: inherit;
  transition: color 160ms ease;
}
.page-header > .kicker a:hover {
  color: var(--ink);
}
.page-header > .kicker .kicker__sep {
  color: var(--ink-faint);
  letter-spacing: 0;
  font-weight: normal;
}
/* Title — fluid размер 22-32px responsive */
.page-header > .title {
  font-size: clamp(22px, 4vw, 32px);
}

/* ============================================================
   Page utility row (global navigation links - top of every page)
   Минималистично, right-aligned. Не часть .page-header
   (canonical .page-header = только kicker + title), отдельный bar.
   ============================================================ */
.page-utility {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 16px;
  padding: 12px 24px 4px;
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-muted);
  /* span all columns если parent = grid */
  grid-column: 1 / -1;
}
.page-utility a {
  color: inherit;
  transition: color 160ms ease;
}
.page-utility a:hover {
  color: var(--ink);
}
.page-utility .badge {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 6px;
  background: var(--surface-2);
  border-radius: var(--radius-pill);
  font-size: 10px;
  color: var(--ink-soft);
}

.hint {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-muted);
}

/* ===== Layout-примитивы ===== */

/* Страничный каркас */
.page {
  max-width: 760px;
  margin: 0 auto;
  padding: 56px 40px 80px;
}

/* Контейнер общего назначения */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

/* Flex-row: кнопочные группы, тулбары */
.row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.row--wrap { flex-wrap: wrap; }
.row--end  { justify-content: flex-end; }
.row--between { justify-content: space-between; }

/* Flex-col: вертикальные стеки */
.col {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Утилиты отступов */
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 16px; }
.mt-4 { margin-top: 24px; }
.mt-5 { margin-top: 32px; }
.mt-6 { margin-top: 48px; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 16px; }
.mb-4 { margin-bottom: 24px; }

/* ===== Базовые UI-элементы (кнопки, чипы) ===== */
.btn {
  background: var(--bg);
  color: var(--ink);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  padding: 6px 12px;
  font-family: var(--font-ui);
  font-size: 12px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}
.btn:hover {
  background: var(--hl);
  border-color: var(--border);
}
.btn--primary {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.btn--primary:hover {
  background: var(--ink);
  opacity: 0.88;
}
.btn--ghost {
  background: transparent;
}

/* Large CTA — landing-style primary/secondary button */
.btn--xl {
  padding: 14px 28px;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.005em;
  border-radius: var(--radius-md);
  transition: background 200ms ease, color 200ms ease, border-color 200ms ease,
              transform 160ms ease, box-shadow 200ms ease;
}
.btn--primary.btn--xl:hover {
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 8px 20px color-mix(in oklab, var(--accent) 30%, transparent);
}
.btn--ghost.btn--xl {
  color: var(--ink-soft);
  border: 1px solid var(--border);
}
.btn--ghost.btn--xl:hover {
  color: var(--ink);
  border-color: var(--ink);
  transform: translateY(-1px);
}
.btn--xl:active { transform: translateY(0) scale(0.98); transition-duration: 80ms; }
.btn--xl:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

/* === Brand wordmark (logo style) — used on landing/sitemap/signup === */
.brand-wordmark {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
}

/* .theme-switch / .font-switch — каноническое место: themes.css.
   Копия отсюда удалена 2026-05-15 (была дублем со style.css, разный вид +
   таргетила .is-active вместо .active которое выставляет JS → мёртвое active-состояние). */

/* === Focus-visible базовый для интерактивных элементов === */
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 3px;
}

/* Pill-чип */
.chip {
  background: var(--bg);
  color: var(--ink-soft);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-pill);
  padding: 4px 11px;
  font-family: var(--font-ui);
  font-size: 11px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.chip:hover {
  background: var(--hl);
  color: var(--ink);
}
.chip.is-active,
.chip.on {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

/* Лейбл-маркер для тулбаров */
.bar-label {
  font-family: var(--font-ui);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-right: 4px;
}

/* ===== Скроллбары ===== */
.scroll-thin {
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.scroll-thin::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}
.scroll-thin::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: var(--radius-pill);
}
.scroll-thin::-webkit-scrollbar-track {
  background: transparent;
}

/* ===== Универсальные семантические утилиты ===== */
.surface  { background: var(--surface); }
.surface-2 { background: var(--surface-2); }
.surface-3 { background: var(--surface-3); }

.muted    { color: var(--ink-muted); }
.faint    { color: var(--ink-faint); }
.soft     { color: var(--ink-soft); }

.divider {
  height: 1px;
  background: var(--border-soft);
}
.divider-dashed {
  height: 0;
  border-top: 1px dashed var(--border-soft);
}
