/*==============================================================================
=                                Globals                                       =
==============================================================================*/
/*============================== Colors ======================================*/
::selection {
    background: #e30030;
}
/*============================== Typography ==================================*/
body {
    overflow-x: hidden;
}

body,
h1.body {
    font-family: proxima-nova, sans-serif;
    font-size: 18px;
    -webkit-font-smoothing: subpixel-antialiased;
    font-weight: 300;
}

sup {
    font-size: 65%;
}

a,
a:hover,
a:focus {
    text-decoration: none;
}

ul {
    padding: 0;
    padding-left: 20px;
    margin: 0;
    margin-left: 10px;

    list-style-type: disc;
}

ul.bullets {
    margin-left: 40px;

    list-style-type: disc;
}
/*============================== Helper Classes ==============================*/
/*==============================================================================
=                                Header                                        =
==============================================================================*/
header {
    position: fixed;
    z-index: 100;

    width: 100%;
    padding: 20px 0 12px;

    transition: .5s all;

    background: rgba(0, 0, 0, 0);
}

header.scrolled {
    padding: 8px 0 0;

    background: rgba(0, 0, 0, .7);
}

header .logo img {
    height: 54px;

    transition: .5s all;
}

header.scrolled .logo img {
    height: 47px;
    padding-top: 10px;
}

header .logo {
    display: inline-block;
}

header .nav-button {
    float: right;

    font-size: 45px;

    color: #fff;
}
/*============================== Social Media Bar ======================================*/
.icon-bar {
    position: fixed;
    top: 50%;
    right: 0;
    z-index: 3;

    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
}

.icon-bar a {
    display: block;
    padding: 16px;

    font-size: 20px;

    transition: all .3s ease;
    text-align: center;

    color: white;
}

.icon-bar a:hover {
    background-color: #000;
}

.facebook {
    color: white;
    background: #3b5998;
}

.linkedin {
    color: white;
    background: #007bb5;
}

.twitter {
    color: white;
    background: #55acee;
}

.email {
    color: white;
    background: #777;
}

.text-upper.text-red.text-sm h1 {
    display: inline-block;

    font-size: 14px;
    font-weight: 700;

    letter-spacing: 1.6px;
    text-transform: uppercase;

    color: #e30030;
}
/*============================== Common ======================================*/

/*insights section updates 2023*/
.author-page > .author-library,
.author-page > .author-library > h3 {
    text-align: left;
}

.author-page > .author-library > div.deco-line {
    width: 50%;
    height: 6px;
    margin-top: 12px;

    background-color: #e30030;
}

.spacer-top {
    display: none;
    width: 100%;
    height: 200px;
}

.spacer-btm {
    display: block;
    width: 100%;
    height: 40px;
}

.author-section {
    position: relative;
    z-index: 1;
}

.author-section > .img-wrapper {
    max-width: 280px;
}

.author-section > .author-prev-text {
    position: relative;
    z-index: -1;

    display: flex;
    flex-direction: column;
}

.author-section > .author-prev-text > p {
    font-size: 80%;
}

.author-section > .author-prev-text > p,
.author-section > .author-prev-text > a,
.author-section > .author-prev-text > h4 {
    text-align: left;
}

.author-section > .author-prev-text > .red-button {
    display: flex;
    width: fit-content;

    justify-content: center;
}

.insights-btn {
    display: flex;
    flex-direction: column;

    align-items: center;
}

.recent-insights {
    text-align: center;
}

.recent-insights > .deco-line {
    width: 50%;
    height: 6px;
    margin-top: 12px;
    margin-right: auto;
    margin-bottom: 40px;
    margin-left: auto;

    background-color: #e30030;
}

@media screen and (min-width: 1200px) {
    .recent-insights > .deco-line {
        width: 33%;
        margin-right: unset;
        margin-left: 0;
    }
}

.recent-articles {
    width: 100%;
}

@media screen and (min-width: 1200px) {
    .recent-articles > .container-fluid {
        max-width: 90%;
    }

    .article-section {
        font-size: 18px;
    }

    .insights-btn {
        align-items: flex-end;
    }

    .recent-insights {
        text-align: left;
    }

    .spacer-top {
        display: block;
    }

    .spacer-btm {
        display: none;
    }

    .author-section > .author-prev-text {
        padding-top: 80px;
        padding-right: 20px;

        transform: translateY(-60px);

        border-right: 6px solid #e30030;
    }

    .author-section > .author-prev-text,
    .author-section > .author-prev-text > p,
    .author-section > .author-prev-text > a,
    .author-section > .author-prev-text > h4 {
        text-align: right;
    }

    .author-section > .author-prev-text > .red-button {
        align-self: end;
    }

    .author-section > img.blog-author {
        margin-bottom: 0;
    }
}

@media screen and (min-width: 1400px) {
    .article-section {
        font-size: 22px;
    }
}

.author-page > .bio {
    display: flex;
    flex-direction: column;
}

.author-page > .bio > h3,
.author-page > .bio > p {
    text-align: left;
}

.author-page > .bio > .red-button {
    width: fit-content;
}

img.author-img-lg {
    max-width: 280px;

    border-radius: 2%;
}

p.blog-copy {
    margin-bottom: 20px;
}

img.blog-author {
    margin-bottom: 20px;

    border-radius: 2%;
}

.insights-em {
    font-weight: 500;

    color: #e30030;
}

.box-one,
.box-two,
.box-three {
    display: flex;
    min-height: 420px;
    flex-direction: column;

    border-radius: 2%;

    align-items: center;
    justify-content: center;
}

.box-one > img,
.box-two > img,
.box-three > img {
    padding: 20px 20px 60px 20px;

    transition: ease .6s;

    opacity: 1;
}

.box-one > p,
.box-two > p,
.box-three > p {
    position: absolute;
    top: 300px;

    padding: 0 16px;

    font-family: sans-serif;
    font-size: 24px;

    transition: ease .6s;
    text-align: center;
    text-transform: uppercase;

    color: #fff;
}

@media screen and (min-width: 668px) {
    .hover-caption > .deco-line {
        top: 80px;
    }
}

@media screen and (min-width: 992px) {
    .box-one > p,
    .box-two > p,
    .box-three > p {
        font-size: 24px;
    }

    .hover-caption > span.copy {
        padding: 60px 20px 20px 20px;
    }

    .hover-caption > .deco-line {
        top: 65px;
    }
}

@media screen and (min-width: 1200px) {
    .box-one > p,
    .box-two > p,
    .box-three > p {
        font-size: 26px;
    }
}

@media screen and (min-width: 1360px) {
    .hover-caption > .deco-line {
        top: 80px;
    }
}

@media screen and (min-width: 1500px) {
    .box-one > p,
    .box-two > p,
    .box-three > p {
        font-size: 28px;
    }
}

.box-one:hover > img,
.box-two:hover > img,
.box-three:hover > img,
.box-one.active > img,
.box-two.active > img,
.box-three.active > img {
    transition: ease .6s;

    opacity: 0;
}

.box-one:hover > p,
.box-two:hover > p,
.box-three:hover > p,
.box-one.active > p,
.box-two.active > p,
.box-three.active > p {
    top: 28px;

    transition: ease .6s;
}

.box-one:hover > .hover-caption,
.box-two:hover > .hover-caption,
.box-three:hover > .hover-caption,
.box-one.active > .hover-caption,
.box-two.active > .hover-caption,
.box-three.active > .hover-caption {
    visibility: visible;
}

.hover-caption {
    position: absolute;

    display: flex;
    visibility: hidden;
    width: 100%;
    height: 100%;
    padding: 0 15px;
    flex-direction: column;

    align-items: center;
    justify-content: center;
}

.box-heading {
    color: #fff;
}

.box-one:hover > .box-heading,
.box-two:hover > .box-heading,
.box-three:hover > .box-heading {
    color: #e30030;
}

.hover-caption > span.copy {
    padding: 60px 60px 20px 60px;

    font-size: 22px;
    font-weight: 400;

    color: #e30030;
}

.hover-caption > .deco-line {
    position: absolute;
    top: 100px;

    width: 100px;
    height: 4px;

    border-bottom: 2px solid #e30030;
}

.box-one {
    transition: background-color .4s ease;

    background-color: #e30030;
}

.box-one:hover {
    background-color: #fff;
}

.box-two {
    transition: background-color .4s ease;

    background-color: #e30030;
}

.box-two:hover {
    background-color: #fff;
}

.box-three {
    transition: background-color .4s ease;

    background-color: #e30030;
}

.box-three:hover {
    background-color: #fff;
}

a.blog-btn {
    padding: 8px 28px;

    font-size: 14px;
    font-weight: 400;

    transition: background-color .4s ease;
    text-transform: uppercase;

    color: #e30030;
    border: 2px solid;
}

