html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside,
canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

body {
    line-height: 1;
    font-family: 'Roboto', Roboto, 'Segoe UI', sans-serif;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

    blockquote:before,
    blockquote:after,
    q:before,
    q:after {
        content: '';
        content: none;
    }

table {
    border-collapse: collapse;
    border-spacing: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

.clearfix {
    *zoom: 1;
}

    .clearfix:before, .clearfix:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

.noselect {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    cursor: default;
}

.title-header1 {
    font-size: 9.2em;
    color: #23252D;
    line-height: 1.24em;
    font-family: 'Dancing Script', cursive;
}

@media screen and (min-width: 1280px) and (max-width: 1439px) {
    .title-header1 {
        font-size: 6.2em;
    }
}

@media screen and (min-width: 768px) and (max-width: 1279px) {
    .title-header1 {
        font-size: 5.2em;
    }
}

@media screen and (min-width: 0) and (max-width: 399px) {
    .title-header1 {
        font-size: 3.5em;
    }
}

@media screen and (min-width: 400px) and (max-width: 499px) {
    .title-header1 {
        font-size: 4.6em;
    }
}

@media screen and (min-width: 500px) and (max-width: 767px) {
    .title-header1 {
        font-size: 4.8em;
    }
}

.title-header1.white {
    color: #fff;
}

.title-header1 .block-revealer__element {
    top: 5px;
    height: calc(100% - 10px);
}

.title-header2 {
    font-size: 5.8em;
    color: #23252D;
    line-height: 1.3em;
    font-weight: 300;
}

@media screen and (min-width: 1280px) and (max-width: 1439px) {
    .title-header2 {
        font-size: 4.2em;
    }
}

@media screen and (min-width: 768px) and (max-width: 1279px) {
    .title-header2 {
        font-size: 3.6em;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .title-header2 {
        font-size: 3.0em;
    }
}

.title-header2.white {
    color: #fff;
}

.title-header2 .block-revealer__element {
    top: 5px;
    height: calc(100% + 10px);
}

.title-header3 {
    font-size: 2.4em;
    color: #23252D;
    line-height: 1.54em;
    font-weight: 300;
}

@media screen and (min-width: 0) and (max-width: 1279px) {
    .title-header3 {
        font-size: 1.8em;
    }
}

.title-header3.white {
    color: #fff;
}

.title-header4 {
    font-size: 3.6em;
    color: #23252D;
    line-height: 1.1em;
    font-weight: 300;
}

@media screen and (min-width: 0) and (max-width: 1279px) {
    .title-header4 {
        font-size: 2.8em;
    }
}

.title-header4.white {
    color: #fff;
}

.title-tag {
    font-size: 1.3em;
    color: #23252D;
    line-height: 1.1em;
    font-weight: 300;
    letter-spacing: 0.3em;
    text-transform: uppercase;
}

@media screen and (min-width: 0) and (max-width: 1279px) {
    .title-tag {
        font-size: 1.2em;
        letter-spacing: 0.3em;
    }
}

.title-tag.white {
    color: #fff;
}

.title-button {
    font-size: 1.1em;
    line-height: 1.1em;
    font-weight: 300;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

@media screen and (min-width: 0) and (max-width: 1279px) {
    .title-button {
        font-size: 1em;
        letter-spacing: 0.1em;
    }
}

.title-button.white {
    color: #fff;
}

.txt-p1 p, .txt-p1 ul {
    font-size: 2.1em;
    color: #23252D;
    line-height: 1.6em;
    font-weight: 300;
    padding-bottom: 8px;
}

@media screen and (min-width: 0) and (max-width: 1279px) {
    .txt-p1 p, .txt-p1 ul {
        font-size: 1.6em;
    }
}

.txt-p1.white p {
    color: #fff;
}

.txt-p2 p, .txt-p2 ul {
    font-size: 2.4em;
    color: #23252D;
    line-height: 1.58em;
    font-weight: 300;
    padding-bottom: 10px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    .txt-p2 p, .txt-p2 ul {
        font-size: 2.0em;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .txt-p2 p, .txt-p2 ul {
        font-size: 1.8em;
    }
}

.txt-p2.white p {
    color: #fff;
}

html, body {
    height: 100%;
    width: 100%;
    position: relative;
}

    html.is-open,
    body.is-open {
        overflow: hidden;
        position: fixed;
    }

*,
*:after,
*:before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

*, div, li, p, h1, h2, h3, h4, h5, a, span, html, img {
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: geometricPrecision;
}

body {
    font-size: 100%;
    position: relative;
    font-size: 10px;
    background: #fff;
}

#main {
    overflow: hidden;
}

.container {
    width: 100%;
    position: relative;
}

    .container.maxwidth {
        max-width: 1546px;
        margin: 0 auto;
        padding: 0 63px;
    }

@media screen and (min-width: 992px) and (max-width: 1545px) {
    .container.maxwidth {
        padding: 0 63px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    .container.maxwidth {
        padding: 0 30px;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .container.maxwidth {
        padding: 0 20px;
    }
}

.container.maxwidth2 {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 40px;
}

@media screen and (min-width: 992px) and (max-width: 1419px) {
    .container.maxwidth2 {
        padding: 0 40px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    .container.maxwidth2 {
        padding: 0 30px;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .container.maxwidth2 {
        padding: 0 20px;
    }
}

.stripe,
.stripe-loaded {
    background: #000 !important;
}

.cover-1 {
    position: fixed;
    left: 0;
    top: 100%;
    width: 100%;
    height: 100%;
    z-index: 999;
}

    .cover-1 > div {
        position: relative;
        width: 100%;
        height: 55%;
    }

        .cover-1 > div:nth-child(1) {
            background: #719199;
        }

        .cover-1 > div:nth-child(2) {
            background: #498A99;
        }

.cover-2 {
    z-index: 1000;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: none;
    opacity: 0;
}

.button {
    display: inline-block;
    margin-top: 50px;
}

    .button a.readMore {
        display: block;
        font-size: 1.25em;
        color: #494444;
        text-decoration: none;
        text-transform: uppercase;
        position: relative;
        font-weight: 300;
        letter-spacing: 0.1em;
        padding-bottom: 12px;
        -webkit-transition: padding 300ms ease-in-out;
        -moz-transition: padding 300ms ease-in-out;
        transition: padding 300ms ease-in-out;
    }

        .button a.readMore:before {
            content: '';
            position: absolute;
            bottom: 0;
            width: 100%;
            left: -12px;
            height: 1px;
            background: #2D8599;
            -webkit-transition: left 250ms ease-in-out;
            -moz-transition: left 250ms ease-in-out;
            transition: left 250ms ease-in-out;
        }

        .button a.readMore:after {
            content: '';
            position: absolute;
            bottom: -3px;
            width: 7px;
            left: -12px;
            height: 7px;
            border: solid 1px #7F5D3F;
            border-radius: 30%;
            background: #7F5D3F;
            -webkit-transition: left 250ms ease-in-out;
            -moz-transition: left 250ms ease-in-out;
            transition: left 250ms ease-in-out;
        }

        .button a.readMore:hover {
            padding-left: 5px;
        }

            .button a.readMore:hover:before {
                left: 18px;
            }

            .button a.readMore:hover:after {
                left: 18px;
            }

        .button a.readMore.white {
            color: #fff;
        }

            .button a.readMore.white:before {
                background: #2D8599;
            }

@media screen and (min-width: 1280px) and (max-width: 1439px) {
    .button a.readMore {
        font-size: 1.0em;
    }
}

@-webkit-keyframes draw {
    to {
        stroke-dashoffset: 0;
    }
}

@keyframes draw {
    to {
        stroke-dashoffset: 0;
    }
}

.nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #2D8599;
    z-index: -100;
    opacity: 0;
    -webkit-transition: opacity 400ms ease-in-out 100ms, z-index 400ms linear 1250ms;
    -moz-transition: opacity 400ms ease-in-out 100ms, z-index 400ms linear 1250ms;
    transition: opacity 400ms ease-in-out 100ms, z-index 400ms linear 1250ms;
}

    .nav .nav-content {
        width: 100%;
        max-width: 1200px;
        margin: 0 auto;
        height: 100%;
        position: relative;
        display: table;
        padding: 0 40px;
    }

@media screen and (min-width: 321px) and (max-width: 479px) {
    .nav .nav-content {
        display: block;
        padding-top: 22%;
    }
}

@media screen and (min-width: 0) and (max-width: 320px) {
    .nav .nav-content {
        display: block;
        padding-top: 18%;
    }
}

.nav .nav-content > div {
    display: table-cell;
    *zoom: 1;
    vertical-align: middle;
}

    .nav .nav-content > div:before, .nav .nav-content > div:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 479px) {
    .nav .nav-content > div {
        display: block;
    }
}

.nav .nav-content > div .navigation {
    float: left;
    width: 70%;
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    .nav .nav-content > div .navigation {
        width: 60%;
    }
}

@media screen and (min-width: 480px) and (max-width: 767px) {
    .nav .nav-content > div .navigation {
        width: 50%;
        padding-top: 4%;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    .nav .nav-content > div .navigation {
        width: 100%;
        float: none;
    }
}

.nav .nav-content > div .navigation ul li {
    -webkit-transition: all 400ms ease-in-out;
    -moz-transition: all 400ms ease-in-out;
    transition: all 400ms ease-in-out;
    opacity: 0;
    -webkit-transform: translate3d(0, 40px, 0);
    -moz-transform: translate3d(0, 40px, 0);
    -ms-transform: translate3d(0, 40px, 0);
    transform: translate3d(0, 40px, 0);
}

    .nav .nav-content > div .navigation ul li:nth-child(1) {
        -webkit-transition-delay: 250ms;
        -moz-transition-delay: 250ms;
        transition-delay: 250ms;
    }

    .nav .nav-content > div .navigation ul li:nth-child(2) {
        -webkit-transition-delay: 200ms;
        -moz-transition-delay: 200ms;
        transition-delay: 200ms;
    }

    .nav .nav-content > div .navigation ul li:nth-child(3) {
        -webkit-transition-delay: 150ms;
        -moz-transition-delay: 150ms;
        transition-delay: 150ms;
    }

    .nav .nav-content > div .navigation ul li:nth-child(4) {
        -webkit-transition-delay: 100ms;
        -moz-transition-delay: 100ms;
        transition-delay: 100ms;
    }

    .nav .nav-content > div .navigation ul li:nth-child(5) {
        -webkit-transition-delay: 50ms;
        -moz-transition-delay: 50ms;
        transition-delay: 50ms;
    }

    .nav .nav-content > div .navigation ul li a {
        text-decoration: none;
        color: #fff;
        font-weight: 100;
        font-size: 9em;
        text-decoration: none;
        padding: 0.05em 0;
        display: inline-block;
        -webkit-transition: color 400ms ease-in-out;
        -moz-transition: color 400ms ease-in-out;
        transition: color 400ms ease-in-out;
    }

@media screen and (min-width: 768px) and (max-width: 991px) {
    .nav .nav-content > div .navigation ul li a {
        font-size: 7em;
        padding: 0.05em 0;
    }
}

@media screen and (min-width: 321px) and (max-width: 767px) {
    .nav .nav-content > div .navigation ul li a {
        font-size: 4em;
        padding: 0.25em 0;
    }
}

@media screen and (min-width: 0) and (max-width: 320px) {
    .nav .nav-content > div .navigation ul li a {
        font-size: 4.6em;
        padding: 0.15em 0;
    }
}

.nav .nav-content > div .navigation ul li a:hover {
    color: #7F5D3F;
}

.nav .nav-content > div .navigation ul li.is-current a {
    color: #7F5D3F;
}

.nav.is-open {
    z-index: 100;
    opacity: 1;
    -webkit-transition: opacity 400ms ease-in-out;
    -moz-transition: opacity 400ms ease-in-out;
    transition: opacity 400ms ease-in-out;
}

    .nav.is-open .nav-content .social {
        -webkit-transform: translate3d(0, 0, 0);
        -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    .nav.is-open .nav-content .navigation ul li {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

.bg-nav {
    position: fixed;
    z-index: 10;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .bg-nav {
        height: 60px;
        width: 100%;
        display: block;
        -webkit-transition: background 400ms ease-in-out;
        -moz-transition: background 400ms ease-in-out;
        transition: background 400ms ease-in-out;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .bg-nav.is-fixed {
        background: #7CA8B2;
    }
}

.bg-nav .logo {
    position: fixed;
    top: 73px;
    left: 100px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    .bg-nav .logo {
        left: 70px;
        top: 54px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .bg-nav .logo {
        top: 32px;
        left: 25px;
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        -o-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}

.bg-nav .logo img {
    -webkit-transition: display 400ms ease-in-out;
    -moz-transition: display 400ms ease-in-out;
    transition: display 400ms ease-in-out;
    display: block;
}

    .bg-nav .logo img.white {
        display: block;
    }

    .bg-nav .logo img.black {
        display: none;
    }

.toggle {
    z-index: 101;
    position: fixed;
    top: 49px;
    right: 80px;
    margin: 18px 24px 20px 24px;
    padding: 0;
    height: 24px;
    width: 27px;
    cursor: pointer;
    -webkit-transition: right 400ms ease-in-out, top 400ms ease-in-out;
    -moz-transition: right 400ms ease-in-out, top 400ms ease-in-out;
    transition: right 400ms ease-in-out, top 400ms ease-in-out;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    .toggle {
        right: 55px;
        top: 30px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .toggle {
        top: 5px;
        right: 4px;
    }
}

.toggle > div {
    height: 14px;
    width: 27px;
}

    .toggle > div > div {
        width: 100%;
        height: 2px;
        margin: 0 0 5px 0;
        background-color: #fff;
        transition-duration: .3s;
        transition-delay: 0s, 0s, 0s, 0s;
    }

.toggle.is-open {
    background: none;
}

    .toggle.is-open > div {
        position: relative;
        height: 24px;
        width: 24px;
    }

        .toggle.is-open > div > div {
            background-color: #fff !important;
        }

            .toggle.is-open > div > div:nth-child(1) {
                -webkit-transform: translateY(7px) rotate(45deg);
                -moz-transform: translateY(7px) rotate(45deg);
                -ms-transform: translateY(7px) rotate(45deg);
                transform: translateY(7px) rotate(45deg);
            }

            .toggle.is-open > div > div:nth-child(2) {
                opacity: 0;
            }

            .toggle.is-open > div > div:nth-child(3) {
                width: 100%;
                -webkit-transform: translateX(0) translateY(-7px) rotate(-45deg);
                -moz-transform: translateX(0) translateY(-7px) rotate(-45deg);
                -ms-transform: translateX(0) translateY(-7px) rotate(-45deg);
                transform: translateX(0) translateY(-7px) rotate(-45deg);
            }

.toggle.black > div > div {
    background-color: #000;
}

body.is-open {
    overflow: hidden;
}

body.contact .toggle > div > div,
body.case-study-detail .toggle > div > div,
body.legal .toggle > div > div {
    background-color: #23252D;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact .toggle > div > div,
    body.case-study-detail .toggle > div > div,
    body.legal .toggle > div > div {
        background-color: #23252D;
    }

    body.contact .toggle.is-fixed > div > div,
    body.case-study-detail .toggle.is-fixed > div > div,
    body.legal .toggle.is-fixed > div > div {
        background-color: #fff;
    }

    body.contact .bg-nav .logo img.white,
    body.case-study-detail .bg-nav .logo img.white,
    body.legal .bg-nav .logo img.white {
        display: none;
    }

    body.contact .bg-nav .logo img.black,
    body.case-study-detail .bg-nav .logo img.black,
    body.legal .bg-nav .logo img.black {
        display: block;
    }

    body.contact .bg-nav.is-fixed .logo img.white,
    body.case-study-detail .bg-nav.is-fixed .logo img.white,
    body.legal .bg-nav.is-fixed .logo img.white {
        display: block;
    }

    body.contact .bg-nav.is-fixed .logo img.black,
    body.case-study-detail .bg-nav.is-fixed .logo img.black,
    body.legal .bg-nav.is-fixed .logo img.black {
        display: none;
    }
}

@media screen and (min-width: 992px) {
    html.nav-black .toggle > div > div {
        background-color: #23252D;
    }

    html.logo-black .bg-nav .logo img.white {
        display: none;
    }

    html.logo-black .bg-nav .logo img.black {
        display: block;
    }
}

body.home #main > div {
    overflow: hidden;
}

body.home #main > .header {
    overflow: visible;
    position: relative;
}

    body.home #main > .header > .header-wrap {
        overflow: hidden;
        position: relative;
        height: 100vh;
        width: 100%;
    }

@media screen and (min-width: 768px) and (max-width: 990px) {
    body.home #main > .header > .header-wrap {
        height: 50vh;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.home #main > .header > .header-wrap {
        height: 100vh;
    }
}

body.home #main > .header > .header-wrap .video-wrap {
    height: 100% !important;
    width: 100%;
}

    body.home #main > .header > .header-wrap .video-wrap video {
        width: 100%;
        height: 100%;
        display: inline-block;
        vertical-align: baseline;
    }

    body.home #main > .header > .header-wrap .video-wrap.no-video {
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center;
    }

        body.home #main > .header > .header-wrap .video-wrap.no-video video {
            display: none;
        }

body.home #main > .header > .header-wrap .content {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    display: table;
    z-index: 6;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content {
        display: block;
        left: auto;
        height: auto;
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        -o-transform: translateY(-50%);
        transform: translateY(-50%);
        padding: 0 30px;
    }
}

@media screen and (min-width: 480px) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content {
        top: 55%;
    }
}

body.home #main > .header > .header-wrap .content > div {
    display: table-cell;
    vertical-align: middle;
    color: #fff;
    text-align: center;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content > div {
        display: block;
        text-align: left;
    }
}

body.home #main > .header > .header-wrap .content > div h1 > div:nth-of-type(1) {
    margin-right: 2.1em;
}

body.home #main > .header > .header-wrap .content > div h1 > .content_title_inner.demo4 span {
    color: #9DC4CC;
    display: inline-block;
    width: 50px;
}

