:root {
    --bs-dark-rgb: 55, 55, 55;
    --bs-font-sans-serif: 'Lato', sans-serif;
    --bs-primary-color: #88BE24;
    --bs-primary-color-dark: #6A991E;
    --bs-primary-rgb: 136, 190, 36;
    --bs-link-color: var(--bs-body-color);
    --bs-link-hover-color: var(--bs-primary-color);
    --bs-border-color: #E4E4E4;
    --bs-border-highlight-color: #FFE3E3;
    --bs-body-color: #4E4E4E;
    --bs-body-color-light: #707070;
    --bs-breadcrumb-divider: '>';
    --bs-btn-bg: var(--bs-primary-color);
    --bs-btn-hover-bg: var(--bs-primary-color-dark);
    --bs-btn-color: #fff;
    --bs-btn-border-radius: 0.25rem;
    --vortex-color-bg-1: #f0f2f3;
    --vortex-color-bg-2: #F5F5F5;
    --vortex-gradient: radial-gradient(ellipse farthest-corner at 10% 25%, #fff, #e5e5e5);
}

/* Transitions */
.fade {
    opacity: 0;
}

.show {
    opacity: 1;
}

/* Modal */
.modal-open {
    overflow: hidden;
}

.modal-backdrop {
    --bs-backdrop-opacity: 0.7;
}

.modal-header {
    border-bottom: 0;
    align-items: start;
    position: relative;
}

.modal-header .close {
    background: none;
    border: 0;
    color: inherit;
    font-size: 36px;
    line-height: 40px;
    opacity: .5;
    padding: 0 2px;
    position: absolute;
    top: 12px;
    right: 12px;
    transition: opacity .2s ease-in-out;
}

.modal-header .close:hover {
    opacity: 1;
}

.modal-title {
    padding-right: 40px;
}

.modal-content {
    border: 0;
    --bs-modal-box-shadow: 0 0 1rem rgba(0, 0, 0, 0.85);
    box-shadow: var(--bs-modal-box-shadow);
    border-radius: calc(var(--bs-modal-border-radius));
}

.modal-footer {
    border-top: 0;
    border-bottom: 1rem solid var(--bs-primary-color);
    border-bottom-right-radius: var(--bs-modal-border-radius);
    border-bottom-left-radius: var(--bs-modal-border-radius);
    display: block;
}

.modal-footer::before {
    background-color: var(--bs-body-color);
    content: '';
    display: block;
    height: 1px;
    width: 100%;
    margin-bottom: 1rem;
}

.modal-footer .row {
    margin-right: calc(-0.5 * var(--bs-gutter-x));
    margin-left: calc(-0.5 * var(--bs-gutter-x));
}

.modal-footer__logo {
    background-color: #273E80;
}

.modal-footer__logo img {
    margin-top: 10%;
    margin-bottom: 6%;
    width: 100%;
}

/* Common styles */
body {
    word-break: break-word;
    overflow-x: hidden;
}

pre {
    background-color: var(--bs-light);
    max-width: 100%;
    padding: 1rem;
    border-radius: 0.25rem;
}

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

iframe {
    max-width: 100%;
}

.alignleft {
    display: inline;
    float: left;
    margin-right: 1.5em;
}

.alignright {
    display: inline;
    float: right;
    margin-left: 1.5em;
}

.aligncenter {
    clear: both;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption {
    margin-bottom: 1.5em;
    max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption .wp-caption-text {
    margin: 0.8075em 0;
}

.wp-caption-text {
    text-align: center;
}

.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
    word-wrap: normal !important
}

::selection {
    color: var(--bs-white);
    background-color: var(--bs-primary)
}

::-moz-selection {
    color: var(--bs-white);
    background-color: var(--bs-primary)
}


:focus {
    outline: none !important;
    outline: -webkit-focus-ring-color none !important;
    outline-color: -webkit-focus-ring-color none !important;
    outline-style: none !important;
    outline-width: 0 !important
}

.zi-1000 {
    z-index: 1000 !important
}

.zi-1020 {
    z-index: 1020 !important
}

.zi-1030 {
    z-index: 1030 !important
}

.zi-1040 {
    z-index: 1040 !important
}

.zi-1050 {
    z-index: 1050 !important
}

.zi-1060 {
    z-index: 1060 !important
}

.zi-1070 {
    z-index: 1070 !important
}

.zi-n1 {
    z-index: -1 !important
}
.woocommerce-loop-product__subtitle {
    text-transform: uppercase;
}
.btn {
    background-color: var(--bs-btn-bg);
    border: 1px solid var(--bs-btn-border-color, --bs-btn-bg);
    border-radius: var(--bs-btn-border-radius);
    color: var(--bs-btn-color);
    cursor: pointer;
    display: inline-block;
    font-size: 1.125rem;
    line-height: 1.25;
    max-width: 100%;
    padding: .6em .75em;
    text-align: center;
    text-decoration: none;
    transition: color 0.15s ease-in-out 0s, background-color 0.15s ease-in-out 0s, border-color 0.15s ease-in-out 0s, box-shadow 0.15s ease-in-out 0s;
    user-select: none;
    vertical-align: middle;
}

.btn:hover {
    background-color: var(--bs-btn-hover-bg);
    color: var(--bs-btn-hover-color, var(--bs-btn-color));
}

.btn--sm {
    font-size: .875rem;
}

.btn--lg {
    font-size: 1.25rem;
}

.btn--go {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
}

.btn--go::after {
    content: "\f105";
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    position: relative;
    top: 1px;
    margin-left: 2em;
}

.btn--lg.btn--go::after {
    margin-left: 4em;
}

.btn--outline {
    --bs-btn-bg: none;
    --bs-btn-hover-bg: #6c757d;
    --bs-btn-border-color: #A7A7A7;
    --bs-btn-color: #6c757d;
    --bs-btn-hover-color: #fff;
}

.btn--secondary {
    --bs-btn-bg: rgb(66, 95, 0, .6);
    --bs-btn-hover-bg: rgb(66, 95, 0, .9);
    --bs-btn-border-color: #fff;
    --bs-btn-color: #fff;
}

.btn__icon {
    font-size: 1.5em;
    margin-right: .5em;
}


.anon-link {
    color: inherit;
    text-decoration: none;
}

.anon-link:hover {
    text-decoration: underline;
}



h1,
h2,
h3,
h4,
h5,
.h1,
.h2,
.h3,
.h4,
.h5 {
    font-weight: 900;
}

h1,
.h1 {
    font-size: 2.5rem;
}

h2,
.h2 {
    font-size: 1.625rem;
}

h3,
.h3 {
    font-size: 1.375rem;
}

h4,
.h4 {
    font-size: 1.25rem;
}

h5,
.h5 {
    font-size: 1.125rem;
}


.py-6 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
}

.py-max {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
}

.pt-max {
    padding-top: 5rem !important;
}

.pb-max {
    padding-bottom: 5rem !important;
}

.mt-max {
    margin-top: 5rem !important;
}

.mb-max {
    margin-bottom: 5rem !important;
}

.bg-primary {
    background-color: var(--bs-primary-color);
}

.bg-light-gradient {
    background: var(--vortex-gradient);
}

.color-primary {
    color: var(--bs-primary-color);
}

.color-light {
    color: var(--bs-body-color-light) !important;
}

.full-width {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    overflow: hidden;
}

.full-bleed-mobile {
    box-shadow: 0 0 0 100vmax var(--bg-color);
    clip-path: inset(0 -100vmax);
}


.video-container {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}

.video-container iframe,
.video-container object,
.video-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.section {
    padding: 4rem 0;
}

.section__header {
    text-align: center;
}

.section__header :last-child {
    margin: 0;
}


.card__title {
    display: inline-block;
    margin: 0;
}

.card__title::after {
    background-color: var(--bs-primary-color);
    content: '';
    display: block;
    height: 2px;
    margin: .2em 0;
}

.card__subtitle {
    font-weight: 300;
    margin-bottom: .75em;
    text-transform: uppercase;
}

.card--clickable {
    position: relative;
}
.card--clickable .card__btn::before {
    content: '';
    display: block;
    inset: 0;
    position: absolute;
}

.card--app {
    background: var(--vortex-gradient);
}

.card--app .card__img {
    mix-blend-mode: multiply;
}

.card--app .card__body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1 1 auto;
    padding: var(--bs-card-spacer-y) 0 0;
}

