/* ===========================
   PixelRush — CLEAN STYLE.CSS
   =========================== */

/* ---------- CSS Variables ---------- */
:root {
  --main-purple: #5c0bd6;
  --main-orange: #ff6600;
  --bg-gradient: linear-gradient(135deg, #ffffff, #f4f6ff);

  /* Brand */
  --prn-pink: #ff2ea3;
  --prn-text: #ffffff;
  --prn-card: rgba(16,18,24,.82);
  --prn-shadow: 0 20px 60px rgba(0,0,0,.45);
  --prn-radius: 28px;
  --prn-bg: url('/img/pixelrush-modal-bg.jpg');
}

/* ---------- Base ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Rajdhani', system-ui, Segoe UI, Roboto, Ubuntu, Arial, sans-serif;
  background: var(--bg-gradient);
  color: #2c2c2c;
  line-height: 1.6;
}

.container {
  max-width: 1000px;
  margin: 0 auto;
  padding: 40px 20px;
}

[id] { scroll-margin-top: 80px; }

ul { padding-left: 20px; list-style: disc; }
li { margin-bottom: 10px; }

.contact { margin-top: 10px; font-size: 1.1em; }
.footer { margin-top: 10px; font-size: 0.9em; color: #666; text-align: center; }

.visual {
  display: block;
  margin: 30px auto;
  max-width: 100%;
  height: auto;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

.bottom-photo { margin-top: 50px; text-align: center; }
.bottom-photo img {
  width: 100%;
  max-width: 900px;
  border-radius: 12px;
  box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

/* ---------- Typography ---------- */
/* Заголовки и навигация — Orbitron */
h1, h2, h3, h4, h5, h6,
.nav-container a,
.brand {
  font-family: 'Orbitron', sans-serif;
  font-weight: 700;
  letter-spacing: .02em;
}

/* Кнопки и CTA — Rajdhani */
button, .btn, .prn-cta {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* Компактные размеры под Orbitron (однократно, без дублей) */
h1, h2, h3 {
  letter-spacing: 0;
  line-height: 1.2;
  margin: 20px 0 12px;
  overflow-wrap: anywhere;
}
h1 { font-size: clamp(20px, 2.0vw, 26px); }
h2 { font-size: clamp(18px, 1.9vw, 22px); }
h3 { font-size: clamp(16px, 1.8vw, 19px); }
p, li { line-height: 1.5; margin: 8px 0 12px; }

h1[id], h2[id], h3[id] { scroll-margin-top: 90px; }

/* ---------- Sticky Nav ---------- */
nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #ffffffcc;
  backdrop-filter: blur(12px);
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  overflow: visible;
}
.nav-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  max-width: 1000px;
  margin: 0 auto;
  padding: 10px 20px;
  position: relative;
}
nav a {
  margin: 0 10px;
  text-decoration: none;
  color: var(--main-purple);
  font-weight: 700;
  font-size: 15px;
  padding: 6px 8px;
  line-height: 1.1;
}
.nav-container a:hover { background: #f0f0ff; color: var(--main-purple); }
.burger { background: none; border: none; font-size: 1.5em; display: none; color: var(--main-purple); }

/* Lang dropdown fix */
.nav-container #prn-lang .prn-menu { right: 0; left: auto; }

/* Mobile nav */
#mobile-menu {
  display: none;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(8px);
  border-radius: 0 0 12px 12px;
  padding: 10px 20px;
}
#mobile-menu a { margin: 10px 0; }
.mobile-hidden { display: none; }

@media (max-width: 600px) {
  nav .desktop-link { display: none; }
  .burger { display: block; margin-left: 0; order: -1; }
  #mobile-menu:not(.mobile-hidden) { display: flex; }
  #mobile-menu.mobile-hidden { display: none !important; }
  .contact { font-size: 1rem; }
}

/* ---------- Reusable Grids ---------- */
.gdzie-grid,
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  align-items: stretch;
}
.gdzie-grid { margin-top: 20px; }
.benefits-grid { margin-top: 30px; }