a.blog-btn:hover {
    cursor: pointer;
    transition: background-color .4s ease;

    color: #fff;
    border: 2px solid #e30030;
    background-color: #e30030;
}

.img-fluid {
    height: auto;
    max-width: 100%;
}

.threebox-title {
    min-height: unset;
}

.threebox-title > .title-text {
    text-align: left;
}

section.heading-plus-copy > .row > .col-xs-12 > h2.title-text {
    margin-bottom: 40px;

    text-align: left;
}

section.heading-plus-copy > .row > .col-xs-12 > h2.title-text > div.deco-line {
    width: 50%;
    height: 6px;
    margin-top: 12px;

    background-color: #e30030;
}

section.heading-plus-copy > .row > .col-xs-12 > p > i {
    font-size: 80%;
}

section.heading-plus-copy > .row > .col-xs-12 > p {
    margin-bottom: 20px;

    text-align: left;
}

@media screen and (min-width: 1200px) {
    .threebox-title {
        min-height: 440px;

        background-image: url(/site/templates/_assets/img/common/insights-metrics.svg);
        background-repeat: no-repeat;
        background-position: 110px 140px;
        background-size: 50%;
    }

    .threebox-title > .title-text {
        text-align: center;
    }
}

#insightsModalForm > .modal-dialog > .modal-content > .modal-body {
    background-color: #f5f6fa;
}

.mt0 {
    margin-top: 0 !important;
}

.mt10 {
    margin-top: 10px !important;
}

.mt20 {
    margin-top: 20px !important;
}

.mt30 {
    margin-top: 30px !important;
}

.mt40 {
    margin-top: 40px !important;
}

.mt50 {
    margin-top: 50px !important;
}

.mt60 {
    margin-top: 60px !important;
}

.mt70 {
    margin-top: 70px !important;
}

.mt80 {
    margin-top: 80px !important;
}

.mt90 {
    margin-top: 90px !important;
}

.mt100 {
    margin-top: 100px !important;
}

.mt200 {
    margin-top: 200px !important;
}

.mb0 {
    margin-bottom: 0 !important;
}

.mb10 {
    margin-bottom: 10px !important;
}

.mb20 {
    margin-bottom: 20px !important;
}

.mb30 {
    margin-bottom: 30px !important;
}

.mb40 {
    margin-bottom: 40px !important;
}

.mb50 {
    margin-bottom: 50px !important;
}

.mb60 {
    margin-bottom: 60px !important;
}

.mb70 {
    margin-bottom: 70px !important;
}

.mb80 {
    margin-bottom: 80px !important;
}

.mb90 {
    margin-bottom: 90px !important;
}

.mb100 {
    margin-bottom: 100px !important;
}

.inline {
    display: inline;
}

.inline-block {
    display: inline-block;
}

.text-upper {
    text-transform: uppercase;
}

.text-sm {
    font-size: 14px;
    font-weight: 700;

    letter-spacing: 1.6px;
}

.text-md {
    font-size: 18px;
}

.text-bold {
    font-weight: 500;
}

.text-extra-bold {
    font-weight: 700;
}

.limit-width {
    max-width: 900px;
    margin: 0 auto;
}

.text-red {
    color: #e30030;
}

.text-white {
    color: #fff;
}

.gray-list a {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.7em;

    transition: .5s color;

    color: #5c5c5c;
}

.gray-list li:hover a {
    color: #e30030;
}

.background-gray {
    background: #f5f6fa;
}

.red-button {
    display: inline-block;

    font-size: 12px;
    font-weight: 400;

    cursor: pointer;
    transition: .5s background;
    letter-spacing: 1.6px;
    text-transform: uppercase;

    color: #fff;
    background: #e30030;
}

.red-button:hover {
    background: #000;
}

.red-button a {
    display: block;
    padding: 9px 7px;

    color: #fff;
}

.red-button.button-border {
    border: 2px #fff solid;
}

.clear-button {
    display: inline-block;

    font-size: 12px;
    font-weight: 400;

    transition: .5s background;
    letter-spacing: 1.6px;
    text-transform: uppercase;

    color: #fff;
    border: 2px #fff solid;
}

.clear-button:hover {
    background: rgba(255, 255, 255, .25);
}

.clear-button a {
    display: block;
    padding: 9px 7px;

    color: #fff;
}

.capability-body a,
.insights-body a,
.custom-landing-body a {
    font-weight: 600;

    transition: .5s color;

    color: #333;
}

.capability-body a:hover,
.insights-body a:hover,
.custom-landing-body a:hover {
    color: #e30030;
}

.insights-body {
    font-size: 18px;
}

.insights-body strong {
    font-weight: 500;
}

.insights-body u {
    text-decoration: none;

    border-bottom: 2px solid #333;
}

.insights-categories-title {
    margin-bottom: 0;

    font-weight: 600;

    color: #5c5c5c;
}

.insights-category {
    display: block;
    padding-left: 10px;

    font-size: 14px;
    font-weight: 600;
    line-height: 2em;

    cursor: pointer;
    transition: .5s color;
    text-transform: uppercase;

    color: #565656;
}

.insights-category.active {
    padding-left: 10px;

    transition: .5s background;
    text-align: left;

    color: #fff;
    border-radius: 25px;
    background: #e30030;
}

.insights-category.active i {
    position: absolute;
    right: 21px;

    padding-top: 7px;
}

.insights-category.active:hover,
.insights-category.active:focus {
    color: #fff;
    background: black;
}

.insights-category:active,
.insights-category:focus {
    color: #565656;
}

.insights-category:hover {
    color: #e30030;
}

.insights-thumbnail-tags {
    position: absolute;
    bottom: 15px;
    left: 50%;
    z-index: 2;

    transform: translateX(-50%);
    text-align: center;
}
.insights-thumbnail-tags:hover + .insights-thumbnail .insights-thumbnail-title {
    min-height: 100%;
}

.insights-thumbnail-tag,
.insights-thumbnail-tag:focus {
    display: none;

    font-size: 14px;
    font-weight: 400;
    line-height: 2em;

    transition: .5s color;
    letter-spacing: 1.6px;
    text-transform: uppercase;

    color: rgba(255, 255, 255, 0);
}

.insights-thumbnail:hover .insights-thumbnail-tag {
    color: #fff;
}

.insights-thumbnail-tag:hover {
    color: #e30030 !important;
}

.insights-thumbnail-link {
    display: flex;
    flex-direction: column;
}

.insights-thumbnail {
    position: relative;

    display: block;
}

.insights-thumbnail-title {
    position: absolute;
    bottom: 0;

    width: 100%;
    min-height: 32%;
    padding: 32px;

    transition: .5s all;

    color: #fff;
    background-color: rgba(0, 0, 0, .7);
}

.insights-thumbnail:hover .insights-thumbnail-title {
    min-height: 100%;
}

.insights-thumbnail.on-screen .insights-thumbnail-title {
    min-height: 100%;
}

.insights-more {
    position: absolute;
    right: 10px;
    bottom: 10px;
    z-index: 3;

    padding: 1px 9px 0;

    font-size: 30px;
    font-weight: 500;
    line-height: 1;

    transition: .5s;

    color: #fff;
    background: #e30030;
}

.MarkupPagerNav {
    font-weight: 600;

    text-align: center;
}

.MarkupPagerNav li {
    display: inline-block;
}

.MarkupPagerNav li.active {
    width: 30px;
    height: 30px;
    padding-right: 1px;

    color: #fff;
    border-radius: 15px;
    background: #e30030;
}

.MarkupPagerNav li a {
    padding: 10px;

    transition: .5s color;

    color: #5c5c5c;
}

.MarkupPagerNav li:hover a {
    color: #e30030;
}

.case-study-feature-caption {
    position: absolute;
    right: 0;
    bottom: 0;

    padding: 20px;
    margin: 0 15px;

    color: #fff;
    background: rgba(0, 0, 0, .65);
}

.case-study-feature-caption h4 {
    font-size: 24px;
    font-weight: 700;

    text-transform: uppercase;
}

.case-study-feature-caption p {
    font-size: 16px;
    font-weight: 400;
}

.case-study-feature-caption .outline-button {
    margin: 20px 0;
}

.case-study-feature-caption .outline-button a,
.case-study-feature-caption .outline-button a:visited {
    padding: 8px 22px;

    font-size: 14px;
    font-weight: 600;

    transition: color .3s, background .3s;
    text-transform: uppercase;

    color: #fff;
    border: 2px solid #fff;
    background: rgba(255, 255, 255, 0);
}

.case-study-feature-caption .outline-button a:active,
.case-study-feature-caption .outline-button a:hover,
.case-study-feature-caption .outline-button a:focus {
    color: #333;
    background: #fff;
}
/*============================== Home ========================================*/
.home-slider {
    display: none;
}

