:root {
  --color-dark: #293230;
  --color-navy: #04505F;
  --color-cream-light: #F6E1B8;
  --color-cream-mid: #E5C89E;
  --color-cream-dark: #5B5E52;
  --font-sans-serif: futura-pt, sans-serif;
  --font-serif: minion-pro, serif;;
}

body {
  background-color: var(--color-navy);
  color: white;
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 21px;
}

a {

}

a:hover, a:focus {

}

p {
  margin: 0 0 1.2rem;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-sans-serif);
  font-weight: 400;
  margin: 0 0 1.2rem;
}

.site {
}

/*
  ***********************
  WRAPPER
  ***********************
*/

.site-wrapper {
  position: absolute;
  z-index: 500 !important;
}

/* Tablet and smaller portrait */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : portrait) {

    .site-wrapper {
      background-color: var(--color-dark);
      top: 0;
      left: 0;
      right: 0;
      height: 50vh;
      padding-top: 2rem;
    }

}

/* Mobile portrait */
@media only screen
  and (max-device-width : 767px)
  and (orientation : portrait) {

    .site-wrapper {
      height: 60vh;
    }

}

/* Tablet and smaller landscape */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : landscape) {

  .site-wrapper  {
    top: 5vh;
    left: 0;
    right: 0;
    height: 93%;
  }
}

/* Desktop */
@media only screen
  and (min-device-width : 1025px)
  and (orientation : landscape) {

    .site-wrapper {
      top: 5vh;
      left: 0;
      right: 5vw;
      height: 93%;
    }
}

/* Wide Desktop */
@media only screen
  and (min-width : 1920px)
  and (min-height : 1080px) {

    .site-wrapper  {
      left: 0;
      right: 0;
    }
}

/*
  ***********************
  PARALLAX
  ***********************
*/

.site-plx {
  position: relative;
  height: 100vh;
  overflow: hidden;
}

/*
  Night Sky
  ***********************
*/

.plx-night-sky {
  position: absolute;
  z-index: 1 !important;
  left: 0;
  right: 0;
  height: 66vh;
  background-image: url(../img/plx-night-sky.svg);
  background-repeat: repeat;
  background-size: contain;
  animation-name: twinkle;
  animation-duration: 10s;
  animation-iteration-count: infinite;
  transform: translateZ(0);
}

@keyframes twinkle {
  0%   {opacity: 0.25;}
  50%  {opacity: 0.9;}
  100% {opacity: 0.25;}
}

/* Tablet and smaller portrait */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : portrait) {

    .plx-night-sky {
      top: 50vh !important
    }
}

/* Mobile portrait */
@media only screen
  and (max-device-width : 767px)
  and (orientation : portrait) {

    .plx-night-sky {
      top: 60vh !important
    }
}

/* Desktop */
@media only screen
  and (min-device-width : 1025px)
  and (orientation : landscape) {

    .plx-night-sky {
      top: 0;
    }
}

/* Super Wide Desktop */
@media only screen
  and (min-width : 2560px)
  and (min-height : 975px) {

    .plx-night-sky  {
      height: 100vh;
      left: -5vw !important;
    }
}

/*
  Flying Saucer
  ***********************
*/

.plx-flying-saucer-wrapper {
  position: absolute;
  z-index: 2 !important;
  left: 30% !important;
}

.plx-flying-saucer {
  position: absolute;
  z-index: 3 !important;
  top: 0;
  right: 0;
  left: 30% !important;
  width: 80vw;
  height: 125vh;
  animation-name: rotate;
  animation-duration: 28s;
  animation-iteration-count: infinite;
  transform: translateX(100px)translateY(-100px)translateZ(0);
}

@media not all and (min-resolution:.001dpcm) {
  .plx-flying-saucer {
    animation: none;
  }
}

@keyframes rotate {
  0%   {
    transform: rotateX(0)translateX(100px)translateY(-100px)translateZ(0);
    opacity: 1;
  }
  5% {
    opacity: 1;
  }
  15% {
    transform: rotateX(45deg)translateX(0)translateY(0)translateZ(0);
    opacity: 1;
  }
  48% {
    transform: rotateX(45deg)translateX(0)translateY(0)translateZ(0);
    opacity: 1;
  }
  50%  {
    transform: rotateX(0)translateX(1000px)translateY(-1000px)translateZ(0);
    opacity: 0;
  }
  100% {
    transform: rotateX(0)translateX(1000px)translateY(-1000px)translateZ(0);
    opacity: 0;
  }
}