body.home #main > .header > .header-wrap .content > div h1 > .content_title_inner.demo5 span {
    color: #B7ADA5;
    display: inline-block;
    width: 50px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content > div h1 > div:nth-of-type(1) {
        margin-right: auto;
    }
}

body.home #main > .header > .header-wrap .content > div h1 > div:nth-of-type(2) {
    margin-left: 2.1em;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content > div h1 > div:nth-of-type(2) {
        margin-left: auto;
    }
}

body.home #main > .header > .header-wrap .content > div h2 {
    width: 100%;
    max-width: 736px;
    text-align: left;
    margin: 0 auto;
    margin-bottom: 60px;
    position: relative;
}

    body.home #main > .header > .header-wrap .content > div h2:before {
        content: '';
        width: 7px;
        height: 7px;
        border: solid 1px #7F5D3F;
        border-radius: 30%;
        background: #7F5D3F;
        position: absolute;
        bottom: -40px;
        left: 63px;
        opacity: 0;
        -webkit-transition: all 800ms ease-in-out;
        -moz-transition: all 800ms ease-in-out;
        transition: all 800ms ease-in-out;
        -webkit-transform: translateX(-250px);
        -moz-transform: translateX(-250px);
        -ms-transform: translateX(-250px);
        transform: translateX(-250px);
    }

    body.home #main > .header > .header-wrap .content > div h2:after {
        content: '';
        width: 126px;
        height: 1px;
        background: #2D8599;
        position: absolute;
        bottom: -37px;
        left: -63px;
        opacity: 0;
        -webkit-transition: all 800ms ease-in-out;
        -moz-transition: all 800ms ease-in-out;
        transition: all 800ms ease-in-out;
        -webkit-transform: translateX(-250px);
        -moz-transform: translateX(-250px);
        -ms-transform: translateX(-250px);
        transform: translateX(-250px);
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content > div h2:before {
        bottom: -33px;
        left: 40px;
        opacity: 1;
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }

    body.home #main > .header > .header-wrap .content > div h2:after {
        width: 60px;
        bottom: -30px;
        left: -20px;
        opacity: 1;
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }
}

body.home #main > .header > .header-wrap .content > div h2.is-visible:before {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
}

body.home #main > .header > .header-wrap .content > div h2.is-visible:after {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .header > .header-wrap .content > div h2 {
        max-width: 600px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .header > .header-wrap .content > div h2 {
        margin-bottom: 55px;
    }
}

body.home #main > .intro {
    padding: 330px 0 50px 0;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .intro {
        padding: 200px 0 85px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .intro {
        padding: 75px 0 25px 0;
    }
}

body.home #main > .intro > div {
    position: relative;
    width: 100%;
    height: 100%;
}

    body.home #main > .intro > div .container {
        *zoom: 1;
        display: table;
    }

        body.home #main > .intro > div .container:before,
        body.home #main > .intro > div .container:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }

        body.home #main > .intro > div .container .img {
            float: left;
            width: 48%;
            max-width: 660px;
        }

            body.home #main > .intro > div .container .img img {
                border-radius: 8px;
            }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .intro > div .container .img {
        margin-top: 75px;
        max-width: none;
        float: none;
        text-align: right;
        width: calc(100% - 25px);
        display: table-caption;
        caption-side: bottom;
        -webkit-transform: translateX(25px);
        -moz-transform: translateX(25px);
        -ms-transform: translateX(25px);
        transform: translateX(25px);
    }

        body.home #main > .intro > div .container .img img {
            border-radius: 0;
            border-top-left-radius: 8px;
            border-bottom-left-radius: 8px;
        }
}

body.home #main > .intro > div .container .txt {
    padding-top: 15%;
    margin-left: 10%;
    float: left;
    width: 35%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .intro > div .container .txt {
        float: none;
        width: 100%;
        margin-left: 0;
        padding-top: 0;
    }
}

body.home #main > .intro > div .container .txt .txt-p1 {
    margin-top: 53px;
    -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
    -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
    transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.home #main > .intro > div .container .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

body.home #main > .intro > div .container .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .intro > div .container .txt {
        *zoom: 1;
    }

        body.home #main > .intro > div .container .txt:before, body.home #main > .intro > div .container .txt:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }

        body.home #main > .intro > div .container .txt .button {
            padding-right: 25px;
            float: right;
        }
}

body.home #main > .services {
    position: relative;
    *zoom: 1;
    padding: 115px 0 50px 0;
    margin-top: 15px;
    background: #FCF9F9;
}

    body.home #main > .services:before, body.home #main > .services:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .services {
        padding: 85px 0 85px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services {
        padding: 75px 0 0 0;
    }
}

body.home #main > .services .left {
    float: left;
    width: 50%;
    padding-left: calc((50% - (1420px/2)) + 76px);
}

@media screen and (min-width: 1280px) and (max-width: 1545px) {
    body.home #main > .services .left {
        padding-left: 93px;
        width: 48%;
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .services .left {
        padding-left: 93px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .left {
        padding-left: 25px;
        float: none;
        width: 100%;
        padding-right: 25px;
    }
}

body.home #main > .services .left .txt {
    padding-top: 15%;
    float: left;
    width: 100%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .left .txt {
        float: none;
        padding-top: 0;
    }
}

body.home #main > .services .left .txt .txt-p1 {
    max-width: 468px;
    padding-left: 76px;
    margin-top: 53px;
    -webkit-transition: all 600ms ease-in-out;
    -moz-transition: all 600ms ease-in-out;
    transition: all 600ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.home #main > .services .left .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .services .left .txt .txt-p1 {
        padding-left: 66px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .left .txt .txt-p1 {
        padding-left: 0;
        max-width: none;
    }
}

body.home #main > .services .left .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .left .txt {
        *zoom: 1;
    }

        body.home #main > .services .left .txt:before, body.home #main > .services .left .txt:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }

        body.home #main > .services .left .txt .button {
            padding-right: 25px;
            float: right;
        }
}

body.home #main > .services .right {
    position: relative;
    width: 46%;
    float: right;
    background: #9DC4CC;
    padding: 70px 40px 60px 110px;
    margin-top: 260px;
    color: #fff;
    -webkit-transition: -webkit-transform 600ms ease-in-out;
    -moz-transition: -moz-transform 600ms ease-in-out;
    transition: transform 600ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.home #main > .services .right {
        -webkit-transform: translateX(100%);
        -moz-transform: translateX(100%);
        -ms-transform: translateX(100%);
        transform: translateX(100%);
        border-top-left-radius: 8px;
        border-bottom-left-radius: 8px;
    }
}

