/* **********************************************
 * Main Elements
 ********************************************** */

.p-microsite {
    background: #fff;
}

.p-microsite main a:hover,
.p-microsite main a:focus {
    border-bottom: 1px solid #CCC;
    color: #333;
    text-decoration: none;
    transition: all 0.25s ease 0s;
}

.p-microsite main a.btn span {
    font-size: 0.85em;
}

.p-microsite main a.full.btn {
    width: 100%;
}

.p-microsite main a.btn:hover,
.p-microsite main a.btn:focus {
    border: 2px solid #000;
    color: #fff;
}

.p-microsite .to_top {
    /*background: #fff none repeat scroll 0 0;*/
    background: transparent none repeat scroll 0 0;
    padding: 5px 25px;
    text-align: right;
}

.img-original.img-responsive {
    width: auto;
}

table .img-responsive {
    width: auto;
    display: inline-block;
}

img {
    image-rendering: -webkit-optimize-contrast;
}

p.big	{font-size: 26px; line-height: 1.8;}
p 		{font-size: 15px; line-height: 1.5;}
p.small	{font-size: 10px; line-height: 1.2;}


.space-top-0    { top: 0%!important;     }
.space-top-10   { top: 10%!important;     }
.space-top-20   { top: 20%!important;     }
.space-top-30   { top: 30%!important;     }
.space-top-40   { top: 40%!important;     }
.space-top-50   { top: 50%!important;     }
.space-top-60   { top: 60%!important;     }
.space-top-70   { top: 70%!important;     }
.space-top-80   { top: 80%!important;     }
.space-top-90   { top: 90%!important;     }
.space-top-100  { top: 100%!important;    }

a.anchor {
    float: left;
}

/* **********************************************
 * Image Hover Effect
 ********************************************** */

.image-hover-wrapper {
    position: relative;
}

.grid.text-center .image-hover-wrapper {
    display: flex;
    justify-content: center;
}

/* Nur Firefox */
@-moz-document url-prefix() {
    .grid.text-center .image-hover-wrapper {
        display: inherit;
    }
}

.grid.text-center .image-hover-wrapper img {
    margin: 0;
    align-self: center;
    flex-shrink: 0;
}

img.img-hover {
    position: absolute;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
}

img.img-hover:hover {
    opacity: 1;
}

#microsite_content .box .grid {
    background-color: #fff;
}

#microsite_content .row .u-bgGreen, .row .u-bgGrey,
#microsite_content .row .u-bgBeige, .row .u-bgBlack {
    border-width: 0;
}

/* Primary Colors */

#microsite_content .bg-cd1-40.box,
#microsite_content .bg-cd1-40 .box,
#microsite_content .bg-cd1-40.box .grid,
#microsite_content .bg-cd1-40:not(.box) .grid-col .article          {background: #d1e1b0}

#microsite_content .bg-cd1-70.box,
#microsite_content .bg-cd1-70 .box,
#microsite_content .bg-cd1-70.box .grid,
#microsite_content .bg-cd1-70:not(.box) .grid-col .article          {background: #aecb74}

#microsite_content .bg-cd1-100.box,
#microsite_content .bg-cd1-100 .box,
#microsite_content .bg-cd1-100.box .grid,
#microsite_content .bg-cd1-100:not(.box) .grid-col .article          {background: #89e872}

#microsite_content .bg-cd2-40.box,
#microsite_content .bg-cd2-40 .box,
#microsite_content .bg-cd2-40.box .grid,
#microsite_content .bg-cd2-40:not(.box) .grid-col .article          {background: #96afdb}

#microsite_content .bg-cd2-70.box,
#microsite_content .bg-cd2-70 .box,
#microsite_content .bg-cd2-70.box .grid,
#microsite_content .bg-cd2-70:not(.box) .grid-col .article          {background: #5185c5}

#microsite_content .bg-cd2-100.box,
#microsite_content .bg-cd2-100 .box,
#microsite_content .bg-cd2-100.box .grid,
#microsite_content .bg-cd2-100:not(.box) .grid-col .article         {background: #0057b8}

#microsite_content .bg-flashgreen_40.box,
#microsite_content .bg-flashgreen_40.box .grid,
#microsite_content .bg-flashgreen_40:not(.box) .grid-col .article,
#microsite_content .bg-cd3-40.box,
#microsite_content .bg-cd3-40 .box,
#microsite_content .bg-cd3-40.box .grid,
#microsite_content .bg-cd3-40:not(.box) .grid-col .article          {background: #b0ef9c}

#microsite_content .bg-flashgreen_70.box,
#microsite_content .bg-flashgreen_70.box .grid,
#microsite_content .bg-flashgreen_70:not(.box) .grid-col .article,
#microsite_content .bg-cd3-70.box,
#microsite_content .bg-cd3-70 .box,
#microsite_content .bg-cd3-70.box .grid,
#microsite_content .bg-cd3-70:not(.box) .grid-col .article          {background: #d4f6c6}

#microsite_content .bg-flashgreen.box,
#microsite_content .bg-flashgreen.box .grid,
#microsite_content .bg-flashgreen:not(.box) .grid-col .article,
#microsite_content .bg-cd3-100.box,
#microsite_content .bg-cd3-100 .box,
#microsite_content .bg-cd3-100.box .grid,
#microsite_content .bg-cd3-100:not(.box) .grid-col .article         {background: #89e872}

#microsite_content .bg-black_1.box,
#microsite_content .bg-black_1.box .grid,
#microsite_content .bg-black_1:not(.box) .grid-col .article,
#microsite_content .bg-black-1.box,
#microsite_content .bg-black-1 .box,
#microsite_content .bg-black-1.box .grid,
#microsite_content .bg-black-1:not(.box) .grid-col .article         {background: #f5f5f5}

#microsite_content .bg-black-40.box,
#microsite_content .bg-black-40 .box,
#microsite_content .bg-black-40.box .grid,
#microsite_content .bg-black-40:not(.box) .grid-col .article        {background: #b2b2b2}

#microsite_content .bg-black-100.box,
#microsite_content .bg-black-100 .box,
#microsite_content .bg-black-100.box .grid,
#microsite_content .bg-black-100:not(.box) .grid-col .article       {background: #000; color: #fff;}

#microsite_content .bg-white.box,
#microsite_content .bg-white.box.box .grid,
#microsite_content .bg-white:not(.box) .grid-col .article,
#microsite_content .bg-white-100.box,
#microsite_content .bg-white-100 .box,
#microsite_content .bg-white-100.box.box .grid,
#microsite_content .bg-white-100:not(.box) .grid-col .article       {background: #fff}

#microsite_content .bg-cd1-40 h1,
#microsite_content .bg-cd1-40 h2,
#microsite_content .bg-cd1-40 h3,
#microsite_content .bg-cd1-70 h1,
#microsite_content .bg-cd1-70 h2,
#microsite_content .bg-cd1-70 h3,
#microsite_content .bg-cd2-40 h1,
#microsite_content .bg-cd2-40 h2,
#microsite_content .bg-cd2-40 h3,
#microsite_content .bg-cd2-70 h1,
#microsite_content .bg-cd2-70 h2,
#microsite_content .bg-cd2-70 h3,
#microsite_content .bg-cd2-100 h1,
#microsite_content .bg-cd2-100 h2,
#microsite_content .bg-cd2-100 h3,
#microsite_content .bg-cd3-40 h1,
#microsite_content .bg-cd3-40 h2,
#microsite_content .bg-cd3-40 h3,
#microsite_content .bg-cd3-70 h1,
#microsite_content .bg-cd3-70 h2,
#microsite_content .bg-cd3-70 h3,
#microsite_content .bg-cd3-100 h1,
#microsite_content .bg-cd3-100 h2,
#microsite_content .bg-cd3-100 h3,
#microsite_content .bg-black-40 h1,
#microsite_content .bg-black-40 h2,
#microsite_content .bg-black-40 h3{
    color: #000;
}

