@-webkit-keyframes fadeIn  { from { opacity: 0; } to { opacity: 1; } }
@-moz-keyframes    fadeIn  { from { opacity: 0; } to { opacity: 1; } }
@keyframes         fadeIn  { from { opacity: 0; } to { opacity: 1; } }

@-webkit-keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } }
@-moz-keyframes    fadeOut { from { opacity: 1; } to { opacity: 0; } }
@keyframes         fadeOut { from { opacity: 1; } to { opacity: 0; } }

body, canvas, div {
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    -khtml-user-select: none;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

canvas {
    transform: translate3d(0,0,0);
    -webkit-transform: translate3d(0,0,0);
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

.fade-in {
    opacity: 0;
    -webkit-animation: fadeIn ease-in 1;
    -moz-animation:    fadeIn ease-in 1;
    animation:         fadeIn ease-in 1;
    -webkit-animation-fill-mode: forwards;
    -moz-animation-fill-mode:    forwards;
    animation-fill-mode:         forwards;
    -webkit-animation-duration: 1s;
    -moz-animation-duration:    1s;
    animation-duration:         1s;
}

.fade-out {
    opacity: 0;
    -webkit-animation: fadeOut ease-in 1;
    -moz-animation:    fadeOut ease-in 1;
    animation:         fadeOut ease-in 1;
    -webkit-animation-fill-mode: forwards;
    -moz-animation-fill-mode:    forwards;
    animation-fill-mode:         forwards;
    -webkit-animation-duration: 1s;
    -moz-animation-duration:    1s;
    animation-duration:         1s;
}

#fades {
    width: 100%;
    position: absolute;
    top: 0px;
    background-color: black;
}