@media screen and (min-width: 1280px) and (max-width: 1439px) {
    body.home #main > .services .right {
        padding: 70px 40px 40px 90px;
        margin-top: 200px;
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .services .right {
        padding: 60px 20px 20px 60px;
        margin-top: 180px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .right {
        float: none;
        width: 100%;
        top: auto;
        padding: 45px 25px 35px 25px;
        margin-top: 80px;
    }
}

body.home #main > .services .right h4 {
    margin-bottom: 65px;
    opacity: 0;
    -webkit-transition: opacity 400ms ease-in-out 600ms;
    -moz-transition: opacity 400ms ease-in-out 600ms;
    transition: opacity 400ms ease-in-out 600ms;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .right h4 {
        opacity: 1;
        margin-bottom: 40px;
    }
}

body.home #main > .services .right ul li {
    *zoom: 1;
    padding: 14px 0;
    display: table;
}

    body.home #main > .services .right ul li:before, body.home #main > .services .right ul li:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 1280px) and (max-width: 1439px) {
    body.home #main > .services .right ul li {
        padding: 10px 0;
    }
}

body.home #main > .services .right ul li .img {
    text-align: center;
    display: table-cell;
    width: 85px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .right ul li .img {
        width: 55px;
    }
}

body.home #main > .services .right ul li .txt {
    display: table-cell;
    vertical-align: middle;
    padding-left: 50px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .services .right ul li .txt {
        padding-left: 30px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .services .right ul li .txt {
        padding-left: 20px;
    }
}

body.home #main > .services .right ul li .txt p {
    line-height: 1.25em;
    -webkit-transition: all 400ms ease-in-out;
    -moz-transition: all 400ms ease-in-out;
    transition: all 400ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.home #main > .services .right ul li .txt p {
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        transform: translateY(40px);
        opacity: 0;
    }
}

body.home #main > .services .right ul li:first-child .txt p {
    -webkit-transition-delay: 400ms;
    -moz-transition-delay: 400ms;
    transition-delay: 400ms;
}

body.home #main > .services .right ul li:nth-child(2) .txt p {
    -webkit-transition-delay: 800ms;
    -moz-transition-delay: 800ms;
    transition-delay: 800ms;
}

body.home #main > .services .right ul li:nth-child(3) .txt p {
    -webkit-transition-delay: 1200ms;
    -moz-transition-delay: 1200ms;
    transition-delay: 1200ms;
}

body.home #main > .services .right ul li:nth-child(4) .txt p {
    -webkit-transition-delay: 1600ms;
    -moz-transition-delay: 1600ms;
    transition-delay: 1600ms;
}

body.home #main > .services .right ul li:nth-child(5) .txt p {
    -webkit-transition-delay: 2000ms;
    -moz-transition-delay: 2000ms;
    transition-delay: 2000ms;
}

body.home #main > .services .right.is-visible {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
}

    body.home #main > .services .right.is-visible h4 {
        opacity: 1;
    }

    body.home #main > .services .right.is-visible ul li .txt p {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
        opacity: 1;
    }

body.home #main > .plans {
    padding: 115px 0 50px 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .plans {
        padding: 75px 0 75px 0;
    }
}

body.home #main > .plans > div {
    position: relative;
    width: 100%;
    height: 100%;
}

    body.home #main > .plans > div .container {
        *zoom: 1;
        padding-top: 90px;
    }

        body.home #main > .plans > div .container:before,
        body.home #main > .plans > div .container:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }

        body.home #main > .plans > div .container .img {
            float: left;
            width: 48%;
            max-width: 660px;
        }

            body.home #main > .plans > div .container .img img {
                border-radius: 8px;
            }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .plans > div .container .img {
        margin-top: 75px;
        max-width: none;
        float: none;
        text-align: right;
        width: calc(100% - 25px);
        display: table-caption;
        caption-side: bottom;
        -webkit-transform: translateX(25px);
        -moz-transform: translateX(25px);
        -ms-transform: translateX(25px);
        transform: translateX(25px);
    }

    body.home #main > .plans > div .container {
        padding-top: 0;
    }
}

body.home #main > .plans > div .container .bg {
    position: relative;
    float: left;
    width: 50%;
    max-width: 506px;
}

    body.home #main > .plans > div .container .bg:after {
        content: '';
        display: block;
        padding-bottom: 117%;
    }


    body.home #main > .plans > div .container .bg.is-visible div {
        -webkit-transform: scaleX(1);
        -moz-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1);
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .plans > div .container .bg {
        display: none;
    }
}

body.home #main > .plans > div .container .txt {
    padding-top: 12%;
    margin-right: 5%;
    float: right;
    width: 35%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .plans > div .container .txt {
        float: none;
        width: 100%;
        margin-right: 0;
        padding-top: 30px;
    }
}

body.home #main > .plans > div .container .txt .txt-p1 {
    margin-top: 53px;
    -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
    -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
    transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.home #main > .plans > div .container .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

body.home #main > .plans > div .container .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .plans > div .container .txt {
        *zoom: 1;
    }

        body.home #main > .plans > div .container .txt:before, body.home #main > .plans > div .container .txt:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }

        body.home #main > .plans > div .container .txt .button {
            padding-right: 25px;
            float: right;
        }
}

body.home #main > .case-study {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 758px;
    padding: 140px 0;
}

@media screen and (min-width: 480px) and (max-width: 991px) {
    body.home #main > .case-study {
        height: 50vh;
        min-height: inherit;
        padding: 50px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.home #main > .case-study {
        height: 100vw;
        min-height: inherit;
        display: table;
        width: 100%;
        padding: 0;
    }

        body.home #main > .case-study .container {
            padding: 40px 25px 45px 25px;
            display: table-cell;
            vertical-align: middle;
            height: 100%;
        }
}

body.home #main > .case-study h3 {
    margin: 160px 0 0 0;
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.home #main > .case-study h3 {
        margin: 26% 0 0 0;
    }
}

body.home #main > .case-study h4 {
    font-weight: 300;
    margin-bottom: 90px;
    padding-left: 290px;
}

@media screen and (min-width: 1280px) and (max-width: 1439px) {
    body.home #main > .case-study h4 {
        padding-left: 150px;
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main > .case-study h4 {
        padding-left: 100px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .case-study h4 {
        padding-left: 0;
        margin-bottom: 22%;
    }
}

body.home #main > .case-study h5 {
    position: relative;
}

    body.home #main > .case-study h5:before {
        content: '';
        position: absolute;
        bottom: -12px;
        left: -20px;
        height: 1px;
        width: 71px;
        background: #2D8599;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .case-study .container {
        *zoom: 1;
        height: 100%;
    }

        body.home #main > .case-study .container:before, body.home #main > .case-study .container:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }

    body.home #main > .case-study .button {
        position: absolute;
        right: 25px;
        bottom: 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main > .case-study .button {
        bottom: 25px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main h3.title-header2 {
        position: relative;
    }

        body.home #main h3.title-header2 br {
            display: none;
        }

        body.home #main h3.title-header2:after {
            position: absolute;
            content: '';
            bottom: -25px;
            height: 1px;
            width: 55px;
            left: 0;
            background: #2D8599;
        }
}

body.home #main h3.title-header2 .reveal:nth-of-type(2) {
    margin-left: 75px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main h3.title-header2 .reveal:nth-of-type(2) {
        margin-left: 55px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main h3.title-header2 .reveal:nth-of-type(2) {
        margin-left: 0;
    }
}

@media screen and (min-width: 992px) {
    body.home #main h3.title-header2 .reveal:nth-of-type(2):before {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -moz-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px);
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.home #main h3.title-header2 .reveal:nth-of-type(2):before {
        width: 70px;
        left: -85px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.home #main h3.title-header2 .reveal:nth-of-type(2):before {
        display: none;
    }
}

body.home #main h3.title-header2 .reveal:nth-of-type(2).is-visible:before {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.about #main > div,
body.plans #main > div,
body.services #main > div {
    overflow: hidden;
}

body.about #main > .header,
body.plans #main > .header,
body.services #main > .header {
    position: relative;
    overflow: visible;
}

    body.about #main > .header > .header-wrap,
    body.plans #main > .header > .header-wrap,
    body.services #main > .header > .header-wrap {
        position: relative;
        overflow: hidden;
        height: calc(50vh + 60px);
        min-height: 727px;
        position: relative;
        width: calc(100% - 224px);
        opacity: 0;
        -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
        -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
        transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .header > .header-wrap,
    body.plans #main > .header > .header-wrap,
    body.services #main > .header > .header-wrap {
        opacity: 1;
        -webkit-transform: translateY(0) !important;
        -moz-transform: translateY(0) !important;
        -ms-transform: translateY(0) !important;
        transform: translateY(0) !important;
    }
}

body.about #main > .header > .header-wrap.is-visible,
body.plans #main > .header > .header-wrap.is-visible,
body.services #main > .header > .header-wrap.is-visible {
    opacity: 1;
    -webkit-transform: translateY(-60px);
    -moz-transform: translateY(-60px);
    -ms-transform: translateY(-60px);
    transform: translateY(-60px);
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .header > .header-wrap,
    body.plans #main > .header > .header-wrap,
    body.services #main > .header > .header-wrap {
        width: calc(100% - 176px);
        min-height: 575px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.about #main > .header > .header-wrap,
    body.plans #main > .header > .header-wrap,
    body.services #main > .header > .header-wrap {
        width: 100%;
        min-height: inherit;
    }
}

@media screen and (min-width: 480px) and (max-width: 767px) {
    body.about #main > .header > .header-wrap,
    body.plans #main > .header > .header-wrap,
    body.services #main > .header > .header-wrap {
        height: 100vh;
        width: 100%;
        min-height: inherit;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.about #main > .header > .header-wrap,
    body.plans #main > .header > .header-wrap,
    body.services #main > .header > .header-wrap {
        height: auto;
        width: 100%;
        min-height: inherit;
    }
}

body.about #main > .header > .header-wrap .bg {
    position: absolute;
    height: 100%;
    width: 100%;
    background-image: url('Images/portalfred.jpg');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 0;
}

@media screen and (min-width: 991px) {
    body.about #main > .header > .header-wrap .bg {
        border-bottom-right-radius: 8px;
    }
}

body.plans #main > .header > .header-wrap .bg {
    position: absolute;
    height: 100%;
    width: 100%;
    background-image: url('Images/portalfred.jpg');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 0;
}

@media screen and (min-width: 991px) {
    body.plans #main > .header > .header-wrap .bg {
        border-bottom-right-radius: 8px;
    }
}

body.plans #main > .header > .header-wrap .bg {
    position: absolute;
    height: 100%;
    width: 100%;
    background-image: url('Images/plans.jpg');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 0;
}

@media screen and (min-width: 991px) {
    body.plans #main > .header > .header-wrap .bg {
        border-bottom-right-radius: 8px;
    }
}

body.about #main > .header > .header-wrap .bg.error {
    background-image: url('../Profserve/Images/error404.jpg');
}

body.services #main > .header > .header-wrap .bg {
    position: absolute;
    height: 100%;
    width: 100%;
    background-image: url('Images/services.jpg');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 0;
}

body.plans #main > .header > .header-wrap .bg.error {
    background-image: url('../Profserve/Images/error404.jpg');
}

body.plans #main > .header > .header-wrap .bg.error {
    background-image: url('../Profserve/Images/error404.jpg');
}

@media screen and (min-width: 991px) {
    body.services #main > .header > .header-wrap .bg {
        border-bottom-right-radius: 8px;
    }
}

body.about #main > .header > .header-wrap .content,
body.plans #main > .header > .header-wrap .content,
body.services #main > .header > .header-wrap .content {
    position: relative;
    display: table;
    width: 100%;
    height: 100%;
    max-width: 1546px;
    margin: 0 auto;
}

    body.about #main > .header > .header-wrap .content > div,
    body.plans #main > .header > .header-wrap .content > div,
    body.services #main > .header > .header-wrap .content > div {
        display: table-cell;
        vertical-align: bottom;
        padding: 0 100px;
        padding-bottom: 100px;
    }

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.about #main > .header > .header-wrap .content > div,
    body.plans #main > .header > .header-wrap .content > div,
    body.services #main > .header > .header-wrap .content > div {
        padding: 0 25px;
        padding-bottom: 150px;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.about #main > .header > .header-wrap .content > div,
    body.plans #main > .header > .header-wrap .content > div,
    body.services #main > .header > .header-wrap .content > div {
        padding: 0 25px;
        padding-bottom: 50px;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.about #main > .header > .header-wrap .content > div,
    body.plans #main > .header > .header-wrap .content > div,
    body.services #main > .header > .header-wrap .content > div {
        padding-top: 190px;
    }
}

