/*
 Theme Name:     RYNO Child Theme
 Theme URI:      http://rynoss.com/
 Description:    RYNO Child Theme
 Author:         Ryno SS - Jerad Shepherd
 Author URI:     http://www.rynoss.com
 Template:       theme-3
 Text Domain:    ryno-theme-three-child
 Version:        1.0.0
*/
 
/* =Theme customization starts here
------------------------------------------------------- */


/* COLORS */
:root {
    --color-blue: #00539F;
    --color-dark-blue: #01376A;
    --color-navy-blue: #002344;
    --color-light-blue: #D6EBFF;
    --color-red: #CE1141;
    --color-red-2: #A7012C;
    --color-dark-red: #800122;
    --color-gray: #E4E4E4;
    --color-dark-gray: #A3A3A3;
}
/* TYPOGRAPHY */
:root {
    --home-heading-font: 'Exo 2', sans-serif;
    --home-body-font: 'Roboto', sans-serif;
    --heading-margin-bottom-default: 0px;
    --margin-bottom-default: 0px;
}
.home h1,.home h2,.home h3,
.home h4,.home h5,.home h6 {
    font-family: var(--home-heading-font);
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 0;
}
.home p {
    font-size: 18px;
    line-height: 28px;
    margin-bottom: var(--margin-bottom-default);
}
body {
    font-family: var(--home-body-font);
}


.home h1 {
    color: black;
    font-family: var(--home-heading-font);
    font-size: 48px;
    font-weight: 700;
    line-height: 52px;
    text-transform: uppercase;
}
.home h5 {
    font-size: 24px;
    font-weight: 700;
    line-height: 28px;
}


.section-subheader {
    color: var(--color-blue);
    font-family: var(--home-heading-font);
    font-size: 28px;
    line-height: 28px;
    letter-spacing: 2px;
    text-transform: uppercase;
}
.section-header h2 {
    color: black;
    font-size: 42px;
    font-weight: 700;
    line-height: 48px;
    text-transform: uppercase;
    font-family: var(--home-heading-font);
    margin-bottom: var(--heading-margin-bottom-default);
}
.section-header {
    color: var(--color-variant-name);
}
.callout-text {
    font-weight: 700;
}
/* COMMON STYLES */
.viewport-overflow-wrapper {
    overflow: hidden;
}
.wpcf7 p {
    margin: 0 !important;
}
.button-wrapper {
    display: flex;
    gap: 10px;
}
.section-transition {
    position: absolute;
    bottom: calc(100vw * (0 / 1600));
    width: 100vw;
    height: calc(100vw * (450 / 1600));
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    transform: scale(1.01);
}
.mobile-xs-only,
.mobile-only {
    display: none;
}
@media (max-width: 991.98px) {
    .desktop-only {
        display: none;
    }
    .mobile-only {
        display: block;
    }
}
.slick-dots .slick-active button::before {
    border-color: dodgerblue;
    background-color: dodgerblue;
}
.slick-dots li button:hover::before {
    border-color: orange;
}
.slick-dots li button::before {
    content: '';
    border: 2px solid dodgerblue;
    background-color: transparent;
    border-radius: 100%;
    opacity: 1;
}


/* BUTTONS */
.btn.reviews span::before {
    background-image: url('/wp-content/uploads/more-reviews-icon.svg');
}
.btn.tell-friend span::before {
    background-image: url('/wp-content/uploads/high-five-icon.svg');
}
.btn.see-options span::before {
    background-image: url('/wp-content/uploads/income-icon.svg');
}
.btn.services span::before {
    background-image: url('/wp-content/uploads/setting-icon.svg');
}
.btn.like span::before {
    background-image: url('/wp-content/uploads/like-icon.svg');
}
.btn.contact span::before {
    background-image: url('/wp-content/uploads/phone-icon-white.svg');
}
.btn.request-service span::before {
    background-image: url('/wp-content/uploads/text-bubble-icon.svg');
}
.btn.specials span::before {
    background-image: url('/wp-content/uploads/coupon-icon.svg');
}
.btn.dollar span::before {
    background-image: url('/wp-content/uploads/dollar-icon.svg');
}
.btn span::before {
    display: block;
    content: '';
    position: relative;
    width: 20px;
    height: 20px;
    margin-right: 5px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transition: var(--btn-fx-speed);
}
.btn span {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}
.btn.btn-tertiary::after {
    background-color: var(--color-dark-gray);
    background-image: url('/wp-content/uploads/arrow-right-white.svg');    
}
.btn.btn-tertiary {
    color: var(--color-dark-blue) !important;
    background-color: white;
}
.btn.btn-secondary::after {
    background-color: var(--color-dark-red);
    background-image: url('/wp-content/uploads/arrow-right-white.svg');
}
.btn.btn-secondary {
	color: white !important;
    background-color: var(--color-red);
}
.btn.btn-primary::after {
    background-color: var(--color-navy-blue);
    background-image: url('/wp-content/uploads/arrow-right-white.svg');
}
.btn.btn-primary {
	color: white !important;
    background-color: var(--color-blue);
}
.btn::after {
    display: block;
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 26px;
    height: 100%;
    background-size: 18px;
    background-position: center;
    background-repeat: no-repeat;
    transition: var(--btn-fx-speed);
    opacity: 0;
}
.btn {
    position: relative;
    --button-rem-size: 18px;
    
    display: inline-block;
    max-width: 100%;
    
    
    font-family: var(--home-heading-font);
    font-size: var(--button-rem-size);
    font-weight: 700;
    line-height: 28px;
    text-transform: uppercase;
    

    border-radius: 5px;
    border-style: solid;
    border-color: transparent;
    border-width: 0;
    
    
    padding-top: 13px;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 13px;
    
    overflow: hidden;
    --btn-fx-speed: 0.235s;
}
.postscript-contact .wpcf7-submit,
.main-contact-form .wpcf7-submit,
.page-section .btn,
.header .btn,
.footer .btn,
.home .btn {
    min-width: 260px;
    max-width: max-content;
}
@media (min-width: 991.98px) {
    .btn:hover.btn-tertiary {
        background-color: var(--color-gray);
    }
    .btn:hover.btn-secondary {
        background-color: var(--color-red-2);
    }
    .btn:hover.btn-primary {
        background-color: var(--color-dark-blue);
    }
    .btn:hover::after {
        opacity: 1;
    }
    .btn:hover {
        padding-right: 40px;
    }
}


