


.main-slider {
    position: relative;
    width: 100%;
    height: 42vw;
    min-height: 8vw;
    margin-bottom: 50px;
    opacity: 0;
    visibility: hidden;
    transition: all 1.2s ease;
    left: 0%;
}

    .main-slider.slick-initialized {
        opacity: 1;
        visibility: visible;
    }

    .main-slider .item .vimeo-frame {
        padding: 56.25% 0 0 0;
        position: relative;
    }

        .main-slider .item .vimeo-frame iframe {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }

    .main-slider .item .slide-video {
        height: 100%;
    }

.slick-slide {
    position: relative;
    height: 42vw;
}

    .slick-slide::before {
        background-color: #000;
        opacity: .3;
        z-index: 1;
    }

    .slick-slide video {
        display: block;
        position: absolute;
        top: 50%;
        left: 50%;
        min-width: 100%;
        min-height: 100%;
        width: auto;
        height: auto;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

    .slick-slide iframe {
        position: relative;
        pointer-events: none;
    }

    .slick-slide figure {
        position: relative;
        height: 100%;
    }

    .slick-slide .slide-image {
        opacity: 0;
        height: 100%;
        background-size: cover;
        background-position: center;
        transition: all .8s ease;
    }

        .slick-slide .slide-image.show {
            opacity: 1;
        }

    .slick-slide .image-entity {
        width: 100%;
        opacity: 0;
        visibility: hidden;
    }

    .slick-slide .loading {
        position: absolute;
        top: 44%;
        left: 0;
        width: 100%;
    }

    .slick-slide .slide-media {
        -webkit-animation: slideOut 0.4s cubic-bezier(0.4, 0.29, 0.01, 1);
        animation: slideOut 0.4s cubic-bezier(0.4, 0.29, 0.01, 1);
    }

    .slick-slide.slick-active {
        z-index: 1;
    }

        .slick-slide.slick-active .slide-media {
            -webkit-animation: slideIn 2.4s cubic-bezier(0.4, 0.29, 0.01, 1);
            animation: slideIn 2.4s cubic-bezier(0.4, 0.29, 0.01, 1);
        }

        .slick-slide.slick-active .caption {
            opacity: 1;
            -webkit-transform: translateY(0);
            transform: translateY(0);
            transition: all 0.7s cubic-bezier(0.32, 0.34, 0, 1.62) 0.6s;
        }

.caption {
    position: absolute;
    top: 44%;
    left: 5%;
    text-align: center;
    padding: 20px;
    border: 3px solid;
    color: #fff;
    margin: 0;
    font-size: 40px;
    font-weight: bold;
    letter-spacing: .02em;
    opacity: 0;
    z-index: 1;
    transition: all .3s ease;
    -webkit-transform: translateY(100px);
    transform: translateY(100px);
}

.slick-dots {
    text-align: center;
    padding-top: 15px;
    background-color: transparent;
    height: 43px;
    bottom: 43px;
    position: relative;
}

    .slick-dots li {
        display: inline-block;
        vertical-align: top;
        margin: 0 8px;
    }

        .slick-dots li button {
            width: 16px;
            height: 16px;
            border: none;
            cursor: pointer;
            border-radius: 50%;
            border: 2px solid #fff;
            box-shadow: 0 0 0 0 transparent;
            vertical-align: middle;
            color: #fff;
            background-color: #fff;
            transition: all .3s ease;
            opacity: .4;
        }

            .slick-dots li button:focus {
                outline: none;
            }

            .slick-dots li button:hover {
                opacity: 1;
            }

        .slick-dots li.slick-active button {
            border-color: #2d3042;
            box-shadow: 0 0 0 2px #fff;
            opacity: 1;
        }

@-webkit-keyframes slideIn {
    from {
        -webkit-filter: blur(15px);
        filter: blur(15px);
    }

    to {
        -webkit-filter: blur(0);
        filter: blur(0);
    }
}

@keyframes slideIn {
    from {
        -webkit-filter: blur(15px);
        filter: blur(15px);
    }

    to {
        -webkit-filter: blur(0);
        filter: blur(0);
    }
}

@-webkit-keyframes slideOut {
    from {
        -webkit-filter: blur(0);
        filter: blur(0);
    }

    to {
        -webkit-filter: blur(15px);
        filter: blur(15px);
    }
}

@keyframes slideOut {
    from {
        -webkit-filter: blur(0);
        filter: blur(0);
    }

    to {
        -webkit-filter: blur(15px);
        filter: blur(15px);
    }
}
