/*
Theme Name: 
Theme URI: 
Description: Bespoke Theme developed by Adrian @ AlphaWebServices.net
Author: Adrian Jones
Version: 1.0
License: 
License URI: 
Tags: 
*/

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600;700;800&display=swap');

*		{margin: 0; border: 0; padding: 0; outline: 0; box-sizing: border-box;}
p, a, small, li, textarea, input, label, td, tr, .gform_confirmation_message, div, .uabb-adv-accordion-content p {font-family: "Poppins", system-ui; font-weight: 400; font-style: normal;}
h1, h2, h3, h4, h5		{font-family: "Poppins", system-ui; font-weight: 700; font-style: normal;}
.clear		{clear: both;}
a		{text-decoration: none;}
html		{overflow-y: scroll; background-color: #fff; scroll-behavior: smooth;}
ul		{list-style-type: none;}
img.alignright {float:right; margin:0 0 1em 1em}
img.alignleft {float:left; margin:0 1em 1em 0}
img.aligncenter {display: block; margin-left: auto; margin-right: auto}
.alignright {float:right; }
.alignleft {float:left; }
.aligncenter {display: block; margin-left: auto; margin-right: auto}
img         {max-width: 100%; max-height: 100%; height: auto;}

.wrapper        {width: 1300px; margin: 0 auto; position: relative;}
.wrapper:after  {content: ""; display: block; clear: both;}

.yPadding        {padding-top: 80px; padding-bottom: 80px;}
.centered       {text-align: center;}

.flex			{display: flex;}
.align-center	{align-items: center;}
.align-bottom	{align-items: flex-end;}
.justify-between	{justify-content: space-between;}
.justify-center		{justify-content: center;}

#header         {padding: 15px 0;}
#header .logo   {float: left; max-height: 100px;}
#header .menu       {float: right; padding: 35px 0;}
#header .menu > li  {position: relative; display: inline-block; vertical-align: top;}
#header .menu > li + li     {margin-left: 30px;}
#header .menu > li > a      {display: block; line-height: 30px; color: #2d3032;}
#header .menu > li > ul     {position: absolute; display: none; top: 100%; left: -15px; z-index: 999; background: #fff;}
#header .menu > li > ul > li    {padding: 8px 0;}
#header .menu > li > ul > li > a    {display: block; padding: 0 15px; white-space: nowrap; color: #2d3032;}
#header .menu > li.active > a       {}
#header .menu > li:hover a        {}
#header .menu > li:hover > ul       {display: block;}
#header .menu > li.menu-item-has-children > a:after	{content: "\f0d7"; font-family: 'Font Awesome 5 Free'; font-weight: 900; padding-left: 7px;}

.homebanner			{}
.homebanner .overlay	{color: #fff; padding: 180px 0 50px;}
.homebanner .overlay h2	{font-weight: 800; font-size: 54px;}
.homebanner .overlay p	{font-size: 42px;}
.homebanner .overlay > a	{display: inline-block; color: #fff; text-transform: uppercase; font-size: 22px; font-weight: 700; background: #308c88; padding: 14px 40px; border-radius: 30px; margin-top: 30px;}
.homebanner .overlay > a:hover		{background: #fff; color: #308c88;}
.homebanner .overlay .bannerFeatures	{margin-top: 60px; display: flex; justify-content: center;}
.homebanner .overlay .bannerFeatures > div		{margin: 0 1%; width: 23%;}
.homebanner .overlay .bannerFeatures > div img	{max-height: 200px;}
.homebanner .overlay .bannerFeatures > div p	{font-weight: 800; font-size: 22px; margin-top: 20px;}
.homebanner .overlay .bannerFeatures > div:hover img	{opacity: 0.7;}

.homeIntro			{background: #cbd4b6;}
.homeIntro .flex	{justify-content: space-between;}
.homeIntro .flex .left		{width: 40%;}
.homeIntro .flex .right		{width: 50%;}
.homeIntro .flex .right h1		{color: #1a333e; font-weight: 800; font-size: 36px;}
.homeIntro .flex .right h2		{color: #84a082; font-weight: 800; font-size: 28px;}
.homeIntro .flex .right p		{color: #3c423c; font-size: 18px; line-height: 180%;}
.homeIntro .flex .right a		{display: inline-block; color: #fff; text-transform: uppercase; font-size: 22px; font-weight: 700; background: #308c88; padding: 14px 40px; border-radius: 30px; margin-top: 30px;}
.homeIntro .flex .right a:hover	{background: #fff; color: #308c88;}

.homeServices		{background: #d9ebea;}
.homeServices h2	{color: #1a333e; font-weight: 800; font-size: 36px;}
.homeServices h3	{color: #84a082; font-weight: 800; font-size: 28px;}
.homeServices p		{color: #3c423c; font-size: 18px; line-height: 180%;}
.homeServices .blocks	{margin-top: 50px; justify-content: space-between;}
.homeServices .blocks > div		{width: 23.5%; border-radius: 20px; overflow: hidden;}
.homeServices .blocks .boxInner		{position: relative;}
.homeServices .blocks .boxInner:before	{content: ""; display: block; padding-top: 100%;}
.homeServices .blocks .boxInner > div	{position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 9;}
.homeServices .blocks .boxInner img		{max-height: 85px;}
.homeServices .blocks .boxInner p		{color: #fff; font-size: 20px; font-weight: 800; margin-top: 15px; white-space: nowrap;}
.homeServices .blocks .boxInner:hover:before		{background: rgba(0,0,0,0.4);}

.homeCTA			{background: #1a333e;}
.homeCTA h2			{color: #fff; font-weight: 800; font-size: 36px;}
.homeCTA p			{color: #fff; font-size: 18px; line-height: 180%;}
.homeCTA .gform_wrapper			{margin: 40px 200px 0;}
.homeCTA .gform_wrapper .gform_footer		{margin: 0!important; padding: 0!important;}
.homeCTA .gform_wrapper.gravity-theme .gfield.gfield--width-third	{grid-column: span 5;}
.homeCTA .gform_wrapper.gravity-theme .gfield.gfield--width-third.gfield--type-submit	{grid-column: span 2;}
.homeCTA .gfield--type-submit input[type="submit"]		{display: block; width: 100%; color: #fff; text-transform: uppercase; font-size: 16px; font-weight: 700; background: #308c88; padding: 8px 0; border-radius: 30px; cursor: pointer; text-align: center;}
.homeCTA .gfield--type-submit input[type="submit"]:hover	{background: #fff; color: #308c88;}

#footer				{background: #132228;}
#footer .left		{width: 66%; float: left;}
#footer .left:after		{content: ""; display: block; clear: both;}
#footer .left .map	{width: 45%; margin-right: 10%; float: left;}
#footer .left .details		{float: left;}
#footer .left .details a	{color: #fff;}
#footer .left .details p	{padding-left: 30px; position: relative; color: #fff; letter-spacing: 1px;}
#footer .left .details p.phone:before	{content: "\f095"; font-family: 'Font Awesome 5 Free'; font-weight: 900; position: absolute; left: 0; top: 4px; color: #cbd4b6;}
#footer .left .details p.email:before	{content: "\f0e0"; font-family: 'Font Awesome 5 Free'; font-weight: 900; position: absolute; left: 0; top: 4px; color: #cbd4b6;}
#footer .left .details p.address		{margin-top: 15px;}
#footer .left .details p.address:before	{content: "\f3c5"; font-family: 'Font Awesome 5 Free'; font-weight: 900; position: absolute; left: 0; top: 4px; color: #cbd4b6;}
#footer .right		{float: right;}
#footer .right p	{font-weight: 800; color: #97c3c2;}
#footer .right ul	{margin-top: 10px;}
#footer .right ul li	{display: inline-block;}
#footer .right ul li + li	{margin-left: 10px;}
#footer .right ul li a	{display: block; text-align: center; height: 46px; width: 46px; background: #fff; border-radius: 40px;}
#footer .right ul li i	{color: #132228; line-height: 46px; font-size: 22px;}
#footer > div + div		{margin-top: 40px;}
#footer .footLinks		{}
#footer .footLinks li	{display: inline-block;}
#footer .footLinks li + li	{margin-left: 11px; border-left: 1px solid #fff; padding-left: 15px;}
#footer .footLinks li a		{color: #fff;}
#footer p.copy		{margin-top: 20px; color: #79c7d3; font-weight: 300;}

.blogindex			{}
.blogindex .left	{width: 75%; float: left;}
.blogindex .left .row	{margin-bottom: 40px;}
.blogindex .left .row:after		{content: ""; display: block; clear: both;}
.blogindex .left .row > div		{width: 30%; float: left;}
.blogindex .left .row > div + div	{margin-left: 5%;}
.blogindex .left .row > div .postimg	{margin-bottom: 20px;}
.blogindex .left .row > div .postimg:before		{content: ""; display: inline-block; padding-top: 75%;}
.blogindex .left .row > div a		{color: #84a082;}
.blogindex .right	{width: 20%; float: right;}
.blogindex .right .widget		{list-style-type: none; margin-bottom: 40px;}
.blogindex .right .widgettitle	{color: #84a082; margin-bottom: 15px;}
.blogindex .right .widget_search	{}
.blogindex .right .widget_search label span	{display: block;}
.blogindex .right .widget_search .search-field		{width: 100%; -webkit-appearance: none; padding: 3px; border: 0.001em solid #000; margin-bottom: 8px;}
.blogindex .right .widget_search .search-submit		{display: inline-block; color: #fff; font-size: 13px; font-weight: 700; background: #84a082; padding: 6px 8px;}
.blogindex .right .widget ul li		{padding: 5px 0;}
.blogindex .right .widget a			{color: #84a082;}

.content h1         {color: #1a333e; font-weight: 800; font-size: 36px; margin-bottom: 30px; text-align: center;}
.content h2         {color: #1a333e; font-weight: 800; font-size: 32px; margin-bottom: 25px;}
.content h3         {color: #84a082; font-weight: 800; font-size: 28px; margin-bottom: 20px;}
.content h4         {color: #84a082; font-weight: 800; font-size: 24px; margin-bottom: 20px;}
.content h5         {color: #84a082; font-weight: 800; font-size: 20px; margin-bottom: 20px;}
.content p          {color: #3c423c; font-size: 18px; line-height: 180%; margin-bottom: 15px;}
.content a          {font-weight: bold; color: #84a082;}
.content ul         {margin: 0 0 20px 30px;}
.content ul li      {color: #3c423c; font-size: 18px; padding: 8px 0; list-style-type: disc;}
.content ol         {margin: 0 0 20px 30px;}
.content ol li      {color: #3c423c; font-size: 18px; padding: 8px 0; list-style-type: decimal;}
.content .fl-pricing-table li   {list-style-type: none;}
#more_posts			{display: block; max-width: 250px; background: #000; color: #fff; border-radius: 2px; text-align: center; font-size: 17px; font-weight: 600; cursor: pointer; text-transform: uppercase; padding: 12px 0; margin: 60px auto 0; border-radius: 5px; -webkit-border-radius: 5px;}

.innerpage .gform_wrapper .gform_body input,
.innerpage .gform_wrapper .gform_body textarea	{border: 1px solid #3c423c;}
.innerpage .gform_wrapper .gform_body label		{font-weight: 800; color: #3c423c;}
.innerpage .gform_wrapper .gform_footer input[type="submit"]	{display: inline-block; color: #fff; text-transform: uppercase; font-size: 16px; font-weight: 700; background: #308c88; border: 3px solid #308c88; padding: 8px 40px; border-radius: 30px; cursor: pointer; text-align: center;}
.innerpage .gform_wrapper .gform_footer input[type="submit"]:hover		{background: #fff; color: #308c88;}

@media all and (max-width : 1300px) {
	.wrapper,
	.innerpage {
		width: auto;
		padding-left: 15px;
		padding-right: 15px;
	}
	#header .logo {
		max-height: 90px;
	}
	#header .menu {
		padding: 30px 0;
	}
	#header .menu > li + li {
		margin-left: 25px;
	}
	.homebanner .overlay {
		padding: 120px 0 50px;
	}
	.homebanner .overlay h2 {
		font-size: 48px;
	}
	.homebanner .overlay .bannerFeatures > div {
		margin: 0 15px;
		text-align: center;
	}
	.homebanner .overlay .bannerFeatures > div img {
		max-height: 185px;
		display: inline-block;
	}
	.homebanner .overlay .bannerFeatures > div p,
	.homeServices .blocks .boxInner p {
		font-size: 18px;
	}
	.homeIntro .flex .left {
		width: 47%;
	}
	#footer .left {
		width: 75%;
	}
	.homeCTA .gfield--type-submit input[type="submit"] {
		font-size: 14px;
	}
}

@media all and (max-width : 992px) {
	#header {
		text-align: center;
	}
	#header .logo {
		float: none;
	}
	.homebanner .overlay h2 {
		font-size: 42px;
	}
	.homebanner .overlay .bannerFeatures > div img {
		max-height: 160px;
	}
	.homeServices .blocks {
		flex-wrap: wrap;
	}
	.homeServices .blocks > div {
		width: 49%;
		margin-bottom: 20px;
	}
	.homeCTA .gform_wrapper {
		margin: 40px 0 0;
	}
	#footer .left {
		width: auto;
		float: none;
	}
	#footer .left .map {
		margin-right: 0;
	}
	#footer .left .details {
		float: right;
	}
	#footer .right {
		float: none;
		text-align: center;
		margin-top: 40px;
	}
	.blogindex .left {
		width: auto;
		float: none;
	}
	.blogindex .right {
		width: auto;
		float: none;
		margin-top: 40px;
		text-align: center;
	}
}

@media all and (max-width : 768px) {
	.homebanner .overlay {
		padding: 50px 0;
	}
	.homebanner .overlay h2,
	.homeIntro .flex .right h1,
	.homeServices h2,
	.homeCTA h2 {
		font-size: 32px;
	}
	.homebanner .overlay > a,
	.homeIntro .flex .right a {
		font-size: 18px;
	}
	.homebanner .overlay .bannerFeatures {
		flex-wrap: wrap;
	}
	.homebanner .overlay .bannerFeatures > div {
		width: 30%;
		margin: 0 40px 40px;
	}
	.homebanner .overlay .bannerFeatures > div p {
		margin-top: 5px;
	}
	.homeIntro .flex {
		flex-wrap: wrap;
	}
	.homeIntro .flex .left {
		width: 100%;
	}
	.homeIntro .flex .right {
		width: 100%; margin-top: 40px;
	}
	.homeIntro .flex .right h2,
	.homeServices h3 {
		font-size: 24px;
	}
	.homeCTA .gform_wrapper.gravity-theme .gform_fields {
		display: block;
	}
	.homeCTA .gform_wrapper.gravity-theme .gform_fields > div + div {
		margin-top: 10px;
	}
}

@media all and (max-width : 586px) {
	.homebanner .overlay h2,
	.homeIntro .flex .right h1,
	.homeServices h2,
	.homeCTA h2 {
		font-size: 28px;
	}
	.homeIntro .flex .right h2,
	.homeServices h3 {
		font-size: 20px;
	}
	.homebanner .overlay .bannerFeatures > div p,
	.homeServices .blocks .boxInner p {
		font-size: 15px;
	}
	#header .logo {
		max-height: 75px;
	}
	.homebanner .overlay {
		padding: 50px 0 0;
	}
	.homebanner .overlay .bannerFeatures {
		margin-top: 30px;
	}
	.homebanner .overlay .bannerFeatures > div {
		margin: 0 30px 30px;
	}
	.homebanner .overlay .bannerFeatures > div img {
		max-height: 140px;
	}
	#footer .left .map {
		float: none;
		width: 75%;
		margin: 0 auto;
	}
	#footer .left .details {
		float: none;
		width: auto;
		margin: 25px auto 0;
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.blogindex .left .row > div {
		width: auto;
		float: none;
		text-align: center;
	}
	.blogindex .left .row > div + div {
		margin: 40px 0 0;
	}
}