#microsite_content .bg-cd1-100 h1,
#microsite_content .bg-cd1-100 h2,
#microsite_content .bg-cd1-100 h3,
#microsite_content .bg-cd1-100 p,
#microsite_content .bg-black-100 h1,
#microsite_content .bg-black-100 h2,
#microsite_content .bg-black-100 h3,
#microsite_content .bg-black-100 p {
    color: #fff;
}

/* Additional Colors */

#microsite_content .bg-paleblue_70.box,
#microsite_content .bg-paleblue_70.box .grid,
#microsite_content .bg-paleblue_70:not(.box) .grid-col .article,
#microsite_content .bg-add1-70.box,
#microsite_content .bg-add1-70 .box,
#microsite_content .bg-add1-70.box .grid,
#microsite_content .bg-add1-70:not(.box) .grid-col .article         {background: #65cdef}

#microsite_content .bg-paleblue.box,
#microsite_content .bg-paleblue.box .grid,
#microsite_content .bg-paleblue:not(.box) .grid-col .article,
#microsite_content .bg-add1-100.box,
#microsite_content .bg-add1-100 .box,
#microsite_content .bg-add1-100.box .grid,
#microsite_content .bg-add1-100:not(.box) .grid-col .article        {background: #00b5e2}

#microsite_content .bg-add2-70.box,
#microsite_content .bg-add2-70 .box,
#microsite_content .bg-add2-70.box .grid,
#microsite_content .bg-add2-70:not(.box) .grid-col .article         {background: #b7d876}

#microsite_content .bg-add2-100.box,
#microsite_content .bg-add2-100 .box,
#microsite_content .bg-add2-100.box .grid,
#microsite_content .bg-add2-100:not(.box) .grid-col .article        {background: #cedc00}

#microsite_content .bg-add3-70.box,
#microsite_content .bg-add3-70 .box,
#microsite_content .bg-add3-70.box .grid,
#microsite_content .bg-add3-70:not(.box) .grid-col .article         {background: #f9a263}

#microsite_content .bg-add3-100.box,
#microsite_content .bg-add3-100 .box,
#microsite_content .bg-add3-100.box .grid,
#microsite_content .bg-add3-100:not(.box) .grid-col .article        {background: #e87722}

#microsite_content .bg-add4-70.box,
#microsite_content .bg-add4-70 .box,
#microsite_content .bg-add4-70.box .grid,
#microsite_content .bg-add4-70:not(.box) .grid-col .article         {background: #dd6866}

#microsite_content .bg-add4-100.box,
#microsite_content .bg-add4-100 .box,
#microsite_content .bg-add4-100.box .grid,
#microsite_content .bg-add4-100:not(.box) .grid-col .article        {background: #ba0c2f}

#microsite_content .bg-add1-70 h1,
#microsite_content .bg-add1-70 h2,
#microsite_content .bg-add1-70 h3,
#microsite_content .bg-add1-100 h1,
#microsite_content .bg-add1-100 h2,
#microsite_content .bg-add1-100 h3,
#microsite_content .bg-add2-70 h1,
#microsite_content .bg-add2-70 h2,
#microsite_content .bg-add2-70 h3,
#microsite_content .bg-add2-100 h1,
#microsite_content .bg-add2-100 h2,
#microsite_content .bg-add2-100 h3,
#microsite_content .bg-add3-70 h1,
#microsite_content .bg-add3-70 h2,
#microsite_content .bg-add3-70 h3,
#microsite_content .bg-add3-100 h1,
#microsite_content .bg-add3-100 h2,
#microsite_content .bg-add3-100 h3,
#microsite_content .bg-add4-70 h1,
#microsite_content .bg-add4-70 h2,
#microsite_content .bg-add4-70 h3,
#microsite_content .bg-add4-100 h1,
#microsite_content .bg-add4-100 h2,
#microsite_content .bg-add4-100 h3 {
    color: #000;
}

/* Vendor/Topic related Colors */
/*
.bg-rel1
.bg-rel2
*/

/* Mixed Colors */

#microsite_content .bg-flashgreen_100_70.box,
#microsite_content .bg-flashgreen_100_70 .box,
#microsite_content .bg-flashgreen_100_70.box .grid,
#microsite_content .bg-flashgreen_100_70:not(.box) .grid-col .article,
#microsite_content .bg-cd3-100--cd3-70.box,
#microsite_content .bg-cd3-100--cd3-70 .box,
#microsite_content .bg-cd3-100--cd3-70.box .grid,
#microsite_content .bg-cd3-100--cd3-70:not(.box) .grid-col .article,
#microsite_content .bg-flashgreen_100_paleblue_70.box,
#microsite_content .bg-flashgreen_100_paleblue_70 .box,
#microsite_content .bg-flashgreen_100_paleblue_70.box .grid,
#microsite_content .bg-flashgreen_100_paleblue_70:not(.box) .grid-col .article,
#microsite_content .bg-cd3_100_add1_70.box,
#microsite_content .bg-cd3_100_add1_70 .box,
#microsite_content .bg-cd3_100_add1_70.box .grid { background: #89E872}

#microsite_content .bg-cd3-100--cd3-70.box .grid,
#microsite_content .bg-cd3_100_add1_70.box .grid,
#microsite_content .bg-white-100_bg-black-1,
#microsite_content .bg-white-100_bg-cd1-100 { background: transparent;}