/* ---------- Cards (Gdzie / Benefits) ---------- */
.gdzie-card {
  background: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(6px);
  border: 1px solid #ddd;
  border-radius: 12px;
  padding: 16px 20px;
  font-size: 0.95em;
  line-height: 1.4;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  display: flex;
  flex-direction: column;
  height: 100%;
  /* reveal (ожидает .visible из JS) */
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease-out, transform .6s ease-out;
  will-change: opacity, transform;
}
.gdzie-card.visible { opacity: 1; transform: none; }

.benefit-card {
  background: #f2eaff;
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 12px;
  padding: 20px;
  font-size: 0.95em;
  box-shadow: 0 4px 12px rgba(0,0,0,0.04);
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform .4s ease, box-shadow .4s ease;
  /* reveal */
  opacity: 0;
  transform: translateY(16px);
  transition-property: opacity, transform, box-shadow; /* объединено */
}
.benefit-card.visible { opacity: 1; transform: none; }
.benefit-icon { font-size: 1.5em; margin-bottom: 10px; display: inline-block; }
.benefit-title { font-weight: bold; margin-bottom: 6px; color: #2c2c2c; }

/* Общий helper для анимаций: можно вешать на любой блок */
.fade-in {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease-out, transform .6s ease-out;
  will-change: opacity, transform;
}
.fade-in.visible { opacity: 1; transform: none; }
.fade-delay-1 { transition-delay: .1s; }
.fade-delay-2 { transition-delay: .2s; }
.fade-delay-3 { transition-delay: .3s; }
.fade-delay-4 { transition-delay: .4s; }
.fade-delay-5 { transition-delay: .5s; }
.fade-delay-6 { transition-delay: .6s; }

/* ---------- Blog preview / cards ---------- */
#blog-preview { background: var(--bg-gradient); padding: 0 20px; text-align: center; }
#blog-preview h2 { color: #ff6600; font-size: 2em; text-align: center; margin-bottom: 16px; }
#blog-preview p { margin-bottom: 20px; font-size: 1.1em; }
.btn-main { background: #5c0bd6; color: #fff; padding: 12px 24px; border-radius: 8px; text-decoration: none; font-weight: bold; white-space: nowrap; }

.blog-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
  align-items: stretch;
  margin: 40px 0;
}
@media (max-width: 1024px) { .blog-cards { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 640px)  { .blog-cards { grid-template-columns: 1fr; } }

.blog-card {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  overflow: hidden;
  text-align: left;
  display: flex;
  flex-direction: column;
  height: 100%;
  /* reveal — по умолчанию с задержками через nth-child */
  opacity: 0;
  transform: translateY(16px);
  animation: blogFadeIn .6s ease forwards;
}
.blog-card:nth-child(1) { animation-delay: .1s; }
.blog-card:nth-child(2) { animation-delay: .3s; }
.blog-card:nth-child(3) { animation-delay: .5s; }
.blog-card:hover { transform: translateY(-5px); }
.blog-card img { width: 100%; height: 180px; object-fit: cover; }
.blog-card h3 { font-size: 1.2em; color: #5c0bd6; margin: 16px; }
.blog-card p { font-size: 0.95em; color: #333; margin: 0 16px 16px; }
.blog-card a { display: block; margin: 0 16px 16px; color: #ff6600; font-weight: bold; text-decoration: none; }

@keyframes blogFadeIn { to { opacity: 1; transform: translateY(0); } }

/* ---------- Gallery ---------- */
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 50px;
  padding: 0 10px;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  align-items: stretch;
}
.gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.6;
  filter: grayscale(60%);
  transition: opacity .3s, filter .3s, transform .3s, box-shadow .3s;
  border-radius: 12px;
  cursor: pointer;
  display: block;
}
.gallery img:hover {
  opacity: 1;
  filter: none;
  transform: scale(1.03);
  box-shadow: 0 8px 30px rgba(0,0,0,0.15);
}

/* ---------- Lightbox ---------- */
#lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  justify-content: center;
  align-items: center;
  flex-direction: column;
  z-index: 9999;
}
#lightbox-img {
  max-width: 90%;
  max-height: 80%;
  border-radius: 12px;
  box-shadow: 0 0 20px rgba(255,255,255,0.2);
  animation: fadeIn .3s ease-in-out;
}
.nav {
  position: absolute;
  top: 50%;
  font-size: 3rem;
  color: white;
  cursor: pointer;
  padding: 10px 20px;
  background: rgba(0,0,0,0.3);
  border-radius: 8px;
  transform: translateY(-50%);
  user-select: none;
}
.nav.left { left: 20px; }
.nav.right { right: 20px; }
#caption {
  margin-top: 15px;
  background: var(--bg-gradient);
  font-size: 1.1em;
  text-align: center;
  max-width: 90%;
  opacity: 0;
  transform: translateY(10px);
  animation: slideFadeIn .4s forwards;
}
@keyframes fadeIn { from { opacity: 0; transform: scale(.9); } to { opacity: 1; transform: scale(1); } }
@keyframes slideFadeIn { to { opacity: 1; transform: translateY(0); } }

