/* ========================== Spacing Styles ========================= */
.site-content{
    
}

.blurbColumns .container { 
    padding: 0; 
}

.row-flush {
    margin: 0;
}

@media screen and (max-width: 991px){
    .two-col-wave-bottom-row .text-area,
    .two-col-wave-top-row .text-area,
    .two-col-img-right-row .text-area,
    .two-col-img-left-row .text-area,
    .two-col-right-row .text-area
    {
        margin-bottom: 30px
    }
}

@media screen and (max-width: 767px){
    .site-content{
        margin-top: 0;
    }
}

.four-col-row.blurbColumns{
    padding-top: 0;
}

.no-padding{
    padding:0;
}

.no-padding-bottom{
    padding-bottom: 0;
}

.no-margin{
    margin: 0;
}

.no-margin-bottom{
    margin-bottom: 0;
}

.margin-top-small{
    margin-top: 5px;
}

.padding-bottom-large{
    padding-bottom: 15px;
}

@media screen and (min-width: 1024px){
    .text-area img.aligncenter.margin-top-neg,
    .margin-top-neg{
        margin-top: -20px;
    }

    .text-area img.aligncenter.margin-top-neg-double,
    .margin-top-neg-double{
         margin-top: -50px;
    }
}
/* ========================== END Spacing Styles ========================= */


/* =============== Text Classes ================*/

.font18{
    font-size: 18px;
    line-height: 24px;
}

.font20{
    font-size: 20px;
    line-height: 26px;
}

/* =============== End Text Classes ================*/



/* =============== Hero Properties ================*/
.home section,
.about-wave-page section,
.clients-page section,
.blurbColumns {
    padding: 60px 0;
}

    .home section:last-of-type {
        padding-bottom: 5px;
    }

    .clients-page section:last-of-type {
        padding-bottom: 100px;
        padding-top: 70px;
    }

@media screen and (max-width: 767px){
.home section, .blurbColumns {
    padding: 30px 0;
}
}

@media only screen and (max-width: 767px) {
.home section{
    padding: 30px 0;
}
}

#hero.hero-tall .container .text-area{
    width: 40%;
}

.mobileHeroText {
    font-family: "interstate", sans-serif;
font-weight: 400;
font-style: normal;
color: #FFF !important;
}

.mobileHeroText blockquote{
    font-family: "interstate", sans-serif;
font-weight: 400;
font-style: normal;
color: #FFF !important;
}
@media screen and (min-width: 768px) and (max-width: 1023px){
    #hero.hero-tall{
        background-size: 145%;
        background-position: 32% 0;
        min-height: 500px;
    }
    .hero-tall p,
    .hero-short p{
        font-size: 18px;
        line-height: 24px;
        width: 100%;
    }
    #hero.hero-tall .container .text-area {
        width: 47%;
    }
}

@media only screen and (max-width: 767px) {
    #hero.hero-tall .container {
        background-image: url('/wp-content/uploads/2020/04/bigstock-Digital-Marketing-Concept-Lan-306817033-2-300x181.jpg');
        background-size: 85%;
        background-repeat: no-repeat;
        background-position: center 35%;
    }
    
    #hero.hero-tall .container .text-area {
        width: 100%;
    }

    #hero.hero-tall {
        background-image: url('/wp-content/uploads/2020/04/home-wave-bottom-hero.png')!important;
        background-repeat: no-repeat;
        background-position: bottom center;
        background-size: 100%;
        padding: 0 0 80px 0;
        min-height: 700px;
    }

    .hero-mobile-split{
        font-family: "interstate", sans-serif;
        font-weight: 400;
        font-style: normal;
        color: #fff;
    }

}

@media screen and (min-width: 557px) and (max-width: 767px) {
    #hero.hero-tall .container {
        background-position: center 29%;
    }
    
    #hero.hero-tall {
        min-height: 830px;
    }

    #hero.hero-tall .container{
        padding-bottom: 100px;
    }
}

@media screen and (min-width: 400px) and (max-width: 556px) {
    #hero.hero-tall {
        height: 640px;
    }

    #hero.hero-tall .container{
        padding-bottom: 100px;
        background-position: center 30%;
    }
}

