* {
  transition-timing-function: cubic-bezier(0.77, 0.2, 0.05, 1);
  transition-duration: 200ms;
  transition-property: none; }

html, body {
  margin: 0;
  padding: 0;
  min-width: 100%;
  width: 100%;
  max-width: 100%;
  min-height: 100%;
  height: 100%;
  max-height: 100%; }

html {
  font-size: 62.5%; }

body {
  font-family: Helvetica, sans-serif;
  font-size: 1.6rem;
  color: #95989a;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }
  body * {
    box-sizing: border-box; }

.main {
  position: relative; }

p {
  line-height: 25px; }

.container, .header__row, .footer__row {
  max-width: 1200px;
  margin: 0 auto;
  padding: 3rem 5%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  overflow: visible;
  -ms-flex: 1 0 auto;
  flex: 1;
  -webkit-flex-direction: row;
  -moz-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row; }

.header {
  position: relative;
  width: 100%;
  top: 0;
  left: 0;
  height: auto;
  background-color: white;
  z-index: 999;
  transition-property: color; }
  .header:hover {
    color: #0082c2; }
  @media screen and (min-width: 900px) {
  .header {
    transform: translateY(-30px); }
    .header > * {
      transform: translateY(15px); } }
  @media (min-width: 900px) {
  .header {
    position: fixed; }
    .header--hidden {
      transform: translateY(-100%); } }
  .header__col {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: auto;
    -moz-flex-direction: auto;
    -ms-flex-direction: auto;
    flex-direction: auto;
    align-items: center; }
    .header__col:nth-child(1) {
      flex: 1;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding-right: 3rem; }
      @media (min-width: 900px) {
  .header__col:nth-child(1) {
    flex-direction: row;
    justify-content: flex-start;
    flex: 0 0 300px;
    align-items: center; } }
      .header__col:nth-child(1) a {
        text-decoration: none; }
    .header__col:nth-of-type(2) {
      flex: 1; }
  .header__logo {
    max-width: 100%;
    width: 75px;
    height: auto;
    align-self: flex-start; }
    @media (min-width: 900px) {
  .header__logo {
    align-self: center; } }
    .header__logo:nth-child(1) {
      margin-bottom: 1.5rem; }
      @media (min-width: 900px) {
  .header__logo:nth-child(1) {
    margin-bottom: 0;
    margin-right: 1.5rem; } }
  .nav {
    display: flex;
    height: 100%;
    width: 100%; }
  .nav__items {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: column;
    -moz-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    align-items: flex-end;
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none; }
    @media (min-width: 900px) {
  .nav__items {
    flex-direction: row;
    align-items: center; } }
  .nav__item {
    flex: 1;
    margin-bottom: 0.75rem;
    text-align: center;
    list-style: none; }
    @media (min-width: 900px) {
  .nav__item {
    margin-bottom: 0; } }
  .nav__link {
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-weight: bold;
    color: #95989a;
    transition-property: color; }
    .nav__link:hover {
      color: #0082c2; }
    .banner {
      position: relative;
      height: 475px;
      width: 100%;
      background: white;
      text-align: center; }
  @media (min-width: 900px) {
  .banner {
    background: black; } }
  .banner--full-height {
    min-height: calc(100vw / 16 * 9);
    max-height: 100vh;
    overflow: hidden; }
    .banner--full-height video {
      object-fit: cover;
      transform: scale(1.2); }
  .banner:not(.banner--full-height) {
    display: none; }
    @media (min-width: 900px) {
  .banner:not(.banner--full-height) {
    display: block; } }
  .banner div.container, .banner div.header__row, .banner div.footer__row {
    padding: 0 5%; }
  .banner__img {
    height: 100%;
    width: 1573px;
    max-width: 1573px;
    min-height: 600px; }
  .banner video {
    display: block;
    height: 100%;
    width: 100%;
    margin: 0 auto; }
  .banner__bg {
    height: 100%;
    width: 100%;
    margin: 0 auto;
    background-image: url("https://videvos.nl/themes/videvos/assets/img/contact-hero.jpg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 50% 66%; }
    .banner__bg.over {
      background-image: url("/themes/videvos/assets/img/joshua.jpg");
      background-size: 125%;
      background-position: 0% 30%;
      overflow: hidden; }

.over .banner {
  height: 550px; }

.video {
  position: relative;
  margin-bottom: 3rem;
  box-sizing: border-box;
  overflow: hidden;
  max-height: 1080px;
  height: 45vw;
  background: white; }
  .video#highlight:not(.home) {
    margin-top: 7rem; }
  @media (min-width: 1000px) {
  .video {
    padding-bottom: 0; } }
  .video img {
    transition-property: transform;
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer; }
  .video img.hidden {
    display: none; }
    .video img.hidden ~ iframe {
      display: block; }
  .video iframe {
    display: none;
    z-index: 99;
    width: 80vw;
    height: 45vw;
    max-width: 1920px;
    max-height: 1080px;
    margin: 0 auto; }

.heading {
  display: block;
  margin-top: 0;
  color: #0082c2;
  text-transform: uppercase; }
  .heading--rotated {
    text-align: center; }
    @media (min-width: 1300px) {
  .heading--rotated {
    position: absolute;
    top: 50%;
    margin: 0;
    transform: translateY(-50%) rotate(270deg) !important;
    transform-origin: center; } }

.overlay {
  padding: 3rem;
  max-width: 100%;
  width: 100%;
  z-index: 100;
  background: linear-gradient(to right, rgba(0, 130, 194, 1) 20%, rgba(0, 130, 194, 0.7) 70%, rgba(0, 130, 194, 0) 100%);
  color: white;
  text-align: left; }
  @media screen and (max-width: 1111px) {
  .overlay {
    padding-bottom: 100px; } }
  .overlay.overlay--intro {
    opacity: 1;
    transition-property: none;
    width: calc(100% / 3);
    transform: translateX(0) translateY(0);
    top: 6rem;
    left: auto;
    right: 0;
    position: absolute; }
    @media screen and (max-width: 900px) {
  .overlay.overlay--intro {
    width: 100%;
    height: 100%;
    top: 0; } }
    @media screen and (min-width: $medium and max-width: $large) {
  .overlay.overlay--intro {
    width: 50%; } }
    @media screen and (min-width: 1000px) {
  .overlay.overlay--intro {
    transform: translateX(-10%) translateY(20%); } }
  .overlay:not(.overlay--intro) {
    height: 100%;
    max-height: 100%;
    display: flex;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    transition-property: transform; }
  .overlay__inner {
    width: 1200px;
    padding: 5%;
    margin: 0 auto; }
  .overlay h3, .overlay p {
    margin: 0;
    max-width: 600px; }
  .overlay h3 {
    font-size: 2rem;
    margin-bottom: 3rem; }
    @media (min-width: 768px) {
  .overlay h3 {
    font-size: 4rem; } }
  .overlay__desc {
    max-width: 600px;
    display: -webkit-box;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    line-height: 1.5em;
    display: none; }
    @media (min-width: 768px) {
  .overlay__desc {
    display: block;
    height: 16rem;
    -webkit-line-clamp: 8; } }
  .overlay input {
    display: none;
    height: 100%; }
  .overlay label, .overlay .loader {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: auto;
    -moz-flex-direction: auto;
    -ms-flex-direction: auto;
    flex-direction: auto;
    font-size: 4rem;
    position: absolute;
    left: calc((200% / 3) - 40px);
    top: calc(50% - 40px);
    width: 80px;
    height: 80px;
    text-align: center;
    cursor: pointer; }
    @media screen and (max-width: 1111px) {
  .overlay label, .overlay .loader {
    left: calc(50vw - 40px);
    bottom: 40px;
    top: auto; } }
    .overlay label.loading:after, .overlay .loader.loading:after {
      pointer-events: none;
      position: absolute;
      box-sizing: border-box;
      content: "";
      top: 0;
      left: 0;
      height: 100%;
      width: 100%;
      border: 3px transparent solid;
      border-top-color: rgba(0, 130, 194, 1);
      border-radius: 50%;
      transform-origin: center center;
      animation-duration: 600ms;
      animation-timing-function: ease-in;
      animation-iteration-count: infinite;
      animation-name: spin; }
    .overlay label div, .overlay .loader div, .overlay label .play-button, .overlay .loader .play-button {
      cursor: pointer;
      transition-property: color, background-color;
      background-color: #fff;
      border-radius: 50%;
      width: 80px;
      height: 80px;
      overflow: visible;
      -webkit-appearance: none;
      border: 0;
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flexbox;
      display: flex;
      overflow: visible;
      -ms-flex: 1 0 auto;
      flex: 1;
      -webkit-flex-direction: column;
      -moz-flex-direction: column;
      -ms-flex-direction: column;
      flex-direction: column;
      align-items: center;
      justify-content: center; }
      .overlay label div, .overlay .loader div, .overlay label .play-button, .overlay .loader .play-button, .overlay label div *, .overlay .loader div *, .overlay label .play-button *, .overlay .loader .play-button * {
        -ms-align-self: stretch;
        align-self: center; }
      .overlay label div:hover, .overlay .loader div:hover, .overlay label .play-button:hover, .overlay .loader .play-button:hover {
        background-color: #0082c2; }
        .overlay label div:hover i, .overlay .loader div:hover i, .overlay label .play-button:hover i, .overlay .loader .play-button:hover i {
          color: #fff; }
      .overlay label div i, .overlay .loader div i, .overlay label .play-button i, .overlay .loader .play-button i {
        transition-property: color;
        color: #0082c2;
        font-style: normal;
        font-size: 40px;
        text-align: right;
        display: block;
        width: 40px; }
  .overlay.hidden:not(.overlay--intro) {
    transform: translateX(-100%);
    transition-property: transform; }
  .overlay__button {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    margin-top: 1.5rem;
    border: 1px solid white;
    border-radius: 3px;
    text-decoration: none;
    color: white; }
    @media (min-width: 900px) {
  .overlay__button {
    transition: box-shadow 0.2s linear; }
    .overlay__button:hover {
      box-shadow: 2px 2px 12px -1px rgba(255, 255, 255, 0.3); } }

@keyframes spin {
  0% {
    transform: rotate(0deg); }

  100% {
    transform: rotate(359deg); } }

.grid {
  position: relative; }
  .grid .container, .grid .header__row, .grid .footer__row {
    padding-top: 0;
    padding-bottom: 5rem; }
    @media (min-width: 1300px) {
  .grid .container, .grid .header__row, .grid .footer__row {
    padding-top: 5rem; } }
  .grid__items {
    width: 100%;
    margin-top: -30px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: row;
    -moz-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    flex-wrap: wrap; }
  .grid__item {
    position: relative;
    flex: 1 100%;
    max-width: 100%;
    margin-top: 35px;
    height: auto;
    border-radius: 3px;
    box-shadow: 2px 2px 12px -1px rgba(0, 0, 0, 0.3);
    cursor: pointer;
    overflow: hidden;
    transition-property: box-shadow; }
    .grid__item:hover {
      box-shadow: 2px 2px 12px -1px rgba(0, 0, 0, 0.6); }
      .grid__item:hover div:nth-child(2) {
        opacity: 1;
        height: 100%; }
    .grid__item div:nth-child(1) {
      position: relative;
      width: 100%;
      padding: calc((50% / 16) * 9);
      overflow: hidden;
      background: black; }
      .grid__item div:nth-child(1) iframe, .grid__item div:nth-child(1) object, .grid__item div:nth-child(1) embed, .grid__item div:nth-child(1) img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        transform: scale(calc(10/7)); }
      .grid__item div:nth-child(2) {
        padding: 1.5rem;
        opacity: 0;
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        height: 0;
        width: 100%;
        background-color: rgba(0, 130, 194, 0.75);
        transition-property: opacity, height;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flexbox;
        display: flex;
        overflow: visible;
        -ms-flex: 1 0 auto;
        flex: 1;
        -webkit-flex-direction: column;
        -moz-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        align-content: center;
        justify-content: center;
        overflow: visible; }
      .grid__item div:nth-child(2) h3 {
        color: white;
        text-align: center; }
      .grid__item div:nth-child(2) div.grid__desc {
        display: none; }
    @media (min-width: 900px) {
  .grid__item {
    flex: 1 1 calc(50% - 30px);
    margin-right: 30px; } }
    @media (min-width: 1000px) {
  .grid__item {
    flex: 1 1 calc(100% / 5);
    margin: 30px 30px 0 0; }
    .grid__item:nth-of-type(5n + 1), .grid__item:nth-of-type(5n + 2) {
      flex: 1 1 40%; } }
    @media screen and (max-width: 900px) {
  .grid__item div:nth-child(2) {
    opacity: 1;
    height: 20%; } }
    .grid__item h3 {
      margin: 0;
      color: #0082c2;
      font-size: 1.8rem;
      line-height: 1.2em;
      text-align: left; }

.contact-form {
  margin: 3rem 0; }
  .contact-form__msg {
    resize: vertical;
    min-height: 35px;
    max-height: 333px; }
  .contact-form__submit, .newsletter__submit {
    width: 100%;
    padding: 1.5rem;
    background: #0082c2;
    color: white;
    font-size: 1.8rem; }

.newsletter {
  margin: 3rem 0; }
  .footer {
    position: relative;
    bottom: 0;
    background: #343434;
    color: white; }
  .footer__row {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: column;
    -moz-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column; }
    @media (min-width: 900px) {
  .footer__row {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: row;
    -moz-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row; } }
  .footer__col {
    flex: 1;
    margin-bottom: 3rem;
    text-align: center; }
    @media (min-width: 900px) {
  .footer__col {
    margin-bottom: 0;
    text-align: left; } }
    .footer__col h3 {
      margin: 0;
      margin-bottom: 1.5rem; }
    .footer__col ul {
      list-style: none;
      padding: 0; }
      .footer__col ul li {
        margin-bottom: 0.75rem; }
      .footer__col ul li:last-child {
        margin-bottom: 0; }
    .footer__col a {
      color: inherit;
      text-decoration: none; }
      @media (min-width: 900px) {
  .footer__col a {
    transition-property: color; }
    .footer__col a:hover {
      color: #0082c2; } }
    .footer__col--center {
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flexbox;
      display: flex;
      overflow: visible;
      -ms-flex: 1 0 auto;
      flex: 1;
      -webkit-flex-direction: column;
      -moz-flex-direction: column;
      -ms-flex-direction: column;
      flex-direction: column; }
      .footer__col--center img {
        width: 175px;
        height: auto;
        transition-property: transform, opacity; }
      @media (min-width: 900px) {
    .footer__col--center img:hover {
      transform: rotate(13deg);
      opacity: 0.8; } }

.contact {
  margin-top: 2rem;
  display: block; }
  @media (min-width: 900px) {
    .contact .container, .contact .header__row, .contact .footer__row {
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flexbox;
      display: flex;
      overflow: visible;
      -ms-flex: 1 0 auto;
      flex: 1;
      -webkit-flex-direction: auto;
      -moz-flex-direction: auto;
      -ms-flex-direction: auto;
      flex-direction: auto; } }
  .contact .container__col {
    width: 100%; }
    @media (min-width: 900px) {
  .contact .container__col {
    flex: 1 1 calc(100% - $l-spacing);
    margin-right: 5rem; }
    .contact .container__col:last-child {
      margin-right: 0; } }
  .contact input, .contact textarea {
    font-family: Helvetica, sans-serif;
    resize: none;
    padding: 0.75rem 1.5rem;
    width: 100%;
    margin-bottom: 1.5rem;
    outline: none;
    border: 1px solid #95989a;
    font-size: 1.6rem;
    transition: border-color 0.15s linear; }
    .contact input:focus, .contact textarea:focus {
      border-color: #0082c2; }
  .contact *[type="submit"] {
    width: 100%;
    padding: 1.5rem;
    border: none;
    background: #0082c2;
    transition-property: background;
    color: white;
    font-size: 1.8rem;
    cursor: pointer; }
    .contact *[type="submit"]:hover {
      background: rgba(0, 130, 194, 0.75); }
  .contact span br {
    display: none; }
    @media (min-width: 1000px) {
  .contact span br {
    display: block; } }

.socials__item {
  position: relative; }
  @media (min-width: 900px) {
    .socials__link {
      transition-property: color; }
      .socials__link:before {
        margin-right: 1.5rem;
        font-family: FontAwesome;
        font-style: normal; }
      .socials__link.fb:before {
        content: '\f230'; }
      .socials__link.li:before {
        content: '\f08c'; }
      .socials__link.vi:before {
        content: '\f194'; } }

.about {
  margin-top: 2rem;
  display: block;
  word-wrap: break-word;
  hyphens: auto;
  text-align: justify; }
  @media (min-width: 900px) {
  .about {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: visible;
    -ms-flex: 1 0 auto;
    flex: 1;
    -webkit-flex-direction: auto;
    -moz-flex-direction: auto;
    -ms-flex-direction: auto;
    flex-direction: auto;
    text-align: left;
    hyphens: none; } }
  .about .container__col {
    width: 100%; }
    @media (min-width: 900px) {
  .about .container__col {
    flex: 1 1 calc(100% - $l-spacing);
    margin-right: 5rem; }
    .about .container__col:last-child {
      margin-right: 0; } }
