/* ============================================================
   GLOBAL — КВАЗАР (редакционная система, де-AI)
   ============================================================ */

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  color: var(--color-text);
  background-color: var(--color-bg);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv01";
}

.header, main, footer, section { position: relative; z-index: var(--z-base); }

/* ── машиночитаемый блок для ИИ ── */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ── CONTAINER ── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ── SECTIONS / фоновые состояния ── */
.section     { padding-block: var(--section-py); }
.section--sm { padding-block: var(--section-py-sm); }
.section--alt{ background: var(--color-bg-alt); }
/* .section--light определена в variables.css (бумага для кейсов/контента) */
.section--dark { background: var(--color-void); }

/* ── ЗАГОЛОВКИ (редакционная шкала с контрастом) ── */
.section__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5.5vw, var(--text-5xl));
  font-weight: var(--font-weight-bold);
  line-height: var(--leading-snug);
  letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
}
.section__lead {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 60ch;
  margin-bottom: var(--space-8);
  line-height: var(--leading-relaxed);
}

/* eyebrow — чистый трекинговый лейбл с короткой чертой (без свечения) */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--color-text-dim);
}
.eyebrow::before {
  content: '';
  width: 22px; height: 1px;
  background: currentColor;
}

/* ── КНОПКИ — система состояний ── */
.btn {
  --btn-bg: transparent;
  --btn-fg: var(--color-text);
  --btn-bd: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.85rem 1.6rem;
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semi);
  line-height: 1;
  letter-spacing: -0.01em;
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-bd);
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast),
              border-color var(--transition-fast), transform var(--transition-fast);
}
.btn:focus-visible { outline: 2px solid var(--color-gold); outline-offset: 3px; }
.btn:active { transform: translateY(1px) scale(.99); }
.btn[disabled], .btn.is-disabled { opacity: .4; pointer-events: none; }

/* Primary / Accent — единственная заметная заливка акцентом */
.btn--primary, .btn--accent {
  --btn-bg: var(--color-gold);
  --btn-fg: var(--color-text-on-gold);
  --btn-bd: var(--color-gold);
}
.btn--primary:hover, .btn--accent:hover { --btn-bg: var(--color-gold-bright); --btn-bd: var(--color-gold-bright); }

/* Outline — основной вторичный */
.btn--outline { --btn-fg: var(--color-text); --btn-bd: var(--color-border-strong); }
.btn--outline:hover { --btn-bd: var(--color-text); }

/* Ghost — третичный, заливка инверсией при hover */
.btn--ghost { --btn-fg: var(--color-text); --btn-bd: var(--color-border-strong); }
.btn--ghost:hover { --btn-bg: var(--color-text); --btn-fg: var(--color-bg); --btn-bd: var(--color-text); }

.btn--lg  { padding: 1.05rem 2rem; font-size: var(--text-base); }
.btn--sm  { padding: 0.55rem 1rem; font-size: var(--text-xs); }
.btn--full{ width: 100%; }

/* ── PAGE HERO ── */
.page-hero {
  padding-block: var(--space-32) var(--space-12);
}
.page-hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-5xl), 8vw, var(--text-7xl));
  font-weight: var(--font-weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: -0.04em;
  margin-bottom: var(--space-5);
}
.page-hero__sub {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 56ch;
  line-height: var(--leading-relaxed);
}
.page-hero__eyebrow { margin-bottom: var(--space-5); }

/* ── BREADCRUMB ── */
.breadcrumb {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-dim);
  margin-bottom: var(--space-8);
  letter-spacing: .02em;
}
.breadcrumb a:hover { color: var(--color-text); }

/* ── FILTERS ── */
.filters { display: flex; flex-wrap: wrap; gap: 0; }
.filter-btn {
  padding: 0.5rem 1.1rem;
  border: none;
  border-bottom: 2px solid transparent;
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-dim);
  transition: color var(--transition-fast), border-color var(--transition-fast);
  background: transparent;
}
.filter-btn:hover { color: var(--color-text); }
.filter-btn--active { color: var(--color-text); border-bottom-color: var(--color-gold); }

/* ── TAGS ── */
.tag {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  border-bottom: 1px solid var(--color-border-strong);
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.tag:hover { color: var(--color-text); border-color: var(--color-text); }

/* ── CTA SECTION ── */
.cta { text-align: center; }
.cta__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
}
.cta__text { color: var(--color-text-muted); margin-bottom: var(--space-8); font-size: var(--text-lg); }

/* ── PAGINATION ── */
.pagination { display: flex; align-items: center; justify-content: center; gap: var(--space-4); margin-top: var(--space-12); }
.pagination__btn {
  width: 44px; height: 44px;
  border: 1px solid var(--color-border-strong);
  font-size: var(--text-lg);
  color: var(--color-text);
  transition: border-color var(--transition-fast), color var(--transition-fast);
}
.pagination__btn:hover:not(:disabled) { border-color: var(--color-text); }
.pagination__btn:disabled { opacity: .3; cursor: not-allowed; }
.pagination__current { color: var(--color-text); font-weight: var(--font-weight-bold); }
.pagination__total, .pagination__sep { color: var(--color-text-dim); }

/* ── REVEAL (interaction-based motion) ── */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity var(--transition-slow), transform var(--transition-slow); }
.reveal.is-revealed { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

@media (max-width: 768px) {
  :root {
    --section-py: 2.75rem;
    --section-py-sm: 1.75rem;
    --container-pad: 1.25rem;
  }
}