#home-dropdown-cta .modal-body a.cta-option {
    font-size: 22px;
    font-weight: 600;
    line-height: 1.2em;

    text-decoration: none;

    color: #fff;
}

#home-dropdown-cta .modal-content {
    border-radius: 0;
}

#home-dropdown-cta .modal-cta-title {
    font-size: 30px;
    font-weight: 600;

    text-align: center;
    text-transform: uppercase;

    color: #fff;
}

#home-dropdown-cta .modal-content {
    background-color: rgba(0, 0, 0, .85);
}

.width-100 {
    width: 100%;
}

.height-100 {
    height: 100%;
}
/*============================== Interior ====================================*/
/*==============================================================================
=                                Navigation                                    =
==============================================================================*/
/*============================== Off Canvas ==================================*/
.navigation {
    position: fixed;
    z-index: 100;

    width: 0;
    height: 100%;
    overflow: hidden;

    transition: .5s width;
}

.feature {
    left: 0;

    background: #000;
}

.feature-content {
    position: absolute;
    top: 50%;
    z-index: 2;

    width: 100%;

    transition: .5s opacity;
    transform: translateY(-50%);
    text-align: center;

    opacity: 0;
    color: #fff;
}

.feature-content.active {
    opacity: 1;
}

.feature-title {
    padding: 15px;

    font-size: 14px;
    font-weight: 600;

    text-transform: uppercase;
}

.feature-tagline {
    padding: 0 15px;

    font-size: 36px;
    font-weight: 400;
    line-height: 1;
}

.feature-background {
    position: absolute;
    top: 50%;
    left: 50%;

    min-width: 100%;
    min-height: 100%;

    transform: translateX(-50%) translateY(-50%);
}

.nav-feature-slider .arrows {
    position: absolute;
    bottom: 50px;
    z-index: 4;

    font-size: 30px;

    color: #fff;
}

.nav-feature-slider .prevArrow {
    right: 60px;
}

.nav-feature-slider .nextArrow {
    right: 40px;
}

.feature.active {
    display: block;
}

.main {
    right: 0;

    background: #fff;
}

.main.active {
    display: block;
    width: 100%;
}

.main .links {
    position: absolute;
    top: 50%;

    width: 100%;

    transform: translateY(-50%);
    text-align: center;
}

.main .links .site-nav a {
    font-size: 28px;
    font-weight: 500;
    line-height: 1.8;

    transition: .5s color;

    color: #333;
}

.main .links .site-nav a:hover {
    color: #e30030;
}

.nav-logo {
    position: absolute;
    top: 20px;
    left: 20px;
    z-index: 2;

    background: white;
}

.nav-close {
    position: absolute;
    top: 20px;
    right: 20px;
    z-index: 2;

    font-size: 40px;

    color: #d0d0d0;
}

.nav-social {
    margin-top: 40px;

    font-size: 18px;
    font-weight: 600;

    white-space: nowrap;
    text-transform: uppercase;

    color: #333;
}

.nav-social i {
    margin: 5px;

    font-size: 20px;

    color: #e30030;
}

.nav-feature-slider .slide {
    height: 100vh;

    background: white;
}

@media screen and (min-width: 768px) {
    .feature.active {
        width: 50%;
    }

    .main.active {
        width: 50%;
    }

    .main .links .site-nav a {
        font-size: 40px;
    }
}/*============================== Common ======================================*/































































































































































































































/*============================== Top Navigation ==============================*/
/*============================== Side Navigation =============================*/
/*============================== Bottom Navigation ===========================*/
/*==============================================================================
=                                Footer                                        =
==============================================================================*/
/*============================== Common ======================================*/
footer {
    padding: 50px 0;

    font-size: initial;

    color: #fff;
    background: #333;
}

.footer-logo-section img {
    margin: 0 auto;
}

.footer-nav-section {
    text-align: center;
}

.footer-nav-section ul {
    margin: 20px 0;

    column-count: 2;
}

.footer-contact-section {
    margin-top: 20px;
}

.footer-contact-section ul {
    column-count: 1;
}

.footer-nav {
    display: inline-block;

    column-count: 3;
}

.footer-contact-links {
    display: inline-block;

    column-gap: 0;
}

.footer-contact-links li {
    white-space: nowrap;
}

.footer-copy {
    font-size: 14px;
    font-weight: 500;

    color: #fff;
}

.footer-copy a,
.footer-copy a:visited {
    transition: .5s color;

    color: #fff;
}

.footer-copy a:hover,
.footer-copy a:focus,
.footer-copy a:active {
    color: #e30030;
}

.footer-info {
    font-size: 12px;
    font-weight: 500;

    color: #fff;
}

.footer-info a,
.footer-info a:hover,
.footer-info a:active,
.footer-info a:visited {
    color: #fff;
}

.footer-hubspot {
    width: 100%;
    max-width: 250px;
}
/*============================== Home ========================================*/
/*============================== Interior ====================================*/
/*==============================================================================
=                                Home Page                                     =
==============================================================================*/
.landing-video {
    position: relative;

    float: left;
    width: 100%;
    height: 80vh;
}

.landing-video .overlay {
    position: absolute;
    top: 50%;
    z-index: 2;

    width: 100%;

    transform: translateY(-50%);
    text-align: center;
}

.landing-video .overlay .headline {
    padding: 0 15px;

    font-size: 30px;
    line-height: 1.1em;

    text-transform: uppercase;

    color: #fff;
}

.landing-video .overlay .headline strong {
    font-weight: 700;

    color: #e30030;
}

.landing-video .overlay .headline .home-slider div {
    height: 134px;
    max-width: 1200px;
    margin: 0 auto;
}

.landing-video video {
    position: absolute;
    right: 0;
    bottom: 0;

    min-width: 100%;
    min-height: 100%;

    object-fit: cover;
}

.landing-scroller {
    position: absolute;
    bottom: 20px;
    left: 50%;
    z-index: 2;

    font-size: 55px;

    transform: translateX(-50%);

    color: #fff;
}

.dropdown-button {
    position: absolute;
    left: 50%;

    display: inline-block;
    padding: 9px 7px;

    font-size: 12px;
    font-weight: 400;

    transition: 2s ease-in-out;
    transform: translateX(-50%);
    text-align: left;
    letter-spacing: 1.6px;

    color: #fff;
    background: #e30030;
}

.dropdown-button:hover {
    background: rgba(0, 0, 0, .5);
}

.dropdown-button .options {
    max-width: 0;
    max-height: 0;
    overflow: hidden;

    transition: 2s ease-in-out;
}

.dropdown-button:hover .options {
    max-width: 1000px;
    max-height: 1000px;
}

.dropdown-button .options div {
    transition: 2s;
    transition-delay: 1s;
    white-space: nowrap;

    opacity: 0;
}

.dropdown-button:hover .options div {
    opacity: 1;
}

.dropdown-button .options a div {
    position: relative;

    font-size: 14px;

    text-decoration: none;

    color: #fff;
}

.dropdown-button .options a {
    display: block;
    padding: 5px;
    margin-top: 5px;

    transition: .5s all;
}

.dropdown-button .options a:hover {
    display: block;

    background: #fff;
}

.dropdown-button .options a:hover div p {
    color: #333;
}

.dropdown-button .options a div p {
    display: inline;

    transition: .5s ease-in-out;
}

section#capabilities-feature {
    float: left;
    width: 100%;
    padding: 80px 0;
}

section#work {
    float: left;
    width: 100%;
    padding: 100px 0 0;
}

section#quote {
    float: left;
    width: 100%;
    padding: 100px 0;
}

section#capabilities {
    float: left;
    width: 100%;
    padding: 70px 0 90px;

    background: #e30030;
}

section#capabilities .container {
    width: 90%;
}

section#capabilities .links-list {
    text-align: left;
}

section#capabilities .links-list div {
    margin-bottom: 15px;

    font-weight: 600;

    transition: opacity .3s;

    opacity: .7;
}

section#capabilities .links-list div:hover {
    opacity: 1;
}

section#capabilities .links-list a {
    font-size: 15px;
    line-height: 1.2em;

    color: #fff;
}

section#contact {
    position: relative;

    float: left;
    width: 100%;
    padding: 100px 0;

    background-image: url("../img/common/contact-desk.jpg");
    background-repeat: no-repeat;
    background-position: 80% 0;
    background-size: cover;
}

section#social {
    position: relative;

    float: left;
    width: 100%;
    padding: 100px 0 50px;
}

.quote {
    margin-bottom: 15px;
}

.capability {
    max-width: 300px;
    margin: 0 auto;

    transition: .5s;

    color: #e30030;
    border: 1px solid #e30030;
    border-radius: 150px;
    background: white;
}

.capability:hover {
    color: #fff;
    background: #e30030;
}

