@import "_variables.css";

body {
  background-color: var(--background-color-light);
  color: var(--text-color-light);
  min-height: 100vh;
  font-family: "MesloLGL", "Menlo", "Meslo LG", monospace;
  font-size: 1rem; /* Use rem for base font size */
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

body.dark-mode {
  background-color: var(--background-color-dark);
  color: var(--text-color-dark);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--heading-color);
  font-weight: 700;
  letter-spacing: 0.01em;
}

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

/* Import the font face */
@font-face {
  font-family: "MesloLGL";
  src: url("/static/fonts/MesloLGS-Regular.ttf") format("truetype");
}

/* Header Styles */
header {
  img.logo {
    height: 60px;
    width: auto;
    margin-right: 20px;
    vertical-align: middle;
  }

  /* Theme Toggle Button */
  #theme-toggle {
    background-color: var(--special);
    color: var(--background-color);
    border: none;
    padding: 5px 10px;
    cursor: pointer;
    transition: background-color 0.3s;
    font-family: "MesloLGL", "Menlo", "Meslo LG", monospace;

    &:hover {
      background-color: var(--link-underline);
    }
  }
}

/* Navigation Styles */
nav {
  &#main-nav {
    display: block;

    @media (max-width: 37.5em) {
      display: none;
      flex-direction: column;
      width: 100%;

      a {
        padding: 0.625rem;
        display: block;
      }
    }
  }
}

/* Mobile Menu Toggle */
#menu-toggle {
  display: none;

  @media (max-width: 37.5em) {
    display: block;
    background-color: var(--special);
    color: var(--text-color-light);
    border: none;
    padding: 0.3125rem 0.625rem;
    cursor: pointer;
    font-size: 1rem;
    text-align: center;
  }
}

/* Media Queries for Responsiveness */
@media (max-width: 37.5em) {
  body,
  header,
  footer,
  nav,
  main {
    padding: 0.625rem;
  }

  body {
    font-size: 0.875rem;
  }
  header img.logo {
    margin-bottom: 0.625rem;
  }

  nav#main-nav a {
    padding: 0.3125rem;
  }

  header,
  footer {
    flex-direction: column;
    padding: 1.25rem;
  }

  header {
    img.logo {
      margin-bottom: 1.25rem;
    }
  }
}