/* =============== END Hero ================*/


@media screen and (min-width: 1800px) {
    .jcarousel > ul {
        margin-left: -15px;
    }
}

.two-col-form-row .gform_wrapper {
    margin: 0;
}

.two-col-form-row .gform_wrapper ul.gform_fields {
    display: flex;
    flex-wrap: wrap;
}

.two-col-form-row .gform_wrapper ul li.gfield {
    flex: 0 50%;
}

    .two-col-form-row .gform_wrapper ul li.gfield:nth-of-type(-n+2) {
        margin-top: 0;
    }

    .two-col-form-row .gform_wrapper ul li.gfield:nth-of-type(-n+2) .ginput_container {
        margin-top: 0;
    }

.two-col-form-row .gform_wrapper ul li.gfield#field_1_8 {
    flex: 0 100%;
}

    .two-col-form-row .gform_wrapper ul li.gfield#field_1_9 {
        flex: 0 20%;
        position: absolute;
        bottom: -5px;
        right: 17%;
    }

.two-col-form-row .gform_wrapper .top_label .gfield_label, .two-col-form-row .gform_wrapper legend.gfield_label {
    display: none;
}

    .two-col-form-row .gform_wrapper .gform_footer {
        text-align: right;
        padding-top: 0;
        margin-top: 0;
    }

    .two-col-form-row a {
        line-height: 2em;
    }

.two-col-form-row a.phoneLink {
    font-size: 1.375em;
    line-height: 2.5em;
}

input[type="text"], input[type="email"], input[type="url"], 
input[type="password"], input[type="search"], input[type="number"], 
input[type="tel"], input[type="range"], input[type="date"], input[type="month"], 
input[type="week"], input[type="time"], input[type="datetime"], input[type="datetime-local"], input[type="color"], textarea {
    border-radius: 6px;
    border-color: #ccc;
}

@media only screen and (min-width: 641px) {
    .two-col-form-row .gform_wrapper textarea.large {
        height: 222px;
    }
}

@media screen and (max-width: 1338px) {
    .hero-short {
        background-size: contain;
    }
}

@media screen and (max-width: 1024px) {
    .hero-short{
        min-height: 600px;
    }
    .hero-short{
        padding: 30px 0;
    }
}

@media screen and (max-width: 991px){
    .hero-short{
        position: relative;
    }
}

.hero-short h1{
    
}
.hero-short p{
    margin-bottom: 100px;
    max-width: 42%;
    text-align: left;
}

@media screen and (max-width: 767px){
    .hero-short {
        background-position: -60vw 110px;
        background-size: 148vw;
    }

        .hero-short h1 {
            margin-bottom: 58vw;
        }

    .hero-short p{
        line-height: 22px;
        max-width: 100%;
    }
}
/* =============== END Short Hero ==================*/


/* =============== Start About Short Hero ==================*/