.capability svg {
    position: absolute;
    top: 40%;
    left: 50%;

    display: block;
    height: 35%;
    max-height: 100px;

    transform: translateX(-50%) translateY(-50%);
}

.capability:before {
    display: block;
    padding-top: 100%;

    content: "";
}

.capability .title {
    position: absolute;
    top: 60%;
    left: 50%;

    font-size: 14px;
    font-weight: 700;

    transform: translateX(-50%);
    letter-spacing: 1.6px;
    text-transform: uppercase;
}

.capability svg polyline,
.capability svg path,
.capability svg line {
    transition: .5s stroke;

    stroke: #e30030 !important;
}

.capability:hover svg polyline,
.capability:hover svg path,
.capability:hover svg line {
    stroke: #fff !important;
}

.work-categories {
    display: none;
}

.work-category {
    padding: 0 22px;

    font-size: 14px;
    font-weight: 600;

    cursor: pointer;
    transition: .5s color;
    text-transform: uppercase;

    color: #565656;
}

.work-category:hover {
    color: #e30030;
}

.companies {
    margin: 0;
}

.company {
    overflow: hidden;
}

.company .title {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3;

    width: 100%;
    padding: 10px;

    font-size: 12px;
    font-weight: 400;

    transition: .5s;
    transition: .5s background;
    text-align: right;
    text-transform: uppercase;

    opacity: 1;
    color: #fff;
    background: rgba(0, 0, 0, .35);
}

.company:hover .title,
.company.on-screen .title {
    background: rgba(0, 0, 0, 0);
}

.company.inactive .title {
    opacity: 0;
}

.company.inactive:hover .title {
    opacity: 1;
}

.company .button {
    position: absolute;
    bottom: 10px;
    left: 10px;
    z-index: 3;

    padding: 1px 9px 0;

    font-size: 30px;
    font-weight: 500;
    line-height: 1;

    transition: .5s;

    opacity: 0;
    color: rgba(255, 255, 255, 0);
    background: rgba(255, 255, 255, 0);
}

.company.active .button {
    opacity: 1;
    color: #fff;
    background: #e30030;
}

.company:hover .button,
.company.on-screen .button {
    opacity: 1;
    color: #e30030;
    background: #fff;
}

.company .overlay {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;

    width: 100%;
    height: 100%;

    transition: .5s;

    opacity: 0;
    background: rgba(0, 0, 0, 0);

    mix-blend-mode: multiply;
}

.company.inactive .overlay {
    opacity: .9;
    background: #000;
}

.company:hover .overlay,
.company.on-screen .overlay {
    opacity: 1;
    background: #b00025;
}

.company .description {
    position: relative;
    z-index: 3;

    max-width: 300px;
    padding: 40px 5px;
    margin: 15px auto;

    transition: .5s;

    opacity: 0;
    color: #fff;
}

.company .description p {
    position: relative;
    top: 50%;

    font-size: 18px;

    transform: translateY(-50%);
}

.company:hover .description,
.company.on-screen .description {
    opacity: 1;
}

.company .image {
    position: absolute;
    top: 50%;
    left: 50%;

    display: block;
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;

    transform: translate(-50%, -50%);
}

#quote .attribution {
    margin-bottom: 5px;

    font-weight: 600;
}

#quote .company-attribution {
    max-width: 100%;
    margin-bottom: 15px;
}

.body-contact-container {
    max-width: 750px;
    margin: 0 auto;
}

#capabilities .capability-icon {
    position: relative;
    top: 50%;

    display: inline-block;
    width: 110px;
    margin: 10px;

    font-size: 12px;
    font-weight: 500;

    transition: .5s opacity;
    transform: translateY(-50%);
    text-align: center;
    text-transform: uppercase;

    opacity: .7;
    color: #fff;
}

#capabilities .capability-icon.top {
    top: 0;

    transform: none;
}

#capabilities .capability-icon:hover {
    opacity: 1;
}

#capabilities .capability-icon.active {
    opacity: 1;
}

#capabilities .capability-icon svg {
    display: block;
    height: 50px;
    margin: 10px auto;
}

#capabilities .capability-icon svg polyline,
#capabilities .capability-icon svg path,
#capabilities .capability-icon svg polygon,
#capabilities .capability-icon svg circle,
#capabilities .capability-icon svg line {
    stroke: #fff;
}

.capabilites-list {
    padding: 80px 15px;
}
/*==============================================================================
=                                Interior                                      =
==============================================================================*/
.instagram-container {
    display: inline-block;
    width: 100%;
    padding: 5px;
    margin: 30px 0;
}

.instagram-container .instagram-spacing {
    position: relative;

    float: left;
    width: 33.333333%;
}

.instagram-container .instagram-image {
    position: relative;

    margin: 5px;
    overflow: hidden;
}

.instagram-container .instagram-caption {
    position: absolute;
    z-index: 2;

    min-height: 100%;
    padding: 5px;

    font-size: 15px;
    font-weight: 500;

    transition: .5s opacity;

    opacity: 0;
    color: #fff;
    background: rgba(0, 0, 0, .7);
}

.instagram-container .instagram-image-container {
    width: 100%;
    padding-bottom: 100%;
    overflow: hidden;
}

.instagram-container .instagram-video-container {
    width: 100%;
    overflow: hidden;
}

.instagram-container .instagram-image:hover .instagram-caption {
    opacity: 1;
}

.instagram-container .instagram-image img {
    position: absolute;
    top: 50%;

    transform: translateY(-50%);
}

.social-icon,
.social-icon:active {
    padding: 7px;

    font-size: 26px;

    transition: .5s;

    color: #e30030;
}

.social-icon:hover,
.social-icon:focus {
    color: #000;
}

.interior-banner {
    margin: 200px 0;

    text-align: center;

    color: #fff;
}

.interior-banner.insights {
    margin: 100px 0;

    text-align: left;
}

.interior-banner.insights.author {
    margin-top: 100px;
    margin-bottom: 40px;
}

.interior-banner.insights > h1,
.interior-banner.insights > p {
    text-align: left;
}

.interior-banner.insights > p {
    max-width: unset;
}

.insights-banner > .container > .content {
    display: flex;
    flex-direction: row;

    align-items: center;
}

.insights-banner > .container > .content > .icon {
    display: flex;

    font-size: 28px;

    color: #e30030;

    justify-content: flex-end;
}

.insights-banner > .container > .content > .icon.author-icon {
    margin-top: 100px;
    margin-bottom: 40px;
}

@media screen and (min-width: 768px) {
    .insights-banner > .container > .content > .icon {
        font-size: 40px;
    }
}

@media screen and (min-width: 992px) {
    .insights-banner > .container > .content > .icon {
        font-size: 60px;
    }
}

.capabilities-parent.three-column {
    padding: 0;
}

.capabilities-parent.three-column .container {
    width: 100%;
    padding: 0;
    margin: 0;
}

.capabilities-parent.three-column .container .col-lg-4 {
    height: 300px;

    background-position: center center;
    background-size: cover;
}

#capabilities-parent-content.capability-body .cls-1,
#capabilities-parent-content.capability-body .cls-2 {
    fill: none;
    stroke: #e30030;
    stroke-width: 4px;
}

#capabilities-parent-content.capability-body .col-lg-6:first-child {
    padding-top: 50px;
}

#capabilities-parent-content.capability-body img {
    width: 100%;
    height: auto;
}

#capabilities-parent-content.capability-body svg {
    position: relative;
    top: 15px;

    display: inline-block;
    float: left;
    width: 50px;
    height: 50px;
    margin-right: 10px;
    margin-bottom: 0;
}

.interior-banner h1,
.interior-banner h2.styled-h1 {
    font-weight: 700;

    text-transform: uppercase;
}

.interior-banner h2.styled-h1 h1 {
    display: inline-block;
}

.interior-banner p {
    max-width: 600px;
    margin: 0 auto;
}

svg.red-icon {
    display: inline-block;
    height: 50px;
}
svg.red-icon + h2 {
    display: inline-block;
    margin-left: 10px;
}

svg.red-icon polyline,
svg.red-icon path,
svg.red-icon polygon,
svg.red-icon circle,
svg.red-icon line {
    stroke: #e30030;
}

.interior-banner .capability-icon {
    display: inline-block;
    width: 110px;
    margin: 10px;

    font-size: 12px;
    font-weight: 500;

    transition: .5s opacity;
    text-align: center;
    text-transform: uppercase;

    opacity: .4;
    color: #fff;
}

.interior-banner .capability-icon:hover {
    opacity: 1;
}

.interior-banner .capability-icon.active {
    opacity: 1;
}

.interior-banner .capability-icon svg {
    display: block;
    height: 50px;
    margin: 10px auto;
}

