*, *::before, *::after {
  box-sizing: border-box;
}

body {
  line-height: 1.5;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  font-family: system-ui, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  padding: 1rem;
}

/* ======= */
/* Margins */
/* ======= */

body {
  margin: 0;
}

h1, header:has(h1) {
  margin-top: 1.5rem;
}

h2, header:has(h2) {
  margin-top: 1.2rem;
}

h3, header:has(h3), h4 {
  margin-top: 1rem;
}

header, h1, h2, h3, h4, h5, h6 {
  margin-bottom: 0px;

  &:first-child, form {
    margin-top: 0rem;
  }
}

p, ul, pre, ol, ul {
  margin-top: 1rem;
  margin-bottom: 0;

  &:first-child {
    margin-top: 0rem;
  }
}

ol, ul {
  margin-top: 0.5rem;
}

div, section, table + h2, nav, fieldset {
  margin-top: 1rem;
}

dl {
  margin-bottom: 1rem;
}

/* =========== */
/* End margins */
/* =========== */

h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
  text-wrap: wrap;
  font-weight: normal;
}

h1 {
  border-bottom: 1px solid var(--light-gray);
  padding-bottom: 0.5rem;
}

h2 {
  border-bottom: 1px solid var(--lightest-gray);
  padding-bottom: 0.3rem;
}

/* h3 { */
/*   border-bottom: 1px solid var(--lightest-gray); */
/*   padding-bottom: 0.3rem; */
/* } */

h4 {
  font-size: 1.1rem;
}

a {
  color: var(--link-color);
  text-decoration: none;

  &:visited {
    color: var(--link-color);
  }
  &:hover {
    text-decoration: underline;
  }
}

/* Layout */

body:has(aside + main) {
  padding: 0px;
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
}

body:has(main + aside), body:has(main:first-child:last-child) {
  padding: 0px;
  display: grid;
  grid-template-columns: 800px minmax(0, 1fr);
}

aside {
  border-right: 1px solid lightgray;
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 1.5rem;
  overflow-y: auto;

  nav {
    display: block;
  }

  header, nav {
    margin-bottom: 1rem;
  }

  header img {
    max-width: 200px;
  }

  nav, footer {
    section {
      margin-left: 0.7rem;
      margin-bottom: 0.3rem;
      font-size: 0.9rem;
      margin-top: 0;
    }

    div {
      display: flex;
      justify-content: space-between;

      > a:first-child {
        flex: 1;
      }
    }

    span * {
      display: inline-block;
    }
  }

  a {
    display: block;
    color: black;
    &:visited {
      color: black;
    }
  }
  span {
    color: var(--gray);
  }

  footer {
    margin-top: 2rem;
  }
}

main {
  section {
    border: 1px solid rgba(0, 0, 0, 0.175);
    background-color: white;
    border-radius: 3px;
    padding: 1rem;
  }
}

/* End layout */

header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-bottom: 0.5rem;
  gap: 0.3rem;

  &:has(h1) {
    border-bottom: 1px solid var(--light-gray);
    padding-bottom: 0.5rem;
  }

  &:has(h2) {
    border-bottom: 1px solid var(--lightest-gray);
    padding-bottom: 0.3rem;
  }

  &:has(nav) {
    display: grid;
    grid-template-columns: auto min-content;

    div {
      display: flex;
      gap: 0.3rem;
    }

    nav {
      grid-column-start: 1;
      grid-column-end: 2;
      grid-row-start: 2;
      grid-row-end: 2;
      margin-top: 0px;
    }
  }

  h1, h2, h3 {
    border-bottom: none;
    margin-right: auto;
    padding-bottom: 0px;
  }

  h1 + p {
    color: #4d4d4d;
  }
}

main {
  padding: 1.5rem;
}

dl {
  display: grid;
  grid-template-columns: max-content auto;
  gap: 0rem 0.6rem;
}

dt {
  grid-column-start: 1;
}

dd {
  grid-column-start: 2;
}

nav {
  display: flex;
  gap: 0.2rem 0.7rem;
  flex-wrap: wrap;
}

pre {
  padding: 1rem;
  background-color: gainsboro;
}
