/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
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 {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

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;
}

@-moz-keyframes ping {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  1% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(1.8);
  }
}
@-webkit-keyframes ping {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  1% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(1.8);
  }
}
@keyframes ping {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  1% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(1.8);
  }
}
@-moz-keyframes ping-x {
  0% {
    opacity: 1;
    transform: scaleX(1);
  }
  1% {
    opacity: 1;
    transform: scaleX(1);
  }
  100% {
    opacity: 0;
    transform: scaleX(calc(1 + 4em));
  }
}
@-webkit-keyframes ping-x {
  0% {
    opacity: 1;
    transform: scaleX(1);
  }
  1% {
    opacity: 1;
    transform: scaleX(1);
  }
  100% {
    opacity: 0;
    transform: scaleX(calc(1 + 4em));
  }
}
@keyframes ping-x {
  0% {
    opacity: 1;
    transform: scaleX(1);
  }
  1% {
    opacity: 1;
    transform: scaleX(1);
  }
  100% {
    opacity: 0;
    transform: scaleX(calc(1 + 4em));
  }
}
@-moz-keyframes arrow {
  0% {
    transform: translate(-50%, 15%);
  }
  20% {
    transform: translate(-50%, -15%);
  }
  80% {
    transform: translate(-50%, 45%);
  }
  100% {
    transform: translate(-50%, 15%);
  }
}
@-webkit-keyframes arrow {
  0% {
    transform: translate(-50%, 15%);
  }
  20% {
    transform: translate(-50%, -15%);
  }
  80% {
    transform: translate(-50%, 45%);
  }
  100% {
    transform: translate(-50%, 15%);
  }
}
@keyframes arrow {
  0% {
    transform: translate(-50%, 15%);
  }
  20% {
    transform: translate(-50%, -15%);
  }
  80% {
    transform: translate(-50%, 45%);
  }
  100% {
    transform: translate(-50%, 15%);
  }
}
@-moz-keyframes spin {
  0% {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
@-webkit-keyframes spin {
  0% {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
@keyframes spin {
  0% {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
@-moz-keyframes spin2 {
  0% {
    transform: rotate(0deg);
  }
  10% {
    transform: rotate(360deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@-webkit-keyframes spin2 {
  0% {
    transform: rotate(0deg);
  }
  10% {
    transform: rotate(360deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes spin2 {
  0% {
    transform: rotate(0deg);
  }
  10% {
    transform: rotate(360deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@-moz-keyframes frame {
  00% {
    width: calc(100% - 0em);
    height: calc(100% - 0em);
    border-width: 0em;
  }
  80% {
    width: calc(100% - 12em);
    height: calc(100% - 12em);
    border-width: 6em;
  }
  100% {
    width: calc(100% - 9em);
    height: calc(100% - 9em);
    border-width: 4.5em;
  }
}
@-webkit-keyframes frame {
  00% {
    width: calc(100% - 0em);
    height: calc(100% - 0em);
    border-width: 0em;
  }
  80% {
    width: calc(100% - 12em);
    height: calc(100% - 12em);
    border-width: 6em;
  }
  100% {
    width: calc(100% - 9em);
    height: calc(100% - 9em);
    border-width: 4.5em;
  }
}
@keyframes frame {
  00% {
    width: calc(100% - 0em);
    height: calc(100% - 0em);
    border-width: 0em;
  }
  80% {
    width: calc(100% - 12em);
    height: calc(100% - 12em);
    border-width: 6em;
  }
  100% {
    width: calc(100% - 9em);
    height: calc(100% - 9em);
    border-width: 4.5em;
  }
}
@font-face {
  font-family: 'HyperwaveOne';
  src: url("../fonts/HyperwaveOne.otf");
  src: url("../fonts/HyperwaveOne.otf") format("opentype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'DrukTextWide';
  src: url("../fonts/DrukTextWide-Medium.otf");
  src: url("../fonts/DrukTextWide-Medium.otf") format("opentype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'DrukTextWide';
  src: url("../fonts/DrukTextWide-Bold.otf");
  src: url("../fonts/DrukTextWide-Bold.otf") format("opentype");
  font-weight: bold;
  font-style: normal;
}
.row {
  zoom: 1;
}
.row:before, .row:after {
  content: '';
  display: table;
  clear: both;
}
.row .col {
  display: inline-block;
  float: left;
  vertical-align: top;
  min-height: 1px;
}

body {
  font-size: 0.36vw;
  line-height: 1;
  font-weight: 300;
  color: #ffffff;
  font-family: "Space Mono", monotype;
  overflow-x: hidden;
}
body.overlayed {
  pointer-events: none;
  overflow-y: scroll;
}
body.busy * {
  cursor: progress !important;
}
@media only screen and (max-width: 640px) {
  body {
    font-size: 0.76vw;
    position: relative;
  }
}

body, html {
  min-height: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-color: #000000;
  cursor: url(../images/cursor_sm.svg) 6 6, auto;
}

* {
  box-sizing: border-box;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}

::-moz-selection {
  background: #ffffff;
  color: white;
  text-shadow: none;
}

::selection {
  background: #ffffff;
  color: white;
  text-shadow: none;
}

a {
  text-decoration: none;
  -moz-transition: color 0.25s;
  -o-transition: color 0.25s;
  -webkit-transition: color 0.25s;
  transition: color 0.25s;
  cursor: inherit;
}

#cursor {
  display: block;
  width: 24px;
  height: 24px;
  background-color: #ed1c24;
  position: absolute;
  pointer-events: none;
  z-index: 10000;
  border-radius: 50%;
  -moz-transform: translateZ(0) scale(0);
  -ms-transform: translateZ(0) scale(0);
  -webkit-transform: translateZ(0) scale(0);
  transform: translateZ(0) scale(0);
  -moz-transition: -moz-transform 0.2s;
  -o-transition: -o-transform 0.2s;
  -webkit-transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
}
#cursor.active {
  -moz-transform: translateZ(0) scale(1);
  -ms-transform: translateZ(0) scale(1);
  -webkit-transform: translateZ(0) scale(1);
  transform: translateZ(0) scale(1);
}
@media only screen and (max-width: 768px) {
  #cursor {
    display: none;
  }
}

#frame {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: fixed;
  pointer-events: none;
  z-index: 890;
}
#frame em {
  display: block;
  background-color: #ed1c24;
  position: absolute;
  -moz-transition-property: -moz-transform;
  -o-transition-property: -o-transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: transform;
  -moz-transition-duration: 0.5s;
  -o-transition-duration: 0.5s;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
#frame em:nth-child(1) {
  left: 0;
  top: 0;
  width: 100%;
  height: 4.5em;
  -moz-transition-delay: 0s;
  -o-transition-delay: 0s;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -moz-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
}
#frame em:nth-child(2) {
  right: 0;
  top: 0;
  height: 100%;
  width: 4.5em;
  -moz-transition-delay: 0.5s;
  -o-transition-delay: 0.5s;
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
  -moz-transform: scaleY(0);
  -ms-transform: scaleY(0);
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -moz-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
}
#frame em:nth-child(3) {
  left: 0;
  bottom: 0;
  width: 100%;
  height: 4.5em;
  -moz-transition-delay: 1s;
  -o-transition-delay: 1s;
  -webkit-transition-delay: 1s;
  transition-delay: 1s;
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -moz-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
}
#frame em:nth-child(4) {
  left: 0;
  top: 0;
  height: 100%;
  width: 4.5em;
  -moz-transition-delay: 1.5s;
  -o-transition-delay: 1.5s;
  -webkit-transition-delay: 1.5s;
  transition-delay: 1.5s;
  -moz-transform: scaleY(0);
  -ms-transform: scaleY(0);
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -moz-transform-origin: 0 100%;
  -ms-transform-origin: 0 100%;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
@media only screen and (max-width: 640px) {
  #frame em:nth-child(1), #frame em:nth-child(3) {
    height: 7em;
  }
  #frame em:nth-child(2), #frame em:nth-child(4) {
    width: 7em;
  }
}
.loaded #frame em {
  -moz-transform: none !important;
  -ms-transform: none !important;
  -webkit-transform: none !important;
  transform: none !important;
}

#hamburger {
  position: fixed;
  right: -14em;
  top: 50%;
  width: 10em;
  height: 10em;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 2900;
  -moz-transition: right 0.6s 0s;
  -o-transition: right 0.6s 0s;
  -webkit-transition: right 0.6s;
  -webkit-transition-delay: 0s;
  transition: right 0.6s 0s;
}
@media only screen and (max-width: 640px) {
  #hamburger {
    top: 27em;
  }
}
.loaded #hamburger {
  right: 14em;
  -moz-transition: right 0.6s 0.6s;
  -o-transition: right 0.6s 0.6s;
  -webkit-transition: right 0.6s;
  -webkit-transition-delay: 0.6s;
  transition: right 0.6s 0.6s;
}
.full-video #hamburger {
  right: -14em !important;
}
#hamburger em {
  display: block;
  position: absolute;
  width: 100%;
  height: 20%;
  left: 0;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  top: 50%;
  background-color: #ed1c24;
  -moz-transition: opacity 0.4s, -moz-transform 0.4s;
  -o-transition: opacity 0.4s, -o-transform 0.4s;
  -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;
  transition: opacity 0.4s, transform 0.4s;
  opacity: 1;
  pointer-events: none;
}
#hamburger em:nth-child(1) {
  top: 20%;
}
#hamburger em:nth-child(4) {
  top: 80%;
}
.menu-expanded #hamburger em:nth-child(1), .menu-expanded #hamburger em:nth-child(4) {
  opacity: 0;
}
.menu-expanded #hamburger em:nth-child(2) {
  -moz-transform: translateY(-50%) rotate(30deg);
  -ms-transform: translateY(-50%) rotate(30deg);
  -webkit-transform: translateY(-50%) rotate(30deg);
  transform: translateY(-50%) rotate(30deg);
}
.menu-expanded #hamburger em:nth-child(3) {
  -moz-transform: translateY(-50%) rotate(-30deg);
  -ms-transform: translateY(-50%) rotate(-30deg);
  -webkit-transform: translateY(-50%) rotate(-30deg);
  transform: translateY(-50%) rotate(-30deg);
}