.about-wave-page .hero-short{
    background-image: url("/wp-content/uploads/2020/04/about-wave-icon.png"), linear-gradient(to top, #eee 0%,#fff 40%);
    background-position: right 40%;
    min-height: 490px;
}

    .about-wave-page .hero-short p {
        max-width: 70%;
    }




@media screen and (max-width: 991px){
    .about-wave-page .hero-short p{
        max-width: 70%;
    }
}

@media screen and (max-width: 767px){
    .about-wave-page .hero-short,
    .clients-page .hero-short {
        background-image: url("/wp-content/uploads/2020/04/about-wave-icon-mobile.png");
        background-position: bottom center;
        background-size: 120%;
        padding-top: 0px;
        min-height: 680px;
    }

        .about-wave-page .hero-short .container,
        .clients-page .hero-short  .container{
            padding-left: 15px;
        }

        .about-wave-page .hero-short p, 
        .clients-page .hero-short p {
            line-height: 22px;
            max-width: 100%;
        }
}
/* =============== END About Short Hero ==================*/

@media screen and (max-width: 767px){
}

@media screen and (max-width: 425px){

}

/* =============== Carousel Properties ================*/
  .jcarousel-control-prev,
  .jcarousel-control-next{
      background-image: none;
  }
/* =============== END Carousel Properties ================*/


/* =============== WP Testimonial Slider ==================*/
.wp-block-image img{
    max-width: 50%;
}

.ciSlideContent .text-inner .text-wrap p{
    color: #FFF;
}

.jcarousel-wrapper{
    margin-top: 0;
}
/* =============== END WP Testimonial Slider ==================*/


/* =============== BlurbColumn Width ==================*/

#hero.hero-short span,
.two-col-wave-bottom-row span,
.two-col-wave-top-row span,
.two-col-img-right-row span,
.two-col-img-left-row span,
.two-col-right-row span,
.three-col-icons-row span{
    color: #FFF;
    display: block;
    text-align: left;
    font-size: 20px;
    line-height: 26px;
    margin-bottom: 20px;
}

.two-col-wave-bottom-row p,
.two-col-wave-top-row p,
.two-col-img-right-row p,
.two-col-right-row p,
.two-col-right-row ul{
  
}

.two-col-img-left-row p,
.two-col-img-left-row h2{
    padding-left: 0;
}

.two-col-img-right-row p.no-padding-right,
.two-col-right-row p.no-padding-right,
.two-col-wave-bottom-row p.no-padding-right,
.two-col-wave-bottom-row p.no-padding-right,
.two-col-wave-top-row p.no-padding-right{
    padding-right: 0;
}

.two-col-img-left-row p.no-padding-left{
    padding-left: 0;
}

.two-col-img:nth-of-type(odd) {
    position: relative;
}

.two-col-img:nth-of-type(even) {
    position: relative;

}

    .two-col-img:nth-of-type(even):before {
        content: "";
        position: absolute;
        top: -3.6vw;
        left: 0;
        right: 0;
        height: 3.6vw;
    }

    .two-col-img:nth-of-type(even):after {
        content: "";
        position: absolute;
        bottom: -3.6vw;
        left: 0;
        right: 0;
        height: 3.6vw;
        z-index: 2;
    }

.wave-section,
.wave-section-both-gray {
    background: none;
    background-color: #4E215D;
    position: relative;
    margin-bottom: 50px;
}

    .wave-section:before,
    .wave-section-both-gray:before {
        content: "";
        position: absolute;
        top: -3.6vw;
        left: 0;
        right: 0;
        height: 3.6vw;
    }

    .wave-section:after,
    .wave-section-both-gray:after {
        content: "";
        position: absolute;
        bottom: -3.6vw;
        left: 0;
        right: 0;

        height: 3.6vw;
    }

.wave-section-both-white {
    background: none;
    background-color: #fff;
    position: relative;
    margin-bottom: 0;
}

    .wave-section-both-white:before {
        content: "";
        position: absolute;
        top: -1.8vw;
        left: 0;
        right: 0;
        height: 3.6vw;
        z-index: 2;
    }

    .wave-section-both-white:after {
        content: "";
        position: absolute;
        bottom: -1.8vw;
        left: 0;
        right: 0;

        height: 3.6vw;
        z-index: 2;
    }

.wave-section-top-white {
    background: none;
    background-color: #000632;
    position: relative;
}

    .wave-section-top-white:before {
        content: "";
        position: absolute;
        top: -3.6vw;
        left: 0;
        right: 0;

        height: 7.251vw;
        z-index: 2;
    }

.pt-partner.wave-section-top-white {
    padding-top: 40px;
}

.wave-section-bottom-white {

    position: relative;
    margin-bottom: 50px;
}
    .wave-section-bottom-white:after {
        content: "";
        position: absolute;
        bottom: -3.6vw;
        left: 0;
        right: 0;

        height: 3.6vw;
        z-index: 2;
    }

.wave-section-top-gray {
    position: relative;
    margin-bottom: 50px;
}

    .wave-section-top-gray:after {
        content: "";
        position: absolute;
        bottom: -3.6vw;
        left: 0;
        right: 0;
        height: 3.6vw;
        z-index: 2;
    }

.wave-section-btm-gray {
    position: relative;
    margin-bottom: 50px;
}

    .wave-section-btm-gray:after {
        content: "";
        position: absolute;
        bottom: -3.6vw;
        left: 0;
        right: 0;
        height: 3.6vw;
        z-index: 2;
    }

    .image-wrap.wave-section-bottom {
        margin-bottom: 0;
    }



    /*.solutions-page .hero-short {
        position: relative;
        margin-bottom: 50px;
    }

        .solutions-page .hero-short:after {
            content: "";
            position: absolute;
            bottom: -3.6vw;
            left: 0;
            right: 0;

            height: 3.6vw;
            z-index: 2;
        } */

.two-col-img-right-row .row h2 {
    text-align: left;
}

.two-col-img-right-row .row h3 {
    color: #FFF;
}

.two-col-img-right-row .row p {
    padding-right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.two-col-img-right-row .row img {
    /*object-fit: cover;
    max-width: none;
    width: 100%;*/
    width: 40%;
}

.two-col-img-left-row .row h2 {
    text-align: left;
}

.two-col-img-left-row .row h3 {
    color: #FFF;
}

.two-col-img-left-row .row p {
    padding-left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.two-col-img-left-row .row img {
    width: 40%;
}

@media screen and (max-width: 991px){
    #hero.hero-short span,
    .two-col-wave-bottom-row span,
    .two-col-wave-top-row span,
    .two-col-img-right-row span,
    .two-col-img-left-row span,
    .two-col-right-row span{
        font-size: 18px;
        line-height: 24px;
    }
    
    .two-col-wave-bottom-row img,
    .two-col-wave-top-row img,
    .two-col-img-right-row img,
    .two-col-img-left-row img,
    .two-col-right-row img{
        max-width: 100%;
    }
}

@media screen and (max-width: 991px){
    .two-col-img-left-row p, 
    .two-col-img-left-row h2{
        padding-left: 0;
    }

    .two-col-right-row p,
    .two-col-right-row ul,
    .two-col-img-right-row p,
    .two-col-img-right-row h2,
    .two-col-wave-bottom-row p,
    .two-col-wave-top-row p {
        padding-right: 0;
    }
}

.four-col-row h3{
    padding-bottom: 10px;
    position: relative;
    text-align: center;
    margin: 0 auto 30px;
}

.four-col-row h3:before{
    content: "";
    position: absolute;
    width: 50%;
    height: 1px;
    bottom: 0;
    left: 25%;
    border-bottom: 2px solid #d8d8d8;
}

/* Center Headers */
.wave-icon,
.one-col-row h3,
.three-col-icons-row h2,
.three-col-icons-row-two h2,
.three-col-icons-row h3,
.three-col-icons-row-two h3,
.four-col-description-row h3,
.five-col-wave-logo-bottom-row h2{
    text-align: center;
}

/* =============== END BlurbColumn Width Classes ==================*/


/* =============== Wave Section Classes ==================*/

.wave-top.blurbColumns {
    position: relative;
}

section.wave-top::before {
    content: "";
    position: absolute;
    top: -3.6vw;
    left: 0;
    right: 0;
    height: 3.6vw;
    z-index: 2;
}

.wave-btm.blurbColumns{

    position: relative;
    
}

section.wave-btm::after {
    content: "";
    position: absolute;
    bottom: -3.6vw;
    left: 0;
    right: 0;

    height: 3.6vw;
    z-index: 2;
}

@media screen and (max-width: 991px){
    section.wave-btm::after{
        /*padding-top: 20px;*/
    }
}

@media screen and (max-width: 991px){
    section.wave-top::before{
        /*padding-bottom: 40px;*/
    }
}
/* =============== END Wave Section Classes ==================*/


/* =============== Three Col Icon Row Layout ================*/

.three-col-icons-row-two.blurbColumns {
    padding-top: 15px;
}

/* ================= END Three Col Icon Row Layout ================ */


/* =============== Card and Wave Icon Column Classes ==================*/
.four-col-row .text-area,
.four-col-icons-top-row .text-area,
.five-col-icons-top-row .text-area{
    -webkit-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.2);
    -moz-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.2);
    box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.2);
    border-radius: 4px;
    padding: 20px 15px 15px 15px;
    text-align: center;
}