body.about #main > .header > .header-wrap .content > div h2,
body.plans #main > .header > .header-wrap .content > div h2,
body.services #main > .header > .header-wrap .content > div h2 {
    margin-bottom: 60px;
    position: relative;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.about #main > .header > .header-wrap .content > div h2,
    body.plans #main > .header > .header-wrap .content > div h2,
    body.services #main > .header > .header-wrap .content > div h2 {
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .header > .header-wrap .content > div h2:after,
    body.plans #main > .header > .header-wrap .content > div h2:after,
    body.services #main > .header > .header-wrap .content > div h2:after {
        width: 60px;
        bottom: -20px;
        left: -10px;
        opacity: 1;
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }
}

body.about #main > .header > .header-wrap .content > div h2.is-visible:after,
body.plans #main > .header > .header-wrap .content > div h2.is-visible:after,
body.services #main > .header > .header-wrap .content > div h2.is-visible:after {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
}

body.about #main > .intro {
    position: relative;
    padding: 50px 0 50px 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .intro {
        padding: 60px 0 50px 0;
    }
}

body.about #main > .intro .txt {
    padding-left: 170px;
    padding-right: 3%;
    position: relative;
    opacity: 0;
    -webkit-transition: opacity 1000ms ease-in-out;
    -moz-transition: opacity 1000ms ease-in-out;
    transition: opacity 1000ms ease-in-out;
}

@media screen and (min-width: 992px) and (max-width: 1546px) {
    body.about #main > .intro .txt {
        padding-right: 10%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .intro .txt {
        margin-top: 0;
        padding-left: 0;
        padding-right: 0;
        padding-top: 53px;
        opacity: 1;
    }
}

body.about #main > .intro .txt.is-visible {
    opacity: 1;
}

body.about #main > .intro .txt:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 15px;
    width: 99px;
    height: 1px;
    background: #2D8599;
}

body.about #main > .intro .txt:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 12px;
    width: 7px;
    height: 7px;
    border: solid 1px #7F5D3F;
    border-radius: 30%;
    background: #7F5D3F;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .intro .txt:before {
        width: 45px;
        top: 25px;
    }

    body.about #main > .intro .txt:after {
        top: 22px;
    }
}

body.about #main > .values {
    overflow: visible;
    position: relative;
    padding: 115px 0 150px 0;
    background: #FCF9F9;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .values {
        padding: 100px 0 100px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values {
        padding: 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container {
        padding: 0;
    }
}

body.about #main > .values .container > .img {
    max-width: 614px;
    width: 36.5%;
    position: absolute;
    right: 3%;
    top: -10%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center bottom;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .values .container > .img {
        right: 25px;
        width: 40%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .img {
        position: static;
        width: 100%;
        max-width: none;
    }
}

body.about #main > .values .container > .img > div {
    position: relative;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .img > div {
        height: 100vw;
    }
}

body.about #main > .values .container > .img > div:after {
    content: '';
    display: block;
    padding-bottom: 139.4%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .img > div:after {
        display: none;
    }
}

body.about #main > .values .container > .img img {
    position: absolute;
    top: -10%;
    left: 0;
    width: 100%;
    display: block;
    border: solid 1px transparent;
    border-radius: 8px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .img img {
        top: auto;
        bottom: 0;
        border: none;
    }
}

body.about #main > .values .container > .content {
    margin-left: 10%;
    width: 45%;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .values .container > .content {
        margin-left: 0;
        width: 50%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .content {
        padding: 60px 25px 80px 25px;
        width: 100%;
        margin-left: 0;
    }
}

body.about #main > .values .container > .content h3 {
    padding-bottom: 40px;
    position: relative;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .content h3 {
        padding-bottom: 0;
    }
}

body.about #main > .values .container > .content h3:before {
    content: '';
    display: block;
    position: absolute;
    left: -50px;
    bottom: 10px;
    width: 99px;
    height: 1px;
    background: #2D8599;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .content h3:before {
        display: none;
    }
}

body.about #main > .values .container > .content ul li {
    *zoom: 1;
    margin-top: 90px;
}

    body.about #main > .values .container > .content ul li:before, body.about #main > .values .container > .content ul li:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .values .container > .content ul li {
        margin-top: 60px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .content ul li {
        margin-top: 60px;
    }
}

body.about #main > .values .container > .content ul li .img {
    width: 90px;
    float: left;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .content ul li .img {
        float: none;
        width: 100%;
        margin-bottom: 10px;
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
}

body.about #main > .values .container > .content ul li .txt {
    width: calc(100% - 90px);
    float: left;
    padding-left: 40px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .values .container > .content ul li .txt {
        float: none;
        width: 100%;
        padding: 0;
    }
}

body.about #main > .values .container > .content ul li .txt h4 {
    margin-bottom: 0.5em;
    -webkit-transition: -webkit-transform 400ms ease-in-out;
    -moz-transition: -moz-transform 400ms ease-in-out;
    transition: transform 400ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.about #main > .values .container > .content ul li .txt h4 {
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        transform: translateY(40px);
        opacity: 0;
    }
}

body.about #main > .values .container > .content ul li .txt p {
    -webkit-transition: -webkit-transform 400ms ease-in-out;
    -moz-transition: -moz-transform 400ms ease-in-out;
    transition: transform 400ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.about #main > .values .container > .content ul li .txt p {
        -webkit-transform: translateY(40px);
        -moz-transform: translateY(40px);
        -ms-transform: translateY(40px);
        transform: translateY(40px);
        opacity: 0;
    }
}

body.about #main > .values .container > .content ul li:first-child p {
    -webkit-transition-delay: 200ms;
    -moz-transition-delay: 200ms;
    transition-delay: 200ms;
}

body.about #main > .values .container > .content ul li:nth-child(2) p {
    -webkit-transition-delay: 700ms;
    -moz-transition-delay: 700ms;
    transition-delay: 700ms;
}

body.about #main > .values .container > .content ul li:nth-child(2) h4 {
    -webkit-transition-delay: 500ms;
    -moz-transition-delay: 500ms;
    transition-delay: 500ms;
}

body.about #main > .values .container > .content ul li:nth-child(3) p {
    -webkit-transition-delay: 1200ms;
    -moz-transition-delay: 1200ms;
    transition-delay: 1200ms;
}

body.about #main > .values .container > .content ul li:nth-child(3) h4 {
    -webkit-transition-delay: 1000ms;
    -moz-transition-delay: 1000ms;
    transition-delay: 1000ms;
}

body.about #main > .values .container > .content ul li:nth-child(4) p {
    -webkit-transition-delay: 1900ms;
    -moz-transition-delay: 1900ms;
    transition-delay: 1900ms;
}

body.about #main > .values .container > .content ul li:nth-child(4) h4 {
    -webkit-transition-delay: 1700ms;
    -moz-transition-delay: 1700ms;
    transition-delay: 1700ms;
}

body.about #main > .values .container > .content.is-visible ul li .txt p,
body.about #main > .values .container > .content.is-visible ul li .txt h4 {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
}

body.about #main > .team {
    padding: 220px 0 170px;
    position: relative;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .team {
        padding: 170px 0;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.about #main > .team {
        padding: 100px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.about #main > .team {
        padding: 65px 0;
    }
}

body.about #main > .team > .bg {
    position: absolute;
    width: 40%;
    height: 35%;
    top: 55%;
    background: #F3F7FF;
}

@media screen and (min-width: 992px) {
    body.about #main > .team > .bg {
        -webkit-transition: -webkit-transform 600ms ease-in-out;
        -moz-transition: -moz-transform 600ms ease-in-out;
        transition: transform 600ms ease-in-out;
        -webkit-transform-origin: left top;
        -moz-transform-origin: left top;
        -ms-transform-origin: left top;
        transform-origin: left top;
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        transform: scaleX(0);
    }

        body.about #main > .team > .bg.is-visible {
            -webkit-transform: scaleX(1);
            -moz-transform: scaleX(1);
            transform: scaleX(1);
        }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.about #main > .team .container {
        padding: 0;
    }
}

body.about #main > .team .container h2 {
    text-align: center;
}

body.about #main > .team .container .list {
    padding-top: 100px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .team .container .list {
        padding-top: 75px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.about #main > .team .container .list {
        padding-top: 55px;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.about #main > .team .container .list {
        padding-top: 45px;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.about #main > .team .container .list {
        overflow: hidden;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.about #main > .team .container .list > ul {
        width: 2000px;
        -webkit-transition: all 400ms ease-in-out;
        -moz-transition: all 400ms ease-in-out;
        transition: all 400ms ease-in-out;
    }
}

body.about #main > .team .container .list > ul > li {
    float: left;
    width: 25%;
    padding: 0 20px;
    position: relative;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.about #main > .team .container .list > ul > li {
        padding: 0 15px;
    }
}

@media screen and (min-width: 480px) and (max-width: 991px) {
    body.about #main > .team .container .list > ul > li {
        padding: 0 10px;
    }
}

@media screen and (min-width: 0) and (max-width: 479px) {
    body.about #main > .team .container .list > ul > li {
        padding: 0 15px;
    }
}

body.about #main > .team .container .list > ul > li > div {
    position: relative;
    width: 100%;
    height: 100%;
}

body.about #main > .team .container .list > ul > li .cover {
    z-index: 2;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: #fff;
    -webkit-transition: all 400ms ease-in-out;
    -moz-transition: all 400ms ease-in-out;
    transition: all 400ms ease-in-out;
    -webkit-transform-origin: center right;
    -moz-transform-origin: center right;
    -ms-transform-origin: center right;
    transform-origin: center right;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.about #main > .team .container .list > ul > li .cover {
        display: none;
    }
}

body.about #main > .team .container .list > ul > li .content {
    position: relative;
}

    body.about #main > .team .container .list > ul > li .content > img {
        display: block;
        width: 100%;
    }

    body.about #main > .team .container .list > ul > li .content .info {
        padding: 32px 25px;
        position: absolute;
    }

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.about #main > .team .container .list > ul > li .content .info {
        padding: 25px 20px;
    }
}

body.about #main > .team .container .list > ul > li .content .info h3 {
    opacity: 0;
    -webkit-transition: all 300ms ease-in-out;
    -moz-transition: all 300ms ease-in-out;
    transition: all 300ms ease-in-out;
    -webkit-transform: translateY(30px);
    -moz-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px);
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.about #main > .team .container .list > ul > li .content .info h3 {
        font-size: 2.4em;
    }
}

body.about #main > .team .container .list > ul > li .content .info p {
    margin-top: 0.5em;
    opacity: 0;
    -webkit-transition: all 300ms ease-in-out;
    -moz-transition: all 300ms ease-in-out;
    transition: all 300ms ease-in-out;
    -moz-transition-delay: 100ms;
    transition-delay: 100ms;
    -webkit-transform: translateY(30px);
    -moz-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px);
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.about #main > .team .container .list > ul > li .content .info p {
        font-size: 1.1em;
    }
}

body.about #main > .team .container .list > ul > li .content .social {
    opacity: 0;
    padding: 32px 25px;
    position: absolute;
    bottom: 0;
    left: 0;
    -webkit-transition: all 300ms ease-in-out;
    -moz-transition: all 300ms ease-in-out;
    transition: all 300ms ease-in-out;
}

    body.about #main > .team .container .list > ul > li .content .social .line {
        height: 2px;
        width: 104px;
        background: #00A8FF;
        margin-bottom: 20px;
        -webkit-transition: all 300ms ease-in-out;
        -moz-transition: all 300ms ease-in-out;
        transition: all 300ms ease-in-out;
        -webkit-transform-origin: center left;
        -moz-transform-origin: center left;
        -ms-transform-origin: center left;
        transform-origin: center left;
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
    }

    body.about #main > .team .container .list > ul > li .content .social ul li {
        margin-right: 30px;
        display: inline-block;
    }

        body.about #main > .team .container .list > ul > li .content .social ul li a {
            display: block;
        }

body.about #main > .team .container .list > ul > li:nth-child(2n+2) {
    padding-top: 87px;
}

