/* ==== HEADER.CSS - OPTIMIZED ==== */

/* root font variable (fonts.css должен задавать MontserratCustom 400/700) */
:root{
  --font-head: "MontserratCustom", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --accent: #ff6d3d;
}

/* базовый хедер */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: #000;
  color: #fff;
  width: 100%;
  box-sizing: border-box;
}

/* контейнер/линия хедера — фиксированная высота для ровного центрирования */
.header__inner{
  display: flex;
  align-items: center;        /* строго по центру вертикали */
  justify-content: space-between;
  height: 64px;
  padding: 0 20px;
  width: 100%;
  box-sizing: border-box;
  position: relative;
}

/* логотип */
.logo{ display:flex; flex-direction:column; line-height:1; flex-shrink:0; text-decoration:none; }
.logo__title{ color: var(--accent); font-weight:700; font-size:20px; font-family: var(--font-head); }
.logo__subtitle{ color:#fff; font-size:14px; }

/* основное меню - растягиваем по горизонтали */
.main-nav{
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.main-nav ul{
  display:flex;
  gap: 34px;                 /* увеличенный промежуток между пунктами */
  list-style:none;
  margin:0;
  padding:0;
  align-items:center;
}
.main-nav a{
  font-family: var(--font-head);
  font-weight: 600;          /* чуть потолще — близко к 700, при наличии 600 будет точнее */
  font-size: 15px;
  line-height: 1.2;
  color: #fff;
  text-decoration: none;
  letter-spacing: 0.01em;
  white-space: nowrap;
  transition: color .18s ease, transform .12s ease, opacity .12s ease; /* НЕ анимируем font-weight */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-synthesis: none;      /* запретить браузеру синтезировать жирность/курсив */
  padding: 4px 2px;         /* лёгкая кликабельная зона */
}

/* hover / active — явный family + явный weight, без transition на weight */
.main-nav a:hover,
.main-nav a:focus,
.main-nav .current-menu-item > a,
.main-nav a.active{
  color: var(--accent);
  font-weight: 700;
  outline: none;
  transform: translateY(-1px);
}

/* доступнысть: фокус */
.main-nav a:focus{ box-shadow: 0 0 0 4px rgba(255,109,61,0.08); border-radius:6px; }

/* правый блок (соц/кнопка) */
.header__socials{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.social-link svg{ width:20px; height:20px; fill:#fff; opacity:.9; transition: transform .12s, fill .12s; }
.social-link:hover svg{ fill:var(--accent); transform: translateY(-2px); }
.btn-orange{ background:var(--accent); color:#fff; padding:8px 16px; border-radius:6px; text-decoration:none; font-weight:600; }

/* BURGER — inline-flex зона (появляется только на мобилке) */
.nav-toggle{ display:none; }
.nav-toggle-label{
  display:none;               /* shown only in media query */
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  padding:6px;
  cursor:pointer;
  flex-shrink:0;
  border-radius:6px;
  background:transparent;
  box-sizing:border-box;
  -webkit-tap-highlight-color: transparent;
  z-index:1101;
}
.nav-toggle-label span{ display:inline-block; width:22px; height:2px; background:#fff; border-radius:2px; position:relative; transition: transform .22s ease, opacity .18s ease; }
.nav-toggle-label span::before,
.nav-toggle-label span::after{ content:""; position:absolute; left:0; width:22px; height:2px; background:#fff; border-radius:2px; transition: transform .22s ease, top .22s ease; }
.nav-toggle-label span::before{ top:-7px; } 
.nav-toggle-label span::after{ top:7px; }
/* крестик при открытии */
.nav-toggle:checked + .nav-toggle-label span{ background:transparent; }
.nav-toggle:checked + .nav-toggle-label span::before{ transform: translateY(7px) rotate(45deg); }
.nav-toggle:checked + .nav-toggle-label span::after{ transform: translateY(-7px) rotate(-45deg); }

/* MOBILE / TABLET off-canvas menu */
@media (max-width: 920px){
  .nav-toggle-label{ display:inline-flex; }
  .main-nav{
    position: fixed;
    top: 0;
    right: -100%;
    width: 76%;
    max-width: 360px;
    height: 100vh;
    background: rgba(0,0,0,0.98);
    padding: 110px 28px 40px;
    display:flex;
    flex-direction:column;
    gap:18px;
    transition: right .28s cubic-bezier(.2,.9,.3,1);
    z-index:1000;
    justify-content:flex-start;
    align-items:flex-start;
  }
  .main-nav ul{ flex-direction: column; gap: 18px; width:100%; padding:0; margin:0; }
  .main-nav a{
    font-family: var(--font-head);
    font-weight: 400;        /* mobile list — regular for better reading */
    font-size: 18px;
    padding: 10px 0;
    width:100%;
    transition: color .16s;
  }
  .main-nav a:hover, .main-nav a:focus, .main-nav .current-menu-item > a{ color:var(--accent); font-weight:700; }
  .nav-toggle:checked ~ .main-nav{ right: 0; }
  .header__socials{ display:none; }
}

/* small mobile tweaks */
@media (max-width:480px){
  .header__inner{ height:60px; padding:0 14px; }
  .main-nav ul{ gap:18px; }
  .main-nav a{ font-size:17px; }
  .nav-toggle-label{ width:40px; height:40px; padding:6px; }
}

/* small polish: ensure menu doesn't wrap awkwardly on narrow desktops */
@media (min-width: 1280px){
  .main-nav ul{ gap:36px; }
}

/* ===== HEADER: полупрозрачный затемнённый фон с blur ===== */

/* регулируемая интенсивность темнения (0.0 — прозрачно, 1.0 — полностью чёрный) */
:root {
  --header-overlay-opacity: 0.55; /* поменяй на 0.35 / 0.7 для светлее/темнее */
  --header-blur: 6px;             /* степень размытия фона под хедером */
  --header-bg-color: 0,0,0;       /* rgb(0,0,0) — можно сменить на 20,20,20 для тёплее */
}

/* сам хедер — делаем фон прозрачным, а затем накладываем overlay через ::before */
.site-header {
  background: transparent !important;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  /* чтобы overlay не мешал клику по элементам, псевдоэлемент ниже контента */
}

/* overlay */
.site-header::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0; /* ниже внутренних элементов .header__inner (у которых z-index выше) */
  pointer-events: none;
  background: rgba(var(--header-bg-color), var(--header-overlay-opacity));
  /* мягкое размытие под шапкой (поддерживается не везде) */
  -webkit-backdrop-filter: blur(var(--header-blur));
  backdrop-filter: blur(var(--header-blur));
  transition: background .22s ease, backdrop-filter .22s ease;
}

/* контент хэдера — поверх overlay */
.header__inner {
  position: relative; /* важно: чтобы контент был выше ::before */
  z-index: 1;
}

/* опция: ещё больше затемнить при скролле — добавь класс .is-scrolled на .site-header (см. JS опционально) */
.site-header.is-scrolled::before {
  background: rgba(var(--header-bg-color), calc(var(--header-overlay-opacity) + 0.18));
  backdrop-filter: blur(calc(var(--header-blur) + 4px));
}

/* резервный стиль для браузеров, которые не поддерживают backdrop-filter — просто темнее фон */
@supports (not (backdrop-filter: blur(1px))) {
  .site-header::before {
    background: rgba(var(--header-bg-color), calc(var(--header-overlay-opacity) + 0.06));
  }
}

/* уменьшение эффекта для пользователей, которые отключили прозрачность/эффекты */
@media (prefers-reduced-transparency: reduce) {
  .site-header::before {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: rgba(var(--header-bg-color), calc(var(--header-overlay-opacity) + 0.12));
  }
}
