@charset "UTF-8";

#header {
    background-color: rgba(0, 0, 0, 0.6);
    position: absolute;
    width: 100%;
}

#header a {
    color: #fff;
    text-transform: uppercase;
    font-weight: bold;
    margin-top: 10px;
}

#header a:hover {
    text-decoration: underline;
}

#header .dropdown-item a {
    color: #fff;
    padding-top: 5px;
    padding-bottom: 5px;
}

#header ul li.dropdown-item:first-child a {
    color: #ffd458;
}

#header .dropdown-item a:hover {
    color: #34b139 !important;
}

.navbar-brand {
    margin-top: 0 !important;
}

.navbar-brand > img {
     max-width: 150px;
     max-height: 100px;
}

#header .toll-free-number {
    position: absolute;
    right: 15px;
    top: 15px;
    color: #fff;
    font-weight: bold;
}

#header .toll-free-number.mobile {
    display: none;
}

#header #navbarMainNav {
    padding-top: 25px;
    padding-left: 97px;
}

#header .dropdown-menu {
    background-color: #043365;
    border: none;
}

.section-heading-text {
    color: #777;
    text-transform: uppercase;
}

h1, .h1 {
    font-size: 2.3em;
}

h2, .h2 {
    font-size: 1.8rem;
    margin-bottom: 30px;
}

.h2.max-w-700 {
    margin: 0 auto;
}

p {
    color: #232527;
}

a {
    text-decoration: underline;
}