@media screen and (min-width: 768px) and (max-width: 1279px) {
    body.about #main > .team .container .list > ul > li:nth-child(2n+2) {
        padding-top: 71px;
    }
}

body.about #main > .team .container .list > ul > li:nth-child(2n+2) .cover {
    -webkit-transition-delay: 200ms;
    -moz-transition-delay: 200ms;
    transition-delay: 200ms;
}

body.about #main > .team .container .list > ul > li:hover .content .bg {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

body.about #main > .team .container .list > ul > li:hover .content .info h3, body.about #main > .team .container .list > ul > li:hover .content .info p {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.about #main > .team .container .list > ul > li:hover .content .social {
    opacity: 1;
}

    body.about #main > .team .container .list > ul > li:hover .content .social .line {
        -webkit-transform: scaleX(1);
        -moz-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1);
    }

body.about #main > .team .container .list > ul > li.is-visible .cover {
    -webkit-transform: scaleX(0);
    -moz-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0);
}

body.plans #main > .intro {
    position: relative;
    padding: 50px 0 50px 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.plans #main > .intro {
        padding: 60px 0 50px 0;
    }
}

body.plans #main > .intro .txt {
    padding-left: 170px;
    padding-right: 3%;
    position: relative;
    opacity: 0;
    -webkit-transition: opacity 1000ms ease-in-out;
    -moz-transition: opacity 1000ms ease-in-out;
    transition: opacity 1000ms ease-in-out;
}

@media screen and (min-width: 992px) and (max-width: 1546px) {
    body.plans #main > .intro .txt {
        padding-right: 10%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.plans #main > .intro .txt {
        margin-top: 0;
        padding-left: 0;
        padding-right: 0;
        padding-top: 53px;
        opacity: 1;
    }
}

body.plans #main > .intro .txt.is-visible {
    opacity: 1;
}

body.plans #main > .intro .txt:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 15px;
    width: 99px;
    height: 1px;
    background: #2D8599;
}

body.plans #main > .intro .txt:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 12px;
    width: 7px;
    height: 7px;
    border: solid 1px #7F5D3F;
    border-radius: 30%;
    background: #7F5D3F;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.plans #main > .intro .txt:before {
        width: 45px;
        top: 25px;
    }

    body.plans #main > .intro .txt:after {
        top: 22px;
    }
}

body.plans #main > .values {
    overflow: visible;
    position: relative;
    padding: 115px 0 150px 0;
    background: #FCF9F9;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.plans #main > .values {
        padding: 100px 0 100px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.plans #main > .values {
        padding: 0;
        padding-top: 30px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.plans #main > .values .container {
        padding: 0;
    }
}

body.services #main > .intro {
    overflow: visible;
    position: relative;
    padding: 60px 0 50px 0;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.services #main > .intro {
        padding: 60px 0 50px 0;
    }
}

body.services #main > .intro .txt {
    padding-left: 170px;
    padding-right: 3%;
    position: relative;
    opacity: 0;
    -webkit-transition: all 1000ms ease-in-out;
    -moz-transition: all 1000ms ease-in-out;
    transition: all 1000ms ease-in-out;
}

@media screen and (min-width: 992px) and (max-width: 1546px) {
    body.services #main > .intro .txt {
        padding-right: 10%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .intro .txt {
        margin-top: 0;
        padding-left: 0;
        padding-right: 0;
        padding-top: 53px;
        opacity: 1;
    }
}

body.services #main > .intro .txt.is-visible {
    opacity: 1;
}

body.services #main > .intro .txt:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 15px;
    width: 99px;
    height: 1px;
    background: #2D8599;
}

body.services #main > .intro .txt:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 12px;
    width: 7px;
    height: 7px;
    border: solid 1px #7F5D3F;
    border-radius: 30%;
    background: #7F5D3F;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .intro .txt:before {
        width: 45px;
        top: 25px;
    }

    body.services #main > .intro .txt:after {
        top: 22px;
    }
}

body.services #main > .blocks {
    overflow: visible;
}

    body.services #main > .blocks .block {
        position: relative;
        margin: 0 0 320px 0;
    }

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.services #main > .blocks .block {
        margin: 0 0 230px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block {
        margin: 0 0 130px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block > .bg {
        display: none;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container {
        padding: 0;
    }
}

body.services #main > .blocks .block .container > .bg {
    position: relative;
    width: 40%;
    max-width: 506px;
}

    body.services #main > .blocks .block .container > .bg:after {
        content: '';
        display: block;
        padding-bottom: 117%;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container > .bg:after {
        padding-bottom: 50%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container > .bg {
        width: 79%;
        max-width: none;
    }
}

body.services #main > .blocks .block .container > .bg div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

@media screen and (min-width: 992px) {
    body.services #main > .blocks .block .container > .bg div {
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transition: -webkit-transform 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container > .bg p span {
        display: none;
    }
}

body.services #main > .blocks .block .container > .bg.is-visible div {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

body.services #main > .blocks .block .container > .txt {
    width: 50%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container > .txt {
        float: none;
        width: 100%;
        padding-left: 25px !important;
        padding-right: 25px !important;
        padding-top: 25px !important;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container > .txt .title-tag {
        display: none;
    }
}

body.services #main > .blocks .block .container > .txt .txt-p1 {
    margin-top: 53px;
    width: 100%;
    max-width: 460px;
    -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
    -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
    transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.services #main > .blocks .block .container > .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block .container > .txt .txt-p1 {
        max-width: none;
        margin-top: 23px;
    }
}

body.services #main > .blocks .block .container > .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+1) > .bg {
        display: none;
    }
}

body.services #main > .blocks .block:nth-child(2n+1) > .bg.is-visible {
    -webkit-transition: -webkit-transform 600ms ease-in-out;
    -moz-transition: -webkit-transform 600ms ease-in-out;
    transition: -webkit-transform 600ms ease-in-out;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

body.services #main > .blocks .block:nth-child(2n+1) .container {
    *zoom: 1;
}

    body.services #main > .blocks .block:nth-child(2n+1) .container:before, body.services #main > .blocks .block:nth-child(2n+1) .container:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg {
        float: left;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg {
        margin-right: 21%;
    }
}

body.services #main > .blocks .block:nth-child(2n+1) .container > .bg div {
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
}

    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg div.option1 {
        background-image: url('Images/servicesBranding.jpg');
        background-position: center center;
        background-size: cover;
        background-repeat: no-repeat;
        border-radius: 8px;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg div.option1 {
        border-radius: 0;
        border-top-right-radius: 8px;
        border-bottom-right-radius: 8px;
    }
}

body.services #main > .blocks .block:nth-child(2n+1) .container > .bg div.option4 {
    background-image: url('Images/servicesDesign.jpg');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 8px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg div.option4 {
        border-radius: 0;
        border-top-right-radius: 8px;
        border-bottom-right-radius: 8px;
    }
}

body.services #main > .blocks .block:nth-child(2n+1) .container > .bg p {
    top: 50px;
    left: 30px;
}

@media screen and (min-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg p {
        -webkit-transform: translateX(-100%) rotate(-90deg);
        -moz-transform: translateX(-100%) rotate(-90deg);
        -ms-transform: translateX(-100%) rotate(-90deg);
        -o-transform: translateX(-100%) rotate(-90deg);
        transform: translateX(-100%) rotate(-90deg);
        -webkit-transform-origin: top right;
        -moz-transform-origin: top right;
        -ms-transform-origin: top right;
        -o-transform-origin: top right;
        transform-origin: top right;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+1) .container > .bg p {
        top: auto;
        bottom: 30px;
    }
}

body.services #main > .blocks .block:nth-child(2n+1) .container > .txt {
    float: right;
    padding-top: 10%;
    padding-left: 10%;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.services #main > .blocks .block:nth-child(2n+1) .container > .txt {
        padding-top: 0;
    }
}

body.services #main > .blocks .block:nth-child(2n+2) .container {
    *zoom: 1;
}

    body.services #main > .blocks .block:nth-child(2n+2) .container:before, body.services #main > .blocks .block:nth-child(2n+2) .container:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container {
        display: -webkit-flex;
        display: flex;
        -webkit-flex-flow: row wrap;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
    }
}

body.services #main > .blocks .block:nth-child(2n+2) .container > .bg {
    float: right;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container > .bg {
        order: 1;
        margin-left: 21%;
    }
}

body.services #main > .blocks .block:nth-child(2n+2) .container > .bg div {
    -webkit-transform-origin: right center;
    -moz-transform-origin: right center;
    -ms-transform-origin: right center;
    transform-origin: right center;
}

    body.services #main > .blocks .block:nth-child(2n+2) .container > .bg div.option2 {
        background-image: url('Images/servicesMarketing.jpg');
        background-position: center center;
        background-size: cover;
        background-repeat: no-repeat;
        border-radius: 8px;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container > .bg div.option2 {
        border-radius: 0;
        border-top-left-radius: 8px;
        border-bottom-left-radius: 8px;
    }
}

body.services #main > .blocks .block:nth-child(2n+2) .container > .bg div.option3 {
    background-image: url('Images/servicesCollateral.jpg');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 8px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container > .bg div.option3 {
        border-radius: 0;
        border-top-left-radius: 8px;
        border-bottom-left-radius: 8px;
    }
}

body.services #main > .blocks .block:nth-child(2n+2) .container > .bg p {
    bottom: 50px;
    right: 35px;
}

@media screen and (min-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container > .bg p {
        -webkit-transform-origin: 100% 100%;
        -moz-transform-origin: 100% 100%;
        -ms-transform-origin: 100% 100%;
        transform-origin: 100% 100%;
        -webkit-transform: rotate(270deg) translateX(100%);
        -moz-transform: rotate(270deg) translateX(100%);
        -ms-transform: rotate(270deg) translateX(100%);
        transform: rotate(270deg) translateX(100%);
    }
}

body.services #main > .blocks .block:nth-child(2n+2) .container > .txt {
    float: left;
    padding-top: 10%;
    padding-right: 10%;
    padding-left: 5%;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container > .txt {
        padding-top: 16%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block:nth-child(2n+2) .container > .txt {
        order: 2;
    }
}

body.services #main > .blocks .block:last-child {
    margin: 0 0 150px 0;
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.services #main > .blocks .block:last-child {
        margin: 0 0 60px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    body.services #main > .blocks .block:last-child {
        margin: 0 0 0 0;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block.block1 .container > .bg p:after {
        content: attr(data-number);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block.block2 .container > .bg p:after {
        content: attr(data-number);
    }
}

body.services #main > .blocks .block.block2 .container > .bg > span {
    -webkit-transform-origin: right center;
    -moz-transform-origin: right center;
    -ms-transform-origin: right center;
    transform-origin: right center;
    -webkit-transform: scaleX(0);
    -moz-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0);
    position: absolute;
    top: -6%;
    right: -7%;
    width: 35%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block.block2 .container > .bg > span {
        display: none;
    }
}

body.services #main > .blocks .block.block2 .container > .bg > span:after {
    content: '';
    padding-bottom: 100%;
    display: block;
    background: #F3F7FF;
}

body.services #main > .blocks .block.block2 .container > .bg.is-visible > span {
    -webkit-transition: -webkit-transform 600ms ease-in-out;
    -moz-transition: -webkit-transform 600ms ease-in-out;
    transition: -webkit-transform 600ms ease-in-out;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block.block3 .container > .bg p:after {
        content: attr(data-number);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block.block4 .container > .bg p:after {
        content: attr(data-number);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main > .blocks .block.block5 .container > .bg p:after {
        content: attr(data-number);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main h3.title-header2 {
        position: relative;
    }

        body.services #main h3.title-header2 br {
            display: none;
        }
}

body.services #main h3.title-header2 .reveal:nth-of-type(2) {
    margin-left: 75px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.services #main h3.title-header2 .reveal:nth-of-type(2) {
        margin-left: 55px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main h3.title-header2 .reveal:nth-of-type(2) {
        margin-left: 0;
    }
}

@media screen and (min-width: 992px) {
    body.services #main h3.title-header2 .reveal:nth-of-type(2):before {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -moz-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px);
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.services #main h3.title-header2 .reveal:nth-of-type(2):before {
        width: 70px;
        left: -85px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.services #main h3.title-header2 .reveal:nth-of-type(2):before {
        display: none;
    }
}

body.services #main h3.title-header2 .reveal:nth-of-type(2).is-visible:before {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.contact #main {
    overflow: visible;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main .container {
        padding: 0;
    }
}