.interior-banner .capability-icon svg polyline,
.interior-banner .capability-icon svg path,
.interior-banner .capability-icon svg polygon,
.interior-banner .capability-icon svg circle,
.interior-banner .capability-icon svg line {
    stroke: #fff;
}

.capabilities-feature-svg {
    max-width: 100px;
    margin-bottom: 20px;
}

.capabilities-feature-svg polyline,
.capabilities-feature-svg path,
.capabilities-feature-svg polygon,
.capabilities-feature-svg circle,
.capabilities-feature-svg line {
    stroke: #e30030;
}

.capability-preview {
    display: inline-block;
    width: 100%;

    transition: .5s color, .5s background;
    vertical-align: top;

    color: #333;
}

.capability-preview:focus {
    color: #333;
}

.capability-preview svg {
    position: relative;
    top: 50%;

    max-height: 75px;

    transform: translateY(-50%);
}

.capability-preview .svg-container svg polyline,
.capability-preview .svg-container svg path,
.capability-preview .svg-container svg polygon,
.capability-preview .svg-container svg circle,
.capability-preview .svg-container svg line {
    transition: .5s stroke;

    stroke: #e30030;
}

.capability-preview .svg-container {
    margin-top: 20px;

    text-align: center;
}

.capability-preview .capability-summary {
    margin-bottom: 20px;
}

.capability-preview .capability-summary h3 {
    margin-bottom: 0;
}

.capability-preview .text-red {
    transition: .5s color;
}

.capability-preview:hover {
    color: #fff;
    background: #e30030;
}

.capability-preview:hover .svg-container svg polyline,
.capability-preview:hover .svg-container svg path,
.capability-preview:hover .svg-container svg polygon,
.capability-preview:hover .svg-container svg circle,
.capability-preview:hover .svg-container svg line {
    stroke: #fff;
}

.capability-preview:hover .text-red {
    color: #fff;
}

.banner-icon svg {
    display: block;
    height: 70px;
    margin: 10px auto;
}

.banner-icon svg polyline,
.banner-icon svg path,
.banner-icon svg polygon,
.banner-icon svg circle,
.banner-icon svg rect,
.banner-icon svg line {
    stroke: #fff;
}

.capability-headline {
    margin-bottom: 60px;

    font-size: 30px;
    font-weight: 700;

    text-align: center;

    color: #e30030;
}

.banner-bottom-right {
    position: absolute;
    right: 15px;
    bottom: 30px;
}

.big-bold-headline {
    margin-top: 20px;
    margin-bottom: 20px;

    font-size: 36px;
    font-weight: 800;
    line-height: 1.1;

    text-align: center;
    text-transform: uppercase;

    color: #333;
}

.big-bold-headline h1 {
    display: inline-block;
    margin: 0;

    font-size: 36px;
    font-weight: 800;
    line-height: 1.1;
}

.case-study-introduction {
    font-size: 18px;
}

.case-study-introduction .case-study-body {
    font-weight: 500;
}

.case-study-introduction .gray-list a {
    line-height: 1.2em;
}

.case-study-introduction .text-bold {
    margin-bottom: 0;

    font-weight: 600;

    color: #5c5c5c;
}

.case-study-introduction .company-website a {
    font-weight: 600;

    transition: .5s color;

    color: #333;
}

.case-study-introduction .company-website a:hover {
    color: #e30030;
}

.gallery .container {
    width: 100%;
    padding: 0;
}

.gallery .container .row {
    margin: 0;
}

.gallery .container .row > div {
    padding: 0;
}

.client-logos-container {
    display: inline-block;

    font-size: 0;

    text-align: center;
}

.client-logo {
    display: inline-block;
    float: none;
    height: 90px;
    margin-bottom: 45px;
}

.client-logo img {
    position: relative;
    top: 50%;

    max-height: 90px;
    padding: 0 55px;

    transition: .5s all;
    transform: translateY(-50%);

    opacity: .9;

    filter: grayscale(1);
}

.client-logo:hover img {
    opacity: 1;

    filter: grayscale(0);
}

.gallery .youtube {
    position: relative;

    padding-top: 56.25% !important;
    overflow: hidden;

    cursor: pointer;

    background-color: #000;
}

.gallery .youtube img {
    top: 0;
    left: 0;

    width: 100%;

    opacity: .7;
}

.gallery .youtube .play-button {
    z-index: 1;

    width: 70px;
    height: 70px;

    opacity: .8;
    border-radius: 35px;
    background-color: #fff;
    box-shadow: 0 0 30px rgba(0, 0, 0, .6);
}

.gallery .youtube .play-button:before {
    margin-left: 2px;

    content: "";

    border-width: 15px 0 15px 26.0px;
    border-style: solid;
    border-color: transparent transparent transparent #333;
}

.gallery .youtube img,
.gallery .youtube .play-button {
    cursor: pointer;
}

.gallery .youtube img,
.gallery .youtube iframe,
.gallery .youtube .play-button,
.gallery .youtube .play-button:before {
    position: absolute;
}

.gallery .youtube .play-button,
.gallery .youtube .play-button:before {
    top: 50%;
    left: 50%;

    transform: translate3d(-50%, -50%, 0);
}

.gallery .youtube iframe {
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;
}

.padding-0 {
    padding: 0 !important;
}

.padding-10 {
    padding: 10px !important;
}

.padding-20 {
    padding: 20px !important;
}

.padding-30 {
    padding: 30px !important;
}

.padding-40 {
    padding: 40px !important;
}

.padding-50 {
    padding: 50px !important;
}

.padding-60 {
    padding: 60px !important;
}

.padding-70 {
    padding: 70px !important;
}

.padding-80 {
    padding: 80px !important;
}

.padding-90 {
    padding: 90px !important;
}

.padding-100 {
    padding: 100px !important;
}

.padding-110 {
    padding: 110px !important;
}

.padding-120 {
    padding: 120px !important;
}

.padding-130 {
    padding: 130px !important;
}

.padding-140 {
    padding: 140px !important;
}

.padding-150 {
    padding: 150px !important;
}

.padding-160 {
    padding: 160px !important;
}

.padding-170 {
    padding: 170px !important;
}

.padding-180 {
    padding: 180px !important;
}

.padding-190 {
    padding: 190px !important;
}

.padding-200 {
    padding: 200px !important;
}

#product-video {
    width: 100%;
}

#product-video-play {
    position: absolute;
    right: 20px;
    bottom: 0;

    font-size: 45px;

    transition: font-size .25s ease-in-out;
}

.product-video-play-hidden {
    font-size: 0 !important;
}

.two-columns {
    max-width: 900px;
    margin: 0 auto;

    font-size: 18px;

    text-align: left;

    column-count: 1;
}

a.seo-close-button,
a.seo-close-button:hover,
a.seo-close-button:active,
a.seo-close-button:focus,
a.seo-close-button:visited {
    position: absolute;
    right: 15px;

    color: #b9b9b9;
}

.packages .container {
    position: relative;

    padding-top: 35px;

    font-weight: 400;

    background: #f5f5f5;
}

.package-tabs {
    position: absolute !important;
    top: 0;

    width: 100%;
    max-width: 750px;

    cursor: pointer;
}

.package-tabs.fixed {
    position: fixed !important;
    top: 72px;
    z-index: 2;
}

.package-tab {
    padding-right: 5px;
    padding-left: 5px;

    font-size: 12px;

    transition: padding-bottom .3s, border-bottom .3s;
    text-align: center;
    text-transform: uppercase;

    color: #fff;
    border-bottom: 0 solid #e30030;
    background: #333;
}

.package-tab.active {
    padding-bottom: 3px !important;

    border-bottom: 5px solid #e30030;
}

.packages #intermediate {
    white-space: nowrap;
}

.packages > .container > a {
    color: #333;
}

.packages > .container > a .row {
    font-size: 90%;

    transition: background .3s, color .3s;
}

.packages > .container > a:hover .row {
    color: #fff;
    background: #e30030;
}

.packages p {
    margin: 0;
}

.packages > .container > .row:first-child {
    padding-top: 0;
}

.packages .row {
    position: relative;

    padding-top: 0;
    padding-bottom: 0;
    overflow: hidden;
}

.packages a {
    cursor: pointer;
}

.packages .row > div {
    padding-top: 10px;
    padding-bottom: 8px;
}

.packages .basic,
.packages .intermediate,
.packages .advanced {
    text-align: center;
}

.packages .intermediate h3 {
    font-weight: 600;
}

.packages h3 {
    margin-top: 40px;
}

.packages .intermediate .value-badge {
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    padding-top: 2px;

    font-size: 14px;
    font-weight: 600;

    letter-spacing: 1.6px;
    text-transform: uppercase;

    color: #fff;
    background: #e30030;
}

.packages .pricing,
.packages-fixed-nav .pricing {
    font-size: 30px;
}

