/* 
Theme Name: O'Brien's HVAC Company
Theme URI: https://github.com/elementor/hello-theme/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: FDM
Author URI: https://elementor.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/******Default vip css start*****/   
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital@0;1&family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');
*{
	outline: none !important; 
	text-decoration: none !important;  
}
ul {
	padding: 0;
} 
.site-branding {
	display: none;
} 
p,li {
	margin-bottom: 20px; 
}  
p, li, div, p.elementor-heading-title {
	color: #808080;
	font-size: 16px;
	font-family: "Open Sans", sans-serif;
	line-height: 28px;
	font-weight: 400;
}
p:last-child{
	margin-bottom: 0;
} 
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5 h6, .h6 {
	color: #333333;
	letter-spacing: 0;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
}
.bigheading > .elementor-widget-container {
	margin-bottom: 20px;
}
p a {
	color: #4aaf34 !important;
	font-weight: normal;
	text-decoration: unset !important;
}
p a:hover, .link-text a:hover {
	text-decoration: underline !important;
}
strong {
	font-weight: 500 !important;
}  
.subheading h6 {
	font-size: 18px;
	line-height: 49px;
	text-transform: uppercase;
	color: #2b328c;
}
.pl60{
	padding-left: 60px;
}
.pl30{
	padding-left: 30px;
}
.pr60{
	padding-right: 60px;
} 
.pt0 {
	padding-top:0px !important;
}
.pb0 {
	padding-bottom:0px !important;
}
.mt50{
	margin-top: 50px;
}   
.mt35{
	margin-top: 35px;
} 
.mt100{
	margin-top: 100px;
}    
.pad100 {
	padding: 100px 15px;
} 
.pt100{
	padding-top: 100px;
} 
.pb100{
	padding-bottom: 100px;
}
.pt50 {
	padding-top: 50px;
}
.defbtn .elementor-widget-container {
	margin-top: 30px;
}
body {
	position: relative;
}
a {
	transition: all ease-in-out 0.5s !important;
}
div[data-elementor-type="wp-page"] {
	overflow: hidden;
}
/*** Header ***/  
@keyframes slideIn {
	from { top: -50% }
	to { top: 0 }
}   
.hdactive .elementor-location-header {
	position: fixed;
	-webkit-animation: slideIn 0.5s ease-in;
	-moz-animation: slideIn 0.5s ease-in;
	animation: slideIn 0.5s ease-in;
	z-index: 102;
	padding: 10px 15px;
	background: #fff;
	box-shadow: 0px 0px 11px rgba(0,0,0,0.2);
}
.hd_menu  .elementor-widget-container {
	width: 100%;
}      
.header_main .elementor-widget-wrap {
	justify-content: space-between;
	align-items: center;
} 
.hd_menu .elementor-nav-menu > li {
	margin-left: 50px;
}
.hd_menu .elementor-nav-menu > li > a {
	font-size: 16px;
	color: #428bca !important;
	padding: 0 !important;
	text-transform: uppercase;
}
/* .hd_menu .elementor-nav-menu > li > a:hover {
color: #dbdbdb !important;
} */
/* .hd_menu .elementor-nav-menu > li:last-child > a {
background: #6d7358;
border-radius: 0px !important;
font-family: 'SCHABO Condensed';
text-transform: uppercase;
font-size: 24px;
padding: 14px 80px 10px 22px !important;
position: relative;
border: 2px solid #6d7358;
color: #fff !important;
} */
.elementor-nav-menu > li > ul.sub-menu a {
	padding: 14px 14px !important;
	color: #fff !important;
	border-bottom: 1px solid #ffffff38;
	border-left: 0;
	white-space: normal;
	background: #6d7358 !important;
	font-size: 15px;
	text-transform: capitalize;
	letter-spacing: 0;
}
.elementor-nav-menu > li > ul.sub-menu li:last-child a {
	border-bottom: 0px !important;
}  
.elementor-sub-item.elementor-item-active {
	background-color: transparent !important;
} 
.elementor-nav-menu > li > ul.sub-menu {
	background: #222334;
	min-width: 235px !important;
	border-radius: 0px;
	margin-top: -5px !important;
}
.elementor-nav-menu > li > ul.sub-menu:last-child a {
	border-radius: 0px; 
} 
.elementor-nav-menu > li > ul.sub-menu .sub-arrow {
	display: none !important;
} 
.elementor-nav-menu > li > ul.sub-menu a:hover {
	background: #4c5238 !important;
	opacity: 1;
	border-left: unset !important;
	color: #fff !important;
}
.elementor-location-header {
	position: relative;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	padding: 15px 0px;
}
.elementor-nav-menu li .sub-arrow svg {
	transition: all ease-in-out 0.5s;
	fill: #fff;
}
.elementor-nav-menu li:hover .sub-arrow svg {
	fill: #dbdbdb;
} 
.site_logo {
	width: auto !important;
	max-width: 325px;
}
.hd_menu {
	width: auto !important;
}
.hdactive .site_logo { 
	max-width: 206px;
}
.top-bar {
	border-bottom: 1px solid #e6e6e6;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.top-bar p {
	font-size: 15px;
	line-height: 22px;
}
.top-hd-list ul {
	justify-content: flex-end;
	margin: 0 !important;
	column-gap: 20px;
}
.top-hd-list li {
	margin: 0 !important;
}
.top-hd-list li a {
	color: #4aaf34;
	font-size: 15px !important;
	line-height: 22px;
}
.top-hd-list li a svg {
	fill: #000;
	width: 15px !important;
	height: 15px !important;
}
.top-hd-list li:hover a {
	color: #428bca;
	text-decoration: underline !important;
}



