@font-face {
  font-family: 'Europa-Regular';
  src: url("../fonts/europa-regular.woff") format("woff"), url("../fonts/europa-regular.woff2") format("woff2");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: 'VanDijck-Regular';
  src: url("../fonts/VanDijck-Regular.woff2") format("woff2"), url("../fonts/VanDijck-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  font-size: 100%;
  font: inherit;
  padding: 0;
  border: 0;
  margin: 0;
  vertical-align: baseline; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; }

.clear {
  clear: both; }

.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important; }

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

html, body {
  font-size: 10px; }

body {
  line-height: 1;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.004);
  overflow-x: hidden;
  background-color: #fcfcfc; }

a, p, li, h1, h2, .trigger {
  font-family: "VanDijck-Regular", sans-serif;
  color: #354b5e; }
  a::-moz-selection, p::-moz-selection, li::-moz-selection, h1::-moz-selection, h2::-moz-selection, .trigger::-moz-selection {
    background-color: transparent; }
  a::selection, p::selection, li::selection, h1::selection, h2::selection, .trigger::selection {
    background-color: transparent; }
  a *::-moz-selection, p *::-moz-selection, li *::-moz-selection, h1 *::-moz-selection, h2 *::-moz-selection, .trigger *::-moz-selection {
    background-color: transparent; }
  a *::selection, p *::selection, li *::selection, h1 *::selection, h2 *::selection, .trigger *::selection {
    background-color: transparent; }

h1 span {
  letter-spacing: .015em; }

header h1, .intro-wrapper p {
  opacity: 0;
  -webkit-transform-origin: 50% 50% 0px;
          transform-origin: 50% 50% 0px; }

header {
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  -webkit-perspective: 650px;
          perspective: 650px;
  -webkit-perspective-origin: 0 50%;
          perspective-origin: 0 50%; }

a {
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  color: #d74b4b; }

video {
  display: block;
  width: 100%;
  height: 100%; }

.intro-wrapper {
  margin-top: 30px; }
  .intro-wrapper p {
    font-size: 2rem;
    margin-bottom: 12px;
    letter-spacing: .01em;
    color: #354b5e;
    line-height: 1.35; }
    .intro-wrapper p span:not(.unicode) {
      font-size: 1.8rem;
      top: -1px;
      position: relative;
      letter-spacing: 0;
      margin-right: 1px; }
    .intro-wrapper p:nth-child(2) {
      margin-bottom: 13px; }
    .intro-wrapper p:last-child {
      margin-bottom: 0; }
    @media (max-width: 767px) {
      .intro-wrapper p {
        font-size: 2.1rem;
        margin-bottom: 18px;
        transform-origin: 80% 0;}
        .intro-wrapper p:nth-child(2) {
          margin-bottom: 16px; } }
    @media (max-width: 320px) {
      .intro-wrapper p {
        max-width: 100%; } }

.container {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  padding: 120px 0; }

h1 {
  font-size: 6.5rem;
  letter-spacing: .04em;
  font-weight: bold;
  color: #354b5e;
  margin-left: 5px; }
  @media (max-width: 767px) {
    h1 {
      font-size: 6.5rem;
      transform-origin: 80% 0;} }

.unicode {
  top: 10px;
  position: relative;
  line-height: 1;
  font-size: 2.1rem; }

@media (max-width: 1520px) {
  .container {
    padding: 60px;
    max-width: none; } }

@media (max-width: 959px) {
  .container {
    padding: 40px; }
    .container p.intro {
      font-size: 1.4rem; } }

@media (max-width: 600px) {
  .container {
    padding: 50px 20px; } }