.packages .pricing:after,
.packages-fixed-nav .pricing:after {
    font-size: 14px;

    content: "/mo.";
}
.packages .pricing + p,
.packages-fixed-nav .pricing + p {
    font-size: 14px;
}

.packages .seo-service {
    padding-top: 12px !important;

    font-size: 16px;
}

.packages > .container > a .row:before {
    position: absolute;
    top: 0;
    right: 15px;
    left: 0;

    width: 100%;
    height: 2px;

    border-right: 15px solid #f6f6f6;
    border-left: 15px solid #f6f6f6;
    background: #d2d2d2;
}

.packages-fixed-nav {
    position: fixed;
    top: 72px;
    z-index: 500;

    width: 100%;

    font-weight: 500;

    transition: opacity .3s;
    text-align: center;
    pointer-events: none;

    opacity: 0;
}

.packages-fixed-nav.visible {
    pointer-events: all;

    opacity: 1;
}

.packages-fixed-nav .pricing {
    margin: 0;
}

.packages-fixed-nav h3 {
    margin: 10px 0;
}

.packages-fixed-nav .intermediate-fixed h3 {
    font-weight: 600;
}

.packages-fixed-nav .col-xs-3 {
    background: #f6f6f6;
}

.packages-fixed-nav .row {
    box-shadow: 0 50px 120px -30px #333;
}

.packages-fixed-nav .intermediate-fixed {
    color: #fff;
    background: #e30030;
}

.seo-modal .modal-content {
    border-radius: 0;
}

.seo-modal.plan .modal-content {
    background: #edf0f5;
}

.seo-modal.plan h3 {
    font-weight: 800;

    text-align: center;
    text-transform: uppercase;
}

.body-link a {
    font-weight: 700;

    cursor: pointer;
    transition: .5s color;

    color: #333;
}

.body-link:hover a {
    color: #e30030;
}

.video-banner {
    position: relative;

    height: 540px;
    overflow: hidden;

    background: black;
}

.video-banner video {
    position: relative;
    top: 50%;
    left: 50%;

    width: 100%;

    transition: transform .5s, top .5s;
    transform: translateX(-50%) translateY(-50%);

    opacity: .7;
}

.video-banner .container {
    position: absolute;
    top: 0;

    width: 100%;
}

.video-banner video.align-top {
    top: 0;

    transform: translateX(-50%) translateY(0);
}

.dial-fill {
    animation: dial 2s ease-out forwards;
}

.dial-bg {
    fill: none;
    stroke: #eee;
    stroke-width: 3.8;
}

.dial {
    opacity: 0;

    fill: none;
    stroke-linecap: round;
    stroke-width: 2.8;
}

.dial-container {
    position: relative;

    float: left;
    width: 100%;
}

.dial-svg {
    display: block;
    max-width: 80%;
    max-height: 250px;
    margin: 10px auto;
}

.dial-svg.blue .dial {
    stroke: #3c9ee5;
}

.dial-percent {
    font-family: proxima-nova, sans-serif;
    font-size: .5em;

    fill: #666;
    text-anchor: middle;
}

.dial-container a,
.dial-container a:hover,
.dial-container a:focus,
.dial-container a:active,
.dial-container a:visited {
    color: #333;
}

.dial-container p.title {
    font-size: 15px;
    font-weight: 600;

    text-align: center;
}

.dial-container p.notes {
    padding: 0 15px;

    font-size: 15px;
    font-weight: 400;
}

.tooltip-inner {
    text-align: left;
}

.website-thumbnail {
    border: 2px solid #f0f0f0;
}

h2 a,
h2 a:active,
h2 a:visited,
h2 a:focus {
    transition: color .3s;

    color: #333;
}

h2:hover a {
    color: #e30030;
}

.alert {
    position: relative;

    cursor: pointer;
    transition: background .3s;

    color: #fff;
    background: #333;
}

.alert a,
.alert a:active,
.alert a:visited,
.alert a:focus {
    font-weight: 800;

    transition: color .3s;

    color: #333;
}

.alert a:hover {
    color: #e30030;
}

.alert h3 {
    margin-top: 0;
    margin-bottom: 0;
}

.alert h3 i {
    position: absolute;
    right: 10px;
}

.alert-body {
    padding: 5px 10px;

    color: #333;
    border-radius: 5px;
    background: #fff;
}

.hs-input {
    background: green !important;
}

.alert:hover {
    background: #000;
}

.alert .condition-box {
    position: relative;

    display: inline-block;
    margin-top: 8px;

    font-size: 15px;
    font-weight: 600;

    text-align: center;

    color: #fff;
    border-radius: 40px;
}

.alert.status-1 .condition-box {
    background: #63bb02;
}

.alert.status-2 .condition-box {
    background: #ff8100;
}

.alert.status-3 .condition-box {
    background: #e30030;
}

.alert .icon-container {
    position: relative;

    display: inline-block;
    float: left;
    width: 30px;
    height: 30px;

    border-radius: 100px;
    background: #fff;
}

.alert.status-1 .icon-container {
    color: #63bb02;
}

.alert.status-2 .icon-container {
    color: #ff8100;
}

.alert.status-3 .icon-container {
    color: #e30030;
}

.alert .icon-container i {
    position: absolute;
    top: 50%;
    left: 50%;

    transform: translateX(-50%) translateY(-50%);
}

.alert .alert-copy {
    top: 0;

    display: inline-block;
    height: 30px;
    padding: 0;
    margin: 0;
}

.alert .alert-copy p {
    padding: 5px 10px;
    margin-bottom: 0;
}

i.condition {
    position: absolute;
    top: 10px;
    right: 10px;

    font-size: 30px;
}

.dial-container i.condition.fa-check {
    color: #63bb02;
}

.dial-container i.condition.fa-exclamation-triangle {
    color: #ff8100;
}

.dial-container i.condition.fa-exclamation {
    color: #e30030;
}

@keyframes dial {
    0% {
        opacity: 1;

        stroke: #3c9ee5;
        stroke-dasharray: 0 100;
    }

    100% {
        opacity: 1;

        stroke: #3c9ee5;
    }
}

.gallery-row {
    padding: 0 5px;
}

.image-box {
    padding: 2px;
}

.image-box i,
.image-box i:focus,
.image-box i:visited,
.image-box i:active {
    transition: color .3s;

    color: #696969;
}

.image-box i:hover {
    color: #e30030;
}

.image-box .gallery-image {
    position: relative;

    border: 1px solid #a7a5a5;
    background: #232323;
}

.image-box .gallery-image img {
    position: relative;

    width: 100%;
}

.image-box .view-bar {
    position: absolute;
    bottom: 0;

    width: 100%;
    padding-top: 4px;

    font-size: 20px;

    transition: opacity .3s;
    text-align: center;

    opacity: 1;
    background: #e8e8ea;
}

.image-index {
    position: absolute;
    top: 0;
    left: 0;

    padding: 2px 5px;

    line-height: 1;

    color: #fff;
    background: rgba(0, 0, 0, .5);
}

.dropdown {
    box-shadow: 0 25px 38px -25px #333;
}

#companyContent {
    transition: opacity .3s;

    opacity: 1;
}

#companyContent.refresh {
    opacity: 0;
}

#companies-nav {
    position: absolute;
    z-index: 9;

    width: 100%;

    background: #fff;
}

#companies-nav.sticky {
    position: fixed;
    top: 72px;

    background: #fff;
}

#companies-nav-mobile-spacer {
    height: 60px;
}

#companies-nav .dropdown-tooltip {
    position: absolute;
    top: 50%;
    right: 5px;

    width: 85px;

    transform: translateY(-50%);
    text-align: center;
}

#companies-nav .dropdown-tooltip p {
    margin-bottom: 0;

    font-size: 14px;
    font-weight: 800;
    line-height: 1em;

    text-transform: uppercase;
}

#companies-nav .dropdown-tooltip i.fas.fa-caret-down {
    font-size: 30px;
    line-height: 0;
}

#companies-nav ul {
    position: relative;

    width: 100%;
    padding-bottom: 0;
    margin-top: 0;

    border-radius: 0;
}

#companies-nav ul li {
    border-bottom: 1px solid #d8d8d8;
}

#floating-underline {
    position: absolute;
    top: 100%;
    z-index: 1000;

    display: none;
    width: 140px;
    height: 8px;
    margin-top: -4px;

    transition: left .6s;
    transform: translateX(-50%);

    background: #e30030;
}

.companies.nav-refresh #floating-underline {
    display: block;
}

.companies.nav-refresh .dropdown-menu {
    display: flex !important;
    padding: 0;
    overflow-x: auto;
}

.companies.nav-refresh .dropdown-menu::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background-color: #a1a1a1;
}

.companies.nav-refresh .dropdown-menu::-webkit-scrollbar {
    height: 5px;
}

