/* Small custom styling on top of Tailwind */

/* Шапка без Tailwind (CDN недоступен): не показывать десктоп+мобильный ряд одновременно */
header#site-header .sg-nav-fallback-desktop {
  display: none;
}
header#site-header .sg-nav-fallback-mobile-bar {
  display: flex;
}
@media (min-width: 768px) {
  header#site-header .sg-nav-fallback-desktop {
    display: flex;
  }
  header#site-header .sg-nav-fallback-mobile-bar {
    display: none;
  }
  header#site-header #mobileMenu.sg-mobile-menu-panel {
    display: none !important;
  }
}
header#site-header #mobileMenu.sg-mobile-menu-panel.hidden {
  display: none;
}
header#site-header #mobileMenu.sg-mobile-menu-panel:not(.hidden) {
  display: block;
}

html {
  scroll-behavior: smooth;
  overflow-x: clip;
}

/* Главная: hero-фон на всю ширину — подстраховка против preflight у video */
section[data-home-hero] video.hero-bg-video {
  width: 100%;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  /* Пока видео не играет — не показываем первый кадр из файла (часто «лишний» план); фон — bg-slate-900 у обёртки */
  opacity: 0;
  transition: opacity 0.45s ease;
}

section[data-home-hero] video.hero-bg-video.is-home-hero-ready {
  opacity: 1;
}

/* Hero video: preflight max-width:100% ломает cover — дублируем в CSS (и inline на теге) */
video.hero-bg-video {
  max-width: none !important;
  max-height: none !important;
}

/* Видео в карточках на главной (не hero): тот же конфликт с preflight */
video.sg-home-inline-video {
  max-width: none !important;
  max-height: none !important;
}

/* Карточки «Рулонный / посевной»: чуть резче апскейл на ретине (без «мыла» от сглаживания) */
img.gazon-compare-img {
  image-rendering: auto;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
}

/* Страница «Газон»: фон чуть больше блока + scale — убирает белую полоску (dvh/header + субпиксель у video) */
section[data-gazon-hero] .gazon-hero-media {
  position: absolute;
  z-index: -1;
  /* низ с большим запасом: на Pages без #site-header + JS щель заметнее */
  inset: -16px -16px -48px -16px;
  width: auto;
  height: auto;
  overflow: hidden;
  background-color: #0f172a;
}

section[data-gazon-hero] .gazon-hero-media video.hero-bg-video {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  transform: translate3d(-50%, -50%, 0) scale(1.06);
  object-fit: cover;
  object-position: 50% 52%;
  display: block;
  /* Пока видео не играет — виден тот же кадр, что и poster (фон на .gazon-hero-media), без вспышки старого кадра из кэша */
  opacity: 0;
  transition: opacity 0.45s ease;
}

section[data-gazon-hero] .gazon-hero-media video.hero-bg-video.is-gazon-hero-ready {
  opacity: 1;
}

/* На случай 1px щели между hero и следующей секцией (белый body) */
section[data-gazon-hero] {
  box-shadow: inset 0 -2px 0 0 rgb(15, 23, 42);
  background-color: #0f172a;
}

/* Страница B2B: hero-фон — видео (как у «Газон»: cover, scale, без щели снизу) */
section[data-b2b-hero] .b2b-hero-media {
  position: absolute;
  z-index: -1;
  inset: -16px -16px -48px -16px;
  width: auto;
  height: auto;
  overflow: hidden;
  background-color: #0f172a;
}

section[data-b2b-hero] .b2b-hero-media video.hero-bg-video {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  transform: translate3d(-50%, -50%, 0) scale(1.06);
  object-fit: cover;
  object-position: 50% 50%;
  display: block;
  opacity: 0;
  transition: opacity 0.45s ease;
}

section[data-b2b-hero] .b2b-hero-media video.hero-bg-video.is-b2b-hero-ready {
  opacity: 1;
}

section[data-b2b-hero] {
  box-shadow: inset 0 -2px 0 0 rgb(15, 23, 42);
  background-color: #0f172a;
}

/* Садовые центры: тот же приём, что у «Газон» / B2B — без белой щели снизу у hero */
section[data-sadovye-centry-hero] {
  box-shadow: inset 0 -2px 0 0 rgb(15, 23, 42);
  background-color: #0f172a;
}

/* Служба заботы: градиентный hero — подложка + полоска снизу, как у видео-hero (щель body / dvh / субпиксель) */
section[data-zaboty-hero] {
  box-shadow: inset 0 -3px 0 0 rgb(15, 23, 42);
  background-color: rgb(15, 23, 42);
}

/* Кнопка «Служба заботы» в шапке — без глобального сдвига как у rounded-2xl ссылок */
a.nav-zaboty-pill {
  transform: none;
}
a.nav-zaboty-pill:hover {
  transform: none;
}
a.nav-zaboty-pill:active {
  transform: none;
}

/* Modal open animation */
.modal-enter {
  animation: modalEnter 220ms ease-out both;
}

@keyframes modalEnter {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Footer year */
#year {
  font-variant-numeric: tabular-nums;
}

/* Global button animations */
button,
a.rounded-2xl,
a.rounded-xl {
  transition:
    transform 220ms ease,
    box-shadow 220ms ease,
    filter 220ms ease,
    background-color 220ms ease,
    border-color 220ms ease,
    color 220ms ease;
  will-change: transform;
}

button:hover,
a.rounded-2xl:hover,
a.rounded-xl:hover {
  transform: translateY(-2px);
}

button:active,
a.rounded-2xl:active,
a.rounded-xl:active {
  transform: translateY(0) scale(0.98);
}

button:focus-visible,
a.rounded-2xl:focus-visible,
a.rounded-xl:focus-visible {
  outline: 2px solid rgba(64, 145, 108, 0.45);
  outline-offset: 2px;
}

/* Slightly stronger glow for already highlighted CTAs */
button.shadow-glow:hover,
a.shadow-glow:hover {
  box-shadow:
    0 0 0 1px rgba(64, 145, 108, 0.35),
    0 18px 36px rgba(45, 106, 79, 0.25);
}

/* Respect reduced-motion preferences */
@media (prefers-reduced-motion: reduce) {
  button,
  a.rounded-2xl,
  a.rounded-xl {
    transition: none !important;
    transform: none !important;
  }
}

