@layer components {
  .logo {
    text-transform: uppercase;
    font-style: italic;
    font-weight: 800;
    font-size: larger;
    letter-spacing: 0.1ch;
    color: var(--color-text);
  }

  .header {
    display: flex;
    justify-content: space-between;

    padding-block-end: var(--block-space-double);

    nav ul {
      display: flex;
      gap: var(--inline-space);
      flex-wrap: wrap;
    }
  }

  #menu {
    --hidden: 100vw;
    --visible: 0;

    width: 100%;
    margin: 0;
    border: 0;
    height: 100vh;
    background-color: var(--color-surface);
    translate: var(--hidden);

    padding: var(--block-space) var(--block-space);

    &::backdrop {
      background-color: rgb(20, 20, 20);
      opacity: 0;

      transition-duration: 300ms;
      transition-timing-function: ease;
      transition-property: opacity;
    }

    @media (prefers-reduced-motion: reduce) {
      &::backdrop {
        transition-duration: 1ms;
      }
    }

    @media (prefers-reduced-motion: no-preference) {
      transition:
        translate 300ms ease,
        display 300ms,
        overlay 300ms;

      transition-behavior: allow-discrete;
    }
    &:popover-open {
      position: fixed;
      top: 0;
      right: 0;
      translate: var(--visible);

      &::backdrop {
        opacity: 0.5;

        @starting-style {
          opacity: 0;
        }
      }

      @starting-style {
        translate: var(--hidden);
      }
    }

    .menu-entry {
      display: inline-block;
      width: 100%;
      padding: 0 0 var(--block-space);
      text-decoration: none;
      border-bottom: 1px solid var(--color-text-softest);
      color: var(--color-text);

      /* only for buttons */
      background-color: transparent;
      text-align: start;
    }
  }

  .btn-nav-open {
    --btn-bg-color: transparent;
    --btn-text-color: var(--color-text);
    --icon-size: 1.5rem;
    padding: 0;
  }

  .btn-nav-close {
    --btn-bg-color: transparent;
    --btn-text-color: var(--color-text);
    --icon-size: 1.5rem;
    padding: 0;
    text-align: end;
    font-size: 1.5rem;
  }
}