body.contact #main > .intro {
    overflow: hidden;
    position: relative;
    *zoom: 1;
    padding-top: 200px;
}

    body.contact #main > .intro:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro {
        padding-top: 120px;
    }
}

body.contact #main > .intro .left {
    position: relative;
    width: 46%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .left {
        width: 100%;
    }
}

body.contact #main > .intro .left > .txt {
    padding-left: 40px;
    padding-bottom: 360px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .left > .txt {
        padding: 0 25px 10px 25px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .left > .txt h1.title-header2 {
        position: relative;
    }

        body.contact #main > .intro .left > .txt h1.title-header2 br {
            display: none;
        }
}

body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2) {
    margin-left: 75px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2) {
        margin-left: 55px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2) {
        margin-left: 0;
    }
}

@media screen and (min-width: 992px) {
    body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2):before {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -moz-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px);
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2):before {
        width: 70px;
        left: -85px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2):before {
        display: none;
    }
}

body.contact #main > .intro .left > .txt h1.title-header2 .reveal:nth-of-type(2).is-visible:before {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.contact #main > .intro .left > .txt .txt-p1 {
    margin-top: 53px;
    width: 100%;
    max-width: 365px;
    -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
    -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
    transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
}

@media screen and (min-width: 992px) {
    body.contact #main > .intro .left > .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .left > .txt .txt-p1 {
        max-width: none;
        margin-top: 23px;
    }
}

body.contact #main > .intro .left > .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    padding-right: 25px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .info {
        width: 100%;
        margin-bottom: 0;
    }
}

body.contact #main > .intro .info .txt {
    padding: 110px;
    padding-top: 40px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.contact #main > .intro .info .txt {
        padding: 45px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .info .txt {
        padding: 10px 25px 40px 25px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .info .txt h2 {
        margin-bottom: 48px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .info .txt h2 {
        margin-left: 20px;
    }
}

body.contact #main > .intro .info .txt p {
    font-size: 1.6em;
    font-weight: 300;
    line-height: 2.75em;
    margin-bottom: 75px;
    margin-top: 30px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .info .txt p {
        margin-bottom: 55px;
    }
}

body.contact #main > .intro .info .txt ul li {
    display: inline-block;
    margin-right: 15px;
}

    body.contact #main > .intro .info .txt ul li a {
        width: 37px;
        height: 37px;
        background-repeat: no-repeat;
        background-position: 0 0;
        display: block;
    }

        body.contact #main > .intro .info .txt ul li a.twitter {
            background-image: url("Images/bluetwitter.png");
        }

        body.contact #main > .intro .info .txt ul li a.facebook {
            background-image: url("Images/bluefacebook.png");
        }

        body.contact #main > .intro .info .txt ul li a.youtube {
            background-image: url("Images/blueyoutube.png");
        }

        body.contact #main > .intro .info .txt ul li a.instagram {
            background-image: url("Images/blueinstagram.png");
        }

@media screen and (min-width: 992px) {
    body.contact #main > .intro .info .txt {
        opacity: 0;
        -webkit-transform: translateY(60px);
        -moz-transform: translateY(60px);
        -ms-transform: translateY(60px);
        transform: translateY(60px);
        -webkit-transition-delay: 400ms;
        -moz-transition-delay: 400ms;
        transition-delay: 400ms;
        -webkit-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
    }
}

body.contact #main > .intro .info > .bg {
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
    background: #F3F7FF;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
}

@media screen and (min-width: 992px) {
    body.contact #main > .intro .info > .bg {
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transition: -webkit-transform 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out;
    }
}

body.contact #main > .intro .info.is-visible .txt {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.contact #main > .intro .info.is-visible > .bg {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

body.contact #main > .intro .right {
    z-index: 2;
    position: absolute;
    right: 0;
    top: 204px;
    width: 54%;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.contact #main > .intro .right {
        right: 40px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right {
        width: 100%;
        position: relative;
        top: auto;
        right: auto;
    }
}

body.contact #main > .intro .right .form {
    position: relative;
    padding: 12.87% 17.5%;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.contact #main > .intro .right .form {
        padding: 12% 16% 11% 16%;
    }
}

@media screen and (min-width: 992px) {
    body.contact #main > .intro .right .form {
        opacity: 0;
        -webkit-transform: translateY(60px);
        -moz-transform: translateY(60px);
        -ms-transform: translateY(60px);
        transform: translateY(60px);
        -webkit-transition-delay: 400ms;
        -moz-transition-delay: 400ms;
        transition-delay: 400ms;
        -webkit-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right .form {
        padding: 0px 25px 5px 25px;
    }
}

body.contact #main > .intro .right .form h2 {
    color: #fff;
    margin-bottom: 68px;
}

    body.contact #main > .intro .right .form h2:after {
        left: -30px;
        position: relative;
        display: block;
        content: '';
        width: 73px;
        height: 1px;
        background: #2D8599;
        margin-top: 10px;
    }

    body.contact #main > .intro .right .form h2:before {
        content: '';
        display: block;
        position: relative;
        left: -36px;
        top: 28px;
        width: 7px;
        height: 7px;
        border: solid 1px #7F5D3F;
        border-radius: 30%;
        background: #7F5D3F;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right .form h2:after {
        left: -20px;
    }

    body.contact #main > .intro .right .form h2:before {
        top: 27px;
        left: -26px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right .form h2 {
        margin-left: 20px;
        margin-bottom: 20px;
    }
}

body.contact #main > .intro .right .form form input[type="text"],
body.contact #main > .intro .right .form form input[type="email"],
body.contact #main > .intro .right .form form .select,
body.contact #main > .intro .right .form form textarea {
    outline: none;
    width: 100%;
    background: #25237C;
    border: 1px solid #4240B6;
    color: #9593F3;
    font-size: 1.4em;
    padding: 18px;
}

body.contact #main > .intro .right .form form textarea {
    resize: none;
}

body.contact #main > .intro .right .form form .form-group {
    margin-bottom: 25px;
    *zoom: 1;
}

    body.contact #main > .intro .right .form form .form-group:before,
    body.contact #main > .intro .right .form form .form-group:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right .form form .form-group:last-child {
        padding-top: 0;
    }
}

body.contact #main > .intro .right .form form #checkbox {
    margin-bottom: 5px;
    font-size: 1.2em;
    color: #000;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right .form form #checkbox {
        font-size: 1.2em;
        margin-bottom: 25px;
    }
}

body.contact #main > .intro .right .form form #checkbox a {
    text-decoration: none;
    color: #000;
    border-bottom: 1px solid #2D8599;
    padding-bottom: 2px;
}

body.contact #main > .intro .right .form form #checkbox .checkbox {
    width: 17px;
    position: relative;
    display: inline-block;
    margin-right: 5px;
}

    body.contact #main > .intro .right .form form #checkbox .checkbox label {
        width: 17px;
        height: 17px;
        cursor: pointer;
        position: absolute;
        top: 0;
        left: 0;
        border-radius: 0;
        background: #25237C;
        border: 1px solid #4240B6;
    }

        body.contact #main > .intro .right .form form #checkbox .checkbox label:after {
            content: '';
            width: 9px;
            height: 5px;
            position: absolute;
            top: 3px;
            left: 3px;
            border: 1px solid #fff;
            border-top: none;
            border-right: none;
            opacity: 0;
            transform: rotate(-45deg);
        }

        body.contact #main > .intro .right .form form #checkbox .checkbox label:hover::after {
            opacity: 0.5;
        }

    body.contact #main > .intro .right .form form #checkbox .checkbox input[type=checkbox] {
        visibility: hidden;
    }

        body.contact #main > .intro .right .form form #checkbox .checkbox input[type=checkbox]:checked + label:after {
            opacity: 1;
        }

body.contact #main > .intro .right .form form .button-contact {
    text-align: right;
}

    body.contact #main > .intro .right .form form .button-contact button {
        display: inline-block;
        position: relative;
        height: 55px;
        padding: 0 35px;
        background: #7F5D3F;
        border: none;
        outline: none;
        cursor: pointer;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .intro .right .form form .button-contact button {
        width: 100%;
        height: 65px;
    }
}

body.contact #main > .intro .right .form form .button-contact button:disabled {
    opacity: 0.3;
}

    body.contact #main > .intro .right .form form .button-contact button:disabled:hover {
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
        opacity: 0;
    }

body.contact #main > .intro .right .form form .button-contact button div {
    top: 0;
    left: 0;
    position: absolute;
    height: 100%;
    width: 100%;
    background: #fff;
    opacity: 0.1;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
    -webkit-transform: scaleX(0);
    -moz-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transition: -webkit-transform 300ms ease-in-out;
    -moz-transition: -webkit-transform 300ms ease-in-out;
    transition: -webkit-transform 300ms ease-in-out;
}

body.contact #main > .intro .right .form form .button-contact button:hover div {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

@media screen and (min-width: 992px) {
    body.contact #main > .intro .right > .bg {
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transition: -webkit-transform 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out;
    }
}

body.contact #main > .intro .right.is-visible > .bg {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

body.contact #main > .intro .right.is-visible .form {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.contact #main > .maps {
    position: relative;
    bottom: -120px;
}

@media screen and (min-width: 992px) {
    body.contact #main > .maps {
        opacity: 0;
        -webkit-transform: translateY(60px);
        -moz-transform: translateY(60px);
        -ms-transform: translateY(60px);
        transform: translateY(60px);
        -webkit-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact #main > .maps {
        bottom: 0;
    }
}

body.contact #main > .maps .map {
    height: 560px;
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.contact #main > .maps .map {
        height: 40vh;
        max-height: 560px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    body.contact #main > .maps .map {
        height: 80vh;
        max-height: 560px;
    }
}

body.contact #main > .maps.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.case-study-detail #main > .header .container {
    height: 55vh;
    min-height: 150px;
    width: 100%;
    display: table;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .header .container {
        height: auto;
        min-height: inherit;
        padding-top: 120px;
        padding-bottom: 50px;
        display: block;
    }
}

body.case-study-detail #main > .header .container .txt {
    display: table-cell;
    vertical-align: middle;
}

    body.case-study-detail #main > .header .container .txt h2 {
        position: relative;
    }

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .header .container .txt h2 {
        -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
        -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
        transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
        opacity: 0;
        -webkit-transform: translateY(80px);
        -moz-transform: translateY(80px);
        -ms-transform: translateY(80px);
        transform: translateY(80px);
    }
}

body.case-study-detail #main > .header .container .txt h2:after {
    display: block;
    content: '';
    width: 126px;
    height: 1px;
    background: limegreen;
    position: relative;
    margin: 37px 0;
    left: -63px;
    opacity: 0;
    -webkit-transition: opacity 800ms ease-in-out 100ms, -webkit-transform 800ms ease-in-out 100ms;
    -moz-transition: opacity 800ms ease-in-out 100ms, -moz-transform 800ms ease-in-out 100ms;
    transition: opacity 800ms ease-in-out 100ms, transform 800ms ease-in-out 100ms;
    -webkit-transform: translateX(-250px);
    -moz-transform: translateX(-250px);
    -ms-transform: translateX(-250px);
    transform: translateX(-250px);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .header .container .txt h2:after {
        width: 60px;
        bottom: 0;
        left: -10px;
        opacity: 1;
        margin: 17px 0;
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }
}

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .header .container .txt h1 {
        -webkit-transition: opacity 600ms ease-in-out 700ms, -webkit-transform 600ms ease-in-out 700ms;
        -moz-transition: opacity 600ms ease-in-out 700ms, -moz-transform 600ms ease-in-out 700ms;
        transition: opacity 600ms ease-in-out 700ms, transform 600ms ease-in-out 700ms;
        opacity: 0;
        -webkit-transform: translateY(150px);
        -moz-transform: translateY(150px);
        -ms-transform: translateY(150px);
        transform: translateY(150px);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .header .container .txt h1 br {
        display: none;
    }
}

body.case-study-detail #main > .header.is-visible .container .txt h1 {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
}

body.case-study-detail #main > .header.is-visible .container .txt h2 {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
}

    body.case-study-detail #main > .header.is-visible .container .txt h2:after {
        opacity: 1;
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }

