/*!
Theme Name: energyPlus
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: energyplus
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

energyPlus is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/
@import url("https://p.typekit.net/p.css?s=1&k=jvh4pmx&ht=tk&f=32227.32228&a=25273744&app=typekit&e=css");
@font-face {
    font-family: "din-2014";
    src: url("https://use.typekit.net/af/c2b6e5/00000000000000007735afee/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"), url("https://use.typekit.net/af/c2b6e5/00000000000000007735afee/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/c2b6e5/00000000000000007735afee/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
    font-display: auto;
    font-style: normal;
    font-weight: 400;
    font-stretch: normal;
}
@font-face {
    font-family: "din-2014";
    src: url("https://use.typekit.net/af/2bc98d/00000000000000007735aff1/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("woff2"), url("https://use.typekit.net/af/2bc98d/00000000000000007735aff1/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("woff"), url("https://use.typekit.net/af/2bc98d/00000000000000007735aff1/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("opentype");
    font-display: auto;
    font-style: normal;
    font-weight: 600;
    font-stretch: normal;
}
.tk-din-2014 {
    font-family: "din-2014", sans-serif;
}
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
}
/* Sections
	 ========================================================================== */
body {
    margin: 0;
    position: relative;
}
body.popup-open {
    overflow: hidden;
}
main {
    display: block;
}
h1 {
    font-size: 2em;
    margin: 0.67em 0;
}
p {
    font-family: "din-2014", sans-serif;
}
hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}
pre {
    font-family: monospace, monospace;
    font-size: 1em;
}
a {
    background-color: transparent;
}
abbr[title] {
    border-bottom: none;
    text-decoration: underline;
}
b,
strong {
    font-weight: bolder;
}
code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}
small {
    font-size: 80%;
}
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}
sub {
    bottom: -0.25em;
}
sup {
    top: -0.5em;
}
img {
    border-style: none;
}
button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0;
}
button,
input {
    overflow: visible;
}
button,
select {
    text-transform: none;
}
button,
[type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
    outline: 1px dotted ButtonText;
}
fieldset {
    padding: 0.35em 0.75em 0.625em;
}
legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal;
}
progress {
    vertical-align: baseline;
}
textarea {
    overflow: auto;
}
[type="checkbox"],
[type="radio"] {
    box-sizing: border-box;
    padding: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}
[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}
::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit;
}
details {
    display: block;
}
summary {
    display: list-item;
}
template {
    display: none;
}
[hidden] {
    display: none;
}
*,
*::before,
*::after {
    box-sizing: inherit;
}
html {
    box-sizing: border-box;
}
body,
button,
input,
select,
optgroup,
textarea {
    color: #001602;
    font-family: "din-2014", "Helvetica Neue", sans-serif;
    font-size: 1rem;
    line-height: 1.5;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    clear: both;
}
p {
    margin-bottom: 1.5em;
}
dfn,
cite,
em,
i {
    font-style: italic;
}
blockquote {
    margin: 0 1.5em;
}
address {
    margin: 0 0 1.5em;
}
pre {
    background: #eee;
    font-family: "din-2014", courier, monospace;
    line-height: 1.6;
    margin-bottom: 1.6em;
    max-width: 100%;
    overflow: auto;
    padding: 1.6em;
}
code,
kbd,
tt,
var {
    font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}
abbr,
acronym {
    border-bottom: 1px dotted #666;
    cursor: help;
}
mark,
ins {
    background: #fff9c0;
    text-decoration: none;
}
big {
    font-size: 125%;
}
/* Elements
--------------------------------------------- */
body {
    background: #fff;
}
hr {
    background-color: #ccc;
    border: 0;
    height: 1px;
    margin-bottom: 1.5em;
}
ul,
ol {
    margin: 0 0 1.5em 3em;
}
ul {
    list-style: none;
}
ol {
    list-style: decimal;
}
li>ul,
li>ol {
    margin-bottom: 0;
    margin-left: 1.5em;
}
dt {
    font-weight: 700;
}
dd {
    margin: 0 1.5em 1.5em;
}
/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
    max-width: 100%;
}
img {
    height: auto;
    max-width: 100%;
}
figure {
    margin: 1em 0;
}
table {
    margin: 0 0 1.5em;
    width: 100%;
}
/* Links
--------------------------------------------- */
a {
    color: #fff;
    text-decoration: none;
    cursor: pointer;
}
a:hover,
a:focus,
a:active {
    color: #fff;
    opacity: 1;
    outline: none;
}
/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
    border: none;
    border-radius: 25px;
    background: #73F880;
    color: #1A451F;
    line-height: 1;
    padding: 17px 55px 15px;
    font-size: 22px;
}
button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
    border-color: transparent;
    background: #73F880;
    color: #1A451F;
}
button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
    border-color: transparent;
    background: #5CD668;
    color: #1A451F;
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
    color: #1A451F;
    border-color: #C4DEC7 !important;
    border-radius: 6px;
    background: white;
    border: 1px solid;
    padding: 8px 14px;
    width: 100%;
    font: 18px/28px 'din-2014', sans-serif;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
    color: #1A451F;
}
select {
    color: #37464A;
    border-color: #E7E7EB !important;
    border-radius: 6px;
    border: 1px solid;
    padding: 9px 16px;
    width: 100%;
    margin: 0 8px 16px;
    font: 18px/28px 'din-2014', sans-serif;
}
.jcf-select {
    color: #001602;
    border-color: #C4DEC7 !important;
    border-radius: 8px;
    border: 1px solid;
    padding: 9px 18px;
    width: 100%;
    font: 18px/28px 'din-2014', sans-serif;
    height: 48px;
    text-align: left;
    margin: 0;
}
.jcf-select .jcf-select-text {
    font: 18px/28px 'din-2014', sans-serif;
    margin: 0 35px 0 0;
    color: #1A451F;
}
.jcf-select .jcf-select-opener {
    position: absolute;
    text-align: center;
    background: #fff;
    border-radius: 8px;
    width: 46px;
    bottom: 0;
    right: 0;
    top: 0;
}
.jcf-select-opener:before {
    position: absolute;
    top: 9px;
    right: 20px;
    content: "\e900";
    font-family: 'icomoon';
    font-size: 10px;
    transform: rotate(90deg);
    color: #1A451F;
}
.jcf-focus, .jcf-focus * {
    border-color: #C4DEC7 !important;
}
.jcf-select-drop .jcf-hover, .jcf-list-box .jcf-selected {
    background: #F5F9F5;
    color: #1A451F;
}
.jcf-list .jcf-option {
    white-space: nowrap;
    overflow: hidden;
    cursor: default;
    display: block;
    padding: 8px 16px;
    color: #1A451F;
    min-height: 24px !important;
    height: 1%;
    font-size: 16px;
}
textarea {
    width: 100%;
    margin: 0 9px 28px;
    max-height: 120px;
}
/*--------------------------------------------------------------
# Main Styles
--------------------------------------------------------------*/
.wrapper {
    position: relative;
    overflow: hidden;
}
body {
    font: 22px/25px 'din-2014', sans-serif;
    font-weight: 400;
    background: #fff;
    color: #1A451F;
    overflow-x: hidden;
}
.container {
    max-width: 1580px;
    padding: 0 15px;
    margin: 0 auto;
    position: relative;
    width: 100%;
}
h1 {
    font: 98px/91px 'din-2014', sans-serif;
    margin-block-start: 0;
    margin-block-end: 17px;
    font-weight: 600;
    color: #fff;
}
h2 {
    font: 55px/57px 'din-2014', sans-serif;
    margin-block-start: 0;
    margin-block-end: 12px;
    font-weight: 600;
}
h3 {
    font: 45px/50px 'din-2014', sans-serif;
    margin-block-start: 0;
    margin-block-end: 24px;
    font-weight: 600;
}
.btn {
    background: #5CD668;
    color: #1A451F;
    font-family: 'din-2014', sans-serif;
    font-weight: 400;
    padding: 17px 55px 15px;
    border-radius: 28px;
    text-transform: uppercase;
    font-size: 22px;
    line-height: 1;
    transition: 0.3s;
    display: block;
    width: max-content;
    cursor: pointer;
}
.btn:focus, .btn:active {
    color: #1A451F;
}
.btn-small {
    padding: 17px 45px 15px;
    border-radius: 25px;
    font-size: 18px;
}
.btn-small:hover, .btn:hover {
    background: #73F880;
    color: #1A451F;
}
.btn-arrow {
    color: #3D9246;
    text-transform: uppercase;
    font-size: 18px;
    display: flex;
    align-items: center;
    line-height: 1;
    transition: 0.3s;
}
.btn-arrow:hover {
    color: #3D9246;
}
.btn-arrow .icon-arrow-next {
    color: #3D9246;
    margin-left: 10px;
    font-size: 11px;
    position: relative;
    transition: 0.3s;
}
.btn-arrow:hover .icon-arrow-next {
    margin-left: 24px;
}
.bg-light {
    background-color: #F5F9F5;
}
/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    padding: 34px 0 31px;
    z-index: 10;
    background: transparent;
    transition: 0.3s;
}
.site-header.dark-type-logo.sticky {
    background: #F5F9F5;
}
.site-header.dark-type-header{
    background: #1A451F;
}
.site-header.sticky {
    background: #1A451F;
}
.site-header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.site-header.dark-type-logo .custom-logo-link .light-logo {
    opacity: 0;
    visibility: hidden;
    display: none;
}
.site-header.dark-type-logo .custom-logo-link .dark-logo {
    opacity: 1;
    visibility: visible;
    display: block;
}
.site-header.dark-type-logo .menu li a {
    color: #327A39;
}
.site-header.dark-type-logo .menu li:last-child a {
    color: #1A451F !important;
}
.site-header.dark-type-logo .menu .menu-item-has-children:after {
    color: #327A39;
}
.menu {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0;
    margin: 0;
}
.menu li {
    margin: 0 17px 0;
    transition: 0.3s;
    position: relative;
    padding: 22px 0;
}
.menu li:last-child {
    margin: 0 0 0 17px;
    border-bottom: none;
}
.menu li:last-child:before {
    display: none;
}
.menu li:last-child a {
    background: #5CD668;
    color: #1A451F;
    padding: 13px 27px;
    border-radius: 25px;
    transition: 0.3s;
}
.menu li:last-child a:hover {
    background: #73F880;
}
.menu li:last-child:hover {
    border-bottom: none;
}
.menu li a {
    font-size: 18px;
}
.menu li:before {
    content: "";
    position: absolute;
    bottom: 22px;
    left: 0;
    width: 0;
    height: 2px;
    background: #5CD668;
    transition: 0.3s;
}
.menu li.menu-item-has-children:before {
    content: "";
    position: absolute;
    bottom: 22px;
    left: 0;
    width: 0;
    height: 2px;
    background: #5CD668;
    transition: 0.3s;
}
.menu li.current-menu-item:before {
    width: 100%;
}
.menu li:hover:before {
    width: 100%;
}
.menu li.current-menu-parent:before {
    width: 145% !important;
}
.menu li.menu-item-has-children.current-menu-item:before {
    width: 135% !important;
}
.menu li.menu-item-has-children:hover:before {
    width: 145%;
}
.menu .menu-item-has-children:hover:after {
    transform: rotate(-90deg);
}
.menu li.menu-item-has-children:nth-child(2):hover:before {
    width: 135%;
}
.menu li:nth-child(3) {
    margin-left: 28px;
}
.menu .menu-item-has-children {
    position: relative;
    margin: 0 28px;
}
.menu .menu-item-has-children:after {
    content: "\e900";
    font-family: 'icomoon';
    font-size: 9px;
    transform: rotate(90deg);
    color: white;
    position: absolute;
    top: 20px;
    right: -20px;
}
.menu .menu-item-has-children:after {
    content: "\e900";
    font-family: 'icomoon';
    font-size: 9px;
    transform: rotate(90deg);
    color: white;
    position: absolute;
    top: 20px;
    right: -20px;
}
.menu .menu-item-has-children .sub-menu {
    visibility: hidden;
    display: none;
    position: absolute;
    padding: 0;
    left: 0;
    top: 100%;
    background: white;
    border: 1px solid #C4DEC7;
    border-radius: 8px;
    margin: 0;
    width: max-content;
    max-width: 610px;
    flex-wrap: wrap;
}
.sub-menu {
    display: flex;
    align-items: center;
    overflow: hidden;
}
.sub-menu li {
    margin: 0 !important;
    width: 50%;
    padding: 0 !important;
}
.sub-menu li a {
    padding: 36px 31px !important;
    color: #1A451F !important;
    display: block;
    position: relative;
    transition: 0.3s;
    font-weight: 600;
    font-family: 'din-2014', sans-serif;
}
.sub-menu li a:after {
    content: "\e900";
    position: absolute;
    top: 50%;
    right: 37px;
    transform: translateY(-50%);
    font-family: "icomoon";
    font-size: 13px;
    color: #327A39;
}
.sub-menu li:hover a {
    background: #D8E9DA;
}
.sub-menu li:last-child:hover a {
    background: #D8E9DA;
}
.sub-menu li:before {
    display: none !important;
}
.sub-menu li.menu-item-background {
    width: 100%;
    position: relative;
}
.sub-menu li.menu-item-background a {
    padding: 41px 50px 40px !important;
    color: white !important;
    text-transform: uppercase;
    font-size: 25px !important;
    position: relative;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    display: block;
}
.sub-menu li.menu-item-background a:before {
    content: "";
    background: #001602;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    background-blend-mode: darken;
    opacity: 0.8;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.sub-menu li.menu-item-background a span {
    position: relative;
    z-index: 2;
}
.sub-menu li.menu-item-background a:after {
    font-size: 19px;
}
.sub-menu li.menu-item-background a span:before {
    content: "";
    width: 100%;
    height: 2px;
    position: absolute;
    display: block;
    background: #5CD668;
    bottom: -7px;
    left: 0;
}
.sub-menu li:last-child a {
    background: transparent;
    color: #1A451F;
    padding: 30px 40px 33px 33px;
    border-radius: 0;
    transition: 0.3s;
}
.sub-menu li:last-child {
    margin: 0;
}
.menu .menu-item-has-children:hover .sub-menu {
    visibility: visible;
    display: flex;
}
.menu-toggler {
    display: none;
}
.menu-toggler::before, .menu-toggler::after, .menu-toggler span {
    content: "";
    display: block;
    width: 30px;
    height: 3px;
    border-radius: 3px;
    margin: 3px 0;
    position: relative;
    background: #5CD668;
    z-index: 1;
    transform-origin: 3px 0;
    transition: transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1), background-color 0.5s cubic-bezier(0.77, 0.2, 0.05, 1), opacity 0.55s ease, -webkit-transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1);
}
.open-header-menu .site-header .menu-menu-main-container {
    transform: translateY(0);
}
.open-header-menu .menu-toggler::before {
    transform: rotate(45deg) translate(0px, -1px);
}
.open-header-menu .menu-toggler span {
    opacity: 0;
    transform: rotate(0deg) scale(0.2, 0.2);
}
.open-header-menu .menu-toggler::after {
    transform: rotate(-45deg) translate(0px, -3px);
}
.site-header .custom-logo-link, .site-header .menu-menu-main-container {
    position: relative;
    z-index: 2;
}
.site-header .custom-logo-link .dark-logo {
    opacity: 0;
    visibility: hidden;
    display: none;
}
.open-header-menu .site-header .custom-logo-link .dark-logo {
    opacity: 1;
    visibility: visible;
    display: block;
}
.open-header-menu .site-header {
    background: #F5F9F5 !important;
}
.open-header-menu .site-header .custom-logo-link .light-logo {
    opacity: 0;
    visibility: hidden;
    display: none;
}
.site-header .menu-menu-main-container {
    transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
}
.has-sub-menu-services .sub-menu {
    max-width: 371px;
    flex-wrap: nowrap;
    flex-direction: column;
}
.has-sub-menu-services .sub-menu li {
    width: 100%;
}
.has-sub-menu-services .sub-menu li a {
    padding: 27px 54px 27px 33px !important;
    display: flex;
    align-items: center;
}
.has-sub-menu-services .sub-menu li a p {
    margin: 0;
    padding: 0;
    max-width: 150px;
    font-size: 22px;
    line-height: 1;
    font-weight: 600;
    font-family: 'din-2014', sans-serif;
}
.has-sub-menu-services .sub-menu li:first-child a p {
    max-width: 216px;
}
.has-sub-menu-services .sub-menu li a i {
    font-size: 36px;
    margin-right: 32px;
}
.has-sub-menu-services .sub-menu li a:after {
    right: 35px;
}
/*--------------------------------------------------------------
# Home
--------------------------------------------------------------*/
.banner {
    height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    background-color: rgba(26, 69, 31, 0.8);
    background-blend-mode: multiply;
    overflow: hidden;
}
.banner .container {
    z-index: 1;
    position: relative;
}
.banner:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(26, 69, 31, 0.8);
    mix-blend-mode: multiply;
}
.banner video {
    position: absolute;
    width: 100%;
    height: auto;
    top: 0;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    right: 0;
}
.banner h1 {
    max-width: 913px;
}
.banner p {
    max-width: 1010px;
    color: white;
    margin: 0 0 45px;
}
.banner .btn-holder {
    display: flex;
    align-items: center;
}
.banner-slider{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100vh;
    width: 100%;
}
.banner-slide{
    height: 100vh;
    width: 100%;
    overflow: hidden;
}
.banner-slide .slide-img{
    height: 100vh;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    transition:all 3s ease-in-out;
    position: relative;
}
.banner-slide:nth-child(even) .slide-img{
    transform: scale(1.08);
}
.banner-slide:nth-child(even).slick-active .slide-img{
    transform: scale(1);
}
.banner-slide .slide-img:after{
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: black;
    opacity: 0.5;
    transition:all 1s ease-in-out;
}
.banner-slide.slick-active .slide-img:after{
    opacity: 0;
}
.banner-slide.slick-active .slide-img{
    transform: scale(1.08);
}
#fade {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: black;
    z-index: 100;
    -moz-opacity: 0.8;
    opacity: .80;
    filter: alpha(opacity=80);
}
#light {
    display: none;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 101;
    width: 100%;
    padding: 0 25px;
    overflow: visible;
    max-width: 1490px;
}

