/****************************************************** */
/****************  Padding Margin Spacing ************* */
/****************************************************** */
.p-5 {
    padding: 5px !important
}

.p-10 {
    padding: 10px
}

.p-15 {
    padding: 15px
}

.p-20 {
    padding: 20px
}

.p-25 {
    padding: 25px
}

.p-30 {
    padding: 30px
}

.p-35 {
    padding: 35px
}

.p-40 {
    padding: 40px
}

.p-45 {
    padding: 45px
}

.p-50 {
    padding: 50px
}

.p-55 {
    padding: 55px
}

.p-60 {
    padding: 60px
}

.p-65 {
    padding: 65px
}

.p-70 {
    padding: 70px
}

.p-75 {
    padding: 75px
}

.p-80 {
    padding: 80px
}

.p-85 {
    padding: 85px
}

.p-90 {
    padding: 90px
}

.p-95 {
    padding: 95px
}

.p-100 {
    padding: 100px
}

.p-105 {
    padding: 105px
}

.p-110 {
    padding: 110px
}

.p-115 {
    padding: 115px
}

.p-120 {
    padding: 120px
}

.p-125 {
    padding: 125px
}

.p-130 {
    padding: 130px
}

.p-135 {
    padding: 135px
}

.p-140 {
    padding: 140px
}

.p-145 {
    padding: 145px
}

.p-150 {
    padding: 150px
}

.p-155 {
    padding: 155px
}

.p-160 {
    padding: 160px
}

.p-165 {
    padding: 165px
}

.p-170 {
    padding: 170px
}

.p-175 {
    padding: 175px
}

.p-180 {
    padding: 180px
}

.p-185 {
    padding: 185px
}

.p-190 {
    padding: 190px
}

.p-195 {
    padding: 195px
}

.p-200 {
    padding: 200px
}

.p-205 {
    padding: 205px
}

.p-210 {
    padding: 210px
}

.p-215 {
    padding: 215px
}

.p-220 {
    padding: 220px
}

.p-225 {
    padding: 225px
}

.p-230 {
    padding: 230px
}

.p-235 {
    padding: 235px
}

.p-240 {
    padding: 240px
}

.p-245 {
    padding: 245px
}

.p-250 {
    padding: 250px
}

.pt-5,
.py-5 {
    padding-top: 5px !important
}

.pt-10,
.py-10 {
    padding-top: 10px
}

.pt-15,
.py-15 {
    padding-top: 15px
}

.pt-20,
.py-20 {
    padding-top: 20px
}

.pt-25,
.py-25 {
    padding-top: 25px
}

.pt-30,
.py-30 {
    padding-top: 30px
}

.pt-35,
.py-35 {
    padding-top: 35px
}

.pt-40,
.py-40 {
    padding-top: 40px
}

.pt-45,
.py-45 {
    padding-top: 45px
}

.pt-50,
.py-50 {
    padding-top: 50px
}

.pt-55,
.py-55 {
    padding-top: 55px
}

.pt-60,
.py-60 {
    padding-top: 60px
}

.pt-65,
.py-65 {
    padding-top: 65px
}

.pt-70,
.py-70 {
    padding-top: 70px
}

.pt-75,
.py-75 {
    padding-top: 75px
}

.pt-80,
.py-80 {
    padding-top: 80px
}

.pt-85,
.py-85 {
    padding-top: 85px
}

.pt-90,
.py-90 {
    padding-top: 90px
}

.pt-95,
.py-95 {
    padding-top: 95px
}

.pt-100,
.py-100 {
    padding-top: 100px
}

.pt-105,
.py-105 {
    padding-top: 105px
}

.pt-110,
.py-110 {
    padding-top: 110px
}

.pt-115,
.py-115 {
    padding-top: 115px
}

.pt-120,
.py-120 {
    padding-top: 120px
}

.pt-125,
.py-125 {
    padding-top: 125px
}

.pt-130,
.py-130 {
    padding-top: 130px
}

.pt-135,
.py-135 {
    padding-top: 135px
}

.pt-140,
.py-140 {
    padding-top: 140px
}

.pt-145,
.py-145 {
    padding-top: 145px
}

.pt-150,
.py-150 {
    padding-top: 150px
}

.pt-155,
.py-155 {
    padding-top: 155px
}

.pt-160,
.py-160 {
    padding-top: 160px
}

.pt-165,
.py-165 {
    padding-top: 165px
}

.pt-170,
.py-170 {
    padding-top: 170px
}

.pt-175,
.py-175 {
    padding-top: 175px
}

.pt-180,
.py-180 {
    padding-top: 180px
}

.pt-185,
.py-185 {
    padding-top: 185px
}

.pt-190,
.py-190 {
    padding-top: 190px
}

.pt-195,
.py-195 {
    padding-top: 195px
}

.pt-200,
.py-200 {
    padding-top: 200px
}

.pt-205,
.py-205 {
    padding-top: 205px
}

.pt-210,
.py-210 {
    padding-top: 210px
}

.pt-215,
.py-215 {
    padding-top: 215px
}

.pt-220,
.py-220 {
    padding-top: 220px
}

.pt-225,
.py-225 {
    padding-top: 225px
}

.pt-230,
.py-230 {
    padding-top: 230px
}

.pt-235,
.py-235 {
    padding-top: 235px
}

.pt-240,
.py-240 {
    padding-top: 240px
}

.pt-245,
.py-245 {
    padding-top: 245px
}

.pt-250,
.py-250 {
    padding-top: 250px
}

.pb-5,
.py-5 {
    padding-bottom: 5px !important
}

.pb-10,
.py-10 {
    padding-bottom: 10px
}

.pb-15,
.py-15 {
    padding-bottom: 15px
}

.pb-20,
.py-20 {
    padding-bottom: 20px
}

.pb-25,
.py-25 {
    padding-bottom: 25px
}

.pb-30,
.py-30 {
    padding-bottom: 30px
}

.pb-35,
.py-35 {
    padding-bottom: 35px
}

.pb-40,
.py-40 {
    padding-bottom: 40px
}

.pb-45,
.py-45 {
    padding-bottom: 45px
}

.pb-50,
.py-50 {
    padding-bottom: 50px
}

.pb-55,
.py-55 {
    padding-bottom: 55px
}

.pb-60,
.py-60 {
    padding-bottom: 60px
}

.pb-65,
.py-65 {
    padding-bottom: 65px
}

.pb-70,
.py-70 {
    padding-bottom: 70px
}

.pb-75,
.py-75 {
    padding-bottom: 75px
}

.pb-80,
.py-80 {
    padding-bottom: 80px
}

.pb-85,
.py-85 {
    padding-bottom: 85px
}

.pb-90,
.py-90 {
    padding-bottom: 90px
}

.pb-95,
.py-95 {
    padding-bottom: 95px
}

.pb-100,
.py-100 {
    padding-bottom: 100px
}

.pb-105,
.py-105 {
    padding-bottom: 105px
}

.pb-110,
.py-110 {
    padding-bottom: 110px
}

.pb-115,
.py-115 {
    padding-bottom: 115px
}

.pb-120,
.py-120 {
    padding-bottom: 120px
}

.pb-125,
.py-125 {
    padding-bottom: 125px
}

.pb-130,
.py-130 {
    padding-bottom: 130px
}

.pb-135,
.py-135 {
    padding-bottom: 135px
}

.pb-140,
.py-140 {
    padding-bottom: 140px
}

.pb-145,
.py-145 {
    padding-bottom: 145px
}

.pb-150,
.py-150 {
    padding-bottom: 150px
}

.pb-155,
.py-155 {
    padding-bottom: 155px
}

.pb-160,
.py-160 {
    padding-bottom: 160px
}

.pb-165,
.py-165 {
    padding-bottom: 165px
}

.pb-170,
.py-170 {
    padding-bottom: 170px
}

.pb-175,
.py-175 {
    padding-bottom: 175px
}

.pb-180,
.py-180 {
    padding-bottom: 180px
}

.pb-185,
.py-185 {
    padding-bottom: 185px
}

.pb-190,
.py-190 {
    padding-bottom: 190px
}

.pb-195,
.py-195 {
    padding-bottom: 195px
}

.pb-200,
.py-200 {
    padding-bottom: 200px
}

.pb-205,
.py-205 {
    padding-bottom: 205px
}

.pb-210,
.py-210 {
    padding-bottom: 210px
}

.pb-215,
.py-215 {
    padding-bottom: 215px
}

.pb-220,
.py-220 {
    padding-bottom: 220px
}

.pb-225,
.py-225 {
    padding-bottom: 225px
}

.pb-230,
.py-230 {
    padding-bottom: 230px
}

.pb-235,
.py-235 {
    padding-bottom: 235px
}

.pb-240,
.py-240 {
    padding-bottom: 240px
}

.pb-245,
.py-245 {
    padding-bottom: 245px
}

.pb-250,
.py-250 {
    padding-bottom: 250px
}

.m-5 {
    margin: 5px !important
}

.m-10 {
    margin: 10px
}

.m-15 {
    margin: 15px
}

.m-20 {
    margin: 20px
}

.m-25 {
    margin: 25px
}

.m-30 {
    margin: 30px
}

.m-35 {
    margin: 35px
}

.m-40 {
    margin: 40px
}

.m-45 {
    margin: 45px
}

.m-50 {
    margin: 50px
}

.m-55 {
    margin: 55px
}

.m-60 {
    margin: 60px
}

.m-65 {
    margin: 65px
}

.m-70 {
    margin: 70px
}

.m-75 {
    margin: 75px
}

.m-80 {
    margin: 80px
}

.m-85 {
    margin: 85px
}

.m-90 {
    margin: 90px
}

.m-95 {
    margin: 95px
}

.m-100 {
    margin: 100px
}

.m-105 {
    margin: 105px
}

.m-110 {
    margin: 110px
}

.m-115 {
    margin: 115px
}

.m-120 {
    margin: 120px
}

.m-125 {
    margin: 125px
}

.m-130 {
    margin: 130px
}

.m-135 {
    margin: 135px
}

.m-140 {
    margin: 140px
}

.m-145 {
    margin: 145px
}

.m-150 {
    margin: 150px
}

.m-155 {
    margin: 155px
}

.m-160 {
    margin: 160px
}

.m-165 {
    margin: 165px
}

.m-170 {
    margin: 170px
}

.m-175 {
    margin: 175px
}

.m-180 {
    margin: 180px
}

.m-185 {
    margin: 185px
}

.m-190 {
    margin: 190px
}

.m-195 {
    margin: 195px
}

.m-200 {
    margin: 200px
}

.m-205 {
    margin: 205px
}

.m-210 {
    margin: 210px
}

.m-215 {
    margin: 215px
}

.m-220 {
    margin: 220px
}

.m-225 {
    margin: 225px
}

.m-230 {
    margin: 230px
}

.m-235 {
    margin: 235px
}

.m-240 {
    margin: 240px
}

.m-245 {
    margin: 245px
}

.m-250 {
    margin: 250px
}

.mt-5,
.my-5 {
    margin-top: 5px !important
}

.mt-10,
.my-10 {
    margin-top: 10px
}

.mt-15,
.my-15 {
    margin-top: 15px
}

.mt-20,
.my-20 {
    margin-top: 20px
}

.mt-25,
.my-25 {
    margin-top: 25px
}

.mt-30,
.my-30 {
    margin-top: 30px
}

.mt-35,
.my-35 {
    margin-top: 35px
}

.mt-40,
.my-40 {
    margin-top: 40px
}

.mt-45,
.my-45 {
    margin-top: 45px
}

.mt-50,
.my-50 {
    margin-top: 50px
}

.mt-55,
.my-55 {
    margin-top: 55px
}

.mt-60,
.my-60 {
    margin-top: 60px
}

.mt-65,
.my-65 {
    margin-top: 65px
}

.mt-70,
.my-70 {
    margin-top: 70px
}

.mt-75,
.my-75 {
    margin-top: 75px
}

.mt-80,
.my-80 {
    margin-top: 80px
}

.mt-85,
.my-85 {
    margin-top: 85px
}

.mt-90,
.my-90 {
    margin-top: 90px
}

.mt-95,
.my-95 {
    margin-top: 95px
}

.mt-100,
.my-100 {
    margin-top: 100px
}

.mt-105,
.my-105 {
    margin-top: 105px
}

.mt-110,
.my-110 {
    margin-top: 110px
}

.mt-115,
.my-115 {
    margin-top: 115px
}

.mt-120,
.my-120 {
    margin-top: 120px
}

.mt-125,
.my-125 {
    margin-top: 125px
}

.mt-130,
.my-130 {
    margin-top: 130px
}

.mt-135,
.my-135 {
    margin-top: 135px
}

.mt-140,
.my-140 {
    margin-top: 140px
}

.mt-145,
.my-145 {
    margin-top: 145px
}

.mt-150,
.my-150 {
    margin-top: 150px
}

.mt-155,
.my-155 {
    margin-top: 155px
}

.mt-160,
.my-160 {
    margin-top: 160px
}

.mt-165,
.my-165 {
    margin-top: 165px
}

.mt-170,
.my-170 {
    margin-top: 170px
}

.mt-175,
.my-175 {
    margin-top: 175px
}

.mt-180,
.my-180 {
    margin-top: 180px
}

.mt-185,
.my-185 {
    margin-top: 185px
}

.mt-190,
.my-190 {
    margin-top: 190px
}

.mt-195,
.my-195 {
    margin-top: 195px
}

.mt-200,
.my-200 {
    margin-top: 200px
}

.mt-205,
.my-205 {
    margin-top: 205px
}

.mt-210,
.my-210 {
    margin-top: 210px
}

.mt-215,
.my-215 {
    margin-top: 215px
}

.mt-220,
.my-220 {
    margin-top: 220px
}

.mt-225,
.my-225 {
    margin-top: 225px
}

.mt-230,
.my-230 {
    margin-top: 230px
}

.mt-235,
.my-235 {
    margin-top: 235px
}

.mt-240,
.my-240 {
    margin-top: 240px
}

.mt-245,
.my-245 {
    margin-top: 245px
}

.mt-250,
.my-250 {
    margin-top: 250px
}

.mb-5,
.my-5 {
    margin-bottom: 5px !important
}

.mb-10,
.my-10 {
    margin-bottom: 10px
}

.mb-15,
.my-15 {
    margin-bottom: 15px
}

.mb-20,
.my-20 {
    margin-bottom: 20px
}

.mb-25,
.my-25 {
    margin-bottom: 25px
}

.mb-30,
.my-30 {
    margin-bottom: 30px
}

.mb-35,
.my-35 {
    margin-bottom: 35px
}

.mb-40,
.my-40 {
    margin-bottom: 40px
}

.mb-45,
.my-45 {
    margin-bottom: 45px
}

.mb-50,
.my-50 {
    margin-bottom: 50px
}

.mb-55,
.my-55 {
    margin-bottom: 55px
}

.mb-60,
.my-60 {
    margin-bottom: 60px
}

.mb-65,
.my-65 {
    margin-bottom: 65px
}

.mb-70,
.my-70 {
    margin-bottom: 70px
}

.mb-75,
.my-75 {
    margin-bottom: 75px
}

.mb-80,
.my-80 {
    margin-bottom: 80px
}

.mb-85,
.my-85 {
    margin-bottom: 85px
}

.mb-90,
.my-90 {
    margin-bottom: 90px
}

.mb-95,
.my-95 {
    margin-bottom: 95px
}

.mb-100,
.my-100 {
    margin-bottom: 100px
}

.mb-105,
.my-105 {
    margin-bottom: 105px
}

.mb-110,
.my-110 {
    margin-bottom: 110px
}

.mb-115,
.my-115 {
    margin-bottom: 115px
}

.mb-120,
.my-120 {
    margin-bottom: 120px
}

.mb-125,
.my-125 {
    margin-bottom: 125px
}

.mb-130,
.my-130 {
    margin-bottom: 130px
}

.mb-135,
.my-135 {
    margin-bottom: 135px
}

.mb-140,
.my-140 {
    margin-bottom: 140px
}

.mb-145,
.my-145 {
    margin-bottom: 145px
}

.mb-150,
.my-150 {
    margin-bottom: 150px
}

.mb-155,
.my-155 {
    margin-bottom: 155px
}

.mb-160,
.my-160 {
    margin-bottom: 160px
}

.mb-165,
.my-165 {
    margin-bottom: 165px
}

.mb-170,
.my-170 {
    margin-bottom: 170px
}

.mb-175,
.my-175 {
    margin-bottom: 175px
}

.mb-180,
.my-180 {
    margin-bottom: 180px
}

.mb-185,
.my-185 {
    margin-bottom: 185px
}

.mb-190,
.my-190 {
    margin-bottom: 190px
}

.mb-195,
.my-195 {
    margin-bottom: 195px
}

.mb-200,
.my-200 {
    margin-bottom: 200px
}

.mb-205,
.my-205 {
    margin-bottom: 205px
}

.mb-210,
.my-210 {
    margin-bottom: 210px
}

.mb-215,
.my-215 {
    margin-bottom: 215px
}

.mb-220,
.my-220 {
    margin-bottom: 220px
}

.mb-225,
.my-225 {
    margin-bottom: 225px
}

.mb-230,
.my-230 {
    margin-bottom: 230px
}

.mb-235,
.my-235 {
    margin-bottom: 235px
}

.mb-240,
.my-240 {
    margin-bottom: 240px
}

.mb-245,
.my-245 {
    margin-bottom: 245px
}

.mb-250,
.my-250 {
    margin-bottom: 250px
}

