body {
  background-color: #2b2b2b; }

  h1, h2, h3, h4, h5, h6, span, i, a, div, p {
    font-family: 'Alata';
    color: #fff; }
    .white-back h1, .white-back h2, .white-back h3, .white-back h4, .white-back h5,
    .white-back h6, .white-back span, .white-back i, .white-back a, .white-back div,
    .white-back p {
      color: black; }

a:hover, a:hover i {
  text-decoration: none;
  color: #cac7c7; }

img {
  max-width: 100%;
  max-height: 100%;
  border-radius: 0.2rem; }

  .cineor-overlay {
    background-image: url("/static/img/cineor_effect.svg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center; }
    .cineor-overlay.strong {
      background-image: url("/static/img/cineor_effect_strong.svg"); }

.nav {
  position: absolute;
  width: 100%;
  padding-top: 1rem;
  padding-bottom: 1rem;
  height: 7rem;
  z-index: 100;
  background-image: linear-gradient(#181818, transparent); }
  .nav .nav-logo {
    height: 5rem; }
    .nav a, .nav i {
      color: #fff; }
      .nav a {
        text-decoration: none; }
        .nav a:hover {
          transition: 0.4s;
          color: #cac7c7; }
  .nav .row {
    height: 100%; }
    @media (max-width: 768px) {
      .nav .row {
        display: flex;
        align-items: center;   }
}
    .nav .row .nav-items {
      display: flex;
      flex-direction: row;
      align-content: center;
      align-items: center;
      justify-content: space-between;
      z-index: 100; }
      @media (max-width: 768px) {
        .nav .row .nav-items {
          justify-content: flex-start;
          display: flex;
          position: fixed;
          top: 0;
          left: -100vw;
          flex-direction: column;
          padding-top: 10rem;
          align-content: flex-start;
          align-items: flex-start;
          height: 100vh;
          background-color: black;
          transition: 0.5s;
          z-index: 500;   }
          .nav .row .nav-items a {
            margin-bottom: 1rem;
            color: white !important;
            margin-left: 1rem !important;
            font-size: 2rem;
            transition: 0.4s;   }
            .nav .row .nav-items .nav-left > a:hover, .nav .row .nav-items .nav-right > a:hover {
              margin-left: 2rem !important;   }
}
      .nav .row .nav-items .nav-left {
        display: flex;
        justify-content: flex-start; }
        @media (max-width: 768px) {
          .nav .row .nav-items .nav-left {
            flex-direction: column;   }
}
        .nav .row .nav-items .nav-left a {
          margin-right: 1rem; }
      .nav .row .nav-items .nav-right {
        display: flex;
        justify-content: flex-end; }
        @media (max-width: 768px) {
          .nav .row .nav-items .nav-right {
            flex-direction: column;
            margin-top: 1rem;   }
}
        .nav .row .nav-items .nav-right .social-icons i {
          color: #fff; }
          @media (max-width: 768px) {
            .nav .row .nav-items .nav-right .social-icons i {
              color: #fff;   }
}
        @media (max-width: 768px) {
          .nav .row .nav-items .nav-right .social-icons {
            position: absolute;
            bottom: 1rem;
            right: 1rem;   }
}
        .nav .row .nav-items .nav-right .social-icons a {
          margin-left: 0.5rem; }
          @media (max-width: 768px) {
            .nav .row .nav-items .nav-right .social-icons a i {
              font-size: 1rem;   }
}
        .nav .row .nav-items .nav-right a {
          margin-left: 1rem; }
      .nav .row .nav-items .nav-tag {
        position: absolute;
        top: 1.5rem;
        font-size: small;
        color: #cac7c7; }
        @media (max-width: 768px) {
          .nav .row .nav-items .nav-tag {
            position: inherit;
            font-size: 1rem;   }
}
    .nav .row .nav-centre {
      text-align: center;
      position: absolute;
      top: 1rem;
      left: 0; }
      .nav .row .nav-centre a {
        z-index: 600;
        position: relative; }
  .nav .mobile-menu-btn {
    display: none;
    cursor: pointer; }
    @media (max-width: 768px) {
      .nav .mobile-menu-btn {
        display: inline-block;
        z-index: 700;
        width: fit-content;
        position: absolute;
        right: 0;   }
}
    .nav .mobile-menu-btn .bar {
      width: 1.5rem;
      height: 3px;
      background-color: #e0e0e0;
      margin: 3px 0;
      transition: 0.4s; }
      .nav .mobile-menu-btn.change .bar {
        background-color: #fff; }
        .nav .mobile-menu-btn.change .bar1 {
          transform: translate(0, 6px) rotate(-45deg); }
          .nav .mobile-menu-btn.change .bar2 {
            opacity: 0; }
            .nav .mobile-menu-btn.change .bar3 {
              transform: translate(0, -6px) rotate(45deg); }

.video-banner {
  border-bottom: 0.25rem solid #fff;
  position: relative;
  width: 100%;
  max-height: 80%;
  height: 80vh;
  min-height: 50vh;
  overflow: hidden;
  display: flex;
  align-content: center;
  align-items: center;
  justify-content: center;
  background-color: black; }
  @media (max-width: 768px) {
    .video-banner {
      height: 50vh;
      z-index: 50;   }
}
  .video-banner:hover .video-overlay {
    opacity: 1; }
  .video-banner .video-overlay {
    position: absolute;
    display: flex;
    flex-direction: row;
    right: 1rem;
    bottom: 1rem;
    opacity: 0;
    transition: 0.4s;
    z-index: 1000; }
    .video-banner .video-overlay .video-ctrl-btn {
      background-color: #bdbdbd;
      border-radius: 50%;
      padding: 0.5rem;
      width: 2rem;
      height: 2rem;
      color: black;
      display: flex;
      align-content: center;
      justify-content: center;
      align-items: center;
      margin-left: 0.5rem;
      opacity: 0.7;
      transition: 0.4s; }
      .video-banner .video-overlay .video-ctrl-btn:hover {
        opacity: 1; }
        .video-banner .video-overlay .video-ctrl-btn.mute-btn.muted i.muted,
        .video-banner .video-overlay .video-ctrl-btn.mute-btn:not(.muted) i.unmuted {
          display: block !important; }
          .video-banner .video-overlay .video-ctrl-btn.mute-btn i {
            display: none; }
      .video-banner .video-overlay .video-ctrl-btn i {
        color: black;
        width: 1rem; }
  .video-banner .showreel {
    position: absolute;
    height: 79vw;
    width: 100vw; }
    @media (max-width: 1214px) {
      .video-banner .showreel {
        height: 100vh;
        width: 158vw;   }
}
    @media (max-width: 768px) {
      .video-banner .showreel {
        height: 100vh;
        width: 103vh;   }
}

.content {
  width: 60%;
  margin: auto;
  overflow: hidden; }
  .content .row {
    margin-top: 4rem;
    margin-bottom: 4rem; }
    @media (max-width: 768px) {
      .content {
        width: 100%;   }
}

@media (max-width: 1200px) {
  .container {
    width: 100%;   }
}

.service-container {
  width: 80%;
  max-width: 80%; }
  @media (max-width: 1200px) {
    .service-container {
      width: 100%;
      max-width: 100%;   }
}

.services .service-col {
  margin: 0 auto; }
  .services .service-item {
    position: relative;
    opacity: 1;
    transition: 0.4s;
    margin: 0.5rem 0;
    overflow: hidden;
    border-radius: 0.2rem; }
    .services .service-item.hover-zoom:hover img {
      transform: scale(1.085); }
      .services .service-item.hover-zoom:hover .service-overlay.dark-overlay {
        opacity: 0.25; }
    .services .service-item:not(.no-hover-animation):hover .service-overlay {
      opacity: 0; }
      .services .service-item:not(.no-hover-animation):hover .service-title {
        opacity: 0; }
    .services .service-item .service-title {
      position: absolute;
      height: 100%;
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 1;
      transition: 0.4s;
      z-index: 80;
      color: white; }
      .services .service-item .service-title h1,
      .services .service-item .service-title h2,
      .services .service-item .service-title h3,
      .services .service-item .service-title h4,
      .services .service-item .service-title h5,
      .services .service-item .service-title h6,
      .services .service-item .service-title p,
      .services .service-item .service-title span,
      .services .service-item .service-title a {
        margin: 0;
        color: white; }
    .services .service-item div.service-title {
      align-content: center;
      flex-direction: column; }
      .services .service-item .service-overlay {
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        background-color: black;
        opacity: 0.15;
        transition: 0.4s;
        z-index: 50; }
        .services .service-item .service-overlay.dark-overlay {
          opacity: 0.3; }
    .services .service-item .service-image {
      width: 100%;
      transition: 0.4s; }

.clients {
  text-align: center; }
  .clients .client {
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: center;
    align-items: center; }
    .clients .client:hover img {
      filter: grayscale(0%);
      transform: scale(1.05); }
      .clients .client:hover p {
        opacity: 1; }
    .clients .client p {
      opacity: 0;
      transition: 0.4s; }
      .clients .client img {
        filter: grayscale(100%);
        transition: 0.4s; }

.cta {
  min-height: 5rem;
  overflow: hidden;
  background-size: cover;
  background-position: center; }
  .cta .carousel {
    min-height: 40vh; }

.animate-in {
  transition: 1s !important;
  opacity: 0 !important;
  position: relative !important;
  top: 1rem !important; }
  .animate-in.show {
    opacity: 1 !important;
    top: 0rem !important; }

.secondary-text, .secondary-text p, .secondary-text a, .secondary-text span,
.secondary-text i {
  color: #cac7c7;
  transition: 0.4s; }
  .secondary-text a:hover {
    color: #fff; }

.vert-center {
  display: flex;
  align-content: center;
  justify-content: center;
  align-items: center; }

  .footer {
    background-color: #2b2b2b;
    border-top: 0.25rem solid white; }
    .footer * {
      color: white; }
      .footer a {
        text-decoration: none; }
        .footer .footer-list {
          display: flex;
          flex-direction: column; }
          .footer .footer-list .footer-list-title {
            margin-top: 2rem; }

.video {
  width: 80%; }
  .video.full-width {
    width: 100%; }
    @media (max-width: 768px) {
      .video {
        width: 100%;   }
}
  @media (max-width: 1200px) {
    .video {
      width: 95%;   }
}
  .video .video-container {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    border-radius: 0.2rem;
    overflow: hidden; }
    .video .video-container .video-img-overlay {
      height: 100%;
      position: absolute;
      z-index: 75;
      width: 100%;
      left: 0; }
      .video .video-container .video-img-overlay .video-play-btn {
        z-index: 80;
        position: relative;
        font-size: 4rem;
        top: calc(50% - 2rem);
        filter: drop-shadow(0.3rem 0.3rem 0.2rem black);
        cursor: pointer; }
    .video .video-container img {
      z-index: 50; }
      .video .video-container iframe, .video .video-container img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%; }

.spacer {
  height: 3rem; }

  @media (max-width: 768px) {
    .image-row img {
      margin-top: 1rem;   }
}

.admin-bar {
  width: 100%;
  min-height: 1rem;
  background-color: white;
  padding: 0.3rem 1rem;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  align-content: center;
  justify-content: space-between;
  align-items: center; }
  .admin-bar, .admin-bar * {
    color: black; }
