body {
  font-family: Helvetica, 'Calibri', Arial, sans-serif;
  color: #111;
}

  body p {
    font-size: 1rem;
  }

h1, h2, h3, h4, h5, h6, h7, h8, h9 {
  font-family: "Oswald", 'Calibri', Helvetica, sans-serif;
}

a {
  color: #fdfdfd;
  text-decoration: none;
}

  a:hover {
    color: #1693A5;
  }

.clear {
  clear: both;
}

/* Mail-To-Link Behavior */
a.mailto-link:link {
  color: #ce6b07;
}

a.mailto-link:visited {
  color: #ce6b07;
}

a.mailto-link:hover {
  color: #1693A5;
}

/* Bold elements with this class name */
.bold {
  font-weight: bold;
}

/* Header Bar: social media links and main navigation menu */

#showLeft {
  display: none;
}

.container > header {
  width: 100%;
  margin: auto;
  padding: .8em 0;
  background: #111;
  color: #fdfdfd;
}

.header-bar {
  width: 80%;
  max-width: 1280px;
  margin: auto;
}

  .header-bar > button {
    border: none;
    background: #111;
    color: #fdfdfd;
    padding: 7px;
    cursor: pointer;
  }

a.social-media-link:not(:first-child) {
  margin-left: 1em;
}

a.social-media-link i {
  padding: 7px 0;
}

.header-bar-nav {
  float: right;
  font-size: 1rem;
  font-weight: bold;
  margin-top: 7px;
  text-transform: uppercase;
}

  .header-bar-nav a:not(:first-child) {
    margin-left: 1em;
  }

/* Logo */