body.case-study-detail #main > .header-image {
    position: relative;
    *zoom: 1;
}

    body.case-study-detail #main > .header-image:before, body.case-study-detail #main > .header-image:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

    body.case-study-detail #main > .header-image .bg {
        position: absolute;
        left: 0;
        top: 16%;
        height: 72%;
        max-height: 611px;
        width: 81.5%;
        background: #FCF9F9;
    }

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .header-image .bg {
        -webkit-transition: -webkit-transform 800ms ease-in-out;
        -moz-transition: -moz-transform 800ms ease-in-out;
        transition: transform 800ms ease-in-out;
        -webkit-transform-origin: left 0;
        -moz-transform-origin: left 0;
        -ms-transform-origin: left 0;
        transform-origin: left 0;
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
    }
}

body.case-study-detail #main > .header-image .images {
    position: relative;
    float: right;
    width: 100%;
    max-width: 1138px;
    *zoom: 1;
}

    body.case-study-detail #main > .header-image .images:before, body.case-study-detail #main > .header-image .images:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

    body.case-study-detail #main > .header-image .images > img {
        position: absolute;
    }

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .header-image .images > img {
        opacity: 0;
        -webkit-transition: opacity 800ms ease-in-out, -webkit-transform 800ms ease-in-out;
        -moz-transition: opacity 800ms ease-in-out, -moz-transform 800ms ease-in-out;
        transition: opacity 800ms ease-in-out, transform 800ms ease-in-out;
        -webkit-transform: translateY(100px);
        -moz-transform: translateY(100px);
        -ms-transform: translateY(100px);
        transform: translateY(100px);
    }
}

body.case-study-detail #main > .header-image .images > img.header2 {
    position: relative;
    float: right;
    margin-top: 7%;
    width: 75%;
    max-width: 812px;
    z-index: 1;
    -webkit-transition-delay: 500ms, 0ms;
    -moz-transition-delay: 500ms, 0ms;
    transition-delay: 500ms, 0ms;
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;
}

body.case-study-detail #main > .header-image .images > img.header1 {
    position: absolute;
    right: 42.5%;
    top: -2.5%;
    width: 58.30%;
    max-width: 632px;
    -webkit-transition-delay: 400ms, 0ms;
    -moz-transition-delay: 400ms, 0ms;
    transition-delay: 400ms, 0ms;
    border-radius: 8px;
}

body.case-study-detail #main > .header-image.is-visible .bg {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

body.case-study-detail #main > .header-image.is-visible .images > img {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.case-study-detail #main > .header-txt {
    position: relative;
    padding: 92px 0 322px 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .header-txt {
        padding: 30px 0;
    }
}

body.case-study-detail #main > .header-txt .txt-p2 {
    position: relative;
    padding-left: 144px;
    padding-right: 150px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .header-txt .txt-p2 {
        padding: 0;
    }
}

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .header-txt .txt-p2 p {
        -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
        -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
        transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
        opacity: 0;
        -webkit-transform: translateY(150px);
        -moz-transform: translateY(150px);
        -ms-transform: translateY(150px);
        transform: translateY(150px);
    }
}

body.case-study-detail #main > .header-txt .txt-p2:before {
    content: '';
    display: block;
    height: 1px;
    width: 84px;
    background: #2D8599;
}

body.case-study-detail #main > .header-txt .txt-p2:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 12px;
    width: 7px;
    height: 7px;
    border: solid 1px #7F5D3F;
    border-radius: 30%;
    background: #7F5D3F;
}

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .header-txt .txt-p2:before {
        position: absolute;
        left: 0;
        top: 15px;
        -webkit-transition: -webkit-transform 400ms ease-in-out 300ms;
        -moz-transition: -moz-transform 400ms ease-in-out 300ms;
        transition: transform 400ms ease-in-out 300ms;
        -webkit-transform-origin: left top;
        -moz-transform-origin: left top;
        -ms-transform-origin: left top;
        transform-origin: left top;
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .header-txt .txt-p2:before {
        position: relative;
        margin-bottom: 35px;
        width: 45px;
    }

    body.case-study-detail #main > .header-txt .txt-p2:after {
        top: -3px;
    }
}

body.case-study-detail #main > .header-txt.is-visible .txt-p2 p {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.case-study-detail #main > .header-txt.is-visible .txt-p2:before {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks {
        padding-top: 50px;
    }
}

body.case-study-detail #main > .blocks .block {
    width: 100%;
    display: inline-block;
}

    body.case-study-detail #main > .blocks .block > div .container .txt .txt-p1 {
        -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
        -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
        transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
    }

        body.case-study-detail #main > .blocks .block > div .container .txt .txt-p1 p {
            margin-bottom: 0.5em;
        }

            body.case-study-detail #main > .blocks .block > div .container .txt .txt-p1 p span {
                font-weight: 300;
                margin: 0;
                padding: 0;
            }

                body.case-study-detail #main > .blocks .block > div .container .txt .txt-p1 p span.remark {
                    color: limegreen;
                    font-style: italic;
                    font-size: 0.7em;
                    padding-left: 15px;
                }

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .blocks .block > div .container .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

body.case-study-detail #main > .blocks .block > div .container .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks .block > div .container h3 br {
        display: none;
    }
}

body.case-study-detail #main > .blocks > .block1 {
    padding: 0 0 100px 0;
}

    body.case-study-detail #main > .blocks > .block1 > div {
        position: relative;
        width: 100%;
        height: 100%;
    }

        body.case-study-detail #main > .blocks > .block1 > div .bg {
            position: absolute;
            top: 28%;
            left: 0;
            height: 45%;
            max-height: 360px;
            background: #F3F7FF;
            width: calc(630px + ((100% - 1500px)/2));
            -webkit-transform: scaleX(0);
            -moz-transform: scaleX(0);
            -ms-transform: scaleX(0);
            transform: scaleX(0);
            -webkit-transform-origin: left center;
            -moz-transform-origin: left center;
            -ms-transform-origin: left center;
            transform-origin: left center;
            -webkit-transition: -webkit-transform 600ms ease-in-out;
            -moz-transition: -webkit-transform 600ms ease-in-out;
            transition: -webkit-transform 600ms ease-in-out;
        }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block1 > div .bg {
        -webkit-transform: scaleX(1);
        -moz-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1);
    }
}

body.case-study-detail #main > .blocks > .block1 > div .bg.is-visible {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.case-study-detail #main > .blocks > .block1 > div .bg {
        height: 260px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block1 > div .bg {
        display: none;
        bottom: -25px;
        top: auto;
        width: calc(100% - 25px);
        height: auto;
    }

        body.case-study-detail #main > .blocks > .block1 > div .bg:after {
            content: "";
            display: block;
            padding-bottom: 67%;
        }
}

body.case-study-detail #main > .blocks > .block1 > div .container {
    *zoom: 1;
    display: table;
}

    body.case-study-detail #main > .blocks > .block1 > div .container .img #backstretch {
        height: 270px;
        width: 270px;
    }

@media screen and (min-width: 480px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .img #backstretch {
        height: 300px;
        width: 300px;
    }
}

@media screen and (min-width: 768px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .img #backstretch {
        height: 340px;
        width: 340px;
    }
}

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .img #backstretch {
        height: 400px;
        width: 400px;
    }
}

@media screen and (min-width: 1200px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .img #backstretch {
        height: 420px;
        width: 420px;
    }
}

@media screen and (min-width: 1480px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .img #backstretch {
        height: 580px;
        width: 580px;
    }
}

body.case-study-detail #main > .blocks > .block1 > div .container:before, body.case-study-detail #main > .blocks > .block1 > div .container:after {
    display: table;
    clear: both;
    content: "";
    line-height: 0;
}

body.case-study-detail #main > .blocks > .block1 > div .container .img {
    float: left;
    width: 48%;
    max-width: 660px;
}

    body.case-study-detail #main > .blocks > .block1 > div .container .img img {
        border-radius: 8px;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .img {
        margin-top: 15px;
        max-width: none;
        float: none;
        text-align: right;
        width: calc(100% - 20px);
        display: table-caption;
        caption-side: bottom;
        -webkit-transform: translateX(20px);
        -moz-transform: translateX(20px);
        -ms-transform: translateX(20px);
        transform: translateX(20px);
    }
}

body.case-study-detail #main > .blocks > .block1 > div .container .txt {
    padding-top: 55px;
    margin-left: 10%;
    float: left;
    width: 35%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block1 > div .container .txt {
        float: none;
        width: 100%;
        margin-left: 0;
        padding-top: 0;
    }
}

body.case-study-detail #main > .blocks > .block2 {
    margin: 100px 0 180px 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block2 {
        margin: 0 0 100px 0;
    }
}

body.case-study-detail #main > .blocks > .block2 > div {
    background: #fff;
    position: relative;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block2 > div {
        *zoom: 1;
    }

        body.case-study-detail #main > .blocks > .block2 > div:before, body.case-study-detail #main > .blocks > .block2 > div:after {
            display: table;
            clear: both;
            content: "";
            line-height: 0;
        }
}

body.case-study-detail #main > .blocks > .block2 > div .images {
    position: absolute;
    top: 15%;
    right: 0;
    width: 51%;
    max-width: 860px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block2 > div .images {
        position: static;
        width: 100%;
        max-width: none;
        float: right;
        width: calc(100% - 20px);
        padding-top: 50px;
    }
}

body.case-study-detail #main > .blocks > .block2 > div .images > div {
    position: relative;
    height: 100%;
    width: 100%;
}

    body.case-study-detail #main > .blocks > .block2 > div .images > div:after {
        content: '';
        display: block;
        padding-bottom: 66%;
    }

    body.case-study-detail #main > .blocks > .block2 > div .images > div > img {
        position: absolute;
        top: -15.8%;
        left: -4%;
        display: block;
        z-index: 3;
        width: 75%;
    }

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .blocks > .block2 > div .images > div > img {
        opacity: 0;
        -webkit-transition: opacity 600ms ease-in-out 300ms;
        -moz-transition: opacity 600ms ease-in-out 300ms;
        transition: opacity 600ms ease-in-out 300ms;
    }

        body.case-study-detail #main > .blocks > .block2 > div .images > div > img.is-visible {
            opacity: 1;
        }
}

body.case-study-detail #main > .blocks > .block2 > div .images > div .img {
    height: 90%;
    position: absolute;
    right: 0;
    top: 10%;
}

    body.case-study-detail #main > .blocks > .block2 > div .images > div .img img {
        width: 100%;
        display: block;
        border-top-left-radius: 8px;
        border-bottom-left-radius: 8px;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block2 > div .images > div .img img {
        top: auto;
        bottom: 50px;
        position: relative;
    }
}

body.case-study-detail #main > .blocks > .block2 > div .container {
    *zoom: 1;
}

    body.case-study-detail #main > .blocks > .block2 > div .container:before, body.case-study-detail #main > .blocks > .block2 > div .container:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

    body.case-study-detail #main > .blocks > .block2 > div .container .txt {
        margin-left: 5%;
        float: left;
        width: 35%;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block2 > div .container .txt {
        float: none;
        width: 100%;
        margin-left: 0;
        padding-top: 0;
    }
}

body.case-study-detail #main > .blocks > .block3 {
    margin: 100px 0 100px 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 {
        margin: 0 0 0 0;
    }
}

body.case-study-detail #main > .blocks > .block3 > div {
    position: relative;
    width: 100%;
    height: 100%;
}

    body.case-study-detail #main > .blocks > .block3 > div .bg {
        position: absolute;
        top: 20%;
        left: 0;
        height: 55%;
        background: #F3F7FF;
        width: calc(630px + ((100% - 1500px)/2));
        -webkit-transform: scaleX(0);
        -moz-transform: scaleX(0);
        -ms-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transform-origin: left center;
        -moz-transform-origin: left center;
        -ms-transform-origin: left center;
        transform-origin: left center;
        -webkit-transition: -webkit-transform 600ms ease-in-out;
        -moz-transition: -webkit-transform 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .bg {
        -webkit-transform: scaleX(1);
        -moz-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1);
    }
}

body.case-study-detail #main > .blocks > .block3 > div .bg.is-visible {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    transform: scaleX(1);
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.case-study-detail #main > .blocks > .block3 > div .bg {
        height: 260px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .bg {
        display: none;
        bottom: -25px;
        top: auto;
        width: calc(100% - 25px);
        height: auto;
    }

        body.case-study-detail #main > .blocks > .block3 > div .bg:after {
            content: "";
            display: block;
            padding-bottom: 67%;
        }
}

