@import url('https://fonts.googleapis.com/css?family=Open+Sans:400,700');

/*

Navy: #00007d
Grey: #f4f4f4
Black: #212121
  
*/

/* === Basic === */

.brain {
	display: inline-block;
	max-width: 125px; width: 100%;
}

body, h1 {
  font-family: "Open Sans", sans-serif;
}

  @media screen and (max-width: 39.9375em) {
    h1 {
      font-size: 2rem;
    }
  }

h2 {
  color: #00007d;
  font-family: "Open Sans", sans-serif;
  font-weight: bold;
  margin-bottom: 50px;
}

  h2::after {
    border-bottom: 5px solid #00007d;
    content: '';
    display: block;
    margin-top: 5px;
    width: 40%;
  }
  
  @media screen and (max-width: 39.9375em) {
    h2 {
      font-size: 1.6rem;
    }
  }
  
h3 {
  color: #00007d;
  font-family: "Open Sans", sans-serif;
  font-weight: bold;
  margin: 20px 0px;
  text-align: center;
}

h4 {
  color: #00007d;
  font-family: "Open Sans", sans-serif;
  font-weight: bold;
  margin-top: 30px;
}

  h4:first-of-type {
    margin-top: 0px;
  }
  
p {
	font-size: 18px;
}

a[href^=tel] {
  text-decoration:inherit;
  color: inherit;
}

.bold {
  color: #fff;
  font-weight: bold;
}

section {
  padding: 50px 0px;
}

  .grey-background {
    background: #f4f4f4;
  }
  
  .no-padding {
    padding: 0px;
  }
  
  .no-padding-top {
    padding-top: 0px;
  }
  
    @media screen and (max-width: 39.9375em) {
      .no-padding-top-small {
        padding-top: 0px;
      }
      
      .no-padding-bottom-small {
        padding-bottom: 0px;
      }
      
      .no-padding-small {
        padding: 0px;
      }
    }
  
  .small-margin-top {
    margin-top: 25px;
  }
  
  .small-margin-bottom {
    margin-bottom: 25px;
  }

.grid-container {
  max-width: 62.5rem;
}

.relative {
  position: relative;
}

  .relative .grid-container {
    padding: 0;
  }

.button {
  background: transparent;
  border: 3px solid #00007d;
  border-radius: 10px;
  color: #00007d;
  font-weight: bold;
  margin-top: 50px;
  padding: 15px;
  text-transform: uppercase;
}

  .button:hover, .button:active, .button:focus {
    background: #00007d;
    color: #fff;
  }
  
  .button-margin-fix {
    margin: 50px;
  }
  
.image-overlap, .image-overlap-switch {
  background-position: center;
  background-size: cover;
  height: 400px;
  margin-top: -200px;
  overflow: hidden;
  position: relative;
    top: 200px;
}

.image-overlap-static {
  background-position: center;
  background-size: cover;
  height: 400px;
  margin-bottom: 30px;
  overflow: hidden;
}

  @media screen and (max-width: 39.9375em) {
    .image-overlap-switch {
      margin-top: 0px;
      margin-bottom: 30px;
      position: static;
    }
  }

  .margin-fix {
    margin-top: 200px;
  }

.bar {
  background: #f4f4f4;
  margin-top: 50px;
  width: 100%;
}

  .bar:before{
    content: "";
    display: block;
    padding-top: 4px;
  }

.circle {
  background: #00007d;
  border-radius: 50px;
  height: 50px;
  margin: auto;
  width: 50px;
}

.rectangle {
  background: #00007d;
  display: none;
  height: 46px;
  position: absolute;
  width: 100%;
}

.triangle {
	border-left: 7px solid transparent;
	border-right: 7px solid transparent;
	border-top: 11px solid #00007d;
  display: inline-block;
	height: 0;
  margin-left: 10px;
  transition: 0.5s ease;
  width: 0;
}

  .triangle:hover {
    cursor: pointer;
  }

  .rotate {
    transition: 0.5s ease;
    transform: rotate(180deg);
      -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
  }
  
.wbenc {
	max-width: 130px;
}

.wbenc, .oracle {
	margin: 5px 10px;
}
  
/* === Header === */

nav img {
  width: 200px;
}

nav ul li {
  margin-left: 10px;
}

