/* Variables */
.header {
  width: 100%;
  height: 60px;
  position: fixed;
  top: 0;
  left: 0;
  border-bottom: 1px solid #398edb;
  background-color: #fff;
  z-index: 200;
  transition: all 0.5s ease-in-out;
  -ms-box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3);
  -o-box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3);
  box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3);
  background-color: #fff; /* Fallback Color */ /* Saf4+, Chrome */ /* Chrome 10+, Saf5.1+, iOS 5+ */ /* FF3.6 */ /* IE10 */ /* Opera 11.10+ */
  background-image: linear-gradient(to bottom, #fff 30%, #f5f5f5 100%);
  /*filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,StartColorStr='$fromColor', EndColorStr='$toColor');*/
}
@media screen and (min-width: 992px) {
  .header {
    height: 80px;
  }
}

@media screen and (min-width: 992px) {
  .header-container {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}

.logo-link {
  display: block;
  width: 75px;
  padding: 10px 0;
}
@media screen and (min-width: 992px) {
  .logo-link {
    width: 110px;
  }
}
.logo-link img {
  display: block;
  width: 100%;
}

.nav-icon {
  display: block;
  width: 40px;
  height: 26px;
  position: absolute;
  top: 50%;
  right: 20px;
  background-color: transparent;
  transform: translateY(-50%);
  transition: all 0.3s ease-in-out;
  cursor: pointer;
}
@media screen and (min-width: 992px) {
  .nav-icon {
    display: none;
  }
}
.nav-icon span {
  display: block;
  width: 100%;
  height: 5px;
  position: absolute;
  left: 0;
  background-color: #398edb;
  border-radius: 2px;
  transform: rotate(0deg);
  transition: all 0.25s ease-in-out;
}
.nav-icon span:nth-child(1) {
  top: 0;
}
.nav-icon span:nth-child(2), .nav-icon span:nth-child(3) {
  top: 10px;
}
.nav-icon span:nth-child(4) {
  top: 20px;
}
.nav-icon.active span:nth-child(1), .nav-icon.active span:nth-child(4) {
  width: 0%;
  top: 18px;
  left: 50%;
}
.nav-icon.active span:nth-child(2) {
  transform: rotate(45deg);
}
.nav-icon.active span:nth-child(3) {
  transform: rotate(-45deg);
}

.main-nav {
  /*DISPLAY, VISIBILITY AND OVERFLOW PROPERTIES*/
  overflow: auto;
  /*BOX MODEL PROPERTIES*/
  width: 320px;
  height: 100%;
  padding: 0;
  /*POSITIONING PROPERTIES*/
  position: fixed;
  top: 60px;
  right: -100%;
  bottom: 0;
  /*FONT PROPERTIES*/
  background-color: #fff; /* Fallback Color */ /* Saf4+, Chrome */ /* Chrome 10+, Saf5.1+, iOS 5+ */ /* FF3.6 */ /* IE10 */ /* Opera 11.10+ */
  background-image: linear-gradient(to top, #fff 30%, #f5f5f5 100%);
  /*filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,StartColorStr='$fromColor', EndColorStr='$toColor');*/
  -ms-box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3);
  -o-box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3);
  box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3);
  transition: all 0.3s ease-in-out;
  /*MEDIA QUERIES*/
  /*SUB CLASSES AND EFFECTS*/
}
@media screen and (min-width: 992px) {
  .main-nav {
    overflow: visible;
    width: auto;
    position: static;
    background-color: transparent;
    box-shadow: none;
  }
}
.main-nav.active {
  right: 0;
  transition: all 0.3s ease-in-out;
}
.main-nav a {
  display: block;
  border-bottom: 1px solid #398edb;
  padding: 12px 20px;
  position: relative;
  font-family: "Hero", Arial, sans-serif;
  font-weight: bold;
  font-size: 1.4rem;
  text-align: right;
  text-transform: uppercase;
  line-height: 22px;
  color: #444;
}
@media screen and (min-width: 992px) {
  .main-nav a {
    display: inline-block;
    padding: 0 20px 8px;
    border-bottom: none;
  }
}
.main-nav a::before, .main-nav a::after {
  content: "";
  opacity: 0;
  width: 50%;
  height: 2px;
  position: absolute;
  bottom: 0;
  background-color: #398edb;
  transition: all 0.5s ease-in-out;
}
.main-nav a::before {
  left: 0;
  transform: translateX(-100%);
}
.main-nav a::after {
  right: 0;
  transform: translateX(100%);
}
.main-nav a:hover, .main-nav a.active {
  color: #005587;
  transition: all 0.5s ease-in-out;
}
.main-nav a:hover::before, .main-nav a:hover::after, .main-nav a.active::before, .main-nav a.active::after {
  opacity: 1;
  transform: none;
}