#bannervideo {
    position: relative;
    width: 100%;
    height: auto;
}
.boxclose {
    cursor: pointer;
    color: #fff;
    border: 1px solid #AEAEAE;
    border-radius: 3px;
    background: #222222;
    font-size: 30px;
    font-weight: 400;
    display: block;
    line-height: 0;
    padding: 11px 3px;
    position: absolute;
    right: 2px;
    top: 2px;
    width: 30px;
    height: 30px;
    z-index: 1002;
    opacity: 0.9;
}
.boxclose:before {
    content: "×";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
#fade:hover~.boxclose {
    display: none;
}

.video-btn {
    display: flex;
    align-items: center;
    line-height: 1;
    padding: 0 50px;
    border-radius: 25px;
    border: 1px solid #5CD668;
    background: transparent;
    margin-right: 29px;
    transition: 0.3s;
    height: 50px;
}
.video-btn p {
    margin: 0;
    font-size: 30px;
}
.video-btn .play-sign {
    background: #5CD668;
    position: relative;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    margin: 0 0 0 22px;
    transition: 0.3s;
    display: none;
}
.video-btn .play-sign:after {
    content: "";
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 14px solid white;
    position: absolute;
    top: 16px;
    left: 19px;
}

.video-btn:hover {
    border: 1px solid #5CD668;
    background: transparent;
}

