/* roboto-300 - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../src/fonts/roboto-v18-latin-300.eot');
  /* IE9 Compat Modes */
  src: local('Roboto Light'), local('Roboto-Light'), url('../src/fonts/roboto-v18-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../src/fonts/roboto-v18-latin-300.woff2') format('woff2'), /* Super Modern Browsers */ url('../src/fonts/roboto-v18-latin-300.woff') format('woff'), /* Modern Browsers */ url('../src/fonts/roboto-v18-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */ url('../src/fonts/roboto-v18-latin-300.svg#Roboto') format('svg');
  /* Legacy iOS */
}
/* roboto-regular - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('../src/fonts/roboto-v18-latin-regular.eot');
  /* IE9 Compat Modes */
  src: local('Roboto'), local('Roboto-Regular'), url('../src/fonts/roboto-v18-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../src/fonts/roboto-v18-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */ url('../src/fonts/roboto-v18-latin-regular.woff') format('woff'), /* Modern Browsers */ url('../src/fonts/roboto-v18-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */ url('../src/fonts/roboto-v18-latin-regular.svg#Roboto') format('svg');
  /* Legacy iOS */
}
/* roboto-500 - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: url('../src/fonts/roboto-v18-latin-500.eot');
  /* IE9 Compat Modes */
  src: local('Roboto Medium'), local('Roboto-Medium'), url('../src/fonts/roboto-v18-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../src/fonts/roboto-v18-latin-500.woff2') format('woff2'), /* Super Modern Browsers */ url('../src/fonts/roboto-v18-latin-500.woff') format('woff'), /* Modern Browsers */ url('../src/fonts/roboto-v18-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */ url('../src/fonts/roboto-v18-latin-500.svg#Roboto') format('svg');
  /* Legacy iOS */
}
/* roboto-700 - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: url('../src/fonts/roboto-v18-latin-700.eot');
  /* IE9 Compat Modes */
  src: local('Roboto Bold'), local('Roboto-Bold'), url('../src/fonts/roboto-v18-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../src/fonts/roboto-v18-latin-700.woff2') format('woff2'), /* Super Modern Browsers */ url('../src/fonts/roboto-v18-latin-700.woff') format('woff'), /* Modern Browsers */ url('../src/fonts/roboto-v18-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */ url('../src/fonts/roboto-v18-latin-700.svg#Roboto') format('svg');
  /* Legacy iOS */
}
/** Styles **/
* {
  box-sizing: border-box;
}
html {
  width: 100%;
  height: 100%;
  background: #ad8ddc;
  background: linear-gradient(to bottom, #ef9a67 0%, #ee9a69 43%, #e19780 57%, #b98fc7 87%, #ad8ddc 100%);
  overflow: hidden;
}
body {
  margin: 0;
  font-family: "Roboto", sans-serif;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
#wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 10;
  -webkit-overflow-scrolling: touch;
}
#wrapper-scroll {
  height: 400%;
  width: 100%;
  position: relative;
}
@media only screen and (min-device-width: 830px) and (max-device-width: 1024px) and (orientation: landscape) {
  #wrapper-scroll {
    height: calc(400% + 300px);
  }
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  #wrapper-scroll {
    height: calc(450%);
  }
}
#loader {
  position: fixed;
  width: 50vw;
  top: calc(50vh - 10vw);
  right: 25vw;
  transition: top 0.5s ease-in-out, right 0.5s ease-in-out, width 0.5s ease-in-out;
}
#loader svg {
  width: 100%;
}
body.ready #loader {
  position: absolute;
  top: 16px;
  right: 16px;
  bottom: auto;
  left: auto;
  width: 140px;
  height: auto;
}
#wave-canvas {
  opacity: 0;
  transition: opacity 0.5s ease-in-out 0.5s;
  margin: 0 0;
  z-index: 0;
  position: absolute;
  pointer-events: none;
  z-index: -1;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
