.text-lg {
  font-size: 2.5em;
}

.text-med-lg {
  font-size: 2em;
}

.text-med {
  font-size: 1.5em;
}

.text-med-sm {
  font-size: 1.2em;
}

.text-sm {
  font-size: 1em;
}

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */
html {
  color: #4d5259;
  font-size: 16px;
  line-height: 1.4;
  scroll-behavior: smooth;
}

html,
body {
  height: 100%;
  font-family: "Lato", Helvetica, sans-serif;
}

#page-container {
  background-color: #4d5259;
  height: 100%;
  width: 100%;
}

/*
 * Header
 */
header {
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
  -ms-transition: transform 0.2s;
  position: fixed;
  height: 50px;
  background-color: white;
  width: 100%;
  -webkit-transform: translate(0px, -85px);
          transform: translate(0px, -85px);
  border-bottom: 1px solid #dedede;
  z-index: 3;
}

header a img {
  margin: 5px 0 0 10px;
  width: 40px;
}

footer {
  color: white;
  background-color: black;
  margin: 0 auto;
  padding: 50px 0;
}

footer #footer-content {
  margin: 0 auto;
  max-width: 90%;
}

footer #footer-content p {
  font-size: 0.8em;
}

/* ==========================================================================
   Content
   ========================================================================== */
section {
  padding: 50px 0;
}

section .section-content {
  max-width: 90%;
  margin: 0 auto;
}

#content {
  display: block;
  position: relative;
  z-index: 1;
}

#top-section {
  height: 100vh;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1 0 auto;
          flex: 1 0 auto;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

#top-section #scroll-image {
  position: absolute;
  left: 0;
  width: 100%;
  min-height: 100%;
  background: url(../img/fast-light.jpg) center center no-repeat;
  background-size: cover;
}

#top-section #accelerate-container {
  top: 45vh;
  position: absolute;
  color: #fff;
}

#top-section #accelerate-container #accelerate-text h1 {
  margin: 0;
  display: inline-block;
  border-top: 1px solid white;
  border-bottom: 1px solid white;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

/* ==========================================================================
   second section
   ========================================================================== */
#second-section {
  color: #fff;
  background-color: #4d5259;
  text-align: center;
}

#second-section #second-content #second-text {
  margin: 0 auto;
  max-width: 500px;
}

#second-section #second-content #second-text h2 {
  margin: 0;
}

#second-section #second-content #visuals-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 250px;
  margin: auto;
  padding: 20px 0;
}

.visual {
  width: 200px;
  padding: 10px 0;
}

.visual #circle1 {
  background-color: #d47d1a;
}

.visual #circle2 {
  background-color: #acacac;
}

.visual #circle3 {
  background-color: #529c44;
}

.visual .circle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100px;
  width: 100px;
  margin: auto;
  border-radius: 50%;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -ms-transition: all 0.2s;
}

.visual .circle img {
  width: 70%;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -ms-transition: all 0.2s;
}

/* ==========================================================================
   Portfolio Section
   ========================================================================== */
#portfolio-section {
  text-align: center;
  margin: 0 auto;
  background-color: #5aa4e9;
  color: white;
  font-weight: bold;
}

#portfolio-section p {
  margin: 0;
}

#portfolio-section #portfolio-heading {
  margin: 50px 0 20px 0;
}

#portfolio-section .portfolio-subheading {
  font-weight: 500;
  margin: 0 0 25px 0;
}

#portfolio-section .portfolio-list {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 300px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding-bottom: 50px;
}

#portfolio-section .portfolio-list .portfolio-item {
  border: 4px solid white;
  border-radius: 10px;
  margin: 10px;
  padding: 10px;
  min-width: 250px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -ms-transition: all 0.2s;
  color: white;
  text-decoration: none;
  cursor: pointer;
}

#portfolio-section .portfolio-list .portfolio-item:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

/* ==========================================================================
   Partners Section
   ========================================================================== */
#partners-section {
  background-color: white;
  text-align: center;
}

#partners-section #partners-content > p {
  font-weight: bold;
}

#partners-section #partners-content #partners-links {
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  max-width: 350px;
}

#partners-section #partners-content #partners-links a {
  text-decoration: none;
  color: black;
}