@media (min-width: 992px) {

    #microsite_content .bg-flashgreen_100_70.box,
    #microsite_content .bg-flashgreen_100_70 .box,
    #microsite_content .bg-flashgreen_100_70.box .grid,
    #microsite_content .bg-cd3-100--cd3-70.box,
    #microsite_content .bg-cd3-100--cd3-70 .box,
    #microsite_content .bg-cd3-100--cd3-70.box .grid{
        background: #89E872;
        background: -moz-linear-gradient(left,  #89E872 50%, #D4F6C6 50%);
        background: -webkit-linear-gradient(left,  #89E872 50%,#D4F6C6 50%);
        background: linear-gradient(to right,  #89E872 50%,#D4F6C6 50%);
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#89E872', endColorstr='#D4F6C6',GradientType=1 );
    }

    #microsite_content .bg-flashgreen_100_paleblue_70.box,
    #microsite_content .bg-flashgreen_100_paleblue_70 .box,
    #microsite_content .bg-flashgreen_100_paleblue_70.box .grid,
    #microsite_content .bg-cd3_100_add1_70.box,
    #microsite_content .bg-cd3_100_add1_70 .box,
    #microsite_content .bg-cd3_100_add1_70.box .grid{
        background: #89E872;
        background: -moz-linear-gradient(left,  #89E872 50%, #65CDEF 50%);
        background: -webkit-linear-gradient(left,  #89E872 50%,#65CDEF 50%);
        background: linear-gradient(to right,  #89E872 50%,#65CDEF 50%);
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#89E872', endColorstr='#65CDEF',GradientType=1 );
    }

    #microsite_content .bg-white-100_bg-black-1.box,
    #microsite_content .bg-white-100_bg-black-1 .box,
    #microsite_content .bg-white-100_bg-black-1.box .grid{
        background: #ffffff;
        background: -moz-linear-gradient(left,  #ffffff 50%, #f5f5f5 50%);
        background: -webkit-linear-gradient(left,  #ffffff 50%,#f5f5f5 50%);
        background: linear-gradient(to right,  #ffffff 50%,#f5f5f5 50%);
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f5f5f5',GradientType=1 );
    }

    #microsite_content .bg-white-100_bg-cd1-100.box,
    #microsite_content .bg-white-100_bg-cd1-100 .box,
    #microsite_content .bg-white-100_bg-cd1-100.box .grid{
        background: #ffffff;
        background: -moz-linear-gradient(left,  #ffffff 50%, #8bb438 50%);
        background: -webkit-linear-gradient(left,  #ffffff 50%,#8bb438 50%);
        background: linear-gradient(to right,  #ffffff 50%,#8bb438 50%);
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#8bb438',GradientType=1 );
    }

    /* on article level for all / first elements */

    #microsite_content .bg-white-100_bg-cd1-100:not(.box) .grid-col .article{
        background: #8bb438;
    }

    #microsite_content .bg-flashgreen_100_70:not(.box) .grid-col:first-of-type .article,
    #microsite_content .bg-cd3-100--cd3-70:not(.box) .grid-col:first-of-type .article,
    #microsite_content .bg-flashgreen_100_paleblue_70:not(.box) .grid-col:first-of-type .article,
    #microsite_content .bg-cd3_100_add1_70:not(.box) .grid-col:first-of-type .article{
        background: #89E872;
    }

    #microsite_content .bg-flashgreen_100_70:not(.box) .grid-col .article,
    #microsite_content .bg-cd3-100--cd3-70:not(.box) .grid-col .article {
        background: #D4F6C6;
    }

    #microsite_content .bg-white-100_bg-black-1:not(.box) .grid-col:first-of-type .article,
    #microsite_content .bg-white-100_bg-cd1-100:not(.box) .grid-col:first-of-type .article {
        background: #ffffff;
    }

    #microsite_content .bg-white-100_bg-black-1:not(.box) .grid-col .article{
        background: #f5f5f5;
    }

    #microsite_content .bg-flashgreen_100_paleblue_70:not(.box) .grid-col .article,
    #microsite_content .bg-cd3_100_add1_70:not(.box) .grid-col .article {
        background: #65CDEF;
    }


}

#microsite_content .bg-cd3-100--cd3-70 h1,
#microsite_content .bg-cd3-100--cd3-70 h2,
#microsite_content .bg-cd3-100--cd3-70 h3,
#microsite_content .bg-cd3_100_add1_70 h1,
#microsite_content .bg-cd3_100_add1_70 h2,
#microsite_content .bg-cd3_100_add1_70 h3{
    color: #000;
}


/* Header */

#microsite_header {
    background: #fff;
    margin-bottom: 15px;
}

#microsite_header > .row {
    position: relative;
}

#microsite_header div[class*="col"] {
    margin-bottom: 0;
}

#microsite_header ul {
    margin-top: 4px;
    padding: 0;
}

#microsite_header li {
    display: inline-block;
    float: left;
    margin-right: 5px;
}

#microsite_header li a {
    color: #666;
    display: block;
    padding: 0.5em;
    text-transform: uppercase;
}

.ms_search {
    position: absolute;
    right: 0;
    top: 1px;
}

#microsite-search #searchstring-ms {
    margin: 0.25em 0.25em 0.25em 0;
    padding: 0.5em 0.75em 0.5em 0.5em;
    width: 80%;
    font-size: 0.9em;
}

#microsite_header .logo {
    left: -150px;
    position: absolute;
    top: 70px;
    transform: rotate(270deg);
    width: 210px;
}

.p-microsite .lnk-logo:hover,
.p-microsite .lnk-logo:focus {
    border-bottom: none;
}

#p-Startpage .c-Breadcrumb {
    display: none;
}

/* Main */

#microsite_content .container {
    margin-bottom: 0;
}

#microsite_content section:last-of-type {
    margin-bottom: 15px;
}

.u-noSpaceBeforeFooter #microsite_content section:last-of-type {
    margin-bottom: 0;
}

/* Aside */

aside > div {
    background: #cecfce;
    margin-right: -10px;
    margin-left: -25px;
    padding-left: 0;
    height: 100%;
    background: #ccc;
}


/* Content Area */

#microsite_content {
    padding: 0;
}

#microsite_content .article {
    margin-bottom: 0;
}

#microsite_content .article .row > div {
    margin-bottom: 0;
}

#microsite_content .article > .row {
    padding: 15px 0;
}

#microsite_content .article .h-align picture {
    float: left;
    margin-right: 10px;
}

.col-for-image.h-align {
    display: flex;
    flex-flow: row wrap;
}

#microsite_content .equalheight .article {
    height: 100%;
}

/* Sitemap Area */

.sitemap ul .col-xs-12 {
    background: #eee none repeat scroll 0 0;
    margin: 1%;
    padding: 10px;
    width: 22%;
}

/* Contact Area */

#microsite_contact {
    background: #ddd;
    margin-bottom: 0;
    padding-bottom: 10px;
    padding-top: 10px;
}

#microsite_contact div {
    margin-bottom: 5px;
}

#microsite_contact .division-info {
    background-color: #CCC;
    padding: 0 15px 5px 15px;
}

#microsite_contact img {
    height: auto;
    width: 100%;
}

#microsite_contact p {
    margin-bottom: 0;
}

#contact_filter,
#contact-overview {
    padding: 15px;
}

#microsite_content #contact-overview .contact {
    margin-bottom: 15px;
}

@media(max-width: 768px) {
    .contact-detail-image {
        width: 100%;
    }
    .contact-detail-image img {
        margin: 0 auto;
    }
    .contact-info {
        margin-top: 25px
    }
}

/* Footer */

#microsite_footer {
    color: #666;
}

#microsite_footer .row {
    margin-left: -30px;
    margin-right: -30px;
    margin-top: 5px;
}

#microsite_footer div[class*="col"] {}

#microsite_footer div a {
    margin-right: 5px;
    color: #666;
}

#microsite_footer a {
    border: 0;
    border-left: 1px solid #333;
    margin-left: 5px;
    padding-left: 5px;
}

#microsite_footer a:first-child {
    border: 0;
    margin: 0;
    padding: 0;
}


/* **********************************************
 * Content Elements
 ********************************************** */

#microsite_content .text-center li::before {
    position: relative;
    top: -3px;
}

/* slider */

#microsite_content .c-Gallery .container-fluid {
    padding: 0;
}

#microsite_content section.c-Gallery:last-of-type {
    margin-bottom: 0;
}

#microsite_content .c-Gallery .swiper-container .slider-navigation {
    height: 95%;
}

#microsite_content .c-Gallery .swiper-container .swiper-pagination {
    bottom: 0;
}

#microsite_content .c-Gallery .swiper-container .swiper-slide img {
    margin-bottom: 0;
}

#microsite_content .c-Gallery:not(.c-SliderHome) .swiper-container .swiper-slide div {
    display: none;
}

#microsite_content .c-Gallery:not(.c-SliderHome) .swiper-container .swiper-slide div.slider-text-block,
#microsite_content .c-Gallery:not(.c-SliderHome) .swiper-container .swiper-slide div.slider-text-block div {
    display: block;
}


#microsite_content .c-Gallery:not(.c-SliderHome) .swiper-container .swiper-slide div.slider-text-block {
    margin: 2% 10%;
    padding: 25px;
    position: absolute;
    text-align: left;
    top: 0;
    left: 0;
}

#microsite_content .c-Gallery:not(.c-SliderHome) .swiper-container .swiper-slide div.slider-text-block:last-of-type {
    left: 50%;
}