#preloader {
  position: fixed;
  width: 100vw;
  height: 100vh;
  left: 0;
  top: 0;
  background-color: black;
  z-index: 880;
}

#overlay {
  position: fixed;
  width: 100vw;
  height: 100vh;
  left: 0;
  top: 0;
  background-color: rgba(255, 0, 0, 0.3);
  z-index: 885;
}

#page, #subpage {
  position: relative;
  z-index: 100;
}

.slant {
  pointer-events: none;
  position: absolute;
  width: calc(100% - 9em);
  height: calc(100% - 9em);
  left: 50%;
  top: 50%;
  z-index: 190;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  overflow: hidden;
}
@media only screen and (max-width: 640px) {
  .slant {
    width: calc(100% - 14em);
    height: calc(100% - 14em);
  }
}
.slant:before {
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  -moz-transition: width 0.52s 0s, height 0.52s 0s;
  -o-transition: width 0.52s 0s, height 0.52s 0s;
  -webkit-transition: width 0.52s, height 0.52s;
  -webkit-transition-delay: 0s, 0s;
  transition: width 0.52s 0s, height 0.52s 0s;
  -moz-transform-origin: left top;
  -ms-transform-origin: left top;
  -webkit-transform-origin: left top;
  transform-origin: left top;
  background: transparent url(../images/skos.svg) 0 0 no-repeat scroll;
  background-size: 100% 100%;
}
.slant:after {
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  left: auto;
  right: 0;
  -moz-transition: width 0.52s 0.2s, height 0.52s 0.2s;
  -o-transition: width 0.52s 0.2s, height 0.52s 0.2s;
  -webkit-transition: width 0.52s, height 0.52s;
  -webkit-transition-delay: 0.2s, 0.2s;
  transition: width 0.52s 0.2s, height 0.52s 0.2s;
  -moz-transform-origin: right top;
  -ms-transform-origin: right top;
  -webkit-transform-origin: right top;
  transform-origin: right top;
  background: transparent url(../images/skos2.svg) 0 0 no-repeat scroll;
  background-size: 100% 100%;
}

#noise {
  position: fixed;
  height: 100vh;
  width: 100%;
  z-index: 50;
  left: 0;
  top: 0;
}
#noise video {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  object-fit: cover;
}
@media only screen and (max-width: 640px) {
  #noise {
    position: absolute;
    height: 100%;
    background-image: url(../images/noise.png);
    background-position-x: center;
  }
  #noise video {
    display: none;
  }
}

#navigation {
  display: block;
  position: fixed;
  top: 50%;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 890;
  left: -16em;
  -moz-transition: left 0.6s 0s;
  -o-transition: left 0.6s 0s;
  -webkit-transition: left 0.6s;
  -webkit-transition-delay: 0s;
  transition: left 0.6s 0s;
}
.loaded #navigation {
  left: 8em;
}
.full-video #navigation {
  left: -16em !important;
}
.subpage #navigation, .current--home #navigation {
  left: -16em;
}
#navigation li {
  display: block;
  padding: 1em 0;
  width: fit-content;
  -webkit-width: fit-content;
}
#navigation li a {
  text-transform: uppercase;
  color: #ed1c24;
  display: block;
  padding: 0.5em 0 0.5em 1em;
  position: relative;
  font-size: 2.9em;
  font-weight: bold;
  overflow: hidden;
  max-width: 1em;
  -moz-transition: max-width 0.2s;
  -o-transition: max-width 0.2s;
  -webkit-transition: max-width 0.2s;
  transition: max-width 0.2s;
}
#navigation li a:before {
  content: '';
  display: block;
  border-radius: 50%;
  background-color: #ed1c24;
  position: absolute;
  width: 0.5em;
  height: 0.5em;
  left: 0;
  top: 50%;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
#navigation li:hover a, #navigation li.active a {
  max-width: 20em;
}
#navigation li:hover a:before, #navigation li.active a:before {
  border-radius: 0;
  height: 3px;
  top: 50%;
  -moz-transform: translateY(-50%) rotate(45deg);
  -ms-transform: translateY(-50%) rotate(45deg);
  -webkit-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
}
#navigation li:hover a:after, #navigation li.active a:after {
  content: '';
  display: block;
  position: absolute;
  width: 0.5em;
  height: 3px;
  left: 0;
  top: 50%;
  background-color: #ed1c24;
  -moz-transform: translateY(-50%) rotate(-45deg);
  -ms-transform: translateY(-50%) rotate(-45deg);
  -webkit-transform: translateY(-50%) rotate(-45deg);
  transform: translateY(-50%) rotate(-45deg);
}
@media only screen and (max-width: 640px) {
  #navigation {
    display: none;
    left: auto;
    right: -4%;
  }
  .loaded #navigation {
    left: auto;
    right: 4%;
  }
  .subpage #navigation, .current--home #navigation {
    left: auto;
    right: -8%;
  }
  #navigation li a {
    font-size: 10em;
    max-width: 1em !important;
    padding-top: 0.2em;
    padding-bottom: 0.2em;
  }
}

.scrolldown {
  position: fixed;
  left: 50%;
  z-index: 300;
  font-size: 3em;
  padding-bottom: 1.6em;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  text-transform: uppercase;
  text-align: center;
  -moz-transition: bottom 0.6s 0.2s;
  -o-transition: bottom 0.6s 0.2s;
  -webkit-transition: bottom 0.6s;
  -webkit-transition-delay: 0.2s;
  transition: bottom 0.6s 0.2s;
  bottom: 2.6em;
  line-height: 1.2;
}
@media only screen and (max-width: 640px) {
  .scrolldown {
    font-size: 5em;
    bottom: 1.6em;
  }
}
.scrolldown:before {
  font-size: 0.33333333em;
  content: '';
  display: block;
  position: absolute;
  left: 50%;
  bottom: 0.3em;
  width: 3em;
  height: 2.4em;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background: transparent url(../images/down2.png) center center no-repeat scroll;
  background-size: contain;
  animation-delay: 2s;
  animation-duration: 1s;
  animation-name: arrow;
  animation-iteration-count: 10;
}
.current-last .scrolldown {
  bottom: -12em;
}
.full-video .scrolldown {
  bottom: -12em !important;
}