/*** Header End***/ 
.ft-sec {
	padding: 60px 0px 20px;
}
.ft-hd span {
	font-size: 18px;
	line-height: 1.4;
	letter-spacing: 0px;
	margin-bottom: 20px;
	display: block;
}
.btm-bdr {
	border-bottom: 1px solid #e6e6e645;
	padding-bottom: 30px;
}
.mt20 {
	margin-top: 20px;
}
.copyrighttext, .copyrighttext a {
	color: #fff;
	font-size: 15px;
	line-height: 22px;
}
.copyrighttext a:hover {
	text-decoration: underline !important;
}
.ft-logo img {
	width: 100%;
	max-width: 280px;
	display: block !important;
}
.banner {
	padding: 12% 15px;
}
.banner h1 {
	font-size: 50px;
	margin-bottom: 20px;
	line-height: 1.1;
}
.bnrbtn a {
	font-weight: normal;
	text-shadow: none;
	background: #4aaf34;
	border: 1px solid #368026;
	font-size: 24px;
	line-height: 30px;
	padding: 14px 28px;
}
.bnrbtn a:hover {
	background: #6cc63b;
	border: 1px solid #52982c;
}
.bnrbtn {
	margin-top: 20px !important;
}
.bnrbtn a svg {
	width: 30px;
	height: 30px !important;
	margin-right: 10px;
}
.pad80 {
	padding: 80px 15px;
}
.hvac_outer .elementor-widget-wrap {
	justify-content: center;
	column-gap: 20px;
}
.hvac-boxes {
	width: calc(100% / 3 - 14px) !important;
	position: relative;
	z-index: 1;
}
.hvac-boxes .elementor-image-box-img {
	width: auto !important;
	display: block !important;
}
.hvac-boxes .elementor-image-box-img img {
	width: 100%;
	display: block;
}
.hvac-boxes span a {
	color: #333 !important;
	font-size: 24px;
	line-height: 1.1;
}
.hvac-boxes p {
	font-size: 14px;
	line-height: 1.45;
}
.hvac-boxes i {
	display: block;
	color: #4aaf34;
	font-style: normal;
	margin-top: 10px;
}
.hvac-boxes:hover i {
	text-decoration: underline !important;
}
.hvac-boxes a::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}
.hvac-boxes:hover span a {
	color: #6cc63b !important;
}
.bigheading h2 {
	font-size: 40px;
	line-height: 1.1;
}
.bigheading {
	margin-bottom: 20px !important;
}
.subheading p {
	font-size: 30px;
	line-height: 1.1;
	margin-bottom: 20px;
}
.main-hd h3 {
	font-weight: 700;
	font-size: 24px;
	line-height: 1.1;
}
.main-hd {
	margin-bottom: 20px !important;
}
.mb0 {
	margin-bottom: 0px !important;
}
.mt0 {
	margin-top: 0px !important;
}
.service-sec p i {
	font-weight: bold;
	color: #00c2e5;
	font-style: normal;
	margin-bottom: 20px;
	display: block;
}
.service-list ul {
	margin-bottom: 20px !important;
}
.service-list li a {
	color: #00c2e5;
	font-weight: 700;
	font-size: 32px !important;
	letter-spacing: 0;
}
.service-list li {
	margin-bottom: 10px !important;
	font-size: 14px !important;
	line-height: 1.4;
	letter-spacing: 2px;
}
.social-list ul {
	margin: 0 !important;
	column-gap: 20px;
}
.social-list li {
	margin: 0 !important;
}
.social-list li svg {
	width: 54px !important;
	height: 54px !important;
	fill: #bababa;
}
.social-list .e-font-icon-svg {
	margin: 0 !important;
}
.social-list .elementor-icon-list-text {
	display: none;
}
.social-list li:hover svg {
	fill: #333;
}


