﻿body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-display: swap;
}

.b {
    font-weight: bold;
}

.b100 {
    font-weight: 100;
}

.b200 {
    font-weight: 200;
}

.b300 {
    font-weight: 300;
}

.b400 {
    font-weight: 400;
}

.b500 {
    font-weight: 500;
}

.b600 {
    font-weight: 600;
}

a {
    color: crimson;
}

a:hover{
    text-decoration: none;
}

.navbar-brand {
    padding: 10px;
}

.FieldInvalid {
    background-color: #f5e7e7 !important;
}

.discrete-red {
    color: #d3222a;
}

.contact-icon {
    margin-top: 15px;
    margin-right: 11px;
}

.nice-btn {
    background-color: #fff;
    border-color: #d3222a;
    border-radius: 10px;
    border: 1px solid #d3222a;
    color: #d3222a;
    font-weight: 400;
    font-size: 18px;
}

.nice-btn-red {
    background-color: #d3222a;
    border-color: #d3222a;
    border-radius: 10px;
    border: 1px solid #d3222a;
    color: #fff;
    font-weight: 400;
    font-size: 18px;
}

    .nice-btn-red:hover, .nice-btn-red:focus {
        background-color: #fff;
        color: #d3222a;
    }

h1, h2, h3, h4, h5, h6 {
    font-weight: 100;
}

.title {
    font-weight: 100;
    font-size: 44px;
}

.intro-para {
    font-size: 24px;
    line-height: 30px;
}

.animate-infinite {
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-duration: 2s;
    -moz-animation-iteration-count: infinite;
    -moz-animation-duration: 2s;
}

/* On screens that are 767px or less */
@media screen and (max-width: 767px) {
    .title {
        font-size: 32px;
    }

    .intro-para {
        font-size: 18px;
        line-height: 24px;
    }
}

/* On screens that are 400px or less */
@media screen and (max-width: 400px) {
    .title {
        font-size: 24px;
    }

    .intro-para {
        font-size: 16px;
        line-height: 20px;
    }
}

/*******************************************************/
/****************** PAGE TITLE SECTION *****************/
/*******************************************************/

.page-title-section {
    position: relative;
    min-height: 250px;
    width: 100%;
    padding-top: 49px;
    background-image: url(/images/redesign/bg/case-study-header.jpg);
    background-position: bottom center;
    background-size: auto;
}

    .page-title-section h1 {
        font-size: 80px;
        color: #fff;
    }

/* On screens that are 800px or less */
@media screen and (max-width: 800px) {

    .page-title-section h1 {
        font-size: 60px;
        padding-bottom: 30px;
    }
}

/* On screens that are 500px or less */
@media screen and (max-width: 500px) {
    .page-title-section {
        min-height: 200px;
    }
}

/* On screens that are 400px or less */
@media screen and (max-width: 400px) {
    .page-title-section h1 {
        font-size: 50px;
    }
}

/*******************************************************/
/********************* CARD STYLES *********************/
/*******************************************************/

.card {
    background: #fff;
    border-radius: 2px;
    display: inline-block;
    margin: 1rem;
    position: relative;
}

.card-1 {
    box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
    transition: all 0.3s cubic-bezier(.25,.8,.25,1);
}

    .card-1:hover {
        box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
    }

.card-2 {
    box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
}

.card-3 {
    box-shadow: 0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23);
}

.card-4 {
    box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
}

.card-5 {
    box-shadow: 0 19px 38px rgba(0,0,0,0.30), 0 15px 12px rgba(0,0,0,0.22);
}

/*******************************************************/
/******************** COMMON SECTIONS ******************/
/*******************************************************/