.topright {
  position: fixed;
  right: 4em;
  top: 4em;
  font-size: 3em;
  text-transform: uppercase;
  padding-right: 2em;
  z-index: 910;
}
@media only screen and (max-width: 640px) {
  .topright {
    font-size: 5em;
    top: 2em;
    right: 2em;
  }
}
.topright.absolute {
  position: absolute;
}
.full-video .topright {
  top: -24em !important;
}
.topright:before {
  font-size: 0.33333333em;
  content: '';
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  width: 3em;
  height: 2.4em;
  -moz-transform: translateY(-50%) rotate(-90deg);
  -ms-transform: translateY(-50%) rotate(-90deg);
  -webkit-transform: translateY(-50%) rotate(-90deg);
  transform: translateY(-50%) rotate(-90deg);
  background: transparent url(../images/down2.png) center center no-repeat scroll;
  background-size: contain;
}
.topright a:hover {
  color: #ed1c24;
}
.topright .submenu {
  position: relative;
  margin-right: 2em;
  padding-right: 2em;
  display: inline-block;
}
.topright .submenu:after {
  font-size: 0.33333333em;
  content: '';
  display: block;
  position: absolute;
  right: 0;
  top: 0.3em;
  width: 3em;
  height: 2.4em;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background: transparent url(../images/down2.png) center center no-repeat scroll;
  background-size: contain;
}
.topright .submenu ul {
  position: absolute;
  left: -2em;
  top: 2em;
  background-color: #ed1c24;
  color: white;
  padding: 0.8em 1.2em;
  display: none;
}
@media only screen and (max-width: 640px) {
  .topright .submenu ul {
    left: 0;
    width: 20em;
  }
}
.topright .submenu ul li {
  margin: 0.6em 0;
  white-space: nowrap;
}
.topright .submenu ul li a:hover {
  color: inherit;
  text-decoration: underline;
}

#menu {
  position: fixed;
  width: 100vw;
  height: 100%;
  left: 100%;
  top: 0;
  z-index: 800;
}
#menu .bg {
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  -moz-transition: opacity 0.4s, -moz-transform 0s 0.4s;
  -o-transition: opacity 0.4s, -o-transform 0s 0.4s;
  -webkit-transition: opacity 0.4s, -webkit-transform 0s;
  -webkit-transition-delay: 0s, 0.4s;
  transition: opacity 0.4s, transform 0s 0.4s;
}
.menu-expanded #menu .bg {
  opacity: 1;
  -moz-transform: translate3d(-100%, 0, 0);
  -ms-transform: translate3d(-100%, 0, 0);
  -webkit-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
  -moz-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
#menu .inner {
  position: absolute;
  width: 50%;
  height: 100%;
  right: 0;
  top: 0;
  padding: 10em 0 0 8em;
  background-color: #000;
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -moz-transition: -moz-transform 0.4s;
  -o-transition: -o-transform 0.4s;
  -webkit-transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
}
@media only screen and (max-width: 640px) {
  #menu .inner {
    padding: 16em 0 0 12em;
  }
}
.menu-expanded #menu .inner {
  -moz-transform: translate3d(-200%, 0, 0);
  -ms-transform: translate3d(-200%, 0, 0);
  -webkit-transform: translate3d(-200%, 0, 0);
  transform: translate3d(-200%, 0, 0);
}
@media only screen and (max-width: 640px) {
  #menu .inner {
    width: 100%;
  }
  .menu-expanded #menu .inner {
    -moz-transform: translate3d(-100%, 0, 0);
    -ms-transform: translate3d(-100%, 0, 0);
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}
#menu .main li {
  display: block;
  font-size: 8em;
  text-transform: uppercase;
  font-family: "DrukTextWide", sans-serif;
  font-weight: bold;
  padding: 0.1em 0;
  -moz-transition-delay: 0.2s;
  -o-transition-delay: 0.2s;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
@media only screen and (max-width: 640px) {
  #menu .main li {
    font-size: 14em;
  }
}
#menu .main li:nth-of-type(1) {
  -moz-transition-duration: 0.2s;
  -o-transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  transition-duration: 0.2s;
  -moz-transform: translate3d(4em, 0, 0);
  -ms-transform: translate3d(4em, 0, 0);
  -webkit-transform: translate3d(4em, 0, 0);
  transform: translate3d(4em, 0, 0);
}
#menu .main li:nth-of-type(2) {
  -moz-transition-duration: 0.3s;
  -o-transition-duration: 0.3s;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -moz-transform: translate3d(5em, 0, 0);
  -ms-transform: translate3d(5em, 0, 0);
  -webkit-transform: translate3d(5em, 0, 0);
  transform: translate3d(5em, 0, 0);
}
#menu .main li:nth-of-type(3) {
  -moz-transition-duration: 0.4s;
  -o-transition-duration: 0.4s;
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  -moz-transform: translate3d(6em, 0, 0);
  -ms-transform: translate3d(6em, 0, 0);
  -webkit-transform: translate3d(6em, 0, 0);
  transform: translate3d(6em, 0, 0);
}
#menu .main li:nth-of-type(4) {
  -moz-transition-duration: 0.5s;
  -o-transition-duration: 0.5s;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -moz-transform: translate3d(7em, 0, 0);
  -ms-transform: translate3d(7em, 0, 0);
  -webkit-transform: translate3d(7em, 0, 0);
  transform: translate3d(7em, 0, 0);
}
#menu .main li:nth-of-type(5) {
  -moz-transition-duration: 0.6s;
  -o-transition-duration: 0.6s;
  -webkit-transition-duration: 0.6s;
  transition-duration: 0.6s;
  -moz-transform: translate3d(8em, 0, 0);
  -ms-transform: translate3d(8em, 0, 0);
  -webkit-transform: translate3d(8em, 0, 0);
  transform: translate3d(8em, 0, 0);
}
#menu .main li:nth-of-type(6) {
  -moz-transition-duration: 0.7s;
  -o-transition-duration: 0.7s;
  -webkit-transition-duration: 0.7s;
  transition-duration: 0.7s;
  -moz-transform: translate3d(9em, 0, 0);
  -ms-transform: translate3d(9em, 0, 0);
  -webkit-transform: translate3d(9em, 0, 0);
  transform: translate3d(9em, 0, 0);
}
#menu .main li a {
  color: #ed1c24;
}
#menu .main li a:hover {
  color: white;
}
.menu-expanded #menu .main li {
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.current--home #menu .main li.home a, .current--about #menu .main li.about a, .current--films #menu .main li.films a, .current--photos #menu .main li.photos a, .current--services #menu .main li.services a, .current--contact #menu .main li.contact a {
  color: white;
}
#menu .lang {
  position: absolute;
  top: 10em;
  right: 10em;
  z-index: 30;
}
@media only screen and (max-width: 640px) {
  #menu .lang {
    top: auto;
    bottom: 12em;
  }
}
#menu .lang li {
  font-size: 3.5em;
  display: inline-block;
  margin: 0.3em 0.5em;
}
@media only screen and (max-width: 640px) {
  #menu .lang li {
    font-size: 8em;
  }
}
#menu .lang li a {
  color: #ed1c24;
}
#menu .lang li:hover a, #menu .lang li.active a {
  color: white;
}
#menu .lower {
  position: absolute;
  width: 100%;
  left: 8em;
  bottom: 12em;
}
#menu .lower:before, #menu .lower:after {
  content: '';
  display: table;
  clear: both;
}
@media only screen and (max-width: 640px) {
  #menu .lower {
    left: auto;
    bottom: 10em;
  }
}
#menu .lower p {
  font-size: 3em;
  width: 50%;
  float: left;
  line-height: 1.2;
  color: #ed1c24;
  -moz-transition-delay: 0.2s;
  -o-transition-delay: 0.2s;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