.header .header-col--center .header-box {
    justify-content: center;
}
.header-col--right .company-phone-wrapper a::before {
    display: inline-block;
    content: '';
    position: relative;
    top: 2px;
    width: 18px;
    height: 30px;
    margin-right: 8px;
    background-size: contain;
    background-position: center;
    background-image: url('/wp-content/uploads/phone-icon.svg');
}
.header-col--right .company-phone-wrapper a {
    position: relative;
    display: flex;
    align-items: center;
    color: var(--color-blue);
    font-family: var(--home-heading-font);
    font-size: 36px;
    font-weight: 800;
    line-height: 28px; /* 77.778% */
}
.header-col--right .header-box {
    align-items: flex-end;
}
.header .header-box {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}
.header-overbar .serving-text .underline {
    text-decoration: underline;
}
.header .button-wrapper {
    flex-direction: column;
}
.header {
    padding-top: 24px;
}
.header-wrapper {
    box-shadow: 0px 6px 10px 0px rgba(0, 0, 0, 0.25);
}
.header-overbar .serving-text::before {
    display: inline-block;
    content: '';
    position: relative;
    width: 20px;
    height: 20px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url('/wp-content/uploads/location-icon.svg');
}
.header-overbar .serving-text {
    display: flex;
    gap: 5px;
    align-items: center;
    position: relative;
    color: white;
}
.header-overbar {
    color: white;
    padding: 6px 0;
    background-color: var(--color-blue);
}
@media (min-width: 992px) {
    .header-overbar .serving-text:hover {
        color: var(--color-light-blue);
    }
}


.social-icons__icon a > i {
    transition: var(--fx-speed);
}
.social-icons__icon a {
    --icon-size: 24px;
    --fx-speed: 0.225s ease-out;
    display: flex;
    justify-content: center;
    align-items: center;
    width: var(--icon-size);
    height: var(--icon-size);
    font-size: var(--icon-size);
    color: white;
    transition: var(--fx-speed);
}
.social-icons {
    display: flex;
    gap: 31px;
}
@media (min-width: 991.98px) {
    .header-overbar .social-icons__icon:hover a {
        color: var(--color-red);
    }
    .footer .social-icons__icon:hover a > i {
        scale: 1.2;
    }
    .footer .social-icons__icon:hover a {
		color: white;
        background-color: var(--color-dark-red);
    }
}


.slick-prev::before {
    scale: -1;
}
.slick-next::before,
.slick-prev::before {
    display: block;
    content: '';
    width: 100%;
    height: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url('/wp-content/uploads/arrow-right-white.svg');
}
.slick-arrow {
    width: 30px;
    height: 30px;
}


.page-section .image-wrapper img {
    width: 100%;
    height: 100%;
}
.page-section .image-wrapper {
    width: 100%;
    height: 539px;
}
.page-section {
    position: relative;
}