@media screen and (min-width: 768px) {
    .companies.nav-refresh .dropdown-menu::-webkit-scrollbar {
        height: 10px;
    }
}

.companies.nav-refresh .dropdown-menu li.tab {
    position: relative;

    float: left;
    min-width: 166px;
    padding: 5px 0;

    border-bottom: none !important;
}

.companies.nav-refresh .dropdown-menu li.tab.active,
.companies.nav-refresh .dropdown-menu li.tab:hover {
    background-color: #ebebeb;
}

.companies.nav-refresh .dropdown-menu li.tab:not(:last-child):after {
    position: absolute;
    top: 50% !important;
    right: 0;

    width: 1px;
    height: 80%;

    content: " ";
    transform: translateY(-50%) !important;

    background: #b7b7b7;
}

.companies.nav-refresh .dropdown-menu {
    border: none;
    box-shadow: 0 10px 12px rgba(0, 0, 0, .175);
}

#industry-banner-scroll i {
    margin-bottom: 26px;

    font-size: 30px;

    color: #fff;
}

.industry-gallery-copy p {
    margin-bottom: 20px;
}

.preview-version > #companies-nav-mobile-spacer {
    height: 450px;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .tab {
    display: flex;
    flex-direction: column;

    align-items: center;
    justify-content: space-between;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .tab.active,
.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .tab:hover {
    cursor: pointer;

    background-color: #ebebeb;
}

.companies-button {
    display: flex;
    padding: 8px 0;

    font-size: 75%;
    font-weight: 500;

    transition: opacity .3s ease;

    opacity: .6;

    align-items: center;
}

.companies-button > i {
    padding-left: 4px;

    font-size: 60%;

    transition: .3s all;
}

.companies-button:hover > i {
    transition: .3s all;
    transform: translateX(4px);
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav,
.preview-version > #companies-nav-mobile-spacer > #companies-nav.sticky {
    position: relative;
    top: unset;

    width: 100%;

    background: #fff;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav > .button-to-top-wrapper > .button-to-top {
    transition: .1s all;
    transform: translateX(80px);
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav.sticky > .button-to-top-wrapper > .button-to-top {
    transition: .1s all;
    transform: translateX(-16px);
}

.button-to-top {
    position: fixed;
    right: 0;
    bottom: 100px;
    z-index: 10;

    display: flex;
    width: 60px;
    height: 60px;
    flex-direction: column;

    color: #fff;
    border: none;
    border-radius: 50%;
    background-color: rgb(227, 0, 48);
    box-shadow: rgba(0, 0, 0, .1) 0 1px 4px, rgba(0, 0, 0, .2) 0 2px 12px;

    align-items: center;
    justify-content: center;
}

.button-to-top > a {
    display: flex;
    width: 100%;
    height: 100%;
    flex-direction: column;

    color: unset;

    align-items: center;
    justify-content: center;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav.sticky > .button-to-top-wrapper > .button-to-top:hover {
    right: 16px;

    transform: scale(1.1);

    box-shadow: rgba(0, 0, 0, .1) 0 2px 6px, rgba(0, 0, 0, .2) 0 4px 16px;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav .dropdown-menu .tab:not(:last-child):after {
    position: relative;

    max-width: 100%;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu,
.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu::before,
.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu::after {
    position: relative;
    right: 0;
    left: 0;

    max-width: 100%;

    transform: translateX(15px);
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .tab.active > .companies-button {
    opacity: 0;
}

.preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .tab > img {
    max-width: 180px;
    max-height: 60px;
    padding: 12px 8px;
}

.med-dev > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu {
    display: block;
}

.industry-company-intro {
    position: relative;
    z-index: 2;

    box-shadow: 0 25px 38px -25px #333;
}

.calendly-inline-widget {
    height: 1050px;
}

/*==============================================================================
=                                Media Queries                                 =
==============================================================================*/
@media screen and (max-width: 767px) {
    .home-copy {
        text-align: center;
    }

    #companies-nav .dropdown-menu li.tab {
        width: 100% !important;
    }

    section#capabilities-feature {
        padding: 50px 0;
    }

    p,
    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    a,
    .footer-copy,
    footer li,
    footer li a,
    footer .col-md-3,
    .gray-list,
    .gray-list li,
    .gray-list li a,
    .red-subhead-agency,
    .expertise-body h3,
    .expertise-body .col-xs-12 .mt20 {
        text-align: center;
    }

    .expertise-body svg.red-icon {
        display: inline-block;
        float: none!important;
        height: 25px!important;
        margin-top: 10px!important;
        margin-top: 27px!important;
    }

    .capability-summary,
    .capability-summary h3,
    .capability-summary p {
        text-align: left;
    }

    #capabilities p.text-white {
        margin-bottom: 40px;
    }

    #capabilities .red-button,
    .expertise-body .red-button {
        display: block;
        max-width: 200px;
        margin: 20px auto!important;
    }

    .services-body .red-button {
        display: block;
        max-width: 200px;
        margin: 20px auto;
    }

    footer .col-xs-12 {
        padding-bottom: 30px;
    }
}

@media screen and (max-width: 370px) {
    .packages #intermediate i {
        display: none;
    }

    .image-box {
        width: 100%;
    }
}

@media screen and (min-width: 400px) {
    /*============================= Globals ====================================*/
    /*============================= Header =====================================*/
    /*============================= Navigation =================================*/
    /*============================= Footer =====================================*/
    /*============================= Home Page ==================================*/
    /*============================= Interior ===================================*/
    .insights-category {
        float: left;
        width: 50%;
    }

    .insights-category.active i {
        right: 21px;
    }

    .insights-thumbnail-title {
        padding: 50px;
    }

    .insights-thumbnail-tag,
    .insights-thumbnail-tag:focus {
        display: block;
    }
}

@media screen and (min-width: 480px) {
    /*============================= Globals ====================================*/
    /*============================= Header =====================================*/
    /*============================= Navigation =================================*/
    /*============================= Footer =====================================*/
    /*============================= Home Page ==================================*/
    .landing-video .overlay .headline {
        font-size: 35px;
    }

    /*============================= Interior ===================================*/
    .dial-container {
        float: left;
        width: 50%;
    }
}

@media screen and (min-width: 620px) {
    /*============================= Globals ====================================*/
    /*============================= Header =====================================*/
    /*============================= Navigation =================================*/
    /*============================= Footer =====================================*/
    /*============================= Home Page ==================================*/
    .landing-video .overlay .headline {
        font-size: 40px;
    }

    /*============================= Interior ===================================*/
}

@media screen and (min-width: 768px) {
    /*============================= Globals ====================================*/
    body,
    h1.body {
        font-size: 20px;
    }

    h2 {
        font-size: 36px;
    }

    .text-right-sm {
        text-align: right;
    }

    .text-left-sm {
        text-align: left;
    }

    .text-center-sm {
        text-align: center;
    }

    .capabilites-list {
        padding: 100px;
    }

    /*============================= Header =====================================*/
    /*============================= Navigation =================================*/
    /*
  nav.oc-right > ul > li {
    position: relative;
    display: block;
    float: left;
  }

  nav.oc-right > ul > li > a {
    display: block;
    padding: 8px;
  }

  nav.oc-right > ul > li:hover > ul {
    position: absolute;
    display: block;
  }

  nav.oc-right ul ul {
    display: none;
  }
  */
    /*============================= Footer =====================================*/
    .negative-margin {
        margin-bottom: -9px;
    }

    .footer-logo-section img {
        margin: 0;
    }

    .footer-nav-section {
        text-align: right;
    }

    .footer-nav-section ul {
        margin: 0;

        column-count: 3;
    }

    .footer-contact-section ul {
        column-count: 2;
    }

    /*============================= Home Page ==================================*/
    .landing-video .overlay .headline {
        font-size: 50px;
    }

    .work-categories {
        display: block;
    }

    /*============================= Interior ===================================*/
    .interior-banner h1,
    .interior-banner div.styled-h1 {
        font-size: 42px;
    }

    .interior-banner p {
        font-size: 24px;
    }

    .capability-preview {
        float: left;
        width: 50%;
        padding: 40px 0;
    }

    .big-bold-headline {
        margin-bottom: 40px;

        font-size: 60px;
    }

    .big-bold-headline h1 {
        font-size: 60px;
    }

    .two-columns {
        column-count: 2;
        column-gap: 50px;
    }

    .insights-body {
        column-count: 2;
        column-gap: 40px;
    }

    .insights-category {
        float: unset;
        width: auto;
    }

    .insights-category.active i {
        right: 3px;
    }

    .insights-category.active {
        margin: 0 -18px 0 0;
    }

    .padding-sm-0 {
        padding: 0 !important;
    }

    .padding-sm-10 {
        padding: 10px !important;
    }

    .padding-sm-20 {
        padding: 20px !important;
    }

    .padding-sm-30 {
        padding: 30px !important;
    }

    .padding-sm-40 {
        padding: 40px !important;
    }

    .padding-sm-50 {
        padding: 50px !important;
    }

    .padding-sm-60 {
        padding: 60px !important;
    }

    .padding-sm-70 {
        padding: 70px !important;
    }

    .padding-sm-80 {
        padding: 80px !important;
    }

    .padding-sm-90 {
        padding: 90px !important;
    }

    .padding-sm-100 {
        padding: 100px !important;
    }

    .padding-sm-110 {
        padding: 110px !important;
    }

    .padding-sm-120 {
        padding: 120px !important;
    }

    .padding-sm-130 {
        padding: 130px !important;
    }

    .padding-sm-140 {
        padding: 140px !important;
    }

    .padding-sm-150 {
        padding: 150px !important;
    }

    .padding-sm-160 {
        padding: 160px !important;
    }

    .padding-sm-170 {
        padding: 170px !important;
    }

    .padding-sm-180 {
        padding: 180px !important;
    }

    .padding-sm-190 {
        padding: 190px !important;
    }

    .padding-sm-200 {
        padding: 200px !important;
    }

    .image-box .view-bar {
        opacity: 0;
    }

    .image-box:hover .view-bar {
        opacity: 1;
    }

    .preview-version > #companies-nav-mobile-spacer {
        height: 120px;
    }

    .med-dev > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu {
        display: flex;
        flex-direction: row;

        align-items: unset;
    }

    .med-dev > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .company-tab {
        width: 50%;
    }

    .preview-version > #companies-nav-mobile-spacer > #companies-nav > .dropdown > .row.revised-menu > .tab > img {
        max-width: 100%;
        max-height: 80px;
    }
}