/* Tablet and smaller portrait */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : portrait) {

    .plx-flying-saucer  {
      top: 53vh !important;
    }
}

/* Mobile portrait */
@media only screen
  and (max-device-width : 767px)
  and (orientation : portrait) {

    .plx-flying-saucer  {
      top: 60vh !important
    }
}

/* Desktop */
@media only screen
  and (min-device-width : 1025px)
  and (orientation : landscape) {

    .plx-flying-saucer  {
      top: 0;
    }
}

/* Super Wide Desktop */
@media only screen
  and (min-width : 2560px)
  and (min-height : 975px) {

    .plx-flying-saucer  {
      width: 65vw;
    }
}


/*
  Abduction
  ***********************


@keyframes abduct {
  0%   {
    transform: rotateX(0)translateX(0)translateZ(0);
    top: 75%;
    left: 75vw;
    width: 70px;
    height: 70px;
    opacity: 1;
  }
  50%  {
    transform: rotateX(45deg)translateX(-100px)translateZ(0);
    opacity: 1;
  }
  53% {
    opacity: 0;
  }
  75% {
    opacity: 0;
  }
  100% {
    transform: rotateX(0)translateX(0)translateZ(0);
    top: 25%;
    left: 98vw;
    width: 15px;
    height: 15px;
    opacity: 0;
  }
}

.plx-abduction-wrapper {
  height: 100vh;
  right: 0;
  z-index: 4;
}

.plx-abduction {
  background-image: url(../img/plx-abduction-human.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  z-index: 4;
  animation-name: abduct;
  animation-duration: 20s;
  animation-iteration-count: infinite;
}

*/

/*
  Trees
  ***********************
*/

.plx-trees {
  position: absolute;
  z-index: 5 !important;
  left: 0;
  right: 0;
  width: 160vw;
  height: 125vh;
  background-image: url(../img/plx-trees.svg);
  background-repeat: no-repeat;
  background-size: 110%;
  background-position: bottom center;
  transform: translateZ(0);
}

/* Tablet and smaller portrait */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : portrait) {

    .plx-trees {
      bottom: 0;
      top: -10vh !important
    }
}

/* Mobile portrait */
@media only screen
  and (max-device-width : 767px)
  and (orientation : portrait) {

    .plx-trees  {
      top: auto !important;
    }
}

/* Tablet and smaller landscape */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : landscape) {

  .plx-trees  {
    top: 0;
  }
}

/* Mobile landscape */
@media only screen
  and (max-device-width : 812px)
  and (orientation : landscape) {

  .plx-trees  {
    top: 20vh !important;
  }
}

/* Desktop */
@media only screen
  and (min-device-width : 1025px)
  and (orientation : landscape) {

    .plx-trees {
      bottom: -25%;

    }
}

/* Super Wide Desktop */
@media only screen
  and (min-width : 2560px)
  and (min-height : 975px) {

    .plx-trees  {
      top: auto !important;
      bottom: -15%;
      height: 70vh;
      background-position: top left;
    }
}

/*
  Camera
  ***********************
*/

.plx-camera {
  position: absolute;
  z-index: 5 !important;
  bottom: 0;
  background-image: url(../img/plx-camera.svg);
  background-repeat: no-repeat;
}

/* Tablet and smaller portrait */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : portrait) {

    .plx-camera  {
      top: 50vh !important;
      left: -10vw !important;
      width: 80vw;
      height: auto;
      background-size: cover;
      background-position: center right;
    }
}

/* Mobile portrait */
@media only screen
  and (max-device-width : 767px)
  and (orientation : portrait) {

    .plx-camera  {
      top: 60vh !important;
      left: -35vw !important;
      width: 120vw;
      height: 50vh;
      background-size: contain;
      background-position: center;
    }
}

/* Tablet and smaller landscape */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : landscape) {

  .plx-camera  {
    top: 0;
    width: 70vw;
    height: auto;
    background-size: cover;
    background-position: top right;
  }
}