/* ---------- Video ---------- */
.video-wrap { display: flex; justify-content: center; margin: 0; width: 100%; }
.video-wrap video {
  display: block;
  width: 100%;
  max-width: 900px;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 10px 20px rgba(0,0,0,0.1);
  margin: 0;
}

/* Player section tweaks */
.container:has(> .video-wrap) { padding-bottom: 16px; }
.container:has(> .video-wrap) + .container { padding-top: 16px; }
#pixelrush + h1 { margin-top: 8px; }

/* ---------- CTA / Buttons ---------- */
.btn-main { background: #5c0bd6; color: #fff; padding: 12px 24px; border-radius: 8px; text-decoration: none; font-weight: bold; white-space: nowrap; }
.card-link-bottom{
  display:inline-block;
  margin-top:12px;
  font-weight:700;
  color:var(--main-orange);
  text-decoration:none;
  transition: color .2s ease, text-decoration-color .2s ease;
}
.card-link-bottom:hover{ color:#cc5200; text-decoration:underline; }

/* ---------- Gdzie zagrać: карточки + навигация ---------- */
.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
  gap:20px;
  margin-top:30px;
}
.card-link{ display:block; text-decoration:none; color:inherit; }

.card{
  background:#fff;
  border-radius:16px;
  box-shadow:0 4px 12px rgba(0,0,0,.1);
  padding:24px;
  transition: transform .3s ease, box-shadow .3s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
  /* reveal */
  opacity: 0;
  transform: translateY(16px);
  transition-property: opacity, transform, box-shadow;
}
.card-link:hover .card{
  transform: scale(1.02) translateY(-4px);
  box-shadow: 0 12px 24px rgba(0,0,0,.12);
}
.card.reveal,
.card.visible { opacity: 1; transform: none; } /* поддержка двух вариантов JS */

.card h3{ color:var(--main-purple); margin-top:0; }
.card ul{ padding-left:20px; margin:10px 0; }

/* ---------- Modal (PixelRush) ---------- */
.prn-hidden{ display:none !important; }
.prn-lock{ overflow:hidden; }
.prn-visually-hidden{
  position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.prn-modal{ position:fixed; inset:0; z-index:9999; display:grid; place-items:center; }
.prn-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.55); }
.prn-modal__photo{
  position:absolute; inset:0;
  background-image:var(--prn-bg);
  background-size:cover; background-position:center;
  filter:blur(6px) saturate(110%) brightness(.85);
  transform:scale(1.02);
}
.prn-modal__panel{
  position:relative;
  width:min(92vw, 760px);
  border-radius:var(--prn-radius);
  background:var(--prn-card);
  color:var(--prn-text);
  box-shadow:var(--prn-shadow);
  padding:clamp(20px, 4vw, 40px);
  backdrop-filter:saturate(120%) blur(8px);
  -webkit-backdrop-filter:saturate(120%) blur(8px);
  transform: translateY(10px) scale(.98);
  opacity: 0;
  transition: opacity .25s ease, transform .25s ease;
}
.prn-modal[aria-hidden="false"] .prn-modal__panel{ opacity:1; transform: none; }
.prn-modal__close{
  position:absolute; top:14px; right:16px;
  width:40px; height:40px; border-radius:12px;
  display:grid; place-items:center;
  border:none; background:transparent; color:#fff; cursor:pointer;
  font-size:28px; line-height:1;
}
.prn-modal__close:hover{ opacity:.85; }
.prn-modal__title{
  margin:0 0 .5rem 0;
  font-weight:800;
  font-size:clamp(28px, 5vw, 56px);
  line-height:1.05;
  letter-spacing:.2px;
  text-align:center;
}
.prn-modal__desc{
  margin:0 auto clamp(18px,2.5vw,28px);
  max-width:48ch;
  font-size:clamp(16px, 2.2vw, 24px);
  line-height:1.35;
  text-align:center;
  opacity:.95;
}
.prn-cta{
  display:inline-flex; align-items:center; gap:.7em; justify-content:center;
  text-decoration:none; cursor:pointer; border:none;
  background:var(--prn-pink); color:#fff;
  font-weight:800; letter-spacing:.3px;
  font-size:clamp(18px, 2.6vw, 30px);
  padding:.85em 1.2em;
  border-radius:18px;
  box-shadow:0 10px 25px rgba(255,46,163,.35);
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
  width: 100%; max-width: 560px; box-sizing: border-box;
  margin: 24px auto 0;
}
.prn-cta:hover{ transform: translateY(-1px); box-shadow:0 16px 36px rgba(255,46,163,.45); }
.prn-cta:active{ transform: translateY(0); filter: brightness(.95); }

