/* ============================================================================
   header.css — ЕДИНЫЙ сквозной хедер ПКГ РЕБУС (логотип · навигация · действия).
   Единственный источник стилей хедера для ВСЕХ участницких страниц
   (index · collection · rating · conditions · prizes · profile · final-game).

   Подход «единая управляемая система»:
   • Самодостаточен — собственные --h-* токены (значения = канон Главной),
     не зависит от --line/--display/--honey конкретной страницы, поэтому хедер
     выглядит ОДИНАКОВО независимо от того, какой страничный CSS загружен.
   • Все правила скоплены под .topbar / .mobile-menu — не клобберит .icon-btn,
     .notify-dot и пр. из participant.css (подключать header.css ПОСЛЕ неё).
   • Поведение — rebus-bind.js (installNav · installNotify · wireUserMenu ·
     installMobileMenu). Разметка — каноническая, одинаковая на всех страницах.
   Зона: структура/поведение — Claude; визуальная доводка токенов/правил — Codex.
   ============================================================================ */

:root {
  --h-h: 76px;                          /* высота бара */
  --h-line: #1f1f1d;                    /* основной контур/линии */
  --h-ink: #141411;                     /* активный текст */
  --h-ink-dim: #4b4b46;                 /* неактивные пункты навигации */
  --h-muted: #8d8d86;
  --h-soft: #d8d8d0;
  --h-soft-2: #c8c8bf;
  --h-paper: rgba(247, 247, 244, .88);  /* фон бара (с blur) */
  --h-paper-solid: #f7f7f4;
  --h-white: #f7f7f4;
  --h-amber: oklch(0.80 0.15 82);   /* канон акцента = OKLCH honey (един для хедера/кита/Главной) */
  --h-surface: #fffffc;
  --h-display: "Science Gothic", "Arial Black", Impact, sans-serif;
  --h-body: "Inter", Arial, sans-serif;
  --h-mono: ui-monospace, "Cascadia Code", Consolas, monospace;
  --h-shadow: 0 18px 60px rgba(28, 28, 24, .12);
  --h-chamfer: polygon(12px 0, calc(100% - 12px) 0, 100% 12px, 100% calc(100% - 12px), calc(100% - 12px) 100%, 12px 100%, 0 calc(100% - 12px), 0 12px);
  --h-chamfer-s: polygon(10px 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px), 0 10px);
  /* Контурный гекс аватара — двойной hex SVG (как в степпере маршрута, не «квадрат внутри»). */
  --h-hex: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 66 58'%3E%3Cpath d='M17 3h32l14 26-14 26H17L3 29 17 3Z' fill='%23fffefa' fill-opacity='.94' stroke='%2378786f' stroke-width='2.4'/%3E%3Cpath d='M23 12h20l10 17-10 17H23L13 29 23 12Z' fill='none' stroke='%23cfcfc6' stroke-width='2.1'/%3E%3C/svg%3E");
  --h-hex-clip: polygon(26% 5%, 74% 5%, 95% 50%, 74% 95%, 26% 95%, 5% 50%);
}

/* Единый отступ под фиксированный бар (один источник для всех страниц). */
body { padding-top: var(--h-h); }

/* hidden внутри хедера = действительно скрыто (Главная без [hidden]-правила не прятала бы
   дропдаоны .user-menu/.notif-pop, которым header.css задаёт display:grid → «лишняя полоска»). */
.topbar [hidden] { display: none !important; }

/* ── Каркас бара ─────────────────────────────────────────────────────────── */
.topbar {
  position: fixed;          /* закреплён при скролле, на всех страницах одинаково */
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  height: var(--h-h);
  display: grid;
  grid-template-columns: var(--h-h) max-content minmax(0, 1fr) auto;
  align-items: stretch;
  background: var(--h-paper);
  border-bottom: 1px solid var(--h-line);
  backdrop-filter: blur(16px);
  font-family: var(--h-body);
  color: var(--h-ink);
}

/* ── Бренд: логотип-квадрат + строка идентичности ────────────────────────── */
.topbar .brand-mark {
  display: grid;
  place-items: center;
  border-right: 1px solid var(--h-line);
}
.topbar .brand-mark img { width: 38px; height: 38px; }

