:root {
  --company-blue: #020237;
}

body {
  color: #333;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

.body {
  aspect-ratio: auto;
  background-color: var(--company-blue);
  color: #fff;
  max-width: 100vw;
  font-family: Inconsolata, monospace;
  font-size: 1rem;
  line-height: 1rem;
  overflow: visible;
}

.about-section {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 80vw;
  margin-left: auto;
  margin-right: auto;
  padding-top: 25vh;
  padding-bottom: 25vh;
  display: flex;
}

.about-button {
  z-index: 2;
  color: var(--company-blue);
  text-align: center;
  background-color: #fff;
  border: .3vh solid #fff;
  border-radius: 1px;
  font-size: 5vh;
  line-height: 5vh;
  text-decoration: none;
}

.about-button:hover {
  background-color: var(--company-blue);
  color: #fff;
  border: .3vh solid #fff;
  border-radius: 1px;
}

.art-image {
  flex: 0 auto;
  order: 0;
  align-self: center;
  height: 20vh;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.menu-container {
  vertical-align: middle;
  flex-flow: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: center;
  width: 80vw;
  height: 10vh;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.main-section {
  width: 100vw;
}

.menu-button-container {
  flex: 0 auto;
  justify-content: center;
  align-self: center;
  align-items: center;
  height: 10vh;
  display: flex;
}

.menu-image {
  flex: 0 auto;
  align-self: center;
  max-width: none;
  height: 10vh;
}

.art-image-container {
  grid-column-gap: 3vw;
  grid-row-gap: 3vw;
  background-color: #fff;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  display: flex;
}

.main-heading {
  text-align: center;
  text-transform: uppercase;
  border-bottom: 5px solid #fff;
  width: 80vw;
  height: 90vh;
  margin: 0 auto;
  font-size: 20vh;
  line-height: 30vh;
}

.art-preview-section {
  background-color: #fff;
  width: 80vw;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 5vh;
}

.menu-button {
  border: .3vh solid var(--company-blue);
  text-align: center;
  text-transform: uppercase;
  background-color: #0000;
  align-self: center;
  padding: 1vh 1vw;
  font-size: 3vh;
  line-height: 3vh;
  text-decoration: none;
}

.menu-button:hover {
  border: .3vh solid #fff;
}

.menu-button.w--current {
  border: .2vh solid var(--company-blue);
  font-size: 3vh;
  line-height: 3vh;
}

.menu-button.w--current:hover {
  border-color: #fff;
}

.about-heading {
  text-align: center;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 10vh;
  line-height: 10vh;
}

.about-paragraph {
  text-align: justify;
  margin-bottom: 0;
  font-size: 2vh;
  line-height: 2vh;
}

.art-container {
  background-color: #fff;
  width: 80vw;
  margin-left: auto;
  margin-right: auto;
  padding-top: 5vh;
  padding-bottom: 5vh;
}

.art-heading {
  color: var(--company-blue);
  text-align: center;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 5vh;
  padding-bottom: 5vh;
  font-size: 10vh;
  line-height: 10vh;
}

.footer-seaction {
  vertical-align: baseline;
  flex-flow: row;
  justify-content: flex-end;
  align-items: center;
  width: 80vw;
  height: 10vh;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.footer-image {
  align-self: center;
  max-width: none;
  height: 10vh;
}

.footer-heading {
  text-transform: uppercase;
  align-self: center;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3vh;
  font-weight: 400;
  line-height: 3vh;
}

.art-preview-container {
  flex-flow: column;
  padding-top: 5vh;
  display: flex;
}

.art-preview-image-container {
  grid-column-gap: 2vw;
  grid-row-gap: 5vh;
  aspect-ratio: auto;
  flex-flow: wrap;
  justify-content: center;
  align-items: flex-start;
  height: 35vh;
  display: flex;
  overflow: hidden;
}

.art-preview-image {
  max-width: none;
  height: 30vh;
  overflow: visible;
}

.art-preview-button {
  color: var(--company-blue);
  text-align: center;
  text-transform: uppercase;
  background-color: #0000;
  border: .3vh solid #fff;
  margin: 0 auto 2.5vh;
  font-size: 10vh;
  font-weight: 700;
  line-height: 10vh;
}

.art-preview-button:hover {
  box-sizing: content-box;
  border: .3vh solid var(--company-blue);
  border-radius: 0;
}

@media screen and (max-width: 479px) {
  .about-button {
    font-size: 5vw;
    line-height: 5vw;
  }

  .art-image {
    height: 30vw;
  }

  .menu-container, .menu-image {
    height: 10vw;
  }

  .main-heading {
    height: auto;
    font-size: 20vw;
    line-height: 30vw;
  }

  .menu-button, .menu-button.w--current {
    font-size: 3vw;
    line-height: 3vw;
  }

  .about-heading {
    font-size: 10vw;
    line-height: 10vw;
  }

  .about-paragraph {
    font-size: 2vw;
    line-height: 2vw;
  }

  .art-heading {
    padding-top: 5vw;
    padding-bottom: 5vw;
    font-size: 10vw;
    line-height: 10vw;
  }

  .footer-seaction {
    height: auto;
  }

  .footer-image {
    height: 10vw;
  }

  .footer-heading {
    font-size: 3vw;
    line-height: 3vw;
  }

  .art-preview-container {
    padding-top: 5vw;
  }

  .art-preview-image-container {
    grid-row-gap: 5vw;
    height: 35vw;
  }

  .art-preview-image {
    height: 30vw;
  }

  .art-preview-button {
    margin-bottom: 2.5vw;
    font-size: 10vw;
    line-height: 10vw;
  }
}


