body { 
  margin: 0; 
  width: 100%;
  height: 100%;
  //overflow: hidden;
}

canvas { 
  width: 100%; 
  height: 100%;
}
.threed-obj {
    cursor: grab;
    background: url("https://storage.quebecormedia.com/v1/jdx-prod-images/photo/154b3eea-bc25-4bd0-80b2-334f8d463b59_bg-3d.jpg") center center no-repeat;
    background-size: cover;
}



.display_page {
  position: relative;
  width: 100%;
  height: 100%;
  background: #F6EDD0;
  z-index: 1;
}

.before, .after {
  height: 100vw;
  display: block;
  position: relative;
}

/* Loading Animation */

#loading_animation_page {
  visibility: hidden;
  z-index: 2;
}

#loading_animation_div {
  width: 25%;
  height: 25%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#loading_animation_svg {
   width: 100%;
   height: 100%;
}

.loading_animation_lines {
   stroke: #272727;
   stroke-width: 1%;
   stroke-linecap: round;
   animation-name: fade_out_in;
   animation-iteration-count: infinite;
   animation-duration: 900ms;
   animation-timing-function: linear;
}
#loading_animation_line_1 { animation-delay: 0ms; }
#loading_animation_line_2 { animation-delay: 175ms; }
#loading_animation_line_3 { animation-delay: 350ms; }

@keyframes fade_out_in {
   0% { opacity: 1 }
   20% { opacity: 0 }
   100% { opacity: 1 }
}

#loading_animation_insignia {
  position: absolute;
  width: 22%;
  height: 22%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.indicators, .indicators-costumes {
    overflow: hidden;
    white-space: normal;
    z-index: 9999;
    color: #ddc672;
    display: flex;
    text-shadow: 5px 5px 10px #000;
    animation-duration: 3s !important;
}
.gtfo-cta {
    bottom: 10px;
    right: 10px;
    position: fixed;
    z-index: 999;
    cursor: pointer;
}


.indicators img,
.indicators-costumes img {
    height: 70px;
    width: 55px;
}
.gtfo-cta img {
    height: 20px;
    width: 20px;
}

.indicators img, .indicators-costumes img {
    margin-right: 10px;
    margin-top: 10px;
}
 .gtfo-cta img {
    margin: 4% 3% 0;
}

.indicators p {
    font-family: 'Montserrat', sans-serif;
    text-align: left;
    font-size: 18px;
    color: #fff;
    width: 240px;
    margin-top: 15%;
}
.indicators img.ios {
    height: 44px;
    width: 35px;
}
.indicators p.hidden-ios {
    margin-top: 8%;
}
.indicators p.ios-only {
    font-size: 13px;
    margin-top: 8%;
}
.indicators-costumes p {
    font-family: 'Montserrat', sans-serif;
    text-align: left;
    font-size: 18px;
    color: #fff;
    width: 210px;
}
.gtfo-cta {
    border-left: 1px solid #ddc672;
    padding-left: 10px;
}
.gtfo-cta p.big {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
    font-weight: bold;
}
.gtfo-cta p {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    color: #fff;
    margin: 0;
    width: 100px;
}

@media screen and (max-width: 660px) {
    .indicators, .indicators-costumes {
        display: none;
    }
}
@media screen and (min-width: 660px) {
    .threed-obj {
        position: fixed;
        top: 0;
        z-index: 999;
    }
    .indicators {
        position: fixed;
        top: 30%;
        left: 10%;
    }
    .indicators-costumes {
        position: fixed;
        top: 10%;
        left: 10%;
    }
}
@media screen and (max-height: 420px) {
    .indicators {
        top: 17%;
    }
    .indicators-costumes {
        top: 72%;
        left: 30%;
        text-shadow: 5px 3px 3px #000;
        background-color: rgba(0,0,0,0.6);
        padding: 10px;
    }
}