#menu .lower p:nth-of-type(1) {
  -moz-transition-duration: 0.6s;
  -o-transition-duration: 0.6s;
  -webkit-transition-duration: 0.6s;
  transition-duration: 0.6s;
  -moz-transform: translate3d(10em, 0, 0);
  -ms-transform: translate3d(10em, 0, 0);
  -webkit-transform: translate3d(10em, 0, 0);
  transform: translate3d(10em, 0, 0);
}
#menu .lower p:nth-of-type(2) {
  -moz-transition-duration: 0.8s;
  -o-transition-duration: 0.8s;
  -webkit-transition-duration: 0.8s;
  transition-duration: 0.8s;
  -moz-transform: translate3d(12em, 0, 0);
  -ms-transform: translate3d(12em, 0, 0);
  -webkit-transform: translate3d(12em, 0, 0);
  transform: translate3d(12em, 0, 0);
}
.menu-expanded #menu .lower p {
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
@media only screen and (max-width: 640px) {
  #menu .lower p {
    font-size: 5em;
    width: 100%;
    float: none;
    line-height: 1.4;
    margin-bottom: 1em;
  }
}
#menu .lower p a {
  color: white;
}
#menu .lower p a:hover {
  color: #ed1c24;
}

.gallery {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  z-index: 100;
}
.gallery .slides {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
}
.gallery .slides li {
  display: block;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  visibility: hidden;
  opacity: 0;
  -moz-transition: opacity 0.8s;
  -o-transition: opacity 0.8s;
  -webkit-transition: opacity 0.8s;
  transition: opacity 0.8s;
}
.gallery .slides li.visible {
  visibility: visible;
  opacity: 1;
  display: block;
}
.gallery .slides li .bg {
  display: block;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background-position: center center;
  background-size: cover;
  -webkit-filter: brightness(0.25);
  filter: brightness(0.25);
}
.gallery .slides li .frame {
  width: 86%;
  height: 64%;
  position: absolute;
  left: 50%;
  top: 50%;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 640px) {
  .gallery .slides li .frame {
    width: 82%;
  }
}
.gallery .slides li .title {
  position: absolute;
  top: 17.2%;
  font-size: 3em;
  padding: 0.4em;
  white-space: nowrap;
  z-index: 180;
  right: calc(97.2% - 3em);
  -moz-transform-origin: right bottom;
  -ms-transform-origin: right bottom;
  -webkit-transform-origin: right bottom;
  transform-origin: right bottom;
  -moz-transform: translateY(-100%) rotate(-90deg);
  -ms-transform: translateY(-100%) rotate(-90deg);
  -webkit-transform: translateY(-100%) rotate(-90deg);
  transform: translateY(-100%) rotate(-90deg);
}
@media only screen and (max-width: 640px) {
  .gallery .slides li .title {
    font-size: 4em;
  }
}
@media only screen and (max-width: 640px) {
  #photo-gallery .gallery .slides li .title, #service-gallery .gallery .slides li .title {
    right: auto;
    left: 50%;
    top: 12.2%;
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
.gallery.photos .slides li .frame {
  background-size: contain;
}
.gallery .video {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 150;
  overflow-y: hidden;
}
.gallery .video video {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  object-fit: cover;
}
.gallery .video .poster {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background-position: center center;
  background-size: cover;
  opacity: 1;
  -moz-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.gallery .video-full {
  display: none;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: fixed;
  background-color: black;
  z-index: 888;
  padding: 4.5em;
}
.gallery .video-full video {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: relative;
  object-fit: contain;
}
.gallery .video-full .close {
  position: absolute;
  right: 2.5em;
  top: 2em;
  cursor: pointer;
  font-size: 4em;
}
@media only screen and (max-width: 640px) {
  .gallery .video-full .close {
    font-size: 5em;
  }
}
.gallery .bullets {
  position: absolute;
  left: calc(4.7% + 4em);
  bottom: 17.2%;
  z-index: 180;
  -moz-transform-origin: left bottom;
  -ms-transform-origin: left bottom;
  -webkit-transform-origin: left bottom;
  transform-origin: left bottom;
  -moz-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
@media only screen and (max-width: 640px) {
  .gallery .bullets {
    font-size: 1.333333em;
    left: calc(4.7% + 8em);
  }
}
.gallery .bullets li {
  display: inline-block;
  text-align: center;
  font-size: 3em;
  padding: 0.4em;
}
.gallery .bullets li.active {
  color: #ed1c24;
}
.gallery .count {
  position: absolute;
  left: 5.7%;
  bottom: 14.2%;
  font-size: 3em;
  z-index: 180;
}
@media only screen and (max-width: 640px) {
  .gallery .count {
    font-size: 4em;
    left: 50%;
    bottom: 12.2%;
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
.gallery .prevnext {
  position: absolute;
  left: 5.7%;
  bottom: 16%;
  -moz-transform: translate(-100%, 0);
  -ms-transform: translate(-100%, 0);
  -webkit-transform: translate(-100%, 0);
  transform: translate(-100%, 0);
}
.gallery .prevnext > span {
  display: block;
  font-size: 2em;
  width: 2em;
  height: 2em;
  margin: 1em 0;
  background: transparent url(../images/down2.png) center center no-repeat scroll;
  background-size: 50%;
}
.gallery .prevnext > span.prev {
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.gallery .prevnext > span.next {
  -moz-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
@media only screen and (max-width: 640px) {
  .gallery .prevnext {
    -moz-transform: none;
    -ms-transform: none;
    -webkit-transform: none;
    transform: none;
    left: 12em;
    width: calc(100% - 24em);
    bottom: 8.7%;
  }
  .gallery .prevnext > span {
    background-color: #ed1c24;
    font-size: 6em;
    background-size: 25%;
  }
  .gallery .prevnext > span.prev {
    float: left;
  }
  .gallery .prevnext > span.next {
    float: right;
  }
}
.gallery .play {
  position: absolute;
  left: 50%;
  top: 50%;
  font-family: "DrukTextWide", sans-serif;
  font-weight: bold;
  font-size: 5em;
  padding: 1em;
  text-transform: uppercase;
  opacity: 1;
  -moz-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 200;
}
@media only screen and (max-width: 640px) {
  .gallery .play {
    font-size: 10em;
  }
}
.full-video .gallery .play {
  display: none;
}
@media only screen and (min-width: 769px) {
  .gallery .play:hover + .slant:before {
    width: 0 !important;
    height: 0 !important;
  }
  .gallery .play:hover + .slant:after {
    width: 0 !important;
    height: 0 !important;
  }
}
.gallery.instant .slides li {
  -moz-transition-duration: 0s;
  -o-transition-duration: 0s;
  -webkit-transition-duration: 0s;
  transition-duration: 0s;
}

section.gallerylist {
  padding: 6em 12em;
}
section.gallerylist .slant:before {
  background-image: url(../images/skos_b.svg);
}
section.gallerylist .slant:after {
  background-image: url(../images/skos_b2.svg);
}
section.gallerylist .items {
  width: 100%;
  height: 100%;
  display: block;
  padding: 10em 0 0 0;
}
@media only screen and (max-width: 640px) {
  section.gallerylist .items {
    padding-top: 20em;
  }
}
section.gallerylist .items:before, section.gallerylist .items:after {
  content: '';
  display: table;
  clear: both;
}
section.gallerylist .items:after {
  content: '';
  display: table;
  clear: both;
}
section.gallerylist .items li {
  width: calc(100% - 2em);
  padding: 2.4em 5em;
  margin-bottom: 12%;
  position: relative;
  -moz-transition: all 0.5s 0.3s;
  -o-transition: all 0.5s 0.3s;
  -webkit-transition: all 0.5s;
  -webkit-transition-delay: 0.3s;
  transition: all 0.5s 0.3s;
}
@media only screen and (max-width: 640px) {
  section.gallerylist .items li {
    margin-bottom: 18%;
  }
}
section.gallerylist .items li a {
  display: block;
  position: relative;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
section.gallerylist .items li .image {
  display: block;
  position: relative;
  background-color: black;
  background-size: cover;
  background-position: center center;
  pointer-events: none;
}
section.gallerylist .items li .image:before {
  content: '';
  display: block;
  padding-top: 56%;
}
section.gallerylist .items li .title {
  position: absolute;
  text-transform: uppercase;
  font-size: 3em;
  color: white;
  display: block;
  height: 5em;
  -moz-transition: color 0.25s;
  -o-transition: color 0.25s;
  -webkit-transition: color 0.25s;
  transition: color 0.25s;
}
@media only screen and (max-width: 640px) {
  section.gallerylist .items li .title {
    font-size: 5em;
  }
}
section.gallerylist .items li .title em {
  pointer-events: none;
  display: block;
  font-family: "DrukTextWide", sans-serif;
  font-weight: bold;
  font-size: 1.2em;
  padding-top: 1em;
}
section.gallerylist .items li .slant {
  width: 106%;
  height: 106%;
  pointer-events: none;
}
section.gallerylist .items li .slant:before {
  -moz-transition: width 0.2s 0.4s, height 0.2s 0.4s;
  -o-transition: width 0.2s 0.4s, height 0.2s 0.4s;
  -webkit-transition: width 0.2s, height 0.2s;
  -webkit-transition-delay: 0.4s, 0.4s;
  transition: width 0.2s 0.4s, height 0.2s 0.4s;
  width: 0;
  height: 0;
}
section.gallerylist .items li .slant:after {
  -moz-transition: width 0.2s 0.2s, height 0.2s 0.2s;
  -o-transition: width 0.2s 0.2s, height 0.2s 0.2s;
  -webkit-transition: width 0.2s, height 0.2s;
  -webkit-transition-delay: 0.2s, 0.2s;
  transition: width 0.2s 0.2s, height 0.2s 0.2s;
  width: 0;
  height: 0;
  left: auto;
  right: 0;
}
@media only screen and (min-width: 769px) {
  section.gallerylist .items li:hover .slant:before {
    -moz-transition: width 0.2s 0.2s, height 0.2s 0.2s;
    -o-transition: width 0.2s 0.2s, height 0.2s 0.2s;
    -webkit-transition: width 0.2s, height 0.2s;
    -webkit-transition-delay: 0.2s, 0.2s;
    transition: width 0.2s 0.2s, height 0.2s 0.2s;
    width: 100%;
    height: 100%;
  }
  section.gallerylist .items li:hover .slant:after {
    -moz-transition: width 0.2s 0.4s, height 0.2s 0.4s;
    -o-transition: width 0.2s 0.4s, height 0.2s 0.4s;
    -webkit-transition: width 0.2s, height 0.2s;
    -webkit-transition-delay: 0.4s, 0.4s;
    transition: width 0.2s 0.4s, height 0.2s 0.4s;
    width: 100%;
    height: 100%;
  }
  section.gallerylist .items li:hover .title {
    color: #ed1c24;
  }
}
@media only screen and (min-width: 641px) {
  section.gallerylist .items li {
    width: calc(50% - 2em);
    float: left;
    margin: 0;
    padding-bottom: 14em;
  }
  section.gallerylist .items li:nth-child(5n+1), section.gallerylist .items li:nth-child(5n+4) {
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    width: 30%;
    margin: 6% 5%;
  }
  section.gallerylist .items li:nth-child(5n+1) .slant:before, section.gallerylist .items li:nth-child(5n+4) .slant:before {
    background-image: url(../images/skos_c.svg);
  }
  section.gallerylist .items li:nth-child(5n+1) .slant:after, section.gallerylist .items li:nth-child(5n+4) .slant:after {
    background-image: url(../images/skos_c2.svg);
  }
  section.gallerylist .items li:nth-child(5n+1) .slant:before, section.gallerylist .items li:nth-child(5n+4) .slant:before {
    background-image: url(../images/skos_c.svg);
  }
  section.gallerylist .items li:nth-child(5n+1) .slant:after, section.gallerylist .items li:nth-child(5n+4) .slant:after {
    background-image: url(../images/skos_c2.svg);
  }
  section.gallerylist .items li:nth-child(5n+2), section.gallerylist .items li:nth-child(5n+3) {
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    width: 60%;
    margin-bottom: 5%;
  }
  section.gallerylist .items li:nth-child(5n+5) {
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    width: 60%;
    margin: 0 20% 5% 20%;
  }
  section.gallerylist .items li:nth-child(0) {
    -moz-transition-delay: calc(0 * 0.01s);
    -o-transition-delay: calc(0 * 0.01s);
    -webkit-transition-delay: calc(0 * 0.01s);
    transition-delay: calc(0 * 0.01s);
  }
  section.gallerylist .items li:nth-child(1) {
    -moz-transition-delay: calc(1 * 0.01s);
    -o-transition-delay: calc(1 * 0.01s);
    -webkit-transition-delay: calc(1 * 0.01s);
    transition-delay: calc(1 * 0.01s);
  }
  section.gallerylist .items li:nth-child(2) {
    -moz-transition-delay: calc(2 * 0.01s);
    -o-transition-delay: calc(2 * 0.01s);
    -webkit-transition-delay: calc(2 * 0.01s);
    transition-delay: calc(2 * 0.01s);
  }
  section.gallerylist .items li:nth-child(3) {
    -moz-transition-delay: calc(3 * 0.01s);
    -o-transition-delay: calc(3 * 0.01s);
    -webkit-transition-delay: calc(3 * 0.01s);
    transition-delay: calc(3 * 0.01s);
  }
  section.gallerylist .items li:nth-child(4) {
    -moz-transition-delay: calc(4 * 0.01s);
    -o-transition-delay: calc(4 * 0.01s);
    -webkit-transition-delay: calc(4 * 0.01s);
    transition-delay: calc(4 * 0.01s);
  }
  section.gallerylist .items li:nth-child(5) {
    -moz-transition-delay: calc(5 * 0.01s);
    -o-transition-delay: calc(5 * 0.01s);
    -webkit-transition-delay: calc(5 * 0.01s);
    transition-delay: calc(5 * 0.01s);
  }
  section.gallerylist .items li:nth-child(6) {
    -moz-transition-delay: calc(6 * 0.01s);
    -o-transition-delay: calc(6 * 0.01s);
    -webkit-transition-delay: calc(6 * 0.01s);
    transition-delay: calc(6 * 0.01s);
  }
  section.gallerylist .items li:nth-child(7) {
    -moz-transition-delay: calc(7 * 0.01s);
    -o-transition-delay: calc(7 * 0.01s);
    -webkit-transition-delay: calc(7 * 0.01s);
    transition-delay: calc(7 * 0.01s);
  }
  section.gallerylist .items li:nth-child(8) {
    -moz-transition-delay: calc(8 * 0.01s);
    -o-transition-delay: calc(8 * 0.01s);
    -webkit-transition-delay: calc(8 * 0.01s);
    transition-delay: calc(8 * 0.01s);
  }
  section.gallerylist .items li:nth-child(9) {
    -moz-transition-delay: calc(9 * 0.01s);
    -o-transition-delay: calc(9 * 0.01s);
    -webkit-transition-delay: calc(9 * 0.01s);
    transition-delay: calc(9 * 0.01s);
  }
  section.gallerylist .items li:nth-child(10) {
    -moz-transition-delay: calc(10 * 0.01s);
    -o-transition-delay: calc(10 * 0.01s);
    -webkit-transition-delay: calc(10 * 0.01s);
    transition-delay: calc(10 * 0.01s);
  }
}

.wysiwyg h2 {
  color: #ed1c24;
  margin-bottom: 0.6em;
  text-align: center;
}
.wysiwyg h3 {
  color: #ed1c24;
  margin-bottom: 0.6em;
}
.wysiwyg p {
  margin-bottom: 0.6em;
}
.wysiwyg p strong {
  color: #ed1c24;
}
.wysiwyg ul li {
  padding-left: 1.4em;
  position: relative;
  margin-bottom: 0.6em;
}
.wysiwyg ul li:before, .wysiwyg ul li:after {
  content: '';
  position: absolute;
  left: 0em;
  top: 0.6em;
  width: 0.6em;
  height: 4px;
  background-color: #ed1c24;
}
.wysiwyg ul li:before {
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.wysiwyg ul li:after {
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

section {
  position: relative;
  min-height: 100vh;
  width: 100%;
  padding: 4em;
  overflow-y: hidden;
  z-index: 100;
}
.overlayed2 > section {
  display: none;
}
section .stamp {
  position: absolute;
  width: 53.6em;
  height: 53.6em;
}
section .stamp > div {
  animation-iteration-count: infinite;
  animation-duration: 12s;
  animation-name: spin2;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background: transparent url(../images/stamp.png) center center no-repeat scroll;
  background-size: contain;
}
section.active .scrolldown {
  -moz-transition: bottom 0.6s 1s;
  -o-transition: bottom 0.6s 1s;
  -webkit-transition: bottom 0.6s;
  -webkit-transition-delay: 1s;
  transition: bottom 0.6s 1s;
  bottom: 2.4em;
}

section#home h1 {
  position: absolute;
  left: 50%;
  top: -13em;
  width: 43em;
  height: 5em;
  text-indent: -9999px;
  background: transparent url(../images/logo.svg) center center no-repeat scroll;
  background-size: contain;
  -moz-transform: translate3d(-50%, 0, 0);
  -ms-transform: translate3d(-50%, 0, 0);
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  -moz-transition: top 0.6s 0s;
  -o-transition: top 0.6s 0s;
  -webkit-transition: top 0.6s;
  -webkit-transition-delay: 0s;
  transition: top 0.6s 0s;
  z-index: 300;
}
.full-video section#home h1 {
  top: -13em !important;
}
@media only screen and (max-width: 640px) {
  section#home h1 {
    width: 70em;
    height: 8em;
  }
}
section#home .gallery .play,
section#home .gallery .slides li .frame,
section#home .gallery .slides li .title,
section#home .gallery .bullets {
  opacity: 0;
  -moz-transition: opacity 0.5s 0.1s;
  -o-transition: opacity 0.5s 0.1s;
  -webkit-transition: opacity 0.5s;
  -webkit-transition-delay: 0.1s;
  transition: opacity 0.5s 0.1s;
}
section#home .slant {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  clip-path: polygon(0% 0%, 0% 100%, 50% 100%, 50% 50%, 50% 50%, 50% 50%, 50% 50%, 50% 100%, 100% 100%, 100% 0%);
}
section#home .slant:before {
  width: 0;
  height: 0;
}
section#home .slant:after {
  width: 0;
  height: 0;
  left: auto;
  right: 0;
}
.full-video section#home .slant:before {
  width: 0 !important;
  height: 0 !important;
}
.full-video section#home .slant:after {
  width: 0 !important;
  height: 0 !important;
}
section#home.active h1 {
  -moz-transition: top 0.6s 0s;
  -o-transition: top 0.6s 0s;
  -webkit-transition: top 0.6s;
  -webkit-transition-delay: 0s;
  transition: top 0.6s 0s;
  top: 13em;
}
section#home.active .gallery .play,
section#home.active .gallery .slides li .frame,
section#home.active .gallery .slides li .title,
section#home.active .gallery .bullets {
  -moz-transition: opacity 0.5s 0.8s;
  -o-transition: opacity 0.5s 0.8s;
  -webkit-transition: opacity 0.5s;
  -webkit-transition-delay: 0.8s;
  transition: opacity 0.5s 0.8s;
  opacity: 1;
}
section#home.active .slant:before {
  width: 100%;
  height: 100%;
}
section#home.active .slant:after {
  width: 100%;
  height: 100%;
}