.prn-fab {
  position: fixed;
  bottom: 64px;
  right: max(16px, calc((100vw - 1000px)/2 + 16px));
  display: flex; align-items: center; gap: 10px;
  background: radial-gradient(120% 120% at 30% 20%, #5c2fff, #2b1266);
  color: #fff; border: none; border-radius: 999px;
  padding: 12px 16px; cursor: pointer;
  box-shadow: var(--prn-shadow);
  z-index: 9998;
}
.prn-fab__icon{
  display:grid; place-items:center; width:40px; height:40px; border-radius:999px;
  background:rgba(255,255,255,.1); font-size:20px;
}
.prn-fab__label{ font-weight:700; font-size:15px; white-space:nowrap }

@media (max-width: 480px){
  .prn-modal__panel{
    width: 92vw; max-width: 360px; margin: 0 auto; padding: 20px;
    border-radius: 16px; box-sizing: border-box; overflow-wrap: anywhere;
  }
  .prn-modal__title{ font-size: 1.4rem; line-height: 1.2; }
  .prn-modal__desc{ font-size: 1rem; line-height: 1.45; }
  .prn-cta{ width: 100%; max-width: 100%; font-size: 1rem; padding: 14px; margin-top: 16px; }
  .prn-modal__panel ul{ padding-left: 0; list-style: none; margin: 8px 0 0 0; }
  .prn-modal__panel li{ margin: 6px 0; }
}

@supports (padding: max(0px)) {
  .prn-modal__panel{ padding-bottom: max(20px, env(safe-area-inset-bottom)); }
  .prn-fab{ bottom: max(24px, env(safe-area-inset-bottom)); }
}

/* ---------- Minor Section Tweaks ---------- */
.section { padding: 20px 0; }
.section > h1, .section > h2, .section > p {
  width: min(1000px, 100% - 40px);
  margin: 0 auto;
}

/* ---------- Utilities ---------- */
.card-title-link{ color:var(--main-purple); text-decoration:none; }
.card-title-link:hover{ text-decoration:underline; }

.card-link-bottom:focus,
.btn-main:focus,
.prn-cta:focus { outline: 2px solid var(--main-orange); outline-offset: 2px; }

/* ---------- Optional: generic [data-animate] hook ----------
   Если где-то используешь data-атрибут вместо .visible */
[data-animate]{
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease-out, transform .6s ease-out;
  will-change: opacity, transform;
}
[data-animate].is-inview{ opacity: 1; transform: none; }
[data-animate][data-delay]{ transition-delay: var(--d, 0ms); }
[data-animate][data-duration]{ transition-duration: var(--t, .6s); }

/* === Unify page background === */
:root{
  /* один общий фон для всей страницы — можно поменять на solid, если захочешь */
  --page-bg: linear-gradient(180deg, #ffffff 0%, #f4f6ff 100%);
}

/* задаём фон только на html/body */
html, body{
  background: var(--page-bg) !important;
}

/* убираем локальные подложки у секций/блоков, чтобы фон был цельным */
.section,
#blog-preview,
#caption,
.gallery,
.cards,
.benefits-grid,
.gdzie-grid,
.bottom-photo,
.video-wrap {
  background: transparent !important;
}

/* раньше #blog-preview и #caption имели свой градиент — снимаем */
#blog-preview { background: transparent !important; }
#caption { background: transparent !important; }

/* шапка оставляем как была (полупрозрачная) — но если хочется ещё ровнее,
   можно сделать её сплошной белой */
 /* nav { background: #fff; } */

/* === (опционально) мягкий антибэндинг для градиента === */
/* очень лёгкий слой шума поверх страницы, чтобы не было «полос» на 8-битных дисплеях */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: .025;                 /* 2.5% — почти не видно, но сглаживает градиент */
  mix-blend-mode: overlay;       /* мягко ложится на фон */
  background:
    url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'>\
  <filter id='n'>\
    <feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/>\
    <feColorMatrix type='saturate' values='0'/>\
  </filter>\
  <rect width='100%' height='100%' filter='url(#n)' opacity='0.6'/>\
</svg>") repeat;
}

/* чтобы шум оказался под контентом (а не над модалкой), убедимся, что основные слои выше */
nav, .section, .container { position: relative; z-index: 1; }  /* без .prn-modal */


/* --- NAV: не даём пунктам меню сжиматься и переноситься --- */
@media (min-width: 760px){
  .nav-container{ flex-wrap: nowrap; justify-content: center; gap: 14px; }
  nav a{
    flex: 0 0 auto;          /* запрет shrink */
    white-space: nowrap;      /* всегда в одну строку */
    display: inline-flex;     /* ровная вертикаль */
    align-items: center;
    line-height: 1.1;
    margin: 0;                /* чтобы не суммировались margin + gap */
  }
}

/* FAB: готовим к инерции */
.prn-fab{
  will-change: transform;     /* плавность и производительность */
  transform: translateY(0);   /* базовое состояние */
}

/* можно отключить эффект на очень узких экранах */
@media (max-width: 480px){
  .prn-fab{ transform: none !important; }
}

/* === FIX: всегда видимое верхнее меню === */
:root{ --nav-h: 64px; }                 /* высота шапки на десктопе */
@media (max-width: 600px){
  :root{ --nav-h: 56px; }               /* пониже на мобилке */
}

/* делаем шапку фиксированной */
nav{
  position: fixed !important;
  top: 0; left: 0; right: 0;
  z-index: 1000;                        /* поверх контента */
  background: #ffffffcc;                /* полупрозрачный белый + blur */
  backdrop-filter: blur(12px);
  box-shadow: 0 4px 10px rgba(0,0,0,.05);
}

/* даём место под фикс-шапку, чтобы контент не прятался под ней */
body{ padding-top: var(--nav-h); }

/* якоря/заголовки прокручиваются так, чтобы не уходить под шапку */
h1[id], h2[id], h3[id], [id]{ scroll-margin-top: calc(var(--nav-h) + 10px); }

/* мобильное меню поверх всего */
#mobile-menu{ z-index: 1001; }

/* на случай, если где-то у родителя стоит overflow, что ломает fixed/blur */
header, .nav-wrapper { overflow: visible !important; }

:root{ --nav-h: 56px; }

@media (max-width: 600px){
  /* шапка фиксирована, контент ниже неё */
  body{ padding-top: var(--nav-h); }

  /* мобильное меню — фикс под шапкой, скроллируется само */
  #mobile-menu{
    position: fixed;
    top: var(--nav-h); left: 0; right: 0;
    height: calc(100vh - var(--nav-h));
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(8px);
    border-radius: 0 0 12px 12px;
  }
}

/* класс блокировки (для совместимости оставим, но JS всё контролирует) */
html.prn-lock, body.prn-lock{ overflow: hidden; }


/* HOTFIX: модалка снова поверх всего */
.prn-modal{
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: grid;               /* на случай, если где-то сбили */
  place-items: center;
}
/* Убираем прежний «унификатор», если он был:
   nav, .section, .container { position: relative; z-index: 1; } — оставить!
   НО .prn-modal в этот список НЕ включать. */

/* Меню-оверлей поверх контента, но под шапкой */
#mobile-menu{ z-index: 1001; }

/* === MODAL: всегда поверх, фикс к вьюпорту === */
.prn-modal{
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: grid;
  place-items: center;
}

/* если где-то раньше было "..., .prn-modal { position:relative; z-index:1; }" — УДАЛИ или оставь без .prn-modal */

/* Меню точно прячется, если закрыто */
#mobile-menu.mobile-hidden { display: none !important; }

html { scroll-behavior: smooth; }
:root { --header-offset: 60px; }     /* подстрой под высоту фикс-хедера */
[id] { scroll-margin-top: var(--header-offset); }

body.menu-open { position: fixed; width:100%; overflow:hidden; }

/* ========================
   HOTFIX PACK (добавить в КОНЕЦ файла)
   Убираем лишние зазоры на десктопе и возвращаем кликабельность бургера
   ======================== */

/* 1) На десктопе: вернём sticky-шапку и уберём «псевдо-отступ» от body */
@media (min-width: 601px){
  nav{ position: sticky !important; top: 0 !important; }
  body{ padding-top: 0 !important; }
  /* единый отступ для якорей (чтобы не прыгали и не создавали завышенный запас) */
  [id]{ scroll-margin-top: 80px !important; }
}

/* 2) На мобайле: оставляем fixed-хедер, но гарантируем правильную высоту */
@media (max-width: 600px){
  :root{ --nav-h: 56px !important; }        /* фактическая высота шапки на мобайле */
  nav{ position: fixed !important; top:0; left:0; right:0; }
  body{ padding-top: var(--nav-h) !important; }
  #mobile-menu{
    position: fixed; top: var(--nav-h); left:0; right:0;
    height: calc(100vh - var(--nav-h));
    overflow: auto; -webkit-overflow-scrolling: touch;
    z-index: 1001;
  }
  /* якоря под фикс-хедер */
  [id]{ scroll-margin-top: calc(var(--nav-h) + 10px) !important; }
}

