.font {
  font-family: "ninjago", Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.05em;
}
@font-face {
  font-family: "ninjago";
  src: url("../assets/ninjago_core_bold.woff") format("woff");
}
* {
  margin: 0;
  padding: 0;
}
body {
  font-size: 62.5%;
  background-color: #000000;
}
div {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
}
img {
  display: block;
  max-width: 100%;
}
.center_v {
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
}
.center_h {
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
}
.center_vh {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
}
.noselect {
  user-select: none;
  user-drag: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;
  -ms-user-select: none;
  -ms-user-drag: none;
  -moz-user-select: none;
  -moz-user-drag: none;
}
.button {
  font-size: 8em;
  width: auto;
  height: 1em;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
}
@media all and (max-height: 768px) and (min-aspect-ratio: 1/1) {
  .button {
    font-size: 6em;
  }
}
.button .label {
  position: relative;
  margin-top: 0.15em;
  font-size: 0.8em;
  color: #000000;
  font-family: "ninjago", Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.05em;
}
.button .bg {
  width: 100%;
}
.button .bg .left {
  width: 0.5em;
  left: -0.49em;
  background-image: url("../assets/button_bg_left.png");
}
.button .bg .right {
  width: 0.5em;
  right: -0.49em;
  background-image: url("../assets/button_bg_right.png");
}
.button .bg .mid {
  width: 100%;
  background-image: url("../assets/button_bg_mid.png");
  background-repeat: repeat-x;
}
.button .shadow {
  width: calc(100% + 1em);
  top: 0;
  margin-left: -0.5em;
  border-radius: 50%;
  box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.5);
}
.button .ref {
  width: calc(100% + 1em);
  top: 0;
  margin-left: -0.5em;
  background-image: url("../assets/button_bg_ref.png");
  background-repeat: repeat-x;
}
#bt_fullscreen {
  font-size: 60px;
  width: 1em;
  height: 1em;
  bottom: 20px;
  left: 20px;
}
#bt_fullscreen.on {
  background-image: url("../assets/fullscreen_on.png");
}
#bt_fullscreen.off {
  background-image: url("../assets/fullscreen_off.png");
}
#header {
  width: 100%;
  height: auto;
  padding-top: 20%;
  top: -100px;
}
#header .bg {
  top: 0;
  background-image: url("../assets/header_bg.png");
}
#header .lines {
  top: 0;
  background-image: url("../assets/header_lines.png");
}
#header > .content {
  width: calc(100% - 40px);
  height: calc(85% - 100px);
  left: 20px;
  top: 100px;
  font-family: "ninjago", Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.05em;
}
#header > .content .side {
  position: relative;
  float: left;
  width: 50%;
}
#header > .content .side > div {
  position: relative;
  float: left;
}
#header > .content .side .label {
  width: auto;
  top: 30%;
  font-size: 3vw;
  color: white;
}
#header > .content .side .value {
  width: 30%;
  background-image: url("../assets/header_bg_round.png");
  background-size: contain;
  background-position: center -10px;
}
#header > .content .side .value > .content {
  font-size: 4vw;
  top: 30%;
  text-align: center;
  color: black;
}
#header > .content .side.right > div {
  float: right;
}
#header > .content .side.right > div .label {
  text-align: right;
}
@media all and (max-width: 1250px) {
  #header {
    top: -50px;
  }
  #header > .content {
    height: calc(85% - 50px);
    top: 50px;
  }
}
/* PORTRAIT */
#scene {
  z-index: 0;
}
#scene .projectile {
  font-size: 40px;
  width: 1em;
  height: 1em;
  left: -0.5em;
  top: -0.5em;
}
#scene .projectile .img {
  background-image: url("../assets/projectile_bullet.png");
  background-size: 1em 1em;
}
#scene .projectile .img.left {
  width: 50%;
  left: 0;
  background-position: left center;
}
#scene .projectile .img.right {
  width: 50%;
  right: 0;
  background-position: right center;
}
#cut .line {
  width: 0;
  height: 0;
  transform-origin: 0% 50%;
}
#cut .line svg {
  width: 100%;
  height: 100%;
}
#cut .line svg path {
  fill: #b40000;
}
#overlay > .bg {
  background-color: #000000;
  opacity: 0.6;
}
#overlay > .content {
  width: calc(60% - 20px);
  height: calc(80% - 20px);
  min-width: 500px;
  min-height: 400px;
  max-width: 1000px;
  max-height: 800px;
  left: 40px;
  top: 40px;
  background: url("../assets/overlay_bg.gif");
  background-size: 100% 100%;
  padding: 20px;
  font-family: "ninjago", Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.05em;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
}
@media all and (max-width: 1250px) {
  #overlay > .content {
    width: calc(100% - 20px*4);
    min-width: 300px;
    max-width: 100%;
  }
}
@media all and (max-height: 768px) and (min-aspect-ratio: 1/1) {
  #overlay > .content {
    width: calc(100% - 20px*4);
    max-width: 100%;
  }
}
#overlay > .content > div {
  width: 100%;
  position: relative;
  float: top;
}
#overlay > .content .animation {
  height: 35%;
  background-size: auto 80%;
  background-position: 42% center;
}
#overlay > .content .animation .content {
  width: 0;
  height: 0;
  left: 50%;
  bottom: 15%;
  overflow: visible;
}
#overlay > .content .copy {
  width: 80%;
  height: 40%;
  left: 10%;
  color: #ffffff;
  font-size: 4em;
  text-align: center;
}
@media all and (max-width: 1250px) {
  #overlay > .content .copy {
    font-size: 3.5em;
  }
}
@media all and (max-height: 768px) and (min-aspect-ratio: 1/1) {
  #overlay > .content .copy {
    width: calc(100% - 20px*2);
    left: 20px;
    font-size: 3em;
  }
}
#overlay > .content .copy > span {
  font-size: 200%;
}
#overlay > .content .button_container {
  height: 18%;
}
#preloader > .bg {
  background-image: url("../assets/preloader_bg_pattern.gif");
  background-repeat: repeat;
  background-size: initial;
  background-position: center center;
}
#preloader > .content {
  font-size: 400px;
  width: 1em;
  height: 1em;
  margin-top: -0.12em;
  overflow: visible;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
}
#preloader > .content .img {
  width: 0.75em;
  height: 0.75em;
  left: 0.125em;
  top: 0.125em;
  background-image: url("../assets/preloader_icon_content.jpg");
  background-size: 134% auto;
  background-position: center center;
  border-radius: 50%;
  overflow: hidden;
}
#preloader > .content .ring {
  background-image: url("../assets/preloader_icon_ring.png");
}
#preloader > .content .label {
  height: auto;
  top: 100%;
  color: #ffffff;
  font-size: 0.13em;
  text-align: center;
  font-family: "ninjago", Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.05em;
}
#intro .bg {
  background-image: url("../assets/preloader_bg_pattern.gif");
  background-repeat: repeat;
  background-size: initial;
  background-position: center center;
}
#intro video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#intro .playpause {
  position: absolute;
  width: 30%;
  height: 100%;
  max-width: 200px;
  left: 0;
  right: 0;
  margin: 0 auto;
  background-size: 100% auto;
  background-position: center center;
  background-image: url("../assets/video_icon_play.png");
}
#intro .poster {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: contain;
  background-position: center center;
}
#intro .close {
  font-size: 120px;
  width: 1em;
  height: 1em;
  right: 20px;
  top: 20px;
  background-image: url("../assets/close.png");
}
#intro .button {
  top: initial;
  bottom: 20px !important;
}
#app {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: #73cae5;
  overflow: hidden;
  cursor: pointer;
  opacity: 0;
}
.outline {
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  border: solid 1px #340100;
}
#legal {
  width: calc(100% - 6px);
  height: auto;
  left: 3px;
  bottom: 5px;
  font: normal 7px/7px Arial, Verdana, sans-serif;
  color: #000000;
  text-align: right;
}
#lib {
  width: 0;
  height: 0;
  left: -1000px;
  top: -1000px;
  display: none;
}
/*# sourceMappingURL=main.css.map */