#microsite_content .c-Gallery .swiper-container .swiper-pagination-bullet {
    background: #999;
}

#microsite_content section[class*="bg-"] .swiper-wrapper .swiper-slide {
    background-color: transparent;
}

#microsite_content section[class*="bg-"] .c-Gallery {
    padding: 20px 0 10px 0;
}

#microsite_content .c-SliderNoNav .swiper-pagination {
    display: none;
}


/* grid */

#microsite_content .row > div {
    margin-bottom: 0;
}

#microsite_content .grid .row > div,
#microsite_content .article:last-child {
    margin-bottom: 0;
}

#microsite_content .grid .grid-col .row:first-of-type {
    margin: 0;
}

#microsite_content .grid .grid-col {
    padding-left: 8px;
    padding-right: 8px;
}

/* grid three cols */

@media (min-width: 992px) {
    /* first in row */
    #microsite_content section .grid-type-3 .grid-col:nth-child(3n-1) {
        padding-left: 0;
        padding-right: 10px;
    }

    /* second in row */
    #microsite_content section .grid-type-3 .grid-col:nth-child(3n-2) {
        padding-left: 5px;
        padding-right: 5px;
    }

    /* last in row */
    #microsite_content section .grid-type-3 .grid-col:nth-child(3n) {
        padding-left: 10px;
        padding-right: 0;
    }
}

.grid-type-3 .row  {
    padding-left:9px;
    padding-right:9px;
}

/*
@media (min-width: 992px) {
    #microsite_content .grid .grid-col:first-of-type {
        padding-left: 0;
    }
    #microsite_content .grid .grid-col:last-of-type {
        padding-right: 0;
    }
}*/

@media (min-width:768px) {
    #microsite_content .grid-type-3 .grid-col {
        padding-left: 5px;
        padding-right: 5px;
    }

    /*#microsite_content .grid-type-3 .grid-col:first-of-type,
    #microsite_content .grid-type-3 .grid-col:first-of-type:last-of-type*/
    #microsite_content .grid-type-3 .grid-col:nth-child(3n-2) {
        padding-left: 0;
        padding-right: 10px;
    }

    /*#microsite_content .grid-type-3 .grid-col:last-of-type,*/
    #microsite_content .grid-type-3 .grid-col:nth-child(3n+0){
        padding-right: 0;
        padding-left: 10px;
    }
}
@media(max-width: 992px) {
    #microsite_content .grid-type-3.grid .grid-col {
        padding-left: 0;
        padding-right: 0;
    }
}

/* table */

#microsite_content table.table thead tr th:first-child {
    width: auto;
}

#microsite_content .table-datatable .dataTables_wrapper .dataTables_filter input {
    margin-left: 0;
}

#microsite_content .table-datatable .dataTables_info {
    display: none;
}

#microsite_content .table-datatable .dataTables_wrapper .dataTables_paginate {
    margin-top: 17px;
}


/* products */

#microsite_content .c-Products--gallery-Product {
    padding-left: 50px;
    padding-right: 50px;
}

#microsite_content .c-Products--gallery-Product.col-lg-4 .btn,
#microsite_content .c-Products--gallery-Product.col-lg-6 .btn {
    width: 100%;
}

#microsite_content .c-Products--gallery-Product .btn-primary {
    margin: 10px 0 50px 0 !important;
    padding: 14px 50px 14px 20px;
}

#microsite_content .c-Products--gallery-Product .btn-primary::after {
    content: "";
}

@media (max-width: 767px) {
    #microsite_content .c-Products--gallery-Product.col-xs-12 .btn {
        width: 100%;
    }
}

.p-microsite #microsite_content section tr:hover a,
.p-microsite #microsite_content tr:hover .c-Products--gallery-Product span[class^="price"] {
    color: #fff;
}

/* Button */

#microsite_content section .btn-primary {
    margin: 5px 0;
}

#microsite_content section .btn > span {
    color: #000;
}

#microsite_content section .btn:hover > span {
    color: #fff;
}

/* Akkordion */

.tab-pane.text-center img {
    margin:0 auto;
}

.grid.text-center img {
    margin: 0 auto;
}

/* **********************************************
 * Menus
 ********************************************** */

/* dropdown menu */

.navbar-header .navbar-menu {
    float: left;
    margin: 12px 10px 0 0;
}

.col-xs-12 > ul > .dropdown.open {
    position: static;
}

.dropdown-menu {
    background: rgba(230, 230, 230, 0.95);
    border: 0 none;
    border-radius: 0;
    width: 100%;
}

.dropdown.open > .dropdown-toggle:focus,
.dropdown.open > .dropdown-toggle:hover,
.dropdown.open > .dropdown-toggle {
    background: rgba(230, 230, 230, 0.95) none repeat scroll 0 0
    border-bottom: 1px solid #eee;
}

.dropdown-menu > .active > a,
.dropdown-menu > .active > a:focus,
.dropdown-menu > .active > a:hover {
    background-color: transparent;
}

#microsite_header .dropdown-menu li {
    margin-right: 0;
    border-top: 1px solid #cecece;
}

#microsite_header .dropdown-menu li a {
    font-weight: 900;
    border-bottom: 0;
}

#microsite_header .dropdown-menu li a:hover {
    background: none;
    color: #000;
    border-bottom: 0;
}

#microsite_header .dropdown-menu li ul {
    margin-left: 0;

    margin-top: 0;
    margin-bottom: 8px;
}

#microsite_header .dropdown-menu li ul li {
    float: none;
    display: block;
    border-top: 0;
}

#microsite_header .dropdown-menu li ul li a {
    font-weight: normal;
    padding: 0.125em 0.5em;
}

#microsite_header .dropdown-menu li ul li ul li {
    margin-left: 10px;
}

/* main menu */

#microsite_header .active > a,
#microsite_header .active > a:hover {
    color: #000;
}


/* sub menu */

aside ul {
    background: #e7e7e7 none repeat scroll 0 0;
    border-top: 1px solid #cecfce;
    display: block;
    list-style: outside none none;
    margin: 0;
    padding-left: 0;
}

aside ul li {
    border-left: 1px solid #cecfce;
    border-right: 1px solid #cecfce;
    display: block;
}

aside > div > ul > li > a {
    border-bottom: 1px solid #cecfce;
    color: #383838;
    display: block;
    padding: 8px 20px 6px;
    text-decoration: none;
}

aside > div > ul > li > a > span {
    color: #383838;
    display: block;
    line-height: 14px;
    padding: 3px 0 10px;
    text-transform: none;
}

aside > div > ul > li > a:hover,
aside > div > ul > li.active > a {
    background: #dcdada none repeat scroll 0 0;
    color: #000;
    border-bottom: 1px solid #ccc;
}

aside ul ul {
    background: #fff none repeat scroll 0 0;
    border-bottom: 1px solid #cecfce;
    display: block;
    list-style: outside none none;
    padding: 10px 20px;
}

aside ul ul li {
    border: 0 none;
    display: block;
}

aside ul ul li a {
    color: #383838;
    display: block;
    margin: 0 0 3px;
    text-decoration: none;
}

.p-microsite aside ul ul li a,
.p-microsite aside ul ul li.active a,
.p-microsite aside ul ul li a:hover {
    color: #383838;
    border-bottom: 0;
    transition: none;
}

aside ul ul ul {
    border-bottom: medium none;
    display: block;
    list-style: outside none none;
    padding: 0 11px;
}

aside ul ul ul li {
    border: 0 none;
    display: block;
}

aside ul ul ul li a {
    color: #383838;
    display: block;
    margin: 0 0 3px;
    text-decoration: none;
}

aside ul ul ul li.active a,
aside ul ul ul li a:hover {
    color: #383838;
}

