/* ============================================================================
   admin.css — ЕДИНЫЙ источник стилей админки ПКГ РЕБУС (durable-фикс против дрейфа).
   Подключается первым во всех 4 страницах (index / prizes / campaign / season),
   до их инлайн-<style> (там — только page-specific). Канон-токены + shell + AdminNav.
   Стиль админки: лаконично, сухо, функционально. Зона Claude (не Codex).
   ВНИМАНИЕ: палитра типов ачивок (.ach-card[data-type]/.qa-btn[data-type]) —
   НЕ здесь и НЕ трогать (живёт в season.html, семантика типов).
   ============================================================================ */

:root {
  /* — текст (3 ступени серого вместо прежних 5) — */
  --ink: #1b1b18;          /* основной текст */
  --ink-2: #3c3c37;        /* вторичные заголовки/сильный вторичный */
  --label: #5b5b54;        /* подписи полей, текст контролов */
  --muted: #6a6a62;        /* приглушённый текст (AA на светлом) */
  --faint: #71716a;        /* тихий: хинты, who, шевроны, плейсхолдеры, id (AA ≥4.5 на белом, U2) */

  /* — поверхности — */
  --bg: #f4f4f1;
  --surface: #fff;
  --surface-2: #f7f7f4;    /* hover/inset светлый */
  --surface-3: #f2f2ee;    /* hover кнопок/иконок */

  /* — границы — */
  --border: #d9d9d2;       /* бордюр карточек/поверхностей */
  --border-input: #cfcfc7; /* поля ввода, контролы */
  --divider: #e6e6e0;      /* тонкий внутренний разделитель (solid) */

  /* — статус/опасность (ОДИН красный) — */
  --danger: #b3261e;       /* ошибки + деструктив + статус «отменена» */
  --st-draft: #6a6a62;     /* черновик/прочее */
  --st-live: #2c6b1e;      /* идёт / готов */
  --st-paused: #9a6a12;    /* пауза/запланирована */
  --st-cancelled: #b3261e; /* отменена (= --danger) */
  --st-season-live: #145a78;/* сезон в игре */

  /* — радиусы (5 ступеней: убрана дублирующая 9) — */
  --r-sm: 6px;             /* мелкое медиа */
  --r-nav: 7px;            /* пункты nav, мелкие икон-кнопки */
  --r-ctl: 8px;            /* кнопки, поля ввода */
  --r-row: 10px;           /* вторичные строки, меню, icon-cell (было 9/10) */
  --r-card: 12px;          /* карточки, модалки */

  /* — тёмный сайдбар — */
  --nav-w: 232px;           /* ширина сайдбара — единый источник для shell и фикс-панели публикации (K4) */
  --nav-bg: #1b1b18;
  --nav-fg: #cfcfc7;
  --nav-hover: #2e2e2a;
  --nav-cap: #8f8f87;       /* подписи секций сайдбара (AA ≥4.5 на тёмном, U2) */

  /* — фокус — */
  --ring: #2b6cb0;          /* кольцо фокуса с клавиатуры (нейтральный синий, не бренд; U1) */
}

/* ===== reset ===== */
* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, sans-serif; color: var(--ink); background: var(--bg); }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; }
.hide { display: none !important; }

/* ===== фокус с клавиатуры (WCAG 2.4.7, U1) — видимое кольцо на всех интерактивных ===== */
:focus-visible { outline: 2px solid var(--ring) !important; outline-offset: 2px; border-radius: 3px; }
/* мышь/тач — без кольца (только клавиатура) */
:focus:not(:focus-visible) { outline: none; }