.four-col-row .text-area{
    height: 180px;
}

.four-col-row .text-area a{
    color: #272935;
    font-size: 16px;
    text-decoration: none;
    transition: 0.3s;
}

.four-col-row .text-area:visited, 
.four-col-row .text-area:hover,
.four-col-row .text-area:active{
    cursor: pointer;
    -webkit-box-shadow: 0px 0px 5px 0px rgba(29,83,128,1.0);
    -moz-box-shadow: 0px 0px 5px 0px rgba(29,83,128,1.0);
    box-shadow: 0px 0px 5px 0px rgba(29,83,128,1.0);
    transition: 0.3s;
    transform: translate(0, -10px); /* Standard syntax */
}

.five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3:last-child,
.four-col-icons-top-row .col-lg-3.col-xs-12.colNum-4:last-child{
    padding-bottom: 30px;
}

@media screen and (max-width: 1338px){
    .four-col-row .text-area,
    .four-col-icons-top-row .text-area{
        height: 220px;
    }

    .four-col-row .text-area{
        height: 200px;
    }
    
    .five-col-icons-top-row .text-area{
        height: 190px;
    }
}

.five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3{
    max-width: 20%;
    padding: 15px;
}

.four-col-row .col-lg-3.col-xs-12.colNum-4,
.four-col-icons-top-row .col-lg-3.col-xs-12.colNum-4{
    max-width: 25%;
    padding: 15px;
}

