/* #region reset */
p, ol, ul, h1, h2, h3 {
  margin-top: 0;
  margin-bottom: 0;
}
dl, dt, dd {
  margin: 0;
}
/* #endregion */

/* #region css break points */
body:before {
  content: "xs";
  display: none; /* Prevent from displaying. */
}
@media (min-width: 768px) {
  body:before {
    content: "sm";
  }
}
@media (min-width: 992px) {
  body:before {
    content: "md";
  }
}
@media (min-width: 1200px) {
  body:before {
    content: "lg";
  }
}
/* #endregion */

/* #region grid changes */
.visible-xs-sm-block {
  display: none;
}

@media (max-width: 767px) {
  .container {
    padding-left: 23px;
    padding-right: 23px;
  }
}
@media screen and (min-width: 600px) and (max-width: 767px) {
  .row.row-xs-sm {
    margin-left: -15px;
    margin-right: -15px;
  }
  [class^=col-xs-sm] {
    padding-left: 15px;
    padding-right: 15px;
    float: left;
  }
  .col-xs-sm-6 {
    width: 50%;
  }
  .col-xs-sm-offset-3 {
    margin-left: 25%;
  }
  .visible-xs-sm-block {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .container {
    padding-left: 15px;
    padding-right: 15px;
  } 
  .row {
    margin-left: -15px;
    margin-right: -15px;
  }
  [class^=col-] {
    padding-left: 15px;
    padding-right: 15px;
  }
  .container {
    width: 684px;
  }
  .col-sm-5th {
    width: 20%;
  }
}
@media screen and (min-width: 992px) {
  .container {
    padding-left: 15px;
    padding-right: 15px;
  }
  .row {
    margin-left: -15px;
    margin-right: -15px;
  }
  [class^=col-] {
    padding-left: 15px;
    padding-right: 15px;
  }
  .container {
    width: 970px;
   }
}
@media screen and (min-width: 1200px) {
  .container {
    width: 1170px;
  }
}
/* #endregion */

/* #region Default Overrides */
a {
  text-decoration: none;
}
.noscroll {
  overflow: hidden;
}
ul {
  margin-left: 0px;
  padding-left: 0px;
}
cite {
  font-style: normal;
}
body,
html {
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  scroll-behavior:smooth
}
#page-container {
  position: relative;
}
body,
p {
  font-size: 16px;
  line-height:30px;
}
h1,
h2,
h3,
.from-wysiwyg strong {
  font-weight: 400;
}
/* #endregion */

/* #region Fonts */
@font-face {
  font-family: 'rubrik-medium';
  src: url(../fonts/rubrik-medium.woff) format('woff');
}
@font-face {
  font-family: 'rubrik-regular';
  src: url(../fonts/rubrik-regular.woff) format('woff');
}
@font-face {
  font-family: 'rubrik-semibold';
  src: url(../fonts/rubrik-semibold.woff) format('woff');
}
.rubrik-regular,
body,
button  {
  font-family: 'rubrik-regular', sans-serif;
}
.rubrik-medium {
  font-family: 'rubrik-medium', sans-serif;
}
.btn-primary,
.label,
.btn-show-more,
.rubrik-semibold,
.from-wysiwyg strong,
a.btn-arrow,
#featured-blog .margin-minus-small span,
#hero-link .margin-minus-small span,
#blog-carousel .margin-minus-small span {
  font-family: 'rubrik-semibold', sans-serif;
}
/* #endregion */

/* #region Carousel Override */
[id^="testimonial-carousel"] .carousel-inner {
  overflow: visible;
}
.carousel-fade .carousel-inner .item {
  opacity: 0;
  transition-property: opacity;
}
[id^=testimonial-carousel]  .carousel-inner > .next.left,
[id^=testimonial-carousel]  .carousel-inner > .prev.right {
  left: 0;
  right: 0;
  top: 0;
}
.carousel-fade .carousel-inner .active {
  opacity: 1;
}