.service-since::after {
    display: inline-block;
    content: '';
    position: relative;
    width: 267px;
    height: 3px;
    margin-left: 20px;
    background-color: var(--color-dark-blue);
}
.service-since {
    position: relative;
    display: flex;
    align-items: center;
    color: var(--color-red);
    font-family: "Roboto Condensed";
    font-size: 35px;
    font-weight: 800;
    line-height: 148.571%;
    letter-spacing: 4px;
    text-transform: uppercase;
    margin: 10px 0;
}
.hero-header span {
    color: var(--color-dark-blue);
    font-size: 40px;
    font-weight: 700;
    line-height: 100%;
    text-transform: uppercase;
}
.hero-header h2 {
    font-size: 74px;
    font-weight: 800;
    line-height: 70.27%;
    height: 65px;
    margin-top: 10px;
    background: linear-gradient(184deg, #00539F 8.44%, #01376A 84.57%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.page-section--hero::after {
    display: block;
    content: '';
    position: relative;
    left: 0;
    bottom: -1px;
    width: 100vw;
    height: 102px;
    margin-top: 190px;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;    
    background-image: url('/wp-content/uploads/frayed-transition-white.png');
}
.page-section--hero {
    padding-top: 117px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url('/wp-content/uploads/hero-bg-desktop.png');
}
@media (max-width: 991.98px) {
    .service-since::after {
        width: 153px;
        height: 3px;
        margin-left: 14px;
    }
    .service-since {
        color: var(--color-red);
        font-size: 22px;
        line-height: 22px;
        letter-spacing: 3px;
    }
    .hero-header span {
        font-family: var(--home-heading-font);
        font-size: 24px;
    }
    .hero-header h2 {
        font-size: 45px;
        line-height: 100%;
        margin-top: 0px;
    }
    .page-section--hero .button-wrapper {
        margin-top: 30px;
    }
    .page-section--hero::after {
        margin-top: 140px;
        background-size: 100% 100%;
        background-repeat: no-repeat;
        background-position: center;
        background-image: url('/wp-content/uploads/frayed-transition-white.png');
    }
    .page-section--hero {
        padding-top: 32px;
    }
}
@media (max-width: 576px) {
    .page-section--hero::before {
        display: block;
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 576px;
        height: 100%;
        background-image: url('/wp-content/uploads/hero-bg-mobile.png');
        z-index: -1;
    }
    .page-section--hero {
        background-image: unset;
    }
}


.page-section--main {
    padding-top: 40px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url('/wp-content/uploads/section-1-bg-desktop.png');
}
@media (max-width: 991.98px) {
    .page-section--main .image-wrapper {
        width: 482.999px;
        height: 257px;
    }
    .page-section--main .section-subheader,
    .page-section--main .section-header {
        text-align: center;
    }
}


.page-section--our-services .col-bottom {
    margin-top: 60px;
}
.page-section--our-services .content-box {
    display: flex;
    height: 100%;
    min-height: 235px;
    align-items: flex-end;
}
.page-section--our-services .col-lg-12 {
    display: flex;
    justify-content: space-between;
}
.page-section--our-services .text-content {
    display: flex;
    width: 358px;
    flex-direction: column;
    align-items: flex-start;
    gap: 30px;
}
.page-section--our-services::after {
    bottom: 0;
    left: 50% !important;
    transform: translateX(-50%) scale(1.003);
    border-bottom: 1px solid white;
    width: 100vw;
    margin-top: 77px;
    height: calc(100vw * (122 / 1600));
    background-size: 100% 100%;
    background-image: url('/wp-content/uploads/curve-transition-bottom.svg');
}
.page-section--our-services::before {
    top: -1px;
    width: 100vw;
    height: 102px;
    transform: scaleY(-1);
    margin-bottom: 81px;
    background-size: 100% 100%;
    background-image: url('/wp-content/uploads/frayed-transition-white.png');
}
.page-section--our-services::after,
.page-section--our-services::before {
    display: block;
    content: '';
    position: relative;
    left: 0;
    background-repeat: no-repeat;
    background-position: center;
}
.page-section--our-services {
    color: white;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url('/wp-content/uploads/our-services-bg-desktop.png');
}
@media (max-width: 991.98px) {
    .page-section--our-services::after {
        margin-top: 160px;
        bottom: -1px;
        height: calc(100vw * (28 / 320));
        background-image: url('/wp-content/uploads/transition-mobile.svg');
    }
    .page-section--our-services::before {
        margin-bottom: 0px;
    }
    .page-section--our-services .col-lg-12 {
        flex-direction: column;
        margin-top: 26px;
        gap: 26px;
    }
    .page-section--our-services .content-box {
        min-height: unset;
        justify-content: center;
    }
    .page-section--our-services h4 {
        font-size: 30px;
    }
    .page-section--our-services .section-decoration {
        display: block;
        content: '';
        position: absolute;
        bottom: 0px;
        left: 0;
        width: 100vw;
        height: calc(100vw * (200 / 576));
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        background-image: url('/wp-content/uploads/cta-decoration-mobile.png');
        z-index: -1;
    }
    .page-section--our-services {
        background-color: var(--color-dark-blue);
        background-image: unset;
        z-index: 1;
    }
}


.page-section--three .button-wrapper {
    margin-top: 30px;
}
@media (max-width: 991.98px) {
    .page-section--three .image-wrapper {
        width: 482.999px;
        height: 257px;
    }
}


.page-section--six .button-wrapper {
    margin-top: 30px;
}
.page-section--four::after {
    display: block;
    content: '';
    position: absolute;
    left: 0;
    bottom: -1px;
    width: 100vw;
    height: 357px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;    
    background-image: url('/wp-content/uploads/city-skyline.png');
    z-index: -1;
}
.page-section--four {
    padding-bottom: 191px;
    background: linear-gradient(180deg, #FFF 0%, #D6EBFF 100%);
    background-image: url('/wp-content/uploads/postscript-bg-desktop.png');
    z-index: 1;
}
@media (min-width: 992px) and (max-width: 1587px) {    
    .page-section--four::after {
        left: 50%;
        transform: translateX(-50%);
        width: 1600px;
        background-size: contain;
    }
}
@media (max-width: 991.98px) {
    .page-section--four::after {
        height: 115px;
        background-size: 100% 100%;
    }
    .page-section--four {
        background-position: center bottom;
        background-repeat: no-repeat;
    }
}


.page-section--testimonials::after {
    display: block;
    content: '';
    position: relative;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) scale(1.003);
    width: 100vw;
    height: calc(100vw * (122 / 1600));
    border-bottom: 1px solid white;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url('/wp-content/uploads/curve-transition-bottom.svg');
}
.page-section--testimonials svg {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
.page-section--testimonials .section-subheader {
    color: white;
}
.page-section--testimonials .section-header h2 {
    color: white;
}
.page-section--testimonials {
    color: white;
    padding-top: 82px;
    background: linear-gradient(to bottom, #01376A 4.11%, #00539F 94.73%);
}
@media (max-width: 991.98px) {
    .page-section--testimonials svg {
        display: none;
    }
    .page-section--testimonials::after {
        margin-top: 40px;
        bottom: -1px;
        background-image: url('/wp-content/uploads/transition-mobile.png');
    }
    .page-section--testimonials {
        padding-top: 20px;
    }
}


@media (max-width: 991.98px) {
    .page-section--six .image-wrapper {
        width: 483px;
        height: 100%;
    }
}
@media (max-width: 767px) {
    .page-section--six .image-wrapper {
        width: 483px;
    }
}
@media (max-width: 576px) {
    .page-section--six .image-wrapper {
        width: 95vw;
    }
}


.page-section--about-us .image-wrapper {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 554px;
    height: 780px;
    z-index: -1;
}
.page-section--about-us .section-subheader,
.page-section--about-us .section-header h2 {
    color: white;
}
.page-section--about-us .section-content-wrapper {
    display: flex;
    flex-direction: column;
    gap: 30px;
    max-width: 744px;
    margin-left: auto;
}
.page-section--about-us::before {
    display: block;
    content: '';
    position: absolute;
    top: -1px;
    left: 0;
    width: 100vw;
    height: 102px;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    transform: scaleY(-1);
    background-image: url('/wp-content/uploads/frayed-transition-white.png');
}
.page-section--about-us {
    color: white;
    padding-top: 191px;
    padding-bottom: 72px;
    background-image: url('/wp-content/uploads/about-us-bg-desktop.png');
    overflow: hidden;
    z-index: 1;
}
@media (max-width: 991.98px) {
    .page-section--about-us .image-wrapper {
        position: relative;
        margin: auto;
        margin-top: 30px;
        height: 100%;
        width: 696px;
    }
    .page-section--about-us {
        padding-top: 130px;
        padding-bottom: 30px;
    }
}
@media (max-width: 767px) {
    .page-section--about-us .image-wrapper {
        width: 516px;
    }
}
@media (max-width: 576px) {
    .page-section--about-us .image-wrapper img {
        object-fit: contain;
    }
    .page-section--about-us .image-wrapper {
        width: 576px;
        height: 245px;
    }
    .page-section--about-us {
        padding-bottom: 0px;
    }
}


.page-section--deals-banner::after {
    display: block;
    content: '';
    position: relative;
    left: 0;
    bottom: -1px;
    width: 100vw;
    height: 102px;
    margin-top: 30px;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url('/wp-content/uploads/frayed-transition-white.png');
}
.page-section--deals-banner {
    padding-top: 32px;
    background: linear-gradient(2deg, var(--Color-Brand-Color-2, #CE1141) 9%, var(--Color-Brand-Color-4, #800122) 98.6%);
}
@media (max-width: 991.98px) {
    .page-section--deals-banner::after,
    .page-section--about-us::before,
    .page-section--our-services::before,
    .page-section--hero::after {
        background-image: url('/wp-content/uploads/frayed-transition-mobile.png');
    }
}


.home .gform_wrapper .button {
    position: absolute;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%);
}
.home .gform_wrapper .textarea::placeholder {
    color: white;
}
.home .gform_wrapper {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 749.348px;
    height: 442px;
    border-radius: 10px;
    border: 6px solid var(--color-dark-blue);
}
@media (max-width: 991.98px) {
    .home .gform_wrapper .button {
        position: relative;
        bottom: 15px;
    }
    .home .gform_wrapper {
        border: unset;
        height: unset;
        width: unset;
    }
}


.page:not(.home) .postscript-contact {
    padding-top: 40px;
}
.postscript-contact .van {
    position: absolute;
    right: 0;
    bottom: 0;
}
.postscript-contact .header-wrapper span {
    color: var(--Color-Brand-Color-1, #00539F);
text-align: center;
leading-trim: both;
text-edge: cap;
font-family: "Exo 2";
font-size: 30px;
font-style: normal;
font-weight: 400;
line-height: 48px; /* 160% */
text-transform: uppercase;
}
.postscript-contact .header-wrapper h2 {
    font-family: var(--home-heading-font);
    font-size: 70px;
    font-weight: 900;
    line-height: 60px;
    letter-spacing: 4px;
    text-transform: uppercase;
    background: linear-gradient(180deg, #00539F 0%, #01376A 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.postscript-contact .header-wrapper {
    text-align: center;
    max-width: 750px;
    margin-bottom: 30px;
    box-shadow: unset;
}
.postscript-contact::after {
    display: block;
    content: '';
    position: absolute;
    bottom: 0px;
    width: 100vw;
    height: 112px;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url('/wp-content/uploads/curve-transition-bottom.svg');
}
.postscript-contact {
    position: relative;
    padding-bottom: 222px;
    background-size: cover;
    background-image: url('/wp-content/uploads/postscript-bg-desktop.png');
}
@media (max-width: 991.98px) {
    .postscript-contact .van {
        position: relative;
        right: unset;
        left: 50%;
        bottom: 54px;
        transform: translateX(-50%);
        width: 576px;
        height: 349px;
        object-fit: contain;
    }
    .postscript-contact::after {
        display: block;
        content: '';
        position: absolute;
        width: calc(100vw + 4px);
        height: calc(100vw * (28 / 320));
        bottom: -2px;
        left: 50%;
        transform: translateX(-50%);
        background-size: contain;
        background-image: url('/wp-content/uploads/transition-mobile.svg');
    }
    .postscript-contact {
        padding-bottom: 0px;
    }
    .postscript-contact .gform_wrapper.gravity-theme .gform_fields {
        grid-row-gap: 16px;
    }
}


.footer .hours span {
    font-size: 14px;
    letter-spacing: 0.42px;
    line-height: 25px;
    text-transform: uppercase;
}
.footer-box-content .bottom-content .hours {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.footer-box-content .bottom-content {
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    background-color: var(--color-dark-blue);
    width: 333px;
    min-height: 176px;
    border-radius: 0px 0px 15px 16px;
}
.footer .bottom-content h6 {
    margin-bottom: 0px;
}


.footer .social-icons__icon a {
    --icon-size: 48px;
    font-size: 24px;
    border-radius: 100%;
    background-color: var(--color-red);
}
.footer .social-icons {
    max-width: 204px;
    flex-wrap: wrap;
    gap: 30px;
    margin-top: 40px;
}


.footer-col--right .footer-box .hours {
    padding-top: 15px;
}
.footer-col--right .footer-box .bottom-content {
    align-items: flex-start;
}
.footer-col--center img {
    width: 300px;
}
.footer-col--right .footer-box,
.footer-col--left .footer-box {
    border: 4px solid var(--color-red);
    border-radius: 20px;
    padding: 13px;
    padding-top: 35px;
}
.footer-box--heading {
    position: absolute;
    display: flex;
    justify-content: center;
    top: -15px;
    width: 233px;
    height: 31px;
    background-color: white;
}
.footer-box {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    height: 100%;
}


.footer-form {
    width: 100%;
    max-width: 631px;
}
.footer .company-address,
.footer .company-address a {
    color: black;
}
.footer .company-address::before {
    display: inline-block;
    content: '';
    position: relative;
    top: 3px;
    left: 0;
    margin-right: 5px;
    width: 20px;
    height: 20px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url('/wp-content/uploads/location-icon-black.svg');
}
.footer .company-address {
    display: block;
    margin: 10px 0;
    position: relative;
    color: black;
    text-decoration: underline;
    max-width: 340px;
}
.footer .company-phone-wrapper a::before {
    display: inline-block;
    content: '';
    position: relative;
    top: 0px;
    width: 12px;
    height: 20px;
    margin-right: 8px;
    background-size: contain;
    background-position: center;
    background-image: url('/wp-content/uploads/phone-icon.svg');
}
.footer .company-phone-wrapper a {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-blue);
    font-family: var(--home-heading-font);
    font-size: 20px;
    font-weight: 800;
    line-height: 28px;
}
.footer svg {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
.footer .company-phone--link {
    color: var(--color-blue);
    font-family: var(--home-heading-font);
    font-size: 20px;
    font-weight: 800;
    line-height: 28px; /* 140% */
}
.footer {
    position: relative;
}
@media (min-width: 991.98px) {
    .footer .company-address:hover,
    .footer .company-address a:hover {
        color: var(--color-blue);
    }
}
@media (max-width: 991.98px) {
    .footer .social-icons {
        width: 100%;
        max-width: 250px;
        flex-wrap: wrap;
        justify-content: center;
    }
    .footer svg {
        height: 57px;
        width: 100vw;
    }
    .footer .row {
        flex-direction: column;
        gap: 30px;
    }
    .footer .footer-box {
        width: max-content;
        margin: auto;
    }
}
@media (max-width: 500px) {
    .footer-col--left .company-address-wrapper {
        display: flex;
        justify-content: center;
    }
    .footer-col--right .company-address {
        margin-left: auto;
        margin-right: auto;
    }
    .footer-col--right .footer-box--heading,
    .footer-col--left .footer-box--heading {
        align-self: center;
    }
    .footer-col--right .footer-box,
    .footer-col--left .footer-box {
        align-items: unset;
    }
    .footer-box-content .bottom-content {
        width: 100%;
    }
    .footer .footer-box {
        width: 100%;
    }
}


.copyright .bottom-row {
    display: flex;
    justify-content: center;    
}
.copyright .top-row {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
}
.copyright a {
    color: white;
    text-decoration: underline;
    font-weight: 700;
}
.copyright .content-divider {
    width: 1px;
    height: 22px;
    background-color: white;
}
.copyright {
    color: white;
    background-color: var(--color-dark-blue);
}
@media (max-width: 991.98px) {
    .copyright .top-row .content-divider {
        display: none;
    }
    .copyright .bottom-row,
    .copyright .top-row {
        max-width: 300px;
        margin: auto;
    }
    .copyright .middle-row,
    .copyright .top-row {
        display: flex;
        gap: 10px;
        justify-content: center;
    }
    .copyright .mobile-only {
        display: flex;
        flex-direction: column;
        gap: 5px;
    }
    .copyright {
        font-size: 14px;
        text-align: center;
    }
}


.callout-label {
    display: flex;
    flex-direction: column;
    color: var(--color-blue);
    text-align: center;
    font-family: var(--home-heading-font);
    font-size: 18px;
    font-weight: 700;
    line-height: 26px; /* 144.444% */
    letter-spacing: 1px;
    text-transform: uppercase;
}
.callout {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px;
}
.important-callouts {
    display: flex;
    justify-content: space-between;
    max-width: 551px;
    margin: 30px 0;
}
@media (max-width: 991.98px) {
    .callout img {
        width: 50px;
        height: 50px;
    }
    .callout-label {
        font-size: 16px;
        line-height: 20px;
    }
    .important-callouts {
        justify-content: space-around;
    }
}


.cta-item img {
    --icon-size: 120px;
    position: absolute;
    top: -80px;
    width: var(--icon-size);
    height: var(--icon-size);
    transition: var(--fx-speed);
}
.cta-sublabel::after {
    display: inline-block;
    content: '';
    position: relative;
    width: 20px;
    height: 20px;
    bottom: -1px;
    right: -5px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url('/wp-content/uploads/arrow-right-white.svg');
}
.cta-sublabel {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 284px;
    height: 42px;
    font-size: 24px;
    font-weight: 500;
    line-height: 42px; /* 175% */
    letter-spacing: 3px;
    font-family: var(--home-heading-font);
    text-transform: uppercase;
}
.cta-sublabel-wrapper {
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
}
.cutout-border {
    position: absolute;
    z-index: -1;
}
.cta-item:hover {
    color: white;
}
.cta-item {
    --fx-speed: 0.29s ease-out;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 358px;
    height: 142px;
    color: white !important;
    transition: var(--fx-speed);
    z-index: 1;
}
@media (min-width: 991.98px) {
    .cta-item-wrapper:hover .cta-item img {
        scale: 1.08;
        filter: drop-shadow(0px 0px 20px rgba(255, 255, 255, 0.30));
    }
    .cta-item-wrapper:hover .cta-item {
        color: white;
        transform: translateY(-20px);
    }
}
@media (max-width: 991.98px) {
    .cutout-border {
    left: 0;
    }
    .cta-sublabel {
        position: relative;
        bottom: 0px;
        width: unset;
        height: unset;
        left: 0;
        transform: unset;
        font-size: 18px;
        line-height: 120%;
        justify-content: flex-start;
        margin-top: 5px;
    }
    .cta-sublabel-wrapper {
        position: relative;
        top: 0;
        left: 0;
        bottom: 0px;
        transform: unset;
    }
    .cta-item .labels-wrapper {
        margin-left: 10px;
    }
    .cta-item img {
        --icon-size: 60px;
        position: relative;
        top: 0;
        left: 0;
        filter: drop-shadow(0px 0px 10px rgba(255, 255, 255, 0.40));
    }
    .cta-item {
        padding: 20px;
        flex-direction: row;
        width: 304px;
        height: 101px;
        justify-content: flex-start;
        align-items: flex-start;
    }
}


.checklist-item span {
    color: black;
    font-size: 18px;
    font-weight: 600;
    line-height: 28px;
    margin-left: 5px;
}
.checklist-item {
    display: flex;
    justify-content: center;
    align-items: center;
    width: max-content;
    min-width: 204px;
    padding: 10px;
    background-color: var(--color-light-blue);
    border-radius: 5px;
}
.checklist-items {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 30px 0;
}


.affiliation-item img {
    position: relative;
    margin: auto;
    top: 50%;
    transform: translateY(-50%);
    height: 120px;
    object-fit: contain;
}
.affiliation-item {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 195px !important;
    height: 160px;
}
.affiliation-slider .slick-prev::before,
.affiliation-slider .slick-next::before {
    background-image: url('/wp-content/uploads/arrow-right-blue.svg');
}
.affiliation-slider .slick-next,
.affiliation-slider .slick-prev {
    top: calc(100% + 40px);
}
.affiliation-slider {
    margin-top: 40px;
    margin-bottom: 140px;
    width: 100%;
}
@media (min-width: 992px) {
    .affiliation-slider .slick-next {
        right: calc(50% - 60px);
    }
    .affiliation-slider .slick-prev {
        left: calc(50% - 60px);
    }
}
@media (max-width: 991.98px) {
    .affiliation-item img {
        width: 100px;
        height: 100px;
        object-fit: contain;
    }
    .affiliation-item {
        display: flex !important;
        width: 100px;
        height: 100px;
    }
    .affiliation-slider .slick-next {
        right: calc((50% - 60px));
    }
    .affiliation-slider .slick-prev {
        left: calc((50% - 60px));
    }
    .affiliation-slider {
        width: unset;
    }
}


.callout-card img {
    position: absolute;
    top: -59px;
}
.callout-card h5 {
    color: var(--color-dark-blue);
}
.callout-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 30px;
    width: 358px;
    height: 338px;
    padding: 26px;
    padding-top: 60px;
    border-radius: 8px;
    background: var(--Color-Defaults-white, #FFF);
    box-shadow: 4px 4px 10px 2px rgba(1, 55, 106, 0.25);
}
.callout-cards {
    display: flex;
    gap: 30px;
    margin-top: 99px;
    margin-bottom: 40px;
}
@media (max-width: 991.98px) {
    .callout-card img {
        width: 80px;
        height: 80px;
        top: -50px;
    }
    .callout-card h5 {
        font-size: 20px;
    }
    .callout-card {
        padding: 20px;
        width: 100%;
        height: 100%;
        padding-top: 44px;
        padding-bottom: 26px;
        gap: 15px;
    }
    .callout-cards {
        flex-direction: column;
        gap: 80px;
    }
}


.review-name {
    font-family: var(--home-heading-font);
    font-size: 18px;
    font-weight: 700;
    line-height: 28px;
    text-transform: uppercase;
}
.review-stars {
    width: 153.473px;
    height: 23.455px;
}
.review-footer {
    display: flex;
    justify-content: space-between;
}
.review::before {
    display: block;
    content: '';
    position: absolute;
    bottom: -5px;
    right: 10px;
    width: 100px;
    height: 100px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url('/wp-content/uploads/quotes.png');
    z-index: -1;
}
.review {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: var(--color-dark-blue);
    width: 542px;
    height: 251px;
    margin: auto;
    border-radius: 10px;
    padding: 26px 0;
    padding-left: 24px;
    padding-right: 48px;
    border: 6px solid var(--color-red);
    border-left: 43px solid var(--color-red);
    background: #FFF;
    z-index: 1;
}
.review-slider .slick-next {
    right: -40px;
}
.review-slider .slick-prev {
    left: -40px;
}
.review-slider {
    display: flex;
    margin: 40px 0;
}
@media (max-width: 991.98px) {
    .review {
        width: 100%;
    }
}


.about-us-item img {
    --icon-size: 45px;
    position: absolute;
    top: -20px;
    width: var(--icon-size);
    height: var(--icon-size);
}
.about-us-sublabel {
    position: absolute;
    font-family: var(--home-heading-font);
    font-size: 18px;
    line-height: 18px;
    letter-spacing: 2px;
    text-transform: uppercase;
    bottom: -5px;
}
.about-us-label {
    font-family: var(--home-heading-font);
    font-size: 18px;
    font-weight: 700;
    line-height: 18px;
    text-transform: uppercase;
}
.cutout-border {
    position: absolute;
    top: 0;
    z-index: -1;
}
.about-us-item {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 30px;
    padding-bottom: 18px;
    width: 227px;
    height: 69px;
    z-index: 1;
}
.about-us-items {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px;
}
@media (max-width: 991.98px) {
    .about-us-item img {
        --icon-size: 24px;
        top: -10px;
    }
    .about-us-sublabel {
        font-size: 12px;
        line-height: 12px;
        letter-spacing: 2px;
    }
    .about-us-label {
        font-size: 13px;
    }
    .about-us-item {
        width: 138px;
        height: 43px;
    }
    .about-us-items {
        gap: 40px 50px;
        justify-content: center;
    }
}


.deal-card .deal-card-label {
    text-align: center;
    color: black;
    font-family: "Roboto Condensed";
    font-size: 24px;
    font-weight: 700;
    line-height: 28px;
    max-width: 250px;
    text-transform: capitalize;
}
.deal-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 20px;
    width: 357px;
    height: 279px;
    padding: 27px 20px;
    border-radius: 8px;
    background: white;
    box-shadow: 10px 10px 20px 2px rgba(1, 55, 106, 0.25);
}
.deal-cards {
    display: flex;
    justify-content: space-between;
}
@media (max-width: 991.98px) {
    .deal-card {
        width: 100%;
    }
    .deal-cards {
        flex-direction: column;
        gap: 30px;
    }
}


/* FORM COLORS */
.gfield--type-select .ginput_container_select .selection .select2-selection__arrow b {
    border-color: #fff rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0) !important;
}
.gfield--type-select .ginput_container_select .selection .select2-selection__rendered {
    color: white !important;
}


/* 600 SCREEN */
@media (max-width: 600px) {
    .page-section--six .image-wrapper img,
    .page-section--three .image-wrapper img,
    .page-section--main .image-wrapper img {
        object-fit: contain;
    }
    .page-section--six .image-wrapper,
    .page-section--three .image-wrapper,
    .page-section--main .image-wrapper {
        width: 100%;
    }
    .page-section--four::after {
        width: 617px;
        left: 50%;
        transform: translateX(-50%);
    }
    .page-section--deals-banner::after,
    .page-section--about-us::before,
    .page-section--our-services::before,
    .page-section--hero::after {
        background-image: url('/wp-content/uploads/frayed-transition-mobile-xs.png');
    }
    .page-section--our-services .section-decoration {
        height: calc(100vw * (167 / 320));
        background-size: contain;
        background-image: url('/wp-content/uploads/cta-decoration-mobile-xs.png');
    }
    .important-callouts {
        width: 300px;
        gap: 30px 0px;
        flex-wrap: wrap;
        margin: 26px auto;
    }
    .deal-card {
        height: 100%;
        padding-left: 10px;
        padding-right: 10px;
    }
    .postscript-contact .mobile-only.van {
        display: none;
    }
    .mobile-xs-only {
        display: block;
    }
    .postscript-contact .header-wrapper span {
        font-size: 20px;
        line-height: 20px;
    }
    .postscript-contact .header-wrapper h2 {
        font-size: 40px;
        line-height: 40px;
        letter-spacing: 4px;
    }
    .review p::before {
        display: block;
        content: '';
        position: relative;
        width: 154px;
        height: 25px;
        margin-bottom: 20px;
        background-size: contain;
        background-repeat: no-repeat;
        background-image: url('/wp-content/uploads/stars.svg');
    }
    .review .review-footer .review-stars {
        display: none;
    }
    .review {
        gap: 20px;
        width: 100%;
        height: 100%;
        padding-top: 20px;
        padding-bottom: 35px;
        border: 6px solid var(--color-red);
        border-top: 31px solid var(--color-red);
    }
    .page-section--about-us .image-wrapper .mobile-only {
        display: none;
    }
    .page-section--about-us .image-wrapper {
        width: 100%;
        height: 100%;
    }
}



















































/* UNORGANIZED FIXES */



.sidebar-form .gfield--type-select .ginput_container_select .selection .select2-selection__rendered {
    color: black !important;
}
.footer-form textarea::placeholder {
    color: white;
}


.page-section--main .section-body,
.page-section--three .section-body {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.page-section--ethical-hvac .col-lg-5,
.page-section--main .col-lg-5,
.page-section--three .col-lg-5 {
    display: flex;
    align-items: center;
}
.checklist-item {
    min-width: unset;
}


#affiliation-slider .slick-track {
	display: flex !important;
}
#affiliation-slider .slick-slide {
	float: none;
}


.callout-card h5 {
    color: var(--color-dark-blue);
    font-size: 20px;
}
.callout-card {
    padding-top: 55px;
    gap: 10px;
}


.home h3 {
    color: #000;
    font-size: 36px;
}


.page-section--four .section-body {
    margin: 20px 0;
}
.page-section--four {
    padding-bottom: 320px;
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 100%;
}


.home-gradient-box .button-wrapper {
    position: absolute;
    bottom: -25px;
}
.home-gradient-box {
    display: flex;
    position: relative;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-height: 192px;
    color: white;
    padding: 60px;
    margin-top: 60px;
    padding-top: 40px;
    border-radius: 20px;
    background: linear-gradient(186deg, var(--Color-Brand-Color-1, #00539F) 4.9%, var(--Color-Brand-Color-3, #01376A) 95.7%);
    z-index: 2;
}


.page-section--ethical-hvac .section-body {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 20px;
}
.page-section--ethical-hvac {
    padding: 100px 0;
}


.postscript-contact::after {
    left: 50%;
    transform: translateX(-50%);
    background-image: url('/wp-content/uploads/curve-transition-bottom.png')
}
.postscript-contact {
    overflow: hidden;
}









.page-id-3149 .conversion-page-reviews .conversion-page-review-box__review-text {
    color: black !important;
}
.page-id-3149 .conversion-page-reviews .conversion-page-review-box__stars {
    color: var(--conversion-page-review-box--stars-color) !important;
}
.page-id-3149 .conversion-page-reviews .charge-reviews-button {
    color: white !important;
    text-decoration: none;
}
@media (min-width: 991.98px) {
    .page-template-page-conversion .conversion-content-two {
        padding-bottom: 0px;
    }
}
@media (min-width: 991.98px) {
    .rsa-grid-template__link:hover {
        color: white !important;
    }
    .page-id-3149 .conversion-page-reviews .charge-reviews-button:hover {
        color: white !important;
        text-decoration: none;
    }
}


.conversion-content-two a {
    color: var(--color-light-blue) !important;
}
@media (min-width: 991.98px) {
    .conversion-content-two a:hover {
        color: rgb(91,177,255) !important;
    }
}


.page-template.contact .gfield--type-select .ginput_container_select .selection .select2-selection__arrow b {
    border-color: #383838 rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0) !important;
}
.page-template.contact .gfield--type-select .ginput_container_select .selection .select2-selection__rendered {
    color: #383838 !important;
}



























/* PRELAUNCH QA ITEMS */
.page-section--our-services::after {
    bottom: -1px;
}


.home .gform_wrapper {
    flex-direction: column;
    height: unset;
    min-height: 442px;
    backdrop-filter: blur(10px);
}


.van {
    z-index: -1;
}


.postscript-contact {
    z-index: 1;
}


.footer svg {
    width: calc(100vw * (1545 / 1600));
    height: calc(100vw * (152 / 1600));
}
.footer-col--right .footer-box .bottom-content {
    align-items: center;
}
.footer-box--heading {
    z-index: 1;
}


.footer .social-icons__icon.nextdoor a {
    font-size: 16px;
}
.be-icon-livechat-2::before {
    color: white;
}


@media (min-width: 992px) and (max-width: 1199px) {
    .header-overbar .social-icons__icon a {
        font-size: 15px;
    }
    .header-overbar .social-icons {
        gap: 10px;
    }
    .header-overbar {
        font-size: 12px;
    }
    
    
    .cta-item img {
        --icon-size: 80px;
        top: -40px;
    }
    .cta-item .cta-sublabel::after {
        width: 10px;
        height: 10px;
    }
    .cta-item .cta-sublabel {
        font-size: 16px;
    }
    .cta-item .cta-label {
        position: relative;
        top: 10px;
        font-size: 30px;
    }
    .cta-item svg {
        width: 250px;
    }
    .cta-item {
        width: 250px;
        height: 120px;
    }
    .page-section--our-services .col-lg-12 {
        margin-top: 0px;
    }
    
    
    .about-us-items {
        justify-content: flex-start;
    }
    .page-section--about-us .section-content-wrapper {
        max-width: 650px;
    }
    .page-section--about-us .image-wrapper img {
        width: 50%;
        height: 50%;
        top: 50%;
        left: 40px;
        position: relative;
        transform: translateY(-50%);
    }
    
    
    .callout-card h5 {
        font-size: 18px;
    }
    .callout-card p {
        font-size: 14px;
        line-height: 180%;
    }
    
    
    .deal-card .btn,
    .deal-card .deal-card-label {
        font-size: 16px;
    }
    .deal-card {
        gap: 12px;
        width: calc(50% - 170px);
        min-height: 279px;
        padding: 15px 10px;
    }
    
    
    .review {
        width: calc(100% - 20px);
    }
    
    
    .footer .social-icons {
        justify-content: center;
    }
    .footer-box {
        height: max-content;
    }
    
    
    .copyright .site-by {
        margin-top: 10px;
    }
    .copyright {
        font-size: 16px;
    }
}


.page-template-page-conversion .conversion-content-two .h5,
.page-template-page-conversion .conversion-content-two h2,
.page-template-page-conversion .conversion-content-two li,
.page-template-page-conversion .conversion-content-two p {
    color: white;
}


.Widget_isBubble__0YwmO.Widget_Widget__qwfID {
    width: 50px;
    height: 50px;
}
.main-navigation > li.has-dropdown::after {
    max-height: 55px;
}


@media (max-width: 991.98px) {
    .page-section--four {
        padding-bottom: 200px;
    }
    
    .page-section--six .home-gradient-box {
        display: none;
    }

    .page-section--six .image-wrapper img,
    .page-section--ethical-hvac .image-wrapper img {
        margin-top: 30px;
    }
}


@media (max-width: 991.98px) {
    .page-section .section-subheader {
        font-size: 18px;
    }
    .page-section .section-header h2 {
        font-size: 25px;
        line-height: 120%;
    }
}






/* POSTLAUNCH QA ITEMS */
.conversion-page-reviews .conversion-page-reviews__heading {
    color: white !important;
}
.gradient-box-light h2 {
    color: var(--color-dark-blue) !important;
}
.gradient-box-light ul > li {
    color: black !important;
}
.page-template-page-conversion .conversion-content-two .content-area .h5,
.page-template-page-conversion .conversion-content-two .content-area li,
.page-template-page-conversion .conversion-content-two .content-area p {
    color: black;
}
.page-template-page-conversion .conversion-content-two .content-area h2 {
    color: var(--color-dark-blue);
}
.uv-purifiers .content-area h5 {
    color: white;
}