@import url(../aghdasi-typo/typography.css);

/*
* RTL File By Farham Aghdasi
! RTL-THEMES | Orginal Version With Comments
* studyhub HTML Template 1403-1405
*/

:root {
    --font-anjoman: 'anjoman';
    --font-anjoman-bold: 'anjoman-bold';
    --font-aviny: 'aviny';
    --font-behdad: 'behdad';
    --font-dima: 'dima';
    --font-dordane: 'dordane';
    --font-dastnevis: 'dastnevis';
    --font-dana: 'dana';
    --font-dana-bold: 'dana-bold';
    --font-dana-bold-latin: 'dana-bold-latin';
    --font-dana-light: 'dana-light';
    --font-dana-medium: 'dana-medium';
    --font-dana-regular: 'dana-regular';
    --font-dana-thin: 'dana-thin';
    --font-fanavari-bold: 'fanavari-bold';
    --font-fanavari-regular: 'fanavari-regular';
    --font-estedad-bold: 'estedad-bold';
    --font-estedad-light: 'estedad-light';
    --font-estedad-medium: 'estedad-medium';
    --font-hilda: 'hilda';
    --font-hekayat: 'hekayat';
    --font-hana: 'hana';
    --font-hala: 'hala';
    --font-hoor: 'hoor';
    --font-iran: 'iran';
    --font-iran-gerd: 'iran-gerd';
    --font-khandevane: 'khandevane';
    --font-kalameh: 'kalameh';
    --font-khaton: 'khaton';
    --font-lalezar: 'lalezar';
    --font-mahboubeh: 'mahboubeh';
    --font-nahid: 'nahid';
    --font-negaar: 'negaar';
    --font-negaar-bold: 'negaar-bold';
    --font-nic: 'nic';
    --font-pinar: 'pinar';
    --font-pinar-ds1: 'pinar ds1';
    --font-pinar-ds2: 'pinar ds2';
    --font-iranyekan: 'iranyekan';
    --font-iranyekanweb: 'iranyekanweb';
    --font-vazirmatn-thin: 'vazirmatn';
    --font-vazirmatn-extralight: 'vazirmatn';
    --font-vazirmatn-light: 'vazirmatn';
    --font-vazirmatn-regular: 'vazirmatn';
    --font-vazirmatn-medium: 'vazirmatn';
    --font-vazirmatn-semibold: 'vazirmatn';
    --font-vazirmatn-bold: 'vazirmatn';
    --font-vazirmatn-extrabold: 'vazirmatn';
    --font-vazirmatn-black: 'vazirmatn';
    --font-yekanbakh-light: 'yekanbakh';
    --font-estedad: 'estedad';
    --font-yekanbakh-regular: 'yekanbakh';
    --font-yekanbakh-semibold: 'yekanbakh';
    --font-yekanbakh-bold: 'yekanbakh';
    --font-yekanbakh-extrabold: 'yekanbakh';
    --font-iransans: 'iransans';
    --font-iransans-medium: 'iransans-medium';
}

body,
.owl-item {
    direction: ltr;
}

.arrow {
    transform: rotateY(180deg);
}

body {
    direction: rtl;
}

html {
    overflow-x: hidden !important;
}

.fa-regular,
.far {
    vertical-align: middle;
}

*:not(i),
.header-right-area-one .actions-area .cart i::after {
    font-family: 'iransans' !important;
}

* {
    letter-spacing: 0 !important;
}

.owl-carousel {
    direction: rtl;
}

:root {
    --color-primary: #5137E3;
    --color-primary-2: #FFD335;
    --color-secondary: #1F1F25;
    --color-secondary-2: #FF6354;
    --color-body: #4F4F55;
    --color-border: #BCBFDB;
    --color-heading-1: #26262C;
    --color-title: #110C2D;
    --color-white: #fff;
    --color-success: #26CF4B;
    --color-danger: #FF0003;
    --color-warning: #FF8F3C;
    --color-info: #1BA2DB;
    --color-facebook: #3B5997;
    --color-twitter: #1BA1F2;
    --color-youtube: #ED4141;
    --color-linkedin: #0077B5;
    --color-pinterest: #E60022;
    --color-instagram: #C231A1;
    --color-vimeo: #00ADEF;
    --color-twitch: #6441A3;
    --color-discord: #7289da;
    --p-light: 300;
    --p-regular: 400;
    --p-medium: 500;
    --p-semi-bold: 600;
    --p-bold: 700;
    --p-extra-bold: 800;
    --p-black: 900;
    --s-light: 300;
    --s-regular: 400;
    --s-medium: 500;
    --s-semi-bold: 600;
    --s-bold: 700;
    --s-extra-bold: 800;
    --s-black: 900;
    --transition: 0.3s;
    --font-primary: "Hind", sans-serif;
    --font-secondary: "Inter", sans-serif;
    --font-three: "Font Awesome 6 Pro";
    --font-size-b1: 16px;
    --font-size-b2: 16px;
    --font-size-b3: 22px;
    --line-height-b1: 26px;
    --line-height-b2: 26px;
    --line-height-b3: 1.7;
    --h1: 80px;
    --h2: 48px;
    --h3: 32px;
    --h4: 26px;
    --h5: 24px;
    --h6: 20px;
}

* {
    box-sizing: border-box;
}

html {
    margin: 0;
    padding: 0;
    font-size: 10px;
    overflow-y: auto;
    scroll-behavior: auto !important;
}

body {
    font-size: var(--font-size-b1);
    line-height: var(--line-height-b1);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: var(--font-secondary);
    color: var(--color-body);
    font-weight: var(--p-regular);
    position: relative;
    overflow-x: hidden;
}

@media only screen and (min-width: 992px) and (max-width: 1199px) {
    body {
        overflow: hidden;
    }
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    body {
        overflow: hidden;
    }
}

@media only screen and (max-width: 767px) {
    body {
        overflow: hidden;
    }
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
address,
p,
pre,
blockquote,
menu,
ol,
ul,
table,
hr {
    margin: 0;
    margin-bottom: 20px;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
    word-break: break-word;
    font-family: var(--font-primary);
    line-height: 1.4074;
    color: var(--color-heading-1);
}

h1,
.h1 {
    font-size: var(--h1);
    line-height: 91px;
    font-weight: 700;
}

h2,
.h2 {
    font-size: var(--h2);
    line-height: 1.23;
}

h3,
.h3 {
    font-size: var(--h3);
    line-height: 54px;
}

h4,
.h4 {
    font-size: var(--h4);
    line-height: 1.25;
}

h5,
.h5 {
    font-size: var(--h5);
    line-height: 1.24;
}

h6,
.h6 {
    font-size: var(--h6);
    line-height: 1.25;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
.h1 a,
.h2 a,
.h3 a,
.h4 a,
.h5 a,
.h6 a {
    color: inherit;
}

a {
    text-decoration: none;
}

.bg-color-tertiary h1,
.bg-color-tertiary h2,
.bg-color-tertiary h3,
.bg-color-tertiary h4,
.bg-color-tertiary h5,
.bg-color-tertiary h6,
.bg-color-tertiary .h1,
.bg-color-tertiary .h2,
.bg-color-tertiary .h3,
.bg-color-tertiary .h4,
.bg-color-tertiary .h5,
.bg-color-tertiary .h6 {
    color: #fff;
}

.bg-color-tertiary p {
    color: #6c7279;
}

.bg-color-tertiary a {
    color: #6c7279;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {

    h1,
    .h1 {
        font-size: 38px;
    }

    h2,
    .h2 {
        font-size: 32px;
    }

    h3,
    .h3 {
        font-size: 28px;
    }

    h4,
    .h4 {
        font-size: 24px;
    }

    h5,
    .h5 {
        font-size: 18px;
    }
}

@media only screen and (max-width: 767px) {

    h1,
    .h1 {
        font-size: 34px;
    }

    h2,
    .h2 {
        font-size: 28px;
    }

    h3,
    .h3 {
        font-size: 24px;
    }

    h4,
    .h4 {
        font-size: 20px;
    }

    h5,
    .h5 {
        font-size: 20px;
    }
}

h1,
.h1,
h2,
.h2,
h3,
.h3 {
    font-weight: var(--s-bold);
}

h4,
.h4,
h5,
.h5 {
    font-weight: var(--s-bold);
}

h6,
.h6 {
    font-weight: var(--s-bold);
}

p {
    font-size: var(--font-size-b2);
    line-height: var(--line-height-b2);
    font-weight: var(--p-regular);
    color: var(--color-body);
    margin: 0 0 40px;
}

@media only screen and (max-width: 767px) {
    p {
        margin: 0 0 20px;
        font-size: 16px;
        line-height: 28px;
    }
}

p.b1 {
    font-size: var(--font-size-b1);
    line-height: var(--line-height-b1);
}

p.b3 {
    font-size: var(--font-size-b3);
    line-height: var(--line-height-b3);
}

p.has-large-font-size {
    line-height: 1.5;
    font-size: 36px;
}

p.has-medium-font-size {
    font-size: 24px;
    line-height: 36px;
}

p.has-small-font-size {
    font-size: 13px;
}

p.has-very-light-gray-color {
    color: var(--color-white);
}

p.has-background {
    padding: 20px 30px;
}

p.b1 {
    font-size: var(--font-size-b1);
    line-height: var(--line-height-b1);
}

p.b2 {
    font-size: var(--font-size-b2);
    line-height: var(--line-height-b2);
}

p.b3 {
    font-size: var(--font-size-b3);
    line-height: var(--line-height-b3);
}

p:last-child {
    margin-bottom: 0;
}

.b1 {
    font-size: var(--font-size-b1);
    line-height: var(--line-height-b1);
}

.b2 {
    font-size: var(--font-size-b2);
    line-height: var(--line-height-b2);
}

.b3 {
    font-size: var(--font-size-b3);
    line-height: var(--line-height-b3);
}

.b4 {
    font-size: var(--font-size-b4);
    line-height: var(--line-height-b4);
}

table {
    border-collapse: collapse;
    border-spacing: 0;
    margin: 0 0 20px;
    width: 100%;
}

table a,
table a:link,
table a:visited {
    text-decoration: none;
}

var {
    font-family: var(--font-primary);
}

/*---------------------------
	List Style 
---------------------------*/
ul,
ol {
    padding-right: 18px;
}

ul {
    list-style: square;
    margin-bottom: 30px;
    padding-right: 20px;
}

ul li {
    font-size: var(--font-size-b1);
    line-height: var(--line-height-b1);
    margin-top: 10px;
    margin-bottom: 10px;
    color: var(--color-body);
}

ul li a {
    text-decoration: none;
    color: var(--color-gray);
}

ul li a:hover {
    color: var(--color-primary);
}

ul ul {
    margin-bottom: 0;
}

ol {
    margin-bottom: 30px;
}

ol li {
    font-size: var(--font-size-b1);
    line-height: var(--line-height-b1);
    color: var(--color-body);
    margin-top: 10px;
    margin-bottom: 10px;
}

ol li a {
    color: var(--color-heading);
    text-decoration: none;
}

ol li a:hover {
    color: var(--color-primary);
}

ol ul {
    padding-right: 30px;
}

/*=========================
    Section Separation 
==========================*/
.mb_dec--25 {
    margin-bottom: -25px;
}

.mb_dec--30 {
    margin-bottom: -30px;
}

.m--0 {
    margin: 0;
}

.p--0 {
    padding: 0;
}

.rts-section-gap {
    padding: 80px 0;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gap {
        padding: 80px 0;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gap {
        padding: 60px 0;
    }
}

.rts-section-gapTop {
    padding-top: 80px;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gapTop {
        padding-top: 70px;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gapTop {
        padding-top: 60px;
    }
}

.rts-section-gap2Bottom {
    padding-top: 80px;
    padding-bottom: 130px;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gap2Bottom {
        padding-bottom: 80px;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gap2Bottom {
        padding-bottom: 60px;
    }
}

.rts-section-gap2Top {
    padding-top: 130px;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gap2Top {
        padding-top: 70px;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gap2Top {
        padding-top: 60px;
    }
}

.rts-section-gap3 {
    padding: 150px 0;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gap3 {
        padding: 80px 0;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gap3 {
        padding: 60px 0;
    }
}

.rts-section-gap3Bottom {
    padding-bottom: 150px;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gap3Bottom {
        padding-bottom: 80px;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gap3Bottom {
        padding-bottom: 60px;
    }
}

.rts-section-gap3Top {
    padding-top: 150px;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .rts-section-gap3Top {
        padding-top: 70px;
    }
}

@media only screen and (max-width: 767px) {
    .rts-section-gap3Top {
        padding-top: 60px;
    }
}

/*------------------------------
    Scroll Up 
--------------------------------*/
#scrollUp {
    width: 70px;
    height: 80px;
    left: 100px;
    bottom: 60px;
    text-align: center;
    z-index: 9811 !important;
    text-decoration: none;
    background: #fff;
    line-height: 80px;
    color: #757589;
    font-size: 15px;
    font-weight: 400;
    transition: var(--transition);
    display: inline-block;
    background: #ffffff;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    #scrollUp {
        left: 20px;
        bottom: 40px;
    }
}

@media only screen and (max-width: 767px) {
    #scrollUp {
        left: 20px;
        bottom: 40px;
    }
}

#scrollUp::before {
    width: 100%;
    height: 100%;
    right: 0;
    bottom: 0;
    background: rgba(0, 2, 72, 0.1);
    content: "";
    position: absolute;
    z-index: -1;
    transform-style: preserve-3d;
    transform: rotateY(10deg);
    filter: blur(50px);
}

#scrollUp::after {
    background: #ffffff;
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    transform-style: preserve-3d;
    transform: rotateY(10deg);
}

@media only screen and (max-width: 767px) {
    #scrollUp {
        left: 20px;
        bottom: 30px;
        width: 50px;
        height: 60px;
        line-height: 60px;
    }
}

#scrollUp span.text {
    position: relative;
    display: inline-block;
    margin-top: 7px;
}

@media only screen and (max-width: 767px) {
    #scrollUp span.text {
        margin-top: 3px;
    }
}