/* ===== кнопки ===== */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 8px 15px; border: 1px solid var(--ink); border-radius: var(--r-ctl); background: var(--ink); color: #fff; font-weight: 600; font-size: 14px; }
.btn.ghost { background: #fff; color: var(--ink); border-color: var(--border-input); }
.btn.sm { padding: 5px 10px; font-size: 13px; font-weight: 500; }
.btn.block { width: 100%; }
.btn.danger { background: #fff; color: var(--danger); border-color: #e0c4c0; }
.btn:disabled { opacity: .45; cursor: default; }

/* ===== поля формы ===== */
.form-error { color: var(--danger); font-size: 13px; min-height: 18px; margin: 6px 0 0; }
.form-error:empty { min-height: 0; margin: 0; } /* пустой error не резервирует место → ровные отступы между секциями */
.ach-saved:not(.show) { display: none; } /* «сохранено ✓» не занимает строку, пока не вспыхнул */
.field { display: grid; gap: 6px; }
.field label, .lbl { font-size: 12px; color: var(--label); }
.field label .req, .req { color: var(--danger); }
.field input, .field select, .field textarea, .inp { padding: 8px 10px; border: 1px solid var(--border-input); border-radius: var(--r-ctl); width: 100%; }
/* кастомная стрелка select: своя зона 12px от правой стенки (нативная липнет к краю) */
.field select, select.inp { -webkit-appearance: none; -moz-appearance: none; appearance: none; padding-right: 34px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b5b54' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>"); background-repeat: no-repeat; background-position: right 12px center; }
textarea.inp { resize: vertical; min-height: 56px; }
.muted { color: var(--muted); font-size: 13px; }

/* ===== shell + AdminNav (единый канон на всех 4) ===== */
.admin-shell { display: grid; grid-template-columns: var(--nav-w) minmax(0,1fr); min-height: 100vh; }
.admin-nav { background: var(--nav-bg); color: #e8e8e2; display: flex; flex-direction: column; padding: 18px 14px; position: sticky; top: 0; height: 100vh; align-self: start; overflow-y: auto; }
.admin-brand { font-weight: 800; margin: 0 0 14px; font-size: 15px; }
.admin-brand small { display: block; color: var(--faint); font-weight: 500; font-size: 12px; }
.brand-mark { display: none; }
.admin-nav a.back { display: flex; align-items: center; gap: 10px; color: var(--nav-fg); font-size: 13px; margin: 8px 0 16px; }
.admin-nav nav { display: flex; flex-direction: column; gap: 2px; }
.admin-nav-item { display: flex; align-items: center; gap: 10px; padding: 8px 11px; border-radius: var(--r-nav); font-size: 14px; color: var(--nav-fg); }
.admin-nav-item:hover { background: var(--nav-hover); }
.admin-nav-item[aria-current="page"] { background: var(--nav-hover); color: #fff; }
.admin-nav-item.is-disabled { color: var(--nav-cap); pointer-events: none; }
.admin-nav-item.is-disabled .soon { margin-left: auto; font-size: 10px; text-transform: uppercase; letter-spacing: .04em; color: var(--nav-cap); border: 1px solid #3a3a35; border-radius: 999px; padding: 1px 6px; }
.ni-ic { display: grid; place-items: center; flex: none; width: 20px; height: 20px; }
/* Иконочный слот [data-icon]: глиф строго по центру. Inline-SVG имеет baseline-зазор →
   смещал глиф вверх (~1.5px) в кнопках-иконках (cc-btn и пр.). block + grid-center убирают это. */
[data-icon] { display: inline-grid; place-items: center; }
[data-icon] svg { display: block; }
.nav-sep { height: 1px; background: var(--nav-hover); margin: 10px 4px; }
.nav-cap { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--nav-cap); padding: 4px 11px 2px; }
/* Хлебные крошки (рефактор навигации, реш. Mars 2026-06-16) — campaign.html + season.html */
.crumbs { font-size: 13px; color: var(--faint); margin: 0 0 6px; }
.crumbs a:hover { color: var(--ink); }
.crumbs b { color: var(--ink-2); font-weight: 600; }
.admin-foot { margin-top: auto; display: grid; gap: 8px; padding-top: 16px; border-top: 1px solid var(--nav-hover); }
.admin-foot .who { font-size: 12px; color: var(--faint); }
#logoutBtn { display: flex; align-items: center; justify-content: center; gap: 8px; }
@media (max-width: 1180px) {
  :root { --nav-w: 60px; }  /* свёрнутый icon-сайдбар → фикс-панель публикации (var(--nav-w)) едет вместе */
  .admin-nav { padding: 16px 6px; }
  .brand-full { display: none; }
  .brand-mark { display: grid; place-items: center; width: 38px; height: 38px; margin: 0 auto 10px; background: var(--nav-hover); border-radius: 10px; font-weight: 800; font-size: 16px; }
  .admin-nav a.back, .admin-nav-item, #logoutBtn { justify-content: center; gap: 0; padding-left: 0; padding-right: 0; }
  .admin-nav a.back { margin: 4px 0 14px; }
  .admin-nav-item { padding: 10px 0; }
  .nav-cap, .ni-tx, .admin-foot .who, .admin-nav-item.is-disabled .soon { display: none; }
  .nav-sep { margin: 8px 0; }
}

/* ===== контент: общая колонка (страницы переопределяют padding под свои нужды) ===== */
main.admin-main { padding: 24px 28px; max-width: 1240px; }
.head-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 20px; }
.head-row h1 { font-size: 22px; margin: 0; }
/* межсекционный отступ 24 > внутрисекционных (10–16): чёткое разделение секций */
h2.section-h { font-size: 18px; margin: 24px 0 10px; }
h3.cat-h { font-size: 14px; margin: 16px 0 8px; color: var(--ink-2); }
.empty, .empty-line { color: var(--muted); }
.empty { padding: 30px 0; }
.empty-line { font-size: 13px; padding: 6px 2px; }

/* широкая контурная кнопка добавления (отступ 12 от своего списка < межсекционного 24) */
.add-wide { display: block; width: 100%; padding: 11px; border: 1.5px dashed #c7c7bf; border-radius: var(--r-row); background: var(--surface-2); color: var(--label); font-weight: 600; font-size: 14px; margin: 12px 0 0; }
.add-wide:hover { background: #f0f0ea; border-color: #b3b3aa; }

/* ===== статус = цвет заголовка (единый канон; пилюль нет) ===== */
.st-draft { color: var(--st-draft); }
.st-live { color: var(--st-live); }
.st-paused { color: var(--st-paused); }
.st-cancelled { color: var(--st-cancelled); }
.s-draft { color: var(--st-draft); }
.s-ready { color: var(--st-live); }
.s-live { color: var(--st-season-live); }
.status-word { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }

/* ===== модалки (общая обвязка) ===== */
.modal-bd, .modal-backdrop { position: fixed; inset: 0; background: rgba(20,20,18,.45); display: grid; place-items: center; padding: 20px; z-index: 60; }
.modal-card { width: 420px; max-width: 100%; background: var(--surface); border-radius: var(--r-card); padding: 22px; position: relative; }
.modal-card h2 { margin: 0 0 14px; font-size: 18px; }
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 8px; }
.modal-x { position: absolute; top: 12px; right: 12px; width: 30px; height: 30px; border: 0; background: transparent; color: var(--faint); display: grid; place-items: center; border-radius: var(--r-nav); cursor: pointer; }
.modal-x:hover { background: var(--surface-3); color: var(--ink); }