.gform_wrapper .gform_validation_errors {
	display: none;
} 
.custom-contact .gform_page_footer {
	display: flex;
	flex-wrap: wrap;
}
.custom-contact .button:hover {
	background: #333333 !important;
	border: 1px solid #272727;
	margin: 0 !important;
}
.custom-contact .button {
	font-size: 15px !important;
	line-height: 17px;
	padding: 10px 20px !important;
	background: #999999;
	border: 1px solid #8d8d8d;
	color: #fff;
	border-radius: 5px;
	margin: 0px !important;
}
.validation_message {
	padding: 0px !important;
	background: transparent !important;
	border: 0px !important;
	margin-top: 0px !important;
	line-height: 20px !important;
	font-size: 14px !important;
}
.gform_wrapper .gfield_required{
	display: none !important;
} 
.custom-contact .gfield_label {
	display: block !important;
	color: #808080 !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	line-height: 1.45 !important;
	margin: 0 !important;
}
.custom-contact input, .custom-contact select {
	height: 40px;
	padding: 6px 12px !important;
	font-size: 14px !important;
	line-height: 1.428571429;
	color: #808080;
	vertical-align: middle;
	background-color: #fcfcfc;
	background-image: none;
	border: 1px solid #e6e6e6;
	border-radius: 5px;
}
.custom-contact input:focus {
	border-color: #cccccc !important;
}
.custom-contact input:hover, .custom-contact select:hover {
	background: #fff !important;
}
.custom-contact .gform_footer {
	margin: 25px 0px 0px !important;
	padding: 0px !important;
}
.custom-contact label {
	font-weight: normal !important;
	font-size: 15px !important;
	line-height: normal !important;
	padding: 0px !important;
	color: #fff !important;
}
.custom-contact .check-box .gchoice:first-child {
	margin-right: 20px;
}
.half-col {
	grid-column: span 6 !important;
	margin-bottom: 10px;
}
.full-col {
	margin-bottom: 10px !important;
}	
.custom-contact .textarea {
	border-radius: 0px !important;
	height: 150px !important;
	padding: 6px 12px !important;
	font-size: 14px !important;
	line-height: 1.428571429;
	color: #808080;
	vertical-align: middle;
	background-color: #fcfcfc;
	border: 1px solid #e6e6e6;
	border-radius: 5px !important;
}
.custom-contact .textarea:hover {
	background: #fff !important;
}
.instruction {
	display: none;
}
.inr-bnr {
	padding: 7% 15px;
}
.inr-hd h1 {
	font-size: 50px;
	line-height: 1.1;
	margin-bottom: 20px;
}