.title-section {
    width: 100%;
    /*background-color: #808080;*/
    color: #fff;
    background-color: #be4040;
    padding-top: 20px;
    padding-bottom: 20px;

    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+100&0.65+0,0+100;Neutral+Density */
    background: -moz-linear-gradient(45deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(45deg, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(45deg, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a6000000', endColorstr='#00000000',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
}

.gallery-strip {
    background-color: #797878;
    padding-top: 20px;
    padding-bottom: 20px;
}

.contact-us-section {
    min-height: 700px;
    width: 100%;
    position: relative;
    background: url('/images/redesign/bg/bg-contact-us.jpg');
}

    .contact-us-section .contact-us-window {
        background-color: #fff;
        border-radius: 10px;
        margin: 20px;
        padding: 20px;
        margin-bottom: 50px;
        min-height: 350px;
        margin-top: 50px;
    }

    .clients-include {
        letter-spacing: 5px;
        margin: auto;
        color: lightgray;
        font-size: 14px;
        margin-bottom: -30px;
        z-index: 99999;
    }

/* On screens that are 500px or less */
@media screen and (max-width: 500px) {

    .clients-include {
        font-size: 10px;
        letter-spacing: 3px;
    }

    .contact-us-section .container {
        padding-left: 0px;
        padding-right: 0px;
    }

    .contact-us-section .contact-us-window {
        margin: 10px;
        padding: 15px;
        margin-top: 20px;
        padding-top: 20px;
    }
}

/*******************************************************/
/********************** BLOG STYLE *********************/
/*******************************************************/

.blog-section {
    font-family: 'Plus Jakarta Sans', sans-serif;
    width: 100%;
    position: relative;
    background-color: #fff;
    padding-top: 10px;
    padding-bottom: 50px;
    overflow: visible;
    min-height: 500px;
    font-display: swap;
}

    .blog-section .blog-card {
        min-height: 400px;
        background-color: #fff;
    }

    .blog-section .blog-img {
        width: 100%;
        height: 150px;
        background-position: 50% 50%;
        background-repeat: no-repeat;
        background-size: cover;
        object-fit: cover;
    }

    .blog-section .blog-title {
        font-weight: 500;
        margin-top: 30px;
        overflow: hidden;
        text-overflow: ellipsis;
        line-height: 24px;
    }

    .blog-section .blog-content {
        font-size: 13px;
        line-height: 22px;
        overflow: hidden;
        text-overflow: ellipsis;
        color: gray;
        font-weight: 100;
    }

    .blog-section .blog-content-wrapper {
        max-height: 200px;
        overflow-y: hidden;
    }

    .blog-section .blog-btn {
        background-color: darkgray;
        border-color: darkgray;
        border-radius: 5px;
        border: 1px solid darkgray;
        color: #fff;
        font-weight: 400;
        font-size: 12px;
    }

        .blog-section .blog-btn:hover, .blog-btn:focus {
            background-color: #fff;
            color: #d3222a;
        }

/*******************************************************/
/********************* FOOTER STYLE ********************/
/*******************************************************/

#bottom {
    background: #414141;
    font-size: 14px;
    color: #d7d7d7;
}

    #bottom a {
        color: #d7d7d7;
        text-decoration: none;
    }

    #bottom h3 {
        margin-top: 0px;
        margin-bottom: 10px;
        padding-top: 30px;
        text-transform: uppercase;
        font-size: 22px;

        color: #fff;
    }

    #bottom ul {
        list-style: none;
        padding: 0;
        margin: 0;
    }

        #bottom ul li {
            display: block;
            padding: 5px 0;
        }

            #bottom ul li a {
                color: #d7d7d7;
            }

                #bottom ul li a:hover {
                    color: crimson;
                }

    #bottom .widget {
        margin-bottom: 0;
    }

/*************************************************************************/
/********************** PROFILES CARDS SECTION STYLE *********************/
/*************************************************************************/

/** this section is common accross multiple pages - thermaskirt-e & thermaskirt overview pages **/