section#about {
  background-color: black;
  min-height: 100vh;
  height: auto;
}
section#about .text {
  position: relative;
  left: 0;
  width: 100%;
  font-size: 6em;
  line-height: 1.4;
  padding: 3em 4em 3em 3em;
  opacity: 0;
  -moz-transition: opacity 0.5s 0.1s;
  -o-transition: opacity 0.5s 0.1s;
  -webkit-transition: opacity 0.5s;
  -webkit-transition-delay: 0.1s;
  transition: opacity 0.5s 0.1s;
  overflow-y: hidden;
}
section#about .text:after {
  content: '';
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  -moz-transform: translateY(0%);
  -ms-transform: translateY(0%);
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  -moz-transition: -moz-transform 0.5s 0.1s;
  -o-transition: -o-transform 0.5s 0.1s;
  -webkit-transition: -webkit-transform 0.5s;
  -webkit-transition-delay: 0.1s;
  transition: transform 0.5s 0.1s;
  background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzAwMDAwMCIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjEzJSIgc3RvcC1jb2xvcj0iIzAwMDAwMCIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzAwMDAwMCIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==');
  background-size: 100%;
  background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, rgba(0, 0, 0, 0)), color-stop(13%, #000000), color-stop(100%, #000000));
  background-image: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 13%, #000000 100%);
  background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 13%, #000000 100%);
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, #000000 13%, #000000 100%);
}
@media only screen and (max-width: 640px) {
  section#about .text {
    position: absolute;
    top: 50%;
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}
section#about .stamp {
  right: 42em;
  bottom: 12em;
  opacity: 0;
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
  -moz-transition: all 0.5s 0.2s;
  -o-transition: all 0.5s 0.2s;
  -webkit-transition: all 0.5s;
  -webkit-transition-delay: 0.2s;
  transition: all 0.5s 0.2s;
}
section#about .gaffer {
  position: absolute;
  right: 10em;
  bottom: 10em;
  width: 111em;
  height: 22em;
  opacity: 0;
  -moz-transform: translateY(100%);
  -ms-transform: translateY(100%);
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -moz-transition: all 0.5s 0.3s;
  -o-transition: all 0.5s 0.3s;
  -webkit-transition: all 0.5s;
  -webkit-transition-delay: 0.3s;
  transition: all 0.5s 0.3s;
}
section#about .gaffer > div {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background: transparent url(../images/about-gaffer.png) center center no-repeat scroll;
  background-size: contain;
}
section#about.active .text {
  -moz-transition: opacity 0.2s 0s;
  -o-transition: opacity 0.2s 0s;
  -webkit-transition: opacity 0.2s;
  -webkit-transition-delay: 0s;
  transition: opacity 0.2s 0s;
  opacity: 1;
}
section#about.active .text:after {
  -moz-transform: translateY(100%);
  -ms-transform: translateY(100%);
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -moz-transition: -moz-transform 0.5s 0s;
  -o-transition: -o-transform 0.5s 0s;
  -webkit-transition: -webkit-transform 0.5s;
  -webkit-transition-delay: 0s;
  transition: transform 0.5s 0s;
}
section#about.active .stamp {
  -moz-transition: opacity 0.5s 0.4s, -moz-transform 0.6s 0.4s;
  -o-transition: opacity 0.5s 0.4s, -o-transform 0.6s 0.4s;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.6s;
  -webkit-transition-delay: 0.4s, 0.4s;
  transition: opacity 0.5s 0.4s, transform 0.6s 0.4s;
  -moz-transform: translateY(0%);
  -ms-transform: translateY(0%);
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  opacity: 1;
}
section#about.active .gaffer {
  -moz-transition: opacity 0.5s 0.2s, -moz-transform 0.6s 0.2s;
  -o-transition: opacity 0.5s 0.2s, -o-transform 0.6s 0.2s;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.6s;
  -webkit-transition-delay: 0.2s, 0.2s;
  transition: opacity 0.5s 0.2s, transform 0.6s 0.2s;
  -moz-transform: translateY(0%);
  -ms-transform: translateY(0%);
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  opacity: 1;
}

