/* Colours */
/* Fluid heading sizes - set your min/max sizes and you're done! */
/* Some device sizes to use with min-width */
/* adjusted breakpoints for above */
/* 100% widths look better than "Snapping" IMO */
/* Utility */
/* Additional Spacers -- don't think you'll need more than 7, but if you do -- maybe just use a custom class  :)  */
.banner {
  background-color: #343131;
  position: relative;
  padding: 140px 0 80px 0; }
  @media (min-width: 769px) {
    .banner {
      padding: 140px 0 120px 0; } }
  @media (min-width: 1025px) {
    .banner {
      max-height: 540px; } }
  @media (min-width: 1141px) {
    .banner {
      padding: 160px 0 140px 0; } }
  @media (min-width: 1337px) {
    .banner {
      padding: 220px 0 180px 0; } }
  .banner .content {
    z-index: 9; }
    .banner .content h1 {
      color: white;
      margin-bottom: 1rem; }
    .banner .content .h3 {
      color: #eeeff0; }
  .banner .img-area {
    display: none;
    overflow: hidden; }
    @media (min-width: 769px) {
      .banner .img-area {
        display: block;
        position: absolute;
        right: 0;
        bottom: 0;
        left: 33%;
        top: 0; } }
    .banner .img-area .banner-img {
      height: 100% !important;
      width: 100% !important;
      max-height: 100% !important;
      max-width: 100% !important;
      object-fit: contain;
      object-position: right bottom; }
  .banner #breadcrumb {
    position: absolute;
    bottom: 0;
    width: 100%;
    background: rgba(38, 37, 37, 0.34); }
    .banner #breadcrumb p {
      margin: 0 !important;
      padding: 10px 0 10px 0;
      color: #7b7c80;
      font-size: 14px;
      font-family: "Formata-Regular";
      font-weight: 400; }
      .banner #breadcrumb p a {
        color: #7b7c80; }
        .banner #breadcrumb p a:hover {
          color: #ffc729; }
      .banner #breadcrumb p .separator {
        margin: 0 5px;
        color: #ffc729; }

.features {
  padding-bottom: 20px;
  background: linear-gradient(to bottom, #ffffff 0%, #ffffff 12%, #343131 12%, #343131 100%); }
  @media (min-width: 641px) {
    .features {
      background: linear-gradient(to bottom, #ffffff 0%, #ffffff 20%, #343131 20%, #343131 100%); } }
  @media (min-width: 1141px) {
    .features {
      background: linear-gradient(to bottom, #ffffff 0%, #ffffff 48%, #343131 48%, #343131 100%); } }
  .features .feature-card {
    background: transparent linear-gradient(236deg, #343131 0%, #232323 100%) 0% 0% no-repeat padding-box;
    border-radius: 10px;
    box-shadow: 0px 0px 20px #00000080;
    height: 100%;
    padding: 3rem 1.5rem; }
    .features .feature-card .icon-img {
      margin: 0 auto 1.5rem auto; }
    .features .feature-card h5 {
      color: white;
      padding-bottom: 1.5rem;
      margin-bottom: 1.5rem; }
    .features .feature-card p {
      font-size: 16px; }

.what-sets-us-apart {
  background-color: #343131; }
  .what-sets-us-apart .content h2 {
    color: #eeeff0; }
  .what-sets-us-apart .count-box {
    border-left: 2px solid #ffc729; }
    .what-sets-us-apart .count-box .num {
      line-height: 1;
      margin-bottom: 0;
      color: #ffc729;
      font-size: 30px; }
      @media (min-width: 641px) {
        .what-sets-us-apart .count-box .num {
          font-size: 50px; } }
    .what-sets-us-apart .count-box .title {
      margin-bottom: 0;
      font-size: 20px;
      color: #eeeff0; }

@media (min-width: 1025px) {
  .video .content {
    max-width: 585px; } }

.video .vid-box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  flex-direction: column;
  border-radius: 5px;
  overflow: hidden; }
  .video .vid-box:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: rgba(17, 17, 17, 0.59);
    border-radius: 5px;
    z-index: 1; }
  .video .vid-box span {
    position: absolute;
    z-index: 3;
    height: 42px;
    width: 42px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    border: solid 1px #ffc729; }
    .video .vid-box span i {
      color: white; }
  .video .vid-box:hover span {
    background-color: #ffc729; }

.video .vid-title {
  display: flex;
  justify-content: space-between;
  text-align: right;
  align-items: center; }
  .video .vid-title small {
    font-size: 14px;
    line-height: 1;
    max-width: 270px; }
    @media (min-width: 641px) {
      .video .vid-title small {
        max-width: 100%; } }
    @media (min-width: 1025px) {
      .video .vid-title small {
        max-width: 270px; } }
    @media (min-width: 1337px) {
      .video .vid-title small {
        max-width: 100%; } }
  .video .vid-title span {
    border: solid 1px #ffc729;
    flex: 1 1 auto;
    margin: 0 1rem 0 0;
    height: 1px; }

.affiliations {
  border-bottom: 2px solid rgba(238, 239, 240, 0.24);
  background-color: #343131; }
  .affiliations .content h2 {
    color: #eeeff0; }
  .affiliations .cert-logos {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center; }
    @media (min-width: 641px) {
      .affiliations .cert-logos {
        flex-wrap: nowrap;
        justify-content: none;
        gap: 24px; } }
    .affiliations .cert-logos .logo-wrap {
      display: block;
      width: 33.3%; }
      @media (min-width: 641px) {
        .affiliations .cert-logos .logo-wrap {
          width: auto; } }
      .affiliations .cert-logos .logo-wrap:nth-last-child {
        margin-right: 0; }
      .affiliations .cert-logos .logo-wrap .logo-img {
        margin: 0 auto; }