#partners-section #partners-content #partners-links #weknowit, #partners-section #partners-content #partners-links #balsamic {
  background-color: black;
  color: #fff;
}

.partner-item {
  -webkit-box-shadow: 0 0 20px rgba(35, 31, 32, 0.1);
          box-shadow: 0 0 20px rgba(35, 31, 32, 0.1);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100px;
  width: 140px;
  margin: 10px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -ms-transition: all 0.2s;
  position: relative;
}

.partner-item:hover > img {
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
  opacity: 0.1;
}

.partner-item:hover > p {
  opacity: 1;
}

.partner-item img {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -ms-transition: all 0.2s;
  position: relative;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  max-width: 125px;
  max-height: 80px;
  opacity: 1;
}

.partner-item p {
  margin: 0 auto;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 90%;
  position: absolute;
  opacity: 0;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
  -ms-transition: opacity 0.2s;
}

/* ==========================================================================
   Contact Section
   ========================================================================== */
#contact-section {
  background-color: #4d5259;
  color: #fff;
  text-align: center;
}

#contact-section #contact-content {
  max-width: 90%;
  margin: 0 auto;
}

#contact-section #contact-content hr {
  text-align: center;
  margin: 0 auto;
  width: 20%;
}

#contact-section #contact-content a {
  color: #acacac;
}

@media screen and (min-width: 820px) {
  .text-lg {
    font-size: 5em;
  }
  .text-med-lg {
    font-size: 2.8em;
  }
  .text-med {
    font-size: 2em;
  }
  .text-med-sm {
    font-size: 1.25em;
  }
  .text-sm {
    font-size: 1em;
  }
  header {
    height: 85px;
  }
  header a img {
    margin: 15px 0 0 50px;
    width: 50px;
  }
  section {
    padding: 5%;
  }
  #second-section #second-content #visuals-container {
    width: 70%;
    -ms-flex-pack: distribute;
        justify-content: space-around;
  }
  #second-section #second-content #visuals-container .visual {
    margin: 0 10px;
  }
  #second-section #second-content #visuals-container .visual .circle {
    height: 130px;
    width: 130px;
  }
  #second-section #second-content #second-text {
    padding: 0 0 50px;
  }
  #portfolio-section .portfolio-subheading {
    margin: 0 0 30px 0;
    font-size: 1.5em;
  }
  #portfolio-section #portfolio-content .portfolio-list {
    -ms-flex-pack: distribute;
        justify-content: space-around;
    width: 700px;
  }
  #portfolio-section #portfolio-content .portfolio-list .portfolio-item {
    min-width: 280px;
  }
  #partners-section #partners-content #partners-links {
    max-width: 825px;
  }
  #partners-section #partners-content #partners-links .partner-item {
    width: 250px;
    height: 200px;
  }
  #partners-section #partners-content #partners-links .partner-item img {
    max-width: 200px;
    max-height: 100px;
  }
  #partners-section #partners-content #partners-links .partner-item p {
    width: 80%;
  }
  #contact-section #contact-content {
    max-width: 700px;
  }
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  /* IE10+ CSS */
  #top-section #scroll-image {
    -webkit-transform: none;
            transform: none;
    background: url(../img/fast-light.jpg) center center no-repeat fixed;
    background-size: cover;
  }
  #top-section #accelerate-container {
    position: relative;
  }
}

@supports (-ms-ime-align: auto) {
  #top-section #scroll-image {
    -webkit-transform: none;
            transform: none;
    background: url(../img/fast-light.jpg) center center no-repeat fixed;
    background-size: cover;
  }
  #top-section #accelerate-container {
    position: relative;
  }
}

/*
 * Remove text-shadow in selection highlight:
 */
::-moz-selection {
  background: #b3d4fc;
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers
 */
audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */
fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

/* ==========================================================================
   Browser Upgrade Prompt
   ========================================================================== */
.browserupgrade {
  margin: 0.2em 0;
  background: #ccc;
  color: #000;
  padding: 0.2em 0;
}

/* ==========================================================================
   Helper classes
   ========================================================================== */
/*
 * Hide visually and from screen readers
 */
.hidden {
  display: none !important;
}

.visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
  /* 1 */
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
  clip: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  width: auto;
  white-space: inherit;
}

.invisible {
  visibility: hidden;
}
/*# sourceMappingURL=main.css.map */