/* GenMix – Generic reusable mixins */
/* ComMix – Lightweight compatibility mixins */
/* mixins */
/* css */
body {
  line-height: 1.6;
}
h1,
h2,
h3,
h4 {
  line-height: 1.4;
}
/* modules */
.header-box {
  border-bottom: 2px solid #000000;
  background: #ffffff;
  background: rgba(255, 255, 255, 0.85);
  position: relative;
  z-index: 10;
}
.header-box .brand {
  padding-top: 10px;
  padding-bottom: 10px;
  text-align: center;
}
.header-box .brand .logo {
  height: 30px;
  width: auto;
}
.header-box .nav {
  text-align: center;
}
.header-box .nav a {
  margin-bottom: 5px;
}
@media screen and (min-width: 300px) {
  .header-box .brand {
    text-align: left;
  }
  .header-box .brand .logo {
    height: 60px;
  }
  .header-box .nav {
    text-align: right;
    padding-top: 20px;
  }
}
.main-box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100%;
  background-image: url(../img/open/graph-overlay.png),
    url(../img/open/bg-texture.png);
  background-position: center center, center 0;
  background-repeat: no-repeat, repeat;
  background-size: cover, auto;
}
.lt-ie9 .main-box {
  background: url(../img/open/bg-texture.png) repeat;
}
/*@-webkit-keyframes animated-background {
	0% { background-position: 0 0; }
	100% { background-position: -353px -353px; }
}

@keyframes animated-background {
	0% { background-position: 0 0; }
	100% { background-position: -353px -353px; }
}*/
.content-box {
  background: #ffffff;
  background: rgba(255, 255, 255, 0.85);
  margin-top: 110px;
  margin-bottom: 50px;
  border: 1px solid #989898;
  padding: 10px 30px 20px 30px;
}
.content-box p,
.content-box label {
  font-weight: 400;
  margin: 15px 0 5px;
}
.content-box .form-control,
.content-box .btn {
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) {
  .content-box {
    margin-top: 200px;
  }
}
@media screen and (min-width: 992px) {
  .content-box {
    padding: 10px 55px 20px 55px;
  }
}
.content-heading {
  border-bottom: 1px solid #cacaca;
  padding-bottom: 20px;
  text-align: center;
}
.content-heading h1 {
  font-size: 1.5em;
}
.content-heading p {
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  .content-heading h1 {
    font-size: 3em;
  }
  .content-heading p {
    font-size: 1.4em;
  }
}
.content-form {
  border-bottom: 1px solid #cacaca;
  padding: 10px 0 0;
}
.content-form .form-control {
  border: 2px solid #000000;
}
.content-form .input-lg {
  padding: 11px 16px;
  height: 48px;
}
.content-links {
  padding: 10px 0;
}
.content-links .btn-block {
  white-space: normal;
}
/* biz */
body.biz-wrap {
  background: url(../img/business/biz-tile.png) center center;
}
.biz-hero {
  background-color: #969696;
  background-image: url(../img/business/hero-triangles.png),
    url(../img/business/hero-tile.png);
  background-repeat: no-repeat, repeat;
  background-position: center -40px;
  padding-bottom: 40px;
}
.biz-hero h1 {
  text-align: center;
  font-size: 2em;
  color: #ffffff;
  line-height: 1.5;
  margin: 30px auto;
}
@media screen and (min-width: 768px) {
  .biz-hero h1 {
    margin-top: 120px;
    font-size: 4em;
  }
}
@media screen and (min-width: 992px) {
  .biz-hero h1 {
    width: 90%;
  }
}
@media screen and (min-width: 1200px) {
  .biz-hero h1 {
    width: 70%;
  }
}
@media screen and (min-width: 768px) {
  .biz-hero {
    min-height: 440px;
  }
}
.biz-callbox {
  border: 2px solid #000000;
  padding-top: 15px;
  padding-bottom: 15px;
  margin-top: -40px;
  background: #ffffff;
}
.biz-callbox .text {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .biz-callbox .text {
    padding-top: 14px;
  }
}
@media screen and (min-width: 992px) {
  .biz-callbox .text {
    font-size: 1.2em;
  }
}
@media screen and (min-width: 1200px) {
  .biz-callbox .text {
    padding-top: 10px;
    font-size: 1.4em;
  }
}
.example-box {
  padding-top: 30px;
  padding-bottom: 30px;
  border-bottom: 2px solid #000000;
  font-size: 1.3em;
}
.example-box .text {
  padding-top: 10px;
  padding-bottom: 10px;
}
.example-box h2 {
  margin-top: 0px;
  margin-bottom: 10px;
  padding-top: 0px;
  padding-bottom: 0px;
}

