:root {
  --background: #c4e1fa;
  --foreground: #0E1923;
  --background-dim: #111827;
  --foreground-dim: #87a3c5;

  --primary: #748CA9;
  --secondary: #4d5d71;
}

/*@font-face {
  font-family: "Libre Baskerville";
  src: url(.././fonts/LibreBaskerville-SemiBold.ttf);
}*/

/*@font-face {
  font-family: "terminus";
  src: url(./font/spleen-32x64.pcf);
}

* {
  font-family: "terminus";
}*/

h1, h2, h3, h4, p {
  margin: 0;
  padding: 0;
}

html {
  min-height: 100%;
}

body {
  /* background-color: var(--background); */
  background: linear-gradient(to bottom, #f5f5f5, #f5f5f5 50%, #f0f0f0 50%, #f0f0f0);
  background-size: 100% 1vh;
  margin: 15px 30px;
  padding: 0;
  font-size: 1.1rem;
}

header {
  padding: 5px;
  height: 30px;
  flex-basis: 100%;
  flex-shrink: 0;
}

nav {
  margin-top: 1%;
  flex-basis: content;
}

footer {
  text-align: center;
  padding: 3px;
  flex-basis: 100%;
  color: var(--primary);
  margin-top: auto;
}

main {
  /* background-color: var(--background); */
  color: var(--foreground);
  margin: 30px 50px;
  flex-basis: 80%;
  min-height: 70vh;
  display: flex;
  flex-direction: column;
}

a:link, a:visited {
  text-decoration: none;
  color: var(--primary);
}

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

::marker {
  color: var(--foreground);
}

hr {
  border-color: var(--foreground);
}

/*img {
  border: 2px solid var(--foreground);
}*/

.dekstop-img {
  border: 2px solid var(--primary);
}

.flex {
  display: flex;
}

.wrap {
  flex-wrap: wrap;
}

.right {
  float: right;
  align-content: right;
  justify-content: space-between;
}

.space-between {
  justify-content: space-between;
}

.header-buttons {
  margin: 0 5px;
  font-size: 20px;
}

.main-header-name {
  color: var(--primary);
  font-size: 23px !important;
}

.header-separator {
  color: var(--primary);
}

.footer-separator {
  display: none;
  color: var(--primary);
}

.footer-buttons {
  display: none;
  margin: 0 5px;
  font-size: 17px;
}

.footer-credits {
  margin-bottom: 3px;
}

.nav-buttons {
  margin: 0 5px;
  font-size: 20px;
}

@media (max-width: 600px) {
  body {
    margin: 5px;
  }
  main {
    margin: 15px;
    flex-basis: 100%;
  }
  header {
    padding: 0px;
    flex-basis: 100%;
 }
 nav {
   margin-top: 2%
 }
 .header-buttons {
    display: none;
  }
  .header-separator {
    display: none;
  }
  .footer-separator {
    display: inline
  }
  .footer-buttons {
    display: inline;
  }
  .desktop-img {
    height: 30vh !important;
  }
}