.btn-orange {
    background: rgb(255,198,69);
    background: -moz-linear-gradient(180deg, rgba(255,198,69,1) 0%, rgba(238,173,26,1) 50%, rgba(249,166,0,1) 100%);
    background: -webkit-linear-gradient(180deg, rgba(255,198,69,1) 0%, rgba(238,173,26,1) 50%, rgba(249,166,0,1) 100%);
    background: linear-gradient(180deg, rgba(255,198,69,1) 0%, rgba(238,173,26,1) 50%, rgba(249,166,0,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffc645",endColorstr="#f9a600",GradientType=1);
    color: #fff;
}

.btn-orange:hover {
    background: rgb(103,199,106);
    background: -moz-linear-gradient(180deg, rgba(103,199,106,1) 0%, rgba(91,199,95,1) 50%, rgba(52,177,57,1) 100%);
    background: -webkit-linear-gradient(180deg, rgba(103,199,106,1) 0%, rgba(91,199,95,1) 50%, rgba(52,177,57,1) 100%);
    background: linear-gradient(180deg, rgba(103,199,106,1) 0%, rgba(91,199,95,1) 50%, rgba(52,177,57,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#67c76a",endColorstr="#34b139",GradientType=1);
    color: #fff;
}

.btn-pill {
    border-radius: 10px;
    text-decoration: none;
    padding: 8px 30px;
    min-width: 300px;
}

.btn-secondary {
    background-color: #fbc03b;
    border-color: #96711e;
}

#btnScrollTo:hover {
    background-color: #34b139;
}

.icons-services {
    text-align: center;
    border-top: 1px solid #dedede;
}

.services-list {
    text-align: center;
}

@media only screen
and (min-width: 768px) {
    .icons-services .col-md-2 {
        flex: 0 0 19.66667%;
        max-width: 19.66667%;
    }

    .services-list .col-md-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }
}

.icons-services h2,
.services-list h2{
    word-break: keep-all;
}

.services-list h2 {
    margin-top: 10px;
}

.icons-services a,
.services-list a {
    text-decoration: none;
    color: #404040;
}

.icons-services a:hover,
.services-list a:hover {
    text-decoration: underline;
}

.icons-services img {
    width: 80px;
}

.icons-services img.residential {
    width: 90px;
}

.icons-services img.commercial {
    width: 80px;
}

.icons-services img.agricultural {
    width: 100px;
}

.icons-services img.municipal {
    width: 120px;
}

.icons-services img.battery {
    width: 65px;
}

.icons-services .service-icon-container {
    height: 100px;
}

.services-list img {
    width: 260px;
    border-radius: 4px;
}

.green-heading {
    color: #45bf11;
}

.width-full {
    width: 100%;
    padding: 0 10px;
}

.border-top-gray {
    border-top: 1px solid #dedede;
}

.image-left img,
.image-right img {
    width: 100%;
}

.image-left .col-md-6 {
    width: 49%;
    float: left;
    padding: 0;
}

.image-left .col-md-8 {
    width: 65%;
    float: left;
    padding: 0;
}

.image-left .col-md-4 {
    width: 29%;
    float: left;
    padding: 0;
}

.image-right .col-md-4 {
    width: 29%;
    float: right;
    padding: 0;
}

.image-right .col-md-6 {
    width: 49%;
    float: right;
    padding: 0;
}

.image-right .col-md-8 {
    width: 65%;
    float: right;
    padding: 0;
}

.text-with-background {
    padding: 30px !important;
}

.green-list li {
    font-size: 1.3rem;
    font-weight: 500;
    line-height: 1.2em;
    color: #45bf11;
    margin-bottom: 10px;
}

.green-list li span {
    color: #212529;
}

.image-overlay-text {
    position: relative;
}

.image-overlay-text .overlay-text {
    position: absolute;
    bottom: 10%;
    left: 10%;
    background-color: rgba(255,255,255,0.9);
    padding: 30px;
    width: 80%;
}

.image-overlay-text .overlay-text .btn {
    width: 100%;
    min-width: 100%;
}

.banner-with-text-overlay .col-md-6 {
    float: left;
}

.banner-with-text-overlay img {
    width: 100%;
}

.banner-with-text-overlay .text-overlay {
    margin-top: 100px;
    padding-left: 50px;
}

.banner-with-text-overlay .text-overlay h2 {
    font-size: 1.9em !important;
}

.banner-with-text-overlay .text-overlay .inner-text .spec {
    width: 49%;
    float: left;
    position: relative;
    margin-bottom: 15px;
}

.banner-with-text-overlay .text-overlay .inner-text .spec:before
{
    content:' ';
    display: block;
    border: 1px solid #6b6b6b;
    width: 30px;
    margin-bottom: 5px;
}

.banner-with-text-overlay .text-overlay .inner-text .spec-subheading {
    font-weight: bold;
    font-size: 1.1em;
}

.banner-with-text-overlay .text-overlay .inner-text .spec-details {
    display: block;
}

.solar-power-image-with-heading {
    position: relative;
}

.solar-power-image-with-heading span {
    position: absolute;
    top: 0;
    left: 0;
    color: #777;
    font-size: 1em;
    font-weight: bold;
}

.third-party-reviews img,
.third-party-reviews .btn {
    width: 100%;
    min-width: auto;
}

.third-party-reviews .stars {
    width: 165px;
    margin: 0 auto;
}

.third-party-reviews .star-container {
    float: left;
    margin-left: 15px;
}

.star-container ul {
    list-style: none;
    padding: 0;
    margin-left: 0;
}

.star-container li {
    display: inline-block;
    font-size: 20px;
    color: #ccc;
}

.stars .star-rating {
    float: left;
    line-height: 1.8em;
}

.star-container li.active, .star-container li.hover {
    color: orange;
}

.fa-star:before {
    content: "\f005";
}

#starRating li {
    cursor: pointer;
    font-size: 40px !important;
}

.form-group label:first-child {
    font-weight: bold;
}

.text-title {
    font-weight: bold;
    color: #1275b8;
}

#portfolio.portfolio-gutter .item-box {
    margin-bottom: 30px;
}

#portfolio.portfolio-gutter .item-box iframe {
    width: 100%;
    height: 237px;
}

#portfolio .item-box-desc h2, #portfolio .item-box-desc h3 {
    font-size: 18px;
    line-height: 20px;
}

#footer .footer-links-list li {
    width: 100%;
    padding: 3px 0 3px 40px;
}

#footer .footer-links-list li a {
    text-decoration: none;
    text-transform: uppercase;
}

#footer .footer-links-list li a:hover {
    text-decoration: underline;
}

#footer .logo-link {
    display: block;
}

#footer p {
    color: #fff;
    text-align: left;
    font-size: 0.9em;
}

#footer .footer-logo {
    margin-bottom: 15px;
}

#footer .toll-free-number {
    margin-bottom: 20px;
    font-weight: bold;
}

.btn-facebook > i,
.btn-twitter  > i {
    margin-right: 0 !important;
}

.btn-facebook,
.btn-twitter {
    background-color: transparent;
    border: 1px solid #ccc;
    padding: 0.46rem 0.8rem;
    color: #ccc !important;
}

section.bg-cover {
    position: relative;
}

