@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(0.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(0.8) translateX(6px);
    }
    75% {
        transform: scale(0.7) translateX(8px);
    }
    90% {
        transform: scale(0.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(0.8) translateX(-6px);
    }
    75% {
        transform: scale(0.7) translateX(-8px);
    }
    90% {
        transform: scale(0.8) translateX(-6px);
    }
    to {
        transform: scale(1);
    }
}
.drift-zoom-pane {
    background: rgba(0, 0, 0, 0.5);
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}
.drift-zoom-pane.drift-opening {
    animation: a 0.18s ease-out;
    -webkit-animation: a 0.18s ease-out;
}
.drift-zoom-pane.drift-closing {
    animation: b 0.21s ease-in;
    -webkit-animation: b 0.21s ease-in;
}
.drift-zoom-pane.drift-inline {
    border-radius: 75px;
    box-shadow: 0 6px 18px rgba(0, 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%, 0.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: -0.9s;
    -webkit-animation-delay: -0.9s;
    right: 0;
}
.drift-bounding-box {
    background-color: rgba(0, 0, 0, 0.4);
}