.example-box .buttonarea {
  background: url(../img/business/connected-data.png) center center no-repeat;
  background-size: contain;
  text-align: center;
  padding-top: 80px;
  padding-bottom: 80px;
}
.example-box .buttonarea2 {
  background: url(../img/business/map.png) center center no-repeat;
  background-size: contain;
  text-align: center;
  padding-top: 150px;
  padding-bottom: 150px;
}
@media screen and (min-width: 768px) {
  .example-box .buttonarea {
    margin-top: 40px;
  }
}
@media screen and (min-width: 992px) {
  .example-box .buttonarea {
    margin-top: 10px;
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
@media screen and (min-width: 1200px) {
  .example-box .buttonarea {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
.why-box {
  /* real: 982px */
  border-bottom: 2px solid #000000;
  padding-top: 30px;
  padding-bottom: 30px;
}
@media screen and (min-width: 768px) {
  .why-box h2 {
    margin-top: 0;
  }
  .why-box .image {
    margin-top: 150px;
  }
}
@media screen and (min-width: 992px) {
  .why-box .image {
    margin-top: 45px;
  }
}
@media screen and (min-width: 1200px) {
  .why-box .image {
    margin-top: 0;
  }
}
.biz-services {
  border-bottom: 2px solid #000000;
  padding-top: 35px;
  padding-bottom: 20px;
}
.biz-services .services-list {
  margin-bottom: 40px;
}
.biz-services .services-list .heading {
  padding-right: 10px;
}
.biz-services .services-list .btn {
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .biz-services .services-list .heading {
    display: block;
  }
  .biz-services .services-list .btn {
    font-size: 14px;
    padding: 6px 3px;
  }
}
@media screen and (min-width: 768px) {
  .biz-services .services-list .heading {
    font-size: 1em;
  }
}
@media screen and (min-width: 992px) {
  .biz-services .services-list .heading {
    font-size: 2em;
    position: relative;
    top: 2px;
  }
}
.biz-services .services-row {
  padding-top: 15px;
  padding-bottom: 15px;
}
.biz-services .services-row h2 {
  font-size: 1.4em;
  margin-left: 60px;
  border-left: 2px solid transparent;
  padding-left: 30px;
}
.biz-services .services-row#research h2 {
  border-color: #fda428;
}
.biz-services .services-row#marketing h2 {
  border-color: #9061bb;
}
.biz-services .services-row#hr h2 {
  border-color: #1873b2;
}
.biz-services .services-row h2,
.biz-services .services-row .media {
  margin-bottom: 20px;
}
.biz-services .services-row .media img {
  width: 50px;
}
.biz-services .services-row .media-body {
  border-left: 2px solid #000000;
  padding-left: 30px;
}
.biz-services .services-row .media-body h3 {
  font-size: 1.2em;
  margin-top: 0;
}
.biz-services .services-row .media-body p {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .biz-services .services-row h2 {
    margin-left: 110px;
    font-size: 2.1em;
  }
  .biz-services .services-row h2,
  .biz-services .services-row .media {
    margin-bottom: 45px;
  }
  .biz-services .services-row .media img {
    width: 100px;
  }
  .biz-services .services-row .media-body h3 {
    font-size: 1.7em;
  }
}
@media screen and (min-width: 992px) {
  .biz-services .services-row h2 {
    width: 60%;
  }
}
.partner-box {
  border-bottom: 2px solid #000000;
  padding-top: 20px;
  padding-bottom: 50px;
  margin-bottom: 20px;
}
.partner-box h2 {
  margin-bottom: 20px;
  text-align: center;
}

.partner-box .logos {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
  align-content: center;
}

.partner-box .logos span {
  display: flex;
  text-align: center;
  margin-bottom: 50px;
}

.partner-box .logos img {
  float: center;
  object-fit: contain;
  max-width:90vw;
}

.followscicurve {
  float: right;
}

footer {
  margin-bottom: 40px;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}