body.ready #wave-canvas {
  opacity: 1;
}
#background {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #ef9a67;
  /* Old browsers */
  background: linear-gradient(to bottom, #ef9a67 0%, #ee9a69 43%, #e19780 57%, #b98fc7 87%, #ad8ddc 100%);
  background-repeat: no-repeat;
}
#snap-markers {
  position: absolute;
  width: 100%;
  height: 100%;
}
#snap-markers .scroll-snap {
  position: absolute;
  width: 100%;
}
#snap-markers .scroll-snap.scroll-snap-1 {
  top: 0vh;
  height: 100vh;
}
#snap-markers .scroll-snap.scroll-snap-2 {
  top: 100vh;
  height: 100vh;
}
#snap-markers .scroll-snap.scroll-snap-3 {
  top: 200vh;
  height: calc(100% - 200vh);
}
.scene {
  opacity: 0;
  transition: opacity 0.5s ease-in-out 0.1s;
  position: fixed;
  left: 0;
  right: 0;
  top: 50vh;
  margin: -20vw auto 0;
  width: 40vw;
  height: 40vw;
  max-width: 400px;
  max-height: 400px;
  perspective: 100vw;
  z-index: 20;
  pointer-events: none;
}
.scene.static {
  top: 250vh;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .scene {
    width: 30vw;
    height: 30vw;
  }
}
body.ready .scene {
  opacity: 1;
}
.cube {
  width: 100%;
  height: 100%;
  position: relative;
  transform-style: preserve-3d;
  transform: translateZ(-100px);
}
.cube .cube-face {
  position: absolute;
  width: 100%;
  height: 100%;
  text-align: center;
}
.cube .cube-face p {
  margin: 0 0 2.4vw;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .cube .cube-face p {
    margin: 0 0 1.8vw;
  }
}
.cube .cube-face img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 60%;
  height: auto;
}
.cube .cube-face .percent {
  font-size: 9vw;
  color: #1b5d78;
  font-weight: bold;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .cube .cube-face .percent {
    font-size: 6.75vw;
  }
}
.cube .cube-face .more {
  font-size: 4vw;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .cube .cube-face .more {
    font-size: 3vw;
  }
}
.cube .cube-face .receive {
  font-size: 3.2vw;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .cube .cube-face .receive {
    font-size: 2.4vw;
  }
}
.cube .cube-face a.blackbox {
  color: #3d3d3d;
  font-weight: bold;
  text-decoration: none;
  border-bottom: 1px solid #3d3d3d;
  pointer-events: all;
}
.cube .cube-face.cube-face-front {
  background: #000;
  transform: rotateY(-90deg) translateX(50%) rotateY(90deg);
}
.cube .cube-face.cube-face-bottom,
.cube .cube-face.cube-face-back {
  padding-top: 6.4vw;
  color: #3d3d3d;
  font-size: 2.4vw;
}
.cube .cube-face.cube-face-bottom.cube-face-bottom,
.cube .cube-face.cube-face-back.cube-face-bottom {
  background: #b8e6e7;
  transform: translateY(50%) rotateX(-90deg);
}
.cube .cube-face.cube-face-bottom.cube-face-back,
.cube .cube-face.cube-face-back.cube-face-back {
  background: #f6cd98;
  transform: rotateY(-90deg) translateX(-50%) rotateY(90deg) rotateX(180deg);
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .cube .cube-face.cube-face-bottom,
  .cube .cube-face.cube-face-back {
    padding-top: 4.8vw;
    font-size: 1.8vw;
  }
}
.schachtel {
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
  position: absolute;
  bottom: 0px;
  width: 100%;
  margin: 0 auto;
  left: 0;
  right: 0;
}
.schachtel img.box {
  width: 50%;
  display: block;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  max-width: 300px;
  left: 6.25%;
  user-select: none;
  -webkit-user-drag: none;
}
.schachtel .box-animation {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 50%;
  display: block;
  margin: 0 auto;
  max-width: 300px;
  left: 12.5%;
}
.schachtel .box-animation img {
  position: absolute;
  display: none;
  width: 100%;
  user-select: none;
  -webkit-user-drag: none;
}
.schachtel .box-animation .active {
  display: block;
}
.schachtel .buttons {
  padding: 6vw 0;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .schachtel .buttons {
    padding: 6vh 0;
    position: absolute;
    bottom: 0;
    left: -60%;
    right: -60%;
  }
}
.schachtel .buttons a {
  display: block;
  float: left;
  width: 50%;
  text-align: center;
}
.schachtel .buttons a img {
  height: auto;
  max-width: 100%;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .schachtel .buttons a img {
    max-height: 15vh;
  }
}
.schachtel #bubble-canvas {
  position: absolute;
  bottom: 0px;
  z-index: 0;
  pointer-events: none;
}
.schachtel .bubble {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 50px;
  height: 50px;
  border-radius: 100%;
}
.schachtel .bubble:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background-image: url(./bubble.svg);
  background-position: center;
  background-size: contain;
  opacity: 1;
}
.schachtel .bubble:before {
  content: attr(data-text);
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  color: rgba(255, 255, 255, 0);
  font-size: 0px;
  white-space: nowrap;
  z-index: 1;
  width: auto;
  height: auto;
  overflow: visible;
}
.schachtel .bubble.showText:before {
  transition: color 0.3s, font-size 0.3s;
  color: #ffffff;
  font-size: 25px;
}
.schachtel .bubble.showText:after {
  opacity: 0;
  width: 200%;
  height: 200%;
  left: -50%;
  right: -50%;
  top: -50%;
  bottom: -50%;
  transition-property: opacity, width, height, left, right, top, bottom;
  transition-duration: 0.3s;
}
@media only screen and (min-device-width: 480px) and (max-device-width: 830px) and (orientation: landscape) {
  .schachtel {
    max-width: 300px;
  }
}
body.ready .schachtel {
  opacity: 1;
}
@media screen and (min-width: 1000px) {
  #loader {
    width: 400px;
    top: calc(50vh - 50px);
    right: calc(50vw - 200px);
  }
  .scene {
    position: fixed;
    left: 0;
    right: 0;
    margin-top: -200px;
  }
  .cube .cube-face.cube-face-bottom,
  .cube .cube-face.cube-face-back {
    padding-top: 64px;
    font-size: 24px;
  }
  .cube .cube-face p {
    margin: 0 0 24px;
  }
  .cube .cube-face .percent {
    font-size: 90px;
  }
  .cube .cube-face .more {
    font-size: 40px;
  }
  .cube .cube-face .receive {
    font-size: 32px;
  }
  .schachtel {
    width: 400px;
  }
}
/*# sourceMappingURL=main.css.map */