.banner {
  background-position: center center;
  background-size: cover;
}

  .banner-who-we-are {
    background-image: url("../images/team.jpg");
  }
  
  .banner-what-we-do {
    background-image: url("../images/server.jpg");
  }
  
  .banner-contact {
    background-image: url("../images/office.jpg");
  }
  
  .banner-careers {
    background-image: url("../images/careers.jpg");
  }
  
  .banner-doing-business {
    background-image: url("../images/partners.jpg");
  }
  
  .banner-community-involvement {
    background-image: url("../images/community.jpg");
  }

  .banner h1 {
    color: #fff;
    font-weight: bold;
    padding: 150px 0px;
  }
  
    @media screen and (max-width: 39.9375em) {
      .banner h1 {
        padding: 100px 0px;
      }
    }
  
nav .button {
  border: 3px solid transparent;
  margin-top: 0px;
}

  nav .button:hover,
  nav .button:active,
  nav .button:focus {
    background: #00007d;
    color: #fff;
  }
  
    nav .button:hover .triangle,
    nav .button:active .triangle,
    nav .button:focus .triangle {
      border-top: 11px solid #fff;
    }

.secondary-nav {
  background: #00007d;
  position: absolute;
  width: 100%;
  z-index: 1;
}

  .secondary-nav li a {
    color: #fff;
    font-family: "Open Sans", sans-serif;
    font-weight: bold;
    padding: 15px;
    text-transform: uppercase;
  }
  
  @media screen and (max-width: 39.9375em) {
    .secondary-nav {
      padding: 20px 0px;
    }
  }

/* === Home === */
  
.icon {
  text-align: center;
}

  .icon img {
    height: 70px;
      width: auto;
  }

/* === Who We Are === */

.job-description {
  background: rgba(0,0,125,0.75);
  color: #fff;
  height: 100%;
  overflow-y: auto;
  padding: 20px;
  transform: translateY(78%);
  transition: 0.5s ease;
}
  
  .image-overlap-static:hover .job-description,
  .image-overlap:hover .job-description,
  .image-overlap-switch:hover .job-description {
    transform: translateY(0%);
    transition: 0.5s ease;
  }
  
  .job-description-mobile {
    background: rgba(0,0,125,0.75);
    color: #fff;
    height: 100%;
    overflow-y: auto;
    padding: 20px;
    transition: 0.5s ease;
  }
  
/* === What We Do === */
  
.tab {
  background: #00007d;
  padding: 10px;
  transition: 0.2s ease;
}

  .tab:hover {
    background: #fff;
    cursor: pointer;
  }
  
    .tab:hover h4 {
      color: #00007d;
    }

  .tab h4 {
    color: #fff;
    font-size: 1.4rem;
    margin: 0;
  }
  
.tab-content {
  background: #fff;
  display: none;
  padding: 25px 0px;
}

  .tab-content.current {
    display: flex;
  }
  
  .tab-content p {
    margin: 10px;
  }
  
.current {
  background: #fff;
}

  .current h4 {
    color: #00007d;
  }
  
/* === Contact === */
  
.contact {
  margin: 100px 0px 50px 0px;
}

.contact-image {
  position: relative;
}
  
.contact-card {
  background: #00007d;
  color: #fff;
  margin-top: -70px;
  padding: 30px;
  position: absolute;
}

  .contact-card p {
    margin: 0;
    padding: 0;
  }
  
  .contact-card-right {
    right: 0;
  }
  
  @media screen and (max-width: 39.9375em) {
    .contact-card {
      background: #fff;
      color: #00007d;
      margin-top: 0px;
      padding: 30px 0px;
      position: static;
      text-align: center;
    }
    
    .contact {
      margin: 0px;
    }
    
    .contact .bold {
      color: #00007d;
    }
  }

/* === Doing Business with IngenuitE === */
  
.partnerships strong, .service .bold {
  color: #00007d;
}

.service {
  border-right: 5px solid #00007d;
  padding-right: 30px;
}

  .service-description {
    padding-left: 30px;
  }
  
/* === Careers === */

.career-container {
  margin-top: -125px;
  position: relative;
  top: 125px;
}

.careers {
  background: #fff;
  padding: 25px;
  text-align: center;
}

  .careers p {
    margin: 25px 0px;
  }

  .careers .button {
    margin-top: 0px;
  }
  
  @media screen and (max-width: 39.9375em) {
    .careers {
      padding: 15px 25px;
    }
  }

.join strong {
  color: #00007d;
}

.join .margin-fix {
  margin-top: 125px;
}

/* === Footer === */
  
footer {
  background: #00007d;
  padding: 30px 0px;
}

  footer p {
    color: #fff;
    margin: 0px;
    padding: 0px;
  }

  @media screen and (max-width: 39.9375em) {
    footer .cell {
      text-align: center;
    }
    
    footer .cell:first-of-type {
      margin-bottom: 20px;
    }
  }