section.bg-cover .text-overlay {
    position: absolute;
    color: #fff;
    bottom: 40%;
    text-align: center;
    width: 100%;
    text-transform: uppercase;
}

section.bg-cover .text-overlay .inner-text {
    max-width: 1200px;
    margin: 0 auto;
    font-size: 2.8em;
    font-weight: bold;
    text-shadow: 0 0 30px #000, 0 0 10px #000;
    line-height: 1.0em;
}

section.bg-cover .text-overlay .inner-text span {
    text-transform: none;
    font-size: 0.7em;
    line-height: 0;
}

@media only screen
and (min-width: 1025px) {
    section.bg-cover img {
        width: 100%
    }

    #footer .footer-links-list li {
        text-align: left;
    }
}

@media only screen
and (max-width: 992px)
{
    #header .container {
        padding-top: 10px;
        padding-bottom: 10px;
    }

    #header a {
        margin-top: 0;
    }

    .navbar {
        display: block;
    }

    #header .navbar-brand img {
        width: 110px;
        height: 70px;
    }

    .navbar-toggler {
        float: right;
        border: none;
        width: 90px;
        margin-top: -10px;
    }

    .navbar-toggler path {
        stroke: #fff;
        fill: #fff;
    }

    .menu-label {
        text-transform: uppercase;
        float: right;
        font-weight: bold;
        color: #fff;
    }

    #header .toll-free-number {
        top: initial;
        bottom: 0;
        right: 8px;
    }

    #header #navbarMainNav {
        padding: 0;
        background: #043365;
        background: linear-gradient(to bottom, #043365 0%, #156cca 100%);
    }

    .navbar-xs,
    .navbar-collapse.show > .navbar-nav {
        background: rgb(21,74,140);
        background: -moz-linear-gradient(180deg, rgba(21,74,140,1) 0%, rgba(19,73,140,1) 50%, rgba(15,63,123,1) 100%);
        background: -webkit-linear-gradient(180deg, rgba(21,74,140,1) 0%, rgba(19,73,140,1) 50%, rgba(15,63,123,1) 100%);
        background: linear-gradient(180deg, rgba(21,74,140,1) 0%, rgba(19,73,140,1) 50%, rgba(15,63,123,1) 100%);
        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#154a8c",endColorstr="#0f3f7b",GradientType=1);
        top: 115px;
    }

    .socials-mobile {
        margin-top: 50px;
    }

    .socials-mobile .text-muted {
        color: #fff !important;
    }

    h1, .h1 {
        font-size: 1.4rem !important;
    }

    h2, .h2 {
        font-size: 1.1rem !important;
    }

    section.bg-cover img {
        width: 100%
    }

    #footer .logo-link {
        text-align: center;
    }

    #footer p {
        text-align: center;
        padding: 20px;
    }

    #footer .footer-links-list li {
        padding: 3px 0;
    }

    #portfolio.portfolio-gutter .item-box iframe {
        height: 134px;
    }
}

@media only screen
and (min-width: 768px) {
    body:not(.layout-admin) section {
        padding: 50px 0;
    }

    section.bg-cover img {
        width: 100%;
    }

    .image-right .green-list {
        padding-left: 0;
        padding-right: 30px;
    }
}

@media only screen
and (max-width: 768px) {
    body:not(.layout-admin) section {
        padding: 50px 0;
    }
}

@media only screen
and (min-width: 1024px)
and (max-width: 1024px)
{
    #header #navbarMainNav {
        padding-left: 29px;
    }

    #header a {
        font-size: 13px;
    }

    #header .navbar-brand {
        margin-right: 44px;
    }

    section.bg-cover img {
        width: 100%
    }

    .navbar-nav .nav-link.dropdown-toggle:not(.nav-link-caret-hide):before {
        top: 46%;
    }
}

@media only screen and (max-width: 991px) {
    .navbar-xs > .navbar-brand > img {
         max-height: 100px !important;
    }

    section.bg-cover .text-overlay .btn {
        width: auto;
        min-width: auto;
    }
}

@media only screen
and (min-width: 993px)
and (max-width: 1220px) {
    #header #navbarMainNav {
        padding-top: 25px;
        padding-left: 111px;
    }

    #header a {
        min-width: 100px;
        font-size: 15px;
    }
}

