/* Minification failed. Returning unminified contents.
(283,297): run-time error CSS1019: Unexpected token, found '}'
(284,2): run-time error CSS1031: Expected selector, found '/'
(284,2): run-time error CSS1025: Expected comma or open brace, found '/'
(1412,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1413,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1417,1): run-time error CSS1019: Unexpected token, found '@-webkit-keyframes'
(1418,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1422,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1423,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1427,1): run-time error CSS1019: Unexpected token, found '@-webkit-keyframes'
(1428,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1437,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1438,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1442,1): run-time error CSS1019: Unexpected token, found '@-webkit-keyframes'
(1443,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1481,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1482,7): run-time error CSS1035: Expected colon, found ','
(1507,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1508,7): run-time error CSS1035: Expected colon, found ','
(1523,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1524,8): run-time error CSS1035: Expected colon, found '{'
(1541,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1542,8): run-time error CSS1035: Expected colon, found '{'
(1575,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1576,7): run-time error CSS1035: Expected colon, found ','
(1593,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1594,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(1624,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1625,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '20%'
(1651,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1652,8): run-time error CSS1035: Expected colon, found '{'
(1679,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1680,8): run-time error CSS1035: Expected colon, found '{'
(1713,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1714,7): run-time error CSS1035: Expected colon, found ','
(1752,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1753,7): run-time error CSS1035: Expected colon, found ','
(1789,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1790,7): run-time error CSS1035: Expected colon, found ','
(1821,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1822,7): run-time error CSS1035: Expected colon, found ','
(1853,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1854,7): run-time error CSS1035: Expected colon, found ','
(1885,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1886,7): run-time error CSS1035: Expected colon, found ','
(1917,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1918,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '20%'
(1937,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1938,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '20%'
(1957,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1958,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '20%'
(1973,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1974,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '20%'
(1989,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(1990,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '20%'
(2009,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2010,8): run-time error CSS1035: Expected colon, found '{'
(2023,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2024,8): run-time error CSS1035: Expected colon, found '{'
(2039,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2040,8): run-time error CSS1035: Expected colon, found '{'
(2055,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2056,8): run-time error CSS1035: Expected colon, found '{'
(2071,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2072,8): run-time error CSS1035: Expected colon, found '{'
(2087,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2088,8): run-time error CSS1035: Expected colon, found '{'
(2103,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2104,8): run-time error CSS1035: Expected colon, found '{'
(2119,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2120,8): run-time error CSS1035: Expected colon, found '{'
(2135,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2136,8): run-time error CSS1035: Expected colon, found '{'
(2151,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2152,8): run-time error CSS1035: Expected colon, found '{'
(2165,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2166,8): run-time error CSS1035: Expected colon, found '{'
(2180,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2181,8): run-time error CSS1035: Expected colon, found '{'
(2195,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2196,8): run-time error CSS1035: Expected colon, found '{'
(2210,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2211,8): run-time error CSS1035: Expected colon, found '{'
(2225,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2226,8): run-time error CSS1035: Expected colon, found '{'
(2240,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2241,8): run-time error CSS1035: Expected colon, found '{'
(2255,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2256,8): run-time error CSS1035: Expected colon, found '{'
(2270,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2271,8): run-time error CSS1035: Expected colon, found '{'
(2285,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2286,8): run-time error CSS1035: Expected colon, found '{'
(2318,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2319,8): run-time error CSS1035: Expected colon, found '{'
(2350,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2351,8): run-time error CSS1035: Expected colon, found '{'
(2382,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2383,8): run-time error CSS1035: Expected colon, found '{'
(2404,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2405,8): run-time error CSS1035: Expected colon, found '{'
(2426,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2427,8): run-time error CSS1035: Expected colon, found '{'
(2453,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2454,8): run-time error CSS1035: Expected colon, found '{'
(2469,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2470,8): run-time error CSS1035: Expected colon, found '{'
(2487,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2488,8): run-time error CSS1035: Expected colon, found '{'
(2505,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2506,8): run-time error CSS1035: Expected colon, found '{'
(2523,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2524,8): run-time error CSS1035: Expected colon, found '{'
(2541,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2542,8): run-time error CSS1035: Expected colon, found '{'
(2559,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2560,8): run-time error CSS1035: Expected colon, found '{'
(2576,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2577,8): run-time error CSS1035: Expected colon, found '{'
(2593,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2594,8): run-time error CSS1035: Expected colon, found '{'
(2610,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2611,8): run-time error CSS1035: Expected colon, found '{'
(2627,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2628,8): run-time error CSS1035: Expected colon, found '{'
(2644,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2645,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '0%'
(2673,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2674,8): run-time error CSS1035: Expected colon, found '{'
(2700,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2701,8): run-time error CSS1035: Expected colon, found '{'
(2718,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2719,8): run-time error CSS1035: Expected colon, found '{'
(2733,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2734,8): run-time error CSS1035: Expected colon, found '{'
(2748,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2749,8): run-time error CSS1035: Expected colon, found '{'
(2766,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2767,8): run-time error CSS1035: Expected colon, found '{'
(2784,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2785,8): run-time error CSS1035: Expected colon, found '{'
(2802,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2803,8): run-time error CSS1035: Expected colon, found '{'
(2820,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2821,8): run-time error CSS1035: Expected colon, found '{'
(2839,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2840,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '40%'
(2858,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2859,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '40%'
(2875,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2876,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '40%'
(2892,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2893,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '40%'
(2911,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2912,8): run-time error CSS1035: Expected colon, found '{'
(2926,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2927,8): run-time error CSS1035: Expected colon, found '{'
(2941,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2942,8): run-time error CSS1035: Expected colon, found '{'
(2956,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2957,8): run-time error CSS1035: Expected colon, found '{'
(2971,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2972,8): run-time error CSS1035: Expected colon, found '{'
(2986,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(2987,8): run-time error CSS1035: Expected colon, found '{'
(3001,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(3002,8): run-time error CSS1035: Expected colon, found '{'
(3016,1): run-time error CSS1019: Unexpected token, found '@keyframes'
(3017,8): run-time error CSS1035: Expected colon, found '{'
 */
@import url('https://fonts.googleapis.com/css?family=Montserrat:100,200,300,400,500,600,700,800,900');