/****************************************************** */
/*********** Responsive Padding Margin Spacing ******** */
/****************************************************** */
@media only screen and (max-width:991px) {
    .rp-0 {
        padding: 0 !important
    }

    .rp-5 {
        padding: 5px !important
    }

    .rp-10 {
        padding: 10px
    }

    .rp-15 {
        padding: 15px
    }

    .rp-20 {
        padding: 20px
    }

    .rp-25 {
        padding: 25px
    }

    .rp-30 {
        padding: 30px
    }

    .rp-35 {
        padding: 35px
    }

    .rp-40 {
        padding: 40px
    }

    .rp-45 {
        padding: 45px
    }

    .rp-50 {
        padding: 50px
    }

    .rp-55 {
        padding: 55px
    }

    .rp-60 {
        padding: 60px
    }

    .rp-65 {
        padding: 65px
    }

    .rp-70 {
        padding: 70px
    }

    .rp-75 {
        padding: 75px
    }

    .rp-80 {
        padding: 80px
    }

    .rp-85 {
        padding: 85px
    }

    .rp-90 {
        padding: 90px
    }

    .rp-95 {
        padding: 95px
    }

    .rp-100 {
        padding: 100px
    }

    .rp-105 {
        padding: 105px
    }

    .rp-110 {
        padding: 110px
    }

    .rp-115 {
        padding: 115px
    }

    .rp-120 {
        padding: 120px
    }

    .rp-125 {
        padding: 125px
    }

    .rp-130 {
        padding: 130px
    }

    .rp-135 {
        padding: 135px
    }

    .rp-140 {
        padding: 140px
    }

    .rp-145 {
        padding: 145px
    }

    .rp-150 {
        padding: 150px
    }

    .rpt-0,
    .rpy-0 {
        padding-top: 0 !important
    }

    .rpt-5,
    .rpy-5 {
        padding-top: 5px !important
    }

    .rpt-10,
    .rpy-10 {
        padding-top: 10px
    }

    .rpt-15,
    .rpy-15 {
        padding-top: 15px
    }

    .rpt-20,
    .rpy-20 {
        padding-top: 20px
    }

    .rpt-25,
    .rpy-25 {
        padding-top: 25px
    }

    .rpt-30,
    .rpy-30 {
        padding-top: 30px
    }

    .rpt-35,
    .rpy-35 {
        padding-top: 35px
    }

    .rpt-40,
    .rpy-40 {
        padding-top: 40px
    }

    .rpt-45,
    .rpy-45 {
        padding-top: 45px
    }

    .rpt-50,
    .rpy-50 {
        padding-top: 50px
    }

    .rpt-55,
    .rpy-55 {
        padding-top: 55px
    }

    .rpt-60,
    .rpy-60 {
        padding-top: 60px
    }

    .rpt-65,
    .rpy-65 {
        padding-top: 65px
    }

    .rpt-70,
    .rpy-70 {
        padding-top: 70px
    }

    .rpt-75,
    .rpy-75 {
        padding-top: 75px
    }

    .rpt-80,
    .rpy-80 {
        padding-top: 80px
    }

    .rpt-85,
    .rpy-85 {
        padding-top: 85px
    }

    .rpt-90,
    .rpy-90 {
        padding-top: 90px
    }

    .rpt-95,
    .rpy-95 {
        padding-top: 95px
    }

    .rpt-100,
    .rpy-100 {
        padding-top: 100px
    }

    .rpt-105,
    .rpy-105 {
        padding-top: 105px
    }

    .rpt-110,
    .rpy-110 {
        padding-top: 110px
    }

    .rpt-115,
    .rpy-115 {
        padding-top: 115px
    }

    .rpt-120,
    .rpy-120 {
        padding-top: 120px
    }

    .rpt-125,
    .rpy-125 {
        padding-top: 125px
    }

    .rpt-130,
    .rpy-130 {
        padding-top: 130px
    }

    .rpt-135,
    .rpy-135 {
        padding-top: 135px
    }

    .rpt-140,
    .rpy-140 {
        padding-top: 140px
    }

    .rpt-145,
    .rpy-145 {
        padding-top: 145px
    }

    .rpt-150,
    .rpy-150 {
        padding-top: 150px
    }

    .rpb-0,
    .rpy-0 {
        padding-bottom: 0 !important
    }

    .rpb-5,
    .rpy-5 {
        padding-bottom: 5px !important
    }

    .rpb-10,
    .rpy-10 {
        padding-bottom: 10px
    }

    .rpb-15,
    .rpy-15 {
        padding-bottom: 15px
    }

    .rpb-20,
    .rpy-20 {
        padding-bottom: 20px
    }

    .rpb-25,
    .rpy-25 {
        padding-bottom: 25px
    }

    .rpb-30,
    .rpy-30 {
        padding-bottom: 30px
    }

    .rpb-35,
    .rpy-35 {
        padding-bottom: 35px
    }

    .rpb-40,
    .rpy-40 {
        padding-bottom: 40px
    }

    .rpb-45,
    .rpy-45 {
        padding-bottom: 45px
    }

    .rpb-50,
    .rpy-50 {
        padding-bottom: 50px
    }

    .rpb-55,
    .rpy-55 {
        padding-bottom: 55px
    }

    .rpb-60,
    .rpy-60 {
        padding-bottom: 60px
    }

    .rpb-65,
    .rpy-65 {
        padding-bottom: 65px
    }

    .rpb-70,
    .rpy-70 {
        padding-bottom: 70px
    }

    .rpb-75,
    .rpy-75 {
        padding-bottom: 75px
    }

    .rpb-80,
    .rpy-80 {
        padding-bottom: 80px
    }

    .rpb-85,
    .rpy-85 {
        padding-bottom: 85px
    }

    .rpb-90,
    .rpy-90 {
        padding-bottom: 90px
    }

    .rpb-95,
    .rpy-95 {
        padding-bottom: 95px
    }

    .rpb-100,
    .rpy-100 {
        padding-bottom: 100px
    }

    .rpb-105,
    .rpy-105 {
        padding-bottom: 105px
    }

    .rpb-110,
    .rpy-110 {
        padding-bottom: 110px
    }

    .rpb-115,
    .rpy-115 {
        padding-bottom: 115px
    }

    .rpb-120,
    .rpy-120 {
        padding-bottom: 120px
    }

    .rpb-125,
    .rpy-125 {
        padding-bottom: 125px
    }

    .rpb-130,
    .rpy-130 {
        padding-bottom: 130px
    }

    .rpb-135,
    .rpy-135 {
        padding-bottom: 135px
    }

    .rpb-140,
    .rpy-140 {
        padding-bottom: 140px
    }

    .rpb-145,
    .rpy-145 {
        padding-bottom: 145px
    }

    .rpb-150,
    .rpy-150 {
        padding-bottom: 150px
    }

    .rm-0 {
        margin: 0 !important
    }

    .rm-5 {
        margin: 5px !important
    }

    .rm-10 {
        margin: 10px
    }

    .rm-15 {
        margin: 15px
    }

    .rm-20 {
        margin: 20px
    }

    .rm-25 {
        margin: 25px
    }

    .rm-30 {
        margin: 30px
    }

    .rm-35 {
        margin: 35px
    }

    .rm-40 {
        margin: 40px
    }

    .rm-45 {
        margin: 45px
    }

    .rm-50 {
        margin: 50px
    }

    .rm-55 {
        margin: 55px
    }

    .rm-60 {
        margin: 60px
    }

    .rm-65 {
        margin: 65px
    }

    .rm-70 {
        margin: 70px
    }

    .rm-75 {
        margin: 75px
    }

    .rm-80 {
        margin: 80px
    }

    .rm-85 {
        margin: 85px
    }

    .rm-90 {
        margin: 90px
    }

    .rm-95 {
        margin: 95px
    }

    .rm-100 {
        margin: 100px
    }

    .rm-105 {
        margin: 105px
    }

    .rm-110 {
        margin: 110px
    }

    .rm-115 {
        margin: 115px
    }

    .rm-120 {
        margin: 120px
    }

    .rm-125 {
        margin: 125px
    }

    .rm-130 {
        margin: 130px
    }

    .rm-135 {
        margin: 135px
    }

    .rm-140 {
        margin: 140px
    }

    .rm-145 {
        margin: 145px
    }

    .rm-150 {
        margin: 150px
    }

    .rmt-0,
    .rmy-0 {
        margin-top: 0 !important
    }

    .rmt-5,
    .rmy-5 {
        margin-top: 5px !important
    }

    .rmt-10,
    .rmy-10 {
        margin-top: 10px
    }

    .rmt-15,
    .rmy-15 {
        margin-top: 15px
    }

    .rmt-20,
    .rmy-20 {
        margin-top: 20px
    }

    .rmt-25,
    .rmy-25 {
        margin-top: 25px
    }

    .rmt-30,
    .rmy-30 {
        margin-top: 30px
    }

    .rmt-35,
    .rmy-35 {
        margin-top: 35px
    }

    .rmt-40,
    .rmy-40 {
        margin-top: 40px
    }

    .rmt-45,
    .rmy-45 {
        margin-top: 45px
    }

    .rmt-50,
    .rmy-50 {
        margin-top: 50px
    }

    .rmt-55,
    .rmy-55 {
        margin-top: 55px
    }

    .rmt-60,
    .rmy-60 {
        margin-top: 60px
    }

    .rmt-65,
    .rmy-65 {
        margin-top: 65px
    }

    .rmt-70,
    .rmy-70 {
        margin-top: 70px
    }

    .rmt-75,
    .rmy-75 {
        margin-top: 75px
    }

    .rmt-80,
    .rmy-80 {
        margin-top: 80px
    }

    .rmt-85,
    .rmy-85 {
        margin-top: 85px
    }

    .rmt-90,
    .rmy-90 {
        margin-top: 90px
    }

    .rmt-95,
    .rmy-95 {
        margin-top: 95px
    }

    .rmt-100,
    .rmy-100 {
        margin-top: 100px
    }

    .rmt-105,
    .rmy-105 {
        margin-top: 105px
    }

    .rmt-110,
    .rmy-110 {
        margin-top: 110px
    }

    .rmt-115,
    .rmy-115 {
        margin-top: 115px
    }

    .rmt-120,
    .rmy-120 {
        margin-top: 120px
    }

    .rmt-125,
    .rmy-125 {
        margin-top: 125px
    }

    .rmt-130,
    .rmy-130 {
        margin-top: 130px
    }

    .rmt-135,
    .rmy-135 {
        margin-top: 135px
    }

    .rmt-140,
    .rmy-140 {
        margin-top: 140px
    }

    .rmt-145,
    .rmy-145 {
        margin-top: 145px
    }

    .rmt-150,
    .rmy-150 {
        margin-top: 150px
    }

    .rmb-0,
    .rmy-0 {
        margin-bottom: 0 !important
    }

    .rmb-5,
    .rmy-5 {
        margin-bottom: 5px !important
    }

    .rmb-10,
    .rmy-10 {
        margin-bottom: 10px
    }

    .rmb-15,
    .rmy-15 {
        margin-bottom: 15px
    }

    .rmb-20,
    .rmy-20 {
        margin-bottom: 20px
    }

    .rmb-25,
    .rmy-25 {
        margin-bottom: 25px
    }

    .rmb-30,
    .rmy-30 {
        margin-bottom: 30px
    }

    .rmb-35,
    .rmy-35 {
        margin-bottom: 35px
    }

    .rmb-40,
    .rmy-40 {
        margin-bottom: 40px
    }

    .rmb-45,
    .rmy-45 {
        margin-bottom: 45px
    }

    .rmb-50,
    .rmy-50 {
        margin-bottom: 50px
    }

    .rmb-55,
    .rmy-55 {
        margin-bottom: 55px
    }

    .rmb-60,
    .rmy-60 {
        margin-bottom: 60px
    }

    .rmb-65,
    .rmy-65 {
        margin-bottom: 65px
    }

    .rmb-70,
    .rmy-70 {
        margin-bottom: 70px
    }

    .rmb-75,
    .rmy-75 {
        margin-bottom: 75px
    }

    .rmb-80,
    .rmy-80 {
        margin-bottom: 80px
    }

    .rmb-85,
    .rmy-85 {
        margin-bottom: 85px
    }

    .rmb-90,
    .rmy-90 {
        margin-bottom: 90px
    }

    .rmb-95,
    .rmy-95 {
        margin-bottom: 95px
    }

    .rmb-100,
    .rmy-100 {
        margin-bottom: 100px
    }

    .rmb-105,
    .rmy-105 {
        margin-bottom: 105px
    }

    .rmb-110,
    .rmy-110 {
        margin-bottom: 110px
    }

    .rmb-115,
    .rmy-115 {
        margin-bottom: 115px
    }

    .rmb-120,
    .rmy-120 {
        margin-bottom: 120px
    }

    .rmb-125,
    .rmy-125 {
        margin-bottom: 125px
    }

    .rmb-130,
    .rmy-130 {
        margin-bottom: 130px
    }

    .rmb-135,
    .rmy-135 {
        margin-bottom: 135px
    }

    .rmb-140,
    .rmy-140 {
        margin-bottom: 140px
    }

    .rmb-145,
    .rmy-145 {
        margin-bottom: 145px
    }

    .rmb-150,
    .rmy-150 {
        margin-bottom: 150px
    }
}

@charset "UTF-8";

