/* **** */
/* MENU */
/* **** */


header {
  position: sticky;
  top: 0;
  z-index: 100;
}

/* Занимает место под fixed-меню. Fixed, чтобы меню обнимало пункты. Через sticky не работает ховер под меню. */
.menuSpacer {
  height: 25rem;
}

.menuWrapper {
  overflow-x: scroll;
  /* Инерция в сафари */
  -webkit-overflow-scrolling: touch;
  /* Прячем скроллбар */
  -ms-overflow-style: none;
  /* IE and Edge */
  scrollbar-width: none;
  /* Firefox */

  position: fixed;
  top: 0;
  max-width: 100%;
  z-index: 100;

  /* Поднимаем контент ниже до базовой текста */
  /* Не убираем оступ у li чтобы не обрезался текст сзину из-за oveflow */
  margin-bottom: -25rem;

  /* Чтобы кликалось под меню */
  /* Не работает в сафари на телефоне */
  /* pointer-events: none; */
}

/* Прячем скроллбар в Вебките */
.menuWrapper::-webkit-scrollbar {
  display: none;
}

.menu {
  /* Перезаписываем дефолты */
  margin-block-start: 0;
  margin-block-end: 0;

  display: inline-flex;
  align-items: center;
  gap: 50rem;
  /*width: calc(100vw - 50rem);*/

  pointer-events: all;
}

.menu>li {
  margin: 20rem 0;
  display: flex;
}

.menu>li>p {
  --webkit-user-select: none;
  user-select: none;
}

@media screen and (max-width: 800px) {
  .menu {
    gap: 25rem;
    width: unset;
  }
}

@media only screen and (max-width: 360px) {
  .menu {
    gap: 25rem;
  }
}

/* Активный пункт */
.menu .disabled,
footer .disabled {
  pointer-events: none;
  position: relative;
}

.menu li.selected {
  position: relative;
}

.menu li.selected::after {
  content: "·";
  font-size: var(--paragraph-font-size);
  color: var(--text-color);
  position: absolute;
  left: -11rem;
  top: -8rem;
}

/* Ховер красит точку */
.menu li.selected:has(a:hover)::after {
  color: var(--hover-color);
}


/* Логотип */

.logo {
  position: fixed;
  top: 14rem;
  right: var(--margin-grid);
  z-index: 200;
}

.logo svg {
  width: 25rem;
  color: var(--text-color);
  /* Красим в цвет текста */
}

@media screen and (min-width: 1600px) {
  .logo svg {
    width: 38px;
  }
}

@media screen and (max-width: 800px) {
  .logo {
    position: fixed;
    top: initial;
    bottom: 18rem;
  }

  .logo svg {
    width: 36rem;
  }
}

/* Плавная смена цвета по скроллу */
menu,
.logo svg,
.menu>li.order::after {
  transition: background 200ms;
}

/* Убираем плашку у «Заказать» на тёмном фоне */
/*.menu.darkmode>li.order::after {
  background: none;
}*/


/* ****** */
/* SUBMENU */
/* ****** */

.submenu {
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%vw;
}

.submenu menu {
  gap: 25rem;
  padding-left: var(--margin-grid);
}


/* ****** */
/* FOOTER */
/* ****** */

/* Stick footer to the bottom */
body {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

footer {
  margin-top: auto;
  padding-top: var(--margin-header);
  padding-bottom: 20rem;
  /* В ремах чтобы не менялось на мобиле и было визуально одинаково с меню */

  /* Если несколько элементов */
  display: flex;
  flex-wrap: wrap;
  gap: var(--margin-grid);
  /* Отступ для короны */
  padding-right: 54rem;
}