.topbar .brandline {
  display: flex;
  align-items: center;
  gap: clamp(10px, 1.15vw, 22px);
  padding: 0 clamp(16px, 1.8vw, 32px);
  min-width: 0;
}
.topbar .brand-title {
  font-family: var(--h-display);
  font-weight: 900;
  font-size: clamp(22px, 2vw, 34px);
  line-height: .95;
  white-space: nowrap;
  flex: 0 0 auto;
}
.topbar .barcode {
  width: clamp(72px, 7vw, 128px);
  height: 22px;
  background: repeating-linear-gradient(90deg, var(--h-line) 0 2px, transparent 2px 5px, var(--h-line) 5px 8px, transparent 8px 12px);
  opacity: .86;
  flex: 0 1 auto;
  min-width: 44px;
}
.topbar .small-code {
  color: var(--h-muted);
  font-family: var(--h-display);
  font-size: 12px;
  white-space: nowrap;
  flex: 0 0 auto;
}
.topbar .season-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 24px;
  padding: 0 10px;
  border: 1px solid var(--h-line);
  background: var(--h-ink);
  color: var(--h-white);
  font-family: var(--h-display);
  font-size: 12px;
  white-space: nowrap;
  text-transform: uppercase;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Навигация ───────────────────────────────────────────────────────────── */
.topbar .nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0 clamp(8px, 1.4vw, 28px);
  overflow-x: auto;
  scrollbar-width: none;
}
.topbar .nav::-webkit-scrollbar { display: none; }
.topbar .nav a {
  position: relative;
  flex: 0 0 auto;
  padding: 10px clamp(8px, .82vw, 14px);
  color: var(--h-ink-dim);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  white-space: nowrap;
}
.topbar .nav a:hover { color: var(--h-ink); }
.topbar .nav a[aria-current="page"] { color: var(--h-ink); }
.topbar .nav a[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 5px;
  height: 2px;
  background: var(--h-amber);
}

/* ── Зона действий: колокол + юзерблок + гамбургер ───────────────────────── */
.topbar .top-actions {
  display: flex;
  align-items: center;
  justify-self: end;
  border-left: 1px solid var(--h-line);
  min-width: 0;
  overflow: visible;   /* дропдаоны .user-menu/.notif-pop выпадают НИЖЕ бара; иначе легаси-inline
                          `.top-actions{overflow:hidden}` Главной режет их по высоте хедера (видна «полоска») */
}
/* Сам бар тоже не должен клипать выпадающие меню (страховка от leaked overflow). */
.topbar { overflow: visible; }
.topbar .userbox { overflow: visible; }
.topbar .icon-btn {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 0;
  background: transparent;
  color: var(--h-line);
  cursor: pointer;
}
.topbar .icon-btn:hover { color: var(--h-ink); }
.topbar .icon-btn svg { width: 26px; height: 26px; }
.topbar .top-actions > .icon-btn:not(.menu-toggle) { margin: 0 12px 0 10px; }
.topbar .notify-dot {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--h-amber);
  box-shadow: 0 0 0 3px oklch(0.80 0.15 82 / .22);
  display: none;            /* зажигает installNotify при unread>0 */
}

/* Колокол + выпадающая лента уведомлений (строит installNotify) */
.topbar .bell-wrap { position: relative; display: inline-flex; }
.topbar .notif-pop {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: 340px;
  max-width: 86vw;
  max-height: 60vh;
  overflow-y: auto;
  background: var(--h-surface);
  border: 1px solid var(--h-line);
  clip-path: var(--h-chamfer);
  box-shadow: var(--h-shadow);
  padding: 10px;
  z-index: 60;
}
.topbar .notif-pop-h {
  font-family: var(--h-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--h-muted);
  padding: 8px 10px 10px;
}
.topbar .notif-empty { color: var(--h-muted); font-size: 13px; padding: 18px 10px 22px; text-align: center; }
.topbar .notif-row { display: flex; gap: 10px; align-items: flex-start; padding: 10px; }
.topbar .notif-row + .notif-row { border-top: 1px solid var(--h-soft); }
.topbar .notif-row.is-unread { background: oklch(0.80 0.15 82 / .12); }
.topbar .notif-txt { flex: 1; min-width: 0; font-size: 14px; line-height: 1.35; color: var(--h-ink); }
.topbar .notif-time { flex: none; font-family: var(--h-mono); font-size: 10px; color: var(--h-muted); white-space: nowrap; padding-top: 2px; }