.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  left: 0;
  opacity: 0;
  z-index: 1;
}

.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
  opacity: 1;
}

.carousel-fade .carousel-control {
  z-index: 2;
}

@media all and (transform-3d), (-webkit-transform-3d) {
    .carousel-fade .carousel-inner > .item.next,
    .carousel-fade .carousel-inner > .item.active.right {
      opacity: 0;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
    .carousel-fade .carousel-inner > .item.prev,
    .carousel-fade .carousel-inner > .item.active.left {
      opacity: 0;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
    .carousel-fade .carousel-inner > .item.next.left,
    .carousel-fade .carousel-inner > .item.prev.right,
    .carousel-fade .carousel-inner > .item.active {
      opacity: 1;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
}
/* #endregion */

/* #region Icons */

@font-face {
  font-family: 'theme_icons';
  src: url('../fonts/theme_icons.woff?g62kqv') format('woff');
  font-weight: normal;
  font-style: normal;
}
.btn-primary:after,
.btn-arrow:after,
.btn-show-more:after,
.error400 .col-sm-10 a:nth-child(3):before,
[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'theme_icons' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-arrow-down:before {
  content: "\e900";
}
.icon-arrow-left:before {
  content: "\e901";
}
.btn-primary:after,
.btn-arrow:after,
.error400 .col-sm-10 a:nth-child(3):before,
.icon-arrow-right:before {
  content: "\e902";
}
.icon-chevron-down:before,
.bs-select:after {
  content: "\e903";
}
.icon-cross-open:before {
  content: "\e904";
}
.btn-show-more.cross-open:after {
  content: "\e904";
}
.btn-show-more:after,
.icon-cross:before {
  content: "\e905";
}
.icon-email:before,
#locations div.col-sm-7 > :nth-child(3):before {
  content: "\e906";
}
.icon-hamburger-open:before {
  content: "\e909";
}
.icon-hamburger-close:before {
  content: "\e90a";
}
.icon-phone:before,
#locations div.col-sm-7 > p:nth-child(4):before {
  content: "\e90b";
}
#locations div.col-sm-7 > p:nth-child(2):before,
.icon-speech-bubble:before {
  content: "\e90f";
}
/* #endregion */

/* #region Styles */
.list-unstyled {
  list-style: none;
}
.label {
  padding: 5px 12px;
  border: 1px solid #CAD1D8;
  border-radius: 15px;
}
.border-radius1,
blockquote {
  border-radius: 4px;
}
.border-radius2 {
  border-radius: 4px 4px 0px 0px;
}
.border-bottom1 {
  border-bottom: 4px solid #34D9C3;
}
.border-bottom2 {
  border-bottom: 2px solid #65788E;
}
.white-circle,
.box-shadow,
blockquote  {
  box-shadow: 0 0 40px 0 rgba(29,41,53,0.24);
}
.border-top2-xs {
  border-top: 2px solid #65788E;
}
.breaker {
  border-top: 2px solid #65788E;
  margin-bottom: 30px;
}
.thanks-message {
  border-bottom: 2px solid #65788E;
  padding-top: 20px;
  padding-bottom: 40px;
}

#banner .icon-arrow-down {
  cursor: pointer;
}
[id^=tabbed-carousel] .right.control,
[id^=tabbed-carousel] .left.control,
[id^="blog-carousel"] .right.control,
[id^="blog-carousel"] .left.control,
.white-circle {
  background: white;
  padding: 12px 14px;
  border-radius: 100%;
  display: inline-block;
  width: 50px;
  height: 50px;
}
[id^=blog-carousel] .col-sm-12 {
  z-index: 10;
}
[id^=blog-carousel] .carousel-inner {
  z-index: 1;
  overflow: visible;
}
ul.main-nav li,
.inline-block,
.btn-arrow,
.btn-show-more,
cite  {
  display: inline-block;
}
.block {
  display: block;
}
@media (max-width: 767px) {
  .inline-block-xs {
    display: inline-block;
  }
  .block-xs {
    display: block;
  }
  .border-bottom2-xs {
    border-bottom: 1px solid #65788E;
  }
}
@media (min-width: 768px) {
  .block-sm {
    display: block;
  }
  .border-top2-sm {
    border-top: 2px solid #65788E;
  }
  .border-bottom2-sm {
    border-bottom: 2px solid #65788E;
  }
  .inline-block-sm {
    display: inline-block;
  }
  .line-after:after {
    margin-left: 15px;
    top: 40px;
  }
  .box-shadow-sm {
    box-shadow: 1px 2px 40px rgba(42, 61, 130, 0.1);
  }
}
@media (min-width: 992px) {
  .block-md {
    display: block;
  }
  .btn-show-more.hidden-md {
    display: none;
  }
  .inline-block-md,
  #team-index .card span a:nth-child(2) {
    display: inline-block;
  }
}
@media (min-width: 1200px) {
  .inline-block-lg {
    display: inline-block;
  }
}
@media (max-width: 767px) {
  .pagination .prev.white-circle,
  .pagination .next.white-circle {
    box-shadow: none;
    background: transparent;
  }
}
/* #endregion */