#scrollUp span.text::after {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 5px 7px 5px;
    border-color: transparent transparent var(--color-primary) transparent;
    position: absolute;
    content: "";
    right: 50%;
    top: 21%;
    transform: translateX(50%);
}

#scrollUp:hover span.text {
    color: var(--color-primary);
}

/*!
Animate.css - http://daneden.me/animate
Version - 3.4.0
Licensed under the MIT license - http://opensource.org/licenses/MIT

Copyright (c) 2015 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.bounceIn,
.animated.bounceOut {
    -webkit-animation-duration: 0.75s;
    animation-duration: 0.75s;
}

.animated.flipOutX,
.animated.flipOutY {
    -webkit-animation-duration: 0.75s;
    animation-duration: 0.75s;
}

@-webkit-keyframes bounce {

    from,
    20%,
    53%,
    80%,
    to {
        -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

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

    70% {
        -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        -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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

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

    70% {
        -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
        -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;
}

/*jump animation */
@keyframes jump-1 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

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

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

@keyframes jump-2 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

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

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

@keyframes jump-3 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    40% {
        -webkit-transform: translate3d(0, 50px, 0) scale(0.7);
        transform: translate3d(0, 50px, 0) scale(0.7);
    }

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

@keyframes jump-4 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    40% {
        -webkit-transform: translate3d(0, 20px, 0) scale(0.8);
        transform: translate3d(0, 20px, 0) scale(0.8);
    }

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

@keyframes jump-5 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    40% {
        transform: translate3d(0, 10px, 0);
    }

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

@-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;
}