/*!
Animate.css - http://daneden.me/animate
Licensed under the MIT license

Copyright (c) 2013 Daniel Eden

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
.animated {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

.animated.hinge {
    -webkit-animation-duration: 2s;
    animation-duration: 2s
}

@-webkit-keyframes bounce {

    0%,
    100%,
    20%,
    50%,
    80% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    40% {
        -webkit-transform: translateY(-30px);
        transform: translateY(-30px)
    }

    60% {
        -webkit-transform: translateY(-15px);
        transform: translateY(-15px)
    }
}

@keyframes bounce {

    0%,
    100%,
    20%,
    50%,
    80% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    40% {
        -webkit-transform: translateY(-30px);
        -ms-transform: translateY(-30px);
        transform: translateY(-30px)
    }

    60% {
        -webkit-transform: translateY(-15px);
        -ms-transform: translateY(-15px);
        transform: translateY(-15px)
    }
}

.bounce {
    -webkit-animation-name: bounce;
    animation-name: bounce
}

@-webkit-keyframes flash {

    0%,
    100%,
    50% {
        opacity: 1
    }

    25%,
    75% {
        opacity: 0
    }
}

@keyframes flash {

    0%,
    100%,
    50% {
        opacity: 1
    }

    25%,
    75% {
        opacity: 0
    }
}

.flash {
    -webkit-animation-name: flash;
    animation-name: flash
}

@-webkit-keyframes pulse {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    50% {
        -webkit-transform: scale(1.1);
        transform: scale(1.1)
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@keyframes pulse {
    0% {
        -webkit-transform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1)
    }

    50% {
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1)
    }

    100% {
        -webkit-transform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1)
    }
}

.pulse {
    -webkit-animation-name: pulse;
    animation-name: pulse
}

@-webkit-keyframes shake {

    0%,
    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    10%,
    30%,
    50%,
    70%,
    90% {
        -webkit-transform: translateX(-10px);
        transform: translateX(-10px)
    }

    20%,
    40%,
    60%,
    80% {
        -webkit-transform: translateX(10px);
        transform: translateX(10px)
    }
}

@keyframes shake {

    0%,
    100% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    10%,
    30%,
    50%,
    70%,
    90% {
        -webkit-transform: translateX(-10px);
        -ms-transform: translateX(-10px);
        transform: translateX(-10px)
    }

    20%,
    40%,
    60%,
    80% {
        -webkit-transform: translateX(10px);
        -ms-transform: translateX(10px);
        transform: translateX(10px)
    }
}

.shake {
    -webkit-animation-name: shake;
    animation-name: shake
}

@-webkit-keyframes swing {
    20% {
        -webkit-transform: rotate(15deg);
        transform: rotate(15deg)
    }

    40% {
        -webkit-transform: rotate(-10deg);
        transform: rotate(-10deg)
    }

    60% {
        -webkit-transform: rotate(5deg);
        transform: rotate(5deg)
    }

    80% {
        -webkit-transform: rotate(-5deg);
        transform: rotate(-5deg)
    }

    100% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
}

@keyframes swing {
    20% {
        -webkit-transform: rotate(15deg);
        -ms-transform: rotate(15deg);
        transform: rotate(15deg)
    }

    40% {
        -webkit-transform: rotate(-10deg);
        -ms-transform: rotate(-10deg);
        transform: rotate(-10deg)
    }

    60% {
        -webkit-transform: rotate(5deg);
        -ms-transform: rotate(5deg);
        transform: rotate(5deg)
    }

    80% {
        -webkit-transform: rotate(-5deg);
        -ms-transform: rotate(-5deg);
        transform: rotate(-5deg)
    }

    100% {
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0)
    }
}

.swing {
    -webkit-transform-origin: top center;
    -ms-transform-origin: top center;
    transform-origin: top center;
    -webkit-animation-name: swing;
    animation-name: swing
}

@-webkit-keyframes tada {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    10%,
    20% {
        -webkit-transform: scale(.9) rotate(-3deg);
        transform: scale(.9) rotate(-3deg)
    }

    30%,
    50%,
    70%,
    90% {
        -webkit-transform: scale(1.1) rotate(3deg);
        transform: scale(1.1) rotate(3deg)
    }

    40%,
    60%,
    80% {
        -webkit-transform: scale(1.1) rotate(-3deg);
        transform: scale(1.1) rotate(-3deg)
    }

    100% {
        -webkit-transform: scale(1) rotate(0);
        transform: scale(1) rotate(0)
    }
}

@keyframes tada {
    0% {
        -webkit-transform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1)
    }

    10%,
    20% {
        -webkit-transform: scale(.9) rotate(-3deg);
        -ms-transform: scale(.9) rotate(-3deg);
        transform: scale(.9) rotate(-3deg)
    }

    30%,
    50%,
    70%,
    90% {
        -webkit-transform: scale(1.1) rotate(3deg);
        -ms-transform: scale(1.1) rotate(3deg);
        transform: scale(1.1) rotate(3deg)
    }

    40%,
    60%,
    80% {
        -webkit-transform: scale(1.1) rotate(-3deg);
        -ms-transform: scale(1.1) rotate(-3deg);
        transform: scale(1.1) rotate(-3deg)
    }

    100% {
        -webkit-transform: scale(1) rotate(0);
        -ms-transform: scale(1) rotate(0);
        transform: scale(1) rotate(0)
    }
}

.tada {
    -webkit-animation-name: tada;
    animation-name: tada
}

@-webkit-keyframes wobble {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    15% {
        -webkit-transform: translateX(-25%) rotate(-5deg);
        transform: translateX(-25%) rotate(-5deg)
    }

    30% {
        -webkit-transform: translateX(20%) rotate(3deg);
        transform: translateX(20%) rotate(3deg)
    }

    45% {
        -webkit-transform: translateX(-15%) rotate(-3deg);
        transform: translateX(-15%) rotate(-3deg)
    }

    60% {
        -webkit-transform: translateX(10%) rotate(2deg);
        transform: translateX(10%) rotate(2deg)
    }

    75% {
        -webkit-transform: translateX(-5%) rotate(-1deg);
        transform: translateX(-5%) rotate(-1deg)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes wobble {
    0% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    15% {
        -webkit-transform: translateX(-25%) rotate(-5deg);
        -ms-transform: translateX(-25%) rotate(-5deg);
        transform: translateX(-25%) rotate(-5deg)
    }

    30% {
        -webkit-transform: translateX(20%) rotate(3deg);
        -ms-transform: translateX(20%) rotate(3deg);
        transform: translateX(20%) rotate(3deg)
    }

    45% {
        -webkit-transform: translateX(-15%) rotate(-3deg);
        -ms-transform: translateX(-15%) rotate(-3deg);
        transform: translateX(-15%) rotate(-3deg)
    }

    60% {
        -webkit-transform: translateX(10%) rotate(2deg);
        -ms-transform: translateX(10%) rotate(2deg);
        transform: translateX(10%) rotate(2deg)
    }

    75% {
        -webkit-transform: translateX(-5%) rotate(-1deg);
        -ms-transform: translateX(-5%) rotate(-1deg);
        transform: translateX(-5%) rotate(-1deg)
    }

    100% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.wobble {
    -webkit-animation-name: wobble;
    animation-name: wobble
}

@-webkit-keyframes bounceIn {
    0% {
        opacity: 0;
        -webkit-transform: scale(.3);
        transform: scale(.3)
    }

    50% {
        opacity: 1;
        -webkit-transform: scale(1.05);
        transform: scale(1.05)
    }

    70% {
        -webkit-transform: scale(.9);
        transform: scale(.9)
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@keyframes bounceIn {
    0% {
        opacity: 0;
        -webkit-transform: scale(.3);
        -ms-transform: scale(.3);
        transform: scale(.3)
    }

    50% {
        opacity: 1;
        -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
        transform: scale(1.05)
    }

    70% {
        -webkit-transform: scale(.9);
        -ms-transform: scale(.9);
        transform: scale(.9)
    }

    100% {
        -webkit-transform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1)
    }
}

.bounceIn {
    -webkit-animation-name: bounceIn;
    animation-name: bounceIn
}

@-webkit-keyframes bounceInDown {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateY(30px);
        transform: translateY(30px)
    }

    80% {
        -webkit-transform: translateY(-10px);
        transform: translateY(-10px)
    }

    100% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes bounceInDown {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        -ms-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateY(30px);
        -ms-transform: translateY(30px);
        transform: translateY(30px)
    }

    80% {
        -webkit-transform: translateY(-10px);
        -ms-transform: translateY(-10px);
        transform: translateY(-10px)
    }

    100% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.bounceInDown {
    -webkit-animation-name: bounceInDown;
    animation-name: bounceInDown
}

@-webkit-keyframes bounceInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateX(30px);
        transform: translateX(30px)
    }

    80% {
        -webkit-transform: translateX(-10px);
        transform: translateX(-10px)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes bounceInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        -ms-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateX(30px);
        -ms-transform: translateX(30px);
        transform: translateX(30px)
    }

    80% {
        -webkit-transform: translateX(-10px);
        -ms-transform: translateX(-10px);
        transform: translateX(-10px)
    }

    100% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.bounceInLeft {
    -webkit-animation-name: bounceInLeft;
    animation-name: bounceInLeft
}

@-webkit-keyframes bounceInRight {
    0% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        transform: translateX(2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateX(-30px);
        transform: translateX(-30px)
    }

    80% {
        -webkit-transform: translateX(10px);
        transform: translateX(10px)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes bounceInRight {
    0% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        -ms-transform: translateX(2000px);
        transform: translateX(2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateX(-30px);
        -ms-transform: translateX(-30px);
        transform: translateX(-30px)
    }

    80% {
        -webkit-transform: translateX(10px);
        -ms-transform: translateX(10px);
        transform: translateX(10px)
    }

    100% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.bounceInRight {
    -webkit-animation-name: bounceInRight;
    animation-name: bounceInRight
}

@-webkit-keyframes bounceInUp {
    0% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        transform: translateY(2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateY(-30px);
        transform: translateY(-30px)
    }

    80% {
        -webkit-transform: translateY(10px);
        transform: translateY(10px)
    }

    100% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes bounceInUp {
    0% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        -ms-transform: translateY(2000px);
        transform: translateY(2000px)
    }

    60% {
        opacity: 1;
        -webkit-transform: translateY(-30px);
        -ms-transform: translateY(-30px);
        transform: translateY(-30px)
    }

    80% {
        -webkit-transform: translateY(10px);
        -ms-transform: translateY(10px);
        transform: translateY(10px)
    }

    100% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.bounceInUp {
    -webkit-animation-name: bounceInUp;
    animation-name: bounceInUp
}

@-webkit-keyframes bounceOut {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    25% {
        -webkit-transform: scale(.95);
        transform: scale(.95)
    }

    50% {
        opacity: 1;
        -webkit-transform: scale(1.1);
        transform: scale(1.1)
    }

    100% {
        opacity: 0;
        -webkit-transform: scale(.3);
        transform: scale(.3)
    }
}

@keyframes bounceOut {
    0% {
        -webkit-transform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1)
    }

    25% {
        -webkit-transform: scale(.95);
        -ms-transform: scale(.95);
        transform: scale(.95)
    }

    50% {
        opacity: 1;
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1)
    }

    100% {
        opacity: 0;
        -webkit-transform: scale(.3);
        -ms-transform: scale(.3);
        transform: scale(.3)
    }
}

.bounceOut {
    -webkit-animation-name: bounceOut;
    animation-name: bounceOut
}

@-webkit-keyframes bounceOutDown {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        transform: translateY(2000px)
    }
}

@keyframes bounceOutDown {
    0% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateY(-20px);
        -ms-transform: translateY(-20px);
        transform: translateY(-20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        -ms-transform: translateY(2000px);
        transform: translateY(2000px)
    }
}

.bounceOutDown {
    -webkit-animation-name: bounceOutDown;
    animation-name: bounceOutDown
}

@-webkit-keyframes bounceOutLeft {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateX(20px);
        transform: translateX(20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }
}

@keyframes bounceOutLeft {
    0% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateX(20px);
        -ms-transform: translateX(20px);
        transform: translateX(20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        -ms-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }
}

.bounceOutLeft {
    -webkit-animation-name: bounceOutLeft;
    animation-name: bounceOutLeft
}

@-webkit-keyframes bounceOutRight {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateX(-20px);
        transform: translateX(-20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        transform: translateX(2000px)
    }
}

@keyframes bounceOutRight {
    0% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateX(-20px);
        -ms-transform: translateX(-20px);
        transform: translateX(-20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        -ms-transform: translateX(2000px);
        transform: translateX(2000px)
    }
}

.bounceOutRight {
    -webkit-animation-name: bounceOutRight;
    animation-name: bounceOutRight
}

@-webkit-keyframes bounceOutUp {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateY(20px);
        transform: translateY(20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }
}

@keyframes bounceOutUp {
    0% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    20% {
        opacity: 1;
        -webkit-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        -ms-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }
}

.bounceOutUp {
    -webkit-animation-name: bounceOutUp;
    animation-name: bounceOutUp
}

@-webkit-keyframes fadeIn {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

.fadeIn {
    -webkit-animation-name: fadeIn;
    animation-name: fadeIn
}

@-webkit-keyframes fadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-20px);
        -ms-transform: translateY(-20px);
        transform: translateY(-20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.fadeInDown {
    -webkit-animation-name: fadeInDown;
    animation-name: fadeInDown
}

@-webkit-keyframes fadeInDownBig {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes fadeInDownBig {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        -ms-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.fadeInDownBig {
    -webkit-animation-name: fadeInDownBig;
    animation-name: fadeInDownBig
}

@-webkit-keyframes fadeInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-20px);
        transform: translateX(-20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes fadeInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-20px);
        -ms-transform: translateX(-20px);
        transform: translateX(-20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.fadeInLeft {
    -webkit-animation-name: fadeInLeft;
    animation-name: fadeInLeft
}

@-webkit-keyframes fadeInLeftBig {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes fadeInLeftBig {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        -ms-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.fadeInLeftBig {
    -webkit-animation-name: fadeInLeftBig;
    animation-name: fadeInLeftBig
}

@-webkit-keyframes fadeInRight {
    0% {
        opacity: 0;
        -webkit-transform: translateX(20px);
        transform: translateX(20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes fadeInRight {
    0% {
        opacity: 0;
        -webkit-transform: translateX(20px);
        -ms-transform: translateX(20px);
        transform: translateX(20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.fadeInRight {
    -webkit-animation-name: fadeInRight;
    animation-name: fadeInRight
}

@-webkit-keyframes fadeInRightBig {
    0% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        transform: translateX(2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes fadeInRightBig {
    0% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        -ms-transform: translateX(2000px);
        transform: translateX(2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.fadeInRightBig {
    -webkit-animation-name: fadeInRightBig;
    animation-name: fadeInRightBig
}

@-webkit-keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translateY(20px);
        transform: translateY(20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.fadeInUp {
    -webkit-animation-name: fadeInUp;
    animation-name: fadeInUp
}

@-webkit-keyframes fadeInUpBig {
    0% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        transform: translateY(2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes fadeInUpBig {
    0% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        -ms-transform: translateY(2000px);
        transform: translateY(2000px)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.fadeInUpBig {
    -webkit-animation-name: fadeInUpBig;
    animation-name: fadeInUpBig
}

@-webkit-keyframes fadeOut {
    0% {
        opacity: 1
    }

    100% {
        opacity: 0
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1
    }

    100% {
        opacity: 0
    }
}

.fadeOut {
    -webkit-animation-name: fadeOut;
    animation-name: fadeOut
}

@-webkit-keyframes fadeOutDown {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(20px);
        transform: translateY(20px)
    }
}

@keyframes fadeOutDown {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px)
    }
}

.fadeOutDown {
    -webkit-animation-name: fadeOutDown;
    animation-name: fadeOutDown
}

@-webkit-keyframes fadeOutDownBig {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        transform: translateY(2000px)
    }
}

@keyframes fadeOutDownBig {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(2000px);
        -ms-transform: translateY(2000px);
        transform: translateY(2000px)
    }
}

.fadeOutDownBig {
    -webkit-animation-name: fadeOutDownBig;
    animation-name: fadeOutDownBig
}

@-webkit-keyframes fadeOutLeft {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-20px);
        transform: translateX(-20px)
    }
}

@keyframes fadeOutLeft {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-20px);
        -ms-transform: translateX(-20px);
        transform: translateX(-20px)
    }
}

.fadeOutLeft {
    -webkit-animation-name: fadeOutLeft;
    animation-name: fadeOutLeft
}

@-webkit-keyframes fadeOutLeftBig {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }
}

@keyframes fadeOutLeftBig {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        -ms-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }
}

.fadeOutLeftBig {
    -webkit-animation-name: fadeOutLeftBig;
    animation-name: fadeOutLeftBig
}

@-webkit-keyframes fadeOutRight {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(20px);
        transform: translateX(20px)
    }
}

@keyframes fadeOutRight {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(20px);
        -ms-transform: translateX(20px);
        transform: translateX(20px)
    }
}

.fadeOutRight {
    -webkit-animation-name: fadeOutRight;
    animation-name: fadeOutRight
}

@-webkit-keyframes fadeOutRightBig {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        transform: translateX(2000px)
    }
}

@keyframes fadeOutRightBig {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        -ms-transform: translateX(2000px);
        transform: translateX(2000px)
    }
}

.fadeOutRightBig {
    -webkit-animation-name: fadeOutRightBig;
    animation-name: fadeOutRightBig
}

@-webkit-keyframes fadeOutUp {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px)
    }
}

@keyframes fadeOutUp {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-20px);
        -ms-transform: translateY(-20px);
        transform: translateY(-20px)
    }
}

.fadeOutUp {
    -webkit-animation-name: fadeOutUp;
    animation-name: fadeOutUp
}

@-webkit-keyframes fadeOutUpBig {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }
}

@keyframes fadeOutUpBig {
    0% {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        -ms-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }
}

.fadeOutUpBig {
    -webkit-animation-name: fadeOutUpBig;
    animation-name: fadeOutUpBig
}

@-webkit-keyframes flip {
    0% {
        -webkit-transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
        transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out
    }

    40% {
        -webkit-transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
        transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out
    }

    50% {
        -webkit-transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
        transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
        -webkit-animation-timing-function: ease-in;
        animation-timing-function: ease-in
    }

    80% {
        -webkit-transform: perspective(400px) translateZ(0) rotateY(360deg) scale(.95);
        transform: perspective(400px) translateZ(0) rotateY(360deg) scale(.95);
        -webkit-animation-timing-function: ease-in;
        animation-timing-function: ease-in
    }

    100% {
        -webkit-transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
        transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
        -webkit-animation-timing-function: ease-in;
        animation-timing-function: ease-in
    }
}

@keyframes flip {
    0% {
        -webkit-transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
        -ms-transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
        transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out
    }

    40% {
        -webkit-transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
        -ms-transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
        transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out
    }

    50% {
        -webkit-transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
        -ms-transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
        transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
        -webkit-animation-timing-function: ease-in;
        animation-timing-function: ease-in
    }

    80% {
        -webkit-transform: perspective(400px) translateZ(0) rotateY(360deg) scale(.95);
        -ms-transform: perspective(400px) translateZ(0) rotateY(360deg) scale(.95);
        transform: perspective(400px) translateZ(0) rotateY(360deg) scale(.95);
        -webkit-animation-timing-function: ease-in;
        animation-timing-function: ease-in
    }

    100% {
        -webkit-transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
        -ms-transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
        transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
        -webkit-animation-timing-function: ease-in;
        animation-timing-function: ease-in
    }
}

.animated.flip {
    -webkit-backface-visibility: visible;
    -ms-backface-visibility: visible;
    backface-visibility: visible;
    -webkit-animation-name: flip;
    animation-name: flip
}

@-webkit-keyframes flipInX {
    0% {
        -webkit-transform: perspective(400px) rotateX(90deg);
        transform: perspective(400px) rotateX(90deg);
        opacity: 0
    }

    40% {
        -webkit-transform: perspective(400px) rotateX(-10deg);
        transform: perspective(400px) rotateX(-10deg)
    }

    70% {
        -webkit-transform: perspective(400px) rotateX(10deg);
        transform: perspective(400px) rotateX(10deg)
    }

    100% {
        -webkit-transform: perspective(400px) rotateX(0);
        transform: perspective(400px) rotateX(0);
        opacity: 1
    }
}

@keyframes flipInX {
    0% {
        -webkit-transform: perspective(400px) rotateX(90deg);
        -ms-transform: perspective(400px) rotateX(90deg);
        transform: perspective(400px) rotateX(90deg);
        opacity: 0
    }

    40% {
        -webkit-transform: perspective(400px) rotateX(-10deg);
        -ms-transform: perspective(400px) rotateX(-10deg);
        transform: perspective(400px) rotateX(-10deg)
    }

    70% {
        -webkit-transform: perspective(400px) rotateX(10deg);
        -ms-transform: perspective(400px) rotateX(10deg);
        transform: perspective(400px) rotateX(10deg)
    }

    100% {
        -webkit-transform: perspective(400px) rotateX(0);
        -ms-transform: perspective(400px) rotateX(0);
        transform: perspective(400px) rotateX(0);
        opacity: 1
    }
}

.flipInX {
    -webkit-backface-visibility: visible !important;
    -ms-backface-visibility: visible !important;
    backface-visibility: visible !important;
    -webkit-animation-name: flipInX;
    animation-name: flipInX
}

@-webkit-keyframes flipInY {
    0% {
        -webkit-transform: perspective(400px) rotateY(90deg);
        transform: perspective(400px) rotateY(90deg);
        opacity: 0
    }

    40% {
        -webkit-transform: perspective(400px) rotateY(-10deg);
        transform: perspective(400px) rotateY(-10deg)
    }

    70% {
        -webkit-transform: perspective(400px) rotateY(10deg);
        transform: perspective(400px) rotateY(10deg)
    }

    100% {
        -webkit-transform: perspective(400px) rotateY(0);
        transform: perspective(400px) rotateY(0);
        opacity: 1
    }
}

@keyframes flipInY {
    0% {
        -webkit-transform: perspective(400px) rotateY(90deg);
        -ms-transform: perspective(400px) rotateY(90deg);
        transform: perspective(400px) rotateY(90deg);
        opacity: 0
    }

    40% {
        -webkit-transform: perspective(400px) rotateY(-10deg);
        -ms-transform: perspective(400px) rotateY(-10deg);
        transform: perspective(400px) rotateY(-10deg)
    }

    70% {
        -webkit-transform: perspective(400px) rotateY(10deg);
        -ms-transform: perspective(400px) rotateY(10deg);
        transform: perspective(400px) rotateY(10deg)
    }

    100% {
        -webkit-transform: perspective(400px) rotateY(0);
        -ms-transform: perspective(400px) rotateY(0);
        transform: perspective(400px) rotateY(0);
        opacity: 1
    }
}

.flipInY {
    -webkit-backface-visibility: visible !important;
    -ms-backface-visibility: visible !important;
    backface-visibility: visible !important;
    -webkit-animation-name: flipInY;
    animation-name: flipInY
}

@-webkit-keyframes flipOutX {
    0% {
        -webkit-transform: perspective(400px) rotateX(0);
        transform: perspective(400px) rotateX(0);
        opacity: 1
    }

    100% {
        -webkit-transform: perspective(400px) rotateX(90deg);
        transform: perspective(400px) rotateX(90deg);
        opacity: 0
    }
}

@keyframes flipOutX {
    0% {
        -webkit-transform: perspective(400px) rotateX(0);
        -ms-transform: perspective(400px) rotateX(0);
        transform: perspective(400px) rotateX(0);
        opacity: 1
    }

    100% {
        -webkit-transform: perspective(400px) rotateX(90deg);
        -ms-transform: perspective(400px) rotateX(90deg);
        transform: perspective(400px) rotateX(90deg);
        opacity: 0
    }
}

.flipOutX {
    -webkit-animation-name: flipOutX;
    animation-name: flipOutX;
    -webkit-backface-visibility: visible !important;
    -ms-backface-visibility: visible !important;
    backface-visibility: visible !important
}

@-webkit-keyframes flipOutY {
    0% {
        -webkit-transform: perspective(400px) rotateY(0);
        transform: perspective(400px) rotateY(0);
        opacity: 1
    }

    100% {
        -webkit-transform: perspective(400px) rotateY(90deg);
        transform: perspective(400px) rotateY(90deg);
        opacity: 0
    }
}

@keyframes flipOutY {
    0% {
        -webkit-transform: perspective(400px) rotateY(0);
        -ms-transform: perspective(400px) rotateY(0);
        transform: perspective(400px) rotateY(0);
        opacity: 1
    }

    100% {
        -webkit-transform: perspective(400px) rotateY(90deg);
        -ms-transform: perspective(400px) rotateY(90deg);
        transform: perspective(400px) rotateY(90deg);
        opacity: 0
    }
}

.flipOutY {
    -webkit-backface-visibility: visible !important;
    -ms-backface-visibility: visible !important;
    backface-visibility: visible !important;
    -webkit-animation-name: flipOutY;
    animation-name: flipOutY
}

@-webkit-keyframes lightSpeedIn {
    0% {
        -webkit-transform: translateX(100%) skewX(-30deg);
        transform: translateX(100%) skewX(-30deg);
        opacity: 0
    }

    60% {
        -webkit-transform: translateX(-20%) skewX(30deg);
        transform: translateX(-20%) skewX(30deg);
        opacity: 1
    }

    80% {
        -webkit-transform: translateX(0) skewX(-15deg);
        transform: translateX(0) skewX(-15deg);
        opacity: 1
    }

    100% {
        -webkit-transform: translateX(0) skewX(0);
        transform: translateX(0) skewX(0);
        opacity: 1
    }
}

@keyframes lightSpeedIn {
    0% {
        -webkit-transform: translateX(100%) skewX(-30deg);
        -ms-transform: translateX(100%) skewX(-30deg);
        transform: translateX(100%) skewX(-30deg);
        opacity: 0
    }

    60% {
        -webkit-transform: translateX(-20%) skewX(30deg);
        -ms-transform: translateX(-20%) skewX(30deg);
        transform: translateX(-20%) skewX(30deg);
        opacity: 1
    }

    80% {
        -webkit-transform: translateX(0) skewX(-15deg);
        -ms-transform: translateX(0) skewX(-15deg);
        transform: translateX(0) skewX(-15deg);
        opacity: 1
    }

    100% {
        -webkit-transform: translateX(0) skewX(0);
        -ms-transform: translateX(0) skewX(0);
        transform: translateX(0) skewX(0);
        opacity: 1
    }
}

.lightSpeedIn {
    -webkit-animation-name: lightSpeedIn;
    animation-name: lightSpeedIn;
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out
}

@-webkit-keyframes lightSpeedOut {
    0% {
        -webkit-transform: translateX(0) skewX(0);
        transform: translateX(0) skewX(0);
        opacity: 1
    }

    100% {
        -webkit-transform: translateX(100%) skewX(-30deg);
        transform: translateX(100%) skewX(-30deg);
        opacity: 0
    }
}

@keyframes lightSpeedOut {
    0% {
        -webkit-transform: translateX(0) skewX(0);
        -ms-transform: translateX(0) skewX(0);
        transform: translateX(0) skewX(0);
        opacity: 1
    }

    100% {
        -webkit-transform: translateX(100%) skewX(-30deg);
        -ms-transform: translateX(100%) skewX(-30deg);
        transform: translateX(100%) 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 {
    0% {
        -webkit-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(-200deg);
        transform: rotate(-200deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

@keyframes rotateIn {
    0% {
        -webkit-transform-origin: center center;
        -ms-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(-200deg);
        -ms-transform: rotate(-200deg);
        transform: rotate(-200deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: center center;
        -ms-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

.rotateIn {
    -webkit-animation-name: rotateIn;
    animation-name: rotateIn
}

@-webkit-keyframes rotateInDownLeft {
    0% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

@keyframes rotateInDownLeft {
    0% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(-90deg);
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

.rotateInDownLeft {
    -webkit-animation-name: rotateInDownLeft;
    animation-name: rotateInDownLeft
}

@-webkit-keyframes rotateInDownRight {
    0% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

@keyframes rotateInDownRight {
    0% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

.rotateInDownRight {
    -webkit-animation-name: rotateInDownRight;
    animation-name: rotateInDownRight
}

@-webkit-keyframes rotateInUpLeft {
    0% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

@keyframes rotateInUpLeft {
    0% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

.rotateInUpLeft {
    -webkit-animation-name: rotateInUpLeft;
    animation-name: rotateInUpLeft
}

@-webkit-keyframes rotateInUpRight {
    0% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

@keyframes rotateInUpRight {
    0% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(-90deg);
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }

    100% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }
}

.rotateInUpRight {
    -webkit-animation-name: rotateInUpRight;
    animation-name: rotateInUpRight
}

@-webkit-keyframes rotateOut {
    0% {
        -webkit-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(200deg);
        transform: rotate(200deg);
        opacity: 0
    }
}

@keyframes rotateOut {
    0% {
        -webkit-transform-origin: center center;
        -ms-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: center center;
        -ms-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: rotate(200deg);
        -ms-transform: rotate(200deg);
        transform: rotate(200deg);
        opacity: 0
    }
}

.rotateOut {
    -webkit-animation-name: rotateOut;
    animation-name: rotateOut
}

@-webkit-keyframes rotateOutDownLeft {
    0% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }
}

@keyframes rotateOutDownLeft {
    0% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }
}

.rotateOutDownLeft {
    -webkit-animation-name: rotateOutDownLeft;
    animation-name: rotateOutDownLeft
}

@-webkit-keyframes rotateOutDownRight {
    0% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }
}

@keyframes rotateOutDownRight {
    0% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(-90deg);
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }
}

.rotateOutDownRight {
    -webkit-animation-name: rotateOutDownRight;
    animation-name: rotateOutDownRight
}

@-webkit-keyframes rotateOutUpLeft {
    0% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }
}

@keyframes rotateOutUpLeft {
    0% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: left bottom;
        -ms-transform-origin: left bottom;
        transform-origin: left bottom;
        -webkit-transform: rotate(-90deg);
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
        opacity: 0
    }
}

.rotateOutUpLeft {
    -webkit-animation-name: rotateOutUpLeft;
    animation-name: rotateOutUpLeft
}

@-webkit-keyframes rotateOutUpRight {
    0% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }
}

@keyframes rotateOutUpRight {
    0% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        opacity: 1
    }

    100% {
        -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
        transform-origin: right bottom;
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
        opacity: 0
    }
}

.rotateOutUpRight {
    -webkit-animation-name: rotateOutUpRight;
    animation-name: rotateOutUpRight
}

@-webkit-keyframes slideInDown {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }

    100% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
}

@keyframes slideInDown {
    0% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        -ms-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }

    100% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }
}

.slideInDown {
    -webkit-animation-name: slideInDown;
    animation-name: slideInDown
}

@-webkit-keyframes slideInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes slideInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        -ms-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }

    100% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.slideInLeft {
    -webkit-animation-name: slideInLeft;
    animation-name: slideInLeft
}

@-webkit-keyframes slideInRight {
    0% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        transform: translateX(2000px)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes slideInRight {
    0% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        -ms-transform: translateX(2000px);
        transform: translateX(2000px)
    }

    100% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }
}

.slideInRight {
    -webkit-animation-name: slideInRight;
    animation-name: slideInRight
}

@-webkit-keyframes slideOutLeft {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }
}

@keyframes slideOutLeft {
    0% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(-2000px);
        -ms-transform: translateX(-2000px);
        transform: translateX(-2000px)
    }
}

.slideOutLeft {
    -webkit-animation-name: slideOutLeft;
    animation-name: slideOutLeft
}

@-webkit-keyframes slideOutRight {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        transform: translateX(2000px)
    }
}

@keyframes slideOutRight {
    0% {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(2000px);
        -ms-transform: translateX(2000px);
        transform: translateX(2000px)
    }
}

.slideOutRight {
    -webkit-animation-name: slideOutRight;
    animation-name: slideOutRight
}

@-webkit-keyframes slideOutUp {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }
}

@keyframes slideOutUp {
    0% {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateY(-2000px);
        -ms-transform: translateY(-2000px);
        transform: translateY(-2000px)
    }
}

.slideOutUp {
    -webkit-animation-name: slideOutUp;
    animation-name: slideOutUp
}

@-webkit-keyframes hinge {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0);
        -webkit-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    20%,
    60% {
        -webkit-transform: rotate(80deg);
        transform: rotate(80deg);
        -webkit-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    40% {
        -webkit-transform: rotate(60deg);
        transform: rotate(60deg);
        -webkit-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    80% {
        -webkit-transform: rotate(60deg) translateY(0);
        transform: rotate(60deg) translateY(0);
        opacity: 1;
        -webkit-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    100% {
        -webkit-transform: translateY(700px);
        transform: translateY(700px);
        opacity: 0
    }
}

@keyframes hinge {
    0% {
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        -webkit-transform-origin: top left;
        -ms-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    20%,
    60% {
        -webkit-transform: rotate(80deg);
        -ms-transform: rotate(80deg);
        transform: rotate(80deg);
        -webkit-transform-origin: top left;
        -ms-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    40% {
        -webkit-transform: rotate(60deg);
        -ms-transform: rotate(60deg);
        transform: rotate(60deg);
        -webkit-transform-origin: top left;
        -ms-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    80% {
        -webkit-transform: rotate(60deg) translateY(0);
        -ms-transform: rotate(60deg) translateY(0);
        transform: rotate(60deg) translateY(0);
        opacity: 1;
        -webkit-transform-origin: top left;
        -ms-transform-origin: top left;
        transform-origin: top left;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out
    }

    100% {
        -webkit-transform: translateY(700px);
        -ms-transform: translateY(700px);
        transform: translateY(700px);
        opacity: 0
    }
}

.hinge {
    -webkit-animation-name: hinge;
    animation-name: hinge
}

@-webkit-keyframes rollIn {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-100%) rotate(-120deg);
        transform: translateX(-100%) rotate(-120deg)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0) rotate(0);
        transform: translateX(0) rotate(0)
    }
}

@keyframes rollIn {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-100%) rotate(-120deg);
        -ms-transform: translateX(-100%) rotate(-120deg);
        transform: translateX(-100%) rotate(-120deg)
    }

    100% {
        opacity: 1;
        -webkit-transform: translateX(0) rotate(0);
        -ms-transform: translateX(0) rotate(0);
        transform: translateX(0) rotate(0)
    }
}

.rollIn {
    -webkit-animation-name: rollIn;
    animation-name: rollIn
}

@-webkit-keyframes rollOut {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0) rotate(0);
        transform: translateX(0) rotate(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(100%) rotate(120deg);
        transform: translateX(100%) rotate(120deg)
    }
}

@keyframes rollOut {
    0% {
        opacity: 1;
        -webkit-transform: translateX(0) rotate(0);
        -ms-transform: translateX(0) rotate(0);
        transform: translateX(0) rotate(0)
    }

    100% {
        opacity: 0;
        -webkit-transform: translateX(100%) rotate(120deg);
        -ms-transform: translateX(100%) rotate(120deg);
        transform: translateX(100%) rotate(120deg)
    }
}

.rollOut {
    -webkit-animation-name: rollOut;
    animation-name: rollOut
}

@-webkit-keyframes zoomIn {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.3, .3, .3);
        transform: scale3d(.3, .3, .3)
    }

    50% {
        opacity: 1
    }
}

@keyframes zoomIn {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.3, .3, .3);
        transform: scale3d(.3, .3, .3)
    }

    50% {
        opacity: 1
    }
}

.zoomIn {
    -webkit-animation-name: zoomIn;
    animation-name: zoomIn
}

@-webkit-keyframes zoomInDown {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

@keyframes zoomInDown {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

.zoomInDown {
    -webkit-animation-name: zoomInDown;
    animation-name: zoomInDown
}

@-webkit-keyframes zoomInLeft {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
        transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

@keyframes zoomInLeft {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
        transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

.zoomInLeft {
    -webkit-animation-name: zoomInLeft;
    animation-name: zoomInLeft
}

@-webkit-keyframes zoomInRight {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
        transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

@keyframes zoomInRight {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
        transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

.zoomInRight {
    -webkit-animation-name: zoomInRight;
    animation-name: zoomInRight
}

@-webkit-keyframes zoomInUp {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

@keyframes zoomInUp {
    from {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    60% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

.zoomInUp {
    -webkit-animation-name: zoomInUp;
    animation-name: zoomInUp
}

@-webkit-keyframes zoomOut {
    from {
        opacity: 1
    }

    50% {
        opacity: 0;
        -webkit-transform: scale3d(.3, .3, .3);
        transform: scale3d(.3, .3, .3)
    }

    to {
        opacity: 0
    }
}

@keyframes zoomOut {
    from {
        opacity: 1
    }

    50% {
        opacity: 0;
        -webkit-transform: scale3d(.3, .3, .3);
        transform: scale3d(.3, .3, .3)
    }

    to {
        opacity: 0
    }
}

.zoomOut {
    -webkit-animation-name: zoomOut;
    animation-name: zoomOut
}

@-webkit-keyframes zoomOutDown {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    to {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
        -webkit-transform-origin: center bottom;
        transform-origin: center bottom;
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

@keyframes zoomOutDown {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    to {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
        -webkit-transform-origin: center bottom;
        transform-origin: center bottom;
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

.zoomOutDown {
    -webkit-animation-name: zoomOutDown;
    animation-name: zoomOutDown
}

@-webkit-keyframes zoomOutLeft {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0)
    }

    to {
        opacity: 0;
        -webkit-transform: scale(.1) translate3d(-2000px, 0, 0);
        transform: scale(.1) translate3d(-2000px, 0, 0);
        -webkit-transform-origin: left center;
        transform-origin: left center
    }
}

@keyframes zoomOutLeft {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0)
    }

    to {
        opacity: 0;
        -webkit-transform: scale(.1) translate3d(-2000px, 0, 0);
        transform: scale(.1) translate3d(-2000px, 0, 0);
        -webkit-transform-origin: left center;
        transform-origin: left center
    }
}

.zoomOutLeft {
    -webkit-animation-name: zoomOutLeft;
    animation-name: zoomOutLeft
}

@-webkit-keyframes zoomOutRight {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0)
    }

    to {
        opacity: 0;
        -webkit-transform: scale(.1) translate3d(2000px, 0, 0);
        transform: scale(.1) translate3d(2000px, 0, 0);
        -webkit-transform-origin: right center;
        transform-origin: right center
    }
}

@keyframes zoomOutRight {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
        transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0)
    }

    to {
        opacity: 0;
        -webkit-transform: scale(.1) translate3d(2000px, 0, 0);
        transform: scale(.1) translate3d(2000px, 0, 0);
        -webkit-transform-origin: right center;
        transform-origin: right center
    }
}

.zoomOutRight {
    -webkit-animation-name: zoomOutRight;
    animation-name: zoomOutRight
}

@-webkit-keyframes zoomOutUp {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    to {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
        -webkit-transform-origin: center bottom;
        transform-origin: center bottom;
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

@keyframes zoomOutUp {
    40% {
        opacity: 1;
        -webkit-transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
        -webkit-animation-timing-function: cubic-bezier(.55, .055, .675, .19);
        animation-timing-function: cubic-bezier(.55, .055, .675, .19)
    }

    to {
        opacity: 0;
        -webkit-transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
        transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
        -webkit-transform-origin: center bottom;
        transform-origin: center bottom;
        -webkit-animation-timing-function: cubic-bezier(.175, .885, .32, 1);
        animation-timing-function: cubic-bezier(.175, .885, .32, 1)
    }
}

.zoomOutUp {
    -webkit-animation-name: zoomOutUp;
    animation-name: zoomOutUp
}

@font-face {
    font-family: "flaticon";
    src: url("../fonts/flaticon.ttf?98353b5e9709cae8aa6e7f88df8a78aa") format("truetype"),
        url("../fonts/flaticon.woff?98353b5e9709cae8aa6e7f88df8a78aa") format("woff"),
        url("../fonts/flaticon.woff2?98353b5e9709cae8aa6e7f88df8a78aa") format("woff2"),
        url("../fonts/flaticon.eot?98353b5e9709cae8aa6e7f88df8a78aa#iefix") format("embedded-opentype"),
        url("../fonts/flaticon.svg?98353b5e9709cae8aa6e7f88df8a78aa#flaticon") format("svg");
}

i[class^="flaticon-"]:before,
i[class*=" flaticon-"]:before {
    font-family: flaticon !important;
    font-style: normal;
    font-weight: normal !important;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.flaticon-splash:before {
    content: "\f101";
}

.flaticon-data-analysis:before {
    content: "\f102";
}

.flaticon-monitoring:before {
    content: "\f103";
}

.flaticon-fast-delivery:before {
    content: "\f104";
}

.flaticon-increasing:before {
    content: "\f105";
}

.flaticon-layers:before {
    content: "\f106";
}

.flaticon-development:before {
    content: "\f107";
}

.flaticon-quote:before {
    content: "\f108";
}

.flaticon-market:before {
    content: "\f109";
}

.flaticon-pie-chart:before {
    content: "\f10a";
}

.flaticon-quote-1:before {
    content: "\f10b";
}

.flaticon-software:before {
    content: "\f10c";
}

.flaticon-trophy:before {
    content: "\f10d";
}

.flaticon-group:before {
    content: "\f10e";
}

.flaticon-play-button:before {
    content: "\f10f";
}

.flaticon-sharing:before {
    content: "\f110";
}

.flaticon-edit:before {
    content: "\f111";
}

.flaticon-chat:before {
    content: "\f112";
}

.flaticon-file:before {
    content: "\f113";
}

.flaticon-responsive-design:before {
    content: "\f114";
}

.flaticon-security:before {
    content: "\f115";
}

.flaticon-puzzle:before {
    content: "\f116";
}

.flaticon-badge:before {
    content: "\f117";
}

.flaticon-analytics:before {
    content: "\f118";
}

.flaticon-quotation:before {
    content: "\f119";
}

/****************************************************** */
/******************  Main Header style **************** */
/****************************************************** */
.main-header {
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 999;
    width: 100%;
    -webkit-transition: all 500ms ease;
    transition: all 500ms ease;
}