.card--app .card__header {
    padding: 0 var(--bs-card-spacer-x);
    margin-bottom: -1.8rem;
}

.card--app .card__subtitle {
    margin-bottom: 0;
}

.card--app .card__btn {
    box-shadow: none !important;
    padding-top: 1rem;
    padding-bottom: 1rem;
    text-align: left;
}

.card--app .card__btn i {
    margin-left: auto;
}

.card--app-long .card__title {
    display: block;
}

.card--app-long .card__title::after {
    margin: .35em 0;
    width: 75%;
}

.card--app-long .card__subtitle {
    text-transform: none;
}

.swiper-mobile-only .swiper-wrapper {
    width: auto;
}

.swiper-button-prev::after,
.swiper-button-next::after {
    display: none;
}

.swiper-initialized .swiper-slide {
    height: auto !important;
}

.collapse.is-active i {
    transform: scaleY(-1);
}

/* Forms */
.form-control,
.wpcf7-form-control[type=text],
.wpcf7-form-control[type=number],
.wpcf7-form-control[type=email],
.wpcf7-textarea {
    display: block;
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0.375rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-control:focus,
.wpcf7-form-control[type=text]:focus,
.wpcf7-form-control[type=number]:focus,
.wpcf7-form-control[type=email]:focus,
.wpcf7-textarea:focus {
    color: #212529;
    background-color: #fff;
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

.wpcf7-response-output {
    position: relative;
    padding: 1rem 1rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: .25rem;
}

.wpcf7 form.invalid .wpcf7-response-output {
    color: #842029;
    background-color: #f8d7da;
    border-color: #f5c2c7;
}

.wpcf7-not-valid-tip {
    display: none;
}

.pretty-checkbox label {
    display: grid;
    grid-template-columns: 2em auto;
    gap: 0.5em;
}

.pretty-checkbox input[type="checkbox"] {
    -webkit-appearance: none;
    appearance: none;
    background-color: #fff;
    margin: 0;
    font: inherit;
    color: #818181;
    width: 1.1em;
    height: 1.1em;
    border: 0.15em solid currentColor;
    border-radius: 0.15em;
    display: grid;
    place-content: center;
}

.pretty-checkbox input[type="checkbox"]::before {
    background-color: CanvasText;
    content: "";
    width: .65em;
    height: .65em;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    box-shadow: inset 1em 1em var(--form-control-color);
    transform-origin: bottom left;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.pretty-checkbox input[type="checkbox"]:checked::before {
    transform: scale(1);
}

.pretty-checkbox input[type="checkbox"]:focus {
    outline: max(2px, 0.15em) solid currentColor;
    outline-offset: max(2px, 0.15em);
}

.form-group {
    margin-bottom: .5em;
}
.form-group p:last-child {
    margin-bottom: 0;
}

.wpcf7-form-control[type=text],
.wpcf7-form-control[type=number],
.wpcf7-form-control[type=email],
.wpcf7-textarea {
    border: 2px solid var(--bs-border-color);
    border-radius: 0;
}

.wpcf7-not-valid {
    border-color: #dc3545 !important;
    padding-right: calc(1.5em + .75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(.375em + .1875rem) center;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem);
}

.wpcf7-textarea {
    height: 5em;
}

.input-group {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 100%;
}

.input-group>.form-control {
    position: relative;
    flex: 1 1 auto;
    width: 1%;
    min-width: 0;
}

.input-group> :not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group> :not(:first-child) {
    margin-left: -1px;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.content-area li:not(:last-child) {
    margin-bottom: 0.5em;
}

#page {
    display: flex;
    flex-direction: column;
}

#content {
    flex: 1;
}

.top-button {
    background-color: #5e5e5e;
    right: 5%;
    bottom: 30px;
    opacity: 0;
    transition: opacity 1s;
}

.top-button.visible {
    opacity: 1;
}

/* Parallax Background */
.parallax {
    overflow: hidden;
    position: relative;
}
.parallax-bg {
    background-size: cover !important;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 160%;
    opacity: 0;
}
.parallax-overlay {
    position: relative;
}

/* Header */
.site-header {
    background-color: rgba(33, 33, 33, 0.9);
    border-bottom: 5px solid rgb(170, 216, 85);
    --bs-border-color: #555555;
    position: sticky;
    top: 0;
    z-index: 10;
    width: 100%;
}

.site-header.shrink .header__top {
    opacity: .9;
}

.site-header.shrink .header__logo .logo {
    height: 25px;
    margin: -1.9rem 0 .4rem;
}

.site-header.shrink .header__actions {
    margin-top: -2.55rem;
}

.site-header.hidden .header__top {
    margin-top: -100%;
}

.header__top {
    transition: all 1s ease-in-out;
}

.header__logo .logo {
    height: 40px;
    width: auto;
    transition: all .5s ease-in-out;
}

.header__actions {
    margin: 0 calc(var(--bs-gutter-x) * -.5);
    transition: all .5s ease-in-out;
}

.header__burger {
    background: none;
    border: 0 !important;
    color: var(--bs-primary-color) !important;
    font-size: 1.5rem;
}

.header__contact {
    font-size: 1.25rem;
}

.header__contact a {
    color: #fff;
}

.header__contact i {
    opacity: 1 !important;
}

.header__contact a span {
    display: none;
}

.header__contact a,
.header__burger {
    display: inline-block;
    width: 2.75rem;
    line-height: 2.75rem;
    text-align: center;
    padding: 0;
}

/* Nav */
.navbar {
    --bs-navbar-padding-y: 0;
}

.navbar ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.navbar-nav {
    --bs-border-color: rgb(180, 180, 180);
}

.navbar-nav::after {
    content: '';
    display: block;
    background-color: var(--bs-border-color);
    height: 1px;
    margin: 0 calc(var(--bs-offcanvas-padding-x) * -1);
}

.navbar-nav>.nav-item {
    border-bottom: 1px solid var(--bs-border-color);
}

.navbar-nav>.nav-item:last-child {
    border-bottom: 0;
}

.navbar-nav .nav-link {
    color: inherit;
    display: block;
    font-size: 1.125rem;
    font-weight: 700;
    padding-top: 1rem;
    padding-bottom: 1rem;
    text-decoration: none;
}

.navbar-nav .dropdown-icon {
    margin-left: .4em;
    transition: transform .2s ease-in-out;
    vertical-align: middle;
}

.navbar-nav .nav-link[aria-expanded=true] .dropdown-icon {
    transform: rotate(-90deg);
}

.navbar-nav .dropdown-menu.depth_0 {
    background-color: #fff;
    border-left: 1px solid var(--bs-border-color);
    border-radius: 0;
    margin: 0 0 1rem 0.5rem;
    padding: 0 0 0 1rem;
}

.navbar-nav .dropdown-menu {
    border: 0;
    display: none;
    padding-top: 0;
}

.navbar-nav .dropdown-menu .sub-menu {
    margin-left: 1rem;
}

.navbar-nav .dropdown-menu a {
    color: inherit;
    display: inline-block;
    font-size: 0.9rem;
    padding: .4em 0;
    text-decoration: none;
}

.mega-menu .menu>.menu-item>a {
    font-weight: 700;
}


.header__contact--mobile a {
    color: inherit;
    display: inline-block;
    padding: .2rem 0;
}

.header__search .btn {
    border-color: #ced4da;
}

/* Footer */
.site-footer {
    --bs-border-color: #555555;
}

.site-footer ul {
    padding: 0;
    list-style: none;
    margin-bottom: 0
}

.footer__top .contact-info a {
    color: #fff;
    font-size: 1rem;
}

.footer__top .contact-info i {
    opacity: .4;
}

.footer__logo {
    max-width: 90%;
    text-decoration: none;
}

.footer__logo img {
    height: 30px !important;
    width: auto;
}

.footer__logo span {
    color: #fff;
    font-size: .9rem;
    font-weight: 700;
    line-height: 1.2;
}


.footer__body {
    color: rgb(160, 160, 160);
    --bs-link-color: rgb(160, 160, 160);
    --bs-link-hover-color: #fff;
}

.footer__body h3 {
    color: rgb(205, 205, 205);
}

.footer__body a {
    text-decoration: none;
}

.footer__body li {
    margin-bottom: .2em;
}

.footer__body .social-links {
    margin: 0 -.2rem;
}

.footer__body .social-links li {
    display: inline-block;
}

.footer__body .social-links a {
    display: inline-block;
    line-height: 2rem;
    width: 2rem;
    text-align: center;
}

.footer__body .social-links i {
    font-size: 1.5rem;
}

.footer__body .footer__widget__title {
    border-top: 1px solid var(--bs-border-color);
    cursor: pointer;
}

.footer__body .footer__widget__title i {
    transition: transform .2s ease-in-out;
    transform-origin: 50% 50%;
}

.footer__body .footer__widget__title[aria-expanded=true] {
    color: #fff;
}

.footer__body .footer__widget__title+div {
    display: none;
    position: relative;
    top: -1.5rem;
    padding-top: .5rem;
}

.footer__body .footer__widget__title[aria-expanded=true]+div {
    --bs-link-color: #fff;
}

.footer__body .footer__widget a {
    display: inline-block;
    padding: .1rem;
}

.footer__info,
.footer__info a {
    color: #555;
    font-size: .85rem;
    text-decoration: none;
}

.footer__info a:hover {
    color: #333;
}

.footer__links {
    max-width: 90%;
}

.footer__links li::before {
    content: '\2022';
    font-size: .7em;
    margin: 0 .4em;
    position: relative;
    top: -2px;
}

.footer__links li:first-child::before {
    content: '';
}



/* Home page */
.home-hero .card__img {
    mix-blend-mode: multiply;
}

.home-hero .card__btn {
    width: 100%;
}

.home-hero .card--featured {
    --bg-color: var(--vortex-color-bg-1);
    background-color: var(--bg-color);
}

.home-hero .card--featured .card__body {
    padding-left: calc(var(--bs-gutter-x) * .5);
    padding-right: calc(var(--bs-gutter-x) * .5);
}

.home-hero .card--featured .card__btn {
    width: calc(50% - var(--bs-gutter-x) * .5);
}
.home-hero .card--featured .card__btn::after {
    margin-left: auto;
}

.view-all {
    background-color: none;
}

.view-all__link {
    color: inherit;
    display: block;
    margin-top: .1em;
    font-size: 1rem;
    font-weight: 300;
}

.view-all__icon {
    color: var(--bs-primary-color);
    font-size: 3rem;
}

.tagline-breakout__logo {
    height: 40px;
    width: auto;
}





.home-video {
    background: var(--vortex-gradient);
}

.home-video .video-container {
    border: 3px solid #fff;
}

.calculator-breakout {
    background-size: cover;
}

.about-us__logos .logo:nth-child(n+2) {
    margin-left: 1rem;
}

.contact-us__img {
    padding-top: 70%;
    width: 100%;
}
/*
// make parallax effect more subtle 
.contact-us__img .parallax-bg {
    height: 120%;
}
*/

.contact-us .contact-info {
    font-size: 1.375rem;
    font-weight: 900;
}


.contact-info {
    list-style: none;
    padding: 0;
}

.contact-info a {
    text-decoration: none;
}

.contact-info span {
    margin-left: .4em;
}

.contact-info i {
    opacity: .6;
    transition: opacity .2s ease-out;
}

.contact-info a:hover i {
    opacity: 1;
}

.contact-us .contact-info li {
    margin: .3em 0;
}

.contact-us .contact-info a {
    color: #fff;
}

.logo-swiper {
    position: relative;
}

.logo-swiper .swiper-wrapper {
    display: flex;
    align-items: center;
}

.logo-swiper .swiper .swiper-slide {
    margin: 0 1rem;
    max-width: 60%;
    opacity: .3;
    width: auto;
    user-select: none;
}

.logo-swiper .swiper .swiper-slide-active {
    opacity: 1;
}

.logo-swiper .swiper-slide img {
    max-height: 45px;
    width: auto;
}
.logo-swiper .swiper-button-prev {
    left: -10px;
    transform: translate3D(-100%, -50%, 0);
}
.logo-swiper .swiper-button-next {
    right: -10px;
    transform: translate3D(100%, -50%, 0);
}

/* Pages */
.entry-header {
    background-color: var(--bs-primary-color-dark);
}

.entry-header__title br,
.entry-header__subtitle br {
    display: none;
}

.entry-header__title {
    line-height: .9;
}

.entry-header__subtitle {
    font-size: 1.5rem;
}


.viewed-products {
    position: relative;
}

.viewed-products .swiper {
    margin-right: calc(-0.5 * var(--bs-gutter-x));
    margin-left: calc(-0.5 * var(--bs-gutter-x));
}

.viewed-products .swiper-initialized {
    margin: 0 .2rem !important;
}

.viewed-products .swiper-wrapper {
    justify-content: center;
    margin-left: 0;
    margin-right: 0;
    width: auto;
}

.viewed-products .swiper-initialized .swiper-wrapper {
    justify-content: start;

}


.swiper-button-prev,
.swiper-button-next {
    color: #D4D4D4;
    display: none;
    font-weight: 700;
    font-size: 2.5rem;
    height: auto;
    width: auto;
    margin: 0;
    transform: translateY(-50%);
    z-index: 11;
}

.swiper-initialized .swiper-button-prev,
.swiper-initialized .swiper-button-next,
.swiper-initialized~.swiper-button-prev,
.swiper-initialized~.swiper-button-next {
    display: block;
}

.swiper .swiper-button-prev:hover,
.swiper .swiper-button-next:hover {
    color: var(--bs-primary-color) !important;
}


.viewed-products .viewed-products__prev {
    left: calc(-0.5 * var(--bs-gutter-x));
}

.viewed-products .viewed-products__next {
    right: calc(-0.5 * var(--bs-gutter-x));
}




.viewed-products .product {
    background-color: #fff;
    height: auto;
}


/* Product pages */
.woocommerce-loop-product__subtitle br {
    display: none;
}
.woocommerce-loop-product a {
    color: inherit;
    text-decoration: none;
}

.wc-breadcrumb .breadcrumb {
    font-size: .85rem;
    list-style: none;
    padding: 0;
}

.wc-breadcrumb .breadcrumb__item {
    display: inline-block;
}

.wc-breadcrumb .breadcrumb__item:not(:last-child)::after {
    content: ">";
    margin: 0 .25rem;
}

.wc-breadcrumb span {
    color: #999999;
}

.wc-breadcrumb a {
    text-decoration: none;
}

.specs-table-wrapper {
    overflow-x: auto;
    margin: 1rem 0;
}

.specs-table {
    border-collapse: collapse;
    font-size: .9rem;
    line-height: 1.2;
    min-width: 100%;
    text-align: center;
    white-space: normal;
}

.specs-table th,
.specs-table td {
    border: 0;
    padding: 1em .6em;
    vertical-align: middle;
    background: #fff;
}

.specs-table th {
    background: #1d589e;
    color: #fff;
}

.specs-table td {
    white-space: nowrap;
}

.specs-table tbody:first-of-type tr:nth-child(2n+1) td,
.specs-table tbody:nth-of-type(n+2) tr:nth-child(2n) td {
    background: #E8F1D5;
}

.specs-table th:first-child,
.specs-table td:first-child {
    font-weight: 700;
    text-align: right;
    width: 27.5%;
    min-width: 9.375rem;
    position: -webkit-sticky;
    position: sticky;
    left: 0;
    z-index: 2;
    white-space: normal;
}

.specs-table td.specs-table__label {
    background: none !important;
    text-align: left;
}

.specification_table_note {
	font-size: 0.8rem;
	font-style: italic;
}

.gallery__image {
    border: 2px solid var(--bs-border-color);
}

.gallery .main-image {
    border-color: var(--bs-border-highlight-color);
}
.gallery .main-image a {
    display: block;
    text-align: center;
}



.enquiry-form__quantity .wpcf7-number {
    font-size: 1.8em;
    font-weight: 700;
    line-height: 1;
    padding-top: .1em;
    padding-bottom: .1em;
    width: 3em;
}

.enquiry-form__submit .btn {
    padding-top: 0.75em;
    padding-bottom: 0.75em;
    width: 100%;
}

.enquiry-form__submit .btn::after {
    margin-left: auto;
}

.enquiry-form__consent {
    display: grid;
    gap: .25em;
}

.enquiry-form__consent .wpcf7-list-item {
    margin-left: 0;
}

.enquiry-form__consent .wpcf7-form-control {
    background-position: right 0 top;
    width: 100%;
    display: block;
    padding-right: 1rem !important;
}



.enquiry-form__consent label {
    align-items: center;
    font-size: .75rem;
    line-height: 1.2;
}

.enquiry-form__consent input[type="checkbox"] {
    width: 2em;
    height: 2em;
}

.enquiry-form__consent input[type="checkbox"]::before {
    width: .85em;
    height: .85em;
}

.modal .enquiry-form__consent label {
    font-size: .65rem;
}

.product-cats {
    position: relative;
}
.product-cats::after {
    background-color: #fff;
    content: '';
    display: block;
    height: 3px;
    width: 100%;
    position: absolute;
    bottom: 1.5rem;
    left: 0;
}

/* Contact page */
.contact-form .enquiry-form__consent {
    flex-basis: 70%;
}

.contact-form .enquiry-form__submit {
    flex-basis: 30%;
}


/* Search results */
.relevanssi-query-term {
    color: var(--bs-primary-color);
    font-weight: 700;
}

/* Heat Load Calculator */
.hlc {
    max-width: 516px;
    margin-left: auto;
    margin-right: auto;
}
.hlc input[type=number] {
    border-radius: 0;
    padding: 0.75rem 0.75rem;
    text-align: center;
}
.hlc label {
    line-height: 1.2;
}
.hlc .heading {
    display: flex;
}
.hlc .heading__icon {
    font-size: 2rem;
    width: 2.8rem;
    text-align: right;
}
.hlc__dheat-note {
    color: #dc3545;
    max-width: 296px;
    margin-left: auto;
}
.hlc__table {
    background-color: #FBFBFB;
    border: 1px solid var(--bs-border-color);
    font-size: .9rem;
    padding: 1rem;
}
.hlc__table table {
    text-align: center;
    width: 100%;
}
.hlc__table th,
.hlc__table td {
    padding: .2rem 0;
}
.hlc .btn--go {
    font-size: 1.4rem;
    padding: .8em 1em;
}
.hlc .btn--go::after {
    margin-left: 1em;
}

.grecaptcha-badge {
	display: none;
	}

.page-id-19 .grecaptcha-badge {
	display: block;
}






/* BREAK POINTS BELOW */



/* break point: Small sm */
@media (min-width: 576px) {
    .logo-swiper .swiper-slide img {
        max-height: none;
    }
}

/* break point: Medium md */
@media (min-width: 768px) {
    .modal {
        --bs-modal-width: 708px;
    }

    .swiper-mobile-only .col {
        height: auto;
    }

    .swiper-mobile-only .row-cols-md-2 .col {
        width: 50%;
    }

    .logo-swiper .swiper::before,
    .logo-swiper .swiper::after {
        content: '';
        display: block;
        width: 15%;
        height: 100%;
        position: absolute;
        top: 0;
        z-index: 10;
    }

    .logo-swiper .swiper::before {
        background: linear-gradient(to left, rgba(255, 255, 255, 0), rgb(255, 255, 255) 95%);
        left: 0;
    }

    .logo-swiper .swiper::after {
        background: linear-gradient(to right, rgba(255, 255, 255, 0), rgb(255, 255, 255) 95%);
        right: 0;
    }

    .logo-swiper .swiper .swiper-slide {
        opacity: 1;
    }

    .two-cols-text {
        column-count: 2;
        column-gap: var(--bs-gutter-x);
    }
    
}

/* break point: Large lg */
@media (min-width: 992px) {
.right-hero-grid img{padding: 60px 0 0 0}
.first-hero-row img.card__img.order-0.order-lg-2 {
    position: relative;
    top: -75px;
}

    .py-lg-max {
        padding-top: 5rem !important;
        padding-bottom: 5rem !important;
    }

    .pt-lg-max {
        padding-top: 5rem !important;
    }

    .pb-lg-max {
        padding-bottom: 5rem !important;
    }

    .mt-lg-max {
        margin-top: 5rem !important;
    }

    .mb-lg-max {
        margin-bottom: 5rem !important;
    }

    .site-header {
        position: static;
    }

    .site-header .container {
        position: relative;
    }

    .header__logo .logo {
        height: 53px;
    }

    .header__actions {
        margin: 0;
    }

    .navbar .navbar-nav {
        position: relative;
    }

    .navbar-nav>.nav-item {
        border: 0;
    }

    .navbar-nav>.nav-item:not(:last-child) {
        margin-right: 2em;
    }

    .navbar-nav .nav-link {
        color: #fff;
        font-size: 1.125rem;
        font-weight: 900;

    }

    .navbar-nav .nav-link:hover {
        color: var(--bs-primary-color);
    }

    .navbar-nav .dropdown-icon {
        margin-left: .2em;
    }

    .navbar-nav .dropdown {
        position: relative;
    }

    .navbar-nav .dropdown.hover .nav-link {
        color: var(--bs-link-hover-color);
    }

    .navbar-nav .dropdown.hover .dropdown-icon {
        transform: rotate(-90deg);
    }

    .navbar-nav .dropdown.hover .dropdown-menu {
        display: block;
    }

    .navbar-nav .dropdown-menu a {
        font-size: 1rem;
    }

    .navbar-nav .dropdown-menu a:hover {
        text-decoration: underline;
    }

    .navbar-nav .dropdown-menu.depth_0 {
        border: 0;
        border-bottom: 1rem solid var(--bs-primary-color);
        border-radius: var(--bs-dropdown-border-radius);
        box-shadow: 0 5px 10px 0 rgba(0, 0, 0, .5);
        color: var(--bs-body-color);
        margin: 0;
        padding: calc(var(--bs-gutter-x) * .75) var(--bs-gutter-x) !important;
        white-space: nowrap;
        position: absolute;
        left: 0;
        top: 100%;
    }

    .dropdown.has-mega-menu {
        position: static;
    }

    .mega-menu {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: 1fr;
        left: 0;
        width: auto;
    }

    .mega-menu ul {
        list-style: none;
        padding: 0;
        position: static !important;
        border: 0;
        display: block;
    }

    .mega-menu .menu>.menu-item {
        margin-bottom: 1rem;
    }

    .mega-menu .menu>.menu-item>a {
        font-size: 1.375rem;
        font-weight: 900;
        padding: 0;
    }

    .mega-menu .sub-menu a {
        display: inline-block;
        padding: .18em 0;
    }

    .header__contact a {
        display: flex;
        flex-direction: row-reverse;
        align-items: center;
        font-size: 1.125rem;
        margin-bottom: .4em;
        width: auto;
        line-height: inherit;
    }

    .header__contact a:hover {
        color: var(--bs-primary-color);
    }

    .header__contact a span {
        display: inline;
    }

    .header__contact i {
        opacity: 1;
        margin-left: 0.4em;
        margin-right: 0;
        transform: scaleX(-1);
    }

    .header__search {
        margin: 0 -.75rem .5rem;
        position: relative;
    }

    .header__search input,
    .header__search .btn {
        background: none !important;
        border: 0 !important;
        box-shadow: none !important;
        border-radius: 0;
        color: #fff !important;
    }

    .header__search input {
        border-bottom: 2px solid var(--bs-border-color) !important;
        font-size: 1.125rem;
        padding: .375rem .5rem .25rem !important;
        width: 250px !important;
    }

    .header__search input:focus {
        border-color: #fff !important;
    }

    .header__search .btn {
        position: absolute;
        right: -0.25rem;
        top: 0;
        z-index: 20;
        padding-bottom: .25rem !important;
    }

    .header__search .btn:hover {
        color: var(--bs-primary-color) !important;
    }


    .footer__top .contact-info a {
        font-size: inherit;
    }

    .footer__logo img {
        height: 38px !important;
    }

    .footer__logo span {
        font-size: 1.25rem;
        line-height: 1.1;
    }

    .footer__body {
        border-top: 1px solid var(--bs-border-color);
    }

    .footer__body .footer__widget__title {
        border-top: 0;
        cursor: default;
    }

    .footer__body .footer__widget__title+div {
        display: block !important;
        position: static;
    }

    .footer__body .footer__widget a {
        padding: 0;
    }

    .footer__body .col-lg-6 .menu {
        column-count: 2;
        column-gap: var(--bs-gutter-x);
    }

    .section__header {
        max-width: 80%;
        margin-left: auto;
        margin-right: auto;
    }

    .full-bleed-mobile {
        box-shadow: none;
    }

    .home-hero .card {
        background-color: var(--vortex-color-bg-1);
    }

    .home-hero .card__footer {
        flex-grow: 1;
    }

    .home-hero .card__img {
        margin-top: -3rem;
    }

    .home-hero .card--featured .card__img {
        margin-top: -4rem;
    }

    .home-hero .card__btn,
    .home-hero .card--featured .card__btn {
        display: inline-flex;
        width: auto;
        position: relative;
        z-index: 2;
    }

    .home-hero .card--featured .card__btn::after {
        margin-left: 2em;
    }

    .view-all {
        background-color: var(--vortex-color-bg-1);
    }

    .view-all__link {
        display: inline-block;
        font-size: inherit;
        font-weight: inherit;
        text-decoration: none;
    }

    .logo-swiper .swiper .swiper-slide {
        margin: 0 2rem;
    }

    .swiper-mobile-only .row-cols-lg-4 .col {
        width: 25%;
    }

    .contact-us__img {
        padding-top: 0;
        position: absolute;
        left: 50%;
        top: 0;
        width: 50%;
        height: 100%;
    }

    .entry-header .row {
        --bs-gutter-x: 2.2rem;
        flex-wrap: nowrap;
    }

    .entry-header .col-auto:first-child {
        max-width: 42%;
    }
    .entry-header .col-auto:last-child {
        flex-shrink: 1;
    }

    .entry-header__title {
        padding-right: var(--bs-gutter-x);
        position: relative;
    }

    .entry-header__title::after {
        content: '';
        background-color: rgba(255, 255, 255, .4);
        display: block;
        width: 1px;
        height: 70%;
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
    }

    .entry-header__title br,
    .entry-header__subtitle br {
        display: block;
    }

    .entry-header__subtitle {
        font-size: 2rem;
    }

    .wc-breadcrumb .breadcrumb {
        font-size: inherit;
    }

    .product .product__title,
    .product .product__summary {
        float: right;
    }

    .product .product__gallery {
        float: left;
    }

    .viewed-products .swiper-initialized {
        margin: 0 2rem !important;
    }

    .viewed-products .viewed-products__prev,
    .viewed-products .viewed-products__next {
        font-size: 4.5rem;
    }

    .about-more__logo {
        display: grid;
        place-content: end start;
        height: 83px;
    }

    .hlc {
        max-width: none;
    }
    .hlc .heading__icon {
        font-size: 2.4rem;
    }
    .hlc__temp-rise .heading__title {
        white-space: nowrap;
    }
}


/* break point: XLarge xl */
@media (min-width: 1200px) {
    h1,
    .h1 {
        font-size: 3.5rem;
    }

    h2,
    .h2 {
        font-size: 2.5rem;
    }

    h3,
    .h3 {
        font-size: 2rem;
    }

    h4,
    .h4 {
        font-size: 1.5rem;
    }

    h5,
    .h5 {
        font-size: 1.275rem;
    }

    .navbar-nav>.nav-item {
        margin-right: 3.5em;
    }

    .header__search input {
        width: 300px !important;
    }

    .entry-header__title {
        font-size: 2.5rem;
    }

    .entry-header__subtitle {
        font-size: 2rem;
    }

    .modal-header,
    .modal-body,
    .modal-footer {
        padding-left: calc(var(--bs-gutter-x) * 1.5);
        padding-right: calc(var(--bs-gutter-x) * 1.5);
    }

    .enquiry-form__submit {
        width: 40%;
    }

    .enquiry-form__consent {
        padding-left: 1rem;
        width: 60%;
    }

}

/* break point: XXLarge xxl */
@media (min-width: 1400px) {
    .modal-xl {
        width: 1340px;
    }

    .home-contact-us {
        min-height: max(500px, 20vw) !important;
    }
    .entry-header__title {
        font-size: 3.5rem;
    }

    .entry-header__subtitle {
        font-size: 2.5rem;
    }

    .contact-form .enquiry-form__submit {
        flex-basis: 40%;
    }

    .contact-form .enquiry-form__consent {
        flex-basis: 60%;
    }
}


@media (max-width: 991.8px) {
    .offcanvas {
        --bs-offcanvas-padding-x: 1rem;
        --bs-offcanvas-padding-y: 1rem;
        position: fixed;
        bottom: 0;
        z-index: 1045;
        display: flex;
        flex-direction: column;
        max-width: 100%;
        color: var(--bs-body-color);
        visibility: hidden;
        background-color: #fff;
        background-clip: padding-box;
        outline: 0;
        transition: transform 0.3s ease-in-out;
        width: 400px;
        box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
        top: 0;
        left: 0;
        width: 400px;
        transform: translateX(-100%);
    }

    .offcanvas.showing,
    .offcanvas.show:not(.hiding) {
        transform: none;
    }

    .offcanvas.showing,
    .offcanvas.hiding,
    .offcanvas.show {
        visibility: visible;
    }

    .offcanvas-backdrop {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 1040;
        width: 100vw;
        height: 100vh;
        background-color: #000;
        opacity: .5;
    }

    .offcanvas__header {
        color: #fff;
        border-bottom: 5px solid var(--bs-primary-color);
        padding: var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);
    }

    .offcanvas__header .btn-close {
        background: none;
        border: 0;
        color: #fff;
        font-size: 1.5rem;
    }

    .offcanvas__body {
        flex-grow: 1;
        padding: 0 var(--bs-offcanvas-padding-x) var(--bs-offcanvas-padding-y);
        overflow-y: auto;
    }

    .entry-header__subtitle {
        max-width: 600px;
        margin-left: auto;
        margin-right: auto;
    }

}

@media (max-width: 767.8px) {
    .swiper-mobile-only {
        margin-right: calc(-.5 * var(--bs-gutter-x)) !important;
        margin-left: calc(-.5 * var(--bs-gutter-x)) !important;
    }

    .swiper-mobile-only .swiper-wrapper {
        flex-wrap: nowrap;
        margin-left: 0;
        margin-right: 0;
    }

    .swiper-mobile-only .swiper-slide {
        opacity: .50;
        width: 100%;
    }

    .swiper-mobile-only .swiper-slide-active {
        opacity: 1;
    }

    .swiper-mobile-only .row-cols-lg-4 .swiper-slide {
        width: 100%;
    }

    .logo-swiper .swiper {
        overflow: visible;
    }
    .logo-swiper .swiper-button-prev,
    .logo-swiper .swiper-button-next {
        display: none;
    }    

    .card--app .card__title {
        font-size: 1.625rem;
    }

    .product__details .collapse-container {
        border-top: 1px solid var(--bs-border-color);
        border-bottom: 1px solid var(--bs-border-color);
        margin: -1px 0 0;
    }

    .product__details .collapse {
        background-color: var(--vortex-color-bg-2);
        padding: 1rem;
    }

    .product__details .collapse-content {
        display: none;
        padding: 1rem 0;
    }

    .product__details .collapse-content h3 {
        font-size: 1.125rem;
    }

    .specs-table td:first-child::after {
        background-color: #ccc;
        content: '';
        display: block;
        width: 1px;
        height: 100%;
        position: absolute;
        top: 0;
        right: 0;
        z-index: 10;
    }
}


@media (max-width: 379px) {
    html {
        font-size: 100%;
    }
}