.menu {
  --overlay-footer-height: 6.2rem;
}

.menu__sections {
  margin-inline: calc(var(--overlay-content-padding-inline) * -1);
}

.menu__section {
  --menu-link-padding-inline: var(--overlay-content-padding-inline);
  --menu-link-padding-block: 2rem;
  --menu-link-font-weight: var(--font-weight-semibold);
  --focus-outline-width: 3px;
  --focus-outline-offset: -4px;

  display: block;

  &:is([data-open='true']) {
    background-color: var(--color-midnight-offset);
  }

  &:is([data-open='true']) + &::before,
  & + &:is([data-open='true'])::before {
    opacity: 0;
  }

  & + &::before {
    background-color: var(--color-midnight-line);
    block-size: 1px;
    content: '';
    display: block;
    inline-size: calc(100% - var(--overlay-content-padding-inline) * 2);
    margin-block-start: -1px;
    margin-inline: var(--overlay-content-padding-inline);
    position: absolute;
    transition-property: opacity;
    z-index: 1;
  }
}

.menu__navigation {
  font-size: 1.8rem;
  line-height: var(--line-height-body);
  padding-block-end: 2rem;
  padding-inline-end: var(--overlay-content-padding-inline);
  padding-inline-start: calc(var(--overlay-content-padding-inline) * 1.5);
}

.menu__back {
  display: flex;
  font-weight: var(--font-weight-semibold);
  gap: 1rem;
  inline-size: 100%;
  margin-block-end: 2rem;
  padding-block: 0.5rem;
  user-select: text;
}

.menu__back-icon {
  color: var(--color-orange);
  flex-shrink: 0;
  font-size: 1.6rem;
  line-height: 0;
  padding-block: calc((1.8rem * var(--line-height-body) - 1em) / 2);
}

.menu__items {
  --menu-link-padding-inline: 0;
  --menu-link-padding-block: 0.5rem;
  --menu-link-font-weight: var(--font-weight-regular);
  --focus-outline-width: 3px;
  --focus-outline-offset: 3px;

  display: grid;
  row-gap: 1rem;
}

.menu__divider {
  border-block-start-color: var(--color-midnight-line);
  border-block-start-style: solid;
  border-block-start-width: 1px;
  font-size: 1.4rem;
  font-weight: var(--font-weight-semibold);
  margin-block-start: 1rem;
  padding-block-end: 0.5rem;
  padding-block-start: 2.4rem;
}

.menu__item {
  display: block;
}

.menu__link {
  align-items: flex-start;
  display: flex;
  font-weight: var(--menu-link-font-weight, var(--font-weight-regular));
  gap: 1rem;
  inline-size: 100%;
  justify-content: space-between;
  line-height: var(--line-height-body);
  padding-block: var(--menu-link-padding-block, 0);
  padding-inline: var(--menu-link-padding-inline, 0);
  user-select: text;
}

.menu__link-icon {
  color: var(--color-orange);
  flex-shrink: 0;
  font-size: 1.4rem;
  line-height: 0;
  padding-block: calc((1.8rem * var(--line-height-body) - 1em) / 2);
}

.menu__submenu {
  animation: slide-from-right var(--duration-default);
  background-color: var(--color-midnight-offset);
  inline-size: 100%;
  inset-block-end: var(--overlay-footer-height);
  inset-block-start: var(--overlay-bar-height);
  inset-inline-end: 0;
  inset-inline-start: auto;
  margin-block-start: 0;
  max-inline-size: var(--overlay-max-width);
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-block: 2rem;
  padding-inline: var(--overlay-content-padding-inline);
  position: fixed;
  z-index: 3;
}

.menu__footer {
  align-items: stretch;
  block-size: 100%;
  display: flex;
  flex-grow: 1;
  margin-inline: calc(var(--overlay-content-padding-inline) * -1);
}

.menu__footer-lang-switchter {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  padding-inline: var(--overlay-content-padding-inline);
  position: relative;
}