.five-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3{
    max-width: 27%;
    margin-right: -9%;
    padding: 30px 0 0 0;
}

.five-col-wave-logo-bottom-row p{
    max-width: 75%;
    margin: auto;
}

.six-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3 {
    max-width: 25%;
    margin-right: -9%;
    padding: 30px 0 0 0;
}

.six-col-wave-logo-bottom-row p {
    max-width: 75%;
    margin: auto;
}

.six-col-wave-logo-bottom-row .row > div:first-of-type {
    margin-left: -40px;
}

@media screen and (max-width: 991px){
    .five-col-wave-logo-bottom-row p{
        max-width: 100%;
        margin: auto;
    }

    .five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3,
    .four-col-row .col-lg-3.col-xs-12.colNum-4,
    .four-col-icons-top-row .col-lg-3.col-xs-12.colNum-4{
        max-width: 50%;
        padding: 7.5px 15px;
    }

    .five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3:last-child,
    .four-col-row .col-lg-3.col-xs-12.colNum-4:last-child,
    .four-col-icons-top-row .col-lg-3.col-xs-12.colNum-4:last-child{
        padding-bottom: 20px;
    }

    .five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3:last-child{
        max-width: 50%;
        margin: 0 auto;
        padding-bottom: 20px;
    }

    .four-col-row .text-area{
        height: 180px;
    }

    .five-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3{
        max-width: 25%;
        margin-right: -7%;
        padding: 30px 15px 0;
    }
}


@media screen and (max-width: 767px){
    .five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3,
    .four-col-row .col-lg-3.col-xs-12.colNum-4,
    .four-col-icons-top-row .col-lg-3.col-xs-12.colNum-4{
        max-width: inherit;
        padding: 7.5px 15px;
    }

    .five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3:last-child,
    .four-col-row .col-lg-3.col-xs-12.colNum-4:last-child,
    .four-col-icons-top-row .col-lg-3.col-xs-12.colNum-4:last-child{
        padding-bottom: 20px
    }

    .five-col-icons-top-row .col-lg-4.col-xs-12.colNum-3:last-child{
        max-width: 100%;
        margin: unset;
        padding-bottom: 20px;
    }

    .five-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3{
        max-width: 55%;
        margin-right: -10%;
        padding: 10px 15px;
    }

    .five-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3:last-child{
        max-width: 58%;
        margin: 0 auto;
    }

    .four-col-row .text-area,
    .four-col-icons-top-row .text-area{
        height: 200px;
    }

    .five-col-icons-top-row .text-area,
    .four-col-row .text-area {
        height: 180px;
    }
}