section#photos {
  background-color: black;
}

section#services h2 {
  position: absolute;
  left: 50%;
  top: 50%;
  text-transform: uppercase;
  font-family: "DrukTextWide", sans-serif;
  font-weight: bold;
  font-size: 16em;
  -moz-transform: translate3d(-50%, -50%, 0) rotate(-90deg);
  -ms-transform: translate3d(-50%, -50%, 0) rotate(-90deg);
  -webkit-transform: translate3d(-50%, -50%, 0) rotate(-90deg);
  transform: translate3d(-50%, -50%, 0) rotate(-90deg);
  z-index: 200;
  margin-left: 0.1em;
  white-space: nowrap;
}
@media only screen and (max-width: 640px) {
  section#services h2 {
    font-size: 12em;
  }
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#services h2 {
    font-size: 20em;
    left: 86%;
  }
}
section#services .slide {
  display: block;
  position: absolute;
  width: 50%;
  height: 100%;
  z-index: 100;
  left: 0;
  top: 0;
}
section#services .slide.los-angeles {
  left: 50%;
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#services .slide {
    width: 100%;
    height: 50%;
    left: 0;
  }
  section#services .slide.los-angeles {
    left: 0;
    top: 50%;
  }
}
section#services .slide .bg {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background-color: black;
  background-size: cover;
  background-position: center;
  opacity: 1;
  -moz-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