@media only screen
and (min-width: 993px)
and (max-width: 1199px) {
    #header #navbarMainNav {
        padding-left: 19px;
    }

    #header a {
        font-size: 12px;
        min-width: 100px;
    }

    .services-list img {
        width: 160px;
    }

    section.bg-cover .text-overlay.with-button {
        bottom: 50px;
    }

    section.bg-cover .text-overlay.with-button .inner-text {
        line-height: 0.7em;
    }

    section.bg-cover .text-overlay .inner-text span {
        font-size: 25px;
    }

    .image-left .col-md-6,
    .image-right .col-md-6,
    .banner-with-text-overlay .col-md-6,
    .image-left .col-md-8,
    .image-left .col-md-4 {
        width: 100%;
        max-width: 100%;
        float: none;
    }

    .banner-with-text-overlay .col-md-6 {
        padding-bottom: 30px;
    }

    .banner-with-text-overlay .text-overlay {
        margin-top: 0;
    }

    #portfolio.portfolio-gutter .item-box iframe {
        height: 186px;
    }
}

@media (min-width: 320px) and (max-width: 480px) {
    #header .toll-free-number.mobile {
        display: block;
    }

    #header .toll-free-number:not(.mobile) {
        display: none;
    }

    section.bg-cover .text-overlay {
        bottom: 15px;
        padding: 0 25px;
    }

    section.bg-cover .text-overlay .btn {
        width: auto;
        min-width: auto;
        font-size: 12px;
    }

    section.bg-cover .text-overlay .inner-text {
        max-width: 480px;
        margin: 0 auto;
        font-size: 0.9em;
        padding: 0 5px;
        text-shadow: 0 0 10px #101010;
    }

    #header {
        position: relative;
        background: rgb(21,74,140);
        background: -moz-linear-gradient(180deg, rgba(21,74,140,1) 0%, rgba(19,73,140,1) 50%, rgba(15,63,123,1) 100%);
        background: -webkit-linear-gradient(180deg, rgba(21,74,140,1) 0%, rgba(19,73,140,1) 50%, rgba(15,63,123,1) 100%);
        background: linear-gradient(180deg, rgba(21,74,140,1) 0%, rgba(19,73,140,1) 50%, rgba(15,63,123,1) 100%);
        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#154a8c",endColorstr="#0f3f7b",GradientType=1);
    }

    .image-left .col-12,
    .image-right .col-12,
    .banner-with-text-overlay .col-12 {
        width: 100%;
        float: none;
        padding-bottom: 30px;
    }

    .banner-with-text-overlay .text-overlay {
        margin-top: 20px;
    }

    .image-overlay-text .overlay-text,
    .image-overlay-text .overlay-text .btn {
        font-size: 12px;
    }

    section.bg-cover .text-overlay .inner-text span {
        font-size: 12px;
    }
}

@media (min-width: 481px) and (max-width: 767px) {
    section.bg-cover .text-overlay {
        bottom: 25px;
    }

    section.bg-cover .text-overlay .inner-text {
        font-size: 1.1em;
        max-width: 480px;
    }

    .image-left .col-12,
    .image-right .col-12,
    .banner-with-text-overlay .col-12 {
        width: 100%;
        float: none;
        padding-bottom: 30px;
    }

    .banner-with-text-overlay .text-overlay {
        margin-top: 20px;
    }

    .image-overlay-text .overlay-text,
    .image-overlay-text .overlay-text .btn {
        font-size: 12px;
    }

    #portfolio.portfolio-gutter .item-box iframe {
        height: 96px;
    }
}

@media (max-width: 575px) {
    #portfolio.portfolio-gutter .item-box iframe {
        height: 330px;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    section.bg-cover .text-overlay {
        bottom: 40px;
        padding: 0 25px;
    }

    section.bg-cover .text-overlay .inner-text {
        max-width: 768px;
        margin: 0 auto;
        font-size: 1.7em;
        text-shadow: 0 0 20px #101010;
    }

    .services-list img {
        width: 160px;
    }

    .image-left .col-md-6,
    .image-right .col-md-6,
    .banner-with-text-overlay .col-md-6,
    .image-left .col-md-8,
    .image-left .col-md-4 {
        width: 100%;
        max-width: 100%;
        float: none;
    }

    .banner-with-text-overlay .col-md-6 {
        padding-bottom: 30px;
    }

    .banner-with-text-overlay .text-overlay {
        margin-top: 20px;
    }
}