@-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(0.95, 1.05, 1);
        transform: scale3d(0.95, 1.05, 1);
    }

    75% {
        -webkit-transform: scale3d(1.05, 0.95, 1);
        transform: scale3d(1.05, 0.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(0.95, 1.05, 1);
        transform: scale3d(0.95, 1.05, 1);
    }

    75% {
        -webkit-transform: scale3d(1.05, 0.95, 1);
        transform: scale3d(1.05, 0.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 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(0.9, 0.9, 0.9) rotate3d(0, 0, 1, 3deg);
        transform: scale3d(0.9, 0.9, 0.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(0.9, 0.9, 0.9) rotate3d(0, 0, 1, 3deg);
        transform: scale3d(0.9, 0.9, 0.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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

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

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

    40% {
        -webkit-transform: scale3d(0.9, 0.9, 0.9);
        transform: scale3d(0.9, 0.9, 0.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(0.97, 0.97, 0.97);
        transform: scale3d(0.97, 0.97, 0.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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

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

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

    40% {
        -webkit-transform: scale3d(0.9, 0.9, 0.9);
        transform: scale3d(0.9, 0.9, 0.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(0.97, 0.97, 0.97);
        transform: scale3d(0.97, 0.97, 0.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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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.61, 0.355, 1);
        animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    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(0.9, 0.9, 0.9);
        transform: scale3d(0.9, 0.9, 0.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(0.3, 0.3, 0.3);
        transform: scale3d(0.3, 0.3, 0.3);
    }
}

@keyframes bounceOut {
    20% {
        -webkit-transform: scale3d(0.9, 0.9, 0.9);
        transform: scale3d(0.9, 0.9, 0.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(0.3, 0.3, 0.3);
        transform: scale3d(0.3, 0.3, 0.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;
    }
}

@keyframes fadeInUp2 {
    from {
        opacity: 0;
        -webkit-transform: translate3d(0, 40%, 0);
        transform: translate3d(0, 40%, 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(0.95, 0.95, 0.95);
        transform: perspective(400px) scale3d(0.95, 0.95, 0.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(0.95, 0.95, 0.95);
        transform: perspective(400px) scale3d(0.95, 0.95, 0.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: 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 rotateInDownLeft {
    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;
    }
}

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

@-webkit-keyframes rotateInDownRight {
    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 rotateInDownRight {
    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;
    }
}

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

@-webkit-keyframes rotateInUpLeft {
    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 rotateInUpLeft {
    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;
    }
}

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

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

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

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

    to {
        -webkit-transform-origin: left bottom;
        transform-origin: left 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: 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 rotateOutDownLeft {
    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;
    }
}

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

@-webkit-keyframes rotateOutDownRight {
    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 rotateOutDownRight {
    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;
    }
}

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

@-webkit-keyframes rotateOutUpLeft {
    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 rotateOutUpLeft {
    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;
    }
}

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

@-webkit-keyframes rotateOutUpRight {
    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, -90deg);
        transform: rotate3d(0, 0, 1, -90deg);
        opacity: 0;
    }
}

@keyframes rotateOutUpRight {
    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, -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 right;
        transform-origin: top right;
        -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 right;
        transform-origin: top right;
        -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 right;
        transform-origin: top right;
        -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 right;
        transform-origin: top right;
        -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 right;
        transform-origin: top right;
        -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 right;
        transform-origin: top right;
        -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(0.3, 0.3, 0.3);
        transform: scale3d(0.3, 0.3, 0.3);
    }

    50% {
        opacity: 1;
    }
}

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

    50% {
        opacity: 1;
    }
}

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

@-webkit-keyframes zoomInDown {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

@keyframes zoomInDown {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

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

@-webkit-keyframes zoomInLeft {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

@keyframes zoomInLeft {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

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

@-webkit-keyframes zoomInRight {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

@keyframes zoomInRight {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

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

@-webkit-keyframes zoomInUp {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

@keyframes zoomInUp {
    from {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
        transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
        animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }

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

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

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

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

    to {
        opacity: 0;
    }
}

@keyframes zoomOut {
    from {
        opacity: 1;
    }

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

    to {
        opacity: 0;
    }
}

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

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

    to {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
        transform: scale3d(0.1, 0.1, 0.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.32, 1);
        animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    }
}

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

    to {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
        transform: scale3d(0.1, 0.1, 0.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.32, 1);
        animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

    to {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
        transform: scale3d(0.1, 0.1, 0.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.32, 1);
        animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    }
}

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

    to {
        opacity: 0;
        -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
        transform: scale3d(0.1, 0.1, 0.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.32, 1);
        animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 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);
    }
}

@keyframes slideInLeft2 {
    from {
        -webkit-transform: translate3d(10%, 0, 0);
        transform: translate3d(10%, 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);
    }
}

@keyframes slideInUp2 {
    from {
        -webkit-transform: translate3d(0, 20%, 0);
        transform: translate3d(0, 20%, 0);
        visibility: hidden;
    }

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

@keyframes slideInUp3 {
    from {
        -webkit-transform: translate3d(0, 20px, 0);
        transform: translate3d(0, 20px, 0);
        visibility: hidden;
    }

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

[data-aos=slideInUp2] {
    opacity: 0;
    transition-property: transform, opacity;
}

[data-aos=slideInUp2].aos-animate {
    opacity: 1;
}

@media screen and (min-width: 768px) {
    [data-aos=slideInUp2] {
        transform: translateY(30px);
    }

    [data-aos=slideInUp2].aos-animate {
        transform: translateY(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;
}

@keyframes jump-1 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

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

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

@keyframes jump-2 {
    0% {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

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

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

@keyframes rotateIt {
    to {
        transform: rotate(360deg);
    }
}

@keyframes rotateIt2 {
    to {
        transform: rotate(-360deg);
    }
}

@keyframes shape-service-1 {
    0% {
        left: -40%;
        top: 30%;
    }

    100% {
        left: -23%;
        top: 0;
    }
}

@keyframes animate-floting {
    0% {
        transform: translateX(-50%);
    }

    50% {
        transform: translateX(40%);
    }

    100% {
        transform: translateX(-40%);
    }
}

@keyframes animate-floting-2 {
    0% {
        transform: translateX(50%);
    }

    50% {
        transform: translateX(-40%);
    }

    100% {
        transform: translateX(40%);
    }
}

@keyframes animate-floting-3 {
    0% {
        transform: translateX(20%);
    }

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

    100% {
        transform: translateX(20%);
    }
}

.floting-line {
    animation: animate-floting 15s linear infinite;
}

.floting-line:hover {
    animation-play-state: paused;
}

.floting-line-2 {
    animation: animate-floting-2 15s linear infinite;
}

.floting-line-2:hover {
    animation-play-state: paused;
}

@keyframes waves {
    0% {
        -webkit-transform: scale(0.2, 0.2);
        transform: scale(0.2, 0.2);
        opacity: 0;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    }

    50% {
        opacity: 0.9;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=90)";
    }

    100% {
        -webkit-transform: scale(0.9, 0.9);
        transform: scale(0.9, 0.9);
        opacity: 0;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    }
}

@keyframes vsmorph {
    0% {
        border-radius: var(--morp-value);
    }

    50% {
        border-radius: var(--morp-md-value);
    }

    100% {
        border-radius: 60% 40%;
    }
}

@keyframes morpspin {
    to {
        -webkit-transform: rotate(-1turn);
        transform: rotate(-1turn);
    }
}

.reveal-item {
    position: relative;
    display: block;
    overflow: hidden;
}

.reveal-item .reveal-animation {
    position: absolute;
    top: 0;
    width: 100%;
    height: 101%;
    background: var(--color-primary);
}

.reveal-item .reveal-animation::before {
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background-color: var(--bs-gray-400);
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: 1s;
    transition-duration: 1s;
}

.reveal-animation.reveal-primary::before {
    background: #0c0c0a;
}

.reveal-animation.reveal-dark::before {
    background: #000;
}

.reveal-animation.reveal-white::before {
    background: #000;
}

.reveal-animation.reveal-top.aos-animate::before,
.reveal-animation.reveal-bottom.aos-animate::before {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
}

.reveal-animation.reveal-start.aos-animate::before,
.reveal-animation.reveal-end.aos-animate::before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
}

.reveal-animation.reveal-top::before {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
}

.reveal-animation.reveal-start::before {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0% 0%;
    transform-origin: 0% 0%;
}

.reveal-animation.reveal-end::before {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
}

.reveal-animation.reveal-bottom::before {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: 0% 0%;
    transform-origin: 0% 0%;
}

[data-aos=reveal-top],
[data-aos=reveal-start],
[data-aos=reveal-end],
[data-aos=reveal-bottom] {
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-delay: 1s;
    transition-delay: 1s;
}

[data-aos=reveal-top] {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
}

[data-aos=reveal-top].aos-animate {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: 0% 0%;
    transform-origin: 0% 0%;
}

[data-aos=reveal-start] {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
}

[data-aos=reveal-start].aos-animate {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
}

[data-aos=reveal-end] {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
}

[data-aos=reveal-end].aos-animate {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0% 0%;
    transform-origin: 0% 0%;
}

[data-aos=reveal-bottom] {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
}

[data-aos=reveal-bottom].aos-animate {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
}

[data-aos=reveal-item] {
    visibility: hidden;
    -webkit-transition-property: visibility;
    transition-property: visibility;
    -webkit-transition-duration: 0s;
    transition-duration: 0s;
}

[data-aos=reveal-item].aos-animate {
    visibility: visible;
}

@keyframes customOne {
    0% {
        -webkit-transform: translateY(-50%) scale(0);
        transform: translateY(-50%) scale(0);
        opacity: 1;
    }

    100% {
        -webkit-transform: translateY(-50%) scale(1.3);
        transform: translateY(-50%) scale(1.3);
        opacity: 0;
    }
}

@keyframes liveAuction {
    0% {
        background: var(--color-white);
    }

    100% {
        background: var(--color-danger);
    }
}

.cd-intro {
    margin: 4em auto;
}

@media only screen and (min-width: 768px) {
    .cd-intro {
        margin: 5em auto;
    }
}

@media only screen and (min-width: 1170px) {
    .cd-intro {
        margin: 6em auto;
    }
}

.cd-headline {
    font-size: 3rem;
    line-height: 1.2;
}

@media only screen and (min-width: 768px) {
    .cd-headline {
        font-size: 4.4rem;
        font-weight: 300;
    }
}

@media only screen and (min-width: 1170px) {
    .cd-headline {
        font-size: 48px;
    }
}

@media only screen and (max-width: 768px) {
    .cd-headline {
        font-size: 40px;
    }
}

@media only screen and (max-width: 479px) {
    .cd-headline {
        font-size: 26px;
    }
}

.cd-words-wrapper {
    display: inline-block;
    position: relative;
    text-align: right;
}

.cd-words-wrapper b {
    display: inline-block;
    position: absolute;
    white-space: nowrap;
    right: 0;
    top: 0;
}

.cd-words-wrapper b.is-visible {
    position: relative;
}

.no-js .cd-words-wrapper b {
    opacity: 0;
}

.no-js .cd-words-wrapper b.is-visible {
    opacity: 1;
}

/* -------------------------------- 

xclip 

-------------------------------- */
.cd-headline.clip span {
    display: inline-block;
    padding: 0;
}

.cd-headline.clip .cd-words-wrapper {
    overflow: hidden;
    vertical-align: middle;
    position: relative;
    margin-top: -20px;
}

.cd-headline.clip .cd-words-wrapper b {
    font-weight: 700;
}

.cd-headline.clip .cd-words-wrapper::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 4px;
    height: 100%;
    background-color: var(--color-primary-3);
    transform: translateY(-50%);
}

.cd-headline.clip b {
    opacity: 0;
}

.cd-headline.clip b.is-visible {
    opacity: 1;
}

/**
 * Settings
 */
/**
  * Easings
  */
/**
  * Core
  */
[data-sal] {
    transition-duration: 0.2s;
    transition-delay: 0s;
    transition-duration: var(--sal-duration, 0.2s);
    transition-delay: var(--sal-delay, 0s);
    transition-timing-function: var(--sal-easing, ease);
}

[data-sal][data-sal-duration="200"] {
    transition-duration: 0.2s;
}

[data-sal][data-sal-duration="250"] {
    transition-duration: 0.25s;
}

[data-sal][data-sal-duration="300"] {
    transition-duration: 0.3s;
}

[data-sal][data-sal-duration="350"] {
    transition-duration: 0.35s;
}

[data-sal][data-sal-duration="400"] {
    transition-duration: 0.4s;
}

[data-sal][data-sal-duration="450"] {
    transition-duration: 0.45s;
}

[data-sal][data-sal-duration="500"] {
    transition-duration: 0.5s;
}

[data-sal][data-sal-duration="550"] {
    transition-duration: 0.55s;
}

[data-sal][data-sal-duration="600"] {
    transition-duration: 0.6s;
}

[data-sal][data-sal-duration="650"] {
    transition-duration: 0.65s;
}

[data-sal][data-sal-duration="700"] {
    transition-duration: 0.7s;
}

[data-sal][data-sal-duration="750"] {
    transition-duration: 0.75s;
}

[data-sal][data-sal-duration="800"] {
    transition-duration: 0.8s;
}

[data-sal][data-sal-duration="850"] {
    transition-duration: 0.85s;
}

[data-sal][data-sal-duration="900"] {
    transition-duration: 0.9s;
}

[data-sal][data-sal-duration="950"] {
    transition-duration: 0.95s;
}

[data-sal][data-sal-duration="1000"] {
    transition-duration: 1s;
}

[data-sal][data-sal-duration="1050"] {
    transition-duration: 1.05s;
}

[data-sal][data-sal-duration="1100"] {
    transition-duration: 1.1s;
}

[data-sal][data-sal-duration="1150"] {
    transition-duration: 1.15s;
}

[data-sal][data-sal-duration="1200"] {
    transition-duration: 1.2s;
}

[data-sal][data-sal-duration="1250"] {
    transition-duration: 1.25s;
}

[data-sal][data-sal-duration="1300"] {
    transition-duration: 1.3s;
}

[data-sal][data-sal-duration="1350"] {
    transition-duration: 1.35s;
}

[data-sal][data-sal-duration="1400"] {
    transition-duration: 1.4s;
}

[data-sal][data-sal-duration="1450"] {
    transition-duration: 1.45s;
}

[data-sal][data-sal-duration="1500"] {
    transition-duration: 1.5s;
}

[data-sal][data-sal-duration="1550"] {
    transition-duration: 1.55s;
}

[data-sal][data-sal-duration="1600"] {
    transition-duration: 1.6s;
}

[data-sal][data-sal-duration="1650"] {
    transition-duration: 1.65s;
}

[data-sal][data-sal-duration="1700"] {
    transition-duration: 1.7s;
}

[data-sal][data-sal-duration="1750"] {
    transition-duration: 1.75s;
}

[data-sal][data-sal-duration="1800"] {
    transition-duration: 1.8s;
}

[data-sal][data-sal-duration="1850"] {
    transition-duration: 1.85s;
}

[data-sal][data-sal-duration="1900"] {
    transition-duration: 1.9s;
}

[data-sal][data-sal-duration="1950"] {
    transition-duration: 1.95s;
}

[data-sal][data-sal-duration="2000"] {
    transition-duration: 2s;
}

[data-sal][data-sal-delay="50"] {
    transition-delay: 0.05s;
}

[data-sal][data-sal-delay="100"] {
    transition-delay: 0.1s;
}

[data-sal][data-sal-delay="150"] {
    transition-delay: 0.15s;
}

[data-sal][data-sal-delay="200"] {
    transition-delay: 0.2s;
}

[data-sal][data-sal-delay="250"] {
    transition-delay: 0.25s;
}

[data-sal][data-sal-delay="300"] {
    transition-delay: 0.3s;
}

[data-sal][data-sal-delay="350"] {
    transition-delay: 0.35s;
}

[data-sal][data-sal-delay="400"] {
    transition-delay: 0.4s;
}

[data-sal][data-sal-delay="450"] {
    transition-delay: 0.45s;
}

[data-sal][data-sal-delay="500"] {
    transition-delay: 0.5s;
}

[data-sal][data-sal-delay="550"] {
    transition-delay: 0.55s;
}

[data-sal][data-sal-delay="600"] {
    transition-delay: 0.6s;
}

[data-sal][data-sal-delay="650"] {
    transition-delay: 0.65s;
}

[data-sal][data-sal-delay="700"] {
    transition-delay: 0.7s;
}

[data-sal][data-sal-delay="750"] {
    transition-delay: 0.75s;
}

[data-sal][data-sal-delay="800"] {
    transition-delay: 0.8s;
}

[data-sal][data-sal-delay="850"] {
    transition-delay: 0.85s;
}

[data-sal][data-sal-delay="900"] {
    transition-delay: 0.9s;
}

[data-sal][data-sal-delay="950"] {
    transition-delay: 0.95s;
}

[data-sal][data-sal-delay="1000"] {
    transition-delay: 1s;
}

[data-sal][data-sal-easing=linear] {
    transition-timing-function: linear;
}

[data-sal][data-sal-easing=ease] {
    transition-timing-function: ease;
}

[data-sal][data-sal-easing=ease-in] {
    transition-timing-function: ease-in;
}

[data-sal][data-sal-easing=ease-out] {
    transition-timing-function: ease-out;
}

[data-sal][data-sal-easing=ease-in-out] {
    transition-timing-function: ease-in-out;
}

[data-sal][data-sal-easing=ease-in-cubic] {
    transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

[data-sal][data-sal-easing=ease-out-cubic] {
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

[data-sal][data-sal-easing=ease-in-out-cubic] {
    transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
}

[data-sal][data-sal-easing=ease-in-circ] {
    transition-timing-function: cubic-bezier(0.6, 0.04, 0.98, 0.335);
}

[data-sal][data-sal-easing=ease-out-circ] {
    transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
}

[data-sal][data-sal-easing=ease-in-out-circ] {
    transition-timing-function: cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

[data-sal][data-sal-easing=ease-in-expo] {
    transition-timing-function: cubic-bezier(0.95, 0.05, 0.795, 0.035);
}

[data-sal][data-sal-easing=ease-out-expo] {
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}

[data-sal][data-sal-easing=ease-in-out-expo] {
    transition-timing-function: cubic-bezier(1, 0, 0, 1);
}

[data-sal][data-sal-easing=ease-in-quad] {
    transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-sal][data-sal-easing=ease-out-quad] {
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-sal][data-sal-easing=ease-in-out-quad] {
    transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-sal][data-sal-easing=ease-in-quart] {
    transition-timing-function: cubic-bezier(0.895, 0.03, 0.685, 0.22);
}

[data-sal][data-sal-easing=ease-out-quart] {
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
}

[data-sal][data-sal-easing=ease-in-out-quart] {
    transition-timing-function: cubic-bezier(0.77, 0, 0.175, 1);
}

[data-sal][data-sal-easing=ease-in-quint] {
    transition-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
}

[data-sal][data-sal-easing=ease-out-quint] {
    transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);
}

[data-sal][data-sal-easing=ease-in-out-quint] {
    transition-timing-function: cubic-bezier(0.86, 0, 0.07, 1);
}

[data-sal][data-sal-easing=ease-in-sine] {
    transition-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
}

[data-sal][data-sal-easing=ease-out-sine] {
    transition-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
}

[data-sal][data-sal-easing=ease-in-out-sine] {
    transition-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
}

[data-sal][data-sal-easing=ease-in-back] {
    transition-timing-function: cubic-bezier(0.6, -0.28, 0.735, 0.045);
}

[data-sal][data-sal-easing=ease-out-back] {
    transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

[data-sal][data-sal-easing=ease-in-out-back] {
    transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/**
  * Animations
  */
[data-sal|=fade] {
    opacity: 0;
    transition-property: opacity;
}

[data-sal|=fade].sal-animate,
body.sal-disabled [data-sal|=fade] {
    opacity: 1;
}

[data-sal|=slide] {
    opacity: 0;
    transition-property: opacity, transform;
}

[data-sal=slide-up] {
    transform: translateY(20%);
}

[data-sal=slide-down] {
    transform: translateY(-20%);
}

[data-sal=slide-left] {
    transform: translateX(-20%);
}

[data-sal=slide-right] {
    transform: translateX(20%);
}

[data-sal|=slide].sal-animate,
body.sal-disabled [data-sal|=slide] {
    opacity: 1;
    transform: none;
}

[data-sal|=zoom] {
    opacity: 0;
    transition-property: opacity, transform;
}

[data-sal=zoom-in] {
    transform: scale(0.5);
}

[data-sal=zoom-out] {
    transform: scale(1.1);
}

[data-sal|=zoom].sal-animate,
body.sal-disabled [data-sal|=zoom] {
    opacity: 1;
    transform: none;
}

[data-sal|=flip] {
    backface-visibility: hidden;
    transition-property: transform;
}

[data-sal=flip-left] {
    transform: perspective(2000px) rotateY(91deg);
}

[data-sal=flip-right] {
    transform: perspective(2000px) rotateY(-91deg);
}

[data-sal=flip-up] {
    transform: perspective(2000px) rotateX(-91deg);
}

[data-sal=flip-down] {
    transform: perspective(2000px) rotateX(91deg);
}

[data-sal|=flip].sal-animate,
body.sal-disabled [data-sal|=flip] {
    transform: none;
}

/* header styles */
.header-style-one-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
}

.header-style-one-wrapper .button-area-start {
    display: flex;
    align-items: center;
    gap: 23px;
}

@media only screen and (max-width: 767px) {
    .header-style-one-wrapper .button-area-start .call-us {
        display: none;
    }
}

.header-style-one-wrapper .button-area-start a {
    font-weight: 600;
    font-family: var(--font-secondary);
    transition: 0.3s;
    padding: 8px 20px;
}

.header-style-one-wrapper .button-area-start a:hover {
    color: var(--color-white);
    background: var(--color-secondary);
}

.header-style-one-wrapper .logo-area .logo {
    padding: 25px 0;
    display: block;
}

.header-style-one {
    position: absolute;
    background: none;
    z-index: 1;
    border-bottom: 1px solid rgba(137, 137, 137, 0.1725490196);
    width: 100%;
    z-index: 5;
}

@media (max-width: 576px) {
    .header-style-one {
        padding-right: 10px;
        padding-left: 10px;
    }
}

.header-style-one .header-style-one-wrapper .main-nav-area {
    margin-right: 120px;
}

@media (max-width: 991px) {
    .header-style-one .header-style-one-wrapper .main-nav-area {
        display: none;
    }
}

@media only screen and (max-width: 1199px) {
    .header-style-one .header-style-one-wrapper .main-nav-area {
        margin-right: 0;
    }
}

.header--sticky {
    transition: 0s;
}

.header--sticky.sticky {
    position: fixed !important;
    top: 0;
    display: block;
    width: 100%;
    box-shadow: 0px 7px 18px rgba(24, 16, 16, 0.0509803922);
    background: var(--color-primary);
    z-index: 999;
}

.main-nav-area ul {
    padding: 0;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 25px;
}

.main-nav-area ul li {
    margin: 0;
}

.main-nav-area ul li a {
    color: var(--color-white);
    text-align: center;
    font-size: 16px;
    font-weight: 400;
    line-height: 120%;
    letter-spacing: -0.32px;
    font-family: var(--font-secondary);
    transition: all 0.3s;
}

.main-nav-area ul.fluxi-desktop-menu {
    transition: all 0.3s;
}

.main-nav-area ul.fluxi-desktop-menu:hover .menu-item {
    opacity: 0.5;
}

.main-nav-area ul.fluxi-desktop-menu .menu-item {
    transition: all 0.3s;
}

.main-nav-area ul.fluxi-desktop-menu .menu-item .fluxi-dropdown-main-element {
    color: #26262C;
    text-align: center;
    font-size: 16px;
    font-weight: 800;
    line-height: 120%;
    letter-spacing: -0.32px;
    font-family: var(--font-primary);
    transition: all 0.3s;
    padding: 35px 22px;
    display: block;
}

@media (max-width: 1200px) {
    .main-nav-area ul.fluxi-desktop-menu .menu-item .fluxi-dropdown-main-element {
        padding: 35px 17px;
    }
}

.main-nav-area ul.fluxi-desktop-menu .menu-item:hover {
    opacity: 1;
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown {
    z-index: 10;
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown .fluxi-submenu {
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    position: absolute;
    align-items: flex-start;
    opacity: 0;
    max-width: 1000px;
    border-radius: 10px;
    gap: 2px;
    visibility: hidden;
    overflow: visible;
    transform: translateY(30px);
    transition: all 0.3s ease-in-out;
    padding: 15px;
    background: #FFFFFF;
    -webkit-box-shadow: -9px 9px 22px -1px rgba(0, 0, 0, 0.12);
    box-shadow: -9px 9px 22px -1px rgba(0, 0, 0, 0.12);
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown .fluxi-submenu:hover li.nav-item .nav-link {
    opacity: 0.5;
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown .fluxi-submenu li.nav-item {
    width: 100%;
    transition: all 0.3s;
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown .fluxi-submenu li.nav-item:hover .nav-link {
    background: #F2F2F8;
    opacity: 1;
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown .fluxi-submenu li.nav-item .nav-link {
    padding: 12px 15px 12px 45px;
    border-radius: 10px;
    background: #FFFFFF;
    transition: all 0.3s;
    color: #26262C;
    text-align: right;
    font-size: 14px;
    font-weight: 600;
}

.main-nav-area ul.fluxi-desktop-menu .fluxi-has-dropdown:hover .fluxi-submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}

.rts-btn {
    max-width: -webkit-max-content;
    max-width: -moz-max-content;
    max-width: max-content;
    min-width: -webkit-max-content;
    min-width: -moz-max-content;
    min-width: max-content;
    padding: 10px 25px;
    border-radius: 4px;
    -webkit-transition: 0.3s;
    -o-transition: 0.3s;
    transition: 0.3s;
    display: block;
}

@media (max-width: 500px) {
    .rts-btn {
        padding: 10px 24px;
    }
}

.rts-btn.btn-primary {
    background: var(--color-primary-2);
    font-weight: 600;
    color: var(--color-title);
}

.rts-btn.btn-primary:hover {
    background: var(--color-title);
}

.progress-wrap {
    position: fixed;
    left: 30px;
    bottom: 30px;
    height: 46px;
    width: 46px;
    cursor: pointer;
    display: block;
    border-radius: 50px;
    z-index: 10000;
    opacity: 1;
    visibility: hidden;
    -webkit-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
    -webkit-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    transition: all 200ms linear;
}

.progress-wrap.active-progress {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

.progress-wrap::after {
    position: absolute;
    font-family: var(--font-three);
    content: "\f062";
    text-align: center;
    line-height: 46px;
    font-size: 18px;
    color: var(--color-primary);
    right: 0;
    top: 0;
    height: 46px;
    width: 46px;
    cursor: pointer;
    display: block;
    z-index: 1;
    -webkit-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    transition: all 200ms linear;
    border: 2px solid var(--color-primary);
    -webkit-box-shadow: none;
    box-shadow: none;
    border-radius: 50% !important;
    border-radius: 5px;
}

.progress-wrap:hover::after {
    opacity: 1;
    content: "\f062";
    border: 2px solid var(--color-primary);
}

.progress-wrap::before {
    position: absolute;
    font-family: var(--font-three);
    content: "\f062";
    text-align: center;
    line-height: 46px;
    font-size: 18px;
    opacity: 0;
    background: var(--color-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    right: 0;
    top: 0;
    height: 46px;
    width: 46px;
    cursor: pointer;
    display: block;
    z-index: 2;
    -webkit-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    transition: all 200ms linear;
}

.progress-wrap:hover::before {
    opacity: 0;
}

.progress-wrap svg path {
    fill: none;
}

.progress-wrap svg {
    color: var(--color-primary);
    border-radius: 50%;
    background: #fff;
}

.progress-wrap svg.progress-circle path {
    stroke: var(--color-primary);
    stroke-width: 34px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    transition: all 200ms linear;
}


.rts-banner-area {
    background: var(--color-primary);
    position: relative;
    z-index: 1;
    padding: 180px 0 0;
    height: auto;
}

@media (max-width: 991px) {
    .rts-banner-area {
        height: auto;
    }
}

@media (max-width: 576px) {
    .rts-banner-area {
        padding-right: 10px;
        padding-left: 10px;
    }
}

.rts-banner-area .banner-one-content .pre-title {
    color: var(--color-white);
    margin-bottom: 20px;
}

@media (max-width: 450px) {
    .rts-banner-area .banner-one-content .pre-title {
        font-size: 13px;
    }
}

.rts-banner-area .banner-one-content .title {
    color: var(--color-white);
    font-size: 70px;
    line-height: 1;
    font-weight: 700;
}

@media (max-width: 1200px) {
    .rts-banner-area .banner-one-content .title {
        font-size: 50px;
    }
}

.rts-banner-area .banner-one-content .title span {
    color: var(--color-primary-2);
    font-weight: 500;
}

@media (max-width: 991px) {
    .rts-banner-area .banner-one-content .title {
        line-height: 1.2;
    }
}

@media (max-width: 576px) {
    .rts-banner-area .banner-one-content .title {
        font-size: 28px;
        line-height: 1.23;
    }
}

@media (max-width: 450px) {
    .rts-banner-area .banner-one-content .title br {
        display: none;
    }
}

.rts-banner-area .banner-one-content .post-title {
    color: var(--color-white);
    margin-bottom: 30px;
    font-size: 24px;
}

@media (max-width: 576px) {
    .rts-banner-area .banner-one-content .post-title {
        font-size: 18px;
    }
}

.rts-banner-area .banner-one-content .post-title img {
    margin-left: 5px;
}

.rts-banner-area .banner-feature-list {
    padding: 0;
    margin: 60px 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 991px) {
    .rts-banner-area .banner-feature-list {
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .rts-banner-area .banner-feature-list {
        display: none;
    }
}

.rts-banner-area .banner-feature-list li {
    list-style: none;
    justify-content: center;
    display: flex;
    align-items: center;
    padding: 0 35px;
    border-left: 1px solid #BCBFDB;
    gap: 15px;
}

@media (max-width: 991px) {
    .rts-banner-area .banner-feature-list li {
        border: none;
    }
}

.rts-banner-area .banner-feature-list li:last-child {
    border: none;
}

.rts-banner-area .banner-feature-list li .desc {
    color: var(--color-white);
    font-weight: 600;
}

.rts-banner-area .banner-button-area {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 80px;
}

@media (max-width: 768px) {
    .rts-banner-area .banner-button-area {
        margin-top: 30px;
    }
}

.rts-banner-area .banner-button-area .rts-btn.btn-primary {
    background: var(--color-primary-2);
    color: var(--color-title);
}

.rts-banner-area .banner-button-area .rts-btn.btn-primary:hover {
    color: var(--color-white);
    background: var(--color-secondary);
}

.rts-banner-area .banner-button-area .btn-secondary {
    background: none;
    border: 1px solid var(--color-white);
    color: var(--color-white);
    font-weight: 700;
}

.rts-banner-area .banner-button-area .btn-secondary:hover {
    background: var(--color-primary-2);
    color: #4C5671;
    border: 1px solid var(--color-primary-2);
}

.rts-banner-area .banner-img-area {
    position: relative;
}

.rts-banner-area .banner-img-area .banner-img {
    text-align: center;
}

@media (max-width: 1400px) {
    .rts-banner-area .banner-img-area .banner-img img {
        width: 600px;
    }
}

.rts-banner-area .banner-img-area .banner-slider {
    position: absolute;
    max-width: 78%;
    height: 85%;
    top: 25px;
    right: 50%;
    transform: translateX(50%);
}

@media (max-width: 768px) {
    .rts-banner-area .banner-img-area .banner-slider {
        top: 15px;
    }
}

@media (max-width: 450px) {
    .rts-banner-area .banner-img-area .banner-slider {
        top: 8px;
    }
}

.rts-banner-area .banner-img-area .banner-slider img {
    width: 100%;
}

.rts-banner-area .banner-img-area .banner-slider .swiper {
    height: 100%;
    width: 100%;
    border-radius: 10px;
}

.rts-banner-area .counter-up-area {
    border-radius: 10px;
    border: 1px solid rgba(7, 116, 255, 0.1);
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.95) 100%), var(--color-primary);
}

.rts-banner-area .counter-up-area .counter-inner {
    padding: 60px 30px;
}

.rts-banner-area .counter-up-area .single-counter-up {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 25px;
}

@media (max-width: 991px) {
    .rts-banner-area .counter-up-area .single-counter-up {
        justify-content: flex-start;
        margin-bottom: 20px;
    }
}

.rts-banner-area .counter-up-area .single-counter-up .information .title {
    margin-bottom: 0;
    font-weight: 800;
}

@media (max-width: 768px) {
    .rts-banner-area .banner-shape-area {
        display: none;
    }
}

.rts-banner-area .banner-shape-area img {
    position: absolute;
    z-index: -1;
}

@media (max-width: 576px) {
    .rts-banner-area .banner-shape-area img {
        display: none;
    }
}

.rts-banner-area .banner-shape-area img.one {
    top: 32%;
    right: 25%;
}

@media (max-width: 1100px) {
    .rts-banner-area .banner-shape-area img.one {
        right: 10%;
        top: 20%;
    }
}

.rts-banner-area .banner-shape-area img.two {
    top: 42%;
    left: 25%;
}

@media (max-width: 1100px) {
    .rts-banner-area .banner-shape-area img.two {
        left: 10%;
        top: 35%;
    }
}

.rts-banner-area .banner-shape-area img.three {
    bottom: 10%;
    left: 12%;
}

@media (max-width: 1100px) {
    .rts-banner-area .banner-shape-area img.three {
        left: 10%;
    }
}

@media (max-width: 1100px) {
    .rts-banner-area .banner-floating-image-area {
        display: none;
    }
}

.rts-banner-area .banner-floating-image-area .shape {
    position: absolute;
    z-index: -1;
}

@media (max-width: 576px) {
    .rts-banner-area .banner-floating-image-area .shape {
        display: none;
    }
}

.rts-banner-area .banner-floating-image-area .shape.one {
    top: 12%;
    right: -3%;
}

@media (max-width: 1500px) {
    .rts-banner-area .banner-floating-image-area .shape.one {
        right: -6%;
    }
}

@media (max-width: 1400px) {
    .rts-banner-area .banner-floating-image-area .shape.one {
        width: 300px;
        top: 20%;
    }
}

@media (max-width: 1200px) {
    .rts-banner-area .banner-floating-image-area .shape.one {
        right: -8%;
    }
}

.rts-banner-area .banner-floating-image-area .shape.two {
    bottom: 28%;
    right: 5%;
}

@media (max-width: 1500px) {
    .rts-banner-area .banner-floating-image-area .shape.two {
        right: 2%;
    }
}

@media (max-width: 1400px) {
    .rts-banner-area .banner-floating-image-area .shape.two {
        width: 180px;
    }
}

.rts-banner-area .banner-floating-image-area .shape.three {
    top: 18%;
    left: -2%;
}

@media (max-width: 1500px) {
    .rts-banner-area .banner-floating-image-area .shape.three {
        left: -6%;
    }
}

@media (max-width: 1400px) {
    .rts-banner-area .banner-floating-image-area .shape.three {
        width: 300px;
        top: 24%;
    }
}

.rts-banner-area .banner-floating-image-area .shape.four {
    bottom: 25%;
    left: 5%;
}

@media (max-width: 1500px) {
    .rts-banner-area .banner-floating-image-area .shape.four {
        left: 2%;
    }
}

@media (max-width: 1400px) {
    .rts-banner-area .banner-floating-image-area .shape.four {
        width: 200px;
    }
}

.rts-banner-area .banner-fixed-shape img {
    position: absolute;
    z-index: -1;
}

.rts-banner-area .banner-fixed-shape img.shape-image-one {
    top: 15%;
    left: 28%;
}

@media (max-width: 991px) {
    .rts-banner-area .banner-fixed-shape img.shape-image-one {
        right: 50%;
        left: unset;
        transform: translateX(50%);
    }
}

.rts-banner-area .banner-fixed-shape img.shape-image-two {
    bottom: 0;
    right: 0;
}

.rts-demos-area {
    position: relative;
    z-index: 1;
    padding: 210px 0 120px;
    margin-top: 80px;
}

@media (max-width: 576px) {
    .rts-demos-area {
        padding-right: 10px;
        padding-left: 10px;
        margin-top: 0;
    }
}

.rts-demos-area .title-between-area {
    margin-bottom: 40px;
}

.rts-demos-area .section-title-area {
    margin-bottom: 40px;
}

.rts-demos-area .section-title-area .watermark {
    margin-bottom: 0;
    position: absolute;
    top: 0;
    right: 50%;
    transform: translateX(50%);
    color: var(--color-primary);
    font-family: var(--font-primary);
    font-weight: 700;
    font-size: 400px;
    line-height: 100%;
    leading-trim: both;
    text-edge: cap;
    text-align: center;
    background: linear-gradient(-180deg, #DDD8F9 0%, rgba(221, 216, 249, 0) 80%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    z-index: -1;
}

@media (max-width: 1200px) {
    .rts-demos-area .section-title-area .watermark {
        font-size: 300px;
    }
}

@media (max-width: 768px) {
    .rts-demos-area .section-title-area .watermark {
        font-size: 250px;
        top: 70px;
    }
}

@media (max-width: 576px) {
    .rts-demos-area .section-title-area .watermark {
        font-size: 200px;
        top: 85px;
    }
}

@media (max-width: 450px) {
    .rts-demos-area .section-title-area .watermark {
        font-size: 150px;
        top: 100px;
    }
}

.rts-demos-area .section-title-area .heading-title {
    background: none;
    font-size: 70px;
    font-style: normal;
    font-weight: 600;
    line-height: 70px;
    margin-bottom: 10px;
    color: var(--color-title);
}

@media (max-width: 991px) {
    .rts-demos-area .section-title-area .heading-title {
        font-size: 58px;
        line-height: 1.2;
    }
}

@media (max-width: 768px) {
    .rts-demos-area .section-title-area .heading-title {
        font-size: 42px;
    }
}

@media (max-width: 576px) {
    .rts-demos-area .section-title-area .heading-title {
        font-size: 36px;
    }
}

@media (max-width: 450px) {
    .rts-demos-area .section-title-area .heading-title {
        font-size: 26px;
    }
}

@media (max-width: 576px) {
    .rts-demos-area .section-title-area .desc br {
        display: none;
    }
}

.rts-demos-area .section-inner .demo-wrapper {
    margin-bottom: 40px;
}

.rts-demos-area .section-inner .demo-wrapper .image-area {
    background: var(--color-white);
    border-radius: 10px;
    padding: 30px 30px 0;
    border: 1px solid #DDD8F9;
    transition: all 0.3s;
    border-radius: 10px;
}

@media (max-width: 758px) {
    .rts-demos-area .section-inner .demo-wrapper .image-area {
        text-align: center;
    }
}

.rts-demos-area .section-inner .demo-wrapper .image-area:hover img {
    transform: translateY(-5px);
}

.rts-demos-area .section-inner .demo-wrapper .image-area img {
    transform: translateY(0);
    transition: all 0.3s;
    border-radius: 10px 10px 0 0;
}

.rts-demos-area .section-inner .demo-wrapper .content {
    text-align: center;
    font-size: 24px;
    margin-top: 20px;
    font-weight: 600;
}

.rts-demos-area .section-inner .demo-wrapper .content a {
    display: block;
    transition: all 0.4s;
}

.rts-demos-area .section-inner .demo-wrapper .content a:hover {
    color: var(--color-primary);
}

.rts-demos-area .button-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
}

@media (max-width: 991px) {
    .rts-demos-area .button-group {
        flex-wrap: wrap;
    }
}

.rts-demos-area .button-group button {
    border: 1px solid #DDD8F9;
    color: var(--color-primary);
    background: transparent;
    line-height: 1;
    padding: 14px 22px;
    border-radius: 4px;
    font-weight: 500;
    transition: all 0.4s;
}

.rts-demos-area .button-group button.is-checked {
    background: var(--color-primary);
    color: var(--color-white);
}

.rts-demos-area .flash {
    margin-top: 0;
}

.rts-dark-light-area {
    background: #121833;
}

@media (max-width: 576px) {
    .rts-dark-light-area {
        padding-right: 10px;
        padding-left: 10px;
    }
}

.rts-dark-light-area .section-title-area .sub-title {
    color: var(--color-primary);
    margin-bottom: 20px;
}

.rts-dark-light-area .section-title-area .heading-title {
    color: #FFFFFF;
}

.rts-dark-light-area .section-title-area .desc {
    color: #F8F9FB;
    margin-bottom: 40px;
}

@media (max-width: 500px) {
    .rts-dark-light-area .section-title-area .desc br {
        display: none;
    }
}

.rts-dark-light-area .section-title-area .dark-light-image {
    margin-bottom: 60px;
}

.rts-dark-light-area .section-inner .image-area {
    max-width: 1070px;
    margin: auto;
    width: 100%;
    text-align: center;
}

@media (max-width: 576px) {
    .rts-inner-page-area {
        padding-right: 10px;
        padding-left: 10px;
    }
}

.rts-inner-page-area .section-title-area .sub-title {
    color: var(--color-primary);
    margin-bottom: 10px;
    font-weight: 600;
}

.rts-inner-page-area .section-title-area .heading-title {
    font-weight: 800;
    margin-bottom: 10px;
}

.rts-inner-page-area .section-inner {
    overflow: hidden;
    background: linear-gradient(0deg, #033AA7 33.22%, #0774FF 99.45%);
    padding: 50px 0;
    border-radius: 10px;
    margin-top: 60px;
}

.rts-inner-page-area .section-inner .top-inner {
    display: inline-block;
    margin-bottom: 10px;
    width: 100%;
}

.rts-inner-page-area .section-inner .top-inner .marquee {
    padding: 0;
    margin: 0;
    will-change: transform;
    animation: marquee 65s linear infinite;
    align-items: center;
    display: flex;
    padding: 5px 0;
}

.rts-inner-page-area .section-inner .top-inner .marquee:hover {
    animation-play-state: paused;
}

.rts-inner-page-area .section-inner .top-inner .marquee li {
    list-style: none;
    flex: 0 0 20%;
    position: relative;
    text-align: center;
    margin: 0 10px;
}

.rts-inner-page-area .section-inner .bottom-inner {
    display: inline-block;
    width: 100%;
}

.rts-inner-page-area .section-inner .bottom-inner .marquee {
    padding: 0;
    margin: 0;
    will-change: transform;
    animation: marquee-2 85s linear infinite;
    align-items: center;
    display: flex;
    padding: 5px 0;
}

.rts-inner-page-area .section-inner .bottom-inner .marquee:hover {
    animation-play-state: paused;
}

.rts-inner-page-area .section-inner .bottom-inner .marquee li {
    list-style: none;
    flex: 0 0 20%;
    position: relative;
    text-align: center;
    margin: 0 10px;
}

@media (max-width: 576px) {
    .rts-features-area {
        padding-right: 10px;
        padding-left: 10px;
    }
}

.rts-features-area .feature-top-area .feature-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
}

@media (max-width: 991px) {
    .rts-features-area .feature-top-area .feature-wrapper {
        flex-wrap: wrap;
    }
}

.rts-features-area .feature-top-area .feature-wrapper .feature-list {
    display: flex;
    align-items: center;
    list-style: none;
    gap: 16px;
    background: var(--color-primary-2);
    padding: 20px 70px;
    border-radius: 6px;
    margin: 0;
}

@media (max-width: 1200px) {
    .rts-features-area .feature-top-area .feature-wrapper .feature-list {
        padding: 20px 40px;
    }
}

@media (max-width: 450px) {
    .rts-features-area .feature-top-area .feature-wrapper .feature-list {
        padding: 20px;
        width: 100%;
    }
}

.rts-features-area .feature-top-area .feature-wrapper .feature-list .text {
    color: var(--color-white);
    font-size: 16px;
    line-height: 130%;
    font-weight: 500;
}

.rts-features-area .feature-top-area .feature-wrapper .feature-list.one .text {
    color: var(--color-title);
}

.rts-features-area .feature-top-area .feature-wrapper .feature-list.two {
    background: var(--color-primary);
}

.rts-features-area .feature-top-area .feature-wrapper .feature-list.three {
    background: #09A24F;
}

.rts-features-area .feature-bottom-area {
    margin-top: 80px;
}

.rts-features-area .feature-bottom-area .feature-left-area {
    background: #F9F8FE;
    border: 1px solid #DDD8F9;
    border-radius: 10px;
    padding: 50px 70px 50px 40px;
    text-align: center;
    position: relative;
    z-index: 1;
}

@media (max-width: 450px) {
    .rts-features-area .feature-bottom-area .feature-left-area {
        padding: 50px 15px;
    }
}

.rts-features-area .feature-bottom-area .feature-left-area .feature-title {
    font-size: 24px;
    line-height: 28px;
}

@media (max-width: 450px) {
    .rts-features-area .feature-bottom-area .feature-left-area .feature-title br {
        display: none;
    }
}

.rts-features-area .feature-bottom-area .feature-left-area .feature-title span {
    font-weight: 400;
}

.rts-features-area .feature-bottom-area .feature-left-area .feature-shape-area .shape {
    position: absolute;
    top: 20%;
    right: 15%;
    z-index: -1;
}

@media (max-width: 1200px) {
    .rts-features-area .feature-bottom-area .feature-right-area {
        margin-top: 30px;
    }
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area {
    padding: 50px 80px;
    border-radius: 10px;
    border: 1px solid #DDD8F9;
    margin-bottom: 20px;
}

@media (max-width: 1400px) and (min-width: 1201px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area {
        padding: 50px 40px;
    }
}

@media (max-width: 991px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area {
        padding: 50px;
    }
}

@media (max-width: 768px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area {
        padding: 50px 20px;
    }
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-top {
    display: flex;
    align-items: center;
    gap: 55px;
    justify-content: center;
    padding: 0;
    margin: 0;
}

@media (max-width: 768px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-top {
        gap: 15px;
    }
}

@media (max-width: 576px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-top {
        gap: 43px;
        flex-wrap: wrap;
        justify-content: center;
    }
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-top li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 20px;
    margin: 0;
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-top li .text {
    font-size: 16px;
    line-height: 150%;
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-top li .text span {
    font-size: 32px;
    line-height: 100%;
    font-weight: 600;
    color: var(--color-title);
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-bottom-area {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    gap: 50px;
    margin-bottom: 0;
    margin-top: 40px;
}

@media (max-width: 576px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-bottom-area {
        gap: 25px;
    }
}

@media (max-width: 500px) {
    .rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-bottom-area {
        flex-wrap: wrap;
        justify-content: start;
    }
}

.rts-features-area .feature-bottom-area .feature-right-area .feature-counter-area .counter-bottom-area li {
    list-style: none;
    margin: 0;
}

.rts-features-area .section-title-area .sub-title {
    color: #DFDBF9;
    margin-bottom: 15px;
    font-weight: 600;
}

.rts-features-area .section-title-area .heading-title {
    color: #FFFFFF;
    font-weight: 800;
    margin-bottom: 15px;
}

.rts-features-area .section-title-area .desc {
    color: #FFFFFF;
}

@media (max-width: 500px) {
    .rts-features-area .section-title-area .desc br {
        display: none;
    }
}

.rts-features-area .section-inner {
    margin-top: 50px;
}

.rts-features-area .feature-section-bottom2 .feature-area .features-wrapper {
    border: 1px solid #DDD8F9;
    display: flex;
    gap: 30px;
    align-items: center;
    padding: 40px 40px 40px 30px;
    border-radius: 6px;
}

@media (max-width: 450px) {
    .rts-features-area .feature-section-bottom2 .feature-area .features-wrapper {
        flex-direction: column;
        align-items: start;
    }
}

.rts-features-area .feature-section-bottom2 .feature-area .features-wrapper .icon {
    min-width: 68px;
}

.rts-features-area .feature-section-bottom2 .feature-area .features-wrapper .icon img {
    width: 100%;
}

.rts-features-area .feature-section-bottom2 .feature-area .features-wrapper .content .title {
    font-size: 24px;
    line-height: 140%;
    margin-bottom: 5px;
}

@media (max-width: 450px) {
    .rts-features-area .feature-section-bottom2 .feature-area .features-wrapper .content .title {
        font-size: 20px;
    }
}

.rts-features-area .feature-section-bottom2 .feature-area .features-wrapper .content .desc {
    font-size: 14px;
}

.rts-dashboard-area {
    position: relative;
    background: #F9F8FE;
}

.rts-dashboard-area .section-title-area {
    position: relative;
    margin-bottom: 60px;
}

@media (max-width: 576px) {
    .rts-dashboard-area .section-title-area {
        margin-bottom: 30px;
    }
}

.rts-dashboard-area .section-title-area .watermark {
    margin-bottom: 0;
    color: var(--color-primary);
    font-family: var(--font-primary);
    font-weight: 700;
    font-size: 128px;
    line-height: 100%;
    leading-trim: both;
    text-edge: cap;
    text-align: center;
    background: linear-gradient(-180deg, #DDD8F9 0%, rgba(221, 216, 249, 0) 80%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    z-index: -1;
}

@media (max-width: 768px) {
    .rts-dashboard-area .section-title-area .watermark {
        font-size: 90px;
    }
}

@media (max-width: 576px) {
    .rts-dashboard-area .section-title-area .watermark {
        font-size: 64px;
    }
}

.rts-dashboard-area .dashboard-top-inner {
    background: var(--color-white);
    padding: 40px 60px;
    border: 1px solid #DDD8F9;
    border-radius: 16px;
}

@media (max-width: 768px) {
    .rts-dashboard-area .dashboard-top-inner {
        padding: 40px 30px;
    }
}

@media (max-width: 576px) {
    .rts-dashboard-area .dashboard-top-inner {
        padding: 40px 20px;
    }
}

@media (max-width: 1200px) {
    .rts-dashboard-area .dashboard-top-inner .left-side-content {
        margin-bottom: 30px;
    }
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .dashboard-title {
    font-size: 32px;
    line-height: 42px;
    font-weight: 600;
    margin-bottom: 10px;
    color: var(--color-title);
}

@media (max-width: 576px) {
    .rts-dashboard-area .dashboard-top-inner .left-side-content .dashboard-title br {
        display: none;
    }
}

@media (max-width: 450px) {
    .rts-dashboard-area .dashboard-top-inner .left-side-content .dashboard-title {
        font-size: 24px;
        line-height: 34px;
    }
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .dashboard-title span {
    color: var(--color-primary);
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .desc {
    color: #737477;
}

@media (max-width: 576px) {
    .rts-dashboard-area .dashboard-top-inner .left-side-content .desc br {
        display: none;
    }
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .wrapper {
    display: flex;
    align-items: center;
    padding: 0;
    margin: 0;
    gap: 50px;
}

@media (max-width: 576px) {
    .rts-dashboard-area .dashboard-top-inner .left-side-content .wrapper {
        flex-wrap: wrap;
    }
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .wrapper .wrapper-list {
    list-style: none;
    margin: 0;
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .wrapper .wrapper-list .icon {
    margin-bottom: 10px;
}

.rts-dashboard-area .dashboard-top-inner .left-side-content .wrapper .wrapper-list p {
    color: #737477;
}

@media (max-width: 991px) {
    .rts-course-area .section-inner .left-side-content {
        margin-bottom: 30px;
    }
}

.rts-course-area .section-inner .left-side-content .pre-title {
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    border-radius: 3px;
    padding: 7px 8px;
    font-size: 14px;
    max-width: max-content;
    line-height: 1;
    font-weight: 500;
    margin-bottom: 20px;
}

.rts-course-area .section-inner .left-side-content .course-title {
    margin-bottom: 40px;
    font-size: 36px;
    line-height: 40px;
    color: var(--color-title);
}

@media (max-width: 576px) {
    .rts-course-area .section-inner .left-side-content .course-title {
        font-size: 34px;
    }

    .rts-course-area .section-inner .left-side-content .course-title br {
        display: none;
    }
}

@media (max-width: 450px) {
    .rts-course-area .section-inner .left-side-content .course-title {
        font-size: 24px;
        line-height: 30px;
    }
}

.rts-course-area .section-inner .left-side-content .desc {
    color: #737477;
    margin-bottom: 50px;
}

.rts-course-area .section-inner .left-side-content .bottom-icon {
    text-align: center;
}

.rts-course-area .section-inner .right-side-tab-area .nav {
    border: none;
    justify-content: center;
    gap: 10px;
    margin-bottom: 20px;
}

.rts-course-area .section-inner .right-side-tab-area .nav li button {
    padding: 5px 8px;
    color: var(--color-title);
    display: flex;
    align-items: center;
    gap: 8px;
    border: 1px solid #DDD8F9;
    border-radius: 4px;
}

.rts-course-area .section-inner .right-side-tab-area .nav li button.active {
    background: var(--color-primary);
    color: var(--color-white);
}

.rts-course-area .section-inner .right-side-tab-area .nav li button.active svg {
    fill: #FFFFFF;
}

.rts-course-area .section-inner .right-side-tab-area .nav li button.active svg path {
    fill: #fff;
}

.rts-shop-area .left-side-image {
    margin-left: 80px;
}

@media (max-width: 1200px) {
    .rts-shop-area .left-side-image {
        margin-left: 0;
    }
}

.rts-shop-area .right-side-content .pre-title {
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    border-radius: 3px;
    padding: 7px 8px;
    font-size: 14px;
    max-width: max-content;
    line-height: 1;
    font-weight: 500;
    margin-bottom: 20px;
}

.rts-shop-area .right-side-content .course-title {
    margin-bottom: 40px;
    font-size: 36px;
    line-height: 40px;
    color: var(--color-title);
}

@media (max-width: 576px) {
    .rts-shop-area .right-side-content .course-title {
        font-size: 34px;
    }

    .rts-shop-area .right-side-content .course-title br {
        display: none;
    }
}

@media (max-width: 450px) {
    .rts-shop-area .right-side-content .course-title {
        font-size: 24px;
        line-height: 30px;
    }
}

.rts-shop-area .right-side-content .desc {
    color: #737477;
    margin-bottom: 50px;
}

.rts-shop-area .right-side-content .bottom-icon {
    text-align: center;
}

.rts-zoom-area .section-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #2454FF;
    padding: 30px 55px;
    border-radius: 16px;
    position: relative;
}

@media (max-width: 1400px) and (min-width: 1200px) {
    .rts-zoom-area .section-inner {
        padding: 30px;
    }
}

@media (max-width: 576px) {
    .rts-zoom-area .section-inner {
        padding: 30px 20px;
    }
}

@media (max-width: 1200px) {
    .rts-zoom-area .section-inner {
        flex-direction: column;
        align-items: start;
    }
}

.rts-zoom-area .section-inner .left-side-content .pre-title {
    color: var(--color-white);
    border: 1px solid var(--color-white);
    border-radius: 3px;
    padding: 7px 8px;
    font-size: 14px;
    max-width: max-content;
    line-height: 1;
    font-weight: 500;
    margin-bottom: 20px;
}

.rts-zoom-area .section-inner .left-side-content .course-title {
    margin-bottom: 30px;
    font-size: 36px;
    line-height: 40px;
    color: var(--color-white);
}

@media (max-width: 576px) {
    .rts-zoom-area .section-inner .left-side-content .course-title {
        font-size: 34px;
    }

    .rts-zoom-area .section-inner .left-side-content .course-title br {
        display: none;
    }
}

@media (max-width: 450px) {
    .rts-zoom-area .section-inner .left-side-content .course-title {
        font-size: 24px;
        line-height: 30px;
    }
}

.rts-zoom-area .section-inner .left-side-content .desc {
    color: var(--color-white);
    margin-bottom: 0;
}

@media (max-width: 768px) {
    .rts-zoom-area .section-inner .left-side-content .desc br {
        display: none;
    }
}

.rts-zoom-area .section-inner .mid-side-image {
    position: absolute;
    right: 55%;
    bottom: 0;
    transform: translateX(55%);
}

@media (max-width: 1200px) {
    .rts-zoom-area .section-inner .mid-side-image {
        top: 50%;
        bottom: unset;
        transform: translateY(-50%);
    }
}

@media (max-width: 768px) {
    .rts-zoom-area .section-inner .mid-side-image {
        display: none;
    }
}

@media (max-width: 1200px) {
    .rts-zoom-area .section-inner .right-side-image {
        order: -1;
        margin-bottom: 30px;
    }
}

.rts-responsive-area .section-title-area {
    position: relative;
    margin-bottom: 60px;
}

.rts-responsive-area .section-title-area .watermark {
    margin-bottom: 0;
    color: var(--color-primary);
    font-family: var(--font-primary);
    font-weight: 700;
    font-size: 200px;
    line-height: 100%;
    leading-trim: both;
    text-edge: cap;
    text-align: center;
    background: linear-gradient(-180deg, #DDD8F9 0%, rgba(221, 216, 249, 0) 80%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    z-index: -1;
}

@media (max-width: 1200px) {
    .rts-responsive-area .section-title-area .watermark {
        font-size: 130px;
    }
}

@media (max-width: 768px) {
    .rts-responsive-area .section-title-area .watermark {
        font-size: 90px;
    }
}

@media (max-width: 576px) {
    .rts-responsive-area .section-title-area .watermark {
        font-size: 64px;
    }
}

@media (max-width: 450px) {
    .rts-responsive-area .section-title-area .watermark {
        font-size: 50px;
    }
}

.rts-responsive-area .section-inner .desc {
    margin-right: 90px;
}

@media (max-width: 991px) {
    .rts-responsive-area .section-inner .desc {
        margin-right: 0;
    }
}

@media (max-width: 576px) {
    .rts-responsive-area .section-inner .desc br {
        display: none;
    }
}

.rts-responsive-area .section-inner .image-area {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.rts-responsive-area .section-inner .image-area .arrow {
    position: absolute;
    display: none;
    right: 90px;
    top: 50%;
    transform: translateY(-50%);
}

@media (max-width: 1200px) {
    .rts-responsive-area .section-inner .image-area .arrow {
        display: none;
    }
}

.rts-responsive-area .section-inner .image-area .star {
    position: absolute;
    right: 32%;
    top: 50px;
}

.rts-features.area-2 {
    background: #F9F8FE;
}

.rts-features.area-2 .title-sec {
    display: flex;
    justify-content: space-between;
}

@media (max-width: 1200px) {
    .rts-features.area-2 .title-sec {
        display: block;
    }
}

.rts-features.area-2 .title-sec .pre-title {
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    border-radius: 3px;
    padding: 7px 8px;
    font-size: 14px;
    max-width: max-content;
    line-height: 1;
    font-weight: 500;
    margin-bottom: 20px;
}

.rts-features.area-2 .title-sec h2 {
    margin-bottom: 40px;
    font-size: 48px;
    line-height: 48px;
    font-weight: 600;
    color: var(--color-title);
}

@media (max-width: 576px) {
    .rts-features.area-2 .title-sec h2 {
        font-size: 40px;
        line-height: 40px;
    }
}

@media (max-width: 450px) {
    .rts-features.area-2 .title-sec h2 {
        font-size: 26px;
        line-height: 36px;
    }
}

@media (max-width: 576px) {
    .rts-features.area-2 .title-sec p br {
        display: none;
    }
}

.rts-features.area-2 .title-sec .desc {
    color: #737477;
    margin-bottom: 0;
}

.rts-features.area-3 .title-sec {
    margin-bottom: 50px;
}

.rts-features.area-3 .title-sec .sub-title {
    font-weight: 600;
    color: var(--color-title);
    margin-bottom: 20px;
}

.rts-features.area-3 .title-sec h2 {
    font-size: 40px;
    font-weight: 800;
}

@media (max-width: 768px) {
    .rts-features.area-3 .title-sec h2 br {
        display: none;
    }
}

@media (max-width: 576px) {
    .rts-features.area-3 .title-sec h2 {
        font-size: 26px;
    }
}

.rts-features.area-3 .title-sec p {
    color: #737477;
}

@media (max-width: 576px) {
    .rts-features.area-3 .title-sec p br {
        display: none;
    }
}

.rts-features.area-2 .all-features {
    display: flex;
    flex-wrap: wrap;
    margin-top: 70px;
    justify-content: center;
    padding: 0;
}

.rts-features.area-2 .all-features li {
    flex: 0 0 20%;
    max-width: 20%;
    text-align: center;
    list-style: none;
}

@media (max-width: 1200px) {
    .rts-features.area-2 .all-features li {
        flex: 0 0 25%;
        max-width: 25%;
    }
}

@media (max-width: 991px) {
    .rts-features.area-2 .all-features li {
        flex: 0 0 33%;
        max-width: 33%;
    }
}

@media (max-width: 768px) {
    .rts-features.area-2 .all-features li {
        flex: 0 0 50%;
        max-width: 50%;
    }
}

@media (max-width: 576px) {
    .rts-features.area-2 .all-features li {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

.rts-features.area-2 .all-features li:nth-child(odd) div {
    background: linear-gradient(-180deg, #F1EEFF 0%, rgba(231, 226, 255, 0) 100%);
    border: none;
}

.rts-features.area-2 .all-features li div {
    display: block;
    margin: 0 15px 30px;
    padding: 50px 20px 40px 20px;
    cursor: pointer;
    background: linear-gradient(-180deg, rgba(231, 226, 255, 0) 0%, #F1EEFF 100%);
    border: 1px solid #DDD8F9;
    border-radius: 10px;
}

.rts-features.area-2 .all-features li div img {
    display: block;
    height: 70px;
    margin: 0 auto;
    transition: all 0.5s ease;
}

.rts-features.area-2 .all-features li div span {
    display: block;
    color: #1F1F25;
    font-size: 16px;
    font-weight: 600;
    font-family: "Albert Sans", sans-serif;
    line-height: 26px;
    margin-top: 20px;
}

.rts-features.area-2 .all-features li div:hover img {
    transform: scale(1.1) translateY(-10px);
}

.rts-footer-area {
    background: url(../images/footer/footer-bg.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding: 130px 0 80px;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

@media (max-width: 576px) {
    .rts-footer-area {
        padding-right: 10px;
        padding-left: 10px;
    }
}

.rts-footer-area .section-title-area .pre-title {
    color: var(--color-primary-2);
    font-size: 20px;
    line-height: 30px;
    font-weight: 500;
    font-family: var(--font-secondary);
    margin-bottom: 20px;
}

@media (max-width: 450px) {
    .rts-footer-area .section-title-area .pre-title {
        font-size: 16px;
        line-height: 26px;
    }
}

.rts-footer-area .section-title-area .heading-title {
    font-size: 48px;
    line-height: 120%;
    color: #FFFFFF;
    font-weight: 600;
    font-family: var(--font-primary);
}

@media (max-width: 991px) {
    .rts-footer-area .section-title-area .heading-title br {
        display: none;
    }
}

@media (max-width: 768px) {
    .rts-footer-area .section-title-area .heading-title {
        font-size: 40px;
    }
}

@media (max-width: 768px) {
    .rts-footer-area .section-title-area .heading-title {
        font-size: 32px;
    }
}

@media (max-width: 576px) {
    .rts-footer-area .section-title-area .heading-title {
        font-size: 24px;
    }
}

@media (max-width: 450px) {
    .rts-footer-area .section-title-area .heading-title br {
        display: none;
    }
}

.rts-footer-area .section-title-area .title-btn-area .rts-btn {
    background: var(--color-primary-2);
    color: var(--color-secondary);
}

.rts-footer-area .section-title-area .title-btn-area .rts-btn:hover {
    color: var(--color-white);
    background: var(--color-secondary);
}

.rts-footer-area .section-title-area .rts-btn {
    margin: 50px auto 0;
}

.rts-footer-area .banner-shape-area .shape {
    position: absolute;
    z-index: -1;
}

.rts-footer-area .banner-shape-area .shape.one {
    right: 17%;
    top: 35%;
}

.rts-footer-area .banner-shape-area .shape.two {
    left: 17%;
    bottom: 30%;
}

@keyframes marquee {
    0% {
        transform: translateX(0%);
    }

    100% {
        transform: translateX(100%);
    }
}

@keyframes marquee-2 {
    0% {
        transform: translateX(100%);
    }

    100% {
        transform: translateX(0%);
    }
}

img {
    max-width: 100%;
}

/* Mask group */
body {
    /* width */
    /* Track */
    /* Handle */
    /* Handle on hover */
}

body::-webkit-scrollbar {
    width: 0;
}

body::-webkit-scrollbar-track {
    background: #f1f1f1;
}

body::-webkit-scrollbar-thumb {
    background: #888;
}

body::-webkit-scrollbar-thumb:hover {
    background: #555;
}

.rts-customer-review-area {
    background: #F9F8FE;
}

.rts-customer-review-area .title-sec {
    text-align: center;
    margin-bottom: 60px;
}

.rts-customer-review-area .title-sec .pre-title {
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    border-radius: 3px;
    padding: 7px 8px;
    font-size: 14px;
    max-width: max-content;
    line-height: 1;
    font-weight: 500;
    margin-bottom: 20px;
    margin: 0 auto 20px;
}

.rts-customer-review-area .title-sec .course-title {
    margin-bottom: 10px;
    font-size: 40px;
    line-height: 50px;
    font-weight: 600;
    color: var(--color-title);
}

@media (max-width: 450px) {
    .rts-customer-review-area .title-sec .course-title {
        font-size: 26px;
        line-height: 35px;
    }
}

.rts-customer-review-area .title-sec .desc {
    color: #737477;
}

@media (max-width: 450px) {
    .rts-customer-review-area .title-sec .desc br {
        display: none;
    }
}

.rts-customer-review-area .section-inner .single-testimonials-area {
    background: var(--color-white);
    border-radius: 10px;
    border: 1px solid #DDD8F9;
    padding: 50px 40px;
    min-height: 100%;
}

@media (max-width: 576px) {
    .rts-customer-review-area .section-inner .single-testimonials-area {
        padding: 20px;
    }
}

.rts-customer-review-area .section-inner .single-testimonials-area .star-rating-area {
    padding: 0;
    margin: 0 0 30px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.rts-customer-review-area .section-inner .single-testimonials-area .star-rating-area li {
    list-style: none;
    color: #FF6D1C;
    font-size: 20px;
    margin: 0;
}

.rts-customer-review-area .section-inner .single-testimonials-area .desc {
    font-size: 18px;
    color: var(--color-title);
    line-height: 26px;
    font-weight: 500;
    margin-bottom: 50px;
}

.rts-customer-review-area .section-inner .single-testimonials-area .author-area {
    display: flex;
    align-items: center;
    gap: 20px;
}

.rts-customer-review-area .section-inner .single-testimonials-area .author-area .text h4 {
    font-size: 20px;
    margin-bottom: 0;
    font-weight: 600;
}

.rts-customer-review-area .section-inner .single-testimonials-area .author-area .text p {
    font-size: 15px;
    line-height: 26px;
    margin-bottom: 0;
    color: #737477;
}

.rts-customer-review-area .section-inner .rts-btn:hover {
    color: var(--color-white);
}

.overlay-bottom-section {
    position: relative;
    z-index: 2;
}

.overlay-bottom-section::after {
    position: absolute;
    bottom: -130px;
    right: -25%;
    width: 150%;
    background: linear-gradient(-180deg, rgba(255, 255, 255, 0) 6.66%, rgba(255, 255, 255, 0.91) 48.38%, #F9F8FE 85.73%);
    content: "";
    height: 600px;
    z-index: 1;
    pointer-events: none;
    transition: all 0.5s ease;
}

.overlay-bottom-section .rts-btn {
    margin-top: -100px !important;
    transition: all 0.5s ease;
}

.overlay-bottom-section .rts-btn:hover {
    color: var(--color-white);
}

.button-area-box-shadow .btn-bottom-center {
    text-align: center;
    margin: auto;
    z-index: 5;
    position: relative;
    transition: all 0.5s ease;
}

@media (max-width: 991px) {
    .main-nav-one {
        display: none;
    }
}

.main-nav-one ul {
    display: flex;
    align-items: center;
    padding: 0;
    margin: 0;
}

.main-nav-one ul li {
    position: relative;
    list-style: none;
}

.main-nav-one ul li>a {
    padding: 19px 15px;
}

.main-nav-one ul li a.nav-link {
    color: #ffffff;
    font-size: 16px;
    font-weight: 400;
}

.main-nav-one ul li.has-dropdown {
    margin-left: 26px;
    position: relative;
    margin-bottom: 0;
    margin-top: 0;
}

.main-nav-one ul li.has-dropdown a {
    position: relative;
}

.main-nav-one ul li.has-dropdown a.nav-link {
    padding: 27px 15px;
    color: var(--color-white);
    font-size: 16px;
    font-weight: 400;
}

.main-nav-one ul li.has-dropdown a::before {
    content: "\f078" !important;
    position: absolute !important;
    top: 50%;
    font-family: "Font Awesome 5 Pro" !important;
    left: -3px;
    transform: translateY(-50%);
    transition: 0.3s;
    font-size: 12px;
}

.main-nav-one ul li.has-dropdown .submenu {
    min-width: 230px;
    height: auto;
    position: absolute;
    top: 100%;
    right: unset;
    z-index: 90;
    opacity: 0;
    visibility: hidden;
    text-align: right;
    transition: 0.3s;
    border-radius: 0 0 10px 10px;
    background-color: #fff;
    border-right: 1px solid rgba(255, 255, 255, 0.0784313725);
    border-bottom: 1px solid rgba(255, 255, 255, 0.0784313725);
    border-left: 1px solid rgba(255, 255, 255, 0.0784313725);
    display: inline-block;
    box-shadow: 0 36px 35px rgba(0, 0, 0, 0.08);
    padding: 14px 0;
    transform-origin: 100% 0;
    transform: scaleY(0);
}

.main-nav-one ul li.has-dropdown .submenu li {
    margin-left: 0;
    padding: 0;
}

.main-nav-one ul li.has-dropdown .submenu li:last-child a {
    border: none;
}

.main-nav-one ul li.has-dropdown .submenu li:hover a {
    background: #EEEBFF;
    color: var(--color-primary);
}

.main-nav-one ul li.has-dropdown .submenu li a {
    padding: 6px 12px;
    margin: 2px 10px;
    font-weight: 400;
    font-size: 16px;
    transition: all 0.3s;
    border-radius: 4px;
}

.main-nav-one ul li.has-dropdown .submenu li a::before {
    display: none;
}

.main-nav-one ul li.has-dropdown .submenu li .third-lvl li a {
    background: #FFFFFF;
    color: var(--color-secondary);
}

.main-nav-one ul li.has-dropdown .submenu li .third-lvl li:hover a {
    background: #EEEBFF;
}

.main-nav-one ul li.has-dropdown .megamenu-hub {
    min-width: 100%;
    height: auto;
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 90;
    opacity: 0;
    visibility: hidden;
    text-align: right;
    transition: 0.3s;
    border-radius: 0 0 10px 10px;
    background-color: #fff;
    border-right: 1px solid rgba(255, 255, 255, 0.0784313725);
    border-bottom: 1px solid rgba(255, 255, 255, 0.0784313725);
    border-left: 1px solid rgba(255, 255, 255, 0.0784313725);
    display: inline-block;
    box-shadow: 0 36px 35px rgba(0, 0, 0, 0.08);
    padding: 40px 80px;
    transform-origin: 100% 0;
    transform: scaleY(0);
}

@media (max-width: 1199px) {
    .main-nav-one ul li.has-dropdown .megamenu-hub {
        padding: 20px;
    }
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega {
    max-width: 80% !important;
    margin: auto;
    min-width: 70%;
    right: 19%;
    padding: 30px;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li ul {
    flex-basis: 27%;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li ul::after {
    display: none;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li ul li.parent {
    width: 100%;
    border-bottom: 1px solid #DDD8F9;
    margin-bottom: 15px;
    padding-bottom: 15px;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li ul li.parent a {
    font-size: 18px;
    color: #553CDF;
    font-weight: 600;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area {
    right: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    border-right: 1px solid #DDD8F9;
    padding-right: 20px;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav {
    display: block;
    padding: 10px 20px;
    background: #ECE9FF;
    margin-bottom: 10px;
    border-radius: 4px;
    width: 100%;
    transition: 0.3s;
    border: 1px solid transparent;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav.mash {
    background: #D6CEFF;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav .icon {
    margin-bottom: 10px;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav span {
    font-size: 14px;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav::before {
    display: none;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav:last-child {
    margin-bottom: 0;
}

.main-nav-one ul li.has-dropdown .megamenu-hub.min-mega li .thumbnav-area .single-thumbnav:hover {
    border: 1px solid #553CDF;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li {
    display: flex;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul {
    flex-direction: column;
    flex-basis: 25%;
    text-align: right;
    align-items: flex-start;
    position: relative;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul li {
    display: block;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul li:hover a {
    color: var(--color-primary);
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul li a {
    padding: 6px 10px;
    font-weight: 400;
    font-size: 16px;
    font-weight: 400;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul li a::before {
    display: none;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul li span {
    position: absolute;
    right: 100%;
    top: 10px;
    font-size: 13px;
    border-radius: 2px;
    padding: 3px 8px;
    background: var(--color-primary);
    color: #fff;
    line-height: 1;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul li span.popular {
    background: red;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li ul:first-child::after {
    position: absolute;
    content: "";
    left: 70px;
    height: 85%;
    width: 1px;
    top: 3%;
    background: #DDD8F9;
}

@media (max-width: 1399px) {
    .main-nav-one ul li.has-dropdown .megamenu-hub li ul:first-child::after {
        left: 23px;
        height: 90%;
    }
}

@media (max-width: 1199px) {
    .main-nav-one ul li.has-dropdown .megamenu-hub li ul:first-child::after {
        display: none;
    }
}

.main-nav-one ul li.has-dropdown .megamenu-hub li .nav-mega-image {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    flex-basis: 50%;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li .nav-mega-image::before {
    display: none;
}

.main-nav-one ul li.has-dropdown .megamenu-hub li .nav-mega-image a {
    padding: 0;
}

@media (max-width: 1199px) {
    .main-nav-one ul li.has-dropdown .megamenu-hub li .nav-mega-image a {
        max-width: 95%;
    }
}

.main-nav-one ul li.has-dropdown .megamenu-hub li .nav-mega-image a::before {
    display: none;
}

.main-nav-one ul li.has-dropdown .megamenu-hub .absolute-image-shape img {
    position: absolute;
}

.main-nav-one ul li.has-dropdown .megamenu-hub .absolute-image-shape .one {
    position: absolute;
    right: 50%;
    top: 70%;
}

.main-nav-one ul li.has-dropdown .megamenu-hub .absolute-image-shape .two {
    position: absolute;
    left: -3%;
    top: -16%;
}

.main-nav-one ul li.has-dropdown:hover a.nav-link::before {
    content: "\f077" !important;
}

.main-nav-one ul li.has-dropdown:hover .submenu {
    opacity: 1;
    visibility: visible;
    top: 100%;
    transform: translateY(0);
    transform: scaleY(1);
}

.main-nav-one ul li.has-dropdown:hover .megamenu-hub {
    opacity: 1;
    visibility: visible;
    top: 100%;
    transform: translateY(0);
    transform: scaleY(1);
}

.main-nav-one ul li:hover a.nav-link {
    font-size: 16px;
    font-weight: 400;
}

.sub-dropdown {
    position: relative !important;
    display: block !important;
}

.sub-dropdown .submenu.third-lvl {
    opacity: 0 !important;
    min-width: 185px !important;
    right: 100% !important;
    top: -13% !important;
    margin: 0;
    border-radius: 0 !important;
}

.sub-dropdown .submenu.third-lvl.base {
    display: block !important;
}

.sub-dropdown:hover .sub-menu-link {
    color: var(--color-primary);
}

.sub-dropdown:hover .submenu.third-lvl.base {
    opacity: 1 !important;
    min-width: 185px !important;
    top: 0 !important;
    left: 3px;
    display: block !important;
}

.sub-dropdown:hover .submenu.third-lvl.base li {
    display: block;
}

.sub-dropdown:hover .submenu.third-lvl.base li a {
    display: block !important;
}

.rts-faq .title-sec {
    text-align: center;
    font-size: 48px;
    line-height: 58px;
    color: var(--color-title);
    margin-bottom: 60px;
}

.rts-faq .title-sec h2 {
    margin: 0;
    font-weight: 600;
}

.accordion {
    max-width: 930px;
    margin: auto;
}

.accordion-item {
    position: relative;
    border-width: 0 0 1px;
    border-style: solid;
    border-color: #EDEDED;
    border-radius: 0;
    padding: 30px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .accordion-item {
        padding: 30px 20px;
    }
}

.accordion-item.active {
    border-radius: 10px;
    background: linear-gradient(-180deg, rgba(255, 255, 255, 0) 0%, #F4F9FF 100%);
    filter: drop-shadow(0px 4px 30px rgba(224, 231, 253, 0.2));
    border-color: #DDD8F9;
}

.accordion-item .accordion-header {
    transition: 0.2s ease;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    text-transform: capitalize;
    position: relative;
}

.accordion-item .accordion-header::after {
    content: "+";
    position: absolute;
    font-family: "Font Awesome 6";
    left: 20px;
    top: 0;
    font-weight: bold;
    color: #181823;
    font-size: 20px;
}

@media (max-width: 768px) {
    .accordion-item .accordion-header::after {
        left: 0;
    }
}

@media (max-width: 450px) {
    .accordion-item .accordion-header::after {
        left: 0;
    }
}

.accordion-item .accordion-header h2 {
    margin-bottom: 0;
    color: var(--color-title);
    font-size: 20px;
    font-weight: 600;
    line-height: 30px;
}

@media (max-width: 576px) {
    .accordion-item .accordion-header h2 {
        font-size: 16px;
        line-height: 26px;
    }
}

.accordion-item.active .accordion-header h2 {
    color: #181823;
}

.accordion-item.active .accordion-header::after {
    content: "_";
    color: #181823;
    top: 40%;
}

.accordion-item .accordion-content {
    display: none;
    margin-bottom: 0;
    margin-top: 20px;
}

.accordion-item .accordion-content p {
    color: #5E5E5E;
    font-size: 16px;
    font-weight: 500;
    line-height: 26px;
    margin-bottom: 0;
}

@media (max-width: 991px) {
    .accordion-item .accordion-content p br {
        display: none;
    }
}