.p-microsite aside ul li.new a {
    color: #c00;
}


/*  */

.visible-hidden {
    visibility: hidden;
}

.highlight {
    text-decoration: underline;
}

.separat,
.separat_inner {
    display: block;
    margin-top: 15px;
}

.microsite-related.mp-level-overlay {
    /* background-color: rgba(0, 157, 217, 0.5); wrong color ... */
}

.contact .contact-detail {
    display: none;
}

.contact .contact-image {
    max-width: 150px;
    max-height: 150px;
}

.contact .lightbox:hover {
    cursor: pointer;
}

#microsite_content::after {clear:both;}

#microsite_content::after, #microsite_content::before {
    content: " ";
    display: table;
}

.container > .row > *:not(div):not(a) {
    padding: 0;
}

section.container {
    margin-bottom: 0;
}

/* **********************************************
 * Countdown
 ********************************************** */

#wrapper-countdown {
    padding: 15px;
    font-size: 2em;
    color: #fff;
    display: flex;
    text-align: center;
}

#wrapper-countdown div {
    border: 2px solid #fff;
    padding: 25px;
    text-align: center;
    margin: 0 auto;
    width: 20%
}

#wrapper-countdown div span {
    display: block;
}

#wrapper-countdown div span.countdown-head {
    margin-bottom: 25px;
}

/* **********************************************
 * Text with Media - Col For Image
 ********************************************** */

.text_with_media div.col-for-image {
    padding-left:0;
    padding-right:0;
}

.text_with_media span.col-for-image {
    display: block;
    margin-left:-25px;
    margin-right:-25px;
}

/* **********************************************
 * Container Fluid -> Padding
 ********************************************** */

#section {
    padding:0;
}

#microsite_content .container-fluid--nopadding > .row {
    margin:0;
}

#microsite_content .container-fluid--nopadding.grid-type-1,
#microsite_content .container-fluid--nopadding.grid-type-1 > .row.grid > .grid-col,
#microsite_content .container-fluid--nopadding.grid-type-1 .col-xs-12.grid-col,
#microsite_content .container-fluid--nopadding.grid-type-2,
#microsite_content .container-fluid--nopadding.grid-type-2 > .row.grid > .grid-col,
#microsite_content .container-fluid--nopadding.grid-type-2 .col-xs-12.grid-col {
    padding-left: 0;
    padding-right: 0;
}

#microsite_content .container-fluid--nopadding > .row.grid {
    margin-left:0;
    margin-right:0;
}

/* **********************************************
 * Tabs / Acc
 ********************************************** */

#microsite_content .nav {
    margin-bottom: 0;
    margin-left: -15px;
    margin-right: -15px;
    padding-left: 15px !important;
}

#microsite_content .tab-pane {
    margin: 0 -25px;
}

#microsite_content .tab-pane .row {
    padding: 25px;
}

#microsite_content .tab-pane > .col-xs-12 {
    padding-bottom: 15px;
}

#microsite_content  .row .article .row .article > .row div[class^="col"],
#microsite_content  .tab-content .article > .row div[class^="col"]{
    padding-left: 25px;
    padding-right: 25px;
}


#microsite_content  .row .article .row .article > .row,
#microsite_content  .tab-content .article > .row{
    margin-left: -25px;
    margin-right: -25px;
}

#microsite_content  .row .article .row .article > .row img {

}

#microsite_content  .row .article .row .article > .row .col-for-image img {
    display: block;
    margin-left: 0 ;
    margin-right: 0;
    padding-left: 25px;
    padding-right: 25px;
}

#microsite_content .tab-content .article > .row img {
    margin-left: -25px;
    margin-right: -25px;
}

#microsite_content  .tab-content .article > .row .col-for-image img {
    margin-left: 0;
    margin-right: 0;
}

#microsite_content .nav-tabs-background {
    display: table;
    width: 100%;
    table-layout: fixed;
}

#microsite_content .nav-tabs-background li span {
    display: block;
    background-size: cover;
    height: 350px;
}

#microsite_content .nav-tabs-background li,
#microsite_content .nav-tabs-background li.active {
    float: none;
    display: table-cell;
    width: 100%;
    table-layout: fixed;
    height: 350px;
    overflow: hidden;
}

#microsite_content .nav-tabs-background li a {
    position: absolute;
    height: 350px;
    display: block;
    color: #ffffff;
    width: 100%;
    font-size: 1.5em;
    padding-top: 5.5em;
    text-align: center;
    background-color: rgba(0,0,0,0.7);
}

#microsite_content .nav-tabs-background li a:hover {
    color: #ffffff;
    border: 0;
    background-color: rgba(0,0,0,0.3);
}

#microsite_content .nav-tabs-background li.active a {
    display: none;
}

/* **********************************************
 * Address Module
 ********************************************** */

.address-modul .contact_information span.contact-name {
    font-size: 20px;
    line-height: 20px;
    display: block;
    margin-bottom: 10px;
    font-weight: bold;
}

.address-modul .contact_information span.contact-jobtitle {
    font-size: 16px;
    line-height: 1.1;
    margin-bottom: 20px;
}

.address-modul .contact_information span.contact-jobtitle,
.address-modul .contact_information span.contact-telephone,
.address-modul .contact_information a.contact-mail {
    display: block;
}

.address-modul .col-team-img {
    padding-right: 8px;
}

.address-modul .col-team-text {
    padding-left: 8px;
}

/* **********************************************
 * image height for special grids
 ********************************************** */

.chaos_v1 picture {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    height: 200px;
}

.chaos_v1 > .container > .row > .col-xs-12:nth-of-type(1) > div > .row > .col-xs-12 > a > picture {
    height: 400px;
}

.chaos_v1 > .container > .row > .col-xs-12:nth-of-type(2) > div > .row > .col-xs-12 > a > picture {
    height: 450px;
}

.chaos_v1 > .container > .row > .col-xs-12:nth-of-type(4) > div > .row > .col-xs-12 > a > picture {
    height: 240px;
}

.chaos_v1 > .container > .row > .col-xs-12:nth-of-type(5) > div > .row > .col-xs-12 > a > picture {
    height: 240px;
}

.chaos_v1 > .container > .row > .col-xs-12:nth-of-type(6) > div > .row > .col-xs-12 > a > picture {
    height: 240px;
}

.chaos_v1 > .container > .row > .col-xs-12:nth-of-type(8) > div > .row > .col-xs-12 > a > picture {
    height: 230px;
}

/* **********************************************
 * FOR PREVIEW ONLY
 ********************************************** */

#countdown-bg {
    background-size: cover;
}

/* **********************************************
 * FOR PREVIEW ONLY
 ********************************************** */

.auth-online {
    border: 3px dotted #0c0;
    overflow: hidden;
}

.auth-offine {
    border: 3px dotted #c00;
    overflow: hidden;
}

/* **********************************************
 * Parallax
 ********************************************** */
.parallax-container{
    height: 400px;
    overflow:hidden;
    position:relative;
}

.parallax-container .parallax{
    top:0;
    left:0;
    right:0;
    bottom:0;
    z-index:-1;
}

.parallax-container .parallax img{
    position:absolute;
    left:50%;
    bottom:0;
    min-width:100%;
    min-height:100%;
}

.parallax{
    height:auto;
    min-height: 400px;
}

.container.parallax-image,
.container.parallax-text {
    top: 40%;
    position: absolute;
    text-align: center;
    width: 100%;
}

.container.parallax-text h2,
.container.parallax-text p {
    color: #fff;
}

/* button*/

.container.parallax-text .btn {
    color: #fff;
    border-color: #fff
}