.logo {
  width: 80%;
  margin: 1em auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.logo-quote p {
  font-family: 'Oswald', Helvetica, 'Calibri', Arial, sans-serif;
  font-weight: 300;
  font-size: 1rem;
  margin-left: 2em;
}

p.speaker, p.title-company {
  font-weight: 400;
  text-align: right;
  margin-left: 0;
}


/* Footer Code */

/* FOOTER CODE */

.back-to-top {
  width: 100%;
  padding: 7px 0;
  background: #1693A5;
  text-align: center;
}

  .back-to-top a:hover {
    color: #111;
  }

footer {
  width: 100%;
  padding: 1.5em 0;
  background-color: #111;
  color: #fdfdfd;
}

.footer-content-wrap {
  width: 80%;
  margin: auto;
}

  .footer-content-wrap div {
    display: inline-block;
    vertical-align: top;
  }

footer h3 {
  padding-bottom: 5px;
  border-bottom: 1px dotted #fff;
  font-size: 1.5em;
  margin-bottom: 10px;
}

.footer-contact {
  width: 23.5%;
}

  .footer-contact address {
    margin-bottom: 20px;
  }

  .footer-contact p:last-child {
    margin-top: 20px;
  }

a.footer-contact-link:link {
  color: #1693A5;
  text-decoration: none;
}

a.footer-contact-link:visited {
  color: #1693A5;
  text-decoration: none;
}

a.footer-contact-link:hover {
  color: #fdfdfd;
  text-decoration: none;
}

.footer-nav {
  width: 23.5%;
  margin: 0 3%;
}

.footer-links-right {
  margin-left: 1em;
}

.footer-nav p {
  margin-top: 20px;
}

  .footer-nav p:first-of-type {
    margin-top: 0;
  }

a.footer-nav-list:link {
  color: #1693A5;
  text-decoration: none;
  text-transform: uppercase;
}

a.footer-nav-list:visited {
  color: #1693A5;
}

a.footer-nav-list:hover {
  color: #fdfdfd;
}

.footer-twitter {
  width: 45%;
}


/* NIVO SLIDESHOW */
/* NIVO SLIDER START */

.nivoSlider {
  position: relative;
  background: url(images/loading.gif) no-repeat 50% 50%;
}

  .nivoSlider img {
    position: absolute;
    top: 0px;
    left: 0px;
    display: none;
  }

  .nivoSlider a {
    border: 0;
    display: block;
  }

.image_slideshow_home {
  width: 100%;
  margin: 0 auto;
}

/* END OF NIVO SLIDESHOW */

/* MAIN PAGE GRID SYSTEM */

.main-page-grid {
  width: 100%;
  height: auto;
  margin: 2em auto 4em auto;
}

.grid {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-justify-content: center;
  -ms-flex-pack: distribute;
  justify-content: center;
}

  .grid img {
    max-width: 250px;
    height: auto;
    margin-left: 15px;
    border: 5px solid #ce6b07;
  }

  .grid a:link {
    text-decoration: none;
  }

  .grid a:visited {
    text-decoration: none;
  }

  .grid a:hover img {
    opacity: .8;
  }


.page-content {
  margin: 2em auto;
}

.page-header {
  width: 70%;
  height: auto;
  margin: auto;
  margin-bottom: 1em;
  font-size: 2rem;
  border-bottom: 1px solid #1693A5;
}

.philosophy-text {
  width: 70%;
  margin: auto;
  margin-bottom: 2em;
}

.philosophy-text-container {
  margin-left: 2em;
}

.philosophy-text p:not(:first-child) {
  margin-top: 1em;
}

.philosophy-text p, .philosophy-text ul li {
  line-height: 140%;
}

.philosophy-text ul li {
  list-style-type: disc;
  margin-left: 3.5em;
}

.large-video {
  width: 70%;
  margin: auto;
}

  .large-video img {
    width: 100%;
    height: auto;
  }

/* END PHILOSOPHY PAGE CODE */

/* CLIENTS PAGE CODE */

.client-logos {
  width: 50%;
  margin: auto;
  margin-top: 25px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-justify-content: space-around;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

  .client-logos img {
    vertical-align: middle;
    margin: 10px;
    width: 150px;
    height: auto;
  }

  .scrolltoTop {
    padding: 2em;
    padding-right: 4em;
    padding-left: 4em;
  }

  .scrolltoTop:hover {
    cursor: pointer;
  }

/* END CLIENTS PAGE */

/* SERVICES PAGE */

.services-page-header {
  width: 70%;
  height: auto;
  margin: auto;
  font-size: 2rem;
  border-bottom: 1px solid #1693A5;
}

.services-text {
  width: 70%;
  margin: auto;
  margin-bottom: 4em;
}

  .services-text h3 {
    font-size: 1.5rem;
  }

.services-information {
  margin: 0 0 1em 2em;
}

  .services-information h3, .services-information p {
    display: inline;
  }

  .services-information p {
    padding-left: .5em;
    line-height: 140%;
  }

a.service-pages-link:link {
  color: #111;
}

a.service-pages-link:visited {
  color: #111;
}

a.service-pages-link:hover {
  color: #1693A5;
}


/* EXHIBITS PAGE CODE */

.exhibits-page-header {
  width: 70%;
  height: auto;
  margin: auto;
  font-size: 2rem;
  border-bottom: 1px solid #1693A5;
}

.page-sub-header {
  width: 70%;
  height: auto;
  margin: .3em auto 3em auto;
  font-size: 1.2rem;
  font-weight: 300;
}

.exhibits-text {
  width: 70%;
  margin: auto;
  margin-bottom: 4em;
}

  .exhibits-text h3 {
    font-size: 1.5rem;
  }

.exhibits-information {
  margin: 0 0 1em 2em;
  position: relative;
}

  .exhibits-information h3, .exhibits-information p {
    line-height: 140%;
  }

  .exhibits-information p {
    margin-top: 1em;
  }

.exhibits-images {
  width: 70%;
  margin: auto;
  margin-bottom: 4em;
  text-align: center;
}

/* IMAGING PAGE - SHARES A LOT OF THE EXHIBITS PAGE CODE RIGHT NOW */
.imagingbottom2-spacing {
  padding: 0 9px;
}

.drone-pic {
  position: absolute;
  top: -75px;
  right: 0;
}

.imaging-video {
  max-width: 560px;
  height: auto;
  margin: auto;
  margin-bottom: 3em;
}

.video-wrapper {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
}

  .video-wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }


/* DESIGN PAGE - Shares a lot of the same code as exhibits and imaging */

.design-information {
  margin: 0 0 0 2em;
  position: relative;
}

.design-text {
  width: 70%;
  margin: auto;
  margin-bottom: 2em;
}

.design-information h3, .design-information p {
  line-height: 140%;
}

.design-information p {
  margin-top: 1em;
}

.design-text h3 {
  font-size: 1.5rem;
}

.design-text ul {
  margin-top: 1em;
}

  .design-text ul li {
    list-style-type: disc;
    margin-left: 3.5em;
    font-family: "Oswald", 'Calibri', Helvetica, sans-serf;
    font-size: 1.3rem;
    line-height: 140%;
  }


.design-images {
  width: 70%;
  min-height: 800px;
  margin: auto;
  margin-bottom: 4em;
  position: relative;
}

.design-img1, .design-img2, .design-img3, .design-img4 {
  position: absolute;
}

.design-img1 {
  z-index: 5;
  left: 20%;
}

.design-img2 {
  z-index: 3;
  top: 20%;
  left: 55%;
}

.design-img3 {
  z-index: 4;
  top: 40%;
  left: 15%;
}

.design-img4 {
  z-index: 2;
  right: 5%;
  bottom: 0;
}

/* CONTACT PAGE */

.contact-text {
  width: 70%;
  margin: auto;
  margin-bottom: 4em;
}

  .contact-text h3 {
    font-size: 1.5rem;
    margin-top: 1em;
  }

.contact-information {
  margin: 0 0 1em 2em;
}

  .contact-information h3, .contact-information p {
    line-height: 140%;
  }

/* Crew Page */

.crew-information {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: auto;
  margin-bottom: 3%;
  width: 90%;
}

.crew-member {
  margin: 2em;
  padding: 1em;
  background-color: #1693A5;
  border-radius: 0.5em;
}

  .crew-member p {
    margin-top: 0.5em;
    margin-bottom: 0.5em;
    font-size: 1.5em;
    font-family: "Oswald", 'Calibri', Helvetica, sans-serif;
    color: white;
  }

    .crew-member p:first-of-type {
      font-size: 2em;
      font-weight: bold;
    }

  .crew-member span {
    height: auto;
    max-width: 646px;
    overflow: hidden;
  }

    .crew-member span img {
      height: auto;
      width: 100%;
    }


/* TABLET < 1024px */

@media screen and (max-width: 1024px) {

  .logo {
    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .grid {
    /*-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;*/
  }

    .grid img {
      width: 150px;
      height: auto;
    }

  /* Footer Tablet */

  footer {
    width: 100%;
    padding: 1.5em 0;
  }

  .footer-content-wrap {
    width: 80%;
    margin: auto;
  }

  .footer-contact {
    vertical-align: top;
    width: 40%;
    margin: auto;
    margin-top: 2em;
  }

    .footer-contact address {
      margin-bottom: 1.5em;
    }

    .footer-contact p:last-child {
      margin-top: 1.5em;
    }

  .footer-nav {
    display: inline-block;
    vertical-align: top;
    width: 40%;
    margin: auto;
    margin-top: 2em;
    margin-left: 5%;
  }


  .footer-twitter {
    width: 100%;
    margin: auto;
    margin-top: 4em;
  }

  /* CLIENTS PAGE CODE */

  .client-logos {
    width: 50%;
    margin: auto;
    margin-top: 25px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-justify-content: center;
    -ms-flex-pack: distribute;
    justify-content: center;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
  }

    .client-logos img {
      vertical-align: middle;
      max-width: 140px;
      height: auto;
    }

  /*Crew Page Tablet*/

  .crew-information {
    width: 90%;
  }

  .crew-member {
    margin: 1em;
    border-radius: 0.25em;
  }

    .crew-member p {
      font-size: 1em;
    }

      .crew-member p:first-of-type {
        font-size: 1.5em;
      }

  /* DESIGN PAGE TABLET */

  .design-images {
    width: 70%;
    min-height: 1100px;
    margin: auto;
    margin-bottom: 4em;
    position: relative;
  }

    .design-images img {
      max-width: 100%;
    }

  .design-img1 {
    top: 0;
    left: 0;
  }

  .design-img2 {
    top: 255px;
    left: 0;
  }

  .design-img3 {
    top: 465px;
    left: 0;
  }

  .design-img4 {
    top: 820px;
    left: 0;
  }
}

@media screen and (max-width: 800px) {

  #showLeft {
    display: inline-block;
  }

  .header-bar-nav {
    display: none;
  }

  .logo {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

    .logo img {
      margin-bottom: 1.5em;
    }

  .grid {
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }

    .grid img {
      width: 100%;
      height: auto;
    }
}

/* MOBILE < 640px */

@media screen and (max-width: 640px) {

  .nivoSlider {
    margin: 2em auto;
  }

  /* MAIN PAGE GRID SYSTEM */

  .main-page-grid {
    width: 100%;
    height: auto;
    margin: auto;
  }

  .grid img {
    width: 100%;
    height: auto;
    margin: auto;
  }

    .grid img:not(:first-child) {
      margin-top: 5px;
    }

  /* SMALL FOOTER CODE */

  footer {
    width: 100%;
    padding: 1.5em 0;
  }

  .footer-content-wrap {
    width: 80%;
    margin: auto;
  }


  footer h3 {
    padding-bottom: .5em;
    border-bottom: 1px dotted #fff;
    font-size: 1.5em;
    margin-bottom: 1em;
  }

  .footer-contact {
    width: 100%;
    margin: auto;
    margin-top: 2em;
  }

    .footer-contact address {
      font-family: Helvetica, sans-serif;
      margin-bottom: 1.5em;
    }

    .footer-contact p:last-child {
      margin-top: 1.5em;
    }

  .footer-nav {
    width: 100%;
    margin: auto;
    margin-top: 4em;
  }

    .footer-nav p {
      margin-top: 20px;
    }

      .footer-nav p:first-of-type {
        margin-top: 0;
      }

  .footer-twitter {
    width: 100%;
    margin: auto;
    margin-top: 4em;
  }


  /* PHILOSOPHY Page Code */

  .large-video {
    width: 100%;
    height: auto;
    margin: auto;
  }

  /* END PHILOSOPHY PAGE CODE */

  /* EXHIBITS */

  .exhibits-images img {
    max-width: 100%;
  }
}

@media screen and (max-width: 400px) {
  #random-logo {
    width: 100%;
  }

  /* EXHIBITS */

  /* DESIGN PAGE - Mobile */

  .design-images {
    min-height: 850px;
  }

  .design-img1 {
    top: 0;
    left: 0;
  }

  .design-img2 {
    top: 200px;
    left: 0;
  }

  .design-img3 {
    top: 420px;
    left: 0;
  }

  .design-img4 {
    top: 640px;
    left: 0;
  }

  /*Crew Mobile*/

  .crew-information {
    width: 100%;
    margin-bottom: 10%;
  }

  .crew-member {
    margin: 0.15em;
  }

  .crew-member p {
    margin-top: 0;
    margin-bottom: 0.25em;
  }

  .crew-member p:first-of-type {
    font-size: 1.15em;
  }
}