section#services .slide h3 {
  position: absolute;
  left: 50%;
  top: 50%;
  text-transform: uppercase;
  font-size: 7.2em;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -moz-transition: color 0.2s;
  -o-transition: color 0.2s;
  -webkit-transition: color 0.2s;
  transition: color 0.2s;
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#services .slide h3 {
    left: 10%;
    -moz-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    font-size: 10em;
  }
}
section#services .slide h3:after {
  content: '';
  position: absolute;
  bottom: -0.2em;
  left: 50%;
  height: 0.1em;
  width: 0;
  background-color: #ed1c24;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  -moz-transition: width 0.2s;
  -o-transition: width 0.2s;
  -webkit-transition: width 0.2s;
  transition: width 0.2s;
}
@media only screen and (min-width: 769px) {
  section#services .slide:hover h3 {
    color: #ed1c24;
  }
  section#services .slide:hover h3:after {
    width: 100%;
  }
  section#services .slide:hover .bg {
    opacity: 0;
  }
}

section#contact .column {
  position: absolute;
  width: 30%;
  padding-left: 10em;
  top: 20em;
  opacity: 0;
  -moz-transition: all 0.5s 0.1s;
  -o-transition: all 0.5s 0.1s;
  -webkit-transition: all 0.5s;
  -webkit-transition-delay: 0.1s;
  transition: all 0.5s 0.1s;
  z-index: 30;
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .column {
    left: 0em !important;
    top: 40%;
    width: 100%;
    padding-left: 30em;
  }
}
section#contact .column h3 {
  position: absolute;
}
section#contact .column h3 span {
  position: absolute;
  display: block;
  font-family: "DrukTextWide", sans-serif;
  font-size: 7.2em;
  text-transform: uppercase;
  white-space: nowrap;
  -moz-transform: translate(-50%, -50%) rotate(-90deg);
  -ms-transform: translate(-50%, -50%) rotate(-90deg);
  -webkit-transform: translate(-50%, -50%) rotate(-90deg);
  transform: translate(-50%, -50%) rotate(-90deg);
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .column h3 span {
    font-size: 20em;
  }
}
section#contact .column.warsaw {
  left: 30em;
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .column.warsaw {
    -moz-transform: translate(0, -50%) !important;
    -ms-transform: translate(0, -50%) !important;
    -webkit-transform: translate(0, -50%) !important;
    transform: translate(0, -50%) !important;
  }
}
section#contact .column.warsaw h3 {
  top: 0em;
}
section#contact .column.warsaw h3 span {
  right: 0;
  -moz-transform-origin: right center;
  -ms-transform-origin: right center;
  -webkit-transform-origin: right center;
  transform-origin: right center;
  -moz-transform: translate(-20%, -2em) rotate(-90deg);
  -ms-transform: translate(-20%, -2em) rotate(-90deg);
  -webkit-transform: translate(-20%, -2em) rotate(-90deg);
  transform: translate(-20%, -2em) rotate(-90deg);
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .column.warsaw h3 {
    top: 70%;
    left: 15em;
  }
  section#contact .column.warsaw h3 span {
    right: auto;
    left: 50%;
    -moz-transform-origin: center center;
    -ms-transform-origin: center center;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -moz-transform: translate(-50%, -50%) rotate(-90deg);
    -ms-transform: translate(-50%, -50%) rotate(-90deg);
    -webkit-transform: translate(-50%, -50%) rotate(-90deg);
    transform: translate(-50%, -50%) rotate(-90deg);
  }
}
section#contact .column.losangeles {
  left: 160em;
  -moz-transform: translateY(100%);
  -ms-transform: translateY(100%);
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .column.losangeles {
    -moz-transform: translate(100%, -50%) !important;
    -ms-transform: translate(100%, -50%) !important;
    -webkit-transform: translate(100%, -50%) !important;
    transform: translate(100%, -50%) !important;
  }
}
section#contact .column.losangeles h3 {
  bottom: 0;
}
section#contact .column.losangeles h3 span {
  left: 0;
  -moz-transform-origin: left center;
  -ms-transform-origin: left center;
  -webkit-transform-origin: left center;
  transform-origin: left center;
  -moz-transform: translate(-20%, -1em) rotate(-90deg);
  -ms-transform: translate(-20%, -1em) rotate(-90deg);
  -webkit-transform: translate(-20%, -1em) rotate(-90deg);
  transform: translate(-20%, -1em) rotate(-90deg);
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .column.losangeles h3 {
    top: 65%;
    left: 15em;
    bottom: auto;
  }
  section#contact .column.losangeles h3 span {
    right: auto;
    left: 50%;
    -moz-transform-origin: center center;
    -ms-transform-origin: center center;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -moz-transform: translate(-50%, -50%) rotate(-90deg);
    -ms-transform: translate(-50%, -50%) rotate(-90deg);
    -webkit-transform: translate(-50%, -50%) rotate(-90deg);
    transform: translate(-50%, -50%) rotate(-90deg);
  }
}
section#contact .column p {
  font-size: 4em;
  margin-bottom: 1em;
  line-height: 1.3;
}
@media only screen and (max-width: 640px) and (orientation: portrait) {
  section#contact .column p {
    font-size: 6em;
  }
}
section#contact .column p strong {
  color: #ed1c24;
}
section#contact .column p a:hover {
  color: #ed1c24;
}
section#contact .gaffer {
  position: absolute;
  left: 50%;
  bottom: 20em;
  width: 167em;
  height: 14em;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  opacity: 0;
  -moz-transition: opacity 0.5s 0.3s;
  -o-transition: opacity 0.5s 0.3s;
  -webkit-transition: opacity 0.5s;
  -webkit-transition-delay: 0.3s;
  transition: opacity 0.5s 0.3s;
}
section#contact .gaffer > div {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background: transparent url(../images/address-gaffer.png) center center no-repeat scroll;
  background-size: contain;
}
@media only screen and (max-width: 640px) {
  section#contact .gaffer {
    height: 44em;
    bottom: 22em;
  }
  section#contact .gaffer > div {
    background-image: url(../images/address-gaffer-mobile.png);
  }
}
section#contact .copyright {
  position: absolute;
  font-family: "DrukTextWide", sans-serif;
  font-size: 4em;
  left: 50%;
  bottom: 3em;
  -moz-transform: translate(-50%, 100%);
  -ms-transform: translate(-50%, 100%);
  -webkit-transform: translate(-50%, 100%);
  transform: translate(-50%, 100%);
  opacity: 0;
  -moz-transition: all 0.5s 0.4s;
  -o-transition: all 0.5s 0.4s;
  -webkit-transition: all 0.5s;
  -webkit-transition-delay: 0.4s;
  transition: all 0.5s 0.4s;
  white-space: nowrap;
}
section#contact .copyright a:hover {
  color: #ed1c24;
}
section#contact.active .warsaw {
  -moz-transition: opacity 0.5s 0s, -moz-transform 0.6s 0s;
  -o-transition: opacity 0.5s 0s, -o-transform 0.6s 0s;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.6s;
  -webkit-transition-delay: 0s, 0s;
  transition: opacity 0.5s 0s, transform 0.6s 0s;
  -moz-transform: translateY(0%);
  -ms-transform: translateY(0%);
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  opacity: 1;
}
section#contact.active .losangeles {
  -moz-transition: opacity 0.5s 0.4s, -moz-transform 0.6s 0.3s;
  -o-transition: opacity 0.5s 0.4s, -o-transform 0.6s 0.3s;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.6s;
  -webkit-transition-delay: 0.4s, 0.3s;
  transition: opacity 0.5s 0.4s, transform 0.6s 0.3s;
  -moz-transform: translateY(0%);
  -ms-transform: translateY(0%);
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  opacity: 1;
}
section#contact.active .gaffer {
  -moz-transition: opacity 0.5s 0.8s;
  -o-transition: opacity 0.5s 0.8s;
  -webkit-transition: opacity 0.5s;
  -webkit-transition-delay: 0.8s;
  transition: opacity 0.5s 0.8s;
  opacity: 1;
}
section#contact.active .copyright {
  -moz-transition: opacity 0.5s 0.2s, -moz-transform 0.6s 0.3s;
  -o-transition: opacity 0.5s 0.2s, -o-transform 0.6s 0.3s;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.6s;
  -webkit-transition-delay: 0.2s, 0.3s;
  transition: opacity 0.5s 0.2s, transform 0.6s 0.3s;
  -moz-transform: translate(-50%, 0%);
  -ms-transform: translate(-50%, 0%);
  -webkit-transform: translate(-50%, 0%);
  transform: translate(-50%, 0%);
  opacity: 1;
}
section#contact .topright {
  display: none;
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact .topright.losangeles {
    display: block;
  }
}
@media only screen and (max-width: 480px) and (orientation: portrait) {
  section#contact.losangeles .topright.warsaw {
    display: block;
  }
  section#contact.losangeles .topright.losangeles {
    display: none;
  }
  section#contact.losangeles .column.warsaw {
    -moz-transform: translate(-100%, -50%) !important;
    -ms-transform: translate(-100%, -50%) !important;
    -webkit-transform: translate(-100%, -50%) !important;
    transform: translate(-100%, -50%) !important;
  }
  section#contact.losangeles .column.losangeles {
    -moz-transform: translate(0, -50%) !important;
    -ms-transform: translate(0, -50%) !important;
    -webkit-transform: translate(0, -50%) !important;
    transform: translate(0, -50%) !important;
  }
}