/* 3) Бургер всегда над шапкой/меню и кликабелен */
.burger{ position: relative; z-index: 1002; pointer-events: auto; }

/* 4) Страховка отображения скрытого меню */
#mobile-menu.mobile-hidden{ display: none !important; }
#mobile-menu:not(.mobile-hidden){ display: flex !important; flex-direction: column; }

/* 5) Снимаем дубликаты правила из середины файла, чтобы они не давали “запасов” сверху */
html { scroll-behavior: smooth !important; }
:root { --header-offset: 0px !important; }  /* не используем этот offset параллельно с --nav-h */
h1[id], h2[id], h3[id], [id]{ scroll-margin-top: inherit !important; } /* используем то, что задали выше */

/* =========================
   VERTICAL RHYTHM HOTFIX
   ========================= */

/* 1) Секции сами без вертикального паддинга — паддинг держим у .container */
.section { padding: 0 !important; }

/* 2) Унифицируем вертикальные отступы контейнеров внутри секций */
.section > .container { padding-top: 24px !important; padding-bottom: 24px !important; }

/* 3) Соседние секции — чуть компактнее сверху */
.section + .section > .container { padding-top: 16px !important; }

/* 4) Герой-видео и следующий блок уже были «склеены» — оставим компактными */
.container:has(> .video-wrap) { padding-top: 24px !important; padding-bottom: 16px !important; }
.container:has(> .video-wrap) + .container { padding-top: 16px !important; }

