#menu {
  width: 100%;
  background-color: var(--menu-background-color);
  border: var(--menu-border-width) var(--menu-border-style) var(--menu-border-color);
  border-radius: var(--menu-border-radius);
}

#menu:after {
  clear: both;
  content: " ";
  display: table;
}

#menu-button {
  display: none;
  padding: 0.5em 1.5em 0.5em 0.5em;
  letter-spacing: 0.1em;
  font-family: var(--menu-button-font-family);
  font-size: 1em;
  font-weight: var(--menu-button-font-weight);
  color: var(--menu-button-color);
  background-color: var(--menu-button-background-color);
  border-radius: var(--menu-border-radius);
  text-align: center;
  text-decoration: none;
}

@media screen and (max-width: 500px) {
  #menu-button {
    display: block;
  }
}

#menu ul {
  list-style-type: none;
}

#main-menu {
  display: none;
  width: 100%;
}

@media screen and (min-width: 501px) {
  #main-menu {
    display: block !important;
    width: 450px;
    margin-left: auto;
    margin-right: auto;
  }
}

#main-menu > li {
  position: relative;
  float: left;
}

@media screen and (max-width: 500px) {
  #main-menu > li {
    float: none;
    border-top: 1px solid  var(--main-menu-border-color);
  }
}

#main-menu > li > a {
  display: block;
  padding: 0.5em 1.5em 0.5em 0.5em;
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
  border-bottom: 1px solid transparent;
  border-radius: var(--menu-border-radius);
  font-family: var(--main-menu-font-family);
  font-size: 1em;
  font-weight: var(--main-menu-font-weight);
  color: var(--main-menu-color);
  background-color: var(--main-menu-background-color);
  text-align: left;
  text-decoration: none;
}

@media screen and (max-width: 500px) {
  #main-menu > li > a {
    display: block;
    padding: 0.6em 1em;
    border-left: 1px solid transparent;
    border-right: 1px solid transparent;
    border-bottom: 0px solid transparent;
    border-radius: var(--menu-border-radius);
    font-weight: var(--main-menu-font-weight);
  }
}

#main-menu > li > a:hover {
  border-left: 1px solid var(--main-menu-hover-border-color);
  border-right: 1px solid var(--main-menu-hover-border-color);
  border-bottom: 1px solid var(--main-menu-hover-border-color);
  color: var(--main-menu-hover-color);
  background-color: var(--main-menu-hover-background-color);
}

@media screen and (max-width: 500px) {
  #main-menu > li > a:hover {
    border-left: 1px solid var(--main-menu-hover-border-color);
    border-right: 1px solid var(--main-menu-hover-border-color);
    border-bottom: 0px solid var(--main-menu-hover-border-color);
    border-radius: var(--menu-border-radius);
    color: var(--main-menu-hover-color);
    background-color: var(--main-menu-hover-background-color);
  }
}

#main-menu > li:hover ul {
  display: block;
  position: absolute;
  z-index: 2;
}

@media screen and (max-width: 500px) {
  #main-menu > li:hover ul {
    position: absolute;
    top: 0;
    left: var(--sub-menu-left-margin);
  }
}

.sub-menu > ul {
  display: none;
}

.sub-menu > ul > li > a {
  display: block;
  width: 9em;
  padding: 0.5em 0.75em 0.5em 0.5em;
  border: 1px solid transparent;
  font-family: var(--sub-menu-font-family);
  font-weight: var(--sub-menu-font-weight);
  color: var(--sub-menu-color);
  background-color: var(--sub-menu-background-color);
  text-decoration: none;
}

@media screen and (max-width: 500px) {
  .sub-menu > ul > li > a {
    width: 10em;
    padding: 0.6em 1em;
    border: 1px solid transparent;
    font-family: var(--sub-menu-font-family);
    font-weight: var(--sub-menu-font-weight);
    color: var(--sub-menu-color);
    background-color: var(--sub-menu-background-color);
  }
}

.sub-menu > ul > li > a:hover {
  border: 1px solid var(--sub-menu-hover-border-color);
  border-radius: var(--menu-border-radius);
  color: var(--sub-menu-hover-color);
  background-color: var(--sub-menu-hover-background-color);
}

@media screen and (max-width: 500px) {
  .sub-menu > ul > li > a:hover {
    color: var(--sub-menu-hover-color);
  }
}