section#film-details h2 {
  position: absolute;
  left: 1em;
  top: 1em;
  text-transform: uppercase;
  font-family: "DrukTextWide", sans-serif;
  font-weight: bold;
  font-size: 16em;
  line-height: 1.2;
}
@media only screen and (max-width: 640px) {
  section#film-details h2 {
    left: 1em;
    top: 3em;
    width: 80%;
    font-size: 10em;
  }
}
section#film-details .text {
  position: absolute;
  left: 17em;
  bottom: 40em;
  line-height: 1.4;
  color: #ed1c24;
}
section#film-details .text p {
  font-size: 5em;
}
section#film-details .text span {
  display: inline-block;
  padding-right: 1em;
  color: white;
}
@media only screen and (max-width: 640px) {
  section#film-details .text {
    left: 12em;
    top: 40%;
    bottom: auto;
    width: 107em;
  }
  section#film-details .text p {
    font-size: 7em;
  }
}
section#film-details .stamp {
  right: 40em;
  bottom: 20em;
}

section#film-player {
  height: 100vh;
}
section#film-player X.slant {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  opacity: 1;
  clip-path: polygon(0% 0%, 0% 100%, 50% 100%, 50% 50%, 50% 50%, 50% 50%, 50% 50%, 50% 100%, 100% 100%, 100% 0%);
}
section#film-player X.slant:before {
  -moz-transition: width 0.2s 2s, height 0.2s 2s;
  -o-transition: width 0.2s 2s, height 0.2s 2s;
  -webkit-transition: width 0.2s, height 0.2s;
  -webkit-transition-delay: 2s, 2s;
  transition: width 0.2s 2s, height 0.2s 2s;
  width: 100%;
  height: 100%;
}
section#film-player X.slant:after {
  -moz-transition: width 0.2s 2.2s, height 0.2s 2.2s;
  -o-transition: width 0.2s 2.2s, height 0.2s 2.2s;
  -webkit-transition: width 0.2s, height 0.2s;
  -webkit-transition-delay: 2.2s, 2.2s;
  transition: width 0.2s 2.2s, height 0.2s 2.2s;
  width: 100%;
  height: 100%;
}
section#film-player .video.playing .poster,
section#film-player .video.playing ~ .slant,
section#film-player .video.playing ~ .play {
  opacity: 0;
  pointer-events: none;
}

section#photo-details {
  background-color: black;
}
section#photo-details h2 {
  position: absolute;
  left: 1em;
  top: 1em;
  text-transform: uppercase;
  font-family: "DrukTextWide", sans-serif;
  font-weight: bold;
  font-size: 16em;
  line-height: 1.2;
}
@media only screen and (max-width: 640px) {
  section#photo-details h2 {
    left: 1em;
    top: 3em;
    width: 80%;
    font-size: 10em;
  }
}
section#photo-details .text {
  position: absolute;
  left: 17em;
  top: 60em;
  line-height: 1.4;
  color: #ed1c24;
}
section#photo-details .text p {
  font-size: 5em;
}
section#photo-details .text span {
  display: inline-block;
  padding-right: 1em;
  color: white;
}
@media only screen and (max-width: 640px) {
  section#photo-details .text {
    left: 12em;
    top: 40%;
    bottom: auto;
    width: 107em;
  }
  section#photo-details .text p {
    font-size: 7em;
  }
}
section#photo-details .stamp {
  right: 40em;
  bottom: 20em;
}

section#photo-gallery {
  background-color: black;
}
section#photo-gallery .gallery .play {
  padding: 25vh 40vw;
}

section#service-details {
  min-height: 100vh;
  height: auto;
}
section#service-details .text {
  position: relative;
  width: 100%;
  font-size: 7.2em;
  line-height: 1.2;
  padding: 3em 4em 3em 2.6em;
  opacity: 0;
  -moz-transition: opacity 0.5s 0.1s;
  -o-transition: opacity 0.5s 0.1s;
  -webkit-transition: opacity 0.5s;
  -webkit-transition-delay: 0.1s;
  transition: opacity 0.5s 0.1s;
  overflow-y: hidden;
}
section#service-details .text:after {
  content: '';
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  -moz-transform: translateY(0%);
  -ms-transform: translateY(0%);
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  -moz-transition: -moz-transform 0.5s 0.1s;
  -o-transition: -o-transform 0.5s 0.1s;
  -webkit-transition: -webkit-transform 0.5s;
  -webkit-transition-delay: 0.1s;
  transition: transform 0.5s 0.1s;
  background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzAwMDAwMCIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjEzJSIgc3RvcC1jb2xvcj0iIzAwMDAwMCIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzAwMDAwMCIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==');
  background-size: 100%;
  background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, rgba(0, 0, 0, 0)), color-stop(13%, #000000), color-stop(100%, #000000));
  background-image: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 13%, #000000 100%);
  background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 13%, #000000 100%);
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, #000000 13%, #000000 100%);
}
@media only screen and (max-width: 640px) and (orientation: portrait) {
  section#service-details .text {
    padding: 3em 2em 3em 1.6em;
  }
}
section#service-details.active .text {
  -moz-transition: opacity 0.2s 0s;
  -o-transition: opacity 0.2s 0s;
  -webkit-transition: opacity 0.2s;
  -webkit-transition-delay: 0s;
  transition: opacity 0.2s 0s;
  opacity: 1;
}
section#service-details.active .text:after {
  -moz-transform: translateY(100%);
  -ms-transform: translateY(100%);
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -moz-transition: -moz-transform 0.5s 0s;
  -o-transition: -o-transform 0.5s 0s;
  -webkit-transition: -webkit-transform 0.5s;
  -webkit-transition-delay: 0s;
  transition: transform 0.5s 0s;
}

section.service-gallery .gallery {
  display: none;
}
section.service-gallery .gallery:first-of-type {
  display: block;
}
