@media only screen and (min-width: 768px) {
}

@media only screen and (min-width: 1024px) {
}

@media only screen and (min-width: 1280px) {
}

@media only screen and (min-width: 1580px) {
}

body {
  margin: 0;
  background-color: var(--primary-background-color);
  color: var(--primary-text-color);
  font-family: var(--primary-font-style);
}

header {
  grid-area: header;
}
nav {
  grid-area: menu;
}
div.content {
  grid-area: content;
}

a {
  color: var(--primary-link-color);
}
a:hover {
  color: var(--primary-link-color-hover);
}

header,
div.content {
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

nav {
  background-color: var(--secondary-background-color);
}

nav * {
  margin-block-start: 0;
  margin-block-end: 0;
}

nav h2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

nav a {
  color: var(--primary-text-color);
  text-decoration: none;
}
nav a:hover {
  text-decoration: none;
}

nav ul {
  height: 0px;
  overflow: hidden;
  list-style: none;
  padding-inline-start: 0;
  display: flex;
  flex-direction: column;
}

nav ul li a {
  display: block !important;
  padding: 0.5rem 0 0.5rem 0;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}
nav ul li a.active {
  background-color: var(--menu-hover);
}
nav ul li a i {
  margin-right: 0.5rem;
}

@media only screen and (min-width: 768px) {
  body {
    display: grid;
    grid-template-columns: 250px 1fr;
    grid-template-rows: auto 1fr;
    grid-template-areas:
      "menu header"
      "menu content";
    min-height: 100vh;
  }

  nav h2 {
    display: none;
  }
  nav ul {
    height: unset;
    margin-top: 1rem;
    margin-bottom: 1rem;
    position: sticky;
    top: 0;
    max-height: calc(100vh - 2rem);
    overflow: auto;
  }
}

/* alert */

.alert {
  margin-left: auto;
  margin-right: auto;
  padding: 0.25rem 1rem;
}

.alert.alert-info {
  background-color: var(--info-background);
  color: var(--info-text);
}

/* table */

table {
  width: 100%;
}
table th {
  background-color: var(--table-header-background-color);
  padding: 0.5rem;
}
table td {
  padding: 0.5rem;
  border-color: var(--table-border-color);
  border-bottom-width: 1px;
  border-bottom-style: solid;
}

table td.small-col {
  width: 10%;
  min-width: 20px;
}

img.icon {
  max-width: 30px;
}

@media only screen and (min-width: 768px) {
  img.icon {
    max-width: 64px;
  }
}
