html {
  overscroll-behavior: none;
}

body {
  --footer-height: calc((var(--block-space)) + 3.6em + var(--block-space));
  --navbar-height: 4.125em;
  --sidebar-width: 0vw;

  display: grid;
  grid-template-areas:
    "sidebar nav"
    "sidebar main";
  grid-template-columns: var(--sidebar-width) 1fr;
  grid-template-rows: min-content 1fr;
  max-block-size: 100dvh;

  &.sidebar {
    @media (min-width: 120ch) {
      --sidebar-width: calc(26vw + var(--sidebar-tools-width));
    }
  }
}

#app-logo {
  display: none;

  @media (min-width: 120ch) {
    block-size: var(--footer-height);
    display: grid;
    filter: saturate(0);
    inline-size: 5vw;
    inset: auto 0 0 auto;
    opacity: 0.5;
    padding-inline: 1vw;
    place-items: center;
    position: absolute;
    transition: opacity 500ms ease-in-out, filter 500ms ease-in-out;

    & img {
      block-size: auto;
      inline-size: 100%;
      max-inline-size: 2.75em;
    }

    &:hover {
      filter: none;
      opacity: 1;
    }
  }
}

#nav {
  grid-area: nav;
}

#main-content {
  align-content: start;
  background-color: var(--color-bg);
  display: flex;
  flex-direction: column;
  grid-area: main;
  overflow: auto;
  position: relative;
  /* Compensate for fixed #nav which is out of grid flow */
  padding-top: var(--navbar-height, 4.125em);

  .sidebar & {
    justify-content: end;

    &:has(.panel) {
      justify-content: start;
    }

    @media (min-width: 120ch) {
      border-inline: 1px solid var(--color-border-darker);
      margin-inline: 0 5vw;
    }
  }
}

#sidebar {
  grid-area: sidebar;
  position: relative;
  transition: transform 300ms ease;

  .sidebar & {
    background-color: var(--color-bg);
    block-size: 100dvh;
    max-block-size: 100dvh;
    z-index: 3;

    @media (max-width: 120ch) {
      inset: 0;
      position: fixed;
      transform: translate(-100%);
    }
  }

  &.open {
    @media (max-width: 120ch) {
      transform: translate(0);
    }
  }
}

#footer {
  grid-area: footer;
}