.header-top p {
    font-size: 18px;
    margin-bottom: 0;
    font-weight: 500;
}

.header-left-shape {
    position: absolute;
    left: 15%;
    top: 0;
    z-index: -1;
    max-width: 5%;
}

.header-right-shape {
    position: absolute;
    right: 15%;
    top: 10px;
    z-index: -1;
    max-width: 5%;
}

.main-header .header-upper {
    position: relative;
    z-index: 5;
    width: 100%;
    left: 0;
    top: 0;
    -webkit-transition: all 500ms ease;
    transition: all 500ms ease;
}

.fixed-header .header-upper {
    top: 0;
    position: fixed;
    background: white;
    animation: sticky 1s;
    -webkit-animation: sticky 1s;
    box-shadow: 0px 0px 30px 0px rgb(87 95 245 / 10%);
    -webkit-box-shadow: 0px 0px 30px 0px rgb(87 95 245 / 10%);
    transition: background-color 0.3s ease, padding 0.3s ease;
}

.dark-body .fixed-header .header-upper {
    background: #141B2D;
    box-shadow: 0px 0px 30px 0px rgba(255, 255, 255, 0.05);
}

.fixed-header .header-inner {
    border-bottom: none;
    padding-top: 10px;
    padding-bottom: 10px;
}

.header-inner {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--border-color)
}

.main-header .logo {
    position: relative;
    z-index: 9;
}

/** Header Main Menu */
.main-menu .navbar-collapse {
    padding: 0px;
    margin-left: 40px;
}

.main-menu .navigation>li {
    float: left;
    display: flex;
    align-items: center;
    padding-top: 15px;
    padding-bottom: 15px;
}

.main-menu .navigation li.dropdown .dropdown-btn {
    margin-left: 7px;
}

.main-menu .navigation li a {
    position: relative;
    display: block;
    font-size: 18px;
    opacity: 1;
    font-weight: 600;
    text-transform: capitalize;
    transition: all 500ms ease;
}

.main-menu .navigation>li>a {
    margin-left: 30px;
}

.main-menu .navigation>li>a:after {
    position: absolute;
    content: '';
    height: 1px;
    top: 100%;
    left: 0;
    width: 0;
    transition: 0.5s;
    background: var(--primary-color);
}

.main-menu .navigation>li.current>a:after,
.main-menu .navigation>li:hover>a:after {
    width: 100%;
}

.main-menu .navigation li .megamenu {
    position: absolute;
    left: 0px;
    top: 100%;
    width: 100%;
    z-index: 100;
    display: none;
    padding: 20px 0;
    background: #ffffff;
    -webkit-box-shadow: 2px 2px 5px 1px rgba(0, 0, 0, 0.05), -2px 0px 5px 1px rgba(0, 0, 0, 0.05);
    box-shadow: 2px 2px 5px 1px rgba(0, 0, 0, 0.05), -2px 0px 5px 1px rgba(0, 0, 0, 0.05);
}

.main-menu .navigation li .megamenu:after {
    display: block;
    clear: both;
    content: "";
}