/*Reset and Global Rules*/
body { position: relative; background-color: #fff; margin: 0; padding: 0; width: 100%; font-family: sans-serif; line-height: 1.5em; }

* { font-family: 'Montserrat',sans-serif; box-sizing: border-box; }

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6, p, div, span, a, label { line-height: normal; margin:0; padding:0; }

strike { opacity: 0.6; font-weight: 100; line-height: 0; font-style: italic; }

hr { float: left; clear: both; width: 100%; }

ul { padding-left: 40px }

label { font-weight: normal; display: inline-block; }

img { height: auto; max-width: 100%; }

a { color: #333; text-decoration: underline; }
    a:hover { color: #337ab7;  }

p a { text-decoration:none; }
    p a:hover { text-decoration:underline; }


h1 { font-size: 36px; color: #777777; font-weight: bold; }
h2 { font-size: 28px; color: #777777; font-weight: bold; }
h3 { font-size: 24px; color: #777777; font-weight: bold; }
h4 { font-size: 22px; color: #777777; font-weight: normal; }

p, ul, li, label { font-size: 20px; padding: 2px 0; }



@media only screen and (max-width: 1200px) {
    h1 { font-size: 32px; }
    h2 { font-size: 24px; }
    h3 { font-size: 20px; }
    h4 { font-size: 16px; }

    p, ul, li, label { font-size:16px; }
}

@media only screen and (max-width: 1024px) {

    p, ul, li, label { font-size:15px; }
}

@media only screen and (max-width: 768px) {
    h1 { font-size: 26px; }
    h2 { font-size: 23px; }
    h3 { font-size: 18px; }
    h4 { font-size: 16px; }

    p, ul, li, label { font-size:14px; }
}


@media only screen and (max-width: 600px) {
    h1 { font-size: 22px; }
    h2 { font-size: 20px; }
    h3 { font-size: 16px; }
    h4 { font-size: 15px; }

    /*p, ul, li, label { font-size:12px; }*/
}






.btn { font-size: 20px; line-height: normal; padding: 15px 30px; margin-top: 20px; display: inline-block; text-align: center; background-color:#39b54a; color: #fff; border-radius: 10px; text-decoration: none; transition: all ease-out .15s; }
    .btn:hover { color: #333; background-color: #66e077; box-shadow: 0 11px 17px -9px rgba(0,0,0,.75); text-decoration:none; }

@media only screen and (max-width: 1024px) {
    .btn { padding:10px 20px; }
}

@media only screen and (max-width: 768px) {
    .btn { font-size:18px; }
}



/*Animations*/
@keyframes FadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@keyframes FadeOut {
    0% { opacity: 1; }
    100% { opacity: 0; }
}

/*Link Animation*/
@keyframes portfolioSlide {
    from { background-position: 0 0; }
	to { background-position: 0 5000%; }
}

@keyframes portfolioSlide2 {
    from { background-position: 0 0; }
	to { background-position: 0 10000%; }
}


/*@keyframes arrowSlide {
    0% { background-position: left center; opacity: 0; }
    100% { background-position: right center; opacity: 1; }
}*/
/*.lazy-load { opacity: 0; }
    .lazy-load.lazy-load-data { opacity: 1; transition: opacity .5s ease; }*/


/*New Header Styles*/
.newHeader { 
    display:flex;
    flex-wrap:wrap;
    position:fixed;
    top:0;
    left:0;
    right:0;
    background:#fff;
}

    .newHeader .logo { 
        width:140px;
        margin-left:70px;
        margin-top:9px;
    }

    .newHeader .menu { 
        width:calc(100% - 445px);
        text-align:center;
        padding-top:28px;
    }

    .newHeader .info { 
        width:165px;
        margin-right:70px;
    }



/*Page Header*/
.header { float: left; clear: both; width: 100%; text-align: center; padding-bottom: 5px; }
    .header p { padding: 20px 60px; }

    .header ul li,
    .header ul li span,
    .header ul li a { font-size: 14px; }

    .header + .panel { padding-top: 40px; }

    .header .altNav { display: flex; justify-content: space-between; align-items: center; background-color: #777777; margin: 0 0 -35px; padding: 15px 40px; }

    .header ul.breadcrumbs { display: flex; align-items: center; list-style: none; width: auto; text-align: left; padding: 0; margin: 0; position: relative; z-index: 1; }
        .header ul.breadcrumbs li { display: inline-block; margin: 0; color: rgba(255,255,255,0.5); white-space: nowrap; padding: 0 2px; }
    .header .breadcrumbs li:before { display: none; }
    .header ul.breadcrumbs li span { padding: 0 2px; }
    .header ul.breadcrumbs a { color: #fff; text-decoration: underline; }


    /*Sub Page Navigation*/
    .header ul.subNavigation { display: flex; align-items: center; width: 45%; justify-content: flex-end; color: #fff; list-style: none; padding: 0; margin: 0; }
        .header ul.subNavigation li { display: inline-block; margin: 0; padding: 0 5px; border-right: 1px solid #fff; }
            .header ul.subNavigation li:last-of-type { border-right: none; padding-right: 0; }

            .header ul.subNavigation li > span { color: rgba(255,255,255,0.5); text-decoration: none; padding: 0 5px; }

            .header ul.subNavigation li a { color: #fff; text-decoration: none; }
                .header ul.subNavigation li a span { padding: 0 5px; }
                .header ul.subNavigation li a:hover { text-decoration: underline; }
            .header ul.subNavigation li:last-of-type a { border-right: none; }

    /*Page Icon*/
    .header > img { display: inline-block; margin: 0; padding: 0; width: 100px; height: 100px; background: #39b54a center center no-repeat; border: 5px solid #fff; border-radius: 50px; box-shadow: 0 10px 15px -10px rgba(0,0,0,.75); }

@media only screen and (max-width: 1480px) {
    .header .altNav { padding: 15px 20px; }
}

@media only screen and (max-width: 1366px) {
    .header ul.subNavigation li { padding: 0; }
}


@media only screen and (max-width: 1200px) {
    .header .altNav { display: block; margin: 0; }
    .header ul.breadcrumbs { width: 100%; margin-bottom: 10px; }
    .header ul.subNavigation { width: 100%; justify-content: flex-start; }
    .header > img { float: right; margin-top: -80px; margin-right: 20px; }

    .header ul.subNavigation li { padding: 0 10px; }
        .header ul.subNavigation li:nth-of-type(1) { padding-left: 0; }
}

@media only screen and (max-width: 992px) {
    .header p { padding: 20px; }
    .header > img { display: none; }

    .header ul.breadcrumbs { flex-wrap: wrap; }
        .header ul.breadcrumbs li { white-space: normal; }
    .header ul.subNavigation { flex-wrap: wrap; }
}

@media only screen and (max-width: 768px) {
    .header + .panel { padding-top: 10px; }

    .header ul li,
    .header ul li span,
    .header ul li a { font-size: 10px; }

    .header ul.subNavigation li { padding: 0 5px; }
}

@media only screen and (max-width: 600px) {

    .header ul.breadcrumbs { margin-bottom: 0; }
    .header ul.subNavigation { display: none; justify-content: center; }
    /*.header ul.subNavigation li { margin: 5px auto; text-align: center; width: 50%; }
            .header ul.subNavigation li:nth-of-type(even) { border: none; }*/
    .header ul li,
    .header ul li span,
    .header ul li a { font-size: 14px; }
}





/*.white { background-color: #ffffff; }*/
.grey { background-color: #EEEEEE; }

.panel { width: 100%; margin: 0; padding: 40px 60px 0; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; }

    .panel .subTitle h1,
    .panel .subTitle h2 { width: 100%; text-align: center; margin: 0; }
    .panel .subTitle h3 { width: 100%; text-align: center; margin: 0; color: #777777; }

    .panel .subTitle hr { height: auto; margin: 0; padding: 0; border: none; }
        .panel .subTitle hr:before { content: ""; display: block; width: 100%; max-width: 380px; margin: 10px auto; border-bottom: 5px solid #777; }






    .panel ul { padding: 2px 20px 2px 30px; }
        .panel ul li { list-style: none; position: relative; }
            .panel ul li:before { content: ''; width: 10px; height: 10px; background: #39b54a; border-radius: 10px; position: absolute; left: -18px; top: 9px; }   
            
            .panel ul.checkmarks li { margin-bottom:10px; }
            .panel ul.checkmarks li:before { content:"✔"; height:auto; width:auto; background:none; top:-2px; left:-25px; color:#39b54a; font-weight:bold; }

            .panel ul li a { text-decoration: none; }
                .panel ul li a:hover { text-decoration: underline; }

    .panel.top { align-items: flex-start; }

@media only screen and (max-width: 1600px) {
    .panel ul li:before { top: 8px; }
}

@media only screen and (max-width: 1366px) {
    .panel ul li:before { top: 6px; }
}






/*Home Page*/
.panel ul.list li { position: relative; list-style: none; padding: 5px 0 5px 20px; }
    .panel ul.list li:before { content: ""; display: block; width: 10px; height: 10px; border-radius: 50px; background-color: #39b54a; position: absolute; top: 14px; left: 0; }

    .panel ul.list li a { text-decoration: none; position: relative; letter-spacing: 1px; display: flex; align-items: center; }
        .panel ul.list li a:hover { color: #39b54a; text-shadow: -0.08ex 0 #39b54a, 0.08ex 0 #39b54a; }
/*.panel ul.list li a:hover:after { content: ""; position: absolute; right: 0; height: 50px; width: 50px; display: inline-block; background: transparent url("../../Images/2020/list-hover.png") right center no-repeat; background-size: contain; /*animation: arrowSlide; animation-duration: 0.5s;*/ }
*/
.panel ul.list li a p { padding: 0 40px 0 0; }



@media only screen and (max-width: 1600px) {
    .panel ul.list li:before { top: 11px }
}

@media only screen and (max-width: 1366px) {
    .panel { padding: 50px 40px; }
        .panel ul.list li:before { top: 9px }
}

@media only screen and (max-width: 1200px) {
    .panel { padding: 30px 15px; }
        .panel ul.list li:before { top: 9px }
}



.col-2 { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; width: 100%; }
    .col-2 > div { width: 50%; min-width: 320px; padding: 20px; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; }

.col-3 { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; width: 100%; }
    .col-3 > div { width: 32.33%; min-width: 320px; padding: 20px; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; }

.col-4 { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; width: 100%; }
    .col-4 > div { width: 25%; padding: 20px; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; }



@media only screen and (max-width: 768px) {
    .col-2 { flex-direction: column; }
    .col-3 { flex-direction: column; }
    .col-4 { flex-direction: column; }
}


@media only screen and (max-width: 500px) {
    .col-2 > div,
    .col-3 > div,
    .col-4 > div { min-width: 100%; padding: 20px 0; }
}




.grey { background:#eee; border-top:3px solid #1d2127; }
    .grey .col-3 { margin-top:30px; }
        .grey .col-3 div { background:#fff; border-radius:8px; box-shadow:5px 9px 8px #ccc; }
        .panel.Services.grey .col-3 div:nth-of-type(1) { padding-bottom:43px; }
        .panel.Services.grey .col-3 div:nth-of-type(3) { padding-bottom:43px; }
            .panel.Services.grey .col-3 div ul { margin:0; padding-left:19px !important; }
                
            .grey .col-3 div h4 { width:100%; text-align:center; padding:20px 0; }
            .grey .col-3 div p { padding-bottom:10px; }
            .grey .col-3 .btn { margin:60px auto; }



/*Panel / Row*/
.panel.col-2 > div { margin: 0 auto 60px; }
.panel.col-3 > div { margin: 0 0 60px; }

/*Details Container*/
.panel.col-2 div > div,
.panel.col-3 div > div,
.panel.col-4 div > div { width: 100%; border-left: 5px solid #39b54a; padding: 10px 0 10px 20px; min-height: 130px; margin-bottom: 30px; max-width: 730px; }

    /*Header / Link*/
    .panel.col-2 div > div h3,
    .panel.col-3 div > div h3,
    .panel.col-4 div > div h3 { float: left; clear: both; font-weight: bold; color: #333333; }

        .panel.col-2 div > div h3 span,
        .panel.col-3 div > div h3 span,
        .panel.col-4 div > div h3 span { color: #777777; }

        .panel.col-2 div > div h3 a,
        .panel.col-3 div > div h3 a,
        .panel.col-4 div > div h3 a { text-decoration: none; position: relative; display: flex; align-items: center; }

            .panel.col-2 div > div h3 a:hover,
            .panel.col-3 div > div h3 a:hover,
            .panel.col-4 div > div h3 a:hover { text-decoration: underline; color: #39b54a; }

    .panel.col-2 div > div .btn,
    .panel.col-3 div > div .btn,
    .panel.col-4 div > div .btn { margin: 30px 0 20px; font-size: 16px; padding: 15px 10px; }

    /*Description Paragraph*/
    .panel.col-2 div > div p,
    .panel.col-3 div > div p,
    .panel.col-4 div > div p { float: left; clear: both; padding: 15px 0 0; }

    /*Image / Link*/
    .panel.col-2 div > div + a,
    .panel.col-3 div > div + a,
    .panel.col-4 div > div + a { width: auto; }

        .panel.col-2 div img,
        .panel.col-3 div img,
        .panel.col-4 div img,
        .panel.col-2 div > div + a img,
        .panel.col-3 div > div + a img,
        .panel.col-4 div > div + a img { width: 80%; margin: 0 auto; display: block; }



@media only screen and (max-width: 1366px) {
    .panel.col-2 > div,
    .panel.col-3 > div { padding: 30px; }
    .panel.col-4 > div { padding: 30px; width: 50%; }

    .panel.col-2 div img,
    .panel.col-3 div img,
    .panel.col-4 div img,
    .panel.col-2 div > div + a img,
    .panel.col-3 div > div + a img,
    .panel.col-4 div > div + a img { max-width: 60%; }
}

@media only screen and (max-width: 1200px) {
}

@media only screen and (max-width: 1100px) {
    .panel.col-3 > div,
    .panel.col-4 > div { width: 50%; min-width: 0; }

    /*Image / Link*/
    .panel.col-2 div > div + a,
    .panel.col-3 div > div + a,
    .panel.col-4 div > div + a { position: absolute; z-index: -1; opacity: 0.10; max-width: 300px; }

    /*Image / Link*/
    .panel.col-2 div > div + img,
    .panel.col-3 div > div + img,
    .panel.col-4 div > div + img { position: absolute; z-index: -1; opacity: 0.10; max-width: 300px; }
}

@media only screen and (max-width:768px) {
    .panel.col-2 > div,
    .panel.col-3 > div,
    .panel.col-4 > div { width: 100%; margin: 0 auto; padding: 15px 0; min-height: 200px; }

    .panel.col-2 div > div,
    .panel.col-3 div > div,
    .panel.col-4 div > div { min-height: 0; }
}







/*Samples of Our Work*/
.panel.collage { padding: 0 0 30px; }
    .panel.collage div { border: none; }
    .panel.collage h2 { margin-top: 40px; }










.dual { display: flex; flex-direction: row; justify-content: space-between; flex-wrap: wrap; width: 100%; }
    .dual div { width: 50%; display: flex; flex-direction: column; align-items: center; }












.snapHeader { display: flex; width: 100%; }

    .snapHeader .fixed { position: fixed; top: 0; left: 0; right: 0; }








/*Header*/
/*Menu Structure*/
header { position: relative; z-index: 20; clear: both; width: 100%; /*max-width:1920px;*/ margin: 0 auto; padding: 0; }





.Navigation .elements { width: 100%; }

    /*Phone Styles*/
    .Navigation .elements .info { float: right; margin-bottom: 20px; clear: both; }
        .Navigation .elements .info img { display: inline-block; vertical-align: top; margin-top: 6px; margin-right: 20px; }
        .Navigation .elements .info a { background: #39b54a; display: inline-block; font-size: 20px; font-weight: 400; color: #fff; text-decoration: none; padding: 20px 40px; margin-left: -5px; border: 1px solid #0b9444; border-top: none; border-right: none; }
            .Navigation .elements .info a:first-of-type { border-radius: 0 0 0 10px; }
            .Navigation .elements .info a:last-of-type { padding-right: 60px; }
            .Navigation .elements .info a:hover { color: #333; }

        .Navigation .elements .info + div { display: flex; width: 100%; flex-direction: row; justify-content: flex-end; align-items: center; align-content: center; }


/*Snap Header Styles*/
/*Elements*/
.Navigation .fixed { position: fixed; top: 0; left: 0; right: 0; box-shadow: 0 0 15px #666; }
.Navigation .fixed { background-color: rgba(255,255,255,0.85); height: auto; }
    .Navigation .fixed .elements { padding-top: 0px; }
        .Navigation .fixed .elements .phone { display: none; }
        .Navigation .fixed .elements .info a { padding: 10px 40px; }
            .Navigation .fixed .elements .info a:nth-of-type(2) { }





/*----Responsive for Header----*/

@media only screen and (max-width: 1600px) {
    .Navigation .logo { max-width: 200px; margin-left: 40px; }
}

@media only screen and (max-width: 1450px) {
    .Navigation .companyMenu { right: 0; }
}

@media only screen and (max-width: 1400px) {
    .Navigation .logo { max-width: 180px; }
}

@media only screen and (max-width: 1240px) {
    .Navigation .logo { max-width: 170px; margin-left: 10px; }
    .menu ul.stMenu > li a { font-size: 16px; }
}

@media only screen and (max-width: 992px) {
    .Navigation .logo { max-width: 200px; margin-left: 30px; }
    .Navigation .elements form { margin-top: -5px; }

    .Navigation .elements .info a,
    .Navigation .elements .info a:last-of-type,
    .Navigation .fixed .elements .info a { font-size: 16px; font-weight: 500; padding: 10px; }
}

@media only screen and (max-width: 600px) {
    .Navigation { position: relative; background-color: #fff; flex-direction: column; width: 100%; align-items: center; justify-content: center; align-content: center; }

        .Navigation .standard,
        .Navigation .fixed { flex-direction: column; align-items: center; padding-top: 20px; }

        .Navigation .standard { position: absolute; top: 0; }

        .Navigation .logo { width: 100px; margin: 0; position: absolute; left: 15px; top: 10px; }
        .Navigation .fixed .logo img { width: 100%; }

        .Navigation .elements { width: 100%; display: flex; flex-direction: column-reverse; }
            .Navigation .elements .info { width: 100%; padding: 0 10px; display: flex; justify-content: space-between; margin: 10px 0; }
                .Navigation .elements .info a,
                .Navigation .elements .info a:first-of-type,
                .Navigation .elements .info a:last-of-type { display: flex; justify-content: center; align-items: center; font-size: 12px; width: 49%; text-align: center; border-radius: 5px; margin: 0; padding: 5px 1px; }

                .Navigation .elements .info + div { width: 100%; flex-direction: row-reverse; justify-content: space-between; }

            .Navigation .elements form input,
            .Navigation .elements form:focus input { width: calc(100% - 95px); background-color: rgba(204, 204, 204, 0.2); }
}















/*Content*/
main { clear: both; width: 100%; /*max-width:1920px;*/ margin: 0 auto; visibility: visible; position: relative; padding: 0; overflow: hidden; }
    main.contentPg { display: inline-block; padding: 182px 0 0; min-height: 100vh; }

@media only screen and (max-width: 1024px) {
    main.contentPg { padding-top: 145px; }
}



@media only screen and (max-width: 600px) {
    main { padding-top: 135px; }
}










/*Footer*/
/*----Footer Styles----*/

footer { background: #eeeeee; padding: 20px; }

    footer .footerStructure { width: 100%; display: flex; flex-wrap: wrap; justify-content: space-between; padding: 20px; position: relative; }

        footer .footerStructure ul { width: 100%; margin: 0 0 20px; padding: 0; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; }
            footer .footerStructure ul li { list-style: none; padding: 0 10px; }
                footer .footerStructure ul li:before { content: ""; display: inline-block; width: 10px; height: 10px; background-color: #39b54a; border-radius: 100%; margin-right: 10px; }
                footer .footerStructure ul li:nth-of-type(1):before { display: none; }

                footer .footerStructure ul li a { text-decoration: none; font-size: 18px }
                    footer .footerStructure ul li a:hover { text-decoration: underline; }

    footer div.footerStructure .chamber-img { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; text-align: center; padding: 0; width: 100%; margin: 0 auto; }
        footer div.footerStructure .chamber-img p { width: 100%; margin-bottom: 20px; }
        footer div.footerStructure .chamber-img div { display: inline-block; width: 150px; height: 100px; margin: 0 10px; background: transparent center bottom no-repeat; background-size: contain; }




@media only screen and (max-width: 768px) {
    footer .footerStructure ul li { width: 100%; text-align: center; padding: 10px; }
        footer .footerStructure ul li:before { display: none; }
}


/*footer div.footerStructure .cta { width: 100%; max-width: 200px; margin: 0; text-align: center; position: absolute; }
            footer div.footerStructure .cta.left { left: 50px; }
            footer div.footerStructure .cta.right { right: 50px; }



        footer div.footerStructure .btn { display: table; margin: 20px auto; padding: 10px; width: 100%; max-width: 180px; }*/




footer .base { width: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; border-top: 2px solid #e2e2e2; padding-top: 10px; margin: 20px 0; }
    footer .base > div { width: auto; padding: 20px; }

    footer .base p,
    footer .base a { font-size: 16px; margin: 0; padding: 5px 0; text-decoration: none; color: #777777; }
        footer .base a:hover { text-decoration: underline; }

    footer .base .pageLinks ul { margin: 0; padding: 0; list-style: none; display: flex; justify-content: center; align-items: center; }
        footer .base .pageLinks ul li { margin: 0; padding: 0 10px; font-size: 16px; }

    footer .base .links { text-align: right; }



@media only screen and (max-width: 992px) {
    footer .base > div { width: 100%; text-align: center }
    footer .base .pageLinks ul { flex-wrap: wrap; }
        footer .base .pageLinks ul li { width: 100%; text-align: center; padding: 10px; }

    footer .base .links { text-align: center; }
}






footer.footerContent { clear: both; width: 100%; margin: 0 auto; padding: 0 10px 10px; background: #eeeeee; font-size: 18px; position: relative; z-index: 19; }

    footer.footerContent a { text-decoration: none; }
        footer.footerContent a:hover { text-decoration: underline; }

    footer.footerContent .btn { width: 100%; max-width: 240px; margin: 10px 0; }
        footer.footerContent .btn:hover { text-decoration: none; }

    footer.footerContent h2 { margin-bottom: 0; }


    /*New Styles*/
footer.footerContent { padding:0; }
    footer.footerContent .footerCTA { background:url('../../images/FooterCTA.jpg'); background-size:cover; padding:280px 0; }
        footer.footerContent .footerCTA h4 { text-align:center; font-size:40px; font-weight:600; color:#fff; }
            footer.footerContent .footerCTA h4 span { background: -webkit-linear-gradient(#bbd531, #4cb849); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
        footer.footerContent .footerCTA p {max-width:670px; display:block; margin:0 auto; color:#fff; text-align:center; padding-top:30px; padding-bottom:40px; }
        footer.footerContent .footerCTA .btn { margin:0 auto; display:table; }

    footer.footerContent .footerBottom { display:flex; flex-wrap:wrap; justify-content:space-between; background:#1d2127; padding: 30px 60px 20px; }
        footer.footerContent .footerBottom .links { color:#fff; }
            footer.footerContent .footerBottom .links a { color:#fff; }
        footer.footerContent .footerBottom .copyright p { color:#fff; }
        footer.footerContent .footerBottom .social a { width:30px; display:inline-block; margin-left:10px; }
            footer.footerContent .footerBottom .social a img { width:100%; }


    footer.footerContent .topRow,
    footer.footerContent .midRow,
    footer.footerContent .baseRow { display: flex; justify-content: space-evenly; flex-wrap: wrap; align-content: center; text-align: center; padding: 30px 20px; border-top: 2px solid #c4c4c4; }


    /*footer.footerContent Top Row*/

    footer.footerContent .topRow { justify-content: space-between; padding: 30px 60px; color: #777777; }

        footer.footerContent .topRow a { font-size: inherit; color: #777777; padding: 0 10px; }
            footer.footerContent .topRow a:hover { color: #000; }

@media only screen and (max-width: 1200px) {
    footer.footerContent .topRow { padding: 20px; }
        footer.footerContent .topRow div { width: 100%; padding: 10px 0; }
}


/*footer.footerContent Middle Row*/

footer.footerContent .midRow > div { margin: 0; padding: 0; width: 33.333%; }

    /*Middle - Left*/
    footer.footerContent .midRow > div:nth-of-type(1) { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; }
        footer.footerContent .midRow > div:nth-of-type(1) img { width: 100%; max-width: 130px; margin: 10px 25px; height: initial; }

    /*Middle - Center*/
    footer.footerContent .midRow > div:nth-of-type(2) { display: flex; justify-content: center; flex-wrap: wrap; align-items: center; border-right: 2px solid #c4c4c4; border-left: 2px solid #c4c4c4; }
        footer.footerContent .midRow > div:nth-of-type(2) > div { width: 100%; text-align: left; padding: 0 20px; }
            footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type { width: auto; display: flex; flex-direction: column; }


footer.footerContent .pageLinks ul { margin: 0; padding: 0; list-style: none; display: flex; align-items: center; flex-wrap: wrap; }
    footer.footerContent .pageLinks ul li { margin: 0; padding: 10px; font-size: 14px; width: 50%; }
        footer.footerContent .pageLinks ul li .btn { margin: 0; padding: 5px; background-color: #39b54a; }
            footer.footerContent .pageLinks ul li .btn:hover { background-color: #66e077; }


@media only screen and (max-width: 1700px) {
    footer.footerContent .midRow > div { width: 50%; }
        footer.footerContent .midRow > div:nth-of-type(2) { border-right: none; }
        footer.footerContent .midRow > div:last-of-type { width: 100%; }

    footer.footerContent .pageLinks ul li { width: 16%; margin: 20px auto 0; }
}

@media only screen and (max-width: 1400px) {
    footer.footerContent .pageLinks ul li { width: 33%; margin: 10px auto 0; }
}

@media only screen and (max-width: 1200px) {
    footer.footerContent .midRow > div { width: 100%; }
        footer.footerContent .midRow > div:nth-of-type(2) { border: none; padding: 20px; text-align: center; }

            footer.footerContent .midRow > div:nth-of-type(2) p { text-align: center; width: 100%; max-width: 800px; }

    footer.footerContent .pageLinks ul li { width: 33%; margin: 10px auto 0; }
}

@media only screen and (max-width: 768px) {
    footer.footerContent .pageLinks ul li { width: 50%; }
}

@media only screen and (max-width: 500px) {
    footer.footerContent .pageLinks ul li { width: 100%; margin: 0 auto 5px; }
}


/*footer.footerContent Bottom Row*/
footer.footerContent .baseRow { padding: 30px 20px; }
    footer.footerContent .baseRow > div { margin: 0; padding: 0; }

footer.footerContent .baseRow { align-items: flex-end; font-size: 14px; }
    footer.footerContent .baseRow p { font-size: inherit; margin: 0; padding: 0; }



@media only screen and (max-width: 600px) {
    footer.footerContent .baseRow { padding: 20px; }
        footer.footerContent .baseRow .copyright { width: calc(100% - 200px); text-align: center; }
}








/*@media only screen and (max-width: 1480px) {
    footer.footerContent .topRow,
    footer.footerContent .midRow,
    footer.footerContent .baseRow { padding: 40px 20px; }
}

@media only screen and (max-width: 1366px) {
    footer.footerContent .btn { max-width: 220px; padding: 20px 10px; }
}

@media only screen and (max-width: 1200px) {
    footer.footerContent { font-size: 16px; }
        footer.footerContent .midRow > div:nth-of-type(2) > div { padding: 0 10px; }

        footer.footerContent .midRow > div:nth-of-type(2) > div { width: 100%; }
            footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type { flex-direction: row; align-items: flex-end; }
                footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type img { width: 50%; margin: 0 auto; }


        footer.footerContent .midRow > div:nth-of-type(3) .social img { max-width: 50px; }

        footer.footerContent .baseRow > div { width: 100%; padding: 0 0 30px; }
            footer.footerContent .baseRow > div:last-of-type { padding: 0; }
}

@media only screen and (max-width: 992px) {
    footer.footerContent .topRow div:nth-of-type(1) { width: 100%; margin-bottom: 20px; }

    footer.footerContent .topRow div:nth-of-type(2) { width: 100%; }

        footer.footerContent .topRow div:nth-of-type(1) a,
        footer.footerContent .topRow div:nth-of-type(2) a,
        footer.footerContent .topRow div:nth-of-type(3) a { padding: 0 5px; border: none; }

    footer.footerContent .midRow > div { width: 50%; }
        footer.footerContent .midRow > div:nth-of-type(1) { width: 100%; border-bottom: 1px solid #c4c4c4; padding-bottom: 40px; }
        footer.footerContent .midRow > div:nth-of-type(1) { display: flex; justify-content: center; }
            footer.footerContent .midRow > div:nth-of-type(1) a { margin: 0 10px; }

        footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type { flex-direction: column; }
        footer.footerContent .midRow > div:nth-of-type(2) { border-left: none; border-right: 1px solid #c4c4c4; margin: 20px 0; padding: 20px 0; }
            footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type img { margin-bottom: 10px; }
                footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type img:last-of-type { margin-bottom: 0; }
            footer.footerContent .midRow > div:nth-of-type(2) p { margin-top: 10px; }

    footer.footerContent .baseRow { padding: 20px; }
        footer.footerContent .baseRow > div { margin: 10px auto; }
}

@media only screen and (max-width: 600px) {

    footer.footerContent .topRow,
    footer.footerContent .midRow,
    footer.footerContent .baseRow { padding: 40px 0; }

        footer.footerContent .topRow a { margin: 15px auto; font-size: 13px; }

        footer.footerContent .midRow > div { width: 100%; padding: 10px 0; }

            footer.footerContent .midRow > div:nth-of-type(1) { flex-wrap: wrap; padding-bottom: 10px; }
                footer.footerContent .midRow > div:nth-of-type(1) a { margin: 10px auto; }

            footer.footerContent .midRow > div:nth-of-type(2) { width: 100%; border-right: none; border-bottom: 1px solid #c4c4c4; margin: 0; }
                footer.footerContent .midRow > div:nth-of-type(2) > div { max-width: 100%; }
                    footer.footerContent .midRow > div:nth-of-type(2) > div:first-of-type { flex-direction: row; }

                footer.footerContent .midRow > div:nth-of-type(2) > div { text-align: center; }

    footer.footerContent .pageLinks { padding-bottom: 0; }
        footer.footerContent .pageLinks ul { flex-wrap: wrap; }
            footer.footerContent .pageLinks ul li { width: 100%; margin: 0 0 15px; }
                footer.footerContent .pageLinks ul li:last-of-type { margin: 0; }
}*/











.portfolio,
.panel.col-2 div > .portfolio,
.panel.col-3 div > .portfolio,
.panel.col-4 div > .portfolio { display: flex; align-items: center; flex-direction: column; text-align: center; margin-bottom: 50px; background-color: #fff; width: 100%; max-width: 850px; position: relative; border: none; }

    .portfolio .monitor { width: 100%; position: relative; overflow: hidden; }

        .portfolio .monitor img,
        .panel .portfolio .monitor img { position: relative; z-index: 1; width: 100%; max-width: 902px; }

        .portfolio .monitor span { display: block; position: absolute; top: 0; bottom: 10px; right: 0; left: 0; }
            .portfolio .monitor span:after { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 0; background: #eee url('../../Images/2020/scroll-1.jpg') center 16px repeat-y; animation: portfolioSlide 1800s linear infinite; background-size: cover; }

    .portfolio .tablet { width: 100%; max-width: 30%; overflow: hidden; position: absolute; z-index: 1; right: 0px; bottom: 100px; border-radius: 12px; }

        .portfolio .tablet img,
        .panel .portfolio .tablet img { position: relative; z-index: 1; width: 100%; max-width: 264px; }

        .portfolio .tablet span { display: block; position: absolute; top: 0; bottom: 10px; right: 0; left: 0; }
            .portfolio .tablet span:after { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 0; background: #eee url('../../Images/2020/scroll-2.jpg') center top repeat-y; animation: portfolioSlide2 1800s linear infinite; background-size: cover; }





@media only screen and (max-width: 1024px) {
    .portfolio .tablet { bottom: 60px; }
}

@media only screen and (max-width:768px) {
    .portfolio .tablet { border-radius: 7px; }
}









.ppt-form .grey { background-color: #fff !important; }
.ppt-form .wrapper .form-custom-fields td:first-child,
.ppt-form .wrapper .form-captcha td:first-child { width: auto !important; vertical-align: middle; text-align: right; }









/*Testimonials*/
.panel.testimonials { width: 100%; padding-left: 0; padding-right: 0; padding-top: 50px; padding-bottom: 50px; }
    .panel.testimonials .btn { margin-top: 0; }
    .panel.testimonials .col-2 > div { padding: 0; }



        /*Left Column*/
        .panel.testimonials .col-2 > div:nth-of-type(1) { padding-right: 30px; }
            .panel.testimonials .col-2 > div:nth-of-type(1) > div { width: 100%; padding: 20px 0; border-bottom: 2px solid #777777; text-align: right; display: flex; justify-content: flex-end; align-items: center; }

                .panel.testimonials .col-2 > div:nth-of-type(1) > div p { color: #777777; text-align: left; }
                .panel.testimonials .col-2 > div:nth-of-type(1) > div h2 { color: #39b54a; font-weight: bold; font-style: italic; margin-right: 20px; font-size: 36px; width: auto; }
                .panel.testimonials .col-2 > div:nth-of-type(1) > div:last-of-type { border-bottom: 0; }



        /*Right Column*/
        .panel.testimonials .col-2 > div:nth-of-type(2) { padding-left: 30px; }

        .panel.testimonials .col-2 > div:nth-of-type(2) { position: relative; text-align: center; margin-top: 57px; user-select: none; }

            .panel.testimonials .col-2 > div:nth-of-type(2) input[type=radio],
            .panel.testimonials .col-2 > div:nth-of-type(2) input[type=radio] + div { display: none; overflow: hidden; width: 100%; }
                .panel.testimonials .col-2 > div:nth-of-type(2) input[type=radio]:checked + div { display: flex; flex-wrap: wrap; align-items: center; }

            .panel.testimonials .col-2 > div:nth-of-type(2) h2 { width: 100%; font-weight: 900; text-align: center; margin-bottom: 20px; }
                .panel.testimonials .col-2 > div:nth-of-type(2) h2 + div { /*border-top: 2px solid #777777; border-bottom: 2px solid #777777;*/ padding: 30px 0; width: 100%; }
                    .panel.testimonials .col-2 > div:nth-of-type(2) h2 + div p { padding: 30px; width: 75%; margin: 0 auto; }

            .panel.testimonials .col-2 > div:nth-of-type(2) label.arrow { width: 50px; height: 50px; background: transparent center center no-repeat; background-size: contain; position: absolute; top: 50%; }
                .panel.testimonials .col-2 > div:nth-of-type(2) label.arrow.left { left: 40px; background-image: url("../../Images/2020/testimonial-left.png"); cursor: pointer }
                    .panel.testimonials .col-2 > div:nth-of-type(2) label.arrow.left:hover { background-image: url("../../Images/2020/testimonial-left-hover.png"); }

                .panel.testimonials .col-2 > div:nth-of-type(2) label.arrow.right { right: 20px; background-image: url("../../Images/2020/testimonial-right.png"); cursor: pointer }
                    .panel.testimonials .col-2 > div:nth-of-type(2) label.arrow.right:hover { background-image: url("../../Images/2020/testimonial-right-hover.png"); }




@media only screen and (max-width: 1366px) {
    .panel.testimonials .col-2 > div:nth-of-type(2) h4 + div img { max-width: 40%; }
}

@media only screen and (max-width: 1200px) {
    .panel.testimonials .col-2 > div:nth-of-type(1) > div { padding: 15px 0; }
    .panel.testimonials .col-2 > div:nth-of-type(2) { margin-top: 6px; }
}


@media only screen and (max-width: 1024px) {

    .panel.testimonials .col-2 > div:nth-of-type(2) { margin-top: 25px; }
}

@media only screen and (max-width: 768px) {
    .panel.testimonials .col-2 { flex-direction: column; }
        .panel.testimonials .col-2 > div { width: 80%; margin: 0 auto; }

            .panel.testimonials .col-2 > div:nth-of-type(1) { padding: 0; }
                .panel.testimonials .col-2 > div:nth-of-type(1) > div { padding: 15px 0; }

            .panel.testimonials .col-2 > div:nth-of-type(2) { padding: 0; }
                .panel.testimonials .col-2 > div:nth-of-type(2) label.arrow.left { left: 0; }
}






.payment-summation { margin-top: 20px; }
    .payment-summation div > span { padding: 7px; }

@media only screen and (max-width: 500px) {
}



.projects {
  position: relative;
}

    .projects h3 { margin-top:60px; margin-bottom:60px; padding-left:60px; font-size:40px; }
        .projects h3 span { 
            background: -webkit-linear-gradient(#bbd531, #4cb849);
            -webkit-background-clip: text; 
            -webkit-text-fill-color: transparent;
        }

.projects .list {
    display: flex;
    gap: 8px;
    padding: 16px;
    list-style: none;
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

    .projects .list::-webkit-scrollbar { 
        display: none;
    }

    .projects .list .item {
        flex-shrink: 0;
        width: 38%;
        height: 60vh;
        background-color: #FFF;
        scroll-snap-align: center;
    }

        .projects .list .item .content {
            display: flex;
            align-items: flex-start;
            justify-content: center;
            height: 100%;
            font-family: sans-serif;
            font-size: 64px;
            font-weight: bold;
            flex-wrap:wrap;
            margin-left:60px;
        }

            .projects .list .item .content img { 
                width:100%;
                border-radius:10px;
            }

            .projects .list .item .content h4 { 
                width:100%;
                text-align:center;
                font-weight:600;
            }

            .projects .list .item .content .btn { 
                margin-top:0;
            }

        

    .projects .button {
      position: absolute;
      top:0;
      width: 3rem;
      height: 3rem;
      transform: translateY(-50%);
    }

    .projects .button--previous {
      right: 51.5rem;
      transform: rotate(180deg);
    }

    .projects .button--next {
      right: 32.5rem;
      top:23px;
    }


.carousel { 
    height:311px;
    padding:0;
    align-items:flex-start;
}

.image-carousel .image-group ul li img { border-radius:20px; margin:0 10px; }

    .loved {
        display:flex;
        flex-wrap:wrap;
        padding:60px;
        background:#eee;
        justify-content:space-between;
    }

        .loved > div { 
            width:100%;
            display:flex;
            flex-wrap:wrap;
            justify-content:space-between;
        }

            .loved > div > div { 
                width:48%;
            }

            .loved > div h3 { 
                font-size:40px;
                margin-bottom:40px;
            }

                .loved > div h3 span { 
                    background: -webkit-linear-gradient(#bbd531, #4cb849);
                    -webkit-background-clip: text; 
                    -webkit-text-fill-color: transparent;
                }

            .loved > div > p { 
                margin-bottom:60px;
            }

            .loved > div .numbers { 
                display:flex;
                flex-wrap:wrap;
            }

                .loved > div .numbers > div { 
                    width:50%;
                    margin-bottom:30px;
                }

                    .loved > div .numbers > div h4 { 
                        font-size:40px;
                        font-weight:600;
                        background: -webkit-linear-gradient(#bbd531, #4cb849);
                        -webkit-background-clip: text; 
                        -webkit-text-fill-color: transparent;
                    }

            .loved > div .card { 
                background:#fff;
                border-radius:10px;
                box-shadow:5px 9px 8px #ccc;
                padding:20px;
                width:32%;
                margin-bottom:30px;
            }

                .loved > div .card p:first-of-type { 
                    margin-bottom:30px;
                    font-size:17px;
                }

                .loved > div .card p span { 
                    font-weight:600;
                    color:#aaa;
                }


.subTitle h1 span { 
    background:-webkit-linear-gradient(#bbd531, #4cb849);
    -webkit-background-clip:text; 
    -webkit-text-fill-color:transparent;
}


.howItWorks { 
    padding:60px;
}

    .howItWorks h3 { 
        font-size:40px;
    }

        .howItWorks h3 span { 
            background:-webkit-linear-gradient(#bbd531, #4cb849);
            -webkit-background-clip:text; 
            -webkit-text-fill-color:transparent;
        }

    .howItWorks .line { 
        display:flex;
        flex-wrap:wrap;
        justify-content:space-between;
        margin-top:150px;
        position:relative;
        padding:0 100px;
    }

        .howItWorks .line:before { 
            content:'';
            display:block;
            width:100%;
            height:10px;
            background:url(../../Images/lineBG.png);
            position:absolute;
            top:-104px;
            left:0;
            right:0;
        }

        .howItWorks .line div { 
            width:22%;
            position:relative;
        }

            .howItWorks .line div:nth-of-type(1)::before { 
                content:'';
                display:block;
                height:121px;
                width:50px;
                background:url(../../Images/dot1.png);
                background-size:cover;
                position:absolute;
                top:-110px;
                left:0;
            }

            .howItWorks .line div:nth-of-type(2)::before { 
                content:'';
                display:block;
                height:121px;
                width:50px;
                background:url(../../Images/dot2.png);
                background-size:cover;
                position:absolute;
                top:-110px;
                left:0;
            }

            .howItWorks .line div:nth-of-type(3)::before { 
                content:'';
                display:block;
                height:121px;
                width:50px;
                background:url(../../Images/dot3.png);
                background-size:cover;
                position:absolute;
                top:-110px;
                left:0;
            }

            .howItWorks .line div:nth-of-type(4)::before { 
                content:'';
                display:block;
                height:121px;
                width:50px;
                background:url(../../Images/dot4.png);
                background-size:cover;
                position:absolute;
                top:-110px;
                left:0;
            }

            .howItWorks .line div h4 { 
                font-weight:600;
            }

            .howItWorks .line div p { 
                font-size:18px;
            }

    .howItWorks .btn {
        margin:60px auto 0;
        display:table;
    }
/*-- Default Navigation Rules --*/
.menu { user-select: none; }
    .menu ul { position: relative; width: auto; margin: 0; clear: both; padding: 0; list-style: none; z-index: 1; }
        .menu ul li { display: inline-block; text-align: left; margin: 0; padding: 0; }
            .menu ul li a { color: #333333; text-decoration: none; padding: 10px; margin: 0 40px 0 0; display: block; font-size: 20px; }
                .menu ul li a:hover { color: #000; }

        .menu ul.stMenu ul { display: none; width: auto; min-width: 200px; position: absolute; background-color: rgba(244,244,244,0.9); border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; overflow: hidden; }
        .menu ul.stMenu li:last-of-type ul { right: 0; }
        .menu ul.stMenu ul li { width: 100%; display: block; }
            .menu ul.stMenu ul li a { font-size: 18px; padding: 10px 10px; margin: 0; }
                .menu ul.stMenu ul li a:hover { background-color: #1c3f95; color: #fff; }
                    .menu ul.stMenu ul li a:hover span { color: #fff; }

        .menu ul.stMenu ul ul { position: relative; display: block; background: transparent; }
            .menu ul.stMenu ul ul li a { background: none; }
                .menu ul.stMenu ul ul li a:before { content: "-"; width: 15px; display: inline-block; }




    /*Mobile Device View*/
    .menu .mobileMenu { display: none; float: left; position: relative; width: 80px; padding-top: 5px; padding-left: 0; text-align: center; }
        .menu .mobileMenu::after { content: ""; display: inline-block; width: 50px; height: 51px; position: relative; background: transparent url('../../Images/Menu_Icons/menuIcon.png') center center no-repeat; background-size: contain; filter: grayscale(1); }



    .menu ul.stMobileMenu { display: none; float: left; clear: both; width: 100%; overflow: hidden; margin: 0 auto; position: fixed; top: 50px; left: 0; right: 0; bottom: 50px; background-color: #eee; padding: 0; z-index: 2; }

        .menu ul.stMobileMenu > li { float: left; display: block; width: 100%; background-color: #777; margin: 0; position: relative; border: 1px solid rgba(255,255,255,0.4); border-top: 0; }
            .menu ul.stMobileMenu > li a,
            .menu ul.stMobileMenu > li a span { color: #000; }

        .menu ul.stMobileMenu li div.subMenu > ul { position: absolute; width: auto; padding: 0 10px; display: none; overflow: auto; top: 45px; bottom: 0; right: 0; left: 0; background-color: #fefefe; background-color: rgba(254,254,254,0.9); box-shadow: 0 2px 5px -3px #000; }
            .menu ul.stMobileMenu li div.subMenu > ul ul { position: relative; top: 0; background: none; box-shadow: none; }
            .menu ul.stMobileMenu li div.subMenu > ul .subMenu::before { position: relative; z-index: 1; content: " "; float: left; clear: both; width: 100%; padding: 2px; text-align: left; background-color: #187096; color: #fff; font-size: 18px; }
        .menu ul.stMobileMenu li li { float: left; clear: both; width: 100%; color: #fff; list-style: none; padding: 0; }

            .menu ul.stMobileMenu li li a { padding: 15px 21px; position: relative; color: #333; margin: 0; font-size: 16px; }
                .menu ul.stMobileMenu li li a span { color: #333; }
                .menu ul.stMobileMenu li li a::before { content: " "; position: absolute; top: 0; left: 0; bottom: 0; width: 1px; background-color: #187096; }

            .menu ul.stMobileMenu li li:last-of-type a::before { bottom: 50%; }
            .menu ul.stMobileMenu li li a::after { content: " "; position: absolute; left: 0; bottom: 50%; width: 15px; height: 1px; background-color: #187096; }
            .menu ul.stMobileMenu li li a:hover { color: #045c80; background-color: #d2d2d2; }


        .menu ul.stMobileMenu > li:nth-of-type(odd) { background-color: #137aa5; }
        .menu ul.stMobileMenu > li:nth-of-type(even) { background-color: #137aa5; }


    /*Close Buttons*/
    .menu .callAndClose { display: none; float: left; width: 100%; position: fixed; top: 0; bottom: 0; left: 0; right: 0; z-index: 2; }
        .menu .callAndClose .callBtn { position: absolute; top: 0; text-align: center; width: 100%; background-color: #232323; height: 50px; padding-top: 7px; border-bottom: 1px solid #045779; }
            .menu .callAndClose .callBtn:hover { cursor: pointer; }
        .menu .callAndClose .closeBtn { position: absolute; bottom: 0; text-align: center; width: 100%; background-color: #045779; height: 50px; padding-top: 7px; border-top: 1px solid #fff; }
            .menu .callAndClose .closeBtn:hover { cursor: pointer; }

        .menu .callAndClose .callBtn::before { display: inline-block; content: url("../../Images/SVG/MMIcon_Call.svg"); width: 35px; }
        .menu .callAndClose .closeBtn::before { display: inline-block; content: url("../../Images/SVG/MMIcon_Close.svg"); width: 35px; }

        .menu .callAndClose .callBtn::after { display: inline-block; content: "Call Us"; color: #fff; font-size: 28px; text-shadow: 1px 1px 1px rgba(0,0,0,1); position: relative; top: -7px; padding: 0 10px; }
        .menu .callAndClose .closeBtn::after { display: inline-block; content: "Close"; color: #fff; font-size: 28px; text-shadow: 1px 1px 1px rgba(0,0,0,1); position: relative; top: -7px; padding: 0 10px; }

    .menu ul.stMobileMenu li a.activePg + .subMenu .closeSubMenu { position: absolute; z-index: 1; right: 10px; top: 12px; }
        .menu ul.stMobileMenu li a.activePg + .subMenu .closeSubMenu::before { display: inline-block; content: url("../../Images/SVG/MMIcon_Close.svg"); width: 50px; }
        .menu ul.stMobileMenu li a.activePg + .subMenu .closeSubMenu:hover { cursor: pointer; }

    .menu ul.stMobileMenu li a.activePg + .subMenu .subMenu { float: left; width: 100%; }
        .menu ul.stMobileMenu li a.activePg + .subMenu .subMenu ul { width: 100%; }
        .menu ul.stMobileMenu li a.activePg + .subMenu .subMenu .closeSubMenu { display: none; }

    .menu ul.stMobileMenu li a.activePg + .subMenu .currentPg { color: #4e4e4e; font-weight: bold; background: rgba(254,254,254,0.9); }

    /*Mobile Animations*/
    .menu ul.stMobileMenu > li:first-of-type > a,
    .menu ul.stMobileMenu > li:last-of-type > a,
    .menu ul.stMobileMenu > li > a { padding: 10px; margin: 0; font-size: px; background-color: #fff; }

        .menu ul.stMobileMenu > li > a:hover,
        .menu ul.stMobileMenu > li > a.activePg,
        .menu ul.stMobileMenu > li > a.activePg:hover { color: #000; background-color: #aaa; }

            .menu ul.stMobileMenu > li > a.activePg,
            .menu ul.stMobileMenu > li > a.activePg:hover { border: 3px groove #fff; }


    .menu ul.stMobileMenu li a.activePg + div.subMenu { display: inline-block; position: fixed; bottom: 0; right: 0; left: 0; top: 0; z-index: 1; padding: 0; }
        .menu ul.stMobileMenu li a.activePg + div.subMenu::before { position: relative; z-index: 1; content: attr(data-content); float: left; clear: both; width: 99%; padding: 10px; text-align: left; background-color: #39b54a; color: #fff; font-size: 20px; }
        .menu ul.stMobileMenu li a.activePg + div.subMenu::after { content: " "; display: block; position: absolute; top: 0px; right: 0; bottom: 0; left: 0; background-color: #1b84b1; background-color: rgba(35, 35, 35, 0.9); z-index: 0; }

        .menu ul.stMobileMenu li a.activePg + div.subMenu ul { display: inline-block; overflow-x: hidden; }


/*Responsive Rule Set*/
@media only screen and (max-width: 1480px) {
    .menu ul.stMenu > li { padding: 0 15px; }
        .menu ul.stMenu > li a,
        .menu ul.stMenu li li a { font-size: 18px; margin-right: 0; }
}


@media only screen and (max-width: 1300px) {
    .menu ul.stMenu > li { padding: 0 5px; }

        .menu ul.stMenu > li a,
        .menu ul.stMenu li li a { font-size: 16px; }
}


@media only screen and (max-width: 1024px) {
    .menu ul.stMenu > li a { padding: 10px; }

    .menu ul.stMenu > li a,
    .menu ul.stMenu li li a { font-size: 15px; }
}

@media only screen and (min-width: 993px) {
    .menu ul.stMenu { display: block; }
}

@media only screen and (max-width: 992px) {
    .menu ul.stMenu { display: none; }

    .menu .mobileMenu,
    .menu .mobileMenu::before { display: inline-block; cursor: pointer; }

    .menu.homePg div.mobileMenu { display: none; }
    .menu.homePg ul.stMobileMenu { display: block; }
}

@media only screen and (max-width: 992px) {

    .menu .mobileMenu,
    .menu .mobileMenu::before { top: -5px; }
}







@keyframes LoadIn {
    0% { opacity: 0; transform: scale(3); }
    100% { opacity: 1; transform: scale(1); }
}

@-webkit-keyframes LoadIn { /* Safari and Chrome */
    0% { opacity: 0; transform: scale(3); }
    100% { opacity: 1; transform: scale(1); }
}

@keyframes LoadOut {
    0% { opacity: 1; transform: scale(1); }
    100% { opacity: 0; transform: scale(3); }
}

@-webkit-keyframes LoadOut { /* Safari and Chrome */
    0% { opacity: 1; transform: scale(1); }
    100% { opacity: 0; transform: scale(3); }
}


.menu .stMobileMenu.showMenu { display: block; -moz-animation: LoadIn 0.15s both; -webkit-animation: LoadIn 0.15s both; animation: LoadIn 0.15s both; z-index: 100; overflow: auto; }
.menu .stMobileMenu.hideMenu { display: block; -moz-animation: LoadOut 0.15s both; -webkit-animation: LoadOut 0.15s both; animation: LoadOut 0.15s both; }


@keyframes FadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@-webkit-keyframes FadeIn { /* Safari and Chrome */
    0% { opacity: 0; }
    100% { opacity: 1; }
}

/*.menu ul.stMobileMenu > li > .subMenu.activeSubPg { -moz-animation:FadeIn .5s both; -webkit-animation: FadeIn .5s both; animation: FadeIn .5s both; }*/


@charset "UTF-8";

/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.5.2
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2017 Daniel Eden
 */

.animated {
  visibility:hidden;
  animation-duration: 1s;
  animation-fill-mode: both;
}

.animated.infinite {
  animation-iteration-count: infinite;
}

.animated.hinge {
  animation-duration: 2s;
}

.animated.flipOutX,
.animated.flipOutY,
.animated.bounceIn,
.animated.bounceOut {
  animation-duration: .75s;
}

@keyframes bounce {
  from, 20%, 53%, 80%, to {
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    transform: translate3d(0,0,0);
  }

  40%, 43% {
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    transform: translate3d(0,-4px,0);
  }
}

.bounce {
  animation-name: bounce;
  transform-origin: center bottom;
}

@keyframes flash {
  from, 50%, to {
    opacity: 1;
  }

  25%, 75% {
    opacity: 0;
  }
}

.flash {
  animation-name: flash;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@keyframes pulse {
  from {
    transform: scale3d(1, 1, 1);
  }

  50% {
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    transform: scale3d(1, 1, 1);
  }
}

.pulse {
  animation-name: pulse;
}

@keyframes rubberBand {
  from {
    transform: scale3d(1, 1, 1);
  }

  30% {
    transform: scale3d(1.25, 0.75, 1);
  }

  40% {
    transform: scale3d(0.75, 1.25, 1);
  }

  50% {
    transform: scale3d(1.15, 0.85, 1);
  }

  65% {
    transform: scale3d(.95, 1.05, 1);
  }

  75% {
    transform: scale3d(1.05, .95, 1);
  }

  to {
    transform: scale3d(1, 1, 1);
  }
}

.rubberBand {
  animation-name: rubberBand;
}

@keyframes shake {
  from, to {
    transform: translate3d(0, 0, 0);
  }

  10%, 30%, 50%, 70%, 90% {
    transform: translate3d(-10px, 0, 0);
  }

  20%, 40%, 60%, 80% {
    transform: translate3d(10px, 0, 0);
  }
}

.shake {
  animation-name: shake;
}

@keyframes headShake {
  0% {
    transform: translateX(0);
  }

  6.5% {
    transform: translateX(-6px) rotateY(-9deg);
  }

  18.5% {
    transform: translateX(5px) rotateY(7deg);
  }

  31.5% {
    transform: translateX(-3px) rotateY(-5deg);
  }

  43.5% {
    transform: translateX(2px) rotateY(3deg);
  }

  50% {
    transform: translateX(0);
  }
}

.headShake {
  animation-timing-function: ease-in-out;
  animation-name: headShake;
}

@keyframes swing {
  20% {
    transform: rotate3d(0, 0, 1, 15deg);
  }

  40% {
    transform: rotate3d(0, 0, 1, -10deg);
  }

  60% {
    transform: rotate3d(0, 0, 1, 5deg);
  }

  80% {
    transform: rotate3d(0, 0, 1, -5deg);
  }

  to {
    transform: rotate3d(0, 0, 1, 0deg);
  }
}

.swing {
  transform-origin: top center;
  animation-name: swing;
}

@keyframes tada {
  from {
    transform: scale3d(1, 1, 1);
  }

  10%, 20% {
    transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
  }

  30%, 50%, 70%, 90% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }

  40%, 60%, 80% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }

  to {
    transform: scale3d(1, 1, 1);
  }
}

.tada {
  animation-name: tada;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@keyframes wobble {
  from {
    transform: none;
  }

  15% {
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }

  30% {
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }

  45% {
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }

  60% {
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }

  75% {
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }

  to {
    transform: none;
  }
}

.wobble {
  animation-name: wobble;
}

@keyframes jello {
  from, 11.1%, to {
    transform: none;
  }

  22.2% {
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }

  33.3% {
    transform: skewX(6.25deg) skewY(6.25deg);
  }

  44.4% {
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }

  55.5% {
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }

  66.6% {
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }

  77.7% {
    transform: skewX(0.390625deg) skewY(0.390625deg);
  }

  88.8% {
    transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
  }
}

.jello {
  animation-name: jello;
  transform-origin: center;
}

@keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    transform: scale3d(.3, .3, .3);
  }

  20% {
    transform: scale3d(1.1, 1.1, 1.1);
  }

  40% {
    transform: scale3d(.9, .9, .9);
  }

  60% {
    opacity: 1;
    transform: scale3d(1.03, 1.03, 1.03);
  }

  80% {
    transform: scale3d(.97, .97, .97);
  }

  to {
    opacity: 1;
    transform: scale3d(1, 1, 1);
  }
}

.bounceIn {
  animation-name: bounceIn;
}

@keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    transform: translate3d(0, -3000px, 0);
  }

  60% {
    opacity: 1;
    transform: translate3d(0, 25px, 0);
  }

  75% {
    transform: translate3d(0, -10px, 0);
  }

  90% {
    transform: translate3d(0, 5px, 0);
  }

  to {
    transform: none;
  }
}

.bounceInDown {
  animation-name: bounceInDown;
}

@keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  0% {
    opacity: 0;
    transform: translate3d(-3000px, 0, 0);
  }

  60% {
    opacity: 1;
    transform: translate3d(25px, 0, 0);
  }

  75% {
    transform: translate3d(-10px, 0, 0);
  }

  90% {
    transform: translate3d(5px, 0, 0);
  }

  to {
    transform: none;
  }
}

.bounceInLeft {
  animation-name: bounceInLeft;
}

@keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  from {
    opacity: 0;
    transform: translate3d(3000px, 0, 0);
  }

  60% {
    opacity: 1;
    transform: translate3d(-25px, 0, 0);
  }

  75% {
    transform: translate3d(10px, 0, 0);
  }

  90% {
    transform: translate3d(-5px, 0, 0);
  }

  to {
    transform: none;
  }
}

.bounceInRight {
  animation-name: bounceInRight;
}

@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  }

  from {
    opacity: 0;
    transform: translate3d(0, 3000px, 0);
  }

  60% {
    opacity: 1;
    transform: translate3d(0, -20px, 0);
  }

  75% {
    transform: translate3d(0, 10px, 0);
  }

  90% {
    transform: translate3d(0, -5px, 0);
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

.bounceInUp {
  animation-name: bounceInUp;
}

@keyframes bounceOut {
  20% {
    transform: scale3d(.9, .9, .9);
  }

  50%, 55% {
    opacity: 1;
    transform: scale3d(1.1, 1.1, 1.1);
  }

  to {
    opacity: 0;
    transform: scale3d(.3, .3, .3);
  }
}

.bounceOut {
  animation-name: bounceOut;
}

@keyframes bounceOutDown {
  20% {
    transform: translate3d(0, 10px, 0);
  }

  40%, 45% {
    opacity: 1;
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0);
  }
}

.bounceOutDown {
  animation-name: bounceOutDown;
}

@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    transform: translate3d(20px, 0, 0);
  }

  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0);
  }
}

.bounceOutLeft {
  animation-name: bounceOutLeft;
}

@keyframes bounceOutRight {
  20% {
    opacity: 1;
    transform: translate3d(-20px, 0, 0);
  }

  to {
    opacity: 0;
    transform: translate3d(2000px, 0, 0);
  }
}

.bounceOutRight {
  animation-name: bounceOutRight;
}

@keyframes bounceOutUp {
  20% {
    transform: translate3d(0, -10px, 0);
  }

  40%, 45% {
    opacity: 1;
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0);
  }
}

.bounceOutUp {
  animation-name: bounceOutUp;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.fadeIn {
  animation-name: fadeIn;
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInDown {
  animation-name: fadeInDown;
}

@keyframes fadeInDownBig {
  from {
    opacity: 0;
    transform: translate3d(0, -2000px, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInDownBig {
  animation-name: fadeInDownBig;
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translate3d(-100%, 0, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInLeft {
  animation-name: fadeInLeft;
}

@keyframes fadeInLeftBig {
  from {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInLeftBig {
  animation-name: fadeInLeftBig;
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translate3d(100%, 0, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInRight {
  animation-name: fadeInRight;
}

@keyframes fadeInRightBig {
  from {
    opacity: 0;
    transform: translate3d(2000px, 0, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInRightBig {
  animation-name: fadeInRightBig;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInUp {
  animation-name: fadeInUp;
}

@keyframes fadeInUpBig {
  from {
    opacity: 0;
    transform: translate3d(0, 2000px, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInUpBig {
  animation-name: fadeInUpBig;
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

.fadeOut {
  animation-name: fadeOut;
}

@keyframes fadeOutDown {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
  }
}

.fadeOutDown {
  animation-name: fadeOutDown;
}

@keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0);
  }
}

.fadeOutDownBig {
  animation-name: fadeOutDownBig;
}

@keyframes fadeOutLeft {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(-100%, 0, 0);
  }
}

.fadeOutLeft {
  animation-name: fadeOutLeft;
}

@keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0);
  }
}

.fadeOutLeftBig {
  animation-name: fadeOutLeftBig;
}

@keyframes fadeOutRight {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(100%, 0, 0);
  }
}

.fadeOutRight {
  animation-name: fadeOutRight;
}

@keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(2000px, 0, 0);
  }
}

.fadeOutRightBig {
  animation-name: fadeOutRightBig;
}

@keyframes fadeOutUp {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
  }
}

.fadeOutUp {
  animation-name: fadeOutUp;
}

@keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0);
  }
}

.fadeOutUpBig {
  animation-name: fadeOutUpBig;
}

@keyframes flip {
  from {
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    animation-timing-function: ease-out;
  }

  40% {
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    animation-timing-function: ease-out;
  }

  50% {
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    animation-timing-function: ease-in;
  }

  80% {
    transform: perspective(400px) scale3d(.95, .95, .95);
    animation-timing-function: ease-in;
  }

  to {
    transform: perspective(400px);
    animation-timing-function: ease-in;
  }
}

.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  animation-name: flip;
}

@keyframes flipInX {
  from {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    animation-timing-function: ease-in;
  }

  60% {
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }

  80% {
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }

  to {
    transform: perspective(400px);
  }
}

.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  animation-name: flipInX;
}

@keyframes flipInY {
  from {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    animation-timing-function: ease-in;
  }

  60% {
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }

  80% {
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }

  to {
    transform: perspective(400px);
  }
}

.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  animation-name: flipInY;
}

@keyframes flipOutX {
  from {
    transform: perspective(400px);
  }

  30% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }

  to {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}

.flipOutX {
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@keyframes flipOutY {
  from {
    transform: perspective(400px);
  }

  30% {
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }

  to {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}

.flipOutY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  animation-name: flipOutY;
}

@keyframes lightSpeedIn {
  from {
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }

  60% {
    transform: skewX(20deg);
    opacity: 1;
  }

  80% {
    transform: skewX(-5deg);
    opacity: 1;
  }

  to {
    transform: none;
    opacity: 1;
  }
}

.lightSpeedIn {
  animation-name: lightSpeedIn;
  animation-timing-function: ease-out;
}

@keyframes lightSpeedOut {
  from {
    opacity: 1;
  }

  to {
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}

.lightSpeedOut {
  animation-name: lightSpeedOut;
  animation-timing-function: ease-in;
}

@keyframes rotateIn {
  from {
    transform-origin: center;
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0;
  }

  to {
    transform-origin: center;
    transform: none;
    opacity: 1;
  }
}

.rotateIn {
  animation-name: rotateIn;
}

@keyframes rotateInDownLeft {
  from {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }

  to {
    transform-origin: left bottom;
    transform: none;
    opacity: 1;
  }
}

.rotateInDownLeft {
  animation-name: rotateInDownLeft;
}

@keyframes rotateInDownRight {
  from {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    transform-origin: right bottom;
    transform: none;
    opacity: 1;
  }
}

.rotateInDownRight {
  animation-name: rotateInDownRight;
}

@keyframes rotateInUpLeft {
  from {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    transform-origin: left bottom;
    transform: none;
    opacity: 1;
  }
}

.rotateInUpLeft {
  animation-name: rotateInUpLeft;
}

@keyframes rotateInUpRight {
  from {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0;
  }

  to {
    transform-origin: right bottom;
    transform: none;
    opacity: 1;
  }
}

.rotateInUpRight {
  animation-name: rotateInUpRight;
}

@keyframes rotateOut {
  from {
    transform-origin: center;
    opacity: 1;
  }

  to {
    transform-origin: center;
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0;
  }
}

.rotateOut {
  animation-name: rotateOut;
}

@keyframes rotateOutDownLeft {
  from {
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }
}

.rotateOutDownLeft {
  animation-name: rotateOutDownLeft;
}

@keyframes rotateOutDownRight {
  from {
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

.rotateOutDownRight {
  animation-name: rotateOutDownRight;
}

@keyframes rotateOutUpLeft {
  from {
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

.rotateOutUpLeft {
  animation-name: rotateOutUpLeft;
}

@keyframes rotateOutUpRight {
  from {
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0;
  }
}

.rotateOutUpRight {
  animation-name: rotateOutUpRight;
}

@keyframes hinge {
  0% {
    transform-origin: top left;
    animation-timing-function: ease-in-out;
  }

  20%, 60% {
    transform: rotate3d(0, 0, 1, 80deg);
    transform-origin: top left;
    animation-timing-function: ease-in-out;
  }

  40%, 80% {
    transform: rotate3d(0, 0, 1, 60deg);
    transform-origin: top left;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }

  to {
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}

.hinge {
  animation-name: hinge;
}

@keyframes jackInTheBox {
  from {
    opacity: 0;
    transform: scale(0.1) rotate(30deg);
    transform-origin: center bottom;
  }

  50% {
    transform: rotate(-10deg);
  }

  70% {
    transform: rotate(3deg);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

.jackInTheBox {
  animation-name: jackInTheBox;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@keyframes rollIn {
  from {
    opacity: 0;
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.rollIn {
  animation-name: rollIn;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@keyframes rollOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
  }
}

.rollOut {
  animation-name: rollOut;
}

@keyframes zoomIn {
  from {
    opacity: 0;
    transform: scale3d(.3, .3, .3);
  }

  50% {
    opacity: 1;
  }
}

.zoomIn {
  animation-name: zoomIn;
}

@keyframes zoomInDown {
  from {
    opacity: 0;
    transform: scale3d(.1, .1, .1) translate3d(0, -1000px, 0);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInDown {
  animation-name: zoomInDown;
}

@keyframes zoomInLeft {
  from {
    opacity: 0;
    transform: scale3d(.1, .1, .1) translate3d(-1000px, 0, 0);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(10px, 0, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInLeft {
  animation-name: zoomInLeft;
}

@keyframes zoomInRight {
  from {
    opacity: 0;
    transform: scale3d(.1, .1, .1) translate3d(1000px, 0, 0);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(-10px, 0, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInRight {
  animation-name: zoomInRight;
}

@keyframes zoomInUp {
  from {
    opacity: 0;
    transform: scale3d(.1, .1, .1) translate3d(0, 1000px, 0);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  60% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomInUp {
  animation-name: zoomInUp;
}

@keyframes zoomOut {
  from {
    opacity: 1;
  }

  50% {
    opacity: 0;
    transform: scale3d(.3, .3, .3);
  }

  to {
    opacity: 0;
  }
}

.zoomOut {
  animation-name: zoomOut;
}

@keyframes zoomOutDown {
  40% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(0, -60px, 0);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  to {
    opacity: 0;
    transform: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
    transform-origin: center bottom;
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomOutDown {
  animation-name: zoomOutDown;
}

@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(42px, 0, 0);
  }

  to {
    opacity: 0;
    transform: scale(.1) translate3d(-2000px, 0, 0);
    transform-origin: left center;
  }
}

.zoomOutLeft {
  animation-name: zoomOutLeft;
}

@keyframes zoomOutRight {
  40% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(-42px, 0, 0);
  }

  to {
    opacity: 0;
    transform: scale(.1) translate3d(2000px, 0, 0);
    transform-origin: right center;
  }
}

.zoomOutRight {
  animation-name: zoomOutRight;
}

@keyframes zoomOutUp {
  40% {
    opacity: 1;
    transform: scale3d(.475, .475, .475) translate3d(0, 60px, 0);
    animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  }

  to {
    opacity: 0;
    transform: scale3d(.1, .1, .1) translate3d(0, -2000px, 0);
    transform-origin: center bottom;
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.320, 1);
  }
}

.zoomOutUp {
  animation-name: zoomOutUp;
}

@keyframes slideInDown {
  from {
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

.slideInDown {
  animation-name: slideInDown;
}

@keyframes slideInLeft {
  from {
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

.slideInLeft {
  animation-name: slideInLeft;
}

@keyframes slideInRight {
  from {
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

.slideInRight {
  animation-name: slideInRight;
}

@keyframes slideInUp {
  from {
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

.slideInUp {
  animation-name: slideInUp;
}

@keyframes slideOutDown {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    transform: translate3d(0, 100%, 0);
  }
}

.slideOutDown {
  animation-name: slideOutDown;
}

@keyframes slideOutLeft {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    transform: translate3d(-100%, 0, 0);
  }
}

.slideOutLeft {
  animation-name: slideOutLeft;
}

@keyframes slideOutRight {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    transform: translate3d(100%, 0, 0);
  }
}

.slideOutRight {
  animation-name: slideOutRight;
}

@keyframes slideOutUp {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    transform: translate3d(0, -100%, 0);
  }
}

.slideOutUp {
  animation-name: slideOutUp;
}