body.case-study-detail #main > .blocks > .block3 > div .container {
    *zoom: 1;
}

    body.case-study-detail #main > .blocks > .block3 > div .container:before, body.case-study-detail #main > .blocks > .block3 > div .container:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .container {
        display: -webkit-flex;
        display: flex;
        -webkit-flex-flow: row wrap;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
    }
}

body.case-study-detail #main > .blocks > .block3 > div .container .img {
    float: left;
    width: 48%;
    *zoom: 1;
    position: relative;
}

    body.case-study-detail #main > .blocks > .block3 > div .container .img:before, body.case-study-detail #main > .blocks > .block3 > div .container .img:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .container .img {
        order: 2;
        width: 100%;
        float: none;
    }
}

body.case-study-detail #main > .blocks > .block3 > div .container .img img {
    display: block;
}

    body.case-study-detail #main > .blocks > .block3 > div .container .img img:nth-child(1) {
        width: 50%;
        max-width: 350px;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .container .img img:nth-child(1) {
        width: 58%;
        position: relative;
        left: -4%;
    }
}

body.case-study-detail #main > .blocks > .block3 > div .container .img img:nth-child(2) {
    position: absolute;
    top: 10%;
    right: 2%;
    width: 58%;
    max-width: 406px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .container .img img:nth-child(2) {
        width: 65%;
        right: -8%;
    }
}

body.case-study-detail #main > .blocks > .block3 > div .container .txt {
    padding-top: 10%;
    padding-right: 7%;
    float: right;
    width: 48%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .blocks > .block3 > div .container .txt {
        float: none;
        width: 100%;
        margin-left: 0;
        padding-top: 0;
        order: 1;
    }
}

body.case-study-detail #main > .tools {
    display: inline-block;
    width: 100%;
    margin: 100px 0;
    position: relative;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools {
        margin: 50px 0 0 0;
    }
}

body.case-study-detail #main > .tools .bg {
    right: 0;
    height: 100%;
    top: 12%;
    width: 66%;
    position: absolute;
    background: #F3F7FF;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .bg {
        display: none;
    }
}

@media screen and (min-width: 0) and (max-width: 1279px) {
    body.case-study-detail #main > .tools > div {
        margin: 0;
    }
}

body.case-study-detail #main > .tools .container:before, body.case-study-detail #main > .tools .container:after {
    display: table;
    clear: both;
    content: "";
    line-height: 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container {
        padding: 50px 20px;
    }
}

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .tools .container > div {
        -webkit-transform: translateY(80px);
        -moz-transform: translateY(80px);
        -ms-transform: translateY(80px);
        transform: translateY(80px);
        -webkit-transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        -moz-transition: -moz-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        transition: -webkit-transform 600ms ease-in-out, opacity 600ms ease-in-out;
        opacity: 0;
    }
}

body.case-study-detail #main > .tools .container > div.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.case-study-detail #main > .tools .container .left {
    float: left;
    width: 50%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container .left {
        float: none;
        width: 100%;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container .left h3 {
        position: relative;
    }

        body.case-study-detail #main > .tools .container .left h3 br {
            display: none;
        }
}

body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2) {
    margin-left: 75px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2) {
        margin-left: 55px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2) {
        margin-left: 0;
    }
}

@media screen and (min-width: 992px) {
    body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2):before {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -moz-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px);
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2):before {
        width: 70px;
        left: -85px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2):before {
        display: none;
    }
}

body.case-study-detail #main > .tools .container .left h3 .reveal:nth-of-type(2).is-visible:before {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.case-study-detail #main > .tools .container .right {
    float: right;
    width: 40%;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container .right {
        float: none;
        width: 100%;
    }
}

body.case-study-detail #main > .tools .container .right ul li {
    margin-top: 60px;
}

    body.case-study-detail #main > .tools .container .right ul li a {
        color: #fff;
        text-decoration: none;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.case-study-detail #main > .tools .container .right ul li {
        margin-top: 30px;
    }
}

body.case-study-detail #main > .tools .container .right ul li:first-child {
    margin-top: 0;
}

body.case-study-detail #main > .tools .container .right ul li h3 {
    margin-bottom: 25px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main .container {
        padding: 0;
    }
}

body.legal #main > .intro {
    position: relative;
    *zoom: 1;
    padding-top: 300px;
}

    body.legal #main > .intro:before, body.legal #main > .intro:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main > .intro {
        padding-top: 120px;
    }
}

body.legal #main > .intro .left {
    position: relative;
}

    body.legal #main > .intro .left > .txt {
        padding-bottom: 360px;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main > .intro .left > .txt {
        padding: 0 25px 150px 25px;
    }
}

body.legal #main > .intro .left > .txt h1.title-header1 {
    padding-left: 63px;
}

    body.legal #main > .intro .left > .txt h1.title-header1:after {
        position: relative;
        left: -63px;
        margin-top: 23px;
        display: block;
        content: '';
        height: 1px;
        width: 126px;
        background: #2D8599;
        -webkit-transform: translateX(-100px);
        -moz-transform: translateX(-100px);
        -ms-transform: translateX(-100px);
        transform: translateX(-100px);
        opacity: 0;
        -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
        -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
        transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
    }

    body.legal #main > .intro .left > .txt h1.title-header1.is-visible:after {
        opacity: 1;
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main > .intro .left > .txt h1.title-header1 {
        padding-left: 0;
    }

        body.legal #main > .intro .left > .txt h1.title-header1:after {
            left: 0;
            width: 45px;
            opacity: 1;
            -webkit-transform: translateX(0);
            -moz-transform: translateX(0);
            -ms-transform: translateX(0);
            transform: translateX(0);
        }
}

body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2) {
    margin-left: 75px;
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2) {
        margin-left: 55px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2) {
        margin-left: 0;
    }
}

@media screen and (min-width: 992px) {
    body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2):before {
        opacity: 0;
        -webkit-transform: translateY(20px);
        -moz-transform: translateY(20px);
        -ms-transform: translateY(20px);
        transform: translateY(20px);
    }
}

@media screen and (min-width: 992px) and (max-width: 1279px) {
    body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2):before {
        width: 70px;
        left: -85px;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2):before {
        display: none;
    }
}

body.legal #main > .intro .left > .txt h1.title-header1 .reveal:nth-of-type(2).is-visible:before {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

body.legal #main > .intro .left > .txt .txt-p1 {
    margin: 0 auto;
    margin-top: 90px;
    width: 100%;
    max-width: 960px;
    -webkit-transition: opacity 600ms ease-in-out, -webkit-transform 600ms ease-in-out;
    -moz-transition: opacity 600ms ease-in-out, -moz-transform 600ms ease-in-out;
    transition: opacity 600ms ease-in-out, transform 600ms ease-in-out;
}

    body.legal #main > .intro .left > .txt .txt-p1 ul {
        list-style-type: none;
        font-weight: 300;
        padding-left: 0;
    }

        body.legal #main > .intro .left > .txt .txt-p1 ul li {
            margin: 1.0em 0;
        }

@media screen and (min-width: 992px) {
    body.legal #main > .intro .left > .txt .txt-p1 {
        opacity: 0;
        -webkit-transform: translateY(90px);
        -moz-transform: translateY(90px);
        -ms-transform: translateY(90px);
        transform: translateY(90px);
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.legal #main > .intro .left > .txt .txt-p1 {
        max-width: none;
        margin-top: 53px;
    }

        body.legal #main > .intro .left > .txt .txt-p1 ul {
            margin-left: 0;
            list-style-type: none;
        }
}

body.legal #main > .intro .left > .txt .txt-p1.is-visible {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}

.block-revealer__element {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    pointer-events: none;
    opacity: 0;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .block-revealer__element {
        display: none;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    .block-revealer__content {
        opacity: 1 !important;
        word-wrap: break-word;
        white-space: normal;
    }
}

.content_title_inner {
    flex: none;
    display: inline-block;
    white-space: nowrap;
    position: relative;
    font-family: 'Dancing Script', cursive;
    color: #0C6A7F;
}

    .content_title_inner:nth-of-type(2) {
        z-index: 1;
    }

@media screen and (min-width: 0) and (max-width: 991px) {
    .content_title_inner {
        white-space: normal;
        opacity: 1;
    }
}

.content_image {
    display: block;
    width: 100%;
}

.footer {
    background: #AF9C8B;
    padding: 92px 0 80px 0;
    font-weight: 300;
    color: #fff;
    font-size: 1.4em;
}

    .footer .container .bottom .company a,
    .footer .container .bottom .company a:focus,
    .footer .container .bottom .company a:hover,
    .footer .container .bottom .company a:visited,
    .footer .container .bottom .company a:active {
        text-decoration: none;
        color: #fff;
        border-bottom: 1px solid #2D8599;
    }

@media screen and (min-width: 992px) and (max-width: 1279px) {
    .footer {
        padding: 72px 0 60px 0;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    .footer {
        padding: 42px 0 40px 0;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer {
        padding: 50px 0 30px 0;
    }
}

.footer .container .top {
    *zoom: 1;
    margin-bottom: 130px;
    line-height: 2.9em;
}

    .footer .container .top:before, .footer .container .top:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 992px) and (max-width: 1279px) {
    .footer .container .top {
        margin-bottom: 90px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    .footer .container .top {
        margin-bottom: 40px;
    }
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .top {
        margin-bottom: 0;
    }
}

.footer .container .top > div {
    float: left;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .top > div {
        float: none;
        padding-bottom: 20px;
    }
}

.footer .container .top > div:nth-child(2) {
    width: 240px;
    float: right;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .top > div:nth-child(2) {
        float: none;
        width: 100%;
    }
}

.footer .container .bottom {
    *zoom: 1;
    line-height: 27px;
}

    .footer .container .bottom:before, .footer .container .bottom:after {
        display: table;
        clear: both;
        content: "";
        line-height: 0;
    }

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .bottom {
        display: -webkit-box;
        display: -moz-box;
        -webkit-box-orient: vertical;
        -moz-box-orient: vertical;
    }
}

.footer .container .bottom > div {
    float: left;
    color: #fff;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .bottom > div {
        float: none;
        -webkit-box-ordinal-group: 2;
        -moz-box-ordinal-group: 2;
        font-size: 12px;
        margin-top: 10px;
    }
}

.footer .container .bottom > div:nth-child(2) {
    float: right;
    width: 240px;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .bottom > div:nth-child(2) {
        float: none;
        width: 100%;
        -webkit-box-ordinal-group: 1;
        -moz-box-ordinal-group: 1;
        margin-top: 10px;
    }
}

.footer .container .bottom > div:nth-child(2) ul li {
    display: inline-block;
    margin-right: 15px;
}

@media screen and (min-width: 0) and (max-width: 767px) {
    .footer .container .bottom > div:nth-child(2) ul li {
        margin-right: 30px;
    }
}

.footer .container .bottom > div:nth-child(2) ul li a {
    width: 37px;
    height: 37px;
    background-repeat: no-repeat;
    background-position: 0 0;
    display: block;
}

    .footer .container .bottom > div:nth-child(2) ul li a:hover {
        background-position: 0 bottom;
    }

    .footer .container .bottom > div:nth-child(2) ul li a.twitter {
        background-image: url("Images/twitter.png");
    }

    .footer .container .bottom > div:nth-child(2) ul li a.instagram {
        background-image: url("Images/instagram.png");
    }

    .footer .container .bottom > div:nth-child(2) ul li a.facebook {
        background-image: url("Images/facebook.png");
    }

    .footer .container .bottom > div:nth-child(2) ul li a.youtube {
        background-image: url("Images/youtube.png");
    }

body.contact .footer {
    padding-top: 100px;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact .footer {
        padding: 0;
        padding-top: 20px;
        padding-bottom: 20px;
        position: absolute;
        left: 0;
        width: 100%;
    }
}

body.contact .footer .container .top,
body.contact .footer .container .bottom #footerPrivate {
    display: none;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact .footer .container .bottom {
        line-height: normal;
    }
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact .footer .container .bottom > div:nth-child(1) {
        text-align: center;
    }
}

body.contact .footer .container .bottom > div:nth-child(2) {
    width: auto;
}

@media screen and (min-width: 0) and (max-width: 991px) {
    body.contact .footer .container .bottom > div:nth-child(2) {
        display: none;
    }
}

body.contact .footer .container .bottom > div:nth-child(2) ul li {
    margin-right: 0;
    margin-left: 15px;
}
