header nav {
  width: 100%;
  height: 70px;

  display: flex;
  flex-direction: row;
  flex-wrap: wrap;

  position: fixed;

  z-index: 999;

  background: white;

  font-size: 1.2em;
  font-weight: 600;
  text-align: center;
}

header nav + * {
  padding-top: 70px;
}

header nav .nav-icon {
  font-size: 150%;
  padding: 5px 20px;
  display: flex;
  align-items: center;
}

header nav .nav-item {
  height: 60px;

  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;

  padding: 5px 20px;

  cursor: pointer;

  position: relative;
}

header nav .nav-item-right {
  margin-left: auto;
}

header nav .nav-group {
  display: flex;
  position: relative;
}

header nav .nav-group-right {
  justify-content: flex-end;
  margin-left: auto;
}

header nav .nav-button {
  width: 40px;
}

header nav .nav-drop-down {
  top: 70px;
  position: absolute;

  background: inherit;
  width: 100%;

  display: none;

  flex-direction: column;

  z-index: 1000;

  box-shadow: 0px 7px 10px 1px rgba(0, 0, 0, 0.2);
}

header nav .nav-drop-down .seperator {
  border-right: None;
  border-bottom: 1px solid #999;

  height: 0px;
  width: calc(100% - 20px);

  align-self: center;

  margin: 0px 10px 10px 10px;
  padding: 10px 0px 0px 0px;
}

/*
 * Things for on hover sub-menus
 */
header nav .nav-hover-dropdown {
  margin: 0;
  width: 100%;
  font-size: 90%;
}

header nav .nav-group .nav-hover-dropdown {
  position: absolute;
  top: 70px;

  border: 1px solid rgba(211, 211, 211, 1);
  border-top: 0;
  display: none;
}

header nav .nav-group:hover .nav-hover-dropdown {
  display: block;
}

header nav .nav-hover-dropdown a {
  padding: 10px 20px;
  display: block;
  text-align: left;
}

header nav .nav-drop-down .nav-hover-dropdown a {
  padding-left: 35px;
}

/* --------- smartphone ----------- */
@media (max-width: 1071px) {
  .collapse > :not(.nav-drop-down).nav-item:not(.nav-nohide),
  .collapse > :not(.nav-drop-down) .nav-item:not(.nav-nohide) {
    display: none;
  }

  .nav-drop-down * {
    align-content: flex-start !important;
    text-align: left !important;
  }

  .nav-drop-down .nav-item {
    justify-content: flex-start;
    height: 50px;
  }

  .nav-drop-down .nav-item > * {
    margin: 0;
  }

  .collapse-button {
    display: flex;
    height: 27px !important;
    width: 32px !important;
    margin-top: 24.5px !important;
    margin-bottom: 18.5px !important;
    margin-right: 20px;
    padding: 0px !important;
  }
}

@media (min-width: 1072px) {
  .nav-drop-down {
    display: none;
  }

  header nav .seperator {
    border-right: 1px solid #999;

    width: 0px;
    height: 80%;

    align-self: center;

    margin-right: 10px;
    padding: 0px 0px 0px 10px;
  }

  .collapse-button {
    display: none !important;
  }
}

footer {
  display: flex;
  flex-direction: column;
  justify-content: center;

  margin-top: 2%;
  padding-top: 1% !important;

  width: 100%;

  font-size: 0.5em;
  font-weight: 300;
  text-align: center;

  background: #171921;
  color: #ddd;

  box-shadow: 0px -1px 10px 6px #171921;
}

footer .flex {
  justify-content: center;
}

footer .flex > * {
  margin: 1% 1%;
  min-width: 150px;
  max-width: 15%;
}

footer a.link {
  color: #f77e39;
}

footer h2 {
  font-size: 1.3em;
}

footer > * {
  margin: 0.4% 1%;
}

footer * {
  font-weight: inherit;
}

@media (max-width: 1071px) {
  footer > * {
    margin: 10px 10px;
  }

  footer .flex {
    justify-content: center;
  }

  footer .flex {
    flex-wrap: wrap;
  }
}