/* SVG Images in Cards/Columns */
.five-col-icons-top-row .text-area img,
.four-col-icons-top-row .text-area img,
.four-col-row .text-area img,
.three-col-icons-row .text-area img,
.three-col-icons-row-two .text-area img{
    text-align: center;
    height: 100px;
}

.three-col-icons-row .text-area img.architects{
   
}

.text-area img.aligncenter{
    position: relative;
    top: calc(50% - 10px); /* 50% - 3/4 of icon height */
}

/* Sets Padding for three col button */
.three-col-icons-row .colNum-3,
.three-col-icons-row-two .colNum-3,
.four-col-description-row.button-bottom .row > div {
    padding: 40px 50px 70px 55px;
}

/* Three Column Button Styles */
.colNum-3 .text-area a.button,
.colNum-4 .text-area a.button {
    position: absolute;
    bottom: 0;
    left: 15%;
    right: 15%;
    width: 70%;
    white-space: nowrap;
}

@media screen and (max-width: 1200px){
    .colNum-3 .text-area a.button,
    .colNum-4 .text-area a.button {
        left: 5%;
        right: 5%;
        width: 90%;
    }
}

/* =============== END Card and Wave Icon Column Classes ==================*/


/* ======================= Gradient backgrounds ========================*/
/*.two-col-img-right-row, .two-col-img-left-row {
    background: rgb(255,255,255);
    background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 64%, rgba(238,238,238,1) 100%);
}

.two-col-right-row {
    background: rgb(255,255,255);
    background: linear-gradient(0deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 64%, rgba(238,238,238,1) 100%);
}*/
/* ======================= END Gradient backgrounds ========================*/

@media screen and (max-width: 767px){
    .hide-img-mobile{
        display: none;
    }
}

@media screen and (min-width: 768px) {
    .hide-img-desktop{
        display: none;
    }

    .site-featured-image {
        margin-top: 83px;
    }
}

@media screen and (min-width: 769px) {

    .flex-footer-wrap #col_1 {
        max-width: none;
        flex: 0 0 25%;
    }

    .flex-footer-wrap #col_2 {
        max-width: none;
        flex: 0 0 18%;
    }

    .flex-footer-wrap #col_3 {
        max-width: none;
        flex: 0 0 32%;
    }
}

