/* ---------- SLIDE UP ---------- */
.slide-up:not(.loaded) {
    transform: translateY(100px);
    opacity: 0;
}

.slide-up.loaded {
    transform: translateY(0);
    opacity: 1;
}

/* ---------- SLIDE DOWN ---------- */
.slide-down:not(.loaded) {
    transform: translateY(-80px);
    opacity: 0;
}

.slide-down.loaded {
    transform: translateY(0);
    opacity: 1;
}

/* ---------- SLIDE LEFT ---------- */
.slide-left:not(.loaded) {
    transform: translateX(150px);
    opacity: 0;
}

.slide-left.loaded {
    transform: translateX(0);
    opacity: 1;
}

/* ---------- SLIDE RIGHT ---------- */
.slide-right:not(.loaded) {
    transform: translateX(-150px);
    opacity: 0;
}

.slide-right.loaded {
    transform: translateX(0);
    opacity: 1;
}

/* ---------- FADE IN ---------- */
.fade-in:not(.loaded) {
    opacity: 0;
    transition: all 1.5s cubic-bezier(.33,1,.68,1) !important;
}

.fade-in.loaded {
    opacity: 1;
    transition: all 1.5s cubic-bezier(.33,1,.68,1) !important;
}

/* TRANSITIONS */
.slide-up:not(.loaded), .slide-up.loaded {
    transition: all 1.4s cubic-bezier(.33,1,.68,1) !important;
}

.slide-down:not(.loaded), .slide-down.loaded, .slide-left:not(.loaded), .slide-left.loaded, .slide-right:not(.loaded), .slide-right.loaded {
    transition: opacity 1.3s, transform 1.3s cubic-bezier(.33,1,.68,1) !important;
}

/* Delay */
.slide-right.delayed.loaded {
    transition-delay: .2s !important;
}

/* ---------- LOADER ---------- */
.loader {
    position: fixed;
    background-color: #222221;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    transform: scaleX(1);
    transform-origin: left;
    z-index: 99999;
    transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
    -webkit-transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
    -moz-transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
    -o-transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
}

.loader.loaded {
    transform: scaleX(0);
    transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
    -webkit-transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
    -moz-transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
    -o-transition: transform 1.3s cubic-bezier(0.87, 0, 0.13, 1);
}

/* ---------- LOADING CONTROLLER ---------- */
main {
    transition: opacity 0.7s cubic-bezier(0.87, 0, 0.13, 1);
    -webkit-transition: opacity 0.7s cubic-bezier(0.87, 0, 0.13, 1);
    -moz-transition: opacity 0.7s cubic-bezier(0.87, 0, 0.13, 1);
    -o-transition: opacity 0.7s cubic-bezier(0.87, 0, 0.13, 1);
}

main:not(.loaded) {
    opacity: 0;
}

main.loaded {
    opacity: 1;
}


/* ---------- TYPING ---------- */
.typing {
    opacity: 0;
}

.type {
    opacity: 1;
}

.typing-bar {
    border: 1px solid;
    border-color: inherit;
    font-size: 70%;
    padding-top: 1.1rem;
    animation: blinkTextCursor 0.7s steps(1) infinite;
}

.typing-bar.written {
    border-color: transparent;
}

@keyframes blinkTextCursor {
    12% {
        border-color: transparent;
    }
}