#microsite_content section .parallax-text .btn:hover {
    background: #fff;
    color: #000;
    border-color: #fff;
}

#microsite_content section .parallax-text .btn > span {
    color: #fff
}

#microsite_content section .parallax-text .btn:hover > span {
    color: #000
}

.container.parallax-image, {
    padding-left: 0;
    padding-right: 0;
}

.parallax-container .image {
    position: absolute;
    width: 100%;
    margin-top: -12%;
    left: 0;
    height: 400px;
}

.parallax-container .image img {
    display: inline-block;
}

/* **********************************************
 * Submenu Linklist
 ********************************************** */

.submenu-linklist {
    list-style: none;
}

@media (min-width: 768px) {
    .submenu-linklist {
        -webkit-column-count: 3;
        -moz-column-count: 3;
        column-count: 3;
    }
}

.submenu-linklist li:before {
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transform: translate(0, 0);
    content: "\f061";
    margin-right: 5px;
}

/* **********************************************
 * Gallery by Folder
 ********************************************** */

.gallery_by_folder--background-image {
    height: 250px;
    background-size: cover;
    background-position: center;
}

.gallery_by_folder--image,
.gallery_by_folder--background-image {
    margin: 10px 0;
}

/* **********************************************
 * Timeline
 ********************************************** */

#microsite_content .article .limitation {
    max-height: 90vh;
    overflow: auto;
    padding: 0 40px;
}

.timeline_element {
    text-align: right;
}

.timeline_element.even {
    text-align: left;
}

.timeline_element p.big {
    margin: 0;
}

.timeline_element h3 {
    font-size: 36px;
    line-height: 42px;
}

.timeline_element .timeline_point {
    left: -48.25%;
    position: relative;
    top: 145px;
    z-index: 10;
}

.timeline_element.even .timeline_point {
    left: -0.25%;
}

@media (min-width: 992px) {
    .limitation {
        background: url(/ec/cms5/media/img/1010_waas/timeline_bg.png) repeat-y scroll center top;
    }

    .timeline_end {
        background: #fff;
        padding-left: 15px;
    }

    .timeline_end:last-child {
        padding-left: 17px;
    }

    .timeline_element.even {
        margin-right: -2px;
    }

    #microsite_content .timeline_element .col-md-6 {
        padding: 100px;
    }
}

/* **********************************************
 * Helper
 ********************************************** */

.highlight {
    font-weight: bold;
    text-decoration: none;
}

/* **********************************************
 * Career
 ********************************************** */

.c-career ::selection {
    background: #3e3e3e;
    color: #FFF;
}
.c-career ::-moz-selection {
    background: #3e3e3e;
    color: #FFF;
}
.p-microsite .c-career a.row-career,
.p-microsite .c-career a.row-career:hover {
    padding: 20px;
    display: inline-block;
    width: 100%;
    border-bottom: 2px solid #ececec;
    margin: 0px;
    color: #000;
}
.c-career a.row-career .row {
    padding: 0;
}
.c-career a.row-career > div {
    margin-bottom: 0;
}
.c-career a.row-career span {
    border-bottom: 2px solid transparent;
    margin: 0px;
    color: #77af24;
}
.c-career a.row-career:hover {
    background-image: url(/ec/cms5/media/grfx/common_grfx/bg_pinstripes_green.png);
}
.c-career a.row-career:hover span {
    text-decoration: none;
    border-bottom: 2px solid #77af24;
    color: #77af24;
}
.c-career a.row-career:first-child,
.c-career a.row-career:first-of-type {
    border-top: 2px solid #77af24;
}
.c-career a.row-career:last-child,
.c-career a.row-career:last-of-type {
    border-bottom: 2px solid #77af24;
}
.c-career a.row-career::before {
    display: none;
}
.c-career .row.row-career {
    margin-left: auto;
    margin-right: auto;
}

/* career v2 */

.c-career-v2 .selectlist {
    margin: 1em 0;
}

.c-career-v2 .jobs-container {
    margin-bottom: 1em;
}

.c-career-v2 .jobs-container span {
    margin-bottom: .66em;
    display: block;
}

.c-career-v2 .btn-link {
    text-transform: none;
    color: #000;
    border-width: 1px;
    padding: 1px 0;
    margin-top: 1em;
}

.c-career-v2 .btn-link:hover {
    border-color: #ccc;
}

main .container .job_detail_v2 h1 {
    font-size: 30px;
    text-transform: none;
    color: #000;
    background-image: none;
    margin-left: 0;
    padding-left: 0;
}

main .container .job_detail_v2 h2 {
    font-size: 15px;
    font-weight: 600;
    font-family: "ralewayregular", Helvetica, Arial, sans-serif;
}


 [ng\:cloak], [ng-cloak], [data-ng-cloak], [x-ng-cloak], .ng-cloak, .x-ng-cloak {
     display: none !important;
 }

/* **********************************************
 * Slider
 ********************************************** */

.infiniteSlide img {
    margin-right: 50px;
}
@charset "UTF-8";

/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.5.1
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2016 Daniel Eden
 */

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

.animated.hinge {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}

.animated.flipOutX,
.animated.flipOutY,
.animated.bounceIn,
.animated.bounceOut {
  -webkit-animation-duration: .75s;
  animation-duration: .75s;
}

@-webkit-keyframes bounce {
  from, 20%, 53%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
  }

  40%, 43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    -webkit-transform: translate3d(0,-4px,0);
    transform: translate3d(0,-4px,0);
  }
}

@keyframes bounce {
  from, 20%, 53%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
  }

  40%, 43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    -webkit-transform: translate3d(0,-4px,0);
    transform: translate3d(0,-4px,0);
  }
}

.bounce {
  -webkit-animation-name: bounce;
  animation-name: bounce;
  -webkit-transform-origin: center bottom;
  transform-origin: center bottom;
}

@-webkit-keyframes flash {
  from, 50%, to {
    opacity: 1;
  }

  25%, 75% {
    opacity: 0;
  }
}

@keyframes flash {
  from, 50%, to {
    opacity: 1;
  }

  25%, 75% {
    opacity: 0;
  }
}

.flash {
  -webkit-animation-name: flash;
  animation-name: flash;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse;
}

@-webkit-keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1);
  }

  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1);
  }

  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1);
  }

  65% {
    -webkit-transform: scale3d(.95, 1.05, 1);
    transform: scale3d(.95, 1.05, 1);
  }

  75% {
    -webkit-transform: scale3d(1.05, .95, 1);
    transform: scale3d(1.05, .95, 1);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1);
  }

  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1);
  }

  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1);
  }

  65% {
    -webkit-transform: scale3d(.95, 1.05, 1);
    transform: scale3d(.95, 1.05, 1);
  }

  75% {
    -webkit-transform: scale3d(1.05, .95, 1);
    transform: scale3d(1.05, .95, 1);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand;
}

@-webkit-keyframes shake {
  from, to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  10%, 30%, 50%, 70%, 90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  20%, 40%, 60%, 80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
}

@keyframes shake {
  from, to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  10%, 30%, 50%, 70%, 90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  20%, 40%, 60%, 80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
}

.shake {
  -webkit-animation-name: shake;
  animation-name: shake;
}

