/* v5-shared.css (28.06.2026) — общие компоненты v5 публичной части:
   полная шапка, минимальная шапка (signup), полный жирный футер,
   компактный футер (signup), cookie-бар, pre-footer CTA.

   Используется как единый partial-стиль через {% include %} в:
   landing_v5 / event_landing_v5 / season_landing_v5 / leaderboard_v5 / signup_v5.
   Требует var(--v5-*) из design-tokens.css.
*/

/* ===== HEADER (полная, навигация 6 пунктов) ===== */
.v5-header { position: sticky; top: 0; z-index: 50; background: var(--v5-navy-900); color: #fff; }
.v5-header-inner { max-width: var(--v5-container); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 16px 32px; }
.v5-logo { display: flex; align-items: center; gap: 12px; color: #fff; text-decoration: none; }
.v5-logo-main { display: flex; align-items: center; gap: 7px; font-family: var(--v5-font-display); font-weight: 700; font-size: 20px; text-transform: uppercase; letter-spacing: 0.02em; }
.v5-logo-main span { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; background: var(--v5-orange-500); color: #fff; border-radius: 50%; font-size: 12px; }
.v5-logo-tag { font-size: 11px; color: #7e85ad; border-left: 1px solid var(--v5-navy-600); padding-left: 12px; line-height: 1.25; }
.v5-nav { display: flex; align-items: center; gap: 4px; font-size: 14px; font-weight: 600; }
.v5-nav a { color: #c7cae6; padding: 9px 14px; border-radius: 8px; transition: background .15s, color .15s; text-decoration: none; }
.v5-nav a:hover { color: #fff; background: rgba(255,255,255,0.06); }
.v5-nav a.active { color: #fff; background: #1a2150; }
.v5-nav a.login { color: #fff; padding: 9px 16px; margin-left: 6px; }
.v5-nav a.reg { background: var(--v5-orange-500); color: #fff; padding: 11px 22px; border-radius: var(--v5-r-pill); margin-left: 4px; }
.v5-nav a.reg:hover { filter: brightness(0.95); }

/* ===== BURGER + DRAWER (мобильное меню ≤720px) ===== */
.v5-burger { display: none; background: transparent; border: 0; padding: 8px; cursor: pointer; width: 40px; height: 40px; flex-direction: column; align-items: center; justify-content: center; gap: 5px; }
.v5-burger span { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: transform .18s, opacity .18s; }
.v5-burger:hover span { background: var(--v5-orange-300); }

.v5-drawer-overlay { position: fixed; inset: 0; background: rgba(11, 18, 64, 0.55); z-index: 90; opacity: 0; transition: opacity .22s; }
.v5-drawer-overlay.is-open { opacity: 1; }

.v5-drawer { position: fixed; top: 0; right: 0; width: min(320px, 88vw); height: 100vh; background: var(--v5-navy-900); color: #fff; z-index: 100; transform: translateX(100%); transition: transform .22s ease-out; display: flex; flex-direction: column; box-shadow: -8px 0 32px rgba(0,0,0,0.35); }
.v5-drawer.is-open { transform: translateX(0); }
.v5-drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--v5-navy-600); }
.v5-drawer-title { font-family: var(--v5-font-display); font-weight: 700; font-size: 16px; letter-spacing: 0.05em; text-transform: uppercase; color: #fff; }
.v5-drawer-close { background: transparent; border: 0; color: #fff; font-size: 30px; line-height: 1; cursor: pointer; padding: 4px 10px; }
.v5-drawer-close:hover { color: var(--v5-orange-300); }
.v5-drawer-nav { display: flex; flex-direction: column; padding: 12px 12px 20px; gap: 2px; }
.v5-drawer-nav a { color: #c7cae6; font-size: 16px; font-weight: 600; padding: 14px 16px; border-radius: 10px; text-decoration: none; }
.v5-drawer-nav a:hover, .v5-drawer-nav a.active { background: rgba(255,255,255,0.06); color: #fff; }
.v5-drawer-sep { height: 1px; background: var(--v5-navy-600); margin: 12px 8px; }
.v5-drawer-login { color: #fff !important; }
.v5-drawer-reg { background: var(--v5-orange-500); color: #fff !important; text-align: center; margin: 6px 4px 0; padding: 14px 18px !important; border-radius: var(--v5-r-pill) !important; }
.v5-drawer-reg:hover { filter: brightness(0.95); background: var(--v5-orange-500) !important; }

/* ===== HEADER (минимальная — signup) ===== */
.v5-header-min { background: var(--v5-navy-900); color: #fff; }
.v5-header-min-inner { max-width: 1080px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 18px 32px; }
.v5-min-right { font-size: 14px; color: #b9bce0; }
.v5-min-right a { color: #fff; font-weight: 700; text-decoration: none; }

/* ===== PRE-FOOTER CTA (только главная) ===== */
.v5-prefooter { max-width: var(--v5-container); margin: 0 auto; padding: 56px 32px; border-bottom: 1px solid #1c2350; display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.v5-prefooter-text h2 { font-family: var(--v5-font-display); font-weight: 700; font-size: clamp(26px, 3.5vw, 36px); text-transform: uppercase; line-height: 1.05; margin: 0 0 8px; color: #fff; }
.v5-prefooter-text p { font-size: 16px; color: #b9bce0; margin: 0; }
.v5-prefooter-cta { background: var(--v5-orange-500); color: #fff; padding: 18px 38px; border-radius: var(--v5-r-pill); font-weight: 700; font-size: 16px; white-space: nowrap; text-decoration: none; transition: filter .15s; }
.v5-prefooter-cta:hover { filter: brightness(0.95); color: #fff; }

/* ===== FOOTER (полный жирный — landing/event/season/leaderboard) ===== */
.v5-footer { background: var(--v5-navy-900); color: #fff; }
.v5-foot-main { max-width: var(--v5-container); margin: 0 auto; padding: 48px 32px 36px; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; }
.v5-foot-brand .v5-logo-main { font-size: 20px; margin-bottom: 16px; }
.v5-foot-brand p { font-size: 14px; line-height: 1.6; color: #8a8fc0; max-width: 280px; margin: 0 0 20px; }
.v5-foot-brand-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.v5-foot-brand-btn { display: inline-flex; align-items: center; gap: 8px; background: var(--v5-navy-800); border: 1px solid var(--v5-navy-600); color: #fff; padding: 11px 18px; border-radius: var(--v5-r-pill); font-size: 14px; font-weight: 600; text-decoration: none; transition: background .15s; }
.v5-foot-brand-btn:hover { background: #1a2050; color: #fff; }

.v5-foot-col h4 { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; color: #5a6098; text-transform: uppercase; margin: 0 0 16px; }
.v5-foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 11px; }
.v5-foot-col a { color: #c7cae6; font-size: 14.5px; text-decoration: none; }
.v5-foot-col a:hover { color: #fff; }

.v5-foot-bottom { border-top: 1px solid #1c2350; }
.v5-foot-bottom-inner { max-width: var(--v5-container); margin: 0 auto; padding: 22px 32px; display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.v5-foot-copy { font-size: 13px; color: #6b7199; }
.v5-foot-legal { display: flex; gap: 22px; font-size: 13px; flex-wrap: wrap; }
.v5-foot-legal a { color: #8a8fc0; text-decoration: none; }
.v5-foot-legal a:hover { color: #fff; }

/* ===== FOOTER (компактный — signup) ===== */
.v5-footer-compact { background: var(--v5-navy-900); color: #fff; }
.v5-foot-main-compact { max-width: 1080px; margin: 0 auto; padding: 44px 32px 32px; display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 36px; }
.v5-foot-bottom-inner-compact { max-width: 1080px; margin: 0 auto; padding: 20px 32px; display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }

/* ===== COOKIE BAR ===== */
.v5-cookie { position: fixed; left: 20px; bottom: 20px; z-index: 60; max-width: 420px; background: var(--v5-navy-900); color: #fff; border-radius: var(--v5-r-card-sm); padding: 14px 16px; box-shadow: 0 12px 34px rgba(0,0,0,.28); display: flex; align-items: center; gap: 14px; border: 1px solid var(--v5-navy-600); }
.v5-cookie p { font-size: 12.5px; line-height: 1.45; color: #c7cae6; margin: 0; }
.v5-cookie a { color: var(--v5-orange-300); }
.v5-cookie-btns { display: flex; gap: 8px; flex-shrink: 0; }
.v5-cookie-btn { background: var(--v5-orange-500); color: #fff; border: none; padding: 9px 16px; border-radius: var(--v5-r-chip); font-family: var(--v5-font-text); font-weight: 700; font-size: 13px; cursor: pointer; }
.v5-cookie-btn.secondary { background: transparent; color: #c7cae6; border: 1px solid var(--v5-navy-600); font-weight: 600; }
.v5-cookie-btn:hover { filter: brightness(0.92); }

/* ===== Responsive ===== */
@media (max-width: 960px) {
  .v5-foot-main { grid-template-columns: 1fr 1fr; }
  .v5-foot-brand { grid-column: 1 / -1; }
  .v5-prefooter { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 720px) {
  /* A1 (01.07): desktop-nav скрыт, вместо него бургер + drawer */
  .v5-nav-desktop { display: none; }
  .v5-burger { display: inline-flex; }
  .v5-header-inner { padding: 12px 16px; }
  .v5-logo-main { font-size: 17px; }
  .v5-logo-tag { display: none; }
  .v5-header-min-inner { padding: 14px 20px; }
  .v5-foot-main { grid-template-columns: 1fr; padding: 32px 20px 24px; }
  .v5-foot-main-compact { grid-template-columns: 1fr; padding: 32px 20px 24px; }
  .v5-foot-bottom-inner, .v5-foot-bottom-inner-compact { padding: 16px 20px; flex-direction: column; align-items: flex-start; }
  .v5-prefooter { padding: 36px 20px; }
  .v5-cookie { left: 12px; right: 12px; bottom: 12px; flex-direction: column; align-items: stretch; max-width: none; }
}

/* A11Y-2 (01.07): единый focus-visible-ring для всех интерактивных элементов.
   Ранее многие v5-формы имели `outline:none` + только смену border-color →
   клавиатурный юзер терял ориентир. Теперь виден оранжевый ring 3px с
   офсетом 2px — заметен, не сливается с border-color. Работает только при
   навигации Tab (не при клике), чтобы не мешать мыше-юзеру. */
:focus-visible {
  outline: 3px solid rgba(238, 90, 36, 0.55) !important;
  outline-offset: 2px !important;
  border-radius: 4px;
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[role="button"]:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid rgba(238, 90, 36, 0.65) !important;
  outline-offset: 2px !important;
}