.profiles-section {
    min-height: 500px;
    width: 100%;
    position: relative;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#e2e2e2+0,ffffff+45,ffffff+45,e8e8e8+100 */
    background: rgb(226,226,226); /* Old browsers */
    background: -moz-linear-gradient(left, rgba(226,226,226,1) 0%, rgba(255,255,255,1) 45%, rgba(255,255,255,1) 45%, rgba(232,232,232,1) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(left, rgba(226,226,226,1) 0%,rgba(255,255,255,1) 45%,rgba(255,255,255,1) 45%,rgba(232,232,232,1) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, rgba(226,226,226,1) 0%,rgba(255,255,255,1) 45%,rgba(255,255,255,1) 45%,rgba(232,232,232,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e2e2e2', endColorstr='#e8e8e8',GradientType=1 ); /* IE6-9 */
    padding-top: 50px;
    padding-bottom: 50px;
}

    .profiles-section .profile-parent {
        padding: 10px;
        margin-bottom: 30px;
    }

    .profiles-section .profile-card {
        min-height: 300px;
        padding: 20px;
        background-color: #fff;
    }

    .profiles-section .profile-text {
        width: 80%;
        height: auto;
        margin: auto;
        margin-top: 30px;
    }

    .profiles-section .profile-image {
        max-width: 400px;
        height: auto;
        margin: auto;
        margin-bottom: 10px;
        margin-top: 10px;
        padding-right: 50px;
    }

    .profiles-section .profile-bullets {
        font-size: 20px;
        max-width: 400px;
        margin: auto;
    }

        .profiles-section .profile-bullets .profile-bullet {
            margin-bottom: 15px;
            position: relative;
            font-weight: 300;
            margin-left: 20px;
        }

    .profiles-section .profile-heat-scale {
        max-width: 200px;
        width: 100%;
        height: auto;
        margin: auto;
        margin-top: 15px;
    }


    .profiles-section .carousel-inner {
        min-height: 100px;
    }

    .profiles-section .carousel-control {
        color: #000;
    }

    .profiles-section .carousel-indicators li {
        visibility: hidden;
    }

    .profiles-section .carousel-control.left, .carousel-control.right {
        background-image: none
    }

/* On screens that are 850px or less */
@media screen and (max-width: 850px) {

    .profiles-section .profile-image {
        padding-right: 20px;
    }

    .profiles-section .profile-bullets {
        font-size: 15px;
    }
}

/* On screens that are 768px or less */
@media screen and (max-width: 767px) {

    .profiles-section .profile-image {
        padding-right: 20px;
    }

    .profiles-section .profile-bullets {
        font-size: 18px;
    }
}

/* On screens that are 500px or less */
@media screen and (max-width: 500px) {
    .profiles-section .profile-bullets {
        font-size: 15px;
    }
}

/* On screens that are 400px or less */
@media screen and (max-width: 400px) {

    .profiles-section .profile-parent {
        padding: 0px;
        padding-top: 10px;
    }

    .profiles-section .profile-card {
        padding: 10px;
    }


    .profiles-section .profile-text {
        width: 80%;
    }

    .profiles-section .profile-bullets {
        font-size: 14px;
    }

    .profiles-section .profile-image {
        padding-right: 10px;
    }
}

/* On screens that are 300px or less */
@media screen and (max-width: 300px) {
    .profiles-section .profile-bullets {
        font-size: 12px;
    }
}

/*****************************************************************/
/*********************** Hover Panels ****************************/
/*****************************************************************/

.hover-panels-section-parent {
    padding: 0px;
    overflow: hidden;
    margin-bottom: 30px;
    -webkit-box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.3);
    -moz-box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.3);
    box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.3);
}

.hover-panels-section {
    min-height: 200px;
    position: relative;
    overflow: hidden;
}

.hover-panels-section-circle-arrow {
    background-image: url('/images/commercial/circle-arrow.png');
    background-size: 100%;
    height: 50px;
    width: 50px;
    position: absolute;
    right: 10px;
    bottom: 10px;
    opacity: 0.2;
}

.hover-panels-upload-plans .hover-panels-section-bg {
    background-image: url('/images/commercial/architect.jpg');
    background-size: cover;
    background-position: top;
}

.hover-panels-request-sample .hover-panels-section-bg {
    background-image: url('/images/commercial/easyclean.jpg');
    background-size: cover;
    background-position: top;
}

.hover-panels-book-a-call .hover-panels-section-bg {
    background-image: url('/images/redesign/bg/bg-diary.jpg');
    background-size: cover;
    background-position: top;
}