/* #region Heights, Widths */
.full-width,
.from-wysiwyg img {
  width: 100%;
}
.from-wysiwyg img {
  height: auto;
}
.width100 {
  width: 100px;
}
.max-width100 {
  max-width: 100px;
}
.width50 {
  width: 50px;
}
.width-average {
  width: 270px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  [id^=text-with-carousel] p {
    max-width: 450px;
  }
  [id^=text-with-carousel] p,
  [id^=carousel-logos-5] .carousel-inner,
  [id^=icon-columns] .padding-card  {
    margin-left: auto;
    margin-right: auto;
  }
  [id^=icon-columns] .padding-card {
    max-width: 274px;
  }
  [id^=carousel-logos-5] .carousel-inner {
    max-width: 234px;
  }
  .full-width-xs {
    width: 100%;
  }
}
@media screen and (min-width: 600px) {
  .expertise-card h3,
  #vacancy-index .card h3 {
    min-height: 70px;
  }
  .expertise-card p {
    min-height: 270px;
  }

  .service-card p {
    min-height: 210px;
  }
}
@media (min-width: 768px) {
  .expertise-card h3 {
    min-height: 70px;
  }
  #vacancy-index .card h3 {
    min-height: auto;
  }
  .expertise-card p {
    min-height: 226px;
  }

  .service-card p {
    min-height: 180px;
  }
}
@media (min-width: 992px) {
  .logo-carousel .carousel-inner  {
    margin-left: auto;
    margin-right: auto;
  }
  .logo-carousel .carousel-inner {
    max-width: 660px;
  }
  .expertise-card p {
    min-height: 226px;
  }

  .service-card p {
    min-height: auto;
  }
}
@media (min-width: 1200px) {
  .logo-carousel .carousel-inner {
    max-width: 822px;
  }
  .view.vacancies .from-wysiwyg,
  .view.apprenticeships .from-wywisyg  {
    max-width: 761px;
  }
  .expertise-card p {
    min-height: 165px;
  }
  .expertise-card h3 {
    min-height: 90px;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .team-header img {
    width: 280px;
    max-width: 280px;
  }
}
/* #endregion */

/* #region Positioning */
.position-fixed {
   position: fixed;
}
.position-relative,
.btn-arrow,
.btn-show-more,
[id^=tabbed-carousel] .carousel-indicators {
  position: relative;
}
.position-absolute {
  position: absolute;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.float-right {
  float: right;
}
.float-left {
  float: left;
}
.z-index10 {
  z-index: 10;
}
.bottom {
  bottom: 0;
}
.center {
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .center-xs {
    margin-left: auto;
    margin-right: auto;
  }
  .text-center-xs {
    text-align: center;
  }
}
@media (min-width: 768px) {
   .text-center-sm {
     text-align: center;
   }
   .text-right-sm {
     text-align: right;
   }
   .center-sm {
    margin-left: auto;
    margin-right: auto;
  }
  .float-right-sm {
    float: right;
  }
  .float-left-sm {
    float: left;
  }
}
@media (min-width: 992px) {
  .text-left-md {
    text-align: left;
  }
  .text-center-md {
    text-align: center;
  }
  .center-md {
    margin-left: auto;
    margin-right: auto;
  }
  .float-left-md,
  .accreditations {
    float: left;
  }
  .float-right-md {
    float: right;
  }
  .text-right-md {
    text-align: right;
  }
}
@media (min-width: 1200px) {
  .float-left-lg {
    float: left;
  }
  .text-right-lg {
    text-align: right;
  }
}
/* #endregion */

/* #region Colors */
.color-white,
ul.main-nav li a,
ul.mobile-nav li a,
.btn-show-more,
#breadcrumbs-wrap  {
  color: #ffffff;
}
.blog .line-before:before,
[id^="featured-blog"] .block-xs.font-size-small span + span:before,
.precept-credit a {
  color: #B4BEC8;
}
.color1,
.number a,
#locations p:before ,
.btn-arrow,
.from-wysiwyg a,
.bs-select::after {
  color:#34D9C3;
}
.from-wysiwyg a:hover {
  text-decoration: underline;
}
.from-wysiwyg h2,
.color3,
.from-wysiwyg h3,
.from-wysiwyg strong {
  color: #252A5E;
}
.color4,
.has-label label,
cite,
ul.main-nav li a.selected,
.navbar a:hover,
footer a:hover,
#contact-header a:hover,
#contact-header a:hover span.color-white,
#locations a.color6:hover {
  color: #FF5500;
}
#contact-header a:hover i {
  color: #FF5500 !important;
}
footer a:hover:before {
  color: #FFF;
}