/* Mobile landscape */
@media only screen
  and (max-device-width : 812px)
  and (orientation : landscape) {

  .plx-camera  {
    width: 50vw;
    left: -5vw !important;
    background-position: center right;
  }
}

/* Desktop */
@media only screen
  and (min-device-width : 1025px)
  and (orientation : landscape) {

    .plx-camera  {
      top: -15vh !important;
      left: -10vw !important;
      width: 80vw;
      height: 150vh;
      background-size: cover;
      background-position: center right;
    }
}

/* Wide Desktop */
@media only screen
  and (min-width : 1920px)
  and (min-height : 1080px) {

    .plx-camera  {
      top: 0;
      left: 0;
      width: 60vw;
      height: 110vh;
    }
}

/* Super Wide Desktop */
@media only screen
  and (min-width : 2560px)
  and (min-height : 975px) {

    .plx-camera  {
      top: -15vh !important;
      left: -15vw !important;
      width: 60vw;
    }
}

/*
  ***********************
  BRAND / LOGO
  ***********************
*/

.brand {

}

.brand-logo {
  background-image: url(../img/dls-logo-white.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  margin-left: auto;
  margin-right: auto;
}

/* Retina display */
@media
  only screen and (-webkit-min-device-pixel-ratio: 2) and ( max-width: 2000px),
  only screen and (   min--moz-device-pixel-ratio: 2) and ( max-width: 2000px),
  only screen and (     -o-min-device-pixel-ratio: 2/1) and ( max-width: 2000px),
  only screen and (        min-device-pixel-ratio: 2) and ( max-width: 2000px),
  only screen and ( -webkit-min-device-pixel-ratio: 2) and ( max-width: 2000px),
  only screen and (   -webkit-min-device-pixel-ratio: 2) and ( max-width: 2000px),
  only screen and (   min-resolution: 192dpi) and ( max-width: 2000px),
  only screen and (   min-resolution: 2dppx) and ( max-width: 2000px) {

    .brand-logo {
      background-image: url(../img/dls-logo-white@2x.png);
    }

}

/* Tablet and smaller portrait */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : portrait) {

    .brand-logo {
      width: 200px;
      height: 356px;
    }

}

/* Tablet and smaller landscape */
@media only screen
  and (max-device-width : 1024px)
  and (orientation : landscape) {

  .brand-logo {
    width: 200px;
    height: 356px;
  }
}

/* Mobile landscape */
@media only screen
  and (max-device-width : 812px)
  and (orientation : landscape) {

  .brand-logo {
    width: 100px;
    height: 178px;
  }
}

/* Desktop */
@media only screen
  and (min-device-width : 1025px)
  and (orientation : landscape) {

    .brand-logo {
      width: 333px;
      height: 593px;
    }

}

.brand-logo-reader {
  position: absolute!important;
  width: 1px!important;
  height: 1px!important;
  padding: 0!important;
  margin: -1px!important;
  overflow: hidden!important;
  clip: rect(0,0,0,0)!important;
  white-space: nowrap!important;
  border: 0!important;
}

/*
  ***********************
  CONTENT
  ***********************
*/

.content {

}

.content-headline {
  font-family: var(--font-sans-serif);
  font-weight: 400;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.1;
}

/* Tablet and smaller */
@media only screen
  and (max-device-width : 1024px) {

    .content-headline {
      font-size: 2rem;
    }

}

/* Desktop */
@media only screen
  and (min-device-width : 1025px) {

    .content-headline {
      font-size: 3rem;
    }

}

.content-text {
  line-height: 1.5;
  text-align: center;
}

/* Tablet and smaller */
@media only screen
  and (max-device-width : 1024px) {

    .content-text {
      font-size: 1.1rem;
    }

}

/* Desktop */
@media only screen
  and (min-device-width : 1025px) {

    .content-text {
      font-size: 1.5rem;
    }

}

.content-audio {
  position: fixed;
  bottom: 40px;
  right: 40px;
}

.content-audio audio {
  visibility: hidden;
}

@media screen and (-webkit-min-device-pixel-ratio:0) {
  .content-audio audio {
    visibility: visible;
  }
}

/*
  ***********************
  COPYRIGHT
  ***********************
*/

.info {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
}

.info-copyright {
  font-family: var(--font-sans-serif);
  font-weight: 400;
  font-size: 12px;
  line-height: 18px;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 1pt;
}