.main-menu .navigation li .megamenu ul {
    display: block;
    position: relative;
    top: 0;
    width: 100%;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.main-menu .navigation li ul {
    position: absolute;
    left: 0;
    top: 100%;
    min-width: 200px;
    z-index: 100;
    display: none;
    border-radius: 5px;
    background: #ffffff;
    -webkit-box-shadow: 2px 2px 5px 1px rgba(0, 0, 0, 0.05), -2px 0px 5px 1px rgba(0, 0, 0, 0.05);
    box-shadow: 2px 2px 5px 1px rgba(0, 0, 0, 0.05), -2px 0px 5px 1px rgba(0, 0, 0, 0.05);
}

.main-menu .navigation li ul li {
    width: 100%;
    padding: 5px 20px;
    border-bottom: 1px solid #f2f2f2;
}

.main-menu .navigation li ul li:last-child {
    border-bottom: none;
}

.main-menu .navigation li ul li a {
    padding: 5px 0px;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-transform: capitalize;
}

.main-menu .navigation li ul li ul {
    left: 100%;
    top: 0%;
}

.main-menu .navbar-header {
    display: none;
}

.main-menu .navbar-header .navbar-toggle {
    cursor: pointer;
    background: transparent;
}

.main-menu .navbar-header .navbar-toggle .icon-bar {
    width: 30px;
    margin: 6px 0;
}

.icon-bar {
    height: 3px;
    width: 23px;
    display: block;
    margin: 4px auto;
    border-radius: 2px;
    background: var(--primary-color);
}

.menu-right .nice-select {
    border: none;
    font-size: 18px;
    font-weight: 600;
    margin-left: 30px;
    margin-right: 30px;
    padding: 0 25px 0 10px;
}

.menu-right .nice-select:hover {
    background: transparent;
    border: none;
}

.menu-right .nice-select:after {
    height: 8px;
    width: 8px;
    margin-top: -7px;
    border-width: 1px;
    border-color: black;
}

.menu-right .theme-btn {
    padding-top: 8px;
    padding-bottom: 8px;
}

/*Nav Search*/
.nav-search {
    line-height: 1;
    position: relative;
    padding-right: 30px;
    border-right: 2px solid var(--border-color);
}

.nav-search button {
    background: transparent;
}

.nav-search form {
    position: absolute;
    width: 320px;
    top: 30px;
    right: 0;
    z-index: 777;
    background-color: #fff;
    border: 1px solid var(--border-color);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
}

.nav-search form input {
    border: none;
    height: 66px;
}

.nav-search form.hide {
    display: none;
}

.nav-search form button {
    position: absolute;
    width: 50px;
    right: 0;
    top: 0;
    height: 100%;
    color: #6e6e6e;
    cursor: pointer;
    background: #fff;
    border-left: 1px solid #dedede;
}

/* Header Two */
.header-two .container {
    max-width: 1720px;
}

.header-two .nav-search,
.header-two .header-inner {
    border-color: #4b84fa;
}

.header-two.fixed-header .header-upper {
    background: var(--primary-color);
    box-shadow: 0px 0px 30px 0px rgb(0, 0, 0, 0.1);
}

.header-two .main-menu .navbar-collapse {
    margin-left: 0;
}

.header-two .navigation>li:first-child>a {
    margin-left: 0;
}

.header-two .navigation>li>a,
.header-two .navigation>li>.dropdown-btn {
    color: white;
}

.header-two .navigation>li>a:after {
    background: white;
}

.header-two .nav-search>button,
.header-two .nice-select .current {
    color: white;
}

.header-two .nice-select:after {
    border-color: white;
}

.header-three .container {
    max-width: 1880px;
}

.header-three .main-menu .navbar-collapse {
    margin-right: 40px;
}

.header-three .nav-search {
    border: none;
}

.header-three .nav-search button {
    padding: 5px;
}

.header-three .menu-right .login {
    margin-right: 30px;
    font-weight: 600;
    font-size: 18px;
}

.header-three .menu-right .login i {
    margin-left: 5px;
    font-size: 14px;
}

/* Mobile Menu */
@media only screen and (max-width: 991px) {
    .logo-outer {
        display: none;
    }

    .header-inner {
        display: block;
    }

    .main-menu {
        width: 100%;
    }

    .main-menu .navbar-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .main-menu .navigation {
        overflow: auto;
        max-height: 330px;
        padding-top: 25px;
        background: white;
    }

    .main-menu .navbar-collapse {
        background: white;
    }

    .main-menu .navigation li {
        float: none;
        display: block;
        padding: 3px 0;
        border-top: 1px solid #f3f3f3;
    }

    .main-menu .navigation>li:last-child {
        border-bottom: 1px solid #f3f3f3;
    }

    .main-menu .navigation li.dropdown .dropdown-btn {
        position: absolute;
        right: 10px;
        top: 0;
        width: 50px;
        height: 38px;
        cursor: pointer;
        line-height: 40px;
        text-align: center;
        border-left: 1px solid #f3f3f3;
    }

    .main-menu .navigation li a {
        padding: 5px 20px;
        line-height: 22px;
        width: 100%;
        margin: 0;
        font-size: 15px;
        letter-spacing: 1px;
        border-width: 4px 0 4px;
        text-transform: capitalize;
    }

    .main-menu .navigation li .megamenu {
        position: relative;
        -webkit-box-shadow: none;
        box-shadow: none;
        width: 100%;
    }

    .main-menu .navigation li .megamenu .container {
        max-width: 100%;
    }

    .main-menu .navigation li .megamenu .row {
        margin: 0px;
    }

    .main-menu .navigation li ul {
        position: relative;
        display: none;
        width: 100%;
        -webkit-box-shadow: none;
        box-shadow: none;
        background: transparent;
    }

    .main-menu .navigation li ul:after {
        display: block;
        clear: both;
        content: "";
    }

    .main-menu .navigation li ul li {
        padding: 0 20px;
        border-bottom: none;
    }

    .main-menu .navigation li ul li a {
        padding: 8px 10px;
        line-height: 22px;
    }

    .main-menu .navigation li.dropdown li.dropdown .dropdown-btn {
        right: 20px;
    }

    .main-menu .navigation li ul li ul {
        left: auto;
    }

    .main-menu .navigation li a:after,
    .main-menu .navigation li a:before {
        display: none;
    }

    .header-two .header-upper {
        background: var(--primary-color);
        box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.1);
    }

    .header-two .header-inner,
    .header-two .main-menu .navigation,
    .header-two .main-menu .navbar-collapse {
        background: transparent;
    }

    .header-two .icon-bar {
        background: white;
    }

    .header-two .main-menu .navigation li,
    .header-two .main-menu .navigation li.dropdown .dropdown-btn {
        border-color: #f3f3f333;
    }

    .header-two .main-menu .navigation li ul li a {
        color: white;
    }

    .main-header.header-three {
        background: white;
    }

}

@charset "UTF-8";
/*-----------------------------------------------------------------------------------
    Template Name: Sland - softare landing HTML Template
    Author: wordpressriver

    Version: 1.0

    Note: This is Main Style CSS File.
-----------------------------------------------------------------------------------
	CSS INDEX
	===================
    01. Default CSS
    02. Common Class
    03. Hero Section
    04. Page Banner
    05. Partner Section
    06. Solutions
    07. About Section
    08. Counter Section
    09. Features Section
    10. Service Section
    11. Newsletter Area
    12. Feedback Area (Kept for layout)
    13. Dashboard Screenshot
    14. Footer Area
    15. Custom Animations
    16. Dark Version
-----------------------------------------------------------------------------------*/

/****************************************************** */
/******************** 01. Default CSS ***************** */
/****************************************************** */
* {
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}

:root {
    scroll-behavior: auto;
    --base-color: #5b5675;
    --heading-color: #141125;
    --primary-color: #5138ee;
    --light-color: #f8f7fc;
    --yellow-color: #ffc800;
    --border-color: #edebfd;
    --base-font: 'Inter', sans-serif;
    --heading-font: 'Poppins', sans-serif;
}

.home-two {
    --primary-color: #017EFF;
}

.home-two .sub-title {
    background: #edf6ff;
}

.home-two .text-white .sub-title {
    background: #2187fe;
}

.home-two .section-title h2 span {
    background-image: url(../images/shapes/section-title-circle-yellow.png);
}

body {
    color: var(--base-color);
    font-size: 16px;
    font-weight: 400;
    line-height: 33px;
    font-family: var(--base-font);
}

html {
    overflow-x: hidden;
    overflow-y: auto;
    height: 100%;
}

body {
    overflow-x: hidden;
    overflow-y: visible;
    min-height: 100%;
    position: relative;
    width: 100%;
}

a {
    color: var(--base-color);
    cursor: pointer;
    outline: none;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    text-decoration: none;
}

a:focus,
a:visited {
    text-decoration: none;
    outline: none;
}

a:hover {
    text-decoration: none;
    color: var(--primary-color);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 600;
    font-family: var(--heading-font);
}

h1,
h2,
h3,
h4,
h5,
h6,
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    color: var(--heading-color);
}

.text-white h1,
.text-white h2,
.text-white h3,
.text-white h4,
.text-white h5,
.text-white h6,
.text-white h1 a,
.text-white h2 a,
.text-white h3 a,
.text-white h4 a,
.text-white h5 a,
.text-white h6 a,
.text-white.section-title h2 span {
    color: #ffffff;
}

h1 {
    font-size: 65px;
}

h2 {
    font-size: 42px;
    line-height: 1.25;
}

h3 {
    font-size: 24px;
}

h4 {
    font-size: 20px;
    line-height: 1.6;
}

h5 {
    font-size: 18px;
}

h6 {
    font-size: 16px;
}

ul,
li {
    list-style: none;
    padding: 0;
    margin: 0;
}

img {
    max-width: 100%;
    display: inline-block;
}

.logo img,
.footer-logo img,
.main-header .logo img,
.logo-mobile img {
    max-height: 50px !important;
    width: auto !important;
    max-width: 200px;
}

header:after,
section:after,
footer:after {
    display: block;
    clear: both;
    content: "";
}

/*======= Input Styles =======*/
input,
textarea,
select {
    width: 100%;
    height: 60px;
    padding: 0 25px;
    font-size: 16px;
    background-color: #fff;
    border: 1px solid #e1e1e1;
}

textarea {
    height: 170px;
    display: inherit;
    padding-top: 20px;
}

button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus {
    outline: none;
}

::-webkit-input-placeholder {
    opacity: 1;
}

::-moz-placeholder {
    opacity: 1;
}

:-ms-input-placeholder {
    opacity: 1;
}

::-ms-input-placeholder {
    opacity: 1;
}

::placeholder {
    opacity: 1;
}

input[type=search]::-ms-clear {
    display: none;
    width: 0;
    height: 0;
}

input[type=search]::-ms-reveal {
    display: none;
    width: 0;
    height: 0;
}

input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
    display: none;
}

input[type=checkbox],
input[type=radio] {
    height: auto;
    width: auto;
}

/****************************************************** */
/****************** 02. Common Class ****************** */
/****************************************************** */
.page-wrapper {
    position: relative;
    margin: 0 auto;
    width: 100%;
    min-width: 300px;
}

/** Section Title */
.section-title h2 span {
    padding: 10px 10px 0 15px;
    color: var(--primary-color);
    background: url(../images/shapes/section-title-circle.png) no-repeat center/ 100% 100%;
}

/****************************************************** */
/************ 13. Dashboard Screenshot Area *********** */
/****************************************************** */
.dashboard-screenshot-wrap {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 30px;
    padding-bottom: 30px;
    /* Hide scrollbar */
    scrollbar-width: none;
    /* Firefox */
    -ms-overflow-style: none;
    /* IE/Edge */
}

.dashboard-screenshot-wrap::-webkit-scrollbar {
    display: none;
    /* Chrome/Safari/Opera */
}

.dashboard-screenshot-item {
    flex: 0 0 auto;
    width: 70%;
    /* Show part of next slide */
    max-width: 800px;
    scroll-snap-align: center;
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
}

.dashboard-screenshot-item img {
    border-radius: 10px;
    width: 100%;
}

/* Center initial view if needed, or JS will handle auto-scroll */
@media (max-width: 768px) {
    .dashboard-screenshot-item {
        width: 85%;
    }
}

.text-white .sub-title {
    color: white;
    background: #5d46ef;
}

/** Button styles */
.theme-btn,
a.theme-btn {
    z-index: 1;
    cursor: pointer;
    font-weight: 700;
    transition: 0.5s;
    position: relative;
    text-align: center;
    padding: 11px 30px;
    border-radius: 5px;
    align-items: center;
    display: inline-flex;
    justify-content: center;
    text-transform: capitalize;
}

.theme-btn,
a.theme-btn,
.theme-btn.style-two:hover,
a.theme-btn.style-two:hover {
    color: white;
    background: var(--primary-color);
}

.theme-btn:hover,
a.theme-btn:hover,
.theme-btn.style-two,
a.theme-btn.style-two {
    background: #f3f1fe;
    color: var(--primary-color);
}

.theme-btn i,
a.theme-btn i {
    font-size: 12px;
    margin-left: 10px;
}

.theme-btn.style-three,
a.theme-btn.style-three {
    background: white;
    color: var(--primary-color);
    border: 2px solid var(--primary-color);
}

.theme-btn.style-three:hover,
a.theme-btn.style-three:hover {
    color: white;
    background: var(--primary-color);
}

.theme-btn.style-four,
a.theme-btn.style-four {
    color: var(--heading-color);
    background: var(--yellow-color);
    border: 1px solid var(--yellow-color);
}

.theme-btn.style-four:hover,
a.theme-btn.style-four:hover {
    color: white;
    border-color: white;
    background: transparent;
}

.theme-btn.style-five,
a.theme-btn.style-five {
    border: 1px solid white;
}

.theme-btn.style-five:hover,
a.theme-btn.style-five:hover {
    color: var(--heading-color);
    background: var(--yellow-color);
    border-color: var(--yellow-color);
}

/* Learn More Btn */
.learn-more {
    padding: 10px;
    display: block;
    font-weight: 700;
    text-align: center;
    color: var(--primary-color);
}

.learn-more:hover {
    color: white;
    background: var(--primary-color);
}

.learn-more i {
    font-size: 14px;
    margin-left: 5px;
}

/* Read More Btn */
.read-more {
    font-weight: 700;
    display: inline-block;
    color: var(--primary-color);
}

.read-more:hover {
    text-decoration: underline;
}

.read-more i {
    font-size: 13px;
    margin-left: 5px;
}

/*social link style One */
.social-style-one {
    display: flex;
}

.social-style-one a {
    height: 40px;
    width: 40px;
    line-height: 40px;
    border-radius: 50%;
    text-align: center;
    margin: 0 10px 5px 0;
    background: #e7e4fb;
    color: var(--primary-color);
}

.social-style-one a:last-child {
    margin-right: 0;
}

.social-style-one a:hover {
    color: white;
    background: var(--primary-color);
}

/* List Style one */
.list-style-one li {
    font-weight: 600;
    font-size: 18px;
    display: flex;
}

.list-style-one li:before {
    content: "\f00c";
    font-size: 12px;
    height: 25px;
    width: 25px;
    flex: none;
    line-height: 25px;
    border-radius: 50%;
    text-align: center;
    background: #f3f1fe;
    margin: 5px 12px 0 0;
    color: var(--primary-color);
    font-family: 'Font Awesome 5 Free'
}

.list-style-one li:not(:last-child) {
    margin-bottom: 15px;
}

/* List Style Two */
.list-style-two {
    display: flex;
    flex-wrap: wrap;
}

.list-style-two li {
    width: 100%;
    margin-bottom: 5px;
}

.list-style-two.two-column li {
    width: 50%;
}

.list-style-two a {
    position: relative;
}

.list-style-two a:before {
    content: "\f061";
    font-weight: 600;
    font-size: 14px;
    left: 0;
    opacity: 0;
    transition: 0.5s;
    position: absolute;
    font-family: "Font Awesome 5 Free";
}

.list-style-two a:hover {
    padding-left: 20px;
    font-weight: 500;
    text-decoration: underline;
}

.list-style-two a:hover:before {
    opacity: 1;
}

/* List Style Three */
.list-style-three li {
    font-weight: 600;
    margin-bottom: 6px;
}

.list-style-three li i {
    color: var(--primary-color);
    margin-right: 10px;
    font-size: 18px;
    width: 22px;
}

.list-style-three a:hover {
    text-decoration: underline;
}


/*** Preloader style ** */
/*** Preloader style ** */
.preloader {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 9999999;
    background-color: #FFFFFF;
    display: flex;
    justify-content: center;
    align-items: center;
}