@media screen and (min-width: 992px) {
    /*============================= Globals ====================================*/
    body,
    h1.body {
        font-size: 22px;
    }

    .text-right-md {
        text-align: right;
    }

    .text-left-md {
        text-align: left;
    }

    .text-center-md {
        text-align: center;
    }

    /*============================= Header =====================================*/
    /*============================= Navigation =================================*/
    /*============================= Footer =====================================*/
    .footer-nav-section {
        text-align: left;
    }

    .footer-contact-section {
        margin-top: 0;
    }

    /*============================= Home Page ==================================*/
    .landing-video .overlay .headline {
        font-size: 60px;
    }

    .work-category {
        padding: 0 30px;
    }

    /*============================= Interior ===================================*/
    .instagram-container .instagram-spacing {
        width: 16.666666%;
    }

    .interior-banner h1,
    .interior-banner div.styled-h1 {
        font-size: 50px;
    }

    .interior-banner p {
        font-size: 26px;
    }

    .capability-preview .capability-summary p {
        font-size: 18px;
    }

    .big-bold-headline,
    .big-bold-headline h1 {
        font-size: 80px;
    }

    .padding-md-0 {
        padding: 0 !important;
    }

    .padding-md-10 {
        padding: 10px !important;
    }

    .padding-md-20 {
        padding: 20px !important;
    }

    .padding-md-30 {
        padding: 30px !important;
    }

    .padding-md-40 {
        padding: 40px !important;
    }

    .padding-md-50 {
        padding: 50px !important;
    }

    .padding-md-60 {
        padding: 60px !important;
    }

    .padding-md-70 {
        padding: 70px !important;
    }

    .padding-md-80 {
        padding: 80px !important;
    }

    .padding-md-90 {
        padding: 90px !important;
    }

    .padding-md-100 {
        padding: 100px !important;
    }

    .padding-md-110 {
        padding: 110px !important;
    }

    .padding-md-120 {
        padding: 120px !important;
    }

    .padding-md-130 {
        padding: 130px !important;
    }

    .padding-md-140 {
        padding: 140px !important;
    }

    .padding-md-150 {
        padding: 150px !important;
    }

    .padding-md-160 {
        padding: 160px !important;
    }

    .padding-md-170 {
        padding: 170px !important;
    }

    .padding-md-180 {
        padding: 180px !important;
    }

    .padding-md-190 {
        padding: 190px !important;
    }

    .padding-md-200 {
        padding: 200px !important;
    }

    .packages .container {
        padding-top: 0;
    }
    .packages .row:nth-child(n+3):before {
        position: absolute;
        top: 0;
        right: 15px;
        left: 0;

        width: 100%;
        height: 2px;

        border-right: 15px solid #f6f6f6;
        border-left: 15px solid #f6f6f6;
        background: #d2d2d2;
    }

    .packages .row > div {
        padding-top: 10px;
        padding-bottom: 100px;
        margin-bottom: -92px;
    }

    .packages .last-row .intermediate {
        padding-top: 10px;
        padding-bottom: 8px;
        margin-bottom: 0;
    }

    .intermediate:before {
        position: absolute;
        top: 0;
        left: 0;

        width: 2px;
        height: 100%;

        content: "";

        background: #e30030;
    }

    .intermediate:after {
        position: absolute;
        top: 0;
        right: 0;

        width: 2px;
        height: 100%;

        content: "";

        background: #e30030;
    }

    .intermediate-cap {
        border-bottom: 2px solid #e30030;
    }

    .dial-container {
        float: left;
        width: 25%;
    }
}

@media screen and (min-width: 1016px) {
    .calendly-inline-widget {
        height: 700px;
    }
}

@media screen and (min-width: 1200px) {
    /*============================= Globals ====================================*/
    h2 {
        font-size: 48px;
    }

    /*============================= Header =====================================*/
    /*============================= Navigation =================================*/
    /*============================= Footer =====================================*/
    .footer-copy {
        font-size: 15px;
    }

    /*============================= Home Page ==================================*/
    /*============================= Interior ===================================*/
    .interior-banner h1,
    .interior-banner div.styled-h1 {
        font-size: 60px;
    }

    .interior-banner p {
        max-width: 700px;

        font-size: 30px;
    }

    .capability-preview .capability-summary h3 {
        font-size: 34px;
    }

    .big-bold-headline {
        margin-bottom: 50px;

        font-size: 100px;
    }

    .big-bold-headline h1 {
        font-size: 100px;
    }

    .image-box {
        width: 20%;
    }

    .industry-company-intro {
        width: 800px;
        padding: 0 50px;
        margin-top: -110px;

        background: #fff;
    }
}

@media screen and (min-width: 1500px) {
    .d-1500-none {
        display: none;
    }

    .industry-company-intro {
        margin-top: -150px;
    }

    #companies-nav .dropdown-tooltip {
        display: none;
    }

    #companies-nav .dropdown-menu {
        display: block;
    }

    #companies-nav .dropdown-menu li.tab {
        position: relative;

        float: left;
    }

    #companies-nav .dropdown-menu li.tab:not(:last-child):after {
        position: absolute;
        top: 0;
        right: 0;

        width: 1px;
        height: 80%;

        content: " ";

        background: #b7b7b7;
    }

    #companies-nav .dropdown-menu {
        border: none;
        box-shadow: 0 10px 12px rgba(0, 0, 0, .175);
    }

    #floating-underline {
        display: block;
    }
}/*==============================================================================































































































































































































































=                           Vertical Media Queries                             =
==============================================================================*/
@media screen and (max-height: 420px) {
    .landing-scroller {
        display: none;
    }

    .main .links .site-nav a {
        font-size: 28px;
    }
}

@media screen and (max-height: 540px) {
    .nav-social {
        display: none;
    }
}

.expertise-body {
    width: 95%!important;
}

.expertise-body svg.red-icon {
    display: inline-block;
    /* padding-top: 10px; */
    /* bottom: 0px; */
    float: left;
    height: 35px;
    margin-top: 10px!important;
    margin-top: 27px!important;
}

footer {
    position: relative;

    float: left;
    width: 100%;
}

footer ul {
    padding-left: 0;
    margin-left: 0;

    list-style-type: none;
}

footer ul li a {
    text-transform: capitalize;
}

header .container {
    width: 98%;
}

.services-body ul {
    padding-left: 0!important;
    margin-left: 0!important;

    list-style-type: none!important;
}

.nav-social {
    position: absolute;
    bottom: 15px;
    left: 50%;

    display: block;
    width: 200px;
    margin-left: -100px;
    /* margin-top: 40px; */

    font-size: 18px;
    font-weight: 600;

    text-align: center;
    white-space: nowrap;
    text-transform: uppercase;

    color: #333;
}

#pg-1920 .interior-banner {
    margin: 150px 0;
}

.home-copy {
    padding-top: 20px;
    padding-bottom: 30px;
}

.keywordsentence {
    display: inline;

    font-family: inherit;
    font-size: 36px;
    font-weight: 500;
    line-height: 1.1;

    color: inherit;
}