/* 5) Сгладим локальные большие зазоры */
.bottom-photo       { margin-top: 24px !important; }
.gallery            { margin-top: 24px !important; }
.gdzie-grid         { margin-top: 16px !important; }
.benefits-grid      { margin-top: 20px !important; }

/* 6) Убираем «висячие» внешние отступы у первого/последнего элемента в контейнере */
.section > .container > :first-child { margin-top: 0 !important; }
.section > .container > :last-child  { margin-bottom: 0 !important; }

/* 7) Единый отступ под фикс-шапку для якорей (не влияет на компоновку, только на прокрутку) */
[id] { scroll-margin-top: 80px !important; }

/* 8) На мобайле оставляем место под фикс-шапку и корректируем якоря */
@media (max-width: 600px){
  :root { --nav-h: 56px !important; }
  body  { padding-top: var(--nav-h) !important; }
  [id]  { scroll-margin-top: calc(var(--nav-h) + 10px) !important; }
}

/* 9) Не даём локальным правилам снова надуть отступы */
.container { padding-left: 20px !important; padding-right: 20px !important; } /* горизонталь без изменений */

/* =========================
   EMERGENCY SPACING OVERRIDE
   ========================= */

/* A. Десктоп: sticky-хедер, никаких псевдо-отступов */
@media (min-width: 601px){
  nav{ position: sticky !important; top: 0 !important; }
  body{ padding-top: 0 !important; }
  /* единый безопасный offset под заголовки/якоря */
  [id]{ scroll-margin-top: 80px !important; }
}