.preloader .loader-content {
    position: relative;
    width: 100px;
    height: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.preloader img {
    max-width: 60px !important;
    animation: pulse 2s infinite;
}

.preloader .loader-content::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 2px solid transparent;
    border-top-color: var(--primary-color);
    border-bottom-color: var(--primary-color);
    animation: spin 1.5s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

@keyframes pulse {
    0% {
        transform: scale(0.95);
        opacity: 0.8;
    }

    50% {
        transform: scale(1);
        opacity: 1;
    }

    100% {
        transform: scale(0.95);
        opacity: 0.8;
    }
}

/*** Scroll Top style ** */
.scroll-top {
    width: 50px;
    height: 50px;
    position: fixed;
    bottom: 25px;
    right: 25px;
    z-index: 99;
    display: none;
    cursor: pointer;
    border-radius: 50%;
    color: white;
    font-size: 18px;
    border: 1px solid #ffffff33;
    background: var(--primary-color);
    -webkit-animation: pulse 2s infinite;
    animation: pulse 2s infinite;
}

/* text inputs and testarea */
.form-group {
    margin-bottom: 25px;
}

.form-group label {
    cursor: pointer;
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 11px;
    text-transform: capitalize;
    color: var(--heading-color);
    font-family: var(--heading-font);
}

.nice-select,
.form-group input,
.form-group textarea,
.input-group input,
.input-group textarea {
    float: none;
    height: auto;
    border-radius: 5px;
    padding: 15px 25px;
    background: transparent;
    border: 1px solid #eff0f0;
}

.nice-select:focus {
    border-color: #eff0f0;
}

.nice-select:hover,
.form-group input:focus,
.form-group textarea:focus,
.input-group input:focus,
.input-group textarea:focus {
    box-shadow: none;
    background: #f8f7fc;
    border-color: #f8f7fc;
}

.form-group select,
.input-group select {
    font-size: 18px;
    border-radius: 5px;
    background: transparent;
    border: 1px solid #21282f;
}

.before-none:before {
    display: none;
}

.after-none:after {
    display: none;
}

/* overlay */
.overlay {
    position: relative;
}

.overlay:before {
    position: absolute;
    content: '';
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    opacity: 0.75;
    background: var(--light-color);
}

.overlay * {
    z-index: 2;
    position: relative;
}

.rel {
    position: relative;
}

.abs {
    position: absolute;
}

.z-0 {
    z-index: 0;
}

.z--1 {
    z-index: -1;
}

.z-1 {
    z-index: 1;
}

.z-2 {
    z-index: 2;
}

.z-3 {
    z-index: 3;
}

.z-4 {
    z-index: 4;
}

.z-5 {
    z-index: 5;
}

/* Colors + Backgrounds */
.bg-lighter {
    background: var(--light-color);
}

.bg-blue {
    background: var(--primary-color);
}

.bg-gray {
    background: #222b40;
}

.bgs-cover {
    background-size: cover;
    background-position: center;
}

.br-5 {
    border-radius: 5px;
}

.br-10 {
    border-radius: 10px;
}

.row.no-gap {
    margin-left: 0;
    margin-right: 0;
}

.row.no-gap>div {
    padding-left: 0;
    padding-right: 0;
}

/* Shapes */
.dots-shape {
    z-index: -1;
    left: 6%;
    top: 30%;
    position: absolute;
    animation: slideUpDown 20s infinite linear;
}

.tringle-shape {
    z-index: -1;
    left: 3%;
    bottom: 30%;
    position: absolute;
    animation: shapeAnimationOne 20s infinite linear;
}

.close-shape {
    z-index: -1;
    left: 50%;
    top: 25%;
    position: absolute;
    animation: shapeAnimationThree 20s infinite linear;
}

.circle-shape {
    z-index: -1;
    right: 8%;
    bottom: 0;
    position: absolute;
    animation: shapeAnimationTwo 20s infinite linear;
}

.bg-yellow-shape {
    width: 120vw;
    height: 250px;
    top: 20%;
    z-index: 2;
    left: -10vw;
    position: absolute;
    transform: rotate(5deg);
    background: var(--yellow-color);
}

/****************************************************** */
/***************** 03. Hero Section  ****************** */
/****************************************************** */
.hero-content p,
.hero-content-three p,
.hero-content .sub-title {
    font-size: 18px;
}

.hero-content p,
.hero-content-three p {
    max-width: 525px;
}

.hero-btns .theme-btn:first-child {
    margin-right: 15px;
}

/*Hero Home Two*/
.hero-content-two p {
    font-size: 18px;
    max-width: 850px;
    margin-left: auto;
    margin-right: auto;
}

.section-alpha-text {
    color: white;
    opacity: 0.05;
    line-height: 0;
    font-size: 280px;
    font-weight: 700;
    text-align: center;
    font-family: var(--heading-font);
}

.hero-section-two .close-shape {
    left: 80%;
}

.hero-section-two .tringle-shape {
    bottom: 40%;
}

.hero-section-two .left-circles {
    opacity: 0.25;
    height: 365px;
    width: 365px;
    left: -250px;
    top: 200px;
}

.hero-section-two .left-circles:after {
    height: 100%;
    width: 100%;
}

.hero-section-two .right-circles {
    opacity: 0.25;
    right: -200px;
    top: 150px;
}

/* Hero Three */
.hero-section-three:before {
    content: '';
    left: 0;
    top: 0;
    width: 480px;
    height: 480px;
    border-radius: 50%;
    text-align: center;
    position: absolute;
    filter: blur(250px);
    background: #ee9a38;
    transform: translate(-50%, -60%);
}

.hero-content-three .newsletter-email {
    max-width: 585px;
}

.hero-content-three .newsletter-email input {
    border-color: var(--primary-color);
    background-color: transparent;
}

.hero-content-three .newsletter-email button {
    background: var(--primary-color);
}

.hero-content-three .newsletter-email button i {
    font-size: 13px;
}

.hero-content-three .newsletter-radios .custom-control-input:checked~label::before,
.newsletter-inner.style-two .newsletter-radios .custom-control-input:checked~label::before {
    box-shadow: none;
    background: var(--primary-color);
    border-color: var(--primary-color);
}

.hero-content-three .newsletter-radios .custom-control-input:checked~.custom-control-label::after,
.newsletter-inner.style-two .newsletter-radios .custom-control-input:checked~.custom-control-label::after {
    color: white;
}

.hero-image-three:before {
    opacity: 0.22;
    left: 10%;
    top: 10%;
    filter: blur(100px);
    background: var(--primary-color);
}

/****************************************************** */
/***************** 04. Page Banner  ******************* */
/****************************************************** */
.page-banner {
    height: 350px;
    display: flex;
    align-items: center;
}

.page-title {
    color: white;
    font-size: 55px;
    margin-bottom: 10px;
    text-transform: capitalize;
}

.breadcrumb {
    padding: 0;
    margin-bottom: 5px;
    background: transparent;
}

.breadcrumb-item a,
.breadcrumb-item.active {
    font-weight: 500;
    font-size: 22px;
    color: white;
    text-transform: capitalize;
}

.breadcrumb-item.active {
    text-decoration: underline;
}

.breadcrumb-item+.breadcrumb-item::before {
    content: "\f105";
    margin: 0 10px;
    color: white;
    float: left;
    font-weight: 600;
    font-family: "Font Awesome 5 Free"
}

.page-banner .banner-circle {
    position: absolute;
    top: 15%;
    right: 15%;
    z-index: -1;
    max-width: 22%;
}

.page-banner .dots-shape-three {
    position: absolute;
    bottom: 20%;
    right: 40%;
    z-index: -1;
    max-width: 22%;
}

/****************************************************** */
/*************** 05. Partner Section  ***************** */
/****************************************************** */
.partner-item {
    margin-bottom: 40px;
    display: inline-block;
    filter: grayscale(1) opacity(0.4);
}

.partner-item:hover {
    filter: grayscale(0) opacity(1);
}

.hero-about-bg {
    z-index: -1;
    left: 0;
    top: -555px;
    width: 100%;
    position: absolute;
}

.partner-dashboard {
    margin-top: -400px;
    position: relative;
    z-index: 3;
}

.partner-dashboard img {
    width: 100%;
}

.partner-two-wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

/*Partner Three*/
.partner-item-three {
    display: inline-block;
    margin-bottom: 50px;
}

/****************************************************** */
/************** 06. Solutions Section  **************** */
/****************************************************** */
.solution-item {
    transition: 0.5s;
    background: white;
    text-align: center;
    border-radius: 5px;
    margin-bottom: 30px;
    border: 1px solid var(--border-color);
}

.solution-item:hover {
    border-color: white;
    box-shadow: 10px 0 60px rgba(81, 56, 238, 0.1);
}

.solution-content {
    padding: 35px 30px 10px;
    border-bottom: 1px solid var(--border-color);
}

.solution-content i {
    z-index: 1;
    font-size: 65px;
    position: relative;
    margin-bottom: 25px;
    display: inline-block;
    color: var(--primary-color);
}

.solution-content i:after {
    content: '';
    height: 75px;
    width: 75px;
    top: -15px;
    left: -25px;
    z-index: -1;
    position: absolute;
    background: #f3f1fe;
    border-radius: 50%;
}

.solutions-section .close-shape {
    top: 0;
    left: 75%;
}

/* Solution Two */
.solution-item-two {
    position: relative;
    padding: 45px 0 30px 45px;
}

.solution-item-two .number {
    font-size: 200px;
    font-weight: 600;
    opacity: 0.03;
    left: 0;
    top: 0;
    line-height: 1;
    position: absolute;
    color: var(--heading-color);
    font-family: var(--heading-font);
}

.solution-item-two>i {
    height: 30px;
    width: 30px;
    color: white;
    font-size: 14px;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    margin-bottom: 25px;
    display: inline-block;
    background: var(--primary-color);
}

.solution-item-two h4 {
    margin-bottom: 15px;
    font-size: 22px;
}

.solution-item-two.color-two>i {
    background: var(--yellow-color);
}

.solution-item-two.color-three>i {
    background: #ff6101;
}

.solution-item-two.color-four>i {
    background: #f001ff;
}

/* Solutions Three */
.solutions-section-three {
    background-position: center;
    background-repeat: no-repeat;
}

.solution-item-three {
    padding: 0 50px;
    margin-bottom: 50px;
}

.solution-item-three>i {
    height: 85px;
    width: 85px;
    z-index: 1;
    font-size: 38px;
    line-height: 85px;
    background: white;
    position: relative;
    border-radius: 7px;
    margin-bottom: 44px;
    display: inline-block;
    color: var(--primary-color);
}

.solution-item-three>i:after {
    content: '';
    height: 100%;
    width: 100%;
    left: 10px;
    top: 10px;
    z-index: -1;
    opacity: 0.15;
    position: absolute;
    border-radius: 7px;
    border: 1px solid var(--border-color);
}

.solution-item-three h3 {
    font-size: 27px;
    margin-bottom: 15px;
}

.solution-item-three>a {
    color: white;
    text-decoration: underline;
}

/****************************************************** */
/****************** 07. About Section ***************** */
/****************************************************** */
.about-content-three .list-style-one {
    flex-wrap: wrap;
    display: flex;
}

.about-content-three .list-style-one li {
    font-family: var(--heading-font);
    color: var(--heading-color);
    font-size: 22px;
}

.about-content-three .list-style-one li:first-child {
    width: 55%;
}

.about-content-three .list-style-one li:before {
    height: 30px;
    width: 30px;
    color: white;
    margin-top: 2px;
    line-height: 30px;
    background: var(--primary-color);
}

/* browswr-support-content */
.browswr-support-content .solution-item-two {
    padding: 0;
    margin-top: 25px;
}

.browswr-support-content .solution-item-two p {
    margin-bottom: 0;
}

/* About Page */
.about-page-images {
    display: flex;
    align-items: center;
}

.about-page-images img:first-child {
    margin-right: 30px;
    max-width: 60%;
}

.about-page-images img:last-child {
    border-radius: 100px 100px 0 100px;
    width: 33%;
}

.solutions-section-three .number {
    left: -10px;
}

/****************************************************** */
/***************** 08. Counter Section **************** */
/****************************************************** */
.counter-section {
    transform: translateY(85px);
}

.counter-inner {
    border-radius: 7px;
    padding: 50px 65px 15px;
}

.success-item {
    display: flex;
    padding-top: 40px;
    position: relative;
    align-items: center;
    margin-bottom: 40px;
}

.success-item:before {
    content: '';
    height: 20px;
    width: 20px;
    left: -7.5px;
    top: 0;
    transition: 0.5s;
    border-radius: 50%;
    position: absolute;
    transform: scale(0);
    border: 1px solid white;
}

.success-item:hover:before {
    transform: scale(1);
}

.success-item:after {
    content: '';
    height: 5px;
    width: 5px;
    left: 0;
    top: 8px;
    background: white;
    border-radius: 50%;
    position: absolute;
}

.count-text {
    font-size: 42px;
    font-weight: 600;
    margin-right: 15px;
    font-family: var(--heading-font);
}

.count-text:after {
    content: '+';
}

.success-item p {
    font-size: 18px;
    margin-bottom: 0;
    font-weight: 500;
}

.white-circle {
    bottom: 10%;
    left: 65%;
    z-index: -1;
    position: absolute;
    animation: slideLeftRight 5s infinite linear;
}

/* Counter Two */
.counter-inner-two {
    overflow: hidden;
    border-radius: 7px;
}

.success-item.style-two {
    display: block;
    margin-bottom: 0;
    padding: 75px 75px 70px;
    border-right: 1px solid #2791ff;
}

.success-item.style-two:before {
    display: none;
}

.success-item.style-two i {
    margin-bottom: 30px;
    font-size: 55px;
    display: block;
}

.success-item.style-two:after {
    height: 90px;
    width: 90px;
    z-index: -1;
    top: 45px;
    left: 45px;
    background: #1b8bff;
}

/****************************************************** */
/**************** 09. Features Section **************** */
/****************************************************** */
.feature-item {
    display: flex;
    margin-bottom: 10px;
}

.feature-item>i {
    height: 60px;
    width: 60px;
    flex: none;
    font-size: 35px;
    transition: 0.5s;
    line-height: 66px;
    text-align: center;
    margin-right: 25px;
    border-radius: 7px;
    background: #e7e4fb;
    color: var(--primary-color);
}

.feature-item:hover>i {
    color: white;
    background: var(--primary-color);
}

/* Feature Right Images */
.feature-images {
    z-index: 1;
    max-width: 600px;
    margin-left: auto;
    position: relative;
}

.feature-images img {
    position: relative;
    border-radius: 10px;
    box-shadow: 10px 0 60px rgba(81, 56, 238, 0.1);
}

.feature-images .first {
    width: 48%;
}

.feature-images .second {
    margin-left: -7%;
    margin-top: -8%;
    width: 55%;
}

.feature-images .third {
    margin-left: 22%;
    margin-top: -14%;
    width: 36%;
}

.feature-images .fourth {
    position: relative;
    margin-left: -3%;
    margin-top: -30%;
    width: 43%;
}

.feature-images .circle-line {
    position: absolute;
    border-radius: 50%;
    box-shadow: none;
    right: -8%;
    width: 28%;
    top: 33%;
}

.features-section .circle-shape {
    bottom: 10%;
}

.features-section .close-shape {
    left: 90%;
}

/****************************************************** */
/***************** 10. Service Section **************** */
/****************************************************** */
.services-tab .nav {
    background: var(--light-color);
}

.services-tab .nav .nav-link {
    font-size: 20px;
    font-weight: 600;
    border-radius: 0;
    padding-top: 16px;
    padding-bottom: 16px;
    color: var(--heading-color);
    font-family: var(--heading-font);
    border-top: 2px solid transparent;
}

.services-tab .nav .nav-link.active {
    background: transparent;
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.services-tab .tab-content {
    max-width: 1260px;
    margin-left: auto;
    margin-right: auto;
}

.service-content {
    max-width: 428px;
}

.service-content h3 {
    font-size: 27px;
    line-height: 1.45;
    margin-bottom: 15px;
}

.services-image img {
    width: 100%;
}

.dots-circle-half {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    max-width: 20%;
}

/* Services Solutions */
.solutions-tab-nav {
    height: 100%;
}

.solutions-tab-nav .nav-item {
    margin-bottom: 20px;
}

.solutions-tab-nav .nav-link {
    display: flex;
    height: 100%;
    text-align: left;
    padding: 25px 35px;
    border-radius: 7px;
    align-items: center;
    border: 1px solid var(--border-color);
}

.solutions-tab-nav .nav-link>i {
    margin-right: 20px;
    font-size: 60px;
    flex: none;
}

.solutions-tab-nav .nav-link h3 {
    letter-spacing: -0.5px;
}

.solutions-tab-nav .nav-link p {
    margin-bottom: 0;
}

.solutions-tab-nav .nav-link:hover,
.solutions-tab-nav .nav-link.active {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: transparent;
}

/* Services Style Three */
.service-item {
    display: flex;
    background: white;
    position: relative;
    border-radius: 7px;
    margin-bottom: 30px;
    padding: 50px 45px 25px;
}

.service-item:after {
    content: '';
    height: 50px;
    width: 100%;
    left: 0;
    bottom: 0;
    opacity: 0;
    z-index: -1;
    transition: 0.25s;
    border-radius: 7px;
    position: absolute;
    background: var(--primary-color);
}

.service-item:hover:after {
    opacity: 1;
    bottom: -5px;
}

.service-item>i {
    font-size: 60px;
    display: inline-block;
    margin: 0 20px 20px 0;
    color: var(--primary-color);
}

.service-item .content h3 {
    margin-bottom: 10px;
}

/* Service Details */
.single-service-content .image img {
    width: 100%;
}

.single-service-content h2 {
    font-size: 35px;
}

.single-service-content p,
.single-service-content h2 {
    margin-bottom: 15px;
}

/* Service Style Two */
.service-item-two {
    margin-bottom: 50px;
}

.service-item-two>i {
    font-size: 66px;
    margin-bottom: 25px;
    display: inline-block;
    color: var(--primary-color);
}

/****************************************************** */
/***************** 11. Newsletter Area **************** */
/****************************************************** */
/* Newsletter Section Wrapper */
.newsletter-section-two {
    margin-bottom: 220px;
}

.newsletter-inner {
    margin-top: -220px;
    border-radius: 7px;
    transform: translateY(220px);
}

.newsletter-content {
    margin-left: 30px;
}

.newsletter-email {
    position: relative;
}

.newsletter-email input {
    border-radius: 7px;
    padding: 5px 30px;
    height: 70px;
}

.newsletter-email button {
    position: absolute;
    color: white;
    top: 10px;
    right: 10px;
    display: flex;
    padding: 8px 30px;
    border-radius: 5px;
    align-items: center;
    height: calc(100% - 20px);
    background: var(--heading-color);
}

.newsletter-email button i {
    margin: 3px 0 0 7px;
}

.newsletter-radios {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 25px;
}

.newsletter-radios .custom-radio:not(last-child) {
    margin-right: 35px;
}

.newsletter-radios .custom-radio {
    padding-left: 40px;
}

.newsletter-radios .custom-radio label {
    cursor: pointer;
}

.newsletter-radios .custom-radio label:before {
    height: 25px;
    width: 25px;
    left: -40px;
    border: 1px solid;
    background: transparent;
}

.newsletter-radios .custom-control-input:checked~label::before {
    background: transparent;
    border: 1px solid white;
}

.newsletter-radios .custom-radio label:after {
    background-image: none;
    content: '\f00c';
    font-weight: 600;
    font-size: 12px;
    left: -33px;
    top: 1px;
    opacity: 0;
    transition: 0.5s;
    font-family: "Font Awesome 5 Free";
}

.newsletter-radios .custom-control-input:checked~.custom-control-label::after {
    background-image: none;
    opacity: 1;
}

.newsletter-images {
    max-width: 570px;
    margin-top: -30px;
    position: relative;
    margin-bottom: -30px;
}

.newsletter-images .circle {
    position: absolute;
    top: 20%;
    right: 15%;
    z-index: -1;
    width: 33%;
}

.newsletter-images .dots {
    position: absolute;
    left: 20%;
    bottom: 15%;
    z-index: -1;
    width: 11%;
}

/* Newsletter style two */
.newsletter-inner.style-two:after {
    content: '';
    right: 0;
    top: 0;
    width: 40%;
    z-index: -2;
    height: 100%;
    position: absolute;
    background: url(../images/newsletter/newsletter-two-bg.png) no-repeat center/cover;
}

.newsletter-inner.style-two .sub-title {
    background: #323a4d;
}

.newsletter-inner.style-two .newsletter-email button {
    background: var(--primary-color);
}


/****************************************************** */
/****************** 19. Contact Area ****************** */
/****************************************************** */
.contact-form {
    z-index: 9;
    border-radius: 7px;
    position: relative;
    margin-top: -265px;
    padding: 80px 70px 80px;
    box-shadow: 10px 0 60px rgba(81, 56, 238, 0.1);
}

/* Contact Information */
.contact-information-area {
    max-width: 990px;
    margin-left: auto;
    margin-right: auto;
}

.contact-info-item {
    display: flex;
    padding: 35px;
    transition: 0.5s;
    border-radius: 7px;
    margin-bottom: 30px;
    background: var(--light-color);
}

.contact-info-item>i {
    height: 55px;
    width: 55px;
    flex: none;
    color: white;
    transition: 0.5s;
    border: 2px solid;
    line-height: 51px;
    text-align: center;
    margin-right: 20px;
    border-radius: 50%;
    background: var(--primary-color);
}

.contact-info-content h3 {
    margin-bottom: 0;
    transition: 0.5s;
}

.contact-info-content span {
    font-weight: 600;
    transition: 0.5s;
    text-decoration: underline;
}

.contact-info-item:hover {
    background: var(--primary-color);
}

.contact-info-item:hover h3,
.contact-info-item:hover span,
.contact-info-item:hover span a {
    color: white;
}

.contact-left-map {
    min-height: 500px;
}

.contact-form-two .form-control {
    border-width: 0 0 2px;
    padding: 0 0 20px;
    border-radius: 0;
}

.contact-form-two .form-control::placeholder {
    font-size: 18px;
    font-weight: 600;
    text-transform: capitalize;
    color: var(--heading-color);
    font-family: var(--heading-font);
}

.contact-form-two .form-control:focus {
    border-color: var(--primary-color);
    background: transparent;
}

.contact-form-two .form-group {
    margin-bottom: 50px;
}

/* Contact Info style Two */
.contact-info-item.style-two {
    padding: 0;
    margin-bottom: 40px;
    align-items: center;
    background: transparent;
}

.contact-info-item.style-two>i {
    height: 60px;
    width: 60px;
    border: none;
    font-size: 22px;
    line-height: 60px;
}

.contact-info-item.style-two h5 {
    margin-bottom: 5px;
}

.contact-info-item.style-two span {
    font-size: 22px;
    font-weight: 500;
    text-decoration: none;
}

.contact-info-item.style-two span,
.contact-info-item.style-two span a {
    color: var(--base-color);
}

/* Contact Page */
.contact-form-three .form-group {
    margin-bottom: 30px;
}

.contact-form-three .form-control {
    padding: 17px 30px;
    background: var(--light-color);
    border: 1px solid var(--light-color);
}

.contact-form-three .form-control::placeholder {
    font-size: 18px;
    font-weight: 600;
    text-transform: capitalize;
    color: var(--heading-color);
    font-family: var(--heading-font);
}

.contact-form-three .form-control:focus {
    border-color: var(--primary-color);
    background: transparent;
}

/****************************************************** */
/******************* 21. Footer Area ****************** */
/****************************************************** */
.footer-section .newsletter-inner {
    transform: translateY(-220px);
    margin-bottom: -140px;
    margin-top: 0;
}

.footer-section .newsletter-email button {
    background: var(--yellow-color);
    color: var(--heading-color);
    font-weight: 700;
}

.footer-section .bg-yellow-shape {
    top: -100px;
}

.call-to-action {
    border-radius: 7px;
    padding: 45px 90px 25px;
    transform: translateY(-80px);
}

.call-to-action-btns .theme-btn:not(:last-child) {
    border: 2px solid white;
    margin-right: 15px;
}

.call-to-action-btns .theme-btn.style-three {
    background: transparent;
    border-color: white;
    color: white;
}

.call-to-action-btns .theme-btn.style-three:hover {
    color: var(--primary-color);
    background: white;
}

.call-to-action .white-circle {
    left: 2%;
    bottom: 42%;
}

.call-to-action .white-dots {
    position: absolute;
    bottom: 25%;
    left: 45%;
}

.call-to-action .white-dots-circle {
    position: absolute;
    z-index: -1;
    right: 28%;
    top: 0;
}

/* Footer Widgets */
.footer-widget {
    margin-bottom: 50px;
}

.footer-title {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 20px;
}

.about-widget {
    max-width: 235px;
}

.about-widget p b {
    font-weight: 600;
    text-decoration: underline;
    color: var(--primary-color);
}

/* Copyright Area */
.copyright-area {
    margin-top: 15px;
    padding-top: 25px;
    padding-bottom: 10px;
    border-top: 1px solid #dfdbfa;
}

.copyright-area p a {
    color: var(--primary-color);
}

.left-circles,
.right-circles,
.left-circles:after,
.right-circles:after {
    height: 500px;
    width: 500px;
    z-index: -1;
    position: absolute;
    border-radius: 50%;
    border: 1px solid var(--border-color);
    animation: slideUpDown 4s infinite linear;
}

.left-circles:after,
.right-circles:after {
    content: '';
    top: 50%;
    animation-delay: 2s;
}

.left-circles {
    left: -350px;
    top: 5%;
}

.right-circles {
    right: -300px;
    bottom: 5%;
}

.right-circles:after {
    right: -150px;
    top: 0
}

/* Footer Style Two */
.footer-section.text-white p span,
.footer-section.text-white .copyright-area p,
.footer-section.text-white .list-style-two a,
.footer-section.text-white .list-style-three li span {
    opacity: 0.7;
}

.footer-section.text-white p b,
.footer-section.text-white .list-style-two a,
.footer-section.text-white .copyright-area p a,
.footer-section.text-white .social-style-one a,
.footer-section.text-white .list-style-three li i,
.footer-section.text-white .list-style-three li a {
    color: white;
}

.footer-section.text-white .list-style-two a:hover {
    opacity: 1;
}

.footer-section.text-white .social-style-one a {
    background: rgba(255, 255, 255, 0.1);
}

.footer-section.text-white .social-style-one a:hover {
    background: var(--primary-color);
}

.footer-section.text-white .copyright-area {
    border-color: #394153;
}

.footer-two:before {
    content: '';
    left: 0;
    top: 100px;
    z-index: -1;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    text-align: center;
    position: absolute;
    filter: blur(100px);
    background: #ee9a38;
}

.footer-two:after {
    content: '';
    bottom: 0;
    right: 0;
    z-index: -1;
    width: 250px;
    opacity: 0.5;
    height: 250px;
    border-radius: 50%;
    text-align: center;
    position: absolute;
    filter: blur(100px);
    background: #00ff12;
}

.inner-page .footer-section .newsletter-email button {
    background: var(--heading-color);
    color: white;
}

.inner-page .slider-arrow-btns button:hover,
.inner-page .slider-arrow-btns button:focus {
    background: var(--primary-color);
}

/****************************************************** */
/**************** 22. Custom Animations *************** */
/****************************************************** */
/* Menu Sticky */
@-webkit-keyframes sticky {
    0% {
        top: -100px;
    }

    100% {
        top: 0;
    }
}

@keyframes sticky {
    0% {
        top: -100px;
    }

    100% {
        top: 0;
    }
}

@keyframes shapeAnimationOne {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
        transform: translate(0px, 0px) rotate(0deg);
    }

    25% {
        -webkit-transform: translate(0px, 150px) rotate(90deg);
        transform: translate(0px, 150px) rotate(90deg);
    }

    50% {
        -webkit-transform: translate(150px, 150px) rotate(180deg);
        transform: translate(150px, 150px) rotate(180deg);
    }

    75% {
        -webkit-transform: translate(150px, 0px) rotate(270deg);
        transform: translate(150px, 0px) rotate(270deg);
    }

    100% {
        -webkit-transform: translate(0px, 0px) rotate(360deg);
        transform: translate(0px, 0px) rotate(360deg);
    }
}

@keyframes shapeAnimationTwo {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
        transform: translate(0px, 0px) rotate(0deg);
    }

    25% {
        -webkit-transform: translate(-150px, -0px) rotate(270deg);
        transform: translate(-150px, -0px) rotate(270deg);
    }

    50% {
        -webkit-transform: translate(-150px, -150px) rotate(180deg);
        transform: translate(-150px, -150px) rotate(180deg);
    }

    75% {
        -webkit-transform: translate(-0px, -150px) rotate(90deg);
        transform: translate(-0px, -150px) rotate(90deg);
    }

    100% {
        -webkit-transform: translate(0px, 0px) rotate(360deg);
        transform: translate(0px, 0px) rotate(360deg);
    }
}