.hover-panels-homeowners-guide-to-gas-boilers .hover-panels-section-bg {
    background-image: url('/images/redesign/homeowners-guide-to-gas-boilers.jpg');
    background-size: cover;
    background-position: center;
}

.hover-panels-homeowners-guide-to-electric-heating .hover-panels-section-bg {
    background-image: url('/images/redesign/homeowners-guide-to-electric-heating.jpg');
    background-size: cover;
    background-position: center;
}

.hover-panels-homeowners-guide-to-heat-pumps .hover-panels-section-bg {
    background-image: url('/images/redesign/homeowners-guide-to-heat-pumps.jpg');
    background-size: cover;
    background-position: center;
}

.hover-panels-get-a-quote .hover-panels-section-bg {
    background-image: url('/images/redesign/home-page-slides/slide3.jpg');
    background-size: cover;
    background-position: center;
}

.hover-panels-book-a-survey .hover-panels-section-bg {
    background-image: url('/images/redesign/bg/bg-survey.jpg');
    background-size: cover;
    background-position: top;
}

.hover-panels-homeowners-guide-to-gas-boilers, .hover-panels-homeowners-guide-to-electric-heating, .hover-panels-homeowners-guide-to-heat-pumps {
    min-height: 300px !important;
}

.hover-panels-section-bg {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 9997;
    transition: all .5s;
}

.hover-panels-section-overlay {
    background-color: #000;
    width: 100%;
    height: 100%;
    opacity: 0.5;
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 9998;
}

.hover-panels-section-overlay-light {
    background-color: #000;
    width: 100%;
    height: 100%;
    opacity: 0.1;
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 9998;
}

.hover-panels-section-content {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 9999;
    padding: 30px;
    color: #fff;
}

    .hover-panels-section-content h1 {
        font-weight: 400;
        color: #fff;
        font-size: 40px;
    }

    .hover-panels-section-content ul li {
        list-style: none;
        font-size: 20px;
        line-height: 30px;
        font-weight: 500;
    }

.hover-panels-section-parent:hover,
.hover-panels-section-parent:focus {
    -webkit-box-shadow: 0px 0px 50px 0px rgba(0,0,0,0.6);
    -moz-box-shadow: 0px 0px 50px 0px rgba(0,0,0,0.6);
    box-shadow: 0px 0px 50px 0px rgba(0,0,0,0.6);
}


    .hover-panels-section-parent:hover .hover-panels-section-bg,
    .hover-panels-section-parent:focus .hover-panels-section-bg {
        -ms-transform: scale(1.2);
        -moz-transform: scale(1.2);
        -webkit-transform: scale(1.2);
        -o-transform: scale(1.2);
        transform: scale(1.2);
    }

    .hover-panels-section-parent:hover .hover-panels-section-overlay,
    .hover-panels-section-parent:focus .hover-panels-section-overlay {
        -webkit-animation-name: darken;
        -webkit-animation-duration: 0.5s;
        animation-name: darken;
        animation-duration: 0.5s;
        opacity: 0.7;
    }

    .hover-panels-section-parent:hover .hover-panels-section-overlay-light,
    .hover-panels-section-parent:focus .hover-panels-section-overlay-light {
        -webkit-animation-name: darken-light;
        -webkit-animation-duration: 2s;
        animation-name: darken-light;
        animation-duration: 2s;
        opacity: 0.4;
    }

    .hover-panels-section-parent:hover .hover-panels-section-content,
    .hover-panels-section-parent:focus .hover-panels-section-content {
        -webkit-animation-name: moveSlightlyRight;
        -webkit-animation-duration: 0.5s;
        animation-name: moveSlightlyRight;
        animation-duration: 0.5s;
        padding-left: 40px;
    }

    .hover-panels-section-parent:hover .hover-panels-section-circle-arrow,
    .hover-panels-section-parent:focus .hover-panels-section-circle-arrow {
        opacity: 0.4;
    }


@-webkit-keyframes darken {
    0% {
        opacity: 0.5;
    }

    100% {
        opacity: 0.7;
    }
}

