:root {
  --background-color: hsl(233, 14%, 12%);
  --link-color: #b56bff;
  --link-hover-color: white;
  --button-color: rebeccapurple;
  --text-color: #efddff;
  --nav-item-color: #e3bfff;
  --nav-item-hover-background-color: #a348fd;
  --button-text-color: var(--link-color);
  --nav-item-active-color: var(--text-color);
  --nav-item-hover-color: var(--nav-item-active-color);
}

@font-face {
  font-family: "Montserrat";
  src: url("/fonts/Montserrat-VariableFont_wght.ttf") format("woff2");
  font-display: swap;
}
@font-face {
  font-family: "Montserrat";
  src: url("/fonts/Montserrat-Italic-VariableFont_wght.ttf") format("woff2");
  font-style: italic;
  font-display: swap;
}
html,
body {
  background-color: var(--background-color);
  height: 100%;
  padding: 0;
  margin: 0;
  font-family: Montserrat, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
}

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

* {
  box-sizing: border-box;
}

.layout {
  display: grid;
  min-height: 100vh;
  grid-template-rows: auto 1fr auto;
}

.content {
  background-color: var(--background-color);
  color: var(--text-color);
  padding: 1rem;
}

.nav-bar {
  height: 50px;
  background-color: var(--button-color);
  display: flex;
  flex-flow: row;
  align-items: center;
  justify-content: center;
  max-height: 50px;
}

.item {
  font-weight: 500;
  text-transform: uppercase;
  color: var(--nav-item-color);
  text-decoration: none;
  margin-right: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 1.1rem;
  border-radius: 8px;
  transition: color 0.2s ease-in-out, font-size 0.2s ease-in-out, background-color 0.2s ease-in-out; /* Smooth transitions */
}

.item:hover {
  color: var(--nav-item-hover-color);
  background-color: var(--nav-item-hover-background-color);
}

.item.active {
  color: var(--nav-item-active-color);
  font-weight: 700;
}

.menu-toggle {
  display: none;
}

.hamburger {
  display: none;
  flex-direction: column;
  cursor: pointer;
}

.hamburger span {
  height: 2px;
  width: 25px;
  background-color: var(--nav-item-color);
  margin-bottom: 4px;
  transition: all 0.3s ease-in-out;
}

.footer {
  display: none;
}

@media (max-width: 768px) {
  .item {
    padding: 0.5rem 0;
  }
  .item:hover {
    color: var(--nav-item-color);
    background-color: var(--button-color);
  }
  .item.active:hover {
    color: var(--nav-item-active-color);
  }
  .links {
    padding-left: 0.25rem;
  }
  .nav-bar {
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: 1rem;
    padding-left: 1rem;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: max-height 0.3s ease-in-out;
  }
  .nav-bar .links {
    display: none;
    flex-direction: column;
    width: 100%;
  }
  .hamburger {
    display: flex;
    padding-left: 0.4rem;
    padding-top: 3px;
  }
  .menu-toggle:checked + .hamburger span:nth-child(1) {
    transform: rotate(45deg) translateY(8.5px);
  }
  .menu-toggle:checked + .hamburger span:nth-child(2) {
    opacity: 0;
  }
  .menu-toggle:checked + .hamburger span:nth-child(3) {
    transform: rotate(-45deg) translateY(-8.5px);
  }
  .menu-toggle:checked ~ .links {
    display: flex;
    max-height: 190px;
  }
  .nav-bar:has(.menu-toggle:checked) {
    height: fit-content;
    max-height: 190px;
  }
}