@keyframes shapeAnimationThree {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
        transform: translate(0px, 0px) rotate(0deg);
    }

    25% {
        -webkit-transform: translate(50px, 150px) rotate(90deg);
        transform: translate(50px, 150px) rotate(90deg);
    }

    50% {
        -webkit-transform: translate(150px, 150px) rotate(180deg);
        transform: translate(150px, 150px) rotate(180deg);
    }

    75% {
        -webkit-transform: translate(150px, 50px) rotate(270deg);
        transform: translate(150px, 50px) rotate(270deg);
    }

    100% {
        -webkit-transform: translate(0px, 0px) rotate(360deg);
        transform: translate(0px, 0px) rotate(360deg);
    }
}

@keyframes shapeAnimationFour {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
        transform: translate(0px, 0px) rotate(0deg);
    }

    25% {
        -webkit-transform: translate(-150px -50px) rotate(90deg);
        transform: translate(-150px -50px) rotate(90deg);
    }

    50% {
        -webkit-transform: translate(-150px, -150px) rotate(180deg);
        transform: translate(-150px, -150px) rotate(180deg);
    }

    75% {
        -webkit-transform: translate(-50px, -150px) rotate(270deg);
        transform: translate(-50px, -150px) rotate(270deg);
    }

    100% {
        -webkit-transform: translate(0px, 0px) rotate(360deg);
        transform: translate(0px, 0px) rotate(360deg);
    }
}

@keyframes shapeAnimationFive {
    0% {
        -webkit-transform: translate(0px, 0px) rotate(0deg);
        transform: translate(0px, 0px) rotate(0deg);
    }

    25% {
        -webkit-transform: translate(-100px -100px) rotate(90deg);
        transform: translate(-100px -100px) rotate(90deg);
    }

    50% {
        -webkit-transform: translate(100px, 50px) rotate(180deg);
        transform: translate(100px, 50px) rotate(180deg);
    }

    75% {
        -webkit-transform: translate(-100px, 150px) rotate(270deg);
        transform: translate(-100px, 150px) rotate(270deg);
    }

    100% {
        -webkit-transform: translate(0px, 0px) rotate(360deg);
        transform: translate(0px, 0px) rotate(360deg);
    }
}

.shapeAnimationOne {
    animation: shapeAnimationOne 20s infinite linear;
}

.shapeAnimationTwo {
    animation: shapeAnimationTwo 20s infinite linear;
}

.shapeAnimationThree {
    animation: shapeAnimationThree 20s infinite linear;
}

.shapeAnimationFour {
    animation: shapeAnimationFour 20s infinite linear;
}

.shapeAnimationFive {
    animation: shapeAnimationFive 20s infinite linear;
}


@keyframes circleRotated {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.circleRotated {
    animation: circleRotated 10s infinite linear;
}


@keyframes slideLeftRight {
    0% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }

    50% {
        -webkit-transform: translate(20px);
        transform: translate(20px);
    }

    100% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
}

.slideLeftRight {
    animation: slideLeftRight 5s infinite linear;
}

@keyframes slideUpDown {
    0% {
        -webkit-transform: translate(0px, 0px);
        transform: translate(0px, 0px);
    }

    50% {
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px);
    }

    100% {
        -webkit-transform: translate(0px, 0px);
        transform: translate(0px, 0px);
    }
}

.slideUpDown {
    animation: slideUpDown 5s infinite linear;
}

@keyframes slideUpRight {
    0% {
        -webkit-transform: translate(0px, 0px);
        transform: translate(0px, 0px);
    }

    50% {
        -webkit-transform: translate(-20px, 20px);
        transform: translate(-20px, 20px);
    }

    100% {
        -webkit-transform: translate(0px, 0px);
        transform: translate(0px, 0px);
    }
}

.slideUpRight {
    animation: slideUpRight 5s infinite linear;
}


/* Circle Animation */
@-webkit-keyframes circleAnimation {
    0% {
        border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    }

    50% {
        border-radius: 30% 60% 70% 40% / 50% 60% 30% 60%;
    }

    100% {
        border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    }
}

@keyframes circleAnimation {
    0% {
        border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    }

    50% {
        border-radius: 30% 60% 70% 40% / 50% 60% 30% 60%;
    }

    100% {
        border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    }
}

.circleAnimation {
    animation: circleAnimation 8s ease-in-out infinite;
}

/* Animation Delay */
.delay-0-1s {
    -webkit-animation-delay: 0.1s;
    -o-animation-delay: 0.1s;
    animation-delay: 0.1s;
}

.delay-0-2s {
    -webkit-animation-delay: 0.2s;
    -o-animation-delay: 0.2s;
    animation-delay: 0.2s;
}

.delay-0-3s {
    -webkit-animation-delay: 0.3s;
    -o-animation-delay: 0.3s;
    animation-delay: 0.3s;
}

.delay-0-4s {
    -webkit-animation-delay: 0.4s;
    -o-animation-delay: 0.4s;
    animation-delay: 0.4s;
}

.delay-0-5s {
    -webkit-animation-delay: 0.5s;
    -o-animation-delay: 0.5s;
    animation-delay: 0.5s;
}

.delay-0-6s {
    -webkit-animation-delay: 0.6s;
    -o-animation-delay: 0.6s;
    animation-delay: 0.6s;
}

.delay-0-7s {
    -webkit-animation-delay: 0.7s;
    -o-animation-delay: 0.7s;
    animation-delay: 0.7s;
}

.delay-0-8s {
    -webkit-animation-delay: 0.8s;
    -o-animation-delay: 0.8s;
    animation-delay: 0.8s;
}

.delay-0-9s {
    -webkit-animation-delay: 0.9s;
    -o-animation-delay: 0.9s;
    animation-delay: 0.9s;
}

.delay-1-0s {
    -webkit-animation-delay: 1.0s;
    -o-animation-delay: 1.0s;
    animation-delay: 1.0s;
}

.delay-1-1s {
    -webkit-animation-delay: 1.1s;
    -o-animation-delay: 1.1s;
    animation-delay: 1.1s;
}

.delay-1-2s {
    -webkit-animation-delay: 1.2s;
    -o-animation-delay: 1.2s;
    animation-delay: 1.2s;
}

.delay-1-3s {
    -webkit-animation-delay: 1.3s;
    -o-animation-delay: 1.3s;
    animation-delay: 1.3s;
}

.delay-1-4s {
    -webkit-animation-delay: 1.4s;
    -o-animation-delay: 1.4s;
    animation-delay: 1.4s;
}

.delay-1-5s {
    -webkit-animation-delay: 1.5s;
    -o-animation-delay: 1.5s;
    animation-delay: 1.5s;
}

.delay-1-6s {
    -webkit-animation-delay: 1.6s;
    -o-animation-delay: 1.6s;
    animation-delay: 1.6s;
}

.delay-1-7s {
    -webkit-animation-delay: 1.7s;
    -o-animation-delay: 1.7s;
    animation-delay: 1.7s;
}

.delay-1-8s {
    -webkit-animation-delay: 1.8s;
    -o-animation-delay: 1.8s;
    animation-delay: 1.8s;
}

.delay-1-9s {
    -webkit-animation-delay: 1.9s;
    -o-animation-delay: 1.9s;
    animation-delay: 1.9s;
}

.delay-2-0s {
    -webkit-animation-delay: 2.0s;
    -o-animation-delay: 2.0s;
    animation-delay: 2.0s;
}

/****************************************************** */
/****************** 23. Dark Version ****************** */
/****************************************************** */
.dark-body {
    background: #222b40;
    --light-color: #131b2c;
    --border-color: rgba(255, 255, 255, 0.15);
}

.dark-body .service-item,
.dark-body .blog-item-two,
.dark-body .feedback-item-two {
    background: #222b40;
}

.dark-body p,
.dark-body h1,
.dark-body h2,
.dark-body h3,
.dark-body h4,
.dark-body h5,
.dark-body h6,
.dark-body p a,
.dark-body h1 a,
.dark-body h2 a,
.dark-body h3 a,
.dark-body h4 a,
.dark-body h5 a,
.dark-body h6 a,
.dark-body .sub-title,
.dark-body .blog-meta li,
.dark-body .blog-item-two a,
.dark-body footer .read-more,
.dark-body .form-group input,
.dark-body .menu-right .login,
.dark-body .list-style-one li,
.dark-body .navigation>li>a,
.dark-body .form-group textarea,
.dark-body .nav-search>button,
.dark-body .feedback-item-two p b,
.dark-body .theme-btn.style-three,
.dark-body a.theme-btn.style-three,
.dark-body .contact-info-content span,
.dark-body .contact-info-content span a,
.dark-body .form-group input::placeholder,
.dark-body .form-group textarea::placeholder,
.dark-body .navigation li.dropdown .dropdown-btn,
.dark-body .newsletter-radios .custom-radio label,
.dark-body .feedback-author .author-content span,
.dark-body .hero-content-three .newsletter-email input,
.dark-body .hero-content-three .newsletter-email input::placeholder {
    color: white;
}

.dark-body .icon-bar,
.dark-body .navigation>li>a:after {
    background: white;
}

.dark-body hr,
.dark-body .main-menu .navigation li,
.dark-body .form-group input:not(:focus),
.dark-body .form-group textarea:not(:focus),
.dark-body .theme-btn.style-three:not(:hover),
.dark-body a.theme-btn.style-three:not(:hover),
.dark-body .hero-content-three .newsletter-email input,
.dark-body .main-menu .navigation li.dropdown .dropdown-btn {
    border-color: var(--border-color);
}

.dark-body .dots-shape,
.dark-body .close-shape,
.dark-body .tringle-shape {
    filter: brightness(99);
}

.dark-body .hero-section-three:before {
    background: var(--primary-color);
}

.dark-body .fixed-header .header-upper,
.dark-body .bg-blue:not(.call-to-action) {
    background: #141B2D;
}

.dark-body .newsletter-inner {
    background: #172033;
}

.dark-body .sub-title {
    background: rgba(255, 255, 255, 0.07);
}

.dark-body .service-item p,
.dark-body .feedback-item-two p,
.dark-body .blog-item-two:not(:hover) p {
    opacity: 0.7;
}

.dark-body .partner-item-three:not(:hover),
.dark-body .contact-info-item:not(:hover) span,
.dark-body .blog-item-two:not(:hover) .read-more i,
.dark-body .blog-item-two:not(:hover) .blog-meta li {
    opacity: 0.5;
}

.dark-body .feedback-author .author-content span {
    opacity: 0.3;
}

.dark-body .solution-item-three>i:after {
    opacity: 1;
}

.dark-body .contact-info-item:not(:hover)>i {
    border-color: var(--light-color);
}

.dark-body .theme-btn.style-three:not(:hover),
.dark-body a.theme-btn.style-three:not(:hover) {
    background: transparent;
}

@media only screen and (max-width: 991px) {

    .dark-body .header-inner,
    .dark-body .main-menu .navigation,
    .dark-body .main-header.header-three {
        background: #141B2D;
    }

    .dark-body .main-menu .navigation li ul li a {
        color: white;
    }
}

/* Ensure mobile menu background is dark in dark mode */
@media only screen and (max-width: 991px) {
    .main-menu .navigation li {
        border: none !important;
        /* Remove default borders */
    }

    .main-menu .navigation>li:last-child {
        border: none !important;
    }

    .main-menu .navigation li a {
        padding: 15px 25px !important;
        /* Larger touch targets */
        font-weight: 500;
        border-width: 0 !important;
        /* Force remove border-width overrides */
    }

    .dark-body .main-menu .navigation,
    .dark-body .main-menu .navbar-collapse {
        background: #141b2d;
    }

    .dark-body .main-menu .navigation li a {
        color: #ffffff;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        /* Subtle separator */
    }

    .dark-body .main-menu .navigation li:last-child a {
        border-bottom: none !important;
    }
}

.mr-15 {
    margin-right: 15px;
}



/****************************************************** */
/****************** 23. Dark Version ****************** */
/****************************************************** */
.dark-body {
    background: #222b40;
    --light-color: #131b2c;
    --border-color: rgba(255, 255, 255, 0.15);
}

.dark-body .service-item,
.dark-body .blog-item-two,
.dark-body .feedback-item-two {
    background: #222b40;
}

.dark-body p,
.dark-body h1,
.dark-body h2,
.dark-body h3,
.dark-body h4,
.dark-body h5,
.dark-body h6,
.dark-body p a,
.dark-body h1 a,
.dark-body h2 a,
.dark-body h3 a,
.dark-body h4 a,
.dark-body h5 a,
.dark-body h6 a,
.dark-body .sub-title,
.dark-body .blog-meta li,
.dark-body .blog-item-two a,
.dark-body footer .read-more,
.dark-body .form-group input,
.dark-body .menu-right .login,
.dark-body .list-style-one li,
.dark-body .navigation>li>a,
.dark-body .form-group textarea,
.dark-body .nav-search>button,
.dark-body .feedback-item-two p b,
.dark-body .theme-btn.style-three,
.dark-body a.theme-btn.style-three,
.dark-body .contact-info-content span,
.dark-body .contact-info-content span a,
.dark-body .form-group input::placeholder,
.dark-body .form-group textarea::placeholder,
.dark-body .navigation li.dropdown .dropdown-btn,
.dark-body .newsletter-radios .custom-radio label,
.dark-body .feedback-author .author-content span,
.dark-body .hero-content-three .newsletter-email input,
.dark-body .hero-content-three .newsletter-email input::placeholder {
    color: white;
}

.dark-body .icon-bar,
.dark-body .navigation>li>a:after {
    background: white;
}

.dark-body hr,
.dark-body .main-menu .navigation li,
.dark-body .form-group input:not(:focus),
.dark-body .form-group textarea:not(:focus),
.dark-body .theme-btn.style-three:not(:hover),
.dark-body a.theme-btn.style-three:not(:hover),
.dark-body .hero-content-three .newsletter-email input,
.dark-body .main-menu .navigation li.dropdown .dropdown-btn {
    border-color: var(--border-color);
}