.services_outer .elementor-widget-wrap {
	column-gap: 40px;
	justify-content: center;
	row-gap: 40px;
}
.service-boxes {
	width: calc(100% / 3 - 27px) !important;
}
.service-boxes span {
	font-size: 21px;
	line-height: 21px;
	display: block;
	margin-bottom: 20px;
	color: #333333;
}
.service-boxes p {
	font-size: 14px;
	font-weight: 400;
	line-height: 1.45;
}
.service-boxes .elementor-image-box-img {
	display: block;
	margin: 0 auto 20px !important;
	background: #ededed;
	padding: 10px;
	border-radius: 50%;
	width: 100px !important;
	height: 100px;
}
.service-boxes .elementor-image-box-img img {
	width: 100%;
	display: block;
	max-width: 80px;
	margin: 0 !important;
	padding: 7px;
}
.diff-pad {
	padding: 180px 15px;
}
.bdr-ryt p {
	border-left: 5px solid #fff;
	padding-left: 20px;
	font-style: italic;
}
.img-caption .wp-caption {
	position: relative;
}
.img-caption .wp-caption-text {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: rgba(0,0,0,0.7);
	color: #fff;
	padding: 10px 15px;
	font-style: normal;
	font-size: 14px;
}
.wt p {
	color: #fff;
}
.defbtn a {
	font-weight: normal;
	text-shadow: none;
	background: #4aaf34;
	border: 1px solid #368026;
	font-size: 24px;
	line-height: 30px;
	padding: 14px 28px;
}
.defbtn a:hover {
	background: #6cc63b;
	border: 1px solid #52982c;
}
.cta-hd h3 {
	font-size: 24px;
	line-height: 1.4;
	letter-spacing: 0px;
	margin-bottom: 10px;
}
.defbtn {
	margin-top: 20px;
}
.ft-fix-btn {
	display: none;
}

/* Responsive-start */