@media screen and (min-width: 1440px) {
    .error-404 {
        padding: 0 calc((100vw - 1440px) / 2);
    }
}

    @media (max-width: 1024px) {
        .mobile-navigation {
            display: block;
        }

        .main-navigation .sub-menu > li.button {
            display: inline-block;
            margin-right: calc( 24px + 1rem );
            border-color: #fff;
        }

            .main-navigation .sub-menu > li.button a {
                padding-right: 1rem;
            }

        .menu-toggle,
        .menu-toggle:active,
        .menu-toggle:focus,
        .menu-toggle:visited {
            position: absolute;
            top: 0;
            right: 0;
            width: 30px;
            height: 30px;
            background: none;
            background-color: transparent !important;
            padding: 0;
        }

            .menu-toggle span {
                position: relative;
                background-color: #2b77b6;
                width: 100%;
                height: 3px;
                margin: 6px 0;
                display: block;
            }

        .error-404.not-found .page-content {
            padding: 5em 52% 12em 0;
            margin: 0 2em;
        }

        .modal-wrapper.styled .modal {
            padding: 40px 30px;
            width: 98%;
        }
    }

    @media (max-width: 768px) {
        .two-col-form-row .col-lg-8 {
            margin-bottom: 40px;
            border-right: none;
            padding-right: 0;
        }

        .two-three-section .col-lg-8 {
            border-left: none;
        }

        .hero-tall .container, .hero-short .container {
            left: 15px;
        }

        .pt-partner .container {
            padding: 0;
        }

        .clients-page .ciSlide .imgHover {
            height: 210px;
        }

        .flex-footer-wrap {
            text-align: center;
        }

        footer .search-form {
            text-align: center;
        }

        .error-404.not-found .page-content {
            padding: 5em 46% 12em 0;
        }

        .mobile-navigation.toggled-on .inActiveButton {
            display: none;
        }

        .fal.activeButton {
            color: #2b77b6;
            font-size: 2.5em;
        }

        .mobile-navigation.toggled-on .fal.activeButton {
            display: block;
        }
    }

    @media screen and (max-width: 767px) {
        .site-footer {
            /*margin-top: 20px;*/
        }

        .site-logo .custom-logo-link {
            height: 29px;
        }

        .error-404 {
            min-height: calc(100vh + 89px);
        }

            .error-404.not-found .page-content {
                padding: 1em 46% 12em 0;
            }

            .error-404 h1.page-title {
                font-size: 4.375em;
            }

            .error-404 h2 {
                font-size: 1.625em;
            }

            .error-404 p {
                font-size: 1.25em;
            }
    }

    @media (max-width: 640px) {
        .home #hero {
            display: none !important;
        }

        .home #heroMobile {
            display: block !important;
            background-repeat: no-repeat;
            background-position: center 25%;
            padding-bottom: 0;
        }

        blockquote {
            font-size: 16px;
            line-height: 1.4em;
        }

        .ciSlideContent .photo-inner {
            text-align: center;
        }

        .ciSlideContent .text-inner {
            max-width: 85%;
            margin: 0 auto;
        }

        .jcarousel-control-prev {
            left: 20px;
        }

        .jcarousel-control-next {
            right: 20px;
        }

        .desktopSlider {
            /*display: none;*/
        }

            .desktopSlider.pt-expert {
                display: block;
            }

        .experts-page #top-blurb p {
            font-size: 1.125em;
            text-align: left;
        }

        .our-team-page .desktopSlider {
            display: flex;
        }

        .pt-expert .container {
            padding: 0;
            width: 100%;
        }

        .pt-expert.noCarousel .smallThumbs {
            padding-left: 0;
        }

            .pt-expert.noCarousel .smallThumbs li {
                display: block;
            }

        .pt-expert.noCarousel.pps-3 .smallThumbs .ciSlide {
            width: 100%;
            justify-content: center;
        }

        .mobileSlider {
            display: block;
        }

        .jcarousel .smallThumbs .ciSlide {
            width: 100%;
        }

        .letterBox {
            display: block;
            padding: 3em 2em 1em 2em;
        }

            .letterBox > div:first-of-type {
                width: 100%;
                padding-right: 2%;
            }

            .letterBox > div:last-of-type {
                background-image: url(img/bird-color.png);
                background-repeat: no-repeat;
                background-position: bottom right;
                background-size: 40%;
                padding-top: 10%;
                position: static;
                bottom: 0;
                right: 0;
                height: 108%;
                width: 94%;
            }

        .directors_item {
            width: calc( 100%/2 );
        }

        .administration_item {
            text-align: left;
            width: calc( 100%/1 );
            margin-top: 20px;
        }

        .industry_item {
            width: calc( 100% / 2 );
        }

        .hero-tall .container, .hero-short .container {
            left: 0;
        }

        .two-col-form-row .col-lg-8 {
            padding-right: 15px;
        }

        .two-col-form-row .gform_wrapper ul li.gfield {
            flex: 0 100%;
        }

            .two-col-form-row .gform_wrapper ul li.gfield:nth-of-type(-n+2) {
                margin-top: 16px;
            }

        section .gform_wrapper .gform_footer input.button, .gform_wrapper .gform_footer input[type=submit], section .gform_wrapper .gform_page_footer input.button, .gform_wrapper .gform_page_footer input[type=submit] {
            width: 50%;
        }

        .two-col-form-row .gform_wrapper ul li.gfield#field_1_9 {
            bottom: 24px;
            right: unset;
            width: 43%;
            margin-top: 0 !important;
            overflow: hidden;
        }

            .two-col-form-row .gform_wrapper ul li.gfield#field_1_9 > div > div {
                width: 100% !important;
                height: 60px !important;
            }

        body .gform_wrapper .top_label div.ginput_container.ginput_recaptcha {
            margin: -4px 0 0 -4px;
        }

        .flex-box {
            display: block;
        }

            .flex-box > .col:first-of-type {
                flex-basis: 100%;
                flex: 0 0 100%;
                max-width: 100%;
            }

            .flex-box > .col:last-of-type {
                max-width: 100%;
                padding: 0;
                border: none;
            }
    }

    @media screen and (max-width: 425px) {

        .noCarousel .smallThumbs > li {
            display: block;
            align-items: center;
        }

        .noCarousel.pps-3 .smallThumbs .ciSlide {
            width: 80vw;
            margin: 0 auto;
        }

        .clients-page .ciSlide .imgHover {
            height: calc(80vw - 22px);
            max-height: none;
        }

        .error-404 {
            min-height: calc(100vh - 20px);
            background-position: 3em top;
            background-size: 70vw;
        }

            .error-404.not-found .page-content {
                padding: 45vh 0 6em 0;
                text-align: center;
            }

        .jcarousel-wrapper-mobile {
            display: block;
        }

        .jcarousel.pps-3.pt-content .smallThumbs .ciSlide {
            width: 80vw;
            margin: 0 auto;
        }

        .pt-expert .container {
            margin: auto 0;
        }

        .home section, .about-wave-page section, .clients-page section, .blurbColumns {
            padding: 20px 0;
        }

        .about-wave-page .image-wrap .text-area {
            display: block;
        }

            .about-wave-page .image-wrap .text-area p:nth-last-of-type(-n+3) {
                display: none;
            }

        .about-wave-page .hero-short h1,
        .clients-page .hero-short h1 {
            margin-bottom: 30px;
            margin-top: 3em;
        }

        .six-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3 {
            max-width: 50%;
            margin-right: -9%;
            padding: 30px 0 0 0;
        }

            .six-col-wave-logo-bottom-row .col-lg-4.col-xs-12.colNum-3:nth-of-type(odd) {
                margin-left: 20px;
            }

        .wave-section {
            margin-bottom: 20px;
        }

        /*section.wave-top::before {
        top: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    section.wave-top::after {
        bottom: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    .two-col-img:nth-of-type(even):before {
        top: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    .two-col-img:nth-of-type(even):after {
        bottom: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    .wave-section:before {
        top: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    .wave-section:after {
        bottom: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    .wave-section-bottom::after {
        bottom: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }

    .solutions-page .hero-short:after {
        bottom: -6.5vw;
        background-size: 100vw auto;
        height: 10vw;
    }*/

        .three-col-icons-row .row .colNum-3 .text-area p, 
        .three-col-icons-row-two .row .colNum-3 .text-area p {
            text-align: center;
        }

        .colNum-3 .text-area a.button, .colNum-4 .text-area a.button {
            position: relative;
            left: auto;
            right: auto;
            bottom: auto;
            width: auto;
        }

        .pt-testimonial .jcarousel > ul > li {
            width: 88vw;
        }

            .pt-testimonial .jcarousel > ul > li img {
                max-width: 100%;
                margin-left: -15px;
            }

        .three-col-icons-row .colNum-3, .three-col-icons-row-two .colNum-3, .four-col-description-row.button-bottom .row > div {
            padding: 20px 40px 20px 40px;
        }

        .modal-wrapper.styled .modal {
            padding: 40px 20px;
            width: 100%;
            transform: translate(0,-50vh);
        }
    }


.d-flex-vert-center{
    display: flex;
    flex-direction: column;
    align-items: center;
}
@media screen and (max-width: 767px){
    .mobile-w-20{
        padding: 5px 20px !important;
        max-width: 20% !important;
        flex: 0 0 20% !important;
    }
    .mobile-w-25{
        padding: 5px 25px !important;
        max-width: 25% !important;
        flex: 0 0 25% !important;
    }
    .mobile-w-50{
        padding: 5px 30px !important;
        max-width: 50% !important;
        flex: 0 0 50% !important;
    }
    .mobile-w-100{
        padding: 5px 25% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
    }
    .mobile-row-reverse{
        flex-wrap: wrap-reverse !important;
    }
    .m-center{
        margin-left: auto;
        margin-right: auto;
        text-align: center;
    }
    .solutions-page .row-flush p{
        text-align: center;
    }
}
