@keyframes a {
    0% {
        opacity: 0;
        transform: scale(1.5)
    }

    to {
        opacity: 1;
        transform: scale(1)
    }
}

@keyframes b {
    0% {
        opacity: 1;
        transform: scale(1)
    }

    15% {
        opacity: 1;
        transform: scale(1.1)
    }

    to {
        opacity: 0;
        transform: scale(.5)
    }
}

@keyframes c {
    0% {
        transform: translate(-50%,-50%) rotate(0)
    }

    50% {
        transform: translate(-50%,-50%) rotate(-180deg)
    }

    to {
        transform: translate(-50%,-50%) rotate(-1turn)
    }
}

@keyframes d {
    0% {
        transform: scale(1)
    }

    10% {
        transform: scale(1.2) translateX(6px)
    }

    25% {
        transform: scale(1.3) translateX(8px)
    }

    40% {
        transform: scale(1.2) translateX(6px)
    }

    50% {
        transform: scale(1)
    }

    60% {
        transform: scale(.8) translateX(6px)
    }

    75% {
        transform: scale(.7) translateX(8px)
    }

    90% {
        transform: scale(.8) translateX(6px)
    }

    to {
        transform: scale(1)
    }
}

@keyframes e {
    0% {
        transform: scale(1)
    }

    10% {
        transform: scale(1.2) translateX(-6px)
    }

    25% {
        transform: scale(1.3) translateX(-8px)
    }

    40% {
        transform: scale(1.2) translateX(-6px)
    }

    50% {
        transform: scale(1)
    }

    60% {
        transform: scale(.8) translateX(-6px)
    }

    75% {
        transform: scale(.7) translateX(-8px)
    }

    90% {
        transform: scale(.8) translateX(-6px)
    }

    to {
        transform: scale(1)
    }
}

.drift-zoom-pane {
    background: rgba(0,0,0,.5);
    transform: translateZ(0);
    -webkit-transform: translateZ(0)
}

    .drift-zoom-pane.drift-opening {
        animation: a .18s ease-out;
        -webkit-animation: a .18s ease-out
    }

    .drift-zoom-pane.drift-closing {
        animation: b .21s ease-in;
        -webkit-animation: b .21s ease-in
    }

    .drift-zoom-pane.drift-inline {
        border-radius: 75px;
        box-shadow: 0 6px 18px rgba(0,0,0,.3);
        height: 150px;
        position: absolute;
        width: 150px
    }

.drift-loading .drift-zoom-pane-loader {
    animation: c 1.8s linear infinite;
    -webkit-animation: c 1.8s linear infinite;
    display: block;
    height: 20px;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    width: 66px
}

.drift-zoom-pane-loader:after, .drift-zoom-pane-loader:before {
    background: hsla(0,0%,100%,.9);
    border-radius: 20px;
    content: "";
    display: block;
    height: 20px;
    margin-top: -10px;
    position: absolute;
    top: 50%;
    width: 20px
}

.drift-zoom-pane-loader:before {
    animation: d 1.8s linear infinite;
    -webkit-animation: d 1.8s linear infinite;
    left: 0
}

.drift-zoom-pane-loader:after {
    animation: e 1.8s linear infinite;
    -webkit-animation: e 1.8s linear infinite;
    animation-delay: -.9s;
    -webkit-animation-delay: -.9s;
    right: 0
}

.drift-bounding-box {
    background-color: rgba(0,0,0,.4)
}
