/* 4 classes: navInLeft, navInRight, navOutLeft, navOutRight */


/*****************************************/


/* Soft Scale */


/*****************************************/

.fxSoftScale .navOutNext {
    -webkit-animation: scaleUp 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: scaleUp 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxSoftScale .navInNext {
    -webkit-animation: scaleDownUp 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: scaleDownUp 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxSoftScale .navOutPrev {
    -webkit-animation: scaleDown 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: scaleDown 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxSoftScale .navInPrev {
    -webkit-animation: scaleUpDown 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: scaleUpDown 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

@-webkit-keyframes scaleUp {
    to {
        -webkit-transform: scale(1.2);
        opacity: 0;
    }
}

@keyframes scaleUp {
    to {
        transform: scale(1.2);
        opacity: 0;
    }
}

@-webkit-keyframes scaleDownUp {
    from {
        opacity: 0;
        -webkit-transform: scale(0.9);
    }
    to {
        opacity: 1;
        -webkit-transform: scale(1);
    }
}

@keyframes scaleDownUp {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@-webkit-keyframes scaleDown {
    to {
        opacity: 0;
        -webkit-transform: scale(0.9);
    }
}

@keyframes scaleDown {
    to {
        opacity: 0;
        transform: scale(0.9);
    }
}

@-webkit-keyframes scaleUpDown {
    from {
        -webkit-transform: scale(1.2);
    }
    to {
        opacity: 1;
        -webkit-transform: scale(1);
    }
}

@keyframes scaleUpDown {
    from {
        transform: scale(1.2);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}


/*****************************************/


/* Press away */


/*****************************************/

.fxPressAway .navOutNext {
    -webkit-animation: slideOutScaleRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideOutScaleRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxPressAway .navInNext {
    opacity: 1;
    -webkit-animation: slideInFromLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideInFromLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxPressAway .navOutPrev {
    -webkit-animation: slideOutScaleLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideOutScaleLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxPressAway .navInPrev {
    opacity: 1;
    -webkit-animation: slideInFromRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideInFromRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

@-webkit-keyframes slideOutScaleRight {
    to {
        -webkit-transform: translateX(100%) scale(0.9);
        opacity: 0;
    }
}

@keyframes slideOutScaleRight {
    to {
        transform: translateX(100%) scale(0.9);
        opacity: 0;
    }
}

@-webkit-keyframes slideInFromLeft {
    from {
        -webkit-transform: translateX(-100%);
    }
    to {
        -webkit-transform: translateX(0);
    }
}

@keyframes slideInFromLeft {
    from {
        transform: translateX(-100%);
    }
    to {
        transform: translateX(0);
    }
}

@-webkit-keyframes slideOutScaleLeft {
    to {
        -webkit-transform: translateX(-100%) scale(0.9);
        opacity: 0;
    }
}

@keyframes slideOutScaleLeft {
    to {
        transform: translateX(-100%) scale(0.9);
        opacity: 0;
    }
}

@-webkit-keyframes slideInFromRight {
    from {
        -webkit-transform: translateX(100%);
    }
    to {
        -webkit-transform: translateX(0);
    }
}

@keyframes slideInFromRight {
    from {
        transform: translateX(100%);
    }
    to {
        transform: translateX(0);
    }
}


/*****************************************/


/* Side Swing */


/*****************************************/

.fxSideSwing .navOutNext {
    -webkit-animation: slideOutScaleRight 1.2s forwards;
    animation: slideOutScaleRight 1.2s forwards;
    -webkit-animation-timing-function: cubic-bezier(1, 0, 0, 1);
    /* older webkit */
    -webkit-animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
    animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
}

.fxSideSwing .navInNext {
    opacity: 1;
    -webkit-animation: slideInFromLeft 1.2s forwards;
    animation: slideInFromLeft 1.2s forwards;
    -webkit-animation-timing-function: cubic-bezier(1, 0, 0, 1);
    /* older webkit */
    -webkit-animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
    animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
}

.fxSideSwing .navOutPrev {
    -webkit-animation: slideOutScaleLeft 1.2s forwards;
    animation: slideOutScaleLeft 1.2s forwards;
    -webkit-animation-timing-function: cubic-bezier(1, 0, 0, 1);
    /* older webkit */
    -webkit-animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
    animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
}

.fxSideSwing .navInPrev {
    opacity: 1;
    -webkit-animation: slideInFromRight 1.2s forwards;
    animation: slideInFromRight 1.2s forwards;
    -webkit-animation-timing-function: cubic-bezier(1, 0, 0, 1);
    /* older webkit */
    -webkit-animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
    animation-timing-function: cubic-bezier(1, -0.2, 0, 1);
}


/*****************************************/


/* Fortune wheel */


/*****************************************/

.fxFortuneWheel .itemwrap {
    -webkit-perspective: 1600px;
    perspective: 1600px;
}

.fxFortuneWheel .navOutNext {
    -webkit-animation: slideOutScaleRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideOutScaleRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxFortuneWheel .navInNext {
    -webkit-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
    -webkit-animation: rotateInFromLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: rotateInFromLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxFortuneWheel .navOutPrev {
    -webkit-animation: slideOutScaleLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideOutScaleLeft 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxFortuneWheel .navInPrev {
    -webkit-transform-origin: 0% 50%;
    transform-origin: 0% 50%;
    -webkit-animation: rotateInFromRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: rotateInFromRight 1.2s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

@-webkit-keyframes rotateInFromLeft {
    from {
        -webkit-transform: translateX(-100%) rotateY(-55deg);
    }
    to {
        -webkit-transform: translateX(0) rotateY(0deg);
        opacity: 1;
    }
}

@keyframes rotateInFromLeft {
    from {
        transform: translateX(-100%) rotateY(-55deg);
    }
    to {
        transform: translateX(0) rotateY(0deg);
        opacity: 1;
    }
}

@-webkit-keyframes rotateInFromRight {
    from {
        -webkit-transform: translateX(100%) rotateY(55deg);
    }
    to {
        -webkit-transform: translateX(0) rotateY(0deg);
        opacity: 1;
    }
}

@keyframes rotateInFromRight {
    from {
        transform: translateX(100%) rotateY(55deg);
    }
    to {
        transform: translateX(0) rotateY(0deg);
        opacity: 1;
    }
}


/*****************************************/


/* Swipe */


/*****************************************/

.fxSwipe .navOutNext {
    -webkit-animation: decreaseHeight 0.8s forwards ease-in-out;
    animation: decreaseHeight 0.8s forwards ease-in-out;
}

.fxSwipe .navInNext {
    -webkit-animation: show 0.8s forwards ease-in-out;
    animation: show 0.8s forwards ease-in-out;
}

.fxSwipe .navOutPrev {
    -webkit-animation: hide 0.8s forwards ease-in-out;
    animation: hide 0.8s forwards ease-in-out;
}

.fxSwipe .navInPrev {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: increaseHeight 0.8s forwards ease-in-out;
    animation: increaseHeight 0.8s forwards ease-in-out;
}

@-webkit-keyframes decreaseHeight {
    to {
        height: 0;
    }
}

@keyframes decreaseHeight {
    to {
        height: 0;
    }
}

@-webkit-keyframes show {
    0% {
        opacity: 0;
    }
    1%,
    100% {
        opacity: 1;
    }
}

@keyframes show {
    0% {
        opacity: 0;
    }
    1%,
    100% {
        opacity: 1;
    }
}

@-webkit-keyframes hide {
    0%,
    99% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@keyframes hide {
    0%,
    99% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@-webkit-keyframes increaseHeight {
    from {
        height: 0;
    }
    to {
        height: 100%;
    }
}

@keyframes increaseHeight {
    from {
        height: 0;
    }
    to {
        height: 100%;
    }
}


/*****************************************/


/* Push reveal */


/*****************************************/

.fxPushReveal .navOutNext {
    opacity: 1;
    -webkit-animation: slideOutBottom 0.7s forwards ease-in-out;
    animation: slideOutBottom 0.7s forwards ease-in-out;
}

.fxPushReveal .navInNext {
    opacity: 1;
    -webkit-animation: slideInHalfFromTop 0.7s forwards ease-in-out;
    animation: slideInHalfFromTop 0.7s forwards ease-in-out;
}

.fxPushReveal .navOutPrev {
    opacity: 1;
    -webkit-animation: slideOutHalfTop 0.7s forwards ease-in-out;
    animation: slideOutHalfTop 0.7s forwards ease-in-out;
}

.fxPushReveal .navInPrev {
    opacity: 1;
    z-index: 1001;
    -webkit-animation: slideInFromBottom 0.7s forwards ease-in-out;
    animation: slideInFromBottom 0.7s forwards ease-in-out;
}

@-webkit-keyframes slideOutBottom {
    to {
        -webkit-transform: translateY(100%);
    }
}

@keyframes slideOutBottom {
    to {
        transform: translateY(100%);
    }
}

@-webkit-keyframes slideInHalfFromTop {
    from {
        -webkit-transform: translateY(-50%);
    }
    to {
        -webkit-transform: translateY(0);
    }
}

@keyframes slideInHalfFromTop {
    from {
        transform: translateY(-50%);
    }
    to {
        transform: translateY(0);
    }
}

@-webkit-keyframes slideOutHalfTop {
    to {
        -webkit-transform: translateY(-50%);
    }
}

@keyframes slideOutHalfTop {
    to {
        transform: translateY(-50%);
    }
}

@-webkit-keyframes slideInFromBottom {
    from {
        -webkit-transform: translateY(100%);
    }
    to {
        -webkit-transform: translateY(0);
    }
}

@keyframes slideInFromBottom {
    from {
        transform: translateY(100%);
    }
    to {
        transform: translateY(0);
    }
}


/*****************************************/


/* Snap in */


/*****************************************/

.fxSnapIn .navOutNext {
    -webkit-animation: slideOutLeft 0.5s forwards ease-in;
    animation: slideOutLeft 0.5s forwards ease-in;
}

.fxSnapIn .navInNext {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: slideFromRightFast 0.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideFromRightFast 0.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxSnapIn .navOutPrev {
    -webkit-animation: slideOutRight 0.5s forwards ease-in;
    animation: slideOutRight 0.5s forwards ease-in;
}

.fxSnapIn .navInPrev {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: slideFromLeftFast 0.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideFromLeftFast 0.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxSnapIn li::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    background-color: rgba(0, 0, 0, 0.8);
    -webkit-transition: opacity 0.4s 0.1s ease-in;
    transition: opacity 0.4s 0.1s ease-in;
}

.fxSnapIn .navOutPrev::after,
.fxSnapIn .navOutNext::after {
    opacity: 1;
}

@-webkit-keyframes slideOutLeft {
    to {
        -webkit-transform: translateX(-10%);
    }
}

@keyframes slideOutLeft {
    to {
        transform: translateX(-10%);
    }
}

@-webkit-keyframes slideFromRightFast {
    0%,
    50% {
        -webkit-transform: translateX(100%);
    }
    100% {
        -webkit-transform: translateX(0%);
    }
}

@keyframes slideFromRightFast {
    0%,
    50% {
        transform: translateX(100%);
    }
    100% {
        transform: translateX(0%);
    }
}

@-webkit-keyframes slideOutRight {
    to {
        -webkit-transform: translateX(10%);
    }
}

@keyframes slideOutRight {
    to {
        transform: translateX(10%);
    }
}

@-webkit-keyframes slideFromLeftFast {
    0%,
    50% {
        -webkit-transform: translateX(-100%);
    }
    100% {
        -webkit-transform: translateX(0%);
    }
}

@keyframes slideFromLeftFast {
    0%,
    50% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(0%);
    }
}


/*****************************************/


/* Let me in */


/*****************************************/

.fxLetMeIn .itemwrap {
    -webkit-perspective: 1600px;
    perspective: 1600px;
}

.fxLetMeIn .navOutNext {
    -webkit-transform-origin: 0% 50%;
    transform-origin: 0% 50%;
    -webkit-animation: rotateOutRight 0.5s forwards ease-in-out;
    animation: rotateOutRight 0.5s forwards ease-in-out;
}

.fxLetMeIn .navInNext {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: slideFromRightFast 0.5s forwards ease;
    animation: slideFromRightFast 0.5s forwards ease;
}

.fxLetMeIn .navOutPrev {
    -webkit-transform-origin: 100% 0%;
    transform-origin: 100% 0%;
    -webkit-animation: rotateOutLeft 0.5s forwards ease-in-out;
    animation: rotateOutLeft 0.5s forwards ease-in-out;
}

.fxLetMeIn .navInPrev {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: slideFromLeftFast 0.5s forwards ease;
    animation: slideFromLeftFast 0.5s forwards ease;
}

.fxLetMeIn li::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    background-color: rgba(0, 0, 0, 0.6);
    -webkit-transition: opacity 0.5s ease-in-out;
    transition: opacity 0.5s ease-in-out;
}

.fxLetMeIn .navOutPrev::after,
.fxLetMeIn .navOutNext::after {
    opacity: 1;
}

@-webkit-keyframes rotateOutRight {
    to {
        -webkit-transform: rotateY(10deg);
    }
}

@keyframes rotateOutRight {
    to {
        transform: rotateY(10deg);
    }
}

@-webkit-keyframes rotateOutLeft {
    to {
        -webkit-transform: rotateY(-10deg);
    }
}

@keyframes rotateOutLeft {
    to {
        transform: rotateY(-10deg);
    }
}


/*****************************************/


/* Stick it */


/*****************************************/

.fxStickIt .itemwrap {
    -webkit-perspective: 1600px;
    perspective: 1600px;
}

.fxStickIt .navOutNext {
    -webkit-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
    -webkit-animation: rotateBottomSideOut 0.8s forwards ease-in;
    animation: rotateBottomSideOut 0.8s forwards ease-in;
}

.fxStickIt .navInNext {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: slideInFromBottomDelayed 0.8s forwards;
    animation: slideInFromBottomDelayed 0.8s forwards;
}

.fxStickIt .navOutPrev {
    opacity: 1;
    -webkit-animation: slideOutToBottom 0.8s forwards;
    animation: slideOutToBottom 0.8s forwards;
}

.fxStickIt .navInPrev {
    -webkit-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
    -webkit-animation: rotateBottomSideIn 0.8s 0.1s forwards ease-in;
    animation: rotateBottomSideIn 0.8s 0.1s forwards ease-in;
}

@-webkit-keyframes rotateBottomSideOut {
    40% {
        -webkit-transform: rotateX(-15deg);
        -webkit-animation-timing-function: ease-out;
    }
    100% {
        opacity: 0;
        -webkit-transform: scale(0.8) translateZ(-200px);
    }
}

@keyframes rotateBottomSideOut {
    40% {
        transform: rotateX(-15deg);
        animation-timing-function: ease-out;
    }
    100% {
        opacity: 0;
        transform: scale(0.8) translateZ(-200px);
    }
}

@-webkit-keyframes slideInFromBottomDelayed {
    0%,
    30% {
        -webkit-transform: translateY(100%);
    }
    100% {
        -webkit-transform: translateY(0);
    }
}

@keyframes slideInFromBottomDelayed {
    0%,
    30% {
        transform: translateY(100%);
    }
    100% {
        transform: translateY(0);
    }
}

@-webkit-keyframes rotateBottomSideIn {
    0% {
        opacity: 0;
        -webkit-transform: scale(0.8) translateZ(-200px);
    }
    60% {
        -webkit-transform: scale(1) translateZ(0) rotateX(-15deg);
        -webkit-animation-timing-function: ease-out;
    }
    100% {
        opacity: 1;
        -webkit-transform: scale(1) translateZ(0) rotateX(0deg);
    }
}

@keyframes rotateBottomSideIn {
    0% {
        opacity: 0;
        transform: scale(0.8) translateZ(-200px);
    }
    60% {
        transform: scale(1) translateZ(0) rotateX(-15deg);
        animation-timing-function: ease-out;
    }
    100% {
        opacity: 1;
        transform: scale(1) translateZ(0) rotateX(0deg);
    }
}


/*****************************************/


/* Archive me */


/*****************************************/

.fxArchiveMe .navOutNext {
    -webkit-animation: scaleHalfDown 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: scaleHalfDown 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxArchiveMe .navInNext {
    z-index: 1001;
    opacity: 1;
    -webkit-animation: slideInFromBottom 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideInFromBottom 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxArchiveMe .navOutPrev {
    -webkit-animation: slideOutToBottom 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: slideOutToBottom 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxArchiveMe .navInPrev {
    -webkit-animation: scaleHalfUp 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: scaleHalfUp 0.7s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxArchiveMe li::before,
.fxArchiveMe li::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    background-color: rgba(0, 0, 0, 0.7);
    -webkit-transition: opacity 0.7s cubic-bezier(0.7, 0, 0.3, 1);
    transition: opacity 0.7s cubic-bezier(0.7, 0, 0.3, 1);
}

.fxArchiveMe li::after,
.fxArchiveMe .navOutNext::before {
    opacity: 1;
}

.fxArchiveMe li::before,
.fxArchiveMe li.current::after,
.fxArchiveMe .navInNext::after,
.fxArchiveMe .navInPrev::after {
    opacity: 0;
}

.fxArchiveMe .navInNext::after {
    -webkit-transition: none;
    transition: none;
}

@-webkit-keyframes scaleHalfDown {
    to {
        -webkit-transform: scale(0.6);
        opacity: 0;
    }
}

@keyframes scaleHalfDown {
    to {
        transform: scale(0.6);
        opacity: 0;
    }
}

@-webkit-keyframes slideOutToBottom {
    to {
        -webkit-transform: translateY(100%);
    }
}

@keyframes slideOutToBottom {
    to {
        transform: translateY(100%);
    }
}

@-webkit-keyframes scaleHalfUp {
    from {
        opacity: 0;
        -webkit-transform: scale(0.6);
    }
    to {
        opacity: 1;
        -webkit-transform: scale(1);
    }
}

@keyframes scaleHalfUp {
    from {
        opacity: 0;
        transform: scale(0.6);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}


/*****************************************/


/* Vertical growth */


/*****************************************/

.fxVGrowth .navOutNext {
    -webkit-animation: scaleDown 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
    animation: scaleDown 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
}

.fxVGrowth .navInNext {
    z-index: 1001;
    opacity: 1;
    -webkit-transform-origin: 50% 100%;
    transform-origin: 50% 100%;
    -webkit-animation: maximize 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
    animation: maximize 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
}

.fxVGrowth .navOutPrev {
    -webkit-animation: scaleDown 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
    animation: scaleDown 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
}

.fxVGrowth .navInPrev {
    z-index: 1001;
    opacity: 1;
    -webkit-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
    -webkit-animation: maximize 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
    animation: maximize 0.6s forwards cubic-bezier(0.6, 0, 0.4, 1);
}

@-webkit-keyframes maximize {
    from {
        -webkit-transform: scale(0);
    }
    to {
        -webkit-transform: scale(1);
    }
}

@keyframes maximize {
    from {
        transform: scale(0);
    }
    to {
        transform: scale(1);
    }
}


/*****************************************/


/* Slide Behind */


/* From https://github.com/hakimel/kontext by Hakim El Hattab, http://hakim.se */


/*****************************************/

.fxSlideBehind .itemwrap {
    -webkit-perspective: 1000px;
    perspective: 1000px;
}

.fxSlideBehind .navOutNext {
    -webkit-animation: hideLeft 0.8s forwards;
    animation: hideLeft 0.8s forwards;
}

.fxSlideBehind .navInNext {
    -webkit-animation: showRight 0.8s forwards;
    animation: showRight 0.8s forwards;
}

.fxSlideBehind .navOutPrev {
    -webkit-animation: hideRight 0.8s forwards;
    animation: hideRight 0.8s forwards;
}

.fxSlideBehind .navInPrev {
    -webkit-animation: showLeft 0.8s forwards;
    animation: showLeft 0.8s forwards;
}

@-webkit-keyframes hideLeft {
    0% {
        -webkit-transform: translateZ( 0px);
    }
    40% {
        -webkit-transform: translate( 0, -40%) scale( 0.8) rotateX( -20deg);
        z-index: 9999;
    }
    100% {
        opacity: 1;
        -webkit-transform: translateZ( -400px);
    }
}

@keyframes hideLeft {
    0% {
        transform: translateZ( 0px);
    }
    40% {
        transform: translate( 0, -40%) scale( 0.8) rotateX( -20deg);
        z-index: 9999;
    }
    100% {
        opacity: 1;
        transform: translateZ( -400px);
    }
}

@-webkit-keyframes showRight {
    0% {
        -webkit-transform: translateZ( -400px);
        opacity: 1;
    }
    40% {
        -webkit-transform: translate( 0, 40%) scale( 0.8) rotateX( 20deg);
        opacity: 1;
    }
    41% {
        -webkit-transform: translate( 0, 40%) scale( 0.8) rotateX( 20deg);
        opacity: 1;
        z-index: 9999;
    }
    100% {
        -webkit-transform: translateZ( 0px);
        opacity: 1;
        z-index: 9999;
    }
}

@keyframes showRight {
    0% {
        transform: translateZ( -400px);
        opacity: 1;
    }
    40% {
        transform: translate( 0, 40%) scale( 0.8) rotateX( 20deg);
        opacity: 1;
    }
    41% {
        transform: translate( 0, 40%) scale( 0.8) rotateX( 20deg);
        opacity: 1;
        z-index: 9999;
    }
    100% {
        transform: translateZ( 0px);
        opacity: 1;
        z-index: 9999;
    }
}

@-webkit-keyframes hideRight {
    0% {
        -webkit-transform: translateZ( 0px);
    }
    40% {
        -webkit-transform: translate( 0, 40%) scale( 0.8) rotateX( 20deg);
        z-index: 9999;
    }
    100% {
        opacity: 1;
        -webkit-transform: translateZ( -400px);
    }
}

@keyframes hideRight {
    0% {
        transform: translateZ( 0px);
    }
    40% {
        transform: translate( 0, 40%) scale( 0.8) rotateX( 20deg);
        z-index: 9999;
    }
    100% {
        opacity: 1;
        transform: translateZ( -400px);
    }
}

@-webkit-keyframes showLeft {
    0% {
        -webkit-transform: translateZ( -400px);
        opacity: 1;
    }
    40% {
        -webkit-transform: translate( 0, -40%) scale( 0.8) rotateX( -20deg);
        opacity: 1;
    }
    41% {
        -webkit-transform: translate( 0, -40%) scale( 0.8) rotateX( -20deg);
        opacity: 1;
        z-index: 9999;
    }
    100% {
        -webkit-transform: translateZ( 0px);
        opacity: 1;
        z-index: 9999;
    }
}

@keyframes showLeft {
    0% {
        transform: translateZ( -400px);
        opacity: 1;
    }
    40% {
        transform: translate( 0, -40%) scale( 0.8) rotateX( -20deg);
        opacity: 1;
    }
    41% {
        transform: translate( 0, -40%) scale( 0.8) rotateX( -20deg);
        opacity: 1;
        z-index: 9999;
    }
    100% {
        transform: translateZ( 0px);
        opacity: 1;
        z-index: 9999;
    }
}


/*****************************************/


/* Soft Pulse */


/*****************************************/

.fxSoftPulse .navOutPrev,
.fxSoftPulse .navOutNext {
    -webkit-animation: scaleUpFadeOut 0.8s forwards ease-in;
    animation: scaleUpFadeOut 0.8s forwards ease-in;
}

.fxSoftPulse .navInPrev,
.fxSoftPulse .navInNext {
    -webkit-animation: scaleDownFadeIn 0.8s forwards ease-out;
    animation: scaleDownFadeIn 0.8s forwards ease-out;
}

@-webkit-keyframes scaleUpFadeOut {
    50% {
        -webkit-transform: scale(1.2);
        opacity: 1;
    }
    75% {
        -webkit-transform: scale(1.1);
        opacity: 0;
    }
    100% {
        -webkit-transform: scale(1);
        opacity: 0;
    }
}

@keyframes scaleUpFadeOut {
    50% {
        transform: scale(1.2);
        opacity: 1;
    }
    75% {
        transform: scale(1.1);
        opacity: 0;
    }
    100% {
        transform: scale(1);
        opacity: 0;
    }
}

@-webkit-keyframes scaleDownFadeIn {
    50% {
        opacity: 1;
        -webkit-transform: scale(1.2);
    }
    100% {
        opacity: 1;
        -webkit-transform: scale(1);
    }
}

@keyframes scaleDownFadeIn {
    50% {
        opacity: 1;
        transform: scale(1.2);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}


/*****************************************/


/* Earthquake */


/* From http://elrumordelaluz.github.io/csshake/ by Lionel, http://t.co/thCECnx1Yg */


/*****************************************/

.fxEarthquake .navOutNext {
    opacity: 1;
    -webkit-animation: shakeSlideBottom 1s 0.1s forwards;
    animation: shakeSlideBottom 1s 0.1s forwards;
}

.fxEarthquake .navInNext {
    -webkit-animation: pushFromTop 1s 0.1s forwards;
    animation: pushFromTop 1s 0.1s forwards;
}

.fxEarthquake .navOutPrev {
    opacity: 1;
    -webkit-animation: shakeSlideTop 1s 0.1s forwards;
    animation: shakeSlideTop 1s 0.1s forwards;
}

.fxEarthquake .navInPrev {
    opacity: 1;
    -webkit-animation: pushFromBottom 1s 0.1s forwards;
    animation: pushFromBottom 1s 0.1s forwards;
}

.fxEarthquake li::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    background-color: rgba(0, 0, 0, 0.3);
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
}

.fxEarthquake .navOutPrev::after,
.fxEarthquake .navOutNext::after {
    opacity: 1;
}

@-webkit-keyframes shakeSlideBottom {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
    }
    2% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    4% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    6% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    8% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    10% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    12% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    14% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    16% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    18% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    20% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    22% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    24% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    26% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    28% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    30% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    32% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    34% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    36% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    38% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    40% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    42% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    44% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    46% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    48% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    50% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    52% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    54% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    56% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    58% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    60% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    62% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    64% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    66% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    68% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    70% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    100% {
        -webkit-transform: translateY(100%);
    }
}

@keyframes shakeSlideBottom {
    0% {
        transform: translate(0px, 0px) rotate(0deg);
    }
    2% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    4% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    6% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    8% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    10% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    12% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    14% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    16% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    18% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    20% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    22% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    24% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    26% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    28% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    30% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    32% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    34% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    36% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    38% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    40% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    42% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    44% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    46% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    48% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    50% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    52% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    54% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    56% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    58% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    60% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    62% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    64% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    66% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    68% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    70% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    100% {
        transform: translateY(100%);
    }
}

@-webkit-keyframes pushFromTop {
    0%,
    70% {
        opacity: 0;
        -webkit-transform: translateY(-100%);
    }
    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
    }
}

@keyframes pushFromTop {
    0%,
    70% {
        opacity: 0;
        transform: translateY(-100%);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@-webkit-keyframes shakeSlideTop {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
    }
    2% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    4% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    6% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    8% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    10% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    12% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    14% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    16% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    18% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    20% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    22% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    24% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    26% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    28% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    30% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    32% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    34% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    36% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    38% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    40% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    42% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    44% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    46% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    48% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    50% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    52% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    54% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    56% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    58% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    60% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    62% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    64% {
        -webkit-transform: translate(0px, -1px) rotate(-0.5deg);
    }
    66% {
        -webkit-transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    68% {
        -webkit-transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    70% {
        -webkit-transform: translate(0px, 0px) rotate(-0.5deg);
    }
    100% {
        -webkit-transform: translateY(-100%);
    }
}

@keyframes shakeSlideTop {
    0% {
        transform: translate(0px, 0px) rotate(0deg);
    }
    2% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    4% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    6% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    8% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    10% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    12% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    14% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    16% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    18% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    20% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    22% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    24% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    26% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    28% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    30% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    32% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    34% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    36% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    38% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    40% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    42% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    44% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    46% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    48% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    50% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    52% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    54% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    56% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    58% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    60% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    62% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    64% {
        transform: translate(0px, -1px) rotate(-0.5deg);
    }
    66% {
        transform: translate(-1px, -1px) rotate(-0.5deg);
    }
    68% {
        transform: translate(-1px, 0px) rotate(-0.5deg);
    }
    70% {
        transform: translate(0px, 0px) rotate(-0.5deg);
    }
    100% {
        transform: translateY(-100%);
    }
}

@-webkit-keyframes pushFromBottom {
    0%,
    70% {
        opacity: 0;
        -webkit-transform: translateY(100%);
    }
    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
    }
}

@keyframes pushFromBottom {
    0%,
    70% {
        opacity: 0;
        transform: translateY(100%);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}


/*****************************************/


/* Cliff diving */


/*****************************************/

.fxCliffDiving li {
    -webkit-transform-origin: 50% 400%;
    transform-origin: 50% 400%;
}

.fxCliffDiving .navOutNext {
    opacity: 1;
    -webkit-animation: rotateOutCircLeft 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: rotateOutCircLeft 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxCliffDiving .navInNext {
    opacity: 1;
    -webkit-animation: rotateInCircRight 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: rotateInCircRight 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxCliffDiving .navOutPrev {
    opacity: 1;
    -webkit-animation: rotateOutCircRight 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: rotateOutCircRight 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxCliffDiving .navInPrev {
    opacity: 1;
    -webkit-animation: rotateInCircLeft 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: rotateInCircLeft 0.9s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fxCliffDiving li::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    background-color: rgba(0, 0, 0, 1);
    -webkit-transition: opacity 0.9s cubic-bezier(0.7, 0, 0.3, 1);
    transition: opacity 0.9s cubic-bezier(0.7, 0, 0.3, 1);
}

.fxCliffDiving .navOutPrev::after,
.fxCliffDiving .navOutNext::after {
    opacity: 1;
}

@-webkit-keyframes rotateOutCircLeft {
    to {
        -webkit-transform: rotate(-20deg) translateX(-100%);
    }
}

@keyframes rotateOutCircLeft {
    to {
        transform: rotate(-20deg) translateX(-100%);
    }
}

@-webkit-keyframes rotateInCircRight {
    from {
        -webkit-transform: rotate(20deg) translateX(100%);
    }
    to {
        -webkit-transform: rotate(0deg) translateX(0);
    }
}

@keyframes rotateInCircRight {
    from {
        transform: rotate(20deg) translateX(100%);
    }
    to {
        transform: rotate(0deg) translateX(0);
    }
}

@-webkit-keyframes rotateOutCircRight {
    to {
        -webkit-transform: rotate(20deg) translateX(100%);
    }
}

@keyframes rotateOutCircRight {
    to {
        transform: rotate(20deg) translateX(100%);
    }
}

@-webkit-keyframes rotateInCircLeft {
    from {
        -webkit-transform: rotate(-20deg) translateX(-100%);
    }
    to {
        -webkit-transform: rotate(0deg) translateX(0);
    }
}

@keyframes rotateInCircLeft {
    from {
        transform: rotate(-20deg) translateX(-100%);
    }
    to {
        transform: rotate(0deg) translateX(0);
    }
}


/*****************************************/


/* 3d swing */


/*****************************************/

.fx3dSwing>ul>li {
    transform-origin: 50% 50%;
}

.fx3dSwing .navOutNext {
    -webkit-animation: swingOutNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: swingOutNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fx3dSwing .navInNext {
    -webkit-animation: swingInNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: swingInNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    z-index: 1000;
}

.fx3dSwing .navOutPrev {
    -webkit-animation: swingOutPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: swingOutPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fx3dSwing .navInPrev {
    -webkit-animation: swingInPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: swingInPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

@keyframes swingOutNext {
    80% {
        opacity: 0;
    }
    100% {
        opacity: 0;
        transform: perspective(600px) rotateX(5deg) rotateY(-10deg) scale(.8) translateX(-50%);
    }
}

@keyframes swingInNext {
    0% {
        opacity: 0;
        transform: perspective(600px) rotateX(5deg) rotateY(-10deg) scale(.8) translateX(10%);
    }
    80% {
        opacity: 1;
        translateX(0%);
    }
    100% {
        opacity: 1;
        transform: perspective(600px) rotateX(0deg) rotateY(0deg) scale(1) translateX(0%);
    }
}

@keyframes swingOutPrev {
    80% {
        opacity: 0;
    }
    100% {
        opacity: 0;
        transform: perspective(600px) rotateX(-5deg) rotateY(10deg) scale(.8) translateX(50%);
    }
}

@keyframes swingInPrev {
    0% {
        opacity: 0;
        transform: perspective(600px) rotateX(-5deg) rotateY(10deg) scale(.8) translateX(-10%);
    }
    80% {
        opacity: 1;
        translateX(0%);
    }
    100% {
        opacity: 1;
        transform: perspective(600px) rotateX(0deg) rotateY(0deg) scale(1) translateX(0%);
    }
}


/*****************************************/


/* 3d reverse */


/*****************************************/

.fx3dReverse .itemwrap {
    perspective: 1600px;
}

.fx3dReverse .navOutNext {
    -webkit-animation: reverseOutNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: reverseOutNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fx3dReverse .navInNext {
    -webkit-animation: reverseInNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: reverseInNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    z-index: 1000;
}

.fx3dReverse .navOutPrev {
    -webkit-animation: reverseOutPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: reverseOutPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fx3dReverse .navInPrev {
    -webkit-animation: reverseInPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: reverseInPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

@keyframes reverseOutNext {
    0% {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
    100% {
        -webkit-transform: translateY(100%) translateZ(0px) rotateX(-90deg);
        opacity: 0;
        transform-origin: 50% 0%;
    }
}

@keyframes reverseInNext {
    from {
        -webkit-transform: translateY(-100%) translateZ(0px) rotateX(90deg);
        opacity: 0;
        transform-origin: 50% 100%;
    }
    to {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
}

@keyframes reverseOutPrev {
    0% {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
    100% {
        -webkit-transform: translateY(-100%) translateZ(0px) rotateX(90deg);
        opacity: 0;
        transform-origin: 50% 100%;
    }
}

@keyframes reverseInPrev {
    from {
        -webkit-transform: translateY(100%) translateZ(0px) rotateX(-90deg);
        opacity: 0;
        transform-origin: 50% 100%;
    }
    to {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
}


/*****************************************/


/* 3d overthrow */


/*****************************************/

.fx3dOverthrow .itemwrap {
    perspective: 1600px;
}

.fx3dOverthrow .navOutNext {
    -webkit-animation: overthrowOutNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: overthrowOutNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fx3dOverthrow .navInNext {
    -webkit-animation: overthrowInNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: overthrowInNext 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    z-index: 1000;
}

.fx3dOverthrow .navOutPrev {
    -webkit-animation: overthrowOutPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: overthrowOutPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

.fx3dOverthrow .navInPrev {
    -webkit-animation: overthrowInPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
    animation: overthrowInPrev 1.5s forwards cubic-bezier(0.7, 0, 0.3, 1);
}

@keyframes overthrowOutNext {
    0% {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
    100% {
        -webkit-transform: translateY(100%) translateZ(0px) rotateX(90deg);
        opacity: 0;
        transform-origin: 50% 0%;
    }
}

@keyframes overthrowInNext {
    from {
        -webkit-transform: translateY(-100%) translateZ(0px) rotateX(-90deg);
        opacity: 0;
        transform-origin: 50% 100%;
    }
    to {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
}

@keyframes overthrowOutPrev {
    0% {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
    100% {
        -webkit-transform: translateY(-100%) translateZ(0px) rotateX(-90deg);
        opacity: 0;
        transform-origin: 50% 100%;
    }
}

@keyframes overthrowInPrev {
    from {
        -webkit-transform: translateY(100%) translateZ(0px) rotateX(90deg);
        opacity: 0;
        transform-origin: 50% 0%;
    }
    to {
        -webkit-transform: translateY(0) translateZ(0px) rotateX(0deg);
        opacity: 1;
        transform-origin: 50% 50%;
    }
}