@media(max-width: 1400px) {
	.elementor-119 .elementor-element.elementor-element-61519a1:not(.elementor-motion-effects-element-type-background),
	.elementor-119 .elementor-element.elementor-element-61519a1 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
		background-position: 0px 0px;
	}
	.ft-sec {
		padding: 60px 15px 20px;
	}
	.elementor-location-header {
		padding: 15px 15px;
	}
}
@media(max-width: 1199px) {
	.service-boxes .elementor-image-box-img img {
		max-width: 70px;
		padding: 5px;
	}
	.service-boxes .elementor-image-box-img {
		width: 90px !important;
		height: 90px;
	}
	.inr-bnr {
		padding: 17% 15px;
	}
	.ft-logo img {
		max-width: 250px;
	}
	.pl60 {
		padding-left: 50px;
	}
	.pl60 {
		padding-left: 50px;
	}
	.main-hd h3 {
		font-size: 22px;
	}
	.bigheading h2 {
		font-size: 37px;
	}
	.bnrbtn a {
		font-size: 22px;
		line-height: 28px;
		padding: 12px 28px;
	}
	.banner h1 {
		font-size: 46px;
		margin-bottom: 18px;
	}
	.site_logo {
		width: auto !important;
		max-width: 285px;
	}

}
@media(max-width: 1024px) {
	.header_main .elementor-menu-toggle__icon--close.e-font-icon-svg.e-eicon-close {
		fill: #4aaf34;
	}

	.header_main .elementor-menu-toggle__icon--open.e-font-icon-svg.e-eicon-menu-bar {
		fill: #fff;
	}
	.header_main .elementor-menu-toggle {
		background-color: #4aaf33;
		color: #fff;
		padding: 11px;
		margin: 0px 0px !important;
		z-index: 10;
		display: flex;
		justify-content: flex-end;
		width: fit-content;
		border-radius: 0;
	}
	.header_main nav.elementor-nav-menu--dropdown {
		position: fixed;
		top: 0;
		bottom: 0;
		width: 480px;
		margin: 0 !important;
		display: flex;
		align-items: center;
		justify-content: center;
		right: -490px;
		transform: unset !important;
		max-height: 100% !important;
		transition: all ease-in-out 0.3s !important;
		background-color: #4aaf34;
		overflow: auto;
		z-index: 5;
	}
	.header_main .elementor-nav-menu>li>a {
		color: #fff;
	}
	.header_main .elementor-menu-toggle.elementor-active~.elementor-nav-menu--dropdown {
		right: 0px !important;
	}
	.header_main .elementor-menu-toggle.elementor-active {
		background-color: #fff;
		color: #fcb113;
		margin: 0px !important;
		position: fixed;
		right: 15px;
		top: 48px;
	}
	.hd_menu .elementor-nav-menu > li > a:hover {
		color: #fff !important;
	}
	.header_main .elementor-nav-menu {
		margin: auto;
		margin-top: 90px !important;
		width: 100% !important;
	}
	.header_main .sub-arrow {
		position: absolute;
		right: 30px;
	}
	.header_main .elementor-nav-menu>li:last-child>a:hover {
		background: transparent !important;
		color: #fff !important;
	}
	.header_main .elementor-nav-menu>li:last-child {
		margin-left: 0px;
	}
	.header_main .hd_menu .elementor-nav-menu>li:last-child>a {
		border: 0 !important;
	}
	.header_main ul.elementor-nav-menu > li > a, .hd_menu .elementor-nav-menu > li:last-child > a {
		background-color: transparent !important;
		font-size: 20px !important;
		padding: 22px 15px !important;
		border: 0px !important;
		color: #fff !important;
		border-bottom: 1px solid #ffffff1f !important;
	}
	.hd_menu nav > ul.elementor-nav-menu > li {
		margin-left: 0px;
	}
	.header_main ul.elementor-nav-menu .sub-menu li a {
		padding: 20px 20px 20px 35px !important;
		color: #fff !important;
		font-size: 17px !important;
		background-color: #231f20 !important;
		text-transform: uppercase;
	}
	.header_main ul.elementor-nav-menu .sub-menu {
		background: transparent !important;
	}

}
@media(max-width: 999px) {
	.cta-lft .elementor-widget-wrap {
		align-content: center;
	}
	.defbtn a {
		border: 1px solid #368026;
		font-size: 18px;
		line-height: 23px;
		padding: 11px 23px;
	}
	.mob-full img {
		width: 100% !important;
	}
	.mob-full .elementor-column-gap-default {
		max-width: 100% !important;
		width: 100% !important;
	}
	.cta-ryt {
		width: 60% !important;
	}
	.cta-lft {
		width: 40% !important;
	}
	.service-boxes span {
		font-size: 19px;
		line-height: 19px;
	}
	.service-boxes .elementor-image-box-img img {
		max-width: 64px;
		padding: 4px;
	}
	.pad80 {
		padding: 60px 15px;
	}
	.inr-hd h1 {
		font-size: 40px;
		margin-bottom: 16px;
	}
	.social-list li svg {
		width: 44px !important;
		height: 44px !important;
	}
	.service-list li a {
		font-size: 28px !important;
	}
	.pl60 {
		padding-left: 35px;
	}
	.main-hd {
		margin-bottom: 15px !important;
	}
	.main-hd h3 {
		font-size: 20px;
	}
	.hvac-boxes span a {
		font-size: 22px;
	}
	.bigheading {
		margin-bottom: 13px !important;
	}
	.bigheading h2 {
		font-size: 33px;
	}
	.bnrbtn a svg {
		width: 24px;
		height: 24px !important;
	}
	.bnrbtn a svg {
		width: 24px;
		height: 24px !important;
		margin-right: 3px;
	}
	.bnrbtn a {
		font-size: 18px;
		line-height: 24px;
		padding: 10px 20px;
	}
	.banner h1 {
		font-size: 42px;
		margin-bottom: 15px;
	}
}
@media(max-width: 767px) {
	.cta-lft {
		width: 100% !important;
		margin-top: 20px;
	}
	.cta-ryt {
		width: 100% !important;
	}
	.bdr-ryt p {
		border-left: unset;
		padding-left: 0px;
		font-style: italic;
	}
	.inr-hd h1 {
		font-size: 34px;
		margin-bottom: 14px;
	}
	.services_outer .elementor-widget-wrap {
		column-gap: 10px;
		row-gap: 10px;
	}
	.service-boxes {
		width: calc(100% / 2 - 5px) !important;
		border: 1px solid #8080801f;
		padding: 15px;
	}
	.btm-bdr {
		padding-bottom: 20px;
	}
	.ft-fix-btn a {
		color: #fff;
		font-size: 22px;
		line-height: normal;
		width: 100% !important;
		text-transform: uppercase !important;
	}
	.ft-fix-btn {
		display: flex;
		background-color: #4aaf33;
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 10;
		border-top: 1px solid #ffffff2b;
		text-align: center;
		width: 100% !important;
		padding: 9px;
	}
	.bnrbtn a:hover {
		background: #4aaf34;
		border: 1px solid #368026;
	}
	.pl30 {
		padding-left: 0px;
	}
	.ft-logo img {
		max-width: 210px;
		margin: 0 auto 15px;
	}
	.ft-sec {
		padding: 40px 15px 74px;
	}
	.custom-contact .button {
		font-size: 15px !important;
		line-height: 17px;
		padding: 10px 20px !important;
		line-height: 1 !important;
		margin: 0 auto !important;
	}
	.half-col {
		grid-column: span 12 !important;
		margin-bottom: 0px;
	}
	.pl60 {
		padding-left: 0px;
	}
	.hvac-boxes span a {
		font-size: 21px;
	}
	.hvac-boxes span a {
		font-size: 21px;
	}
	.bigheading h2 {
		font-size: 26px;
	}
	.pad80 {
		padding: 40px 15px;
	}
	.bnrbtn a svg {
		width: 22px;
		height: 22px !important;
		margin-right: 3px;
	}
	.bnrbtn a {
		font-size: 16px;
		line-height: 23px;
	}
	.banner h1 {
		font-size: 36px;
		margin-bottom: 12px;
	}
	.header_main .elementor-menu-toggle {
		padding: 9px;
	}
	.site_logo {
		max-width: 235px;
	}
	.social-list li:hover svg {
		fill: #bababa;
	}
}