/* Юзерблок (кликабелен → меню Профиль/Выйти) */
.topbar .userbox {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 18px 0 22px;
  border-left: 1px solid var(--h-soft-2);
  min-width: 220px;
  flex: 0 0 auto;
  cursor: pointer;
  user-select: none;
  background: transparent;
}
.topbar .avatar {
  flex: none;
  width: 42px;
  height: 40px;
  display: grid;
  place-items: center;
  background: var(--h-hex) center / contain no-repeat;   /* контурный гекс (как степпер) */
  font-family: var(--h-display);
  font-weight: 900;
  font-size: 14px;
  color: var(--h-ink);
  clip-path: none;   /* не давать спящему inline .avatar{clip-path} Главной резать SVG-гекс */
}
.topbar .avatar::before { content: none; }   /* гасит легаси-плашку Главной (квадрат внутри) */
/* Фото-аватар: гекс-вырез вместо контурного SVG (ставит .has-photo + background-image — wireUserMenu). */
.topbar .avatar.has-photo {
  background: center / cover no-repeat;
  clip-path: var(--h-hex-clip);
  color: transparent;
}
.topbar .user-copy { display: grid; line-height: 1.05; min-width: 0; }
.topbar .user-copy strong { font-size: 15px; max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topbar .user-copy span { color: var(--h-muted); font-size: 12px; text-transform: uppercase; }
.topbar .userbox-chev { margin-left: auto; font-size: 11px; color: var(--h-muted); transition: transform .12s cubic-bezier(.22, 1, .36, 1); }
.topbar .userbox[aria-expanded="true"] .userbox-chev { transform: rotate(180deg); }
.topbar .user-menu {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 184px;
  background: var(--h-surface);
  border: 1px solid var(--h-line);
  clip-path: var(--h-chamfer-s);
  box-shadow: var(--h-shadow);
  padding: 7px;
  display: grid;
  gap: 2px;
  z-index: 60;
}
.topbar .user-menu a,
.topbar .user-menu button {
  display: block;
  width: 100%;
  text-align: left;
  padding: 9px 10px;
  border: 0;
  background: transparent;
  color: var(--h-ink);
  font-size: 14px;
  cursor: pointer;
}
.topbar .user-menu a:hover,
.topbar .user-menu button:hover { background: var(--h-soft); }
.topbar .user-menu .danger { color: #c0392b; }

/* ── Гамбургер + мобильный drawer (вне .topbar) ──────────────────────────── */
.topbar .menu-toggle { display: none; }

.mobile-menu {
  display: none;
  position: fixed;
  inset: var(--h-h) 0 auto 0;
  z-index: 45;
  background: rgba(247, 247, 244, .97);
  border-bottom: 1px solid var(--h-line);
  padding: 18px;
  box-shadow: var(--h-shadow);
  font-family: var(--h-body);
}
.mobile-menu.open { display: grid; }
.mobile-menu a {
  padding: 14px 2px;
  border-bottom: 1px solid var(--h-soft);
  color: var(--h-ink);
  font-weight: 800;
  text-transform: uppercase;
}
.mobile-menu a[aria-current="page"] { color: var(--h-amber); }
.mobile-menu .drawer-action { display: none; }

/* Баннер админ-предпросмотра «глазами участника» (rebus-bind installPreviewBanner). */
.rb-preview {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  padding: 8px 16px;
  background: var(--h-amber); color: var(--h-ink);
  font-family: var(--h-body); font-size: 13px; font-weight: 700;
  position: relative; z-index: 40;
}
.rb-preview button {
  border: 1px solid var(--h-ink); background: transparent; color: var(--h-ink);
  padding: 4px 12px; font: inherit; cursor: pointer;
}
.rb-preview button:hover { background: var(--h-ink); color: var(--h-amber); }

/* ── Адаптив: одинаков на всех страницах (каденс канона Главной) ──────────── */
/* Приоритет ужимания (JS installHeaderFit, по ФАКТУ нехватки места, не по фикс-порогу, реш. Mars):
   1) штрихкод-декор → 2) бадж кампании → 3) nav в бургер. Классы ставятся на <html>. */
.h-hide-barcode .topbar .barcode { display: none; }
.h-hide-chip .topbar .season-chip { display: none; }
@media (max-width: 1360px) {
  .topbar .small-code { display: none; }
  .topbar .nav { gap: 2px; }
  .topbar .nav a { font-size: 12px; padding-inline: 7px; }
}
@media (max-width: 1120px) {
  .topbar .user-copy { display: none; }
  .topbar .userbox { min-width: 0; padding: 0 14px; }
}

/* ── Сворачивание навигации в бургер ─────────────────────────────────────────
   Управляется JS (installHeaderFit): класс .nav-compact ставится на <html> В ТОТ
   МОМЕНТ, когда nav перестаёт умещаться (точно по факту, а не по фикс-порогу). */
.nav-compact .topbar { grid-template-columns: var(--h-h) minmax(0, 1fr) auto; }
.nav-compact .topbar .nav { display: none; }
.nav-compact .topbar .userbox { display: none; }
.nav-compact .topbar .menu-toggle { display: grid; }
.nav-compact .topbar .top-actions { padding-right: 8px; }
.nav-compact .topbar .top-actions > .icon-btn:not(.menu-toggle) { margin: 0 6px 0 0; }
.nav-compact .mobile-menu .drawer-action { display: block; }

@media (max-width: 460px) {
  .topbar { grid-template-columns: 60px minmax(0, 1fr) auto; }
  .topbar .brand-mark img { width: 30px; height: 30px; }
  .topbar .brand-title { font-size: 20px; }
}