p,
.from-wysiwyg ul li,
#featured-blog .margin-minus-small,
#hero-link .margin-minus-small,
.color6,
.color-credit  {
  color: #65788E;
}
#breadcrumbs-wrap a {
  color: rgba(255,255,255,0.5);
}
.signup.error,
.error input,
.error textarea,
.error select {
  border: 1px solid red !important;
}
label.error {
  position: relative;
  font-size: 14px !important;
  color: red;
  top: -16px;
  left: -16px;
}
.error.form-group i {
  margin-top: 88px;
}
.signup.error {
  padding-top: 8px !important;
}

@media (max-width: 767px) {
  label.error {
    display: block;
    text-align: center;
  }
}

@media (min-width: 768px) {
  label.error {
    left: -16px;
  }
}
/* #endregion */

/* #region Backgrounds */
.bg-blue {
  background-image: url(../img/blue.svg), 
    linear-gradient(to bottom, #252A5E 0% ,#252A5E 100%);
}
@media (min-width: 768px) {
  .bg-white,
  .landing-page.white-paper #page-container {
    background-image: url(../img/background.svg);
    background-position: center;
  }
}

.bg-dark {
  background-image: url(../img/dark-pattern.svg);
  background-position: left top;
}
.bg-dark,
.bg-white,
.landing-page.white-paper #page-container,
.bg-blue {
  background-repeat: no-repeat;
  background-size: cover;
  transform: translate3d(0,0,0);

  -ms-transform: translate3d(0,0,0);
  -o-transform: translate3d(0,0,0);
  -moz-transform: translate3d(0,0,0);
}
.bg-color1,
blockquote,
.dropdown  {
  background: white;
}
ul.main-nav .dropdown  {
  background: none;
}
.bg-color-dark {
  background: #15172E;
}
.precept-credit {
  background: #0C0E1F;
}
@media (max-width: 991px) {
  .bg-dark {
    background-image: url(../img/dark-pattern.svg);
    background-position: right center;
    background-size: cover;
    position: relative;
  }
}
/* #endregion */