.video-btn:hover span {
    background: #5CD668;
}
.key-info {
    padding: 50px 0 120px;
}
.key-info .info-holder {
    background: #1A451F;
    border-radius: 20px;
    color: #ffffff;
}
.key-info .info-holder h3 {
    padding: 0 30px 0;
    margin: 0 auto;
    max-width: 1055px;
    text-align: center;
}
.key-info .info-holder .title-header {
    padding: 71px 0 51px;
    border-bottom: 1px solid rgba(234, 255, 236, 0.2);
}
.key-list {
    margin: 0;
    padding: 65px 62px 83px;
    display: flex;
    justify-content: center;
}
.key-list li {
    margin: 0 38px;
    padding-left: 23px;
    position: relative;
    min-height: 219px;
}
.key-list li:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 11px;
    height: 100%;
    background: #5CD668;
}
.key-list li:first-child {
    min-width: 214px;
}
.key-list li:nth-child(2), .key-list li:last-child {
    min-width: 212px;
}
.key-list li:nth-child(3) {
    min-width: 222px;
}
.key-list li:nth-child(4) {
    min-width: 185px;
}
.key-list li span {
    font-size: 67px;
    font-weight: 700;
    line-height: 1;
}
.key-list li p {
    margin: 30px 0 0;
}
.title-wrapper {
    margin: 0 0 50px;
}
.title-wrapper h2 {
    margin: 0 0 15px;
}
.title-wrapper p {
    margin: 0;
    color: #3D9246;
    font-size: 25px;
}
.services-section {
    padding: 0 0 179px;
}
.services-slider {
    position: relative;
    margin: 0 -9px;
}
.slick-track {
    display: flex;
}
.slick-disabled {
    cursor: context-menu;
    display: none !important;
}
.slick-disabled:before {
    opacity: 0.3;
}
.slick-arrow {
    width: 61px;
    height: 61px;
    background: #F5F9F5 !important;
    box-shadow: 5px 6px 9px rgba(0, 47, 5, 0.1);
    font-size: 0;
    padding: 0;
    border: none;
    border-radius: 8px;
    position: absolute;
    top: 50%;
    transform: scale(1) translateY(-50%);
    z-index: 2;
    transition: 0.3s;
    cursor: pointer;
}
.slick-arrow:hover {
    transform: scale(1.15) translateY(-50%);
}
.slick-arrow:before {
    content: "\e900";
    font-family: 'icomoon';
    font-size: 24px;
    color: #5CD668 !important;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    transition: 0.3s;
}
.slick-prev {
    left: -23px;
}
.slick-prev:before {
    transform: translate(-50%, -50%) rotate(-180deg);
}
.slick-next {
    right: -23px;
    left: auto;
}
.service-item {
    margin: 0 9px;
    border-radius: 15px;
    background: white;
    border: 1px solid #C4DEC7;
    padding: 42px 52px;
    min-height: 530px;
    height: auto;
    display: flex !important;
    flex-direction: column;
}
.icon-holder {
    width: 95px;
    min-width: 95px;
    height: 98px;
    font-size: 51px;
    border-radius: 10px;
    color: #1A451F;
    background: #C4DEC7;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 28px;
}
.service-item .cont {
    display: flex;
    flex-grow: 1;
    flex-direction: column;
    justify-content: center;
}
.service-item .cont-holder {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
.service-item .cont h3 {
    font-weight: 600;
    margin: 0 0 18px;
}
.service-item .cont p {
    margin: 0 0 23px;
}
.cta-section {
    padding: 32px 0 74px;
}
.cta-section .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.cta-section .content-info {
    max-width: 1019px;
    font-size: 25px;
    line-height: 33px;
    width: 66%;
}
.cta-section .content-info h2 {
    max-width: 766px;
    margin: 0 0 16px;
}
.local-law-style .cta-section .content-info h2 {
    max-width: 945px;
    margin: 0 0 16px;
}
.local-law-style .cta-section .container {
    align-items: flex-start;
}
.local-law-style .cta-section-services {
    padding: 180px 0 102px;
}
.ev-style .cta-section-services {
    padding: 94px 0 46px;
}
.service-desc-section.introducing_app{
    padding: 112px 0 14px;
}
.service-holder-section.introducing_app .info-holder p {
    margin: 0 0 32px;
}
.service-desc-section.introducing_app p.bold{
    font-size: 25px;
    font-weight: 300;
    color: #5F8663 !important;
    line-height: 33px !important;
    margin: 0 0 17px !important;
}
.service-desc-section.introducing_app .btn-holder{
    display: flex;
    align-items: center;
}
.service-desc-section.introducing_app .btn-holder .btn-arrow:first-child{
    margin-right: 49px;
    min-width: 158px;
}
.service-desc-section.introducing_app h2{
    margin: 0 0 38px;
}
.service-desc-section.introducing_app .info-holder{
    max-width: 656px;
}
.ev-style .cta-section-services .container {
    align-items: flex-start;
}
.ev-style .cta-section-services .img-holder {
    margin: -166px -138px 0 -85px;
    width: 32%;
}
.ev-style .cta-section .content-info h2 {
    max-width: 1033px;
    margin: 0 0 34px;
}
.rebates-style .cta-section-services {
    padding: 93px 0 0;
}
.rebates-style .cta-section-services .img-holder {
    margin: -175px -138px 0 -85px;
}
.rebates-style .cta-section .content-info h2 {
    max-width: 978px;
    margin: 0;
}
.rebates-style .cta-section .container {
    align-items: flex-start;
}
.cta-section .content-info p {
    margin: 0 0 25px;
    color: #5F8663;
}
.cta-section .img-holder {
    margin: -149px -153px 0 -85px;
    width: 45%;
}
.cta-section img {
    width: 619px;
    height: auto;
}
.why-us-section {
    padding: 0 0 112px;
}
.img-text {
    background-color: #ffffff;
    display: flex;
    border-radius: 20px;
}
.img-text .column {
    display: flex;
    flex-direction: column;
}
.img-text .column:first-child {
    width: 50%;
}
.img-text .column:last-child {
    width: 50%;
}
.img-text .img-holder {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    border-bottom-left-radius: 20px;
    border-top-left-radius: 20px;
    position: relative;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    background-blend-mode: multiply;
}
.img-text .img-holder .content {
    padding: 79px 65px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}
.img-text .img-holder span {
    color: #5CD668;
    text-transform: uppercase;
    z-index: 2;
    position: relative;
    font-size: 18px;
}
.img-text .img-holder h2 {
    color: #ffffff;
    z-index: 2;
    position: relative;
    margin: 9px 0 0;
}
.img-text .text-holder {
    padding: 79px 65px 68px 71px;
}
.img-text .text-holder p {
    margin: 0 0 25px;
    line-height: 1.2;
    color: #5F8663;
}
.img-text .text-holder p:last-of-type {
    margin: 0 0 33px;
}
.projects-section {
    padding: 0 0 75px;
}
.projects-section .btn {
    margin: 0 auto;
}
.projects-section .title-wrapper p {
    font-size: 25px;
    color: #5F8663;
}
.projects-slider, .projects-slider-home {
    margin: 0 -15px 69px;
}
.project-item {
    margin: 0 15px;
    height: auto;
}
.project-item .content {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}
.project-item .content .img-holder {
    overflow: hidden;
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
    width: 100%;
}
.project-item .content .img-holder .img {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    min-height: 317px;
    transition: 0.3s;
}
.project-item .content .img-holder:hover .img {
    transform: scale(1.07);
}
.project-item .content .img-holder img {
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
    transition: 0.3s;
}
.project-item .content .name-holder {
    border-radius: 15px;
    border-top-right-radius: 0;
    background: #fff;
    border: 1px solid #C4DEC7;
    padding: 19px;
    margin: -40px 0 0;
    z-index: 2;
    max-width: 287px;
    min-width: 287px;
}
.project-item .content .name-holder p {
    margin: 0;
    color: #1A451F;
    font-size: 25px;
}
.project-item .content .name-holder p {
    margin: 0;
    color: #1A451F;
    font-size: 25px;
    font-weight: 600;
}
.project-item .content .name-holder .category-name {
    margin: 0 0 6px;
    font-size: 12px;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 1.8px;
}
.expect-section {
    padding: 0 0 114px;
}
.header-block {
    background: white;
    border-radius: 20px;
}
.header-block .img-holder {
    padding: 92px 40px;
    position: relative;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    color: white;
    background-blend-mode: multiply;
}
.header-block .img-holder h2 {
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 2;
}
.header-block .text-holder {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 45px 47px 65px;
}
.header-block .info-block {
    margin: 0 18px;
    width: 50%;
    border-radius: 15px;
    border: 1px solid #C4DEC7;
    padding: 31px 73px 30px 59px;
    min-height: 246px;
    flex-direction: column;
    display: flex;
}
.header-block .info-block h3 {
    margin: 0 0 17px;
}
.header-block .info-block p {
    margin: 0 0 20px;
    color: #5F8663;
}
.header-block .info-block:first-child p {
    margin: 0 0 43px;
}
.reviews-section {
    padding: 0 0 194px;
}
.reviews-section .title-holder {
    display: flex;
    justify-content: space-between;
    margin: 0 0 68px;
}
.reviews-section .text-holder {
    max-width: 1151px;
    margin: 7px 0 0 60px;
    font-size: 25px;
    line-height: 33px;
}
.reviews-section .text-holder b {
    font-weight: 700;
    color: #5F8663;
}
.reviews-section .text-holder p {
    margin: 30px 0 0;
    color: #5F8663;
}
.reviews-section .review-slider {
    width: calc(100% - 311px);
}
.reviews-block {
    display: flex;
    justify-content: space-between;
    margin: 0 -12px;
}
.reviews-block .review-item {
    padding: 0 12px;
    display: flex;
    flex-direction: column;
    height: auto;
}
.reviews-block .review-item .cont {
    flex-grow: 1;
    background: white;
    border-radius: 20px;
    padding: 34px 58px 29px 56px;
    color: #5F8663;
    display: flex;
    flex-direction: column;
    max-width: 398px;
}
.reviews-block .review-item .cont p {
    font-style: italic;
    line-height: 32px;
    margin: 0 0 30px;
    flex-grow: 1;
}
.reviews-block .review-item .cont .name {
    font-size: 30px;
    margin: 0 0 2px;
    color: #1A451F;
}
.reviews-block .review-item .cont .job {
    font-size: 16px;
    margin: 0;
}
.more-reviews {
    min-width: 309px;
    display: flex;
    flex-direction: column;
    padding: 0 12px;
}
.more-reviews .cont {
    flex-grow: 1;
    background: #5F8663;
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 73px 30px;
    text-transform: uppercase;
    transition: 0.3s;
    max-width: 309px;
}
.more-reviews:hover .cont {
    background: #1A451F;
}
.more-reviews .cont p {
    margin: 0 10px 0 0;
    max-width: 103px;
    font-weight: bold;
}
.more-reviews .icon-arrow-next {
    font-size: 11px;
}
.cta-bottom-section {
    padding: 62px 0 42px;
}
.cta-bottom-section .container {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}
.ev-style .cta-bottom-section .container, .hvac-style .cta-bottom-section .container {
    align-items: center;
}
.ev-style .cta-bottom-services .text {
    max-width: 721px;
}
.cta-bottom-services p {
    font-weight: 600;
}
.cta-bottom-section .text {
    max-width: 905px;
    width: 60%;
    margin: 119px 30px 0 0;
    font-size: 25px;
    line-height: 33px;
}
.cta-bottom-section h2 {
    font-size: 65px;
    margin: 0 0 26px;
}
.cta-bottom-section p {
    margin: 0 0 35px;
    color: #5F8663;
}
.cta-bottom-section b {
    font-weight: 600;
    color: #5F8663;
    font-family: "din-2014", "Helvetica Neue", sans-serif;
}
.cta-bottom-section .btn {
    margin: 38px 0 0;
}
.cta-bottom-section .img {
    margin-right: -30px;
}
/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
.site-footer {
    background: #1A451F;
    padding: 76px 0 0;
}
figure {
    margin: 0;
}
.site-footer .container {
    display: flex;
    justify-content: space-between;
    margin: 0 auto 28px;
}
.site-footer .menu li:before {
    display: none;
}
.site-footer #block-7 {
    margin: 0 0 57px;
}
.site-footer #block-7 img {
    min-width: 225px;
}
.contact-links {
    margin: 0 0 19px;
    padding: 0;
    max-width: 310px;
    font-family: "din-2014", "Helvetica Neue", sans-serif;
}
.social-links {
    padding: 0;
    display: flex;
    align-items: center;
    margin: 0 -7px;
}
.social-links li {
    margin: 0 7px;
    font-size: 0;
    width: auto;
    height: 22px;
}
.social-links li a {
    font-size: 0;
    position: relative;
    width: 22px;
    height: 22px;
    display: block;
}
.social-links li a:before {
    position: absolute;
    top: 0;
    left: 0;
    color: #5CD668;
    font-family: 'icomoon';
    font-size: 22px !important;
}
.social-links li:first-child a {
    width: 11px;
}
.social-links li:first-child a:before {
    content: "\e907";
}
.social-links li:nth-child(2) a:before {
    content: "\e90a";
}
.social-links li:nth-child(3) a:before {
    content: "\e91c";
}
.social-links li:last-child a:before {
    content: "\e90f";
}
.site-footer .col-holder {
    display: flex;
    justify-content: flex-end;
    margin-left: 40px;
    width: auto;
}
.site-footer .col-holder .menu {
    flex-direction: column;
    align-items: flex-start;
}
.site-footer .widget-title {
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
    color: #5CD668;
    margin: 0 0 20px;
}
.site-footer .menu li {
    margin: 0 0 13px;
    font-size: 16px;
    padding: 0;
    line-height: 1;
    text-transform: uppercase;
    border-bottom: none;
}
.site-footer .menu li:hover {
    border-bottom: none;
}
.site-footer .menu li a {
    transition: 0.3s;
    font-size: 16px;
}
.site-footer .menu li a span {
    width: 5px;
    display: inline-block;
}
.site-footer .menu li a:hover {
    color: #5CD668;
}
.site-footer .menu li:last-child a:hover {
    color: #5CD668;
}
.site-footer .menu li:last-child a {
    background: transparent;
    color: #ffffff;
    margin: 0 0 13px;
    padding: 0;
    border-radius: 0;
}
#nav_menu-6 {
    margin-right: 58px;
}
#nav_menu-7 {
    margin-right: 75px;
}
#nav_menu-4 {
    margin-right: 81px;
}
#nav_menu-5 {
    max-width: 184px;
}
.site-footer .company-name {
    border-top: 1px solid #225728;
    border-bottom: 1px solid #225728;
    text-align: center;
    color: #5CD668;
    padding: 38px 0 12px;
}
.footer-bottom {
    text-align: center;
    font-size: 12px;
    line-height: 1;
    color: white;
    padding: 38px 0 41px;
    font-family: "din-2014", "Helvetica Neue", sans-serif;
}
/*--------------------------------------------------------------
# Popup
--------------------------------------------------------------*/
.popup {
    color: #333;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    min-width: 928px;
    min-height: 0;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    z-index: 1000;
    transition: transform .3s ease-in-out, opacity .3s ease-in-out, visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(26, 69, 31, 0.5);
}
.popup .close-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    display: flex;
	cursor: pointer;
}
.popup .close-btn img {
    margin: 0 !important;
}
.popup .btn {
    max-width: 178px;
    margin: 0 auto;
}
.popup .contact-form-holder h3 {
    margin-block-start: 0;
    margin-block-end: 32px;
}
.popup .thanks-holder {
    display: none;
}
.popup .apply-holder {
    display: block;
}
.popup .apply-holder.hide {
    display: none;
}
.popup .thanks-holder.show {
    display: block;
}
.popup .thanks-holder p {
    margin-block-start: 0;
    margin-block-end: 44px;
}
.popup .contact-form-holder {
    padding: 50px 50px 42px;
    border-radius: 15px;
    background: white;
    border-bottom: 30px solid #327A39;
}
.popup-wrapper {
    max-width: 650px;
    margin: 0 auto;
    transform: scale(0);
    transition: transform .3s ease-in-out, -webkit-transform .3s ease-in-out;
}
::-webkit-input-placeholder {
    color: #BAC7BB;
}
.popup-wrapper img {
    max-width: 168px;
    margin: 0 0 20px;
}
.popup.popup-open {
    opacity: 1;
    visibility: visible;
}
.popup.popup-open .popup-wrapper {
    transform: scale(1);
}
.popup-overlay {
    position: absolute;
    content: '';
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    background-color: rgba(26, 69, 31, 0.8);
    mix-blend-mode: multiply;
}
.popup-content {
    min-width: 650px;
}
.popup-content h2 {
    color: #1A451F;
    margin: 0 0 20px;
}
.popup-content p {
    color: #5F8663;
    max-width: 426px;
    margin: 0 auto 47px;
}
.form-wrapper .form-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 -8px;
}
.form-wrapper .form-row .form-field {
    width: 50%;
    padding: 0 9px 18px;
}
.form-wrapper .form-row .form-field.full-width {
    width: 100%;
    padding: 0 9px 18px;
}
.popup .thanks-holder h3 {
    color: #1A451F;
    margin: 0 0 20px;
}
/*--------------------------------------------------------------
# Popup video
--------------------------------------------------------------*/
#video-popup {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    min-width: 928px;
    min-height: 0;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    z-index: 1000;
    transition: transform .3s ease-in-out, opacity .3s ease-in-out, visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(26, 69, 31, 0.5);
}
#video-popup.popup-open {
    opacity: 1;
    visibility: visible;
}
#popup_video {
    min-width: 650px;
    position: relative;
}
#popup_video iframe {
    max-width: 1000px;
    width: 1000px !important;
    height: 563px !important;
    margin: 0 auto;
    transform: scale(0);
    transition: transform .3s ease-in-out, -webkit-transform .3s ease-in-out;
}
#video-popup.popup-open #popup_video iframe {
    transform: scale(1);
}
#fade-popup {
    position: absolute;
    content: '';
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    background-color: rgba(26, 69, 31, 0.8);
    mix-blend-mode: multiply;
}
/*--------------------------------------------------------------
# Services Page
--------------------------------------------------------------*/
.banner-dark {
    background: #1A451F;
    padding: 152px 15px 0;
    overflow: hidden;
}
.banner-dark .container {
    max-width: 1740px;
    padding: 161px 15px 154px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #1A451F;
    background-blend-mode: multiply;
    text-align: center;
    border-top-right-radius: 20px;
    border-top-left-radius: 20px;
    position: relative;
    top: 100px;
    opacity: 0;
    transition: 0.6s;
}
.banner-dark.showed .container {
    top: 0;
    opacity: 1;
}
.banner-dark .container h1 {
    margin: 0 auto 32px;
    text-transform: uppercase;
}
.banner-dark .container p {
    margin: 0 auto;
    max-width: 812px;
    color: #5CD668;
    font-size: 30px;
    line-height: 34px;
}
.service-holder-section {
    padding: 100px 0;
    display: flex;
    position: relative;
    justify-content: flex-end;
    align-items: center;
}
.service-holder-section.reverse {
    flex-direction: row-reverse;
}
.service-holder-section .img-holder {
    position: relative;
    top: 100px;
    opacity: 0;
    min-height: 780px;
    width: 46.9%;
    background-blend-mode: multiply;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
    transition: 0.6s;
}
.service-holder-section.reverse .img-holder {
    border-radius: 0 20px 20px 0;
}
.service-holder-section .title-holder {
    display: flex;
    align-items: center;
    margin: 0 0 25px;
}
.service-holder-section .icon-holder {
    margin: 0 29px 0 0;
    min-width: 95px;
}
.service-holder-section h2 {
    margin: 0;
    font-size: 55px;
}
.service-holder-section .info-holder {
    max-width: 715px;
    margin: 0 120px 0 15px;
    width: 50%;
}
.service-holder-section.reverse .info-holder {
    margin: 0 15px 0 120px;
}
.service-holder-section .info-holder p {
    color: #5F8663;
    margin: 0 0 7px;
    line-height: 32px;
}
.service-holder-section .info-holder p:last-of-type {
    margin: 0 0 35px;
}
.service-holder-section .info-holder p.bold {
    color: #1A451F;
    line-height: 24px;
    margin: 0 0 21px;
}
.service-holder-section ul {
    margin: 0 0 34px;
    padding: 0;
}
.service-holder-section ul li {
    margin: 0 0 11px;
    padding-left: 28px;
    position: relative;
    font-weight: 600;
    font-family: "din-2014", sans-serif;
}
.service-holder-section ul li:before, .proj-desc-section .service-text ul li:before {
    content: "";
    background: url("assets/img/point-sign.svg") no-repeat center;
    background-size: contain;
    width: 18px;
    height: 18px;
    position: absolute;
    top: 0;
    left: 0;
}
.services-page .projects-section {
    padding: 100px 0 0;
    margin: 0 0 -30px;
    z-index: 2;
    position: relative;
}
.services-page .cta-bottom-section {
    padding: 0 0 71px;
}
.service-holder-section.showed .img-holder {
    top: 0;
    opacity: 1;
}
/*--------------------------------------------------------------
# Service Template
--------------------------------------------------------------*/
.banner-light {
    padding: 185px 0 116px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
    overflow: hidden;
}
.banner-light:after {
    content: "";
    position: absolute;
    bottom: -35px;
    left: -55px;
    width: 1421px;
    height: 880px;
    background: url("assets/img/banner-lines.svg") no-repeat center;
    background-size: contain;
    opacity: 50%;
}
.banner-light h1 {
    color: #1A451F;
    margin: 0 0 30px;
}
.banner-light p {
    color: #1A451F;
    margin: 0 0 18px;
}
.banner-light p.bold {
    font-size: 26px;
    line-height: 32px;
    margin: 0 0 30px;
    font-weight: 600;
}
.banner-light p.big {
    font-size: 26px;
    line-height: 32px;
    color: #1A451F;
    font-weight: 600;
}
.banner-light p:last-of-type {
    margin: 0;
}
.banner-light .info-holder {
    max-width: 698px;
    margin: 0 137px 0 15px;
    width: 50%;
    position: relative;
    z-index: 1;
}
.plumbing-style .banner-light .info-holder {
    margin: -62px 137px 0 15px;
}
.banner-light .img-holder {
    position: relative;
    top: 100px;
    opacity: 0;
    min-height: 780px;
    width: 46.9%;
    background-blend-mode: multiply;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
    transition: 0.6s;
    z-index: 1;
}
.banner-light.showed .img-holder {
    top: 0;
    opacity: 1;
}
.key-info-services {
    padding: 116px 0;
}
.key-info-services .info-holder .title-header {
    padding: 71px 100px 70px;
}
.key-info-services .info-holder h3 {
    margin: 0 0 20px;
    padding: 0;
    max-width: 100%;
    text-align: left;
}
.key-info-services .info-holder p {
    margin: 0;
    padding: 0;
    max-width: 1006px;
    text-align: left;
}
.key-info-services .key-list {
    margin: 0;
    padding: 66px 80px 70px;
    justify-content: space-between;
}
.key-info-services .key-list li {
    margin: 0 20px;
    min-height: 160px;
    min-width: min-content;
}
.key-info-services .key-list li span {
    white-space: nowrap;
    text-transform: uppercase;
}
.key-info-services .key-list li p {
    margin: 30px 0 0;
}
.text-only {
    padding: 100px 0;
    text-align: center;
}
.text-only .content {
    max-width: 1030px;
    margin: 0 auto;
}
.text-only.full-width .content {
    max-width: 100%;
}
.text-only.big-text .content {
    max-width: 1316px;
}
.text-only.big-text {
    padding: 115px 0;
}
.text-only .content h2 {
    margin: 0 0 27px;
}
.hvac-style .text-only .content h2 {
    margin: 0;
}
.text-only .content p {
    margin: 0;
}
.text-only .content p.big {
    margin: 0;
    font-size: 30px;
    line-height: 40px;
    font-weight: 600;
}
.local-law-style .service-desc-section {
    background-color: white;
}
.local-law-style .service-desc-section.last {
    padding: 100px 0;
    background: white;
}
.hvac-style .service-desc-section.last {
    padding: 100px 0;
}
.cta-bottom-services .text {
    max-width: 905px;
    width: 60%;
    margin: 0 30px 0 0;
}
.plumbing-style .cta-bottom-services {
    padding: 155px 0 43px;
}
.firestoping-style .cta-bottom-services {
    padding: 162px 0 43px;
}
.steam-style .cta-bottom-services {
    padding: 143px 0 43px;
}
.rebates-style .cta-bottom-services {
    padding: 118px 0 43px;
}
.firestoping-style .cta-bottom-services .img {
    margin: -218px -30px 0 0;
}
.plumbing-style .cta-bottom-services .img {
    margin: -211px -30px 0 0;
}
.steam-style .cta-bottom-services .img {
    margin: -199px -30px 0 0;
}
.local-law-style .cta-bottom-section .container, .roof-style .cta-bottom-section .container {
    align-items: center;
}
.rebates-style .cta-bottom-services .img {
    margin: -174px -30px 0 0;
}
.cta-section-services {
    padding: 108px 0 58px;
}
.cta-section-services .img-holder {
    margin: -192px -138px 0 -85px;
    width: 45%;
}
.cta-section-services.big-content {
    padding: 100px 0;
}
.firestoping-style .cta-section-services h2 {
    font-size: 45px;
    line-height: 50px;
    margin: 0 0 33px;
    max-width: 924px !important;
}
.firestoping-style .cta-section-services .content-info {
    max-width: 924px;
}
.firestoping-style .cta-section-services .img-holder {
    margin: -233px -153px 0 -85px;
}
.local-law-style .cta-section-services .img-holder {
    margin: -312px -138px 0 -85px;
}
/*--------------------------------------------------------------
# Img-text variations
--------------------------------------------------------------*/
.img-text-section {
    padding: 100px 0;
}
.firestoping-style .img-text-section {
    padding: 0 0 127px;
}
.steam-style .img-text-section {
    padding: 116px 0 0;
}
.local-law-style .img-text-section {
    padding: 117px 0 161px;
}
.ev-style .img-text-section {
    padding: 116px 0 140px;
}
.img-text-section .img-text {
    border: 1px solid #C4DEC7;
}
.img-text-section .img-text {
    border: 1px solid #C4DEC7;
    min-height: 746px;
}
.img-text-section .img-text .text-holder {
    margin: auto 0;
}
.img-text-section h2 {
    margin: 0 0 30px;
}
.img-text-section .img-text .text-holder p {
    margin: 0 0 18px;
}
.img-text-section .img-text .text-holder p:last-of-type {
    margin: 0;
}
/*--------------------------------------------------------------
# Checkmark section variations
--------------------------------------------------------------*/
.checkmark-section {
    padding: 88px 0 67px;
}
.firestoping-style .checkmark-section {
    padding: 100px 0;
}
.hvac-style .checkmark-section {
    padding: 107px 0 26px;
}
.checkmark-section h2 {
    margin: 0 0 35px;
}
.checkmark-list {
    margin: 0 -10px;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
}
.checkmark-list li {
    padding: 0 10px;
    width: 33.33%;
}
.firestoping-style .checkmark-list li {
    padding: 0 27px;
    width: max-content;
    min-width: 245px;
}
.firestoping-style .checkmark-list {
    max-width: 1200px;
}
.checkmark-list li .cont {
    padding: 34px 0;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #C4DEC7;
}
.checkmark-list li .cont i {
    font-size: 30px;
    color: #5CD668;
    margin-right: 15px;
}
.checkmark-list li .cont p {
    margin: 0;
    font-weight: 600;
    font-size: 30px;
    line-height: 1;
    font-family: "din-2014", sans-serif;
}
.checkmark-list-2 {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -77px;
    padding: 0;
    justify-content: space-between;
}
.checkmark-list-2 li {
    padding: 0 77px;
    width: 50%;
    margin: 0 0 80px;
}
.checkmark-list-2 li h3 {
    font-size: 30px;
    line-height: 35px;
    margin: 0 0 16px;
    padding: 0 0 0 45px;
    position: relative;
}
.checkmark-list-2 li h3:before {
    content: "\e904";
    font-family: "icomoon";
    color: #5CD668;
    font-weight: 400;
    font-size: 30px;
    position: absolute;
    top: 0;
    left: 0;
}
.checkmark-list-2 li p {
    margin: 0;
}
.points-section {
    padding: 0 0 70px;
}
/*--------------------------------------------------------------
# Checkmark section variations
--------------------------------------------------------------*/
.firestoping-style .text-desc {
    padding: 96px 0 81px;
}
.text-desc {
    padding: 0 0 65px;
}
.text-desc .content {
    max-width: 1438px;
}
.firestoping-style .text-desc .content {
    max-width: 940px;
}
.text-desc p {
    font-size: 25px;
    line-height: 32px;
    margin: 0;
    color: #5F8663;
}
.text-desc .bold {
    font-size: 30px;
    line-height: 35px;
    margin: 0 0 25px;
    font-weight: 600;
    color: #1A451F;
    font-family: "din-2014", sans-serif;
}
.plumbing-style .block-icon-section {
    padding: 0 0 173px;
}
.rebates-style .block-icon-section {
    padding: 116px 0 168px;
}
.rebates-style .block-icon-section p {
    color: #5F8663;
    font-size: 25px;
    line-height: 33px;
    max-width: 923px;
    margin: 0 0 50px;
}
.steam-style .block-icon-section {
    padding: 116px 0 136px;
    background: #F5F9F5;
}
.local-law-style .block-icon-section {
    padding: 100px 0 103px;
    background-color: #F5F9F5;
}
.local-law-style .block-icon-section h2 {
    margin: 0 0 63px;
}
.ev-style .block-icon-section {
    padding: 94px 0 0;
}
.ev-style .block-icon-section p {
    color: #5F8663;
    font-size: 25px;
    line-height: 33px;
    margin: 0 0 20px;
    max-width: 1273px;
}
.ev-style .block-icon-section h2 {
    margin: 0 0 50px;
}
.ev-style .block-icon-section p.bold {
    margin: 0 0 70px;
}
.block-icon-section .slider-holder {
    display: flex;
    justify-content: space-between;
    margin: 0 -12px;
    flex-wrap: wrap;
}
.block-icon-section .service-item {
    padding: 0 12px;
    margin: 0;
    display: flex;
    width: 33.33%;
    flex-direction: column;
    border-radius: 0;
    background: transparent;
    border: none;
    min-height: auto;
}
.block-icon-section .slider-holder.col-4 .service-item {
    width: 25%;
}
.block-icon-section .slider-holder.col-2 .service-item {
    width: 50%;
    margin: 0 0 27px;
}
.block-icon-section .slider-holder.col-2 .service-item .bold {
    margin: 0 0 18px;
}
.block-icon-section .slider-holder.col-2 .service-item .title-holder {
    display: flex;
    align-items: center;
}
.block-icon-section .slider-holder.col-2 .icon-holder {
    margin: 0 30px 31px 0;
}
.block-icon-section .service-item .cont {
    display: flex;
    flex-grow: 0;
    flex-direction: column;
    justify-content: center;
}
.block-icon-section .service-item .cont-holder {
    padding: 43px 43px 38px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    border-radius: 15px;
    background: white;
    border: 1px solid #C4DEC7;
}
.block-icon-section .icon-holder {
    margin: 0 0 29px;
}
.block-icon-section .service-item .cont h3 {
    margin: 0 0 20px;
}
.plumbing-style .block-icon-section .service-item .title-holder h3 {
    margin: 0 0 14px;
    max-width: 257px;
}
.block-icon-section .service-item .cont .subtitle {
    margin: 0 0 16px;
    font-weight: 600;
    font-size: 30px;
    line-height: 35px;
    color: #1A451F;
    font-family: "din-2014", sans-serif;
}
.local-law-style .block-icon-section .service-item .cont .subtitle {
    font-size: 22px;
    line-height: 25px;
    color: #5F8663;
    max-width: 580px;
}
.block-icon-section .bold {
    font-weight: 600;
}
.block-icon-section .service-item .cont p {
    margin: 0;
    color: #5F8663;
    font-size: 22px;
    line-height: 25px;
}
.block-icon-section .title-wrapper p {
    margin: 0 0 20px;
    color: #5F8663;
}
.block-icon-section .title-wrapper p:last-of-type {
    margin: 0;
}
.tell-section {
    text-align: center;
    padding: 335px 0 82px;
    margin: -248px 0 0;
}
.tell-section a {
    color: #327A39;
}
.wrapper-title-button{
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-grow: 1;
}
.popup-btn{
    background: #1A451F;
    color: #fff;
    margin-block-end: 24px;
    padding: 16px 40px;
    margin-left: 12px;
    transition: 0.3s;
    cursor: pointer;
}
.popup-btn:hover{
    background: #5CD668;
    color:  #1A451F;
}
.popup-btn p{
    margin: 0;
    text-transform: uppercase;
    font-size: 18px;
}
/*--------------------------------------------------------------
# Accordions
--------------------------------------------------------------*/
.accordion-section {
    padding: 116px 0 83px;
}
.ev-style .accordion-section {
    padding: 100px 0 59px;
}
.accordion-content {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
}
.col-holder {
    width: 50%;
}
.accordion-item {
    padding: 0 12px;
    box-sizing: border-box;
    width: 100%;
}
.item-header {
    display: flex;
    padding: 34px 30px 34px 0;
    align-items: center;
    border-bottom: 1px solid #C4DEC7;
    cursor: pointer;
}
.item-question {
    flex-grow: 1;
    font-size: 30px;
    line-height: 1;
}
.item-header .icon-check {
    color: #5CD668;
    margin-right: 15px;
    font-size: 30px;
}
.item-header .item-icon {
    font-size: 12px;
    color: #3D9246;
    transform: rotate(90deg);
}
.item-header.active .item-icon {
    transform: rotate(270deg);
}
.ev-style .item-content {
    padding: 0 46px 38px;
    background: white;
    display: none;
    margin: -2px 0 0;
    border-bottom: 1px solid #C4DEC7;
}
.item-content {
    padding: 40px 46px;
    background: #F5F9F5;
    display: none;
}
.item-content p {
    margin: 0 0 18px;
    color: #5F8663;
}
.bold {
    font-weight: 600;
}
.item-content p:last-of-type {
    margin: 0;
}
.redesign-page .accordion-content .item-icon-rotate {
    transform: rotate(180deg);
    transition: all .1s ease-in-out;
}
.service-desc-section {
    padding: 40px 0;
}
.hvac-style .service-desc-section, .roof-style .service-desc-section, .local-law-style .service-desc-section, .roof-style .service-desc-section {
    padding: 100px 0;
}
.roof-style .service-desc-section.last {
    padding: 100px 0;
}
.roof-style .service-holder-section .info-holder p.bold {
    display: none;
}
.service-desc-section.last {
    padding: 40px 0 150px;
}
.service-desc-section p.bold {
    font-size: 30px;
    line-height: 40px !important;
    margin: 0 0 30px !important;
}
.service-desc-section .points-holder {
    margin: 0 -25px;
    display: flex;
}
.service-desc-section .points-list {
    margin: 0;
    padding: 0 25px;
    width: max-content;
}
.service-desc-section .points-list li {
    margin: 0 0 11px;
    padding-left: 28px;
    width: max-content;
}
.points-big-list, .points-check-list {
    padding: 0;
    margin: 0;
}
.points-big-list li {
    margin: 0 0 40px !important;
    padding-left: 62px !important;
    position: relative;
    font-weight: 600;
    line-height: 27px;
}
.points-big-list li span {
    font-size: 30px;
    font-weight: 600;
}
.points-big-list li p {
    font-weight: 400;
    margin: 15px 0 0 !important;
}
.hvac-style .points-big-list li p {
    font-weight: 600;
    margin: 20px 0 0 !important;
    color: #1A451F;
}
.points-big-list li:last-child {
    margin: 0;
}
.points-big-list li:before, .hvac-style .points-big-list li:before {
    content: "";
    background: url(assets/img/point-sign-2.svg) no-repeat center !important;
    background-size: contain;
    width: 43px !important;
    height: 42px !important;
    position: absolute;
    top: 50% !important;
    transform: translateY(-50%);
    left: 0;
}
.points-big-list-heading li:before {
    top: -8px !important;
    transform: none;
    left: 0;
}
.points-check-list li {
    padding: 32px 0 20px 45px !important;
    margin: 0 0 5px;
    border-bottom: 1px solid #C4DEC7;
    position: relative;
}
.points-check-list li:before {
    content: "\e904" !important;
    font-family: "icomoon";
    color: #5CD668;
    font-size: 30px;
    position: absolute !important;
    top: 38px !important;
    left: 0;
    background: none !important;
}
.title-only {
    margin: 0 0 58px !important;
    flex-direction: column;
    align-items: flex-start !important;
;
}
.title-only .small-heading {
    text-transform: uppercase;
    font-size: 18px;
    color: #327A39;
    line-height: 1;
    margin: 0 0 24px !important;
}
/*--------------------------------------------------------------
# About Page
--------------------------------------------------------------*/
.banner-about {
    background: #F7FAF7;
    position: relative;
    padding: 269px 0 77px;
    min-height: 72vh;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.banner-about:after {
    content: "";
    position: absolute;
    width: 1167px;
    height: 536px;
    background: url("assets/img/banner-about-lines.svg") no-repeat center;
    background-size: cover;
    bottom: 0;
    right: 0;
    opacity: 50%;
}
.banner-about span {
    text-transform: uppercase;
    color: #327A39;
    font-size: 18px;
    line-height: 1;
    position: relative;
    z-index: 1;
}
.banner-about h1 {
    font: 75px/77px 'din-2014', sans-serif;
    margin: 28px 0 0;
    padding: 0 0 155px;
    color: #1A451F;
    font-weight: 600;
    position: relative;
    z-index: 1;
}
.tab-holder {
    padding: 19px 15px;
    position: absolute;
    bottom: 0;
    top: auto;
    right: 0;
    left: 0;
    z-index: 5;
    background: #F7FAF7;
    width: 100%;
}
/* width */
.anchor-list::-webkit-scrollbar {
    width: 1px;
    height: 1px;
    opacity: 0;
}
/* Track */
.anchor-list::-webkit-scrollbar-track {
    background: #F7FAF7;
}
/* Handle */
.anchor-list::-webkit-scrollbar-thumb {
    background: #F7FAF7;
}
/* Handle on hover */
.anchor-list::-webkit-scrollbar-thumb:hover {
    background: #F7FAF7;
}
.tab-holder.fixed {
    position: fixed;
    top: 135px;
    bottom: auto;
    left: 0;
    right: 0;
}
.anchor-list {
    max-width: 1482px;
    margin: 0 auto;
    padding: 0;
}
.anchor-list .slick-track {
    display: flex;
    align-items: center;
}
.anchor-list .slick-list {
    overflow: visible;
}
.anchor-list .anchor-item {
    margin: 0 10px;
    display: flex;
    justify-content: center;
    max-width: max-content;
}
.anchor-list .anchor-item a {
    font-size: 16px;
    border-radius: 20px;
    background: #F7FAF7;
    transition: 0.3s;
    margin: 0;
    line-height: 1;
    padding: 11px 39px;
    color: #1A451F;
    text-transform: uppercase;
    display: block;
    text-align: center;
    width: 100%;
    white-space: nowrap;
}
.anchor-list .anchor-item a:hover {
    background: #5CD668;
}
.anchor-list .anchor-item a.active {
    background: #5CD668 !important;
}
.description-section {
    padding: 0 0 102px;
}
.description-section .img-holder {
    min-height: 717px;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}
.description-section h2 {
    max-width: 1053px;
    margin: 77px 0 56px;
    padding: 77px 0 0;
}
.text-col-holder {
    display: flex;
    justify-content: space-between;
    margin: 0 -31px;
}
.text-col {
    width: 50%;
    padding: 0 31px;
}
.text-col p {
    margin: 0 0 33px;
    color: #5F8663;
    line-height: 28px;
}
.cta-about-section {
    padding: 105px 0 97px;
}
.cta-about-section .content-info p {
    margin: 0 0 40px;
}
.cta-about-section .img-holder {
    margin: -201px -139px 0 -85px;
}
.cta-about-section .content-info h2 {
    max-width: 800px;
    margin: 0 0 27px;
}
.cta-about-section .content-info {
    max-width: 800px;
}
.values-section {
    padding: 84px 0 0;
    z-index: 1;
    position: relative;
}
.values-section .title-wrapper {
    margin: 0 0 71px;
}
.values-holder {
    margin: 0 -10px;
}
.value-item {
    margin: 0 10px;
    flex-direction: column;
    display: flex !important;
    min-height: 398px;
    height: auto;
}
.value-item .cont-holder {
    background: white;
    border-radius: 15px;
    border: 1px solid #C4DEC7;
    padding: 22px 20px 27px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
.value-item span {
    font-size: 88px;
    line-height: 1;
    margin: 0 0 28px;
    font-weight: 600;
    color: #327A39;
}
.value-item .value-name {
    font-size: 30px;
    line-height: 35px;
    margin: 0 0 16px;
    font-weight: 600;
    min-height: 70px;
    display: flex;
    align-items: center;
}
.value-item p {
    margin: 0;
    color: #3D9246;
    line-height: 29px;
}
.cta-lines {
    padding: 283px 0 134px;
    margin: -166px 0 0;
    position: relative;
}
.cta-lines:after {
    position: absolute;
    content: "";
    width: 715px;
    height: 355px;
    bottom: 0;
    right: 4.5%;
    background: url("assets/img/cta-lines.svg") no-repeat center;
    background-size: cover;
}
.cta-lines h2 {
    margin: 0 0 22px;
    max-width: 994px;
    position: relative;
    z-index: 1;
}
.cta-lines p {
    margin: 0;
    max-width: 835px;
    color: #5F8663;
    position: relative;
    z-index: 1;
    font-size: 25px;
    line-height: 33px;
}
.mission-vision {
    padding: 97px 0 0;
}
.mission-vision.reverse .img-text, .results-section.reverse .img-text {
    flex-direction: row-reverse;
}
.mission-vision .img-text {
    background: #F5F9F5;
    min-height: 746px;
}
.mission-vision .text-holder {
    padding: 79px 146px 68px 146px;
    margin: auto 0;
}
.mission-vision .img-holder .content {
    padding: 102px 65px;
}
.mission-vision.reverse .img-holder, .results-section.reverse .img-holder {
    border-radius: 0 20px 20px 0;
}
.mission-vision.reverse .img-holder .content {
    align-items: flex-end;
}
.mission-vision .text-item h3 {
    margin: 0 0 8px;
}
.mission-vision .text-item {
    margin: 0 0 72px;
}
.mission-vision .text-item:last-child {
    margin: 0;
}
.mission-vision .text-item p {
    margin: 0 !important;
    color: #3D9246;
    line-height: 28px;
}
.why-energy {
    padding: 80px 0 275px;
}
.why-energy h2 {
    margin: 0 0 44px;
}
.why-energy p {
    margin: 0 0 32px;
    color: #5F8663;
    font-size: 25px;
    line-height: 33px;
}
.why-energy p:last-of-type {
    margin: 0;
}
.we-do-section {
    padding: 0 0 45px;
    margin: 0 0 -178px;
}
.we-do-section .container {
    position: relative;
    top: -170px;
}
.we-do-section .info-holder h2 {
    font-size: 75px;
    line-height: 1;
    margin: 0 0 52px;
}
.we-do-section .img-holder {
    min-height: 591px;
    border-radius: 20px;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    margin: 0 0 69px;
}
.we-do-section .text-col p {
    margin: 0 0 33px;
    line-height: 30px;
}
.results-section {
    padding: 0 0 76px;
}
.results-section .img-text {
    background: white;
    border: 1px solid #C4DEC7;
    min-height: auto;
}
.results-section .img-text .column:first-child {
    width: 48.3%;
}
.results-section .img-text .column:last-child {
    width: 51.7%;
}
.results-section .text-holder {
    padding: 80px 70px 77px 71px;
}
.results-section h3 {
    margin: 0 0 14px !important;
}
.results-section p {
    margin: 0 0 8px !important;
    line-height: 32px;
}
.results-section p:last-of-type {
    margin: 0 !important;
}
.results-section.reverse .text-holder {
    padding: 82px 58px 82px 70px;
}
.difference-section {
    padding: 0;
}
.difference-section .info-text {
    color: white;
    background-color: #1A451F;
    border-radius: 20px 20px 0 0;
}
.difference-section .info-text .header {
    border-bottom: 1px solid rgba(234, 255, 236, 0.2);
    padding: 69px 100px;
}
.difference-section .info-text .cont {
    border-bottom: 1px solid rgba(234, 255, 236, 0.2);
    padding: 55px 100px 83px;
}
.difference-section .info-text h2 {
    margin: 0;
}
.difference-section .subtitle {
    margin: 0 0 50px;
    font-size: 30px;
    line-height: 32px;
    font-weight: 600;
}
.columns {
    display: flex;
    justify-content: space-between;
    margin: 0 -39px;
}
.col-text {
    width: 50%;
    margin: 0 37px;
}
.col-text p {
    margin: 0 0 8px;
    line-height: 32px;
}
.col-text p:last-of-type {
    margin: 0;
}
.reach-section {
    padding: 0 0 71px;
}
.reach-section .info-text {
    color: white;
    background-color: #327A39;
    padding: 56px 100px 77px;
    border-radius: 0 0 20px 20px;
}
.reach-section .header {
    margin: 0 0 55px;
}
.reach-section .subtitle {
    margin: 0 0 30px;
    font-size: 30px;
    line-height: 32px;
    font-weight: 600;
}
.reach-section p:last-of-type {
    margin: 0;
    line-height: 28px;
}
.story-section {
    padding: 71px 0 109px;
}
.story-section h2 {
    font-size: 75px;
    line-height: 78px;
    text-align: center;
    margin: 0 auto;
    max-width: 1193px;
}
.story-section .content-holder {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.story-section .text-holder {
    max-width: 775px;
    margin: 0 0 0 35px;
    font-size: 24px;
    line-height: 31px;
    color: #5F8663;
}
.story-section .text-holder p {
    margin: 0 0 40px;
}
.story-section .text-holder p.bold {
    color: #1A451F;
    font-weight: 600;
    font-family: "din-2014", sans-serif;
}
.story-section .text-holder p:last-of-type {
    margin: 0;
}
.feedback-section {
    padding: 122px 0 69px;
}
.feedback-section .reviews-block {
    display: block;
}
.feedback-section h2 {
    text-align: center;
    margin: 0 0 41px;
}
.feedback-section .subtitle {
    text-align: center;
    font-size: 30px;
    line-height: 33px;
    margin: 0 0 60px;
    color: #3D9246;
    font-weight: 600;
    font-family: "din-2014", sans-serif;
}
.feedback-section .columns {
    color: #5F8663;
    margin: 0 -39px 109px;
    line-height: 33px;
}
.feedback-section .col-text {
    margin: 0 37px;
}
.feedback-section .reviews-block {
    width: 100%;
}
.feedback-section .review-slider-arrows {
    width: 100%;
}
.feedback-section .review-slider-arrows .slick-track {
    display: block !important;
}
.feedback-section .review-slider-arrows .review-item {
    min-width: 527px;
    width: 527px !important;
    height: 364px;
}
.feedback-section .review-slider-arrows .review-item .cont {
    padding: 34px 45px 48px;
    max-width: 100%;
    min-height: 364px;
    flex-grow: 0;
}
.feedback-section .review-slider-arrows .review-item:nth-child(9) {
    min-width: 735px;
    width: 735px !important;
}
.goal-section {
    padding: 68px 0 147px;
}
.goal-section .header-block {
    border: 1px solid #C4DEC7;
}
.goal-section .header-block .img-holder {
    padding: 120px 40px;
}
.goal-section .header-block .text-holder {
    display: block;
    padding: 94px 84px 77px;
}
.goal-section .header-block .subtitle {
    text-align: center;
    font-size: 35px;
    line-height: 44px;
    max-width: 1198px;
    margin: 0 auto 73px;
}
.goal-section .header-block .footer-text {
    text-align: center;
    font-size: 30px;
    line-height: 41px;
    max-width: 1312px;
    margin: 0 auto;
}
.goal-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 -9px 32px;
    padding: 0;
}
.goal-list li {
    width: 33.33%;
    padding: 0 9px 19px;
    display: flex;
    flex-direction: column;
}
.goal-list li .goal-cont {
    display: flex;
    flex-grow: 1;
}
.goal-list li .info {
    display: flex;
    height: auto;
    align-items: center;
    background: white;
    border-radius: 15px;
    border: 1px solid #C4DEC7;
    padding: 28px 26px 27px;
    flex-grow: 1;
}
.goal-list li p {
    margin: 0;
    font-weight: 600;
    font-size: 30px;
    line-height: 35px;
    font-family: "din-2014", sans-serif;
}
.goal-list .icon-holder {
    min-width: 83px;
    width: 83px;
    height: 83px;
    font-size: 45px;
    margin: 0 26px 0 0;
}
.gallery-section {
    padding: 106px 0 0;
}
.gallery-section h2 {
    line-height: 71px;
    margin: 0 0 41px;
    max-width: 1255px;
}
.gallery-section .columns {
    margin: 0 -39.5px 81px;
    color: #5F8663;
}
.gallery-slider {
    margin: 0 -12px;
}
.gallery-item {
    margin: 0 12px;
}
.gallery-item img {
    border-radius: 20px;
    width: 100%;
}
/*--------------------------------------------------------------
# Single Project Page
--------------------------------------------------------------*/
.banner-single-proj {
    background-size: cover;
    background-repeat: no-repeat;
    background-blend-mode: multiply;
    background-position: center;
    min-height: 661px;
    display: flex;
    align-items: flex-end;
}
.banner-single-proj span {
    font-size: 22px;
    line-height: 1;
    color: #5CD668;
    text-transform: uppercase;
}
.banner-single-proj span {
    font-size: 22px;
    line-height: 1;
    color: #5CD668;
    text-transform: uppercase;
}
.banner-single-proj h2 {
    color: white;
    margin: 12px 0 16px;
}
.banner-single-proj .location {
    color: white;
    display: flex;
    align-items: center;
    margin: 0 0 100px;
}
.banner-single-proj .location p {
    margin: 0 0 0 10px;
    font-size: 30px;
    line-height: 1.2;
}
.proj-desc-section {
    padding: 96px 0 80px;
}
.proj-desc-section .content-holder {
    display: flex;
    justify-content: space-between;
}
.proj-desc-section .about-text {
    max-width: 601px;
    margin: 0 30px 0 0;
}
.proj-desc-section .about-text h2 {
    margin: 0 0 24px;
}
.proj-desc-section .about-text p {
    margin: 0;
    line-height: 32px;
    color: #5F8663;
}
.proj-desc-section .service-text {
    max-width: 800px;
    width: 55%;
    margin: 0 0 0 30px;
    background: #F5F9F5;
    border-radius: 20px;
    padding: 58px 50px 24px;
}
.proj-desc-section .service-text ul {
    margin: 0;
    padding: 0;
}
.proj-desc-section .service-text ul li {
    margin: 0 0 10px;
    padding-left: 36px;
    position: relative;
}
.proj-desc-section .service-text h2 {
    margin: 0 0 27px;
}
.breadcrumb {
    display: flex;
    align-items: center;
    margin: 0 0 25px;
    color: #5F8663;
    font-size: 16px;
}
.breadcrumb a {
    color: #5F8663;
    margin: 0 2px 0 0;
    text-decoration: underline;
}
.breadcrumb p {
    color: #5F8663;
    margin: 0 0 0 2px;
}
.project-images-section {
    padding: 80px 0 70px;
}
.img-list {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
    margin: 0 -12px;
}
.img-list li {
    width: 33.33%;
    padding: 0 12px;
    margin: 0 0 23px;
    display: block;
}
.project-images-section .img-list img{
    border-radius: 20px;
}
.nav-holder {
    padding: 0 0 90px;
}
.nav-holder .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.nav-prev a, .nav-next a {
    color: #1A451F;
    font-size: 30px;
    padding: 0 33px;
    position: relative;
}
.nav-prev a:before, .nav-next a:before {
    content: "\e900";
    font-family: 'icomoon';
    font-size: 17px;
    color: #1A451F;
    position: absolute;
    top: 8px;
    left: 0;
    transform: scaleX(-1);
}
.nav-next a:before {
    left: auto;
    right: 0;
    transform: none;
}
/*--------------------------------------------------------------
# Contact Us
--------------------------------------------------------------*/
.banner-contact {
    max-height: 500px;
    padding: 238px 0 164px;
    position: relative;
}
.banner-contact:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 920px;
    height: 434px;
    background: url("assets/img/contact-lines.svg") no-repeat center;
    background-size: contain;
    opacity: 50%;
}
.banner-contact h1 {
    line-height: 1;
    margin: 0 auto;
    text-align: center;
    color: #1A451F;
    position: relative;
    z-index: 1;
}
.contact-info {
    padding: 76px 0 90px;
}
.contact-info .container {
    display: flex;
    justify-content: space-between;
}
.forms-holder {
    max-width: 710px;
    width: 50%;
    margin: 5px 47px 0 0;
}
.contact-details-holder {
    max-width: 745px;
    width: 50%;
    margin: 0 0 0 47px;
}
.tab-holder-contact {
    display: flex;
    align-items: center;
    padding: 0 0 0 25px;
}
.tab-holder-contact .tab {
    padding: 15px 27px 13px;
    background: #327A39;
    margin: 0 5px;
    border-radius: 8px 8px 0 0;
    cursor: pointer;
}
.tab-holder-contact .tab.active {
    background: #F5F9F5;
}
.tab-holder-contact .tab.active p {
    color: #1A451F;
    font-family: "din-2014", sans-serif;
}
.tab-holder-contact .tab p {
    color: white;
    text-transform: uppercase;
    font-size: 16px;
    line-height: 1;
    margin: 0;
}
.form-cont-holder {
    background: #F5F9F5;
    padding: 41px 30px 20px;
    border-radius: 8px;
}
.cont-1, .cont-2 {
    display: none;
}
.cont-1.active, .cont-2.active {
    display: block;
}
.contacts {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 -20px 48px;
    padding: 0;
}
.contacts li {
    width: 44.2%;
    padding: 0 20px;
    margin: 0 0 20px;
}
.contacts li p {
    line-height: 1;
    margin: 0 0 10px;
    color: #5F8663;
}
.contacts li .phone {
    font-size: 45px;
    color: #1A451F;
    margin: 0;
    font-weight: 600;
}
.contacts li .hours {
    font-size: 25px;
    line-height: 33px;
    margin: 0;
    font-weight: 600;
    color: #1A451F;
    font-family: "din-2014", sans-serif;
}
.contacts li .email {
    font-size: 35px;
    margin: 0;
    font-weight: 600;
    color: #1A451F;
}
.contacts li .address {
    font-size: 30px;
    line-height: 34px;
    margin: 0;
    font-weight: 600;
    color: #1A451F;
    font-family: "din-2014", sans-serif;
}
.map-holder {
    min-height: 412px;
    margin: 0 0 50px;
}
.map-holder iframe {
    width: 100%;
    border-radius: 20px;
}
.g-recaptcha {
    margin: 0 0 37px;
}
.g-recaptcha iframe body .rc-anchor-light.rc-anchor-normal, .g-recaptcha iframe body .rc-anchor-light.rc-anchor-compact {
    border: none !important;
    border-radius: 8px;
}
.request-call {
    border-radius: 20px;
    padding: 55px 41px 55px 71px;
}
.request-call h2 {
    font-size: 45px;
    line-height: 1;
    margin: 0 0 19px;
}
.request-call .form-wrapper {
    position: relative;
}
.form-wrapper .btn-small {
    padding: 17px 64px 15px;
}
.request-call .btn {
    position: absolute;
    top: 0;
    right: 0;
    padding: 13px 52px 11px;
}
.request-call .form-control {
    max-width: 470px;
}
.thanks-holder {
    display: none;
}
.thanks-holder.show {
    display: block;
}
.form-wrapper h3 {
    font-size: 30px;
    line-height: 1;
    margin: 0;
}
.date {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 0 41px;
}
.flatpickr-day.selected {
    background: #5CD668;
    border-color: #5CD668;
}
.flatpickr-day.today {
    border-color: #1A451F;
}
.flatpickr-day {
    color: #1A451F;
}
span.flatpickr-weekday {
    color: #5F8663;
}
.flatpickr-months .flatpickr-month {
    fill: #1A451F;
}
.flatpickr-current-month .flatpickr-monthDropdown-months, .flatpickr-current-month input.cur-year {
    color: #1A451F;
}
.flatpickr-months .flatpickr-prev-month, .flatpickr-months .flatpickr-next-month {
    color: #5CD668;
    fill: #5CD668;
}
.flatpickr-months .flatpickr-prev-month:hover svg, .flatpickr-months .flatpickr-next-month:hover svg {
    fill: #1A451F;
}
.flatpickr-day.inRange, .flatpickr-day.prevMonthDay.inRange, .flatpickr-day.nextMonthDay.inRange, .flatpickr-day.today.inRange, .flatpickr-day.prevMonthDay.today.inRange, .flatpickr-day.nextMonthDay.today.inRange, .flatpickr-day:hover, .flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover, .flatpickr-day:focus, .flatpickr-day.prevMonthDay:focus, .flatpickr-day.nextMonthDay:focus {
    background: rgba(92, 214, 104, 0.3);
    border-color: rgba(92, 214, 104, 0.3);
}
.date .form-field {
    width: 50%;
    max-width: 315px;
}
.form-wrapper .service-title {
    margin: 10px 0 0 !important;
}
.cont-2 textarea {
    margin: 0 9px 18px;
}
.checkbox-list {
    padding: 0;
    margin: 21px -10px 12px;
    display: flex;
    flex-wrap: wrap;
}
.checkbox-list li {
    width: 50%;
    padding: 0 10px;
    margin: 0 0 16px;
}
.checkbox {
    display: flex;
    align-items: center;
}
.checkbox label {
    margin: 0 0 0 10px;
    color: #1A451F;
    font-size: 18px;
    line-height: 1;
}
[type="checkbox"] {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
    background-color: #fff;
    width: 20px;
    height: 20px;
    border: 1px solid #C4DEC7;
    border-radius: 5px;
    display: grid;
    place-content: center;
    cursor: pointer;
}
[type="checkbox"]::before {
    content: "";
    width: 0.65em;
    height: 0.65em;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    transform-origin: bottom left;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
    background-color: #1A451F;
}
[type="checkbox"]:checked::before {
    transform: scale(1);
}
/*--------------------------------------------------------------
# Projects page
--------------------------------------------------------------*/
.projects-banner .container p {
    font-size: 26px;
    line-height: 34px;
    max-width: 710px;
}
.projects-banner .container .subtitle {
    font-size: 32px;
    color: white;
}
.filter-section .container, .featured-section .container, .logos-section .container {
    max-width: 1337px;
}
.filter-section {
    padding: 83px 0 62px;
}
.filter-holder {
    display: flex;
    justify-content: space-between;
}
.filter-holder h2 {
    font: 35px/38px 'din-2014', sans-serif;
    margin: 0;
    max-width: 746px;
    font-weight: 600;
}
.filter-select {
    align-items: center;
    display: flex;
    min-width: 445px;
}
.filter-select p {
    text-transform: uppercase;
    white-space: nowrap;
    font-size: 18px;
    line-height: 1;
    margin: 0 17px 0 0;
    font-family: "din-2014", sans-serif;
}
.custom-select {
    position: relative;
    width: 100%;
}
.custom-select select {
    display: none;
    /*hide original SELECT element: */
}
.select-selected {
    color: #001602;
    background-color: #5CD668;
    border-color: #5CD668 !important;
    border-radius: 23px;
    border: 1px solid;
    padding: 9px 20px;
    height: 46px;
}
.select-selected.selected-filter {
    color: #001602;
    background-color: #F0F3F0;
}
.select-selected:after {
    position: absolute;
    top: 18px;
    right: 20px;
    content: "\e900";
    font-family: 'icomoon';
    font-size: 10px;
    transform: rotate(90deg);
    color: #1A451F;
}
.select-selected.select-arrow-active:after {
    transform: rotate(270deg);
    top: 17px;
}
.reset-btn {
    display: none;
    cursor: pointer;
    width: 44px;
    height: 44px;
    position: absolute;
    right: 1px;
    top: 1px;
    background: #F0F3F0;
    z-index: 2;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}
.reset-btn.show {
    display: flex;
}
/* style the items (options), including the selected item: */
.select-items div, .select-selected {
    color: #1A451F;
    padding: 7px 50px 7px 20px;
    cursor: pointer;
    text-transform: uppercase;
    font: 16px/1 'din-2014', sans-serif;
    display: flex;
    align-items: center;
}
/* Style items (options): */
.select-items {
    position: absolute;
    background-color: white;
    border-radius: 15px;
    border: 1px solid #C4DEC7;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 99;
    padding: 17px 0;
}
/* Hide the items when the select box is closed: */
.select-hide {
    display: none;
}
.select-items div:hover, .same-as-selected {
    color: #5CD668 !important;
}
.featured-section {
    padding: 45px 0 7px;
}
.featured-section .title-wrapper {
    margin: 0 0 79px;
}
.featured-section .title-wrapper h2 {
    font-size: 45px;
    margin: 0;
    padding: 0 0 18px;
    border-bottom: 1px solid #C4DEC7;
}
.projects-slider-2 {
    display: flex;
    margin: 0 -15px;
    flex-wrap: wrap;
}
.projects-slider-2 .project-item {
    width: 33.33%;
    padding: 0 15px;
    margin: 0 0 75px;
}
.filter-holder-section {
    padding: 65px 0 0;
}
.filter-holder-section.last {
    padding: 65px 0 78px;
}
.logo-list {
    margin: 0 -37px;
    padding: 0;
}
.logo-list .slick-list {
    overflow: visible !important;
}
.logos-section {
    padding: 116px 0 105px;
}
.logos-section h2 {
    margin: 0 0 59px;
}
.logo-list li {
    display: flex !important;
    align-items: center;
    min-height: 104px;
    padding: 0 37px 37px;
    justify-content: center;
}
/*--------------------------------------------------------------
# Privacy page
--------------------------------------------------------------*/
.entry-content,.entry-header{
    max-width: 1580px;
    padding: 0 15px 26px;
    margin: 0 auto;
}
.entry-header{
    padding: 245px 15px 0;
}
.entry-title{
    color: #1A451F;
    font: 75px/91px 'din-2014', sans-serif;
    margin: 0 0 30px;
    font-weight: 600;
    letter-spacing: -3px;
}
.modifaed{
    color: #5F8663;
    margin: 0 0 30px;
}
.entry-content p {
    margin-bottom: 32px;
    margin-block-start: 0;
    letter-spacing: -0.88px;
    font: 22px/32px 'din-2014', sans-serif;
}
.entry-content .margin-big{
    margin-bottom: 52px;
    margin-block-start: 0;
}
.entry-content .margin-big2{
    margin-bottom: 66px;
    margin-block-start: 0;
}
.entry-content .margin-big3{
    margin-bottom:98px;
    margin-block-start: 0;
}
.entry-content .text-small{
font-size: 14px;
    line-height: 32px;
}
.entry-content ul{
    list-style: inherit;
    margin: 0 0 61px;
}
.entry-content ul li{
    margin: 0 0 40px;
}
.entry-content a {
    color: #5CD668;
}
.entry-content a:hover {
    color: #5F8663;
}
.entry-content .btn-arrow {
    color: #3D9246;
    letter-spacing: 0;
    margin: 90px 0 0;
}

.popup-content .form-field p, .popup-content .text-area p, .form-field p, .text-area p, .checkbox-list p {
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
}

.checkbox-list p {
    text-align: left;
}

.popup-content .text-area p, .text-area p {
    margin: 0 -8px;
}

.popup-content .wpcf7-response-output {
    display: none !important;
}

.wpcf7-response-output {
    border: none !important;
}

.wpcf7-list-item label {
    display: flex;
    gap: 10px;
}

.wpcf7-list-item label input[type="checkbox"] {
    min-width: 20px;
}

.checkbox-list .wpcf7-form-control-wrap .wpcf7-form-control.wpcf7-checkbox {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.popup-content {
    overflow-y: auto;
    max-height: 90vh;
    scrollbar-width: thin;
}

.green_tel a[href*="tel:"] {
    color: #5DD669;
}

.tell-section .btn {
    margin: 20px auto 0;
}

/*--------------------------------------------------------------
# Responsive
--------------------------------------------------------------*/
@media only screen and (max-width: 1600px) {
    .services-slider {
        margin: 0 15px;
    }
    .service-item {
        padding-right: 30px;
    }
    .projects-slider, .projects-slider-home {
        margin: 0 25px 69px;
    }
    .cta-bottom-section .img {
        margin-right: 0;
    }
    .gallery-slider {
        margin: 0 12px;
    }
    .review-slider-arrows {
        margin: 0 24px;
    }
    .reviews-block {
        justify-content: center;
        margin: 0;
    }
    .banner video {
        width: auto;
        height: 100%;
    }
}
@media only screen and (max-width: 1440px) {
    .key-list li:first-child {
        min-width: auto;
    }
    .key-list li:nth-child(2), .key-list li:last-child {
        min-width: auto;
    }
    .key-list li:nth-child(3) {
        min-width: auto;
    }
    .key-list li:nth-child(4) {
        min-width: auto;
    }
    .key-list {
        padding: 65px 0 83px;
    }
    .cta-section .content-info {
        padding: 40px 0;
    }
    .cta-section .img-holder {
        margin: -126px -95px 0 -85px;
        width: 45%;
    }
    .banner-light .info-holder {
        margin: 0 80px 0 15px;
    }
    .key-info-services .info-holder .title-header {
        padding: 71px 50px 70px;
    }
    .key-info-services .key-list {
        padding: 66px 30px 70px;
    }
    .cta-section-services.big-content .img-holder {
        margin: -233px 0 0 0;
    }
    .service-holder-section.reverse .info-holder {
        margin: 0 15px 0 50px;
    }
    .service-holder-section .info-holder {
        margin: 0 50px 0 15px;
    }
    .goal-section .header-block .text-holder {
        display: block;
        padding: 94px 30px 77px;
    }
    .anchor-list li a {
        padding: 11px 30px;
    }
    .banner-about h1 {
        padding: 0 0 100px;
    }
    .contact-details-holder {
        margin: 0 0 0 20px;
    }
    .forms-holder {
        margin: 5px 20px 0 0;
    }
    .rebates-style .cta-section .img-holder {
        margin: -192px -138px 0 -85px;
    }
    .anchor-list .anchor-item a {
        padding: 11px 30px;
    }
    .anchor-list {
        max-width: 1300px;
    }
}
@media only screen and (max-width: 1280px) {
    .has-sub-menu-services .sub-menu li a {
        padding: 12px 50px 12px 20px !important;
    }
    .service-desc-section.introducing_app {
        padding: 80px 0 ;
    }
    .key-list {
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .key-list li {
        margin: 0 38px 16px;
        min-height: auto;
        width: 40%;
    }
    .cta-bottom-section {
        padding: 0 0 60px;
    }
    .cta-bottom-section .container {
        flex-direction: column-reverse;
    }
    .local-law-style .cta-bottom-section .container, .roof-style .cta-bottom-section .container {
        align-items: flex-start;
    }
    .cta-bottom-section .img {
        margin: -45px 0 30px;
    }
    .cta-bottom-section .text {
        max-width: 100%;
        width: 100%;
        margin: 0;
        font-size: 18px;
        line-height: 24px;
    }
    .cta-bottom-section h2 {
        margin: 0 0 22px;
    }
    .cta-bottom-section p {
        margin: 0 0 20px;
    }
    .cta-bottom-section .btn {
        margin: 30px 0 0;
        font-size: 20px;
        padding: 17px 30px;
    }
    .cta-section {
        margin: 0;
        padding: 40px 0 82px;
    }
    .cta-section .content-info {
        padding: 0;
    }
    #nav_menu-7, #nav_menu-4, #nav_menu-6 {
        margin-right: 40px;
    }
    .reviews-block {
        flex-wrap: wrap;
    }
    .reviews-block .review-item {
        margin: 0 0 40px;
        width: 33.33%;
    }
    .reviews-block .review-item .cont {
        max-width: 100%;
    }
    .more-reviews {
        min-width: 100%;
    }
    .more-reviews .cont {
        max-width: 100%;
        padding: 27px 54px 21px 54px;
        border-radius: 10px;
    }
    .more-reviews .cont p {
        margin-right: 30px;
        max-width: max-content;
    }
    .more-reviews .icon-arrow-next {
        margin: -5px 0 0;
    }
    .reviews-block .review-item .cont {
        border-radius: 10px;
    }
    .reviews-section {
        padding: 0 0 113px;
    }
    .reviews-section .review-slider {
        width: 100%;
    }
    .service-holder-section .info-holder {
        margin: 0 60px 0 15px;
        width: 50%;
    }
    .service-holder-section.reverse .info-holder {
        margin: 0 15px 0 60px;
    }
    .services-page .projects-section {
        padding: 70px 0 78px;
        margin: 0;
    }
    .services-page .cta-bottom-section .img {
        margin: 0 0 30px;
    }
    .block-icon-section .slider-holder.col-4 .service-item {
        width: 50%;
        margin: 0 0 20px;
    }
    .ev-style .accordion-section, .accordion-section {
        padding: 80px 0;
    }
    .col-holder {
        width: 100%;
    }
    .accordion-section .title-wrapper {
        margin: 0 0 20px;
    }
    .banner-about h1 {
        font: 65px/67px 'din-2014', sans-serif;
        font-weight: 600;
    }
    .anchor-list li {
        margin: 0;
    }
    .banner-about {
        padding: 150px 0 0;
    }
    .mission-vision .text-holder {
        padding: 79px 80px 68px 80px;
    }
    .story-section h2 {
        font-size: 65px;
        line-height: 68px;
        text-align: center;
        margin: 0 auto 40px;
    }
    .story-section .text-holder {
        max-width: 50%;
        margin: 0 0 0 35px;
        font-size: 22px;
        line-height: 31px;
        color: #5F8663;
    }
    .goal-list li {
        width: 50%;
    }
    .gallery-section {
        padding: 106px 0 172px;
    }
    .banner-single-proj {
        min-height: 550px;
    }
    .proj-desc-section {
        padding: 80px 0;
    }
    .logo-list {
        margin: 0 -20px;
    }
    .logo-list li {
        padding: 0 20px 37px;
    }
    .checkmark-list-2 {
        margin: 0 -30px;
    }
    .checkmark-list-2 li {
        padding: 0 30px;
        margin: 0 0 60px;
    }
    .plumbing-style .cta-bottom-services .img, .firestoping-style .cta-bottom-services .img, .steam-style .cta-bottom-services .img {
        margin: -180px 0 30px 0;
    }
    .rebates-style .cta-bottom-services .img {
        margin: -150px 0 30px 0;
    }
    .rebates-style .cta-section-services {
        padding: 93px 0 60px;
    }
    .ev-style .cta-bottom-section .container, .hvac-style .cta-bottom-section .container {
        align-items: flex-start;
    }
}
@media only screen and (max-width: 1024px) {
    .wrapper-title-button{
        flex-direction: column;
        align-items: flex-start;
    }
    .service-desc-section.introducing_app .info-holder {
        max-width: 100%;
    }
    .wrapper-title-button h3{
        margin-bottom: 8px;
    }
    .popup-btn{
        margin-left: 0;
    }
    #popup_video iframe {
        max-width: 800px;
        width: 800px !important;
        height: 450px !important;
    }
    .cta-section .container {
        flex-direction: column-reverse;
        align-items: flex-start;
    }
    .cta-section .content-info {
        max-width: 100%;
        width: 100%;
    }
    .header-block .text-holder {
        padding: 0;
        flex-direction: column;
    }
    .header-block .img-holder {
        padding: 50px 20px;
    }
    .header-block .info-block {
        width: 100%;
        margin: 0;
        border-radius: 0;
        border: none;
        border-bottom: 1px solid #C4DEC7;
        padding: 30px 20px;
        min-height: auto;
    }
    .header-block .info-block:last-child {
        border-bottom: none;
    }
    .header-block .info-block:first-child p {
        margin: 0 0 20px;
    }
    .img-text {
        flex-direction: column;
        border-radius: 10px;
    }
    .img-text .column:first-child {
        width: 100%;
    }
    .img-text .img-holder {
        border-top-right-radius: 10px;
        border-bottom-left-radius: 0;
        border-top-left-radius: 10px;
        min-height: 338px;
    }
    .img-text .img-holder:after {
        border-top-right-radius: 10px;
        border-bottom-left-radius: 0;
        border-top-left-radius: 10px;
    }
    .img-text .img-holder .content {
        padding: 36px 20px;
        align-items: center;
        text-align: center;
    }
    .img-text .column:last-child {
        width: 100%;
    }
    .img-text .text-holder {
        padding: 30px 20px 40px;
    }
    .img-text .text-holder p {
        margin: 0 0 18px;
    }
    .reviews-section .title-holder {
        flex-direction: column;
        margin: 0 0 40px;
    }
    .reviews-section .text-holder {
        max-width: 100%;
        margin: 0;
        font-size: 18px;
        line-height: 24px;
    }
    .reviews-section .text-holder p {
        margin: 18px 0 0;
    }
    .site-footer .container {
        display: flex;
        flex-direction: column;
        margin: 0 auto;
    }
    .site-footer .container .col {
        margin: 0 0 61px;
    }
    .site-footer {
        padding: 60px 0 0;
    }
    .site-footer #block-7 {
        margin: 0 0 30px;
    }
    .site-footer .col-holder {
        flex-direction: column;
        margin-left: 0;
    }
    .site-footer .container .col-holder .col {
        margin: 0 0 34px;
    }
    #nav_menu-7, #nav_menu-4, #nav_menu-6 {
        margin-right: 0;
    }
    #nav_menu-5 {
        max-width: 100%;
    }
    .site-footer .company-name {
        padding: 30px 0;
    }
    .site-footer .company-name h2 {
        font-size: 31px;
        margin: 0;
        line-height: 1;
    }
    .footer-bottom {
        padding: 22px 0;
    }
    .service-holder-section, .service-holder-section.reverse {
        flex-direction: column-reverse;
        padding: 60px 0;
    }
    .service-holder-section .img-holder, .service-holder-section.reverse .img-holder {
        max-width: 100%;
        min-height: 500px;
        width: calc(100% - 30px);
        border-radius: 10px;
        margin: 0 auto 30px;
    }
    .service-holder-section .info-holder, .service-holder-section.reverse .info-holder {
        margin: 0;
        padding: 0 15px;
        width: 100%;
        max-width: 100%;
    }
    .banner-about h1 {
        padding: 0 0 60px;
    }
    .tab-holder {
        padding: 14px 15px;
    }
    .mission-vision .img-holder .content {
        align-items: flex-start;
        text-align: left;
    }
    .mission-vision.reverse .img-text, .results-section.reverse .img-text {
        flex-direction: column;
    }
    .mission-vision .img-text .img-holder {
        min-height: 327px;
    }
    .mission-vision .text-item {
        margin: 0 0 26px;
    }
    .mission-vision.reverse .img-text .img-holder {
        border-top-right-radius: 10px;
        border-bottom-left-radius: 0;
        border-top-left-radius: 10px;
        min-height: 327px;
    }
    .mission-vision .text-holder {
        padding: 40px 20px;
    }
    .mission-vision.reverse .img-holder .content {
        align-items: flex-start;
    }
    .results-section .img-text .column:first-child, .results-section .img-text .column:last-child {
        width: 100%;
    }
    .mission-vision.reverse .img-holder, .results-section.reverse .img-holder {
        border-radius: 10px 10px 0 0;
    }
    .results-section.reverse .text-holder, .results-section .text-holder {
        padding: 30px 20px;
    }
    .difference-section .info-text .header {
        padding: 28px 20px;
    }
    .difference-section .info-text h2 {
        text-align: center;
    }
    .difference-section .info-text .cont {
        padding: 27px 20px 15px;
    }
    .difference-section .info-text {
        border-radius: 10px 10px 0 0;
    }
    .reach-section .info-text {
        padding: 27px 20px;
        border-radius: 0 0 10px 10px;
    }
    .story-section {
        padding: 71px 0 48px;
    }
    .story-section .content-holder {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }
    .story-section .text-holder {
        max-width: 100%;
        margin: 29px 0 0;
        font-size: 18px;
        line-height: 24px;
    }
    .story-section .text-holder p {
        margin: 0 0 23px;
    }
    .story-section h2 {
        margin: 0 auto 20px;
    }
    .review-slider-arrows {
        margin: 0 40px;
    }
    .proj-desc-section .about-text {
        max-width: 480px;
        margin: 0;
    }
    .contact-info .container {
        flex-direction: column;
    }
    .forms-holder {
        margin: 0 0 60px;
        width: 100%;
        max-width: 100%;
    }
    .contact-details-holder {
        margin: 0;
        width: 100%;
        max-width: 100%;
    }
    .request-call .form-control {
        max-width: calc(100% - 50px);
    }
    .filter-holder {
        flex-direction: column;
    }
    .filter-holder h2 {
        margin: 0 0 30px;
        max-width: 100%;
    }
    .custom-select {
        max-width: 370px;
    }
    .logo-list li {
        width: 33.33%;
    }
    .projects-slider-2 .project-item {
        width: 50%;
        margin: 0 0 50px;
    }
}
@media only screen and (max-width: 992px) {
    .site-header .custom-logo-link img {
        max-width: 142px;
    }
    .service-holder-section.introducing_app .info-holder p:last-of-type {
        margin: 0 0 32px;
    }
    .projects-section .btn {
        margin: 40px auto 0;
    }
    .container {
        padding: 0 25px;
    }
    h1 {
        font: 48px/48px 'din-2014', sans-serif;
        font-weight: 600;
    }
    h2 {
        font: 40px/46px 'din-2014', sans-serif;
        font-weight: 600;
    }
    body {
        font: 18px/24px 'din-2014', sans-serif;
    }
    .site-header {
        padding: 24.7px 0;
    }
    .sub-menu {
        display: none;
    }
    .menu .menu-item-has-children:hover .sub-menu {
        display: none;
    }
    .has-children-background.open:after, .submenu-opener.open:after {
        transform: scaleY(-1) rotate(90deg);
    }
    .menu .menu-item-has-children .sub-menu {
        visibility: visible;
        padding: 0 0 16px;
    }
    .sub-menu li h3 a {
        display: block;
    }
    .menu .menu-item-has-children:after {
        right: 31px;
        color: #327A39;
        font-size: 10px;
        top: 25px;
        font-weight: 600;
    }
    .sub-menu li {
        margin: 15px 25px;
        width: 100% !important;
        border-bottom: none !important;
    }
    .sub-menu li:first-child {
        margin: 30px 25px 15px;
    }
    .sub-menu li.menu-item-background a:after {
        font-size: 13px;
    }
    .menu-toggler {
        position: relative;
        z-index: 100;
        width: 36px;
        height: 36px;
        display: flex;
        align-items: flex-end;
        justify-content: center;
        flex-direction: column;
    }
    .site-header .menu-menu-main-container {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        transform: translateY(-150%);
        background-color: #fff;
        height: calc(100vh - 75.3px);
        overflow-y: auto;
        overflow-x: hidden;
        z-index: -1;
        padding: 0 0 30px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        margin: 24.7px 0 0;
    }
    .menu-menu-main-container .menu li:first-child, .menu-menu-main-container .menu li:nth-child(2) {
        margin: 0;
    }
    .menu li {
        margin: 0;
        position: relative;
        padding: 0;
        width: 100%;
    }
    .menu li:nth-child(3) {
        margin-left: 0;
    }
    .menu li a {
        color: #327A39;
        padding: 25px;
        display: block;
        border-bottom: 1px solid #C4DEC7;
    }
    .menu-menu-main-container .menu li:nth-child(2) a::before {
        right: 25px;
        top: 16px;
    }
    .menu-menu-main-container .menu li:nth-child(2) {
        display: block;
        position: relative;
    }
    .menu-menu-main-container .menu li:nth-child(2) a {
        display: block;
        width: 100%;
        margin: 0;
    }
    .submenu-opener {
        position: absolute;
        top: 11px;
        right: 7.5px;
        margin: 0;
        border-bottom: none !important;
        width: 30px !important;
        z-index: 2;
        background: white;
    }
    .submenu-opener:after {
        content: "\e900";
        font-family: 'icomoon';
        font-size: 10px;
        font-weight: 600;
        color: #327A39;
        position: absolute;
        top: 33%;
        left: 41%;
        transform: rotate(90deg) translate(-50%);
        z-index: 2;
    }
    .menu-menu-main-container .menu li:nth-child(2) a::before {
        display: none;
    }
    .menu-menu-main-container .menu li:nth-child(2) a.submenu-opener::before {
        display: block
    }
    .sub-menu.show {
        flex-direction: column;
    }
    .sub-menu li:first-child {
        max-width: 100%;
    }
    .sub-menu li {
        display: block !important;
        width: 100%;
        max-width: 100%;
    }
    .menu-menu-main-container .menu li.menu-item-has-children .sub-menu h3 {
        font-size: 16px;
        margin: 0 0 30px;
        display: block;
    }
    .sub-menu li:nth-child(2) {
        max-width: 100%;
    }
    .sub-menu {
        position: relative;
    }
    .menu-menu-main-container .menu {
        flex-direction: column;
        align-items: flex-start;
    }
    .menu-main-menu-container {
        width: 100%;
    }
    .open-header-menu .wrapper .site-header:after {
        background-color: #F5F9F5;
    }
    .menu li:last-child {
        margin: 30px auto 0;
        display: block;
        padding: 0;
    }
    .menu li:last-child a {
        display: block;
        margin: 0 auto;
        width: max-content;
    }
    .menu .menu-item-has-children .sub-menu {
        position: relative;
        max-width: 100%;
        top: auto;
        width: 100%;
        background: #F5F9F5;
        border: none;
        border-radius: 0;
        flex-wrap: nowrap;
        flex-direction: column;
    }
    .sub-menu li a {
        padding: 13.5px 25px !important;
        display: block;
        position: relative;
    }
    .sub-menu li:last-child a {
        margin: 0;
        width: 100%;
    }
    .sub-menu li.menu-item-background a {
        padding: 36px 25px 13.5px !important;
        color: #1A451F !important;
        font-size: 18px !important;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
        display: block;
        position: relative;
        background: #F5F9F5 !important;
    }
    .sub-menu li.menu-item-background a:before {
        display: none;
    }
    .menu li.menu-item-has-children:before {
        display: none;
    }
    .sub-menu li.menu-item-background a span:before {
        display: none;
    }
    .sub-menu li a {
        border-bottom: none !important;
    }
    .has-sub-menu-services .sub-menu {
        max-width: 100%;
        padding: 16px 0 20px !important;
        flex-wrap: nowrap;
        flex-direction: column;
    }
    .has-sub-menu-services .sub-menu li a {
        padding: 16px 25px !important;
        display: flex !important;
    }
    .has-sub-menu-services .sub-menu li a p {
        font-size: 18px;
    }
    .has-sub-menu-services .sub-menu li:first-child a p {
        max-width: 170px;
    }
    .has-sub-menu-services .sub-menu li a i {
        margin-right: 27px;
    }
    .has-sub-menu-services .sub-menu li a:after {
        right: 25px;
    }
    .banner .btn-holder {
        flex-direction: column;
        align-items: flex-start;
    }
    .video-btn {
        padding: 0 27px;
        margin: 0 0 20px;
    }
    .banner p {
        margin: 0 0 27px;
    }
    .video-btn p {
        margin: 0;
        font-size: 20px;
    }
    .title-wrapper {
        margin: 0 0 37px;
    }
    .title-wrapper h2 {
        margin: 0 0 10px;
    }
    .key-info {
        padding: 60px 0 77px;
    }
    .key-info .info-holder h3 {
        font-size: 25px;
        line-height: 31px;
        padding: 0 20px 0;
    }
    .key-info .info-holder .title-header {
        padding: 27px 0;
    }
    .key-list {
        padding: 20px 0 24px;
    }
    .key-list li p {
        margin: 17px 0 14px;
    }
    .key-list li:before {
        width: 4px;
    }
    .key-list li {
        width: 100%;
        margin: 0 20px 16px;
        padding: 16px 0 0 16px;
    }
    .key-list li span {
        font-size: 45px;
    }
    .sub-menu li a:after {
        content: "\e900";
        position: absolute;
        top: 50%;
        right: 25px;
        transform: translateY(-50%);
        font-family: "icomoon";
        font-size: 13px;
        color: #327A39;
    }
    .cta-section .content-info {
        font-size: 20px;
        line-height: 26px;
    }
    .key-info .info-holder {
        border-radius: 10px;
    }
    .title-wrapper p {
        font-size: 18px;
        line-height: 24px;
    }
    .cta-section .img-holder {
        margin: -93px 0 22px -46px;
        width: 70%;
    }
    .cta-section .content-info h2 {
        max-width: 100%;
        margin: 0 0 24px;
    }
    .img-text .img-holder span {
        font-size: 16px;
    }
    .img-text .img-holder h2 {
        margin: 5px 0 0;
    }
    .img-text .text-holder {
        padding: 28px 19px 40px;
    }
    .img-text .text-holder p {
        margin: 0 0 12px;
    }
    .img-text .text-holder p:last-of-type {
        margin: 0 0 26px;
    }
    .why-us-section {
        padding: 0 0 77px;
    }
    .projects-section .title-wrapper p {
        font-size: 18px;
    }
    .project-item .content .img-holder .img {
        min-height: 253px;
    }
    .project-item .content .name-holder {
        border-radius: 10px;
        border-top-right-radius: 0;
        flex-direction: column;
        align-items: flex-start;
    }
    .project-item .content .name-holder p {
        font-size: 22px;
    }
    .projects-section {
        padding: 0 0 82px;
    }
    .header-block {
        border-radius: 10px;
    }
    .header-block .img-holder {
        padding: 47px 20px;
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
    }
    .header-block .img-holder:after {
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
    }
    .header-block .info-block h3 {
        margin: 0 0 5px;
    }
    .header-block .info-block:first-child p {
        margin: 0 0 17px;
    }
    .expect-section {
        padding: 0 0 73px;
    }
    .reviews-section .title-holder h2 {
        margin: 0 0 10px;
    }
    .reviews-section .text-holder p {
        margin: 13px 0 0;
    }
    .reviews-section .title-holder {
        flex-direction: column;
        margin: 0 0 34px;
    }
    .reviews-block .review-item {
        margin: 0 0 40px;
        width: 33.33%;
    }
    .site-footer .menu li a {
        transition: 0.3s;
        font-size: 16px;
        color: white;
        padding: 0;
        border-bottom: none;
    }
    .site-footer .menu li:last-child {
        margin: 0 0 13px;
        display: block;
        padding: 0;
    }
    .service-holder-section .img-holder, .service-holder-section.reverse .img-holder {
        max-width: 100%;
        min-height: 295px;
        width: calc(100% - 50px);
    }
    .banner-dark {
        padding: 105px 25px 0;
    }
    .banner-dark .container {
        padding: 110px 25px 106px;
        border-top-right-radius: 10px;
        border-top-left-radius: 10px;
    }
    .banner-dark .container p {
        font-size: 20px;
        line-height: 26px;
    }
    .banner-dark .container h1 {
        margin: 0 auto 16px;
    }
    .service-holder-section .icon-holder {
        display: none;
    }
    .service-holder-section .info-holder, .service-holder-section.reverse .info-holder {
        padding: 0 25px;
    }
    .service-holder-section .img-holder, .service-holder-section.reverse .img-holder {
        margin: 0 auto 28px;
    }
    .service-holder-section h2 {
        font-size: 40px;
        line-height: 42px;
    }
    .service-holder-section .title-holder {
        margin: 0 0 17px;
    }
    .service-holder-section .info-holder p {
        line-height: 24px;
    }
    .service-holder-section .info-holder p:last-of-type {
        margin: 0 0 14px;
    }
    .service-holder-section ul li {
        margin: 0 0 6px;
    }
    .service-holder-section ul {
        margin: 0 0 28px;
    }
    .service-holder-section .info-holder p.bold {
        margin: 0 0 15px;
    }
    .item-header {
        padding: 18px 0;
    }
    .item-question {
        font-size: 20px;
        line-height: 22px;
        padding: 0 10px 0 0;
    }
    .item-header .icon-check {
        margin-right: 10px;
        font-size: 20px;
    }
    .ev-style .item-content {
        padding: 0 20px 20px;
    }
    .item-content {
        padding: 20px;
    }
    .img-text-section .img-text {
        min-height: auto;
    }
    .img-text-section h2 {
        margin: 0 0 20px;
    }
    .img-text-section .img-text .text-holder {
        padding: 28px 19px 30px;
    }
    .service-desc-section p.bold {
        font-size: 18px;
        line-height: 24px !important;
        margin: 0 0 18px !important;
    }
    .service-holder-section, .service-holder-section.reverse {
        padding: 30px 0;
    }
    .service-desc-section.last {
        padding: 30px 0 111px;
    }
    .local-law-style .block-icon-section {
        padding: 80px 0 60px;
    }
    .block-icon-section .slider-holder.col-2 .service-item {
        width: 100%;
        margin: 0 0 20px;
    }
    .block-icon-section .service-item .cont-holder {
        padding: 30px 20px;
        border-radius: 10px;
    }
    .block-icon-section .icon-holder {
        width: 72px;
        min-width: 72px;
        height: 75px;
        font-size: 40px;
        border-radius: 10px;
        margin: 0 20px 0 0;
    }
    .block-icon-section .slider-holder.col-2 .icon-holder {
        margin: 0 20px 0 0;
    }
    .block-icon-section .service-item h3 {
        font: 30px/32px 'din-2014', sans-serif;
        margin: 0;
        font-weight: 600;
    }
    .plumbing-style .block-icon-section .service-item .title-holder h3 {
        margin: 0;
    }
    .block-icon-section .slider-holder.col-4 .service-item .title-holder {
        display: flex;
        align-items: center;
        margin: 0 0 20px;
    }
    .block-icon-section .slider-holder.col-4 .service-item {
        width: 100%;
    }
    .block-icon-section .slider-holder.col-4 .service-item:last-child {
        margin: 0;
    }
    .block-icon-section .service-item .cont .subtitle {
        margin: 0 0 18px;
        font-size: 20px;
        line-height: 26px;
    }
    .block-icon-section .service-item .title-holder {
        display: flex;
        align-items: center;
        margin: 0 0 20px;
    }
    .block-icon-section .service-item {
        margin: 0 0 20px;
        width: 100%;
    }
    .firestoping-style .checkmark-list {
        max-width: 100%;
    }
    .firestoping-style .checkmark-list li {
        padding: 0 27px;
        width: max-content;
        min-width: 100%;
    }
    .checkmark-list {
        margin: 0;
    }
    .checkmark-list li {
        padding: 0;
        width: 100%;
    }
    .checkmark-list li .cont {
        padding: 21px 0 20px;
    }
    .checkmark-list li .cont p {
        font-size: 20px;
    }
    .checkmark-list li .cont i {
        font-size: 20px;
        margin-right: 10px;
    }
    .checkmark-section h2 {
        margin: 0 0 14px;
    }
    .firestoping-style .checkmark-section {
        padding: 80px 0;
    }
    .firestoping-style .checkmark-list li {
        padding: 0;
        width: 100%;
        min-width: 100%;
    }
    .checkmark-section {
        padding: 81px 0 43px;
    }
    .firestoping-style .text-desc {
        padding: 60px 0 83px;
    }
    .firestoping-style .text-desc .content {
        max-width: 100%;
    }
    .text-desc {
        padding: 0 0 40px;
    }
    .text-desc .bold {
        font-size: 20px;
        line-height: 26px;
        margin: 0 0 20px;
    }
    .text-desc p {
        font-size: 18px;
        line-height: 24px;
    }
    .key-info-services {
        padding: 80px 0;
    }
    .key-info-services .info-holder .title-header {
        padding: 30px 19px;
    }
    .key-info-services .info-holder h3 {
        margin: 0 auto 20px;
        text-align: center;
    }
    .key-info-services .info-holder p {
        text-align: center;
    }
    .key-info-services .key-list li p {
        margin: 20px 0 13px;
        text-align: left;
    }
    .key-info-services .key-list {
        padding: 20px 20px 24px;
    }
    .key-info-services .key-list li {
        margin: 0 0 16px;
        min-height: auto;
        min-width: min-content;
    }
    .text-only {
        padding: 80px 0;
        text-align: left;
    }
    .hvac-style .text-only {
        padding: 60px 0;
    }
    .text-only .content h2 {
        margin: 0 0 20px;
    }
    .text-only.big-text {
        padding: 60px 0;
    }
    .text-only.full-width {
        padding: 60px 0 40px;
    }
    .text-only .content p.big {
        font-size: 20px;
        line-height: 26px;
    }
    .banner-light {
        height: auto;
        padding: 155px 25px 0;
        flex-direction: column;
    }
    .banner-light .info-holder, .plumbing-style .banner-light .info-holder {
        margin: 0 0 61px;
        max-width: 100%;
        width: 100%;
    }
    .banner-light h1 {
        margin: 0 0 20px;
    }
    .banner-light p.bold {
        font-size: 20px;
        line-height: 26px;
        margin: 0 0 18px;
    }
    .banner-light .img-holder {
        min-height: 295px;
        width: 100%;
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
        border-bottom-left-radius: 0;
    }
    .banner-light p.big {
        font-size: 20px;
        line-height: 26px;
    }
    .banner-light:after {
        content: "";
        position: absolute;
        bottom: 0;
        left: auto;
        right: -17px;
        width: 581px;
        height: 558px;
        background: url(assets/img/banner-lines-mob.svg) no-repeat center;
        background-size: contain;
    }
    .tell-section {
        padding: 162px 0 40px;
        margin: -120px 0 0;
    }
    .tell-section h2 {
        font: 30px/32px 'din-2014', sans-serif;
        margin: 0;
    }
    .hvac-style .service-desc-section.last {
        padding: 60px 0;
    }
    .cta-section-services.big-content {
        padding: 60px 0;
    }
    .cta-section-services.big-content .img-holder {
        display: none;
    }
    .hvac-style .service-holder-section .title-holder, .roof-style .service-holder-section .title-holder {
        margin: 0 0 20px !important;
    }
    .roof-style .service-desc-section {
        padding: 60px 0 111px;
    }
    .points-big-list li:before {
        width: 30px !important;
        height: 30px !important;
        top: 3px !important;
        transform: none;
    }
    .points-big-list li {
        margin: 0 0 20px;
        padding-left: 39px !important;
        line-height: 24px;
    }
    .roof-style .points-big-list li {
        margin: 0 0 35px;
    }
    .roof-style .points-big-list li:before {
        top: -3px !important;
    }
    .title-only .small-heading {
        margin: 0 0 10px !important;
    }
    .points-big-list li span {
        font-size: 20px;
    }
    .points-big-list-heading li:before {
        top: -2px;
    }
    .banner-about {
        height: auto;
        padding: 201px 0 0;
        overflow: hidden;
    }
    .tab-holder.fixed {
        top: 100px;
    }
    .tab-holder {
        position: fixed;
        top: 100px;
        bottom: auto;
        left: 0;
        right: 0;
        box-shadow: 2px 15px 10px rgba(0, 0, 0, 0.08);
    }
    .banner-about h1 {
        font: 40px/42px 'din-2014', sans-serif;
        margin: 7px 0 0;
        padding: 0 0 75px;
        font-weight: 600;
    }
    .banner-about:after {
        content: "";
        position: absolute;
        width: 579px;
        height: 429px;
        background: url(assets/img/banner-lines-mob.svg) no-repeat center;
        background-size: cover;
        bottom: -26px;
        right: -168px;
    }
    .description-section .img-holder {
        min-height: 328px;
        margin: 0;
    }
    .description-section h2 {
        margin: 0 0 15px;
        line-height: 42px;
        padding: 29px 0 0;
    }
    .text-col-holder {
        flex-direction: column;
        margin: 0 -31px;
    }
    .text-col {
        width: 100%;
    }
    .text-col p {
        margin: 0 0 25px;
        line-height: 24px;
    }
    .description-section {
        padding: 0 0 71px;
    }
    .cta-about-section {
        padding: 40px 0 49px;
    }
    .cta-about-section .img-holder {
        margin: -88px 0 27px -33px;
        width: 62%;
    }
    .cta-about-section .content-info p {
        margin: 0 0 27px;
    }
    .values-section {
        padding: 80px 0 0;
    }
    .values-section .title-wrapper {
        margin: 0 0 37px;
    }
    .value-item .cont-holder {
        border-radius: 10px;
        padding: 31px 20px 27px;
    }
    .value-item span {
        font-size: 63px;
        margin: 0 0 23px;
    }
    .values-slider {
        margin: 0 46px 0 0;
    }
    .value-item {
        margin: 0 9px;
        min-height: 334px;
    }
    .value-item .value-name {
        margin: 0 0 13px;
        max-width: 187px;
    }
    .value-item p {
        line-height: 24px;
    }
    .cta-lines {
        padding: 245px 0 198px;
        margin: -166px 0 0;
    }
    .cta-lines h2 {
        margin: 0 0 12px;
        line-height: 42px;
    }
    .cta-lines p {
        font-size: 18px;
        line-height: 24px;
    }
    .cta-lines:after {
        width: 367px;
        height: 175px;
        bottom: 0;
        right: 0;
    }
    .mission-vision {
        padding: 80px 0 38px;
    }
    .mission-vision.reverse {
        padding: 0;
    }
    .mission-vision .text-holder {
        padding: 39px 20px;
    }
    .mission-vision .text-item h3 {
        margin: 0 0 12px;
    }
    .mission-vision .text-item p {
        line-height: 24px;
    }
    .why-energy {
        padding: 47px 0 189px;
    }
    .why-energy h2 {
        margin: 0 0 14px;
        font: 35px/40px 'din-2014', sans-serif;
    }
    .why-energy p {
        margin: 0 0 12px;
        font-size: 18px;
        line-height: 24px;
    }
    .we-do-section {
        padding: 0;
        margin: 0 0 -33px;
    }
    .we-do-section .img-holder {
        min-height: 221px;
        border-radius: 10px;
        margin: 0 0 31px;
    }
    .we-do-section .container {
        top: -112px;
    }
    .we-do-section .info-holder h2 {
        font-size: 40px;
        margin: 0 0 17px;
    }
    .we-do-section .text-col p {
        margin: 0 0 12px;
        line-height: 24px;
    }
    .results-section {
        padding: 0 0 38px;
    }
    .results-section .img-text .img-holder {
        min-height: 265px;
    }
    .results-section h3 {
        margin: 0 0 16px !important;
    }
    .results-section p {
        margin: 0 0 12px !important;
        line-height: 24px;
    }
    .results-section .img-text .text-holder {
        padding: 28px 19px 27px;
    }
    .difference-section .info-text h2 {
        font: 30px/34px 'din-2014', sans-serif;
    }
    .difference-section .subtitle {
        margin: 0 0 11px;
        font-size: 20px;
        line-height: 26px;
    }
    .columns {
        flex-direction: column;
        margin: 0;
    }
    .col-text {
        width: 100%;
        margin: 0 0 12px;
    }
    .col-text p {
        margin: 0 0 12px;
        line-height: 24px;
    }
    .reach-section {
        padding: 0 0 9px;
    }
    .reach-section h2 {
        font: 30px/34px 'din-2014', sans-serif;
        text-align: center;
    }
    .reach-section .header {
        margin: 0 0 13px;
    }
    .reach-section .subtitle {
        margin: 0 0 12px;
        font-size: 18px;
        line-height: 24px;
    }
    .reach-section p:last-of-type {
        line-height: 24px;
    }
    .story-section h2 {
        font-size: 40px;
        line-height: 42px;
        margin: 0 auto 18px;
    }
    .feedback-section {
        padding: 87px 0 124px;
    }
    .feedback-section h2 {
        margin: 0 0 27px;
        line-height: 42px;
    }
    .feedback-section .subtitle {
        font-size: 24px;
        line-height: 28px;
        margin: 0 0 25px;
    }
    .feedback-section .columns {
        color: #5F8663;
        margin: 0 0 25px;
    }
    .feedback-section .col-text {
        margin: 0 0 12px;
    }
    .feedback-section .reviews-block .review-slider-arrows .review-item {
        min-width: 340px;
        width: 340px !important;
        height: auto;
    }
    .feedback-section .reviews-block .review-slider-arrows .review-item .cont {
        padding: 35px 20px 26px;
        min-height: auto;
        flex-grow: 0;
    }
    .feedback-section .reviews-block .review-slider-arrows .slick-list {
        overflow: hidden;
    }
    .review-slider-arrows {
        margin: 0 -25px;
        padding: 0 0 30px;
    }
    .review-slider-arrows .review-item .cont p {
        line-height: 24px;
        margin: 0 0 37px !important;
        font-size: 19px;
    }
    .goal-section .header-block .img-holder {
        padding: 47px 20px;
    }
    .header-block .img-holder h2 {
        line-height: 44px;
    }
    .goal-section {
        padding: 0 0 79px;
    }
    .goal-section .header-block .text-holder {
        padding: 38px 20px 37px;
    }
    .goal-section .header-block .subtitle {
        font-size: 20px;
        line-height: 26px;
        margin: 0 auto 26px;
    }
    .goal-list {
        margin: 0 -9px 8px;
    }
    .goal-list li {
        width: 100%;
        padding: 0 9px 18px;
    }
    .goal-list li .info {
        border-radius: 10px;
        padding: 20px;
    }
    .goal-list .icon-holder {
        min-width: 51px;
        width: 51px;
        height: 51px;
        font-size: 25px;
        margin: 0 10px 0 0;
    }
    .goal-list li p {
        font-size: 18px;
        line-height: 24px;
    }
    .goal-section .header-block .footer-text {
        font-size: 18px;
        line-height: 24px;
    }
    .gallery-section {
        padding: 79px 0 181px;
    }
    .gallery-section h2 {
        line-height: 42px;
        margin: 0 0 27px;
    }
    .gallery-section .columns {
        margin: 0 0 24px;
    }
    .gallery-slider .slick-list {
        overflow: hidden;
    }
    .gallery-slider {
        margin: 0 -12px;
        padding: 0 0 28px;
    }
    .gallery-item img {
        border-radius: 10px;
    }
    .img-list li {
        width: 50%;
        margin: 0 0 20px;
    }
    .project-images-section .img-list img{
        border-radius: 10px;
    }
    .proj-desc-section .content-holder {
        flex-direction: column;
    }
    .proj-desc-section .about-text {
        max-width: 100%;
        margin: 0 0 70px;
    }
    .proj-desc-section {
        padding: 36px 0 48px;
    }
    .proj-desc-section .service-text {
        max-width: 100%;
        width: 100%;
        margin: 0;
        border-radius: 10px;
        padding: 37px 20px 30px;
    }
    .breadcrumb {
        margin: 0 0 53px;
    }
    .proj-desc-section .about-text h2 {
        margin: 0 0 14px;
    }
    .proj-desc-section .about-text p {
        line-height: 24px;
    }
    .proj-desc-section .service-text h2 {
        margin: 0 0 14px;
    }
    .proj-desc-section .points-list {
        margin: 0;
    }
    .project-images-section {
        padding: 60px 0 18px;
    }
    .nav-prev a, .nav-next a {
        font-size: 20px;
        padding: 0 19px;
    }
    .nav-prev a:before, .nav-next a:before {
        top: 1px;
    }
    .banner-single-proj span {
        font-size: 16px;
    }
    .banner-single-proj h2 {
        margin: 3px 0 7px;
    }
    .banner-single-proj .location p {
        font-size: 18px;
        line-height: 1;
    }
    .banner-single-proj .location img {
        max-width: 16px;
    }
    .banner-single-proj .location {
        margin: 0 0 60px;
    }
    .proj-desc-section .service-text ul li {
        margin: 0 0 6px;
        padding-left: 28px;
    }
    .nav-holder {
        padding: 0 0 117px;
    }
    .menu li.current-menu-item:before, .menu li:hover:before {
        display: none;
    }
    .banner-contact {
        max-height: 313px;
        padding: 155px 0 110px;
    }
    .banner-contact:after {
        width: 480px;
        height: 231px;
        background: url(assets/img/contact-lines-mob.svg) no-repeat center;
    }
    .contact-info {
        padding: 61px 0;
    }
    .tab-holder-contact {
        padding: 0 20px;
    }
    .tab-holder-contact .tab {
        padding: 10px 25px 11px;
        border-radius: 10px 10px 0 0;
        text-align: center;
    }
    .form-cont-holder {
        padding: 41px 20px 20px;
        border-radius: 10px;
    }
    .form-wrapper .form-row {
        flex-direction: column;
    }
    .form-wrapper .form-row .form-field {
        width: 100%;
    }
    .text-area {
        padding: 0 9px;
    }
    .form-wrapper .btn-small {
        margin: 0 auto;
    }
    .form-wrapper textarea {
        margin: 0 9px 30px;
    }
    .contacts {
        flex-direction: column;
        margin: 0 -20px 0;
        padding: 0;
    }
    .contacts li {
        width: 100%;
        margin: 0 0 39px;
    }
    .contacts li p {
        font-size: 22px;
        margin: 0 0 10px;
    }
    .forms-holder {
        margin: 0 0 63px;
    }
    .contacts li .email {
        font-size: 30px;
    }
    .map-holder {
        min-height: 340px;
        margin: 0 0 40px;
    }
    .map-holder iframe {
        border-radius: 10px;
    }
    .request-call {
        border-radius: 10px;
        padding: 40px 20px 40px;
    }
    .request-call h2 {
        font-size: 30px;
        margin: 0 0 20px;
        text-align: center;
    }
    .request-call .btn {
        position: relative;
        margin: 0 auto;
    }
    .request-call .form-control {
        max-width: 100%;
        margin: 0 0 20px;
    }
    .checkbox-list li {
        width: 100%;
        margin: 0 0 20px;
    }
    .date {
        flex-direction: column;
        margin: 0 0 41px;
        align-items: flex-start;
    }
    .date .form-field {
        width: 100%;
        max-width: 100%;
    }
    .form-wrapper .service-title {
        margin: 18px 0 0 !important;
        line-height: 1.2;
    }
    .checkbox-list {
        margin: 27px -10px 20px;
    }
    .cont-2 textarea {
        margin: 0 9px 39px;
    }
    .date h3 {
        margin: 0 0 18px;
    }
    .projects-banner .container .subtitle {
        font-size: 20px;
        color: white;
        margin: 0 auto 18px;
    }
    .filter-section {
        padding: 60px 0 40px;
    }
    .featured-section .title-wrapper h2 {
        font-size: 35px;
        line-height: 1;
        padding: 0 0 20px;
    }
    .featured-section {
        padding: 60px 0 20px;
    }
    .featured-section .title-wrapper {
        margin: 0 0 30px;
    }
    .filter-holder-section {
        padding: 60px 0 0;
    }
    .projects-slider-2 .project-item:last-child {
        margin: 0;
    }
    .filter-holder-section.last {
        padding: 60px 0;
    }
    .logos-section {
        padding: 60px 0 121px;
    }
    .logos-section h2 {
        margin: 0 0 36px;
        text-align: center;
    }
    .logo-list {
        margin: 0 -14px;
    }
    .logo-list li {
        padding: 0 14px 16px;
    }
    .plumbing-style .cta-bottom-services, .firestoping-style .cta-bottom-services, .steam-style .cta-bottom-services {
        padding: 155px 0 59px;
    }
    .steam-style .block-icon-section {
        padding: 80px 0 87px;
    }
    .points-check-list li {
        padding: 20px 0 20px 30px !important;
        margin: 0;
    }
    .points-check-list li:before {
        font-size: 20px;
        top: 22px !important;
        font-weight: 400;
    }
    .local-law-style .service-desc-section {
        padding: 80px 0 0;
    }
    .local-law-style .service-desc-section .img-holder {
        display: none;
    }
    .checkmark-list-2 li {
        width: 100%;
        margin: 0 0 50px;
    }
    .points-section {
        padding: 0 0 56px;
    }
    .local-law-style .block-icon-section h2 {
        margin: 0 0 40px;
    }
    .local-law-style .img-text-section {
        padding: 80px 0;
    }
    .local-law-style .cta-section-services .img-holder {
        margin: 0;
        display: none;
    }
    .local-law-style .service-desc-section.last {
        padding: 80px 0 122px;
    }
    .local-law-style .cta-section-services {
        padding: 60px 0 35px;
    }
    .rebates-style .cta-section .img-holder {
        margin: -126px 0 22px -46px;
    }
    .rebates-style .cta-section-services {
        padding: 93px 0 60px;
    }
    .rebates-style .block-icon-section {
        padding: 80px 0 94px;
    }
    .rebates-style .block-icon-section p {
        font-size: 18px;
        line-height: 24px;
        margin: 0 0 40px;
    }
    .ev-style .img-text-section {
        padding: 80px 0;
    }
    .ev-style .cta-section .img-holder {
        margin: -126px 0 22px -46px;
        width: 70%;
    }
    .ev-style .block-icon-section {
        padding: 80px 0 0;
    }
    .ev-style .block-icon-section h2 {
        margin: 0 0 16px;
    }
    .ev-style .block-icon-section p {
        font-size: 18px;
        line-height: 24px;
        margin: 0 0 18px;
    }
    .ev-style .block-icon-section p.bold {
        margin: 0 0 40px;
    }
    .block-icon-section .service-item .cont p {
        font-size: 18px;
        line-height: 24px;
    }
    .ev-style .accordion-section {
        padding: 80px 0 123px;
    }
    .accordion-item {
        padding: 0;
    }
    .points-big-list li:before, .hvac-style .points-big-list li:before {
        width: 30px;
        height: 30px;
        top: 3px;
        transform: none;
        background-size: contain !important;
    }
    .hvac-style .checkmark-section {
        padding: 70px 0 122px;
    }
    .plumbing-style .block-icon-section {
        padding: 0 0 57px;
    }
    .plumbing-style .cta-section {
        padding: 40px 0 25px;
    }
    .firestoping-style .cta-section-services .img-holder {
        display: none;
    }
    .firestoping-style .cta-section {
        padding: 60px 0;
    }
    .firestoping-style .cta-section-services h2 {
        font-size: 40px;
        line-height: 46px;
        margin: 0 0 20px;
    }
    .slick-arrow:hover {
        transform: scale(1) translateY(0);
    }
    .feedback-section .review-slider-arrows {
        margin: 0;
    }
    .tab-holder {
        padding: 14px 0;
    }
    .anchor-list .anchor-item a:hover {
        background: #F7FAF7;
    }
    .tab-holder {
        padding: 14px 25px;
    }
}
@media only screen and (max-width: 768px) {
    #popup_video iframe {
        max-width: 560px;
        width: 560px !important;
        height: 315px !important;
    }
    .wrapper-title-button{
        flex-direction: row;
        align-items: center;
    }
    .wrapper-title-button h3{
        margin-bottom: 0;
    }
    .popup-btn{
        margin-block-end: 0;
    }
    #popup_video {
        min-width: max-content;
    }
    h3 {
        font: 30px/32px 'din-2014', sans-serif;
        margin-block-end: 16px;
        font-weight: 600;
    }
    .services-section {
        padding: 0 0 112px;
    }
    .service-item .cont h3 {
        margin: 0 0 12px;
    }
    .service-item .cont p {
        margin: 0 0 48px;
    }
    .services-slider {
        margin: 0 12px 0 -10px;
    }
    .slick-list {
        overflow: visible;
    }
    .service-item {
        border-radius: 10px;
        padding: 30px 20px 36px;
        min-height: auto;
    }
    .icon-holder {
        width: 73px;
        height: 75px;
        font-size: 39px;
        border-radius: 10px;
        margin: 0 0 28px;
    }
    .projects-slider, .projects-slider-home {
        margin: 0 12px 40px -9px;
    }
    .project-item {
        margin: 0 9px;
    }
    .project-item .content .img-holder {
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
    }
    .reviews-block {
        margin: 0;
    }
    .reviews-section .review-slider {
        margin: 0 30px 40px -9px;
    }
    .reviews-block .review-item {
        padding: 0;
        margin: 0 9px;
    }
    .reviews-block .review-item .cont {
        border-radius: 10px;
        padding: 38px 34px 29px 19px;
        max-width: 100%;
    }
    .reviews-block .review-item .cont p {
        font-style: italic;
        line-height: 24px;
        margin: 0 0 14px;
        flex-grow: 1;
    }
    .reviews-block .review-item .cont .name {
        font-size: 20px;
    }
    .more-reviews {
        padding: 0;
    }
    .more-reviews .cont p {
        margin-right: 30px;
        font-size: 22px;
    }
    .reviews-section {
        padding: 0 0 121px;
    }
    .cta-bottom-section h2 {
        font-size: 40px;
        margin: 0 0 13px;
        max-width: 300px;
    }
    .roof-style .cta-bottom-section h2 {
        max-width: 100%;
    }
    .cta-bottom-section p {
        margin: 0 0 11px;
    }
    .cta-bottom-section .btn {
        margin: 26px 0 0;
    }
    .contact-links {
        margin: 0 0 21px;
        padding: 0;
        font-size: 22px;
    }
    .service-desc-section .points-holder {
        margin: 0 -25px;
        display: flex;
        flex-direction: column;
    }
    .slick-prev {
        left: 40%;
    }
    .slick-next {
        right: 40%;
        left: auto;
    }
    .popup-content {
        min-width: auto;
        max-height: 91vh;
        overflow-y: scroll;
    }
    .popup-wrapper {
        max-width: 340px;
    }
    .popup .contact-form-holder {
        padding: 30px 21px 18px;
        position: relative;
        border-radius: 10px;
        border-bottom: 16px solid #327A39;
    }
    .popup .contact-form-holder img {
        max-height: 47px;
        width: auto;
        margin: 0 0 14px;
    }
    .popup-content h2 {
        color: #1A451F;
        font-size: 35px;
        margin: 0 0 9px;
    }
    .popup-content p {
        margin: 0 auto 17px;
    }
    #popup-form .form-field {
        padding: 0 9px 15px;
    }
    #popup-form {
        margin: 0;
    }
    #popup-form textarea {
        margin: 0 9px 19px;
    }
    .projects-slider-2 .project-item {
        width: 100%;
        margin: 0 0 40px;
    }
    .feedback-section .review-slider-arrows .review-item {
        height: auto;
    }
    .slick-arrow {
        width: 48px;
        height: 48px;
        box-shadow: 5px 6px 9px rgba(0, 47, 5, 0.1);
        position: absolute;
        top: 100%;
        transform: translateY(0);
        margin: 0 10px;
    }
    .slick-arrow:before {
        font-size: 20px;
        z-index: 2;
    }
}
@media only screen and (max-width: 600px) {
    .service-desc-section.introducing_app .btn-holder {
        flex-direction: column;
        align-items: flex-start;
    }
    .service-desc-section.introducing_app .btn-holder .btn-arrow:first-child {
        margin-right: 0;
        margin: 0 0 24px;
        min-width: auto;
    }
    .filter-select {
        align-items: flex-start;
        flex-direction: column;
    }
    .filter-select p {
        margin: 0 0 18px;
    }
    .wrapper-title-button{
        flex-direction: column;
        align-items: flex-start;
    }
    .popup-btn{
        margin-left: 0;
        padding: 12px 30px;
        margin-top: 8px;
    }
    .checkbox-list .wpcf7-form-control-wrap .wpcf7-form-control.wpcf7-checkbox {
        grid-template-columns: repeat(1, 1fr);
        gap: 20px;
    }
}
@media only screen and (max-width: 490px) {
    #popup_video iframe {
        max-width: 400px;
        width: 400px !important;
        height: 225px !important;
    }
    .banner-light:after {
        content: "";
        position: absolute;
        bottom: 0;
        left: -25px;
        right: auto;
        width: 581px;
        height: 558px;
        background: url(assets/img/banner-lines-mob.svg) no-repeat center;
        background-size: contain;
    }
    .slick-prev {
        left: 31%;
    }
    .slick-next {
        right: 31%;
        left: auto;
    }
    .img-list li {
        width: 100%;
    }
    .banner-single-proj {
        min-height: 78.3vh;
    }
    .logo-list li {
        width: 50%;
    }
}
@media only screen and (max-width: 375px) {
    .feedback-section .reviews-block .review-slider-arrows .review-item {
        min-width: 320px;
        width: 320px !important;
    }
    #popup_video iframe {
        max-width: 320px;
        width: 320px !important;
        height: 180px !important;
    }
    .slick-prev {
        left: 28%;
    }
    .slick-next {
        right: 28%;
        left: auto;
    }
    .logo-list li {
        width: 100%;
    }
    .custom-select {
        max-width: 325px;
    }
    .video-btn .play-sign {
        margin: -1px 0 0 7px;
    }
    .video-btn {
        padding: 0 20px;
    }
}
@media only screen and (max-width: 360px) {
    .custom-select {
        max-width: 310px;
    }
    .video-btn p {
        font-size: 16px;
    }
}
@media only screen and (max-width: 320px) {
	.project-item .content .name-holder{
        min-width: 250px;
        max-width: 250px;
    }
    #popup_video iframe {
        max-width: 280px;
        width: 280px !important;
        height: 158px !important;
    }
    .block-icon-section .slider-holder.col-4 .service-item .title-holder {
        flex-direction: column;
        align-items: flex-start;
    }
    .block-icon-section .service-item .title-holder {
        flex-direction: column;
        align-items: flex-start;
    }
    .block-icon-section .slider-holder.col-2 .service-item .title-holder {
        flex-direction: column;
        align-items: flex-start;
    }
    .block-icon-section .slider-holder.col-2 .icon-holder {
        margin: 0 20px 20px 0;
    }
    .block-icon-section .icon-holder {
        margin: 0 20px 20px 0;
    }
    .cta-bottom-section .btn {
        font-size: 15px;
    }
    .banner-about {
        padding: 175px 0 0;
    }
    .banner-about h1 {
        font: 36px/38px 'din-2014', sans-serif;
    }
    .popup-wrapper {
        max-width: 300px;
    }
    .custom-select {
        max-width: 270px;
    }
}