/* B. Мобайл: фикс-хедер, но только реальная высота навигации */
@media (max-width: 600px){
  body{ padding-top: var(--nav-h, 56px) !important; } /* выставим из JS */
  [id]{ scroll-margin-top: calc(var(--nav-h, 56px) + 10px) !important; }
  #mobile-menu{
    position: fixed; top: var(--nav-h, 56px); left:0; right:0;
    height: calc(100vh - var(--nav-h, 56px));
    overflow: auto; -webkit-overflow-scrolling: touch;
    z-index: 1001;
  }
}

/* C. Убираем «двойные» вертикальные набивки между секциями */
.section{ padding: 0 !important; }
.section > .container{ padding-top: 24px !important; padding-bottom: 24px !important; }
.section + .section > .container{ padding-top: 16px !important; }

/* Сгладим локальные большие margin’ы */
.gallery{ margin-top: 24px !important; }
.bottom-photo{ margin-top: 24px !important; }
.gdzie-grid{ margin-top: 16px !important; }
.benefits-grid{ margin-top: 20px !important; }
#blog-preview .blog-cards{ margin: 24px 0 !important; }

/* Внутри контейнера — не даём первому/последнему элементу раздувать края */
.section > .container > :first-child{ margin-top: 0 !important; }
.section > .container > :last-child{  margin-bottom: 0 !important; }

/* Не позволяем наследоваться старому «левому» offset’у */
:root{ --header-offset: 0px !important; }