@keyframes darken {
    0% {
        opacity: 0.5;
    }

    100% {
        opacity: 0.7;
    }
}

@-webkit-keyframes darken-light {
    0% {
        opacity: 0.1;
    }

    100% {
        opacity: 0.4;
    }
}

@keyframes darken-light {
    0% {
        opacity: 0.1;
    }

    100% {
        opacity: 0.4;
    }
}

@-webkit-keyframes moveSlightlyRight {
    0% {
        padding-left: 30px;
    }

    100% {
        padding-left: 40px;
    }
}

@keyframes moveSlightlyRight {
    0% {
        padding-left: 30px;
    }

    100% {
        padding-left: 40px;
    }
}


.hover-panels-section-content h1 {
    font-size: 30px;
    font-weight: 100;
}

/* On screens that are 992px or less (col-sm) */
@media (max-width: 992px) {

    .hover-panels-section-content h1 {
        font-size: 26px;
        font-weight: 100;
    }

    .hover-panels-homeowners-guide-to-gas-boilers, .hover-panels-homeowners-guide-to-electric-heating, .hover-panels-homeowners-guide-to-heat-pumps {
        min-height: 200px !important;
    }
}

/* On screens that are 768px or less (col-xs) */
@media (max-width: 768px) {

    .hover-panels-section-content h1 {
        font-size: 26px;
        font-weight: 500;
    }

    .hover-panels-section-parent {
        margin-bottom: 20px;
    }

    .hover-panels-section {
        min-height: 150px;
    }

    .hover-panels-homeowners-guide-to-gas-boilers, .hover-panels-homeowners-guide-to-electric-heating, .hover-panels-homeowners-guide-to-heat-pumps {
        min-height: 150px !important;
    }
}

/* On screens that are 479px or less (col-xxs) */
@media (max-width:479px) {

    .hover-panels-section-parent {
        margin-bottom: 10px;
        -webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
        -moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
        box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
    }

        .hover-panels-section-parent:hover,
        .hover-panels-section-parent:focus {
            -webkit-box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.6);
            -moz-box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.6);
            box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.6);
        }

    .hover-panels-section {
        min-height: 100px;
    }

    .hover-panels-section-content {
        padding-top: 10px;
    }

        .hover-panels-section-content h1 {
            font-size: 22px;
            font-weight: 500;
        }

    .hover-panels-homeowners-guide-to-gas-boilers, .hover-panels-homeowners-guide-to-electric-heating, .hover-panels-homeowners-guide-to-heat-pumps {
        min-height: 100px !important;
    }
}

/*****************************************************************/

/************************************************/
/******  Progress Bar Fix for File Uploads ******/
/************************************************/

.dz-upload {
    height: 10px !important;
    background: linear-gradient(to bottom, #beebff 0, #a8e4ff 100%);
    width: 0%;
}

.dz-remove {
    display: none;
}

/************************************************/
/** Alter the height of Select2 Dropdowns ---> **/
/************************************************/

.select2-selection__rendered {
    line-height: 31px !important;
}

.select2-container .select2-selection--single {
    height: 35px !important;
}

.select2-selection__arrow {
    height: 34px !important;
}

.select2-selection, .select2-selection__rendered {
    font-size: 14px;
}

/*********************************************************/
/** QUICK QUOTE BANNER APPEARS IN VARIOUS PLACES ---> **/
/*********************************************************/

.quick-quote-banner-wrapper {
    background-color: #d3222a;
    color: white;
    text-align: center;
    padding: 5px;
    cursor: pointer;
}

.quick-quote-banner-text {
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 3px;
    font-weight: 100;
    color: #fff !important;
    margin-top: 5px;
    font-size: 16px;
}

/* On screens that are 450px or less */
@media screen and (max-width: 450px) {
    .quick-quote-banner-text {
        text-align: center;
        text-transform: uppercase;
        letter-spacing: 3px;
        font-weight: 100;
        color: #fff;
        margin-top: 5px;
        font-size: 11px;
    }
}