/* === ШАПКА И НАВИГАЦИЯ (БЭМ) === */

/* Блок .header */
.header {
  background-color: var(--color-bg);
  border-bottom: 1px solid color-mix(in srgb, var(--color-muted) 20%, transparent);
  position: sticky;
  padding: var(--space-3) 0;
  top: 0;
  z-index: 100;
}

.header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-3) 0;
}

/* Элемент .header__logo */
.header__logo {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-primary);
  text-decoration: none;
  transition: color 0.2s ease;
}

.header__logo:hover {
  color: var(--color-primary-hover);
}

/* Блок .nav */
.nav__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--space-3);
}

/* Элемент .nav__link */
.nav__link {
  color: var(--color-fg);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius);
  transition: all 0.2s ease;
  position: relative;
}

/* Состояния навигации (LVHA) */
.nav__link:hover {
  background-color: color-mix(in srgb, var(--color-primary) 8%, transparent);
  color: var(--color-fg);
}

.nav__link:active {
  background-color: color-mix(in srgb, var(--color-primary) 15%, transparent);
  transform: translateY(1px);
}

.nav__link--active {
  background-color: var(--color-primary);
  color: var(--color-bg);
  font-weight: 600;
}

/* Индикатор активной страницы */
.nav__link--active::after {
  content: '';
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  background-color: var(--color-primary);
  border-radius: 50%;
}

/* БАЗА: читаемость и предсказуемость размеров */
* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }
body { font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial,
sans-serif; line-height: 1.5; }

/* Формы: размеры, отступы, визуальный порядок */
label { display: block; margin: 0.5rem 0 0.25rem; }
input, select, textarea, button {
 width: 100%;
 max-width: 480px;
 padding: .5rem .75rem;
 border: 1px solid #c8c8c8;
 border-radius: 8px;
 background: #fff;
}

/* Кнопка по умолчанию */
.button {
 background: #0a84ff;
 color: #fff;
 border: none;
 cursor: pointer;
}

button:hover { filter: brightness(0.95); }
:disabled, [aria-disabled="true"] { opacity: .6; cursor: not-allowed; }

/* Подсветка ошибочных полей */
[aria-invalid="true"] { border-color: #b00020; }

/* ===== FORM ===== */
.form {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    max-width: 480px;
}

.form__label {
    display: block;
    margin-bottom: var(--space-1);
    font-weight: 500;
}

.form__input,
.form__select,
.form__textarea {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-muted);
    border-radius: var(--radius);
    font: inherit;
}

.form__input:invalid,
.form__select:invalid,
.form__textarea:invalid {
    border-color: var(--color-danger);
}

.form__actions {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

/* ===== BREADCRUMBS ===== */
.breadcrumbs {
    background: var(--color-bg);
    border-bottom: 1px solid rgba(0,0,0,0.1);
    padding: var(--space-3) 0;
}

.breadcrumbs__list {
    display: flex;
    gap: var(--space-2);
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 0.9rem;
}

.breadcrumbs__item {
    display: flex;
    align-items: center;
}

.breadcrumbs__item:not(:last-child)::after {
    content: "→";
    margin-left: var(--space-2);
    color: var(--color-muted);
}

.breadcrumbs__link {
    color: var(--color-muted);
    text-decoration: none;
    transition: color 0.2s;
}

.breadcrumbs__link:hover {
    color: var(--color-primary);
    text-decoration: underline;
}

.breadcrumbs__current {
    color: var(--color-fg);
    font-weight: 500;
}

/* ===== MODAL ===== */
dialog { 
  padding: 1.25rem; 
  border: none; 
  border-radius: 12px; 
}
dialog::backdrop { 
  background: rgba(0,0,0,.5); 
}

.media {
    aspect-ratio: 16/9;
    width: min(100%, 960px);
    margin-inline: auto;
}

.media video {
    width: 100%;
    height: 100%;
    border-radius: var(--radius);
}

:root{
 /* Палитра */
 --color-bg:#fff; 
 --color-fg:#0b0b0b; 
 --color-muted:#666;
 --color-primary:#0a84ff; 
 --color-danger:#b00020;

 /* Типографика и размеры */
 --font-body:system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

 /* Отступы (шкала) */
 --space-1: 4px; 
 --space-2: 8px; 
 --space-3: 16px; 
 --space-4: 24px; 
 --space-5: 40px;

 /* Скругления и тени */
 --radius:12px;
 --shadow:0 1px 2px rgba(0,0,0,.08), 0 8px 24px rgba(0,0,0,.08);
}

/* Тёмная тема: переопределяем только значения токенов */
body.theme-dark{
 --color-bg:#0b0b0b; --color-fg:#f5f5f5; --color-muted:#aaa;
 --color-primary:#6aa2ff;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }

body{
 background: var(--color-bg);
 color: var(--color-fg);
 font-family: var(--font-body);
 line-height: 1.5;
 scroll-behavior: smooth;
}

/* ===== SMOOTH SCROLL ===== */
html {
    scroll-behavior: smooth;
}

/* ===== TARGET HIGHLIGHT ===== */
:target {
    background: linear-gradient(90deg, var(--color-primary) 0%, transparent 100%);
    padding: var(--space-3);
    border-radius: var(--radius);
}

@keyframes highlight {
    0% { background: rgba(10, 132, 255, 0.3); }
    100% { background: linear-gradient(90deg, var(--color-primary) 0%, transparent 100%); }
}

/* ===== PAGE NAVIGATION ===== */
.page-nav {
    margin: var(--space-4) 0;
}

.page-nav__list {
    display: flex;
    gap: var(--space-3);
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
}

.page-nav__link {
    display: block;
    padding: var(--space-2) var(--space-3);
    background: var(--color-bg);
    border: 1px solid var(--color-muted);
    border-radius: var(--radius);
    text-decoration: none;
    color: var(--color-fg);
    transition: all 0.2s;
}

.page-nav__link:hover {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
}

/* Центровка и ограничение ширины контейнера */
.container{ 
  width:min(100% - 2*var(--space-4), 1120px); 
  margin-inline:auto; 
}

/* Состояния: клавиатура/мышь/ошибки */
:where(input, select, textarea, button):focus-visible {
 outline: 2px solid #0a84ff; 
 outline-offset: 2px;
}

/* Вертикальные отступы секций по токенам */
.section {
    margin: var(--space-5) 0;
    padding: var(--space-4);
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: var(--radius);
}
.section__title{ margin:0 0 var(--space-3); }

/* Базовые стили для медиа */
img, video {
  max-width: 100%;
  height: auto;
  display: block;
}