@media(max-width: 600px) {
	.ft-logo img {
		max-width: 170px;
		margin: 0 auto 15px;
	}
	.cta-hd h3 {
		font-size: 21px;
		margin-bottom: 7px;
	}
	.inr-hd h1 {
		font-size: 31px;
		margin-bottom: 14px;
	}
	.ft-fix-btn a {
		font-size: 20px;
	}
	.service-boxes .elementor-image-box-img {
		width: 72px !important;
		height: 72px;
	}
	.service-boxes .elementor-image-box-img img {
		max-width: 55px;
		padding: 5px;
	}
	.service-boxes {
		width: 100% !important;
	}
	.hvac-boxes:hover span a {
		color: #333 !important;
	}
	.main-hd {
		margin-bottom: 10px !important;
	}
	.main-hd h3 {
		font-size: 18px;
	}
	.service-list li a {
		font-size: 26px !important;
	}
	.bigheading h2 {
		font-size: 24px;
	}
	.hvac-boxes .elementor-image-box-content {
		padding: 15px;
	}
	.hvac-boxes:nth-child(n+2) {
		margin-top: 10px;
	}
	.hvac-boxes {
		width: 100% !important;
		border: 1px solid #4baf333b;
	}
	
	.banner h1 {
		font-size: 33px;
		margin-bottom: 10px;
	}
	.header_main ul.elementor-nav-menu > li > a, .hd_menu .elementor-nav-menu > li:last-child > a {
		font-size: 19px !important;
		padding: 15px 15px !important;
	}
	.header_main nav.elementor-nav-menu--dropdown {
		width: 340px;
	}
	.header_main .elementor-menu-toggle {
		padding: 8px;
	}
	.site_logo {
		max-width: 205px;
	}
}
@media(max-width: 400px) {

}