.dark-body .dots-shape,
.dark-body .close-shape,
.dark-body .tringle-shape {
    filter: brightness(99);
}

.dark-body .hero-section-three:before {
    background: var(--primary-color);
}

.dark-body .fixed-header .header-upper,
.dark-body .bg-blue:not(.call-to-action) {
    background: #141B2D;
}

.dark-body .newsletter-inner {
    background: #172033;
}

.dark-body .sub-title {
    background: rgba(255, 255, 255, 0.07);
}

.dark-body .service-item p,
.dark-body .feedback-item-two p,
.dark-body .blog-item-two:not(:hover) p {
    opacity: 0.7;
}

.dark-body .partner-item-three:not(:hover),
.dark-body .contact-info-item:not(:hover) span,
.dark-body .blog-item-two:not(:hover) .read-more i,
.dark-body .blog-item-two:not(:hover) .blog-meta li {
    opacity: 0.5;
}

.dark-body .feedback-author .author-content span {
    opacity: 0.3;
}

.dark-body .solution-item-three>i:after {
    opacity: 1;
}

.dark-body .contact-info-item:not(:hover)>i {
    border-color: var(--light-color);
}

.dark-body .theme-btn.style-three:not(:hover),
.dark-body a.theme-btn.style-three:not(:hover) {
    background: transparent;
}

@media only screen and (max-width: 991px) {

    .dark-body .header-inner,
    .dark-body .main-menu .navigation,
    .dark-body .main-header.header-three {
        background: #141B2D;
    }

    .dark-body .main-menu .navigation li ul li a {
        color: white;
    }
}

/* Ensure mobile menu background is dark in dark mode */
@media only screen and (max-width: 991px) {
    .main-menu .navigation li {
        border: none !important;
        /* Remove default borders */
    }

    .main-menu .navigation>li:last-child {
        border: none !important;
    }

    .main-menu .navigation li a {
        padding: 15px 25px !important;
        /* Larger touch targets */
        font-weight: 500;
        border-width: 0 !important;
        /* Force remove border-width overrides */
    }

    .dark-body .main-menu .navigation,
    .dark-body .main-menu .navbar-collapse {
        background: #141b2d;
    }

    .dark-body .main-menu .navigation li a {
        color: #ffffff;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        /* Subtle separator */
    }

    .dark-body .main-menu .navigation li:last-child a {
        border-bottom: none !important;
    }
}

.mr-15 {
    margin-right: 15px;
}

/* Override spacing for mobile header controls to be more spacious */
@media only screen and (max-width: 991px) {
    .mobile-header-controls {
        margin-right: 15px !important;
        gap: 15px;
        background-color: transparent;
        /* inherit from parent */
    }

    .mobile-header-controls .lang-toggle {
        margin-right: 0 !important;
    }

    .navbar-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        background-color: transparent;
        /* inherit from parent */
        transition: background-color 0.3s ease;
    }

    /* Dark Mode Specific Fixes for Header */
    .dark-body .navbar-header,
    .dark-body .mobile-header-controls {
        background-color: #141B2D !important;
    }

    .logo-mobile {
        flex-grow: 1;
    }

    .navbar-toggle {
        position: static !important;
        float: none !important;
        margin: 0 !important;
        display: inline-block !important;
    }

    /* Ensure container transitions match */
    .header-inner,
    .container,
    .header-upper,
    .main-header {
        transition: background-color 0.3s ease;
    }
}

/* Targeted Overflow Fixes */

/* Global Mobile Fixes */
html,
body {
    overflow-x: hidden;
    position: relative;
    width: 100%;
}

/* Modern Preloader */
.preloader {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    background-color: #fff;
    z-index: 9999999;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease;
}

.dark-body .preloader {
    background-color: #141B2D !important;
}

.custom-loader {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: radial-gradient(farthest-side, #2563eb 94%, #0000) top/8px 8px no-repeat,
        conic-gradient(#0000 30%, #2563eb);
    -webkit-mask: radial-gradient(farthest-side, #0000 calc(100% - 8px), #000 0);
    animation: s3 1s infinite linear;
}

@keyframes s3 {
    100% {
        transform: rotate(1turn);
    }
}

/* Force global transition for theme switching on all header layers */
.home-three .main-header,
.home-three .header-upper,
.home-three .header-inner,
.home-three .container,
.home-three .navbar-collapse,
.home-three .navigation {
    -webkit-transition: background 0.3s ease, background-color 0.3s ease !important;
    -moz-transition: background 0.3s ease, background-color 0.3s ease !important;
    -ms-transition: background 0.3s ease, background-color 0.3s ease !important;
    -o-transition: background 0.3s ease, background-color 0.3s ease !important;
    transition: background 0.3s ease, background-color 0.3s ease !important;
}

/* ==========================================================================
   DARK MODE HEADER REDESIGN (Consolidated)
   ========================================================================== */
.dark-body .main-header,
.dark-body .header-upper,
.dark-body .header-inner,
.dark-body .navbar-collapse,
.dark-body .navigation,
.dark-body .navbar-header,
.dark-body .mobile-header-controls {
    background-color: #141B2D !important;
    border-color: rgba(255, 255, 255, 0.05) !important;
}

/* Fix for transparent conflicts */
.dark-body .container,
.dark-body .nav-outer {
    background-color: transparent !important;
}

/* Text Colors */
.dark-body .main-menu .navigation>li>a,
.dark-body .mobile-header-controls .fas,
.dark-body .logo-text {
    color: #ffffff !important;
}

/* Mobile Menu Specifics */
@media only screen and (max-width: 991px) {
    .dark-body .header-inner {
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
    }

    .dark-body .navbar-collapse {
        border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
    }
}

@media only screen and (min-width: 1501px) {
    .feedback-right-content {
        padding-bottom: 55px;
    }

    .counter-section-two .bg-yellow-shape {
        top: 0;
    }

    .solutions-tab-content {
        margin-left: 60px;
        margin-right: -100px;
    }

    .hero-image-three {
        margin-right: -110px;
    }

    .service-sidebar,
    .blog-standard-wrap,
    .blog-details-content {
        margin-right: 50px;
    }

    .blog-sidebar {
        margin-left: 45px;
    }

}

@media only screen and (max-width: 1400px) {
    .menu-right .nice-select {
        margin-left: 15px;
        margin-right: 15px;
    }

    .main-menu .navbar-collapse {
        margin-left: 10px;
    }

    .main-menu .navigation>li>a {
        margin-left: 20px;
    }

    .hero-content h1,
    .hero-content-two h1,
    .hero-content-three h1 {
        font-size: 55px;
    }

    .hero-about-bg {
        top: -444px;
    }

    .services-tab .nav .nav-link,
    .contact-content-area .contact-info-item.style-two span {
        font-size: 16px;
    }

    .call-to-action {
        padding-left: 65px;
        padding-right: 65px;
    }

    .section-alpha-text {
        font-size: 200px;
    }

    .solutions-tab-nav .nav-link>i {
        display: none;
    }

}

@media only screen and (min-width: 1200px) {
    .container {
        max-width: 1510px;
        padding-left: 50px;
        padding-right: 50px;
    }

    .pricing-section .container {
        max-width: 1150px;
    }

    .feedback-right-content {
        margin-left: 50px;
    }

    .call-to-action .section-title h2 {
        font-size: 34px;
    }

    .solutions-tab-nav .nav-item:last-child {
        margin-bottom: 0;
    }

    .page-banner {
        margin-top: 146px;
    }

}

@media only screen and (max-width: 1199px) {
    .header-inner {
        padding-top: 15px;
        padding-bottom: 15px;
    }

    .menu-right .nice-select,
    .header-three .menu-right .login {
        display: none;
    }

    .nav-search {
        border: none;
        padding-right: 25px;
    }

    .page-banner {
        margin-top: 136px;
    }

    .hero-content h1,
    .hero-content-three h1 {
        font-size: 45px;
    }

    .hero-about-bg {
        top: -333px;
    }

    .services-tab .nav {
        background: transparent;
    }

    .services-tab .nav .nav-link {
        padding: 2px 15px;
    }

    .services-tab .nav .nav-link.active {
        background: var(--light-color);
        border-color: transparent;
    }

    .newsletter-content {
        margin-left: 0;
        padding-right: 0;
    }

    .section-alpha-text {
        font-size: 150px;
    }

    .solutions-tab-nav .nav-link {
        height: auto;
    }

    .solutions-tab-nav .nav-link>i {
        display: block;
    }

    .feedback-three-wrap {
        margin-top: 50px;
        margin-left: -15px;
    }

    .blog-standard-item h2,
    .single-service-content h2,
    .project-details-content h2,
    .team-profile-description h2 {
        font-size: 30px;
    }

    .project-information {
        margin-top: -55px;
        padding-left: 45px;
        padding-right: 45px;
    }
}

@media only screen and (min-width: 991px) and (max-width: 1199px) {
    .newsletter-inner {
        margin-top: -120px;
    }

    .for-adjust-spacing {
        margin-top: -30px;
    }

}

@media only screen and (min-width: 991px) {
    .hero-image {
        text-align: right;
    }

    .admin-comment .author-image {
        max-width: 165px;
    }

    .admin-comment .author-image img {
        width: 165px;
        height: 165px;
    }
}

@media only screen and (max-width: 991px) {
    .header-upper {
        box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.05);
        padding: 0 !important;
        transition: background-color 0.3s ease !important;
        background-color: #ffffff;
    }

    /* Dark Mode Override for Header Upper */
    .dark-body .header-upper {
        background-color: #141B2D !important;
        box-shadow: 0px 5px 15px rgba(255, 255, 255, 0.05);
    }

    .header-inner {
        background-color: transparent !important;
        border-bottom: none;
        padding-top: 15px;
        padding-bottom: 15px;
        transition: background-color 0.3s ease !important;
    }

    .main-header,
    .container,
    .nav-outer,
    .mobile-header-controls {
        transition: background-color 0.3s ease !important;
    }

    .page-banner {
        margin-top: 113px;
    }

    .feature-images,
    .main-menu .navigation>li>a,
    .main-menu .navbar-collapse {
        margin-left: 0;
    }

    .header-three .main-menu .navbar-collapse {
        margin-right: 0;
    }

    .hero-content-two h1 {
        font-size: 45px;
    }

    .section-title h2 {
        font-size: 35px;
        line-height: 1.5;
    }

    .hero-about-bg {
        top: -275px;
    }

    .newsletter-images {
        padding-top: 50px;
        padding-left: 50px;
        margin-right: 50px;
    }

    .newsletter-content {
        padding-left: 50px;
        padding-right: 50px;
    }

    .newsletter-top-line {
        transform: translateY(50px);
    }

    .feedback-left-image {
        padding-top: 320px;
    }

    .feedback-left-image:before {
        width: 90vw;
        right: 10vw;
    }

    .partner-two-wrap {
        justify-content: space-around;
    }

    .partner-two-wrap .partner-item {
        margin-right: 15px;
        margin-left: 15px;
        width: calc(25% - 30px);
    }

    .partner-dashboard {
        margin-top: -200px;
    }

    .bg-yellow-shape {
        height: 150px;
        top: 15%;
    }

    .section-alpha-text {
        font-size: 100px;
    }

    .header-three .nav-search,
    .footer-section .newsletter-images {
        display: none;
    }

    .solution-item-three {
        padding: 0 15px;
    }

    .service-item {
        padding-left: 25px;
        padding-right: 25px;
    }

    .newsletter-inner.style-two:after {
        width: 100%;
    }

    .dashboard-screenshot-item img {
        transform: translate(calc(100% - 50px));
    }

    .dashboard-screenshot-item.slick-active+.dashboard-screenshot-item img {
        transform: translate(calc(50px - 100%));
    }

    .project-filter li {
        font-size: 16px;
    }

    .project-information {
        margin-top: 30px;
    }

    .contact-page-map iframe {
        height: 450px;
    }

}

@media only screen and (max-width: 767px) {

    .container,
    .container-fluid {
        padding-left: 15px;
        padding-right: 15px;
    }

    .header-top p {
        padding: 5px 0;
        font-size: 15px;
        line-height: 1.4;
    }

    .section-title h2 {
        font-size: 30px;
    }

    .page-title {
        font-size: 45px;
    }

    .hero-about-bg {
        top: -235px;
    }

    .partner-two-wrap .partner-item {
        width: calc(33% - 30px);
    }

    .section-alpha-text {
        font-size: 75px;
    }

    .hero-section-two .left-circles {
        left: -333px;
    }

    .hero-section-two .right-circles,
    .hero-section-two .right-circles:after {
        height: 250px;
        width: 250px;
    }

    .hero-section-two .right-circles {
        right: -200px;
    }

    .hero-section-two .right-circles:after {
        right: -20px;
        top: 100px;
    }

    .success-item.style-two {
        padding-bottom: 0;
    }

    .counter-inner-two {
        padding-bottom: 75px;
    }

    .big-image .project-content {
        height: 80px;
        width: 80px;
    }

    .big-image .project-content h3 {
        display: none;
    }

}

@media only screen and (max-width: 575px) {

    .page-title,
    .hero-content h1,
    .hero-content-two h1 {
        font-size: 40px;
        line-height: 1.5;
    }

    .hero-about-bg {
        top: -175px;
    }

    blockquote,
    .contact-form,
    .call-to-action {
        padding-left: 25px;
        padding-right: 25px;
    }

    .dashboard-screenshot-item img,
    .about-content-three .list-style-one li:first-child {
        width: 100%;
    }

    .dashboard-screenshot-wrap .dashboard-prev {
        left: -10px;
    }

    .dashboard-screenshot-wrap .dashboard-next {
        right: -10px;
    }

    .about-page-images img:first-child {
        margin-right: 15px;
    }

    .contact-page-map iframe {
        height: 350px;
    }

    .blog-standard-item h2 {
        font-size: 25px;
    }

    blockquote {
        margin-top: 0;
    }

    blockquote p {
        font-size: 20px;
        line-height: 1.7;
    }

    .comment-item {
        display: block;
    }

    .author-image {
        margin-bottom: 20px;
    }

}

@media only screen and (max-width: 480px) {

    .page-title,
    .hero-content h1,
    .hero-content-two h1,
    .hero-content-three h1 {
        font-size: 35px;
    }

    .hero-content p,
    .hero-content-two p,
    .list-style-one li {
        font-size: 16px;
        line-height: 1.6;
    }

    .hero-about-bg {
        top: -115px;
    }

    .counter-inner,
    .newsletter-images,
    .feedback-item-two,
    .newsletter-content {
        padding-left: 25px;
        padding-right: 25px;
    }

    .feedback-item p {
        font-size: 18px;
    }

    .hero-content-two .hero-btns .theme-btn {
        margin-left: 5px;
        margin-right: 5px;
        margin-top: 10px;
    }

    .bg-yellow-shape {
        height: 100px;
        top: 5%;
    }

    .partner-dashboard {
        margin-top: -100px;
    }

    .section-alpha-text {
        font-size: 50px;
        margin-bottom: 150px;
    }

    .solutions-tab-nav .nav-link {
        padding: 15px 25px;
    }

    .solutions-tab-nav .nav-link>i {
        margin-right: 10px;
        font-size: 40px;
    }

    .solutions-tab-nav .nav-link h3 {
        font-size: 20px;
        margin-bottom: 3px;
    }

}

@media only screen and (max-width: 400px) {

    .hero-content h1,
    .hero-content-two h1,
    .hero-content-three h1 {
        font-size: 30px;
    }

    .section-title h2 {
        font-size: 28px;
    }

    .col-small {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .partner-two-wrap .partner-item {
        width: calc(50% - 30px);
    }

    .page-banner {
        margin-top: 132px;
    }

}

@media only screen and (max-width: 375px) {

    .hero-content h1,
    .hero-content-two h1,
    .hero-content-three h1,
    .single-service-content h2,
    .project-details-content h2,
    .team-profile-description h2 {
        font-size: 25px;
    }

    .hero-content-three h1 {
        line-height: 1.4;
    }

    .section-title h2,
    .solution-item-three h3,
    .blog-details-content h3,
    .team-profile-description h3 {
        font-size: 23px;
    }

    .hero-about-bg {
        top: -80px;
    }

    .success-item,
    .service-item,
    .feedback-active .feedback-author {
        display: block;
    }

    .newsletter-email button {
        margin-bottom: 15px;
        position: relative;
        right: 0;
    }

    .feedback-author i {
        margin-right: 16px;
    }

    .blog-standard-item h2,
    .feedback-author .author-content h3 {
        font-size: 22px;
    }

    .blog-author {
        left: 16px;
        width: calc(100% - 32px);
    }

    .blog-content,
    .service-list li a,
    .contact-info-item {
        padding-left: 16px;
        padding-right: 16px;
    }

    .blog-content h4 {
        font-size: 18px;
    }

    blockquote p,
    .blog-author h5,
    .form-group label,
    .service-list li a,
    .project-content h3,
    .news-widget-item h5,
    .solutions-tab-nav .nav-link h3,
    .contact-info-item.style-two span {
        font-size: 16px;
    }

    .blog-meta li:not(:last-child) {
        margin-right: 12px;
    }

    .list-style-two.two-column li {
        width: 100%;
    }

    .solution-item-two {
        padding-left: 25px;
    }

    .solution-item-two .number {
        font-size: 150px;
    }

    .success-item.style-two {
        padding-left: 55px;
        padding-right: 55px;
    }

    .solutions-tab-nav .nav-link {
        text-align: center;
        display: block;
    }

    .pricing-item,
    .admin-comment,
    .blog-item-two,
    .service-widget,
    .call-action-widget,
    .contact-form .theme-btn {
        padding-left: 25px;
        padding-right: 25px;
    }

    .feedback-active .feedback-author i {
        display: inline-block;
        margin-bottom: 13px;
    }

    .contact-form .theme-btn i,
    .solutions-tab-nav .nav-link p,
    .solutions-tab-nav .nav-link>i {
        display: none;
    }

    .solution-item-three>i {
        height: 55px;
        width: 55px;
        font-size: 25px;
        line-height: 55px;
    }

    .hero-content-three .newsletter-email input {
        height: 60px;
    }

    .blog-item-two h3,
    .service-item .content h3,
    .admin-comment .comment-details h3 {
        font-size: 20px;
    }

    .blog-item-two p,
    .news-widget-item h5 {
        line-height: 1.5;
    }

    .project-content {
        height: 155px;
        width: 155px;
    }

    .news-widget-item img {
        margin-right: 20px;
    }

    .comment-item.child-comment {
        margin-left: 35px;
    }

    .solutions-tab-nav .nav-item:not(:last-child) {
        margin-bottom: 5px;
    }

}

/****************************************************** */
/************ 13. Dashboard Screenshot Area *********** */
/****************************************************** */
.dashboard-screenshot-wrap {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 30px;
    padding-bottom: 30px;
    padding-left: 15%;
    padding-right: 15%;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.dashboard-screenshot-wrap::-webkit-scrollbar {
    display: none;
}

.dashboard-screenshot-item {
    flex: 0 0 auto;
    width: 70%;
    max-width: 800px;
    scroll-snap-align: center;
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
}

.dashboard-screenshot-item img {
    border-radius: 10px;
    width: 100%;
}

@media (max-width: 768px) {
    .dashboard-screenshot-wrap {
        /* Mobile: Item is 60%, so padding side is (100% - 60%) / 2 = 20% */
        padding-left: 20%;
        padding-right: 20%;
    }

    .dashboard-screenshot-item {
        width: 60%;
    }
}