@-webkit-keyframes headShake {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }

  6.5% {
    -webkit-transform: translateX(-6px) rotateY(-9deg);
    transform: translateX(-6px) rotateY(-9deg);
  }

  18.5% {
    -webkit-transform: translateX(5px) rotateY(7deg);
    transform: translateX(5px) rotateY(7deg);
  }

  31.5% {
    -webkit-transform: translateX(-3px) rotateY(-5deg);
    transform: translateX(-3px) rotateY(-5deg);
  }

  43.5% {
    -webkit-transform: translateX(2px) rotateY(3deg);
    transform: translateX(2px) rotateY(3deg);
  }

  50% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes headShake {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }

  6.5% {
    -webkit-transform: translateX(-6px) rotateY(-9deg);
    transform: translateX(-6px) rotateY(-9deg);
  }

  18.5% {
    -webkit-transform: translateX(5px) rotateY(7deg);
    transform: translateX(5px) rotateY(7deg);
  }

  31.5% {
    -webkit-transform: translateX(-3px) rotateY(-5deg);
    transform: translateX(-3px) rotateY(-5deg);
  }

  43.5% {
    -webkit-transform: translateX(2px) rotateY(3deg);
    transform: translateX(2px) rotateY(3deg);
  }

  50% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

.headShake {
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-name: headShake;
  animation-name: headShake;
}

@-webkit-keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg);
  }

  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg);
  }

  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg);
  }

  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg);
  }

  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg);
  }
}

@keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg);
  }

  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg);
  }

  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg);
  }

  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg);
  }

  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg);
  }
}

.swing {
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing;
}

@-webkit-keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  10%, 20% {
    -webkit-transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
  }

  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }

  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  10%, 20% {
    -webkit-transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
  }

  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }

  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.tada {
  -webkit-animation-name: tada;
  animation-name: tada;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes wobble {
  from {
    -webkit-transform: none;
    transform: none;
  }

  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }

  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }

  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }

  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }

  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes wobble {
  from {
    -webkit-transform: none;
    transform: none;
  }

  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }

  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }

  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }

  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }

  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble;
}

@-webkit-keyframes jello {
  from, 11.1%, to {
    -webkit-transform: none;
    transform: none;
  }

  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }

  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg);
  }

  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }

  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }

  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }

  77.7% {
    -webkit-transform: skewX(0.390625deg) skewY(0.390625deg);
    transform: skewX(0.390625deg) skewY(0.390625deg);
  }

  88.8% {
    -webkit-transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
    transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
  }
}

@keyframes jello {
  from, 11.1%, to {
    -webkit-transform: none;
    transform: none;
  }

  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }

  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg);
  }

  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }

  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }

  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }

  77.7% {
    -webkit-transform: skewX(0.390625deg) skewY(0.390625deg);
    transform: skewX(0.390625deg) skewY(0.390625deg);
  }

  88.8% {
    -webkit-transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
    transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
  }
}

.jello {
  -webkit-animation-name: jello;
  animation-name: jello;
  -webkit-transform-origin: center;
  transform-origin: center;
}

@-webkit-keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }

  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  40% {
    -webkit-transform: scale3d(.9, .9, .9);
    transform: scale3d(.9, .9, .9);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03);
  }

  80% {
    -webkit-transform: scale3d(.97, .97, .97);
    transform: scale3d(.97, .97, .97);
  }

  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }

  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  40% {
    -webkit-transform: scale3d(.9, .9, .9);
    transform: scale3d(.9, .9, .9);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03);
  }

  80% {
    -webkit-transform: scale3d(.97, .97, .97);
    transform: scale3d(.97, .97, .97);
  }

  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.bounceIn {
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn;
}

@-webkit-keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown;
}

@-webkit-keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft;
}

@-webkit-keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0);
  }

  to {
    -webkit-transform: none;
    transform: none;
  }
}

.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight;
}

@-webkit-keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.bounceInUp {
  -webkit-animation-name: bounceInUp;
  animation-name: bounceInUp;
}

@-webkit-keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(.9, .9, .9);
    transform: scale3d(.9, .9, .9);
  }

  50%, 55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }
}

@keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(.9, .9, .9);
    transform: scale3d(.9, .9, .9);
  }

  50%, 55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }
}

.bounceOut {
  -webkit-animation-name: bounceOut;
  animation-name: bounceOut;
}

@-webkit-keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

@keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

.bounceOutDown {
  -webkit-animation-name: bounceOutDown;
  animation-name: bounceOutDown;
}

@-webkit-keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

.bounceOutLeft {
  -webkit-animation-name: bounceOutLeft;
  animation-name: bounceOutLeft;
}

@-webkit-keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

@keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

.bounceOutRight {
  -webkit-animation-name: bounceOutRight;
  animation-name: bounceOutRight;
}

@-webkit-keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

@keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

.bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
}

@-webkit-keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown;
}

@-webkit-keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig;
}

@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
}

@-webkit-keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig;
}

@-webkit-keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight;
}

@-webkit-keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig;
}

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig;
}

@-webkit-keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}

@-webkit-keyframes fadeOutDown {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

@keyframes fadeOutDown {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

.fadeOutDown {
  -webkit-animation-name: fadeOutDown;
  animation-name: fadeOutDown;
}

@-webkit-keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

@keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

.fadeOutDownBig {
  -webkit-animation-name: fadeOutDownBig;
  animation-name: fadeOutDownBig;
}

@-webkit-keyframes fadeOutLeft {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

@keyframes fadeOutLeft {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

.fadeOutLeft {
  -webkit-animation-name: fadeOutLeft;
  animation-name: fadeOutLeft;
}

@-webkit-keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

@keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

.fadeOutLeftBig {
  -webkit-animation-name: fadeOutLeftBig;
  animation-name: fadeOutLeftBig;
}

@-webkit-keyframes fadeOutRight {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

@keyframes fadeOutRight {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

.fadeOutRight {
  -webkit-animation-name: fadeOutRight;
  animation-name: fadeOutRight;
}

@-webkit-keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

@keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

.fadeOutRightBig {
  -webkit-animation-name: fadeOutRightBig;
  animation-name: fadeOutRightBig;
}

@-webkit-keyframes fadeOutUp {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

@keyframes fadeOutUp {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

.fadeOutUp {
  -webkit-animation-name: fadeOutUp;
  animation-name: fadeOutUp;
}

@-webkit-keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

@keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

.fadeOutUpBig {
  -webkit-animation-name: fadeOutUpBig;
  animation-name: fadeOutUpBig;
}

@-webkit-keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  80% {
    -webkit-transform: perspective(400px) scale3d(.95, .95, .95);
    transform: perspective(400px) scale3d(.95, .95, .95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}

@keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  80% {
    -webkit-transform: perspective(400px) scale3d(.95, .95, .95);
    transform: perspective(400px) scale3d(.95, .95, .95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}

.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  -webkit-animation-name: flip;
  animation-name: flip;
}

@-webkit-keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

@keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInX;
  animation-name: flipInX;
}

@-webkit-keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

@keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInY;
  animation-name: flipInY;
}

@-webkit-keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}

@keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}

.flipOutX {
  -webkit-animation-name: flipOutX;
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}

@keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}

.flipOutY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY;
}

@-webkit-keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }

  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1;
  }

  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }

  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1;
  }

  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

@-webkit-keyframes lightSpeedOut {
  from {
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}

@keyframes lightSpeedOut {
  from {
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}

.lightSpeedOut {
  -webkit-animation-name: lightSpeedOut;
  animation-name: lightSpeedOut;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in;
}

@-webkit-keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn;
}

@-webkit-keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft;
}

@-webkit-keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight;
}

@-webkit-keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft;
}

@-webkit-keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1;
  }
}

.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight;
}

@-webkit-keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0;
  }
}

@keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0;
  }
}

.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut;
}

@-webkit-keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }
}

@keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }
}

.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft;
}

@-webkit-keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

@keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight;
}

@-webkit-keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

@keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft;
}

@-webkit-keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0;
  }
}

@keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0;
  }
}

.rotateOutUpRight {
  -webkit-animation-name: rotateOutUpRight;
  animation-name: rotateOutUpRight;
}

@-webkit-keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  20%, 60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  40%, 80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}

@keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  20%, 60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  40%, 80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}

.hinge {
  -webkit-animation-name: hinge;
  animation-name: hinge;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes rollOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
  }
}

@keyframes rollOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
  }
}

.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut;
}

@-webkit-keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }

  50% {
    opacity: 1;
  }
}

@keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }

  50% {
    opacity: 1;
  }
}

.zoomIn {
  -webkit-animation-name: zoomIn;
  animation-name: zoomIn;
}

@-webkit-keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

@keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInDown {
  -webkit-animation-name: zoomInDown;
  animation-name: zoomInDown;
}

@-webkit-keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
    transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

@keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
    transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInLeft {
  -webkit-animation-name: zoomInLeft;
  animation-name: zoomInLeft;
}

@-webkit-keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
    transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

@keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
    transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInRight {
  -webkit-animation-name: zoomInRight;
  animation-name: zoomInRight;
}

@-webkit-keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

@keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInUp {
  -webkit-animation-name: zoomInUp;
  animation-name: zoomInUp;
}

@-webkit-keyframes zoomOut {
  from {
    opacity: 1;
  }

  50% {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }

  to {
    opacity: 0;
  }
}

@keyframes zoomOut {
  from {
    opacity: 1;
  }

  50% {
    opacity: 0;
    -webkit-transform: scale3d(.3, .3, .3);
    transform: scale3d(.3, .3, .3);
  }

  to {
    opacity: 0;
  }
}

.zoomOut {
  -webkit-animation-name: zoomOut;
  animation-name: zoomOut;
}

@-webkit-keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

@keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomOutDown {
  -webkit-animation-name: zoomOutDown;
  animation-name: zoomOutDown;
}

@-webkit-keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(.1) translate3d(-2000px, 0, 0);
    transform: scale(.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center;
  }
}

@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(.1) translate3d(-2000px, 0, 0);
    transform: scale(.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center;
  }
}

.zoomOutLeft {
  -webkit-animation-name: zoomOutLeft;
  animation-name: zoomOutLeft;
}

@-webkit-keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(.1) translate3d(2000px, 0, 0);
    transform: scale(.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center;
  }
}

@keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
    transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(.1) translate3d(2000px, 0, 0);
    transform: scale(.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center;
  }
}

.zoomOutRight {
  -webkit-animation-name: zoomOutRight;
  animation-name: zoomOutRight;
}

@-webkit-keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

@keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
    transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomOutUp {
  -webkit-animation-name: zoomOutUp;
  animation-name: zoomOutUp;
}

@-webkit-keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown;
}

@-webkit-keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft;
}

@-webkit-keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight;
}

@-webkit-keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInUp {
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp;
}

@-webkit-keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

@keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

.slideOutDown {
  -webkit-animation-name: slideOutDown;
  animation-name: slideOutDown;
}

@-webkit-keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

@keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

.slideOutLeft {
  -webkit-animation-name: slideOutLeft;
  animation-name: slideOutLeft;
}

@-webkit-keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

@keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

.slideOutRight {
  -webkit-animation-name: slideOutRight;
  animation-name: slideOutRight;
}

@-webkit-keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

@keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp;
}


/* ==========================================================================
   General
   ========================================================================== */

body, p, a, h1, h2, h3, h4 {
    font-family: 'Nunito Sans', sans-serif;
}

body, p {
    font-size: 18px;
}

h1, h2, h3, h4 {
    color: #131313;
}

h1, h2, h3 {
    font-size: 25px;
}

h1, h2, h4 {
    font-weight: 800;
}

h2 {
    text-transform: uppercase;
}

h4 {
    font-size: 20px;
}


.highlight {
    color: #131313;
    font-size: 55px;
    line-height: 1.2;
}

.highlight2 {
    color: #131313;
    font-size: 28px;
}

/* **********************************************
 * Countdown
 ********************************************** */

#wrapper-countdown {
    color: #000;
}

#wrapper-countdown div {
    border: 2px solid #000;
}

/* **********************************************
 * Video
 ********************************************** */

button.button-video-play {
    color: #fff;
    position: absolute;
    top: 32%;
    z-index: 1000;
    left: 45%;
    font-size: 9vw;
    background: none;
    border: 0;
}

/* **********************************************
 * Header
 ********************************************** */

header {
    padding: 5px 0 10px 0;
    box-shadow: none;
}

.navbar-nav.navbar-right > li > a {
    padding-top: 0;
    padding-bottom: 0;
}

header,
header ul.dropdown-menu,
header .navbar-nav > li > .dropdown-menu {
    background-color: rgba(0, 0, 0, 0.8);
}

header ul.dropdown-menu {
    border-top: 2px solid #000;
    margin: 0;
}

header ul li.dropdown.open {
    position: static;
}

header ul li a,
header ul.dropdown-menu li a {
    color: #fff;
    border-bottom: 1px solid transparent;
    font-size: 14px;
}

.navbar-nav > li {
    background-color: transparent;
}

header ul li a:hover,
header ul.dropdown-menu li a:hover {
    background: transparent;
    color: #fff;
    border-bottom: 1px solid #fff;
}

header .nav .open > a,
header .nav .open > a:hover,
header .nav .open > a:focus,
header .nav > li > a:hover,
header .nav > li > a:focus {
    background-color: transparent;
    border-color: transparent;
}

header .row > div {
    margin-bottom: 0;
}

header .dropdown .dropdown-menu li {
    float: none;
}

header .dropdown .dropdown-menu img {
    padding-top: 10px;
}

header ul li:first-child a {
    padding-left: 10px;
}

.navbar-nav > li > .dropdown-menu {
    padding: 0;
    top: 75px;
}

/* **********************************************
 * Footer
 ********************************************** */

footer.navbar {
    background-color: #231f20;
}

footer .c-Footer,
footer .c-Footer > .container > .row,
footer .c-Footer > .container > .row > div  {
    background-image: none;
    background-color: transparent;
}

footer .footer-logo {
    margin-bottom: 25px;
}

footer .footer-text {
    color: #fefefe;
}

footer .footer-text a.btn.full {
    color: #fefefe;
    border-color: #fefefe;
    width: 100%;
}

footer #footer-legal span,
footer #footer-legal a{
    color: #74706f;
}

footer #footer-legal span {
    font-size: 1.3em;
}

footer #footer-legal span.fa {
    color: #fefefe;
    padding: 0 4px;
}

footer #footer-legal #footer-legal-url a {
    font-size: .9em;
    border-right: 1px solid #74706f;
    padding: 0 10px;
}

footer #footer-legal #footer-legal-url a:first-of-type {
    padding-left: 0;
}

footer #footer-legal #footer-legal-url a:last-of-type {
    border-right: 0;
    padding-right: 0;
}

footer .c-Footer .nav li a {
    font-size: 18px;
}

@media screen and (max-width: 1200px) {
  #wrapper-countdown div {
        border: 2px solid #fff;
    padding: 4px;
    text-align: center;
    margin: 0 auto;
    width: 22%;
  }
}

@media screen and (max-width: 1200px) {
#wrapper-countdown div {
    border: 2px solid #000;
    font-size: 3vw;
}
}