/* Global
---------------------------------------------------------------------------- */

:root {
	--dark-green: #0f3d2e;
	--med-green: #42994e;
	--light-green: #8bc143;
}

body {
	background-color: #edeae6;
	color: #444;
	font-family: 'Alan Sans', Arial, sans-serif;
	font-size: 18px;
	line-height: 1.5;
}

strong {
	font-weight: 600;
}

a {
	color: var(--light-green);
}

a:focus,
a:hover {
	color: var(--dark-green);
}

h1,
h2,
h3,
h4,
.entry-content h3,
.entry-content h4,
h5,
h6 {
	color: #282420;
	font-family: 'Alan Sans', Arial, sans-serif;
	margin: 0 0 20px;
}

h1 { font-size: 44px; }
h2 { font-size: 36px; }
h3 { font-size: 32px; }
h4 { font-size: 28px; }
h5 { font-size: 24px; }
h6 { font-size: 21px; }

button, 
input[type="button"],
input[type="reset"],
input[type="submit"], 
.button {
	background-color: var(--dark-green);
	border-radius: 8px;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.25;
	padding: 12px 35px;
	position: relative;
}

.site-container div.wp-block-button .wp-block-button__link {
	border-radius: 8px;
	font-family: 'Alan Sans', Arial, sans-serif;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.25;
	padding: 12px 35px;
	position: relative;
	transition: all .2s ease-in-out;
}

.site-container div.wp-block-button.is-style-outline .wp-block-button__link {
	border-width: 1px;
}

button:focus,
button:hover,
input[type="button"]:focus,
input[type="button"]:hover,
input[type="reset"]:focus,
input[type="reset"]:hover,
input[type="submit"]:focus,
input[type="submit"]:hover,
.button:focus,
.button:hover {
	background-color: var(--dark-green);
	//transform: scale(1.01);
}

.site-container div.wp-block-button .wp-block-button__link:focus,
.site-container div.wp-block-button .wp-block-button__link:hover,
.site-container div.wp-block-button.is-style-outline .wp-block-button__link:focus,
.site-container div.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background-color: var(--dark-green) !important;
	border-color: var(--dark-green);
	//box-shadow: inset 0 0 200px rgba(230, 230, 230, .25);
	box-shadow: none;
	color: #fff !important;
	//transform: scale(1.01);
}

button.pointer::after, 
input[type="button"].pointer::after,
input[type="reset"].pointer::after,
input[type="submit"].pointer::after, 
.button.pointer::after,
.site-container .wp-block-button.pointer .wp-block-button__link:after {
	content: '\f178';
	font: var(--fa-font-solid);
	margin-left: 10px;
	position: relative;
	right: 0;
	top: 1px;
	transition: right .2s ease-in-out;
}

button:focus::after,
button:hover::after,
input[type="button"]:focus::after,
input[type="button"]:hover::after,
input[type="reset"]:focus::after,
input[type="reset"]:hover::after,
input[type="submit"]:focus::after,
input[type="submit"]:hover::after,
.button:focus::after,
.button:hover::after,
.site-container .wp-block-button .wp-block-button__link:focus::after,
.site-container .wp-block-button .wp-block-button__link:hover::after {
	right: -3px;
}

*.no-margin {
	margin: 0;
}

/* Containers
----------------------------------------------- */

.site-container {
	animation: none;
	background-color: #fff;
	overflow-x: hidden;
}

.wrap {
	margin-inline: auto;
	max-width: 90%;
}

.site-inner {
	border-bottom: 30px solid #0f3d2e;
	border-top: 1px solid #f6f2ee;
	max-width: none;
	padding-left: 0;
	padding-right: 0;
}

body.transparent-header .site-inner {
	border-top: none;
}

body.full-width-content .content {
	width: 100%;
}

body .content > article {
	margin-bottom: 0;
}

*.alignfull > div {
	margin-inline: auto;
	max-width: 90%;
}

.wp-block-media-text .wp-block-media-text__content p:last-child {
	margin: 0;
}


/* Header
---------------------------------------------------------------------------- */

.site-header {
	box-shadow: none;
	padding: 15px 0;
	position: relative;
}

.site-header > .wrap {
	display: grid;
	gap: 10px;
	grid-template-areas: 'logo nav';
	grid-template-columns: auto 1fr;
}

.site-header > .wrap::before,
.site-header > .wrap::after {
	display: none;
}

.site-header .title-area {
	grid-area: logo;
	float: none;
	justify-self: start;
	padding: 0;
}

.site-header .nav-primary.genesis-responsive-menu {
	align-self: center;
	float: none;
	grid-area: nav;
	justify-self: end;
	padding: 0;
}

.site-header .nav-primary > .wrap {
	margin: 0;
	max-width: none;
}

.nav-primary .genesis-nav-menu a {
	color: #282420;
	font-size: 18px;
	font-weight: 500;
	padding: 9px 25px;
}

.nav-primary .genesis-nav-menu a:focus,
.nav-primary .genesis-nav-menu a:hover {
	color: var(--light-green);
}

@media only screen and (min-width: 960px) {
	.nav-primary .genesis-nav-menu li.menu-highlight a {
		background-color: var(--dark-green);
		border-radius: 5px;
		color: #fff;
		padding-left: 35px;
		padding-right: 35px;
	}
	
	.nav-primary .genesis-nav-menu li.menu-highlight a:focus,
	.nav-primary .genesis-nav-menu li.menu-highlight a:hover {
		background-color: var(--light-green);
	}
}


/* Content
---------------------------------------------------------------------------- */

/* Global
----------------------------------------------- */

.entry-content .wp-block-image img {
	border-radius: 5px;
}

.wp-block-media-text.alignfull > div {
	max-width: 100%;
}

.wp-block-media-text:not(.has-media-on-the-right)>.wp-block-media-text__content {
	padding-right: 0;
}

.wp-block-media-text.has-media-on-the-right>.wp-block-media-text__content {
	padding-left: 0;
}

.wp-block-media-text.alignfull.is-image-fill-element>.wp-block-media-text__media img {
	width: 50vw;
}

.wp-block-media-text.alignfull.is-image-fill-element:not(.has-media-on-the-right)>.wp-block-media-text__media img {
	right: 0;
}

.wp-block-list > li {
	line-height: 1.3;
	margin-bottom: 7px;
}

.wp-block-list.leaves {
	padding-left: 25px;
}

.wp-block-list.checkmarks li,
.wp-block-list.leaves li  {
	list-style-type: none;
	position: relative;
}

.wp-block-list.leaves li {
	margin-bottom: 15px;
}

.wp-block-list.checkmarks li::before {
	color: #42994e;
	content: '\f147';
	display: block;
	font-family: 'dashicons';
	left: -10px;
	pointer-events: none;
	position: absolute;
	transform: translateX(-100%) scale(1.5);
	transform-origin: 50% 50%;
}

.wp-block-list.leaves li::before {
	background: url(../images/petal-green.svg) no-repeat;
	background-size: 16px 8px;
	content: '';
	display: block;
	height: 8px;
	left: -23px;
	pointer-events: none;
	position: absolute;
	top: 9px;
	transform: rotate(45deg);
	transform-origin: 50% 50%;
	width: 16px;	
}

.wp-block-heading.pointer {
	margin-bottom: 5px;
	padding-left: 30px;
	position: relative;
}

.wp-block-heading.pointer::before {
	content: '\f178';
	display: inline-block;
	font: var(--fa-font-solid);
	left: 0;
	margin-right: 3px;
	position: absolute;
	top: 1px;
	transform: scale(.7);
}

.wp-block-group.pointers p {
	padding-left: 30px;
}

/* Hero
----------------------------------------------- */

.hero .wp-block-media-text .wp-block-media-text__content {
	padding-left: 10%;
	padding-right: 0;
}

.hero .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
	padding-left: 0;
	padding-right: 10%;
}

.hero .wp-block-media-text.is-image-fill-element > .wp-block-media-text__media img {
	width: 100vw;
}

@media only screen and (min-width: 601px) {
	
	.hero .wp-block-media-text {
		grid-template-columns: 40% auto !important;
	}
	
	.hero .wp-block-media-text.has-media-on-the-right {
		grid-template-columns: auto 40% !important;
	}
	
	.hero .wp-block-media-text.is-image-fill-element > .wp-block-media-text__media img {
		right: 0;
		width: 50vw;
	}
	
	.hero .wp-block-media-text.has-media-on-the-right.is-image-fill-element > .wp-block-media-text__media img {
		left: 0;
		width: 50vw;
	}
	
	.hero .wp-block-media-text .wp-block-media-text__content {
		padding-bottom: 40px;
		padding-top: 40px;
	}
	
}

/* CTA
----------------------------------------------- */

.wp-block-group.cta h4,
.wp-block-group.cta p:last-child {
	margin: 0;
}

.wp-block-group.cta .gb-layout-columns-2>.gb-layout-column-wrap {
	align-items: center;
	gap: 40px 5%;
	grid-template-columns: repeat(2,auto);
}

.site-container .wp-block-group.cta  div.wp-block-button .wp-block-button__link:focus,
.site-container .wp-block-group.cta  div.wp-block-button .wp-block-button__link:hover,
.site-container .wp-block-group.cta  div.wp-block-button.is-style-outline .wp-block-button__link:focus,
.site-container .wp-block-group.cta  div.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background-color: var(--light-green) !important;
	color: #fff !important;
}

/* Callout
----------------------------------------------- */

@media only screen and (min-width: 601px) {

	.callout .gb-layout-columns-2 > .gb-layout-column-wrap {
		gap: 0 125px;
		grid-template-columns: auto calc(40% - 50px) !important;
		margin: 50px auto;
	}
	
	.callout.value .gb-layout-columns-2 > .gb-layout-column-wrap {
		margin-top: 0;
	}
	
}
	
.callout .wp-block-genesis-blocks-gb-columns .gb-block-layout-column-inner.gb-has-custom-background-color {
	position: relative;
}

.callout.value .wp-block-genesis-blocks-gb-columns .gb-block-layout-column-inner.gb-has-custom-background-color {
	margin-top: 50px;
	position: relative;
}


.callout .wp-block-genesis-blocks-gb-columns .gb-block-layout-column-inner.gb-has-custom-background-color::before {
	background-color: #f4f4f4;
	border-radius: 5px;
	content: '';
	display: block;
	height: calc(100% + 100px);
	left: -50px;
	pointer-events: none;
	position: absolute;
	top: -50px;
	width: calc(100% + 100px);
}

.callout .wp-block-genesis-blocks-gb-columns .gb-block-layout-column-inner.gb-has-custom-background-color > * {
	position: relative;
}

.callout .wp-block-list {
	line-height: 1.25;
}

.callout .wp-block-list li {
	margin-bottom: 20px;
}

/* Stylized Media & Text blocks
----------------------------------------------- */

.wp-block-media-text.fancy.has-background {
	background-color: transparent !important;
}

.wp-block-media-text.fancy.has-background .wp-block-media-text__media {
	border-radius: 5px;
	min-height: none;
	overflow: hidden;
}

.wp-block-media-text.fancy.has-background .wp-block-media-text__content {
	background-color: #fff;
	border-radius: 5px;
	margin: -40px auto 30px auto;
	padding: 30px 35px;
	width: 95%;
	z-index: 2;
}

@media only screen and (min-width: 601px) {
	
	.wp-block-media-text.fancy.has-background .wp-block-media-text__content {
		margin-bottom: 45px;
		margin-left: -10%;
		margin-right: 0;
		margin-top: 45px;
		width: 110%;
	}
	
	.wp-block-media-text.fancy.has-media-on-the-right.has-background .wp-block-media-text__content {
		margin-left: 0;
		margin-right: -10%;
	}

}

/* Chart
----------------------------------------------- */

.chart .gb-layout-columns-3>.gb-layout-column-wrap {
	grid-template-columns: 
		[col1] 1fr 
		[col2] 1.4fr
		[col3] 1fr;
	grid-template-rows:
		[heading] auto
		[title] auto
		[info] auto
		[highlight] auto;
	line-height: 1.25;
}

@media only screen and (min-width: 961px) {
	.chart .gb-layout-columns-3>.gb-layout-column-wrap > *,
	.chart .gb-layout-columns-3>.gb-layout-column-wrap > * > * {
		display: grid;
		grid: subgrid / subgrid;
		grid-row: 1 / span 4;
	}
}

.chart .gb-layout-column-wrap .gb-block-layout-column {
	border: 1px solid rgba(0,0,0,0.2);
	border-radius: 10px;
	padding: 0 15px 15px;
}

.chart .gb-layout-columns-3>.gb-layout-column-wrap .gb-block-layout-column-inner {
	display: grid;
	grid: subgrid / subgrid;
}

.chart .wp-block-group.heading {
	grid-area: heading;
	margin-bottom: 10px;
	margin-left: -15px;
	margin-right: -15px;
	margin-top: -35px;
}

.chart .heading > div {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	justify-self: center;
	width: 100%;
}

.chart .heading > div > * {
	display: inline-block;
	flex: 0 0 auto;
}

.chart .heading h4:where(.wp-block-heading).has-background {
	align-content: center;
	aspect-ratio: 1/1;
	border: 2px solid #fff;
	border-radius: 100%;
	margin: 0;
	max-width: 70px;
	padding: 0;
	position: relative;
	width: 100%;
	z-index: 2;
}

.chart .heading h5:where(.wp-block-heading).has-background {
	border: 2px solid #fff;
	border-radius: 5px;
	line-height: 1.1;
	margin: 0;
	margin-left: -30px;
	padding: 9px 20px;
	padding-left: 40px;
	position: relative;
	max-width: calc(100% - 70px);
	z-index: 1;
}

.chart .wp-block-group.title {
	border-bottom: 1px solid rgba(0,0,0,0.2);
	grid-area: title;
	margin-bottom: 18px;
}

.chart .wp-block-group.title .wp-block-image {
	margin-bottom: 20px;
}

.chart .wp-block-group.title .wp-block-image img {
	height: 120px;
	width: auto !important;
}

.chart p {
	margin-bottom: 18px;
}

.chart .wp-block-separator {
	margin: 10px 0;
}

.chart .wp-block-group.info {
	grid-area: info;
}

.chart .wp-block-group.info .wp-block-list {
	margin-bottom: 18px;
}

.chart .wp-block-group.highlight {
	grid-area: highlight
}

.chart .wp-block-group.highlight > * {
	height: 100%;
}

.chart .wp-block-media-text.has-background {
	gap: 1em;
	grid-template-columns: 50px auto !important;
	height: 100%;
	padding: 10px 15px;
}

.value .chart .wp-block-media-text.has-background {
	padding: 0;
}

.chart .wp-block-media-text>.wp-block-media-text__content {
	padding: 0;
}

@media only screen and (min-width: 960px) and (max-width: 1240px) {
	
	.chart {
		margin-top: 60px;
	}
	
	.value .chart {
		margin-top: 0;
	}
	
	.chart .wp-block-group.heading {
		margin-left: 0;
		margin-right: 0;
		margin-top: -90px;
	}
	
	.chart .heading h5:where(.wp-block-heading).has-background {
		margin-left: 0;
		max-width: 100%;
		padding-left: 20px;
		width: 100%;
	}
	
}

@media only screen and (max-width: 960px) {
	
	.chart .gb-layout-columns-3>.gb-layout-column-wrap {
		display: block;
	}
	
	.chart .gb-layout-column-wrap .gb-block-layout-column {
		margin-bottom: 70px;
	}
	
	.chart .gb-layout-column-wrap .gb-block-layout-column:last-child {
		margin-bottom: 0;
	}
	
	.chart .gb-layout-columns-3>.gb-layout-column-wrap .gb-block-layout-column-inner {
		display: block;
		grid-template-rows:
			[heading] auto
			[title] auto
			[info] auto
			[highlight] auto;
		line-height: 1.25;
	}
	
}

@media only screen and (max-width: 600px) {
	
	.chart {
		margin-top: 60px;
	}
	
	.chart .gb-layout-column-wrap .gb-block-layout-column {
		margin-bottom: 120px;
	}
	
	.chart .wp-block-group.heading {
		margin-left: 0;
		margin-right: 0;
		margin-top: -90px;
	}
	
	.chart .heading h5:where(.wp-block-heading).has-background {
		margin-left: 0;
		max-width: 100%;
		padding-left: 20px;
		width: 100%;
	}
	
	.value .chart .wp-block-media-text.has-background.is-stacked-on-mobile > .wp-block-media-text__content {
		grid-column: 2;
		grid-row: 1;
	}
	
}


/* Homepage
---------------------------------------------------------------------------- */

/* Header
----------------------------------------------- */

body.home .site-header {
	background-color: rgba(7,33,23,0);
	position: absolute;
	transition: background .2s ease-in-out;
	width: 100%;
	z-index: 1000;
}

body.home .site-header.opaque {
	background-color: rgba(7,33,23,1);
}

body.home .nav-primary .genesis-nav-menu a {
	color: #fff;
}

body.home .nav-primary .genesis-nav-menu a:focus,
body.home .nav-primary .genesis-nav-menu a:hover {
	color: var(--light-green);
}

@media only screen and (min-width: 960px) {	
	.nav-primary .genesis-nav-menu li.menu-highlight a:focus,
	.nav-primary .genesis-nav-menu li.menu-highlight a:hover {
		background-color: var(--light-green);
		color: #fff;
	}
}

body.home .menu-toggle,
body.home .sub-menu-toggle {
	color: #fff;
}

/* Hero
----------------------------------------------- */

body.home .hero > div {
	padding: 5vw 0;
}

body.home .hero .gb-container-content {
	margin: 0;
	position: relative;
}

body.home .hero .gb-container-content::before {
	aspect-ratio: 1 / 1;
	background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.66), rgba(0, 0, 0, 0.25) 50%, rgba(0, 0, 0, 0) 70%);
	content: '';
	display: block;
	height: auto;
	left: 50%;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translate(-50%,-50%);
	width: 200%;
	z-index: 0;
}

body.home .hero .gb-container-content > * {
	position: relative;
}

/* About
----------------------------------------------- */

body.home .about .wp-block-media-text.alignfull.is-image-fill-element>.wp-block-media-text__media img {
	width: 40vw;
}

@media only screen and (min-width: 601px) {
	
	body.home .about .wp-block-media-text__content {
		padding-bottom: 80px;
		padding-top: 80px;
	}

}

/* Services
----------------------------------------------- */

.services .gb-layout-columns-3>.gb-layout-column-wrap {
	grid-template-columns: 
		[col1] 1fr 
		[col2] 1fr
		[col3] 1fr;
	grid-template-rows:
		[image] auto
		[title] auto
		[text] auto
		[link] auto;
	line-height: 1.25;
}

@media only screen and (min-width: 961px) {
	.services .gb-layout-columns-3>.gb-layout-column-wrap > *,
	.services .gb-layout-columns-3>.gb-layout-column-wrap > * > * {
		display: grid;
		grid: subgrid / subgrid;
		grid-row: 1 / span 4;
	}
}

.services .gb-layout-column-wrap .wp-block-image {
	grid-area: image;
}

body.home .services .wp-block-image a img {
	opacity: 1;
	transition: all .2s ease-in-out;
}

body.home .services .wp-block-image a:focus img,
body.home .services .wp-block-image a:hover img {
	opacity: .8;
	transform: scale(1.02);
}

.services .gb-layout-column-wrap .wp-block-heading {
	align-self: center;
	grid-area: title;
	margin-bottom: 10px;
}

.services .gb-layout-column-wrap .info {
	border-top: 1px solid rgba(0,0,0,0.2);
	grid-area: text;
	padding-top: 10px;
}

.services .gb-layout-column-wrap .wp-block-buttons {
	grid-area: link;
}


/* Footer
---------------------------------------------------------------------------- */

.footer-widgets {
	background-color: #f6f2ee;
	border-top: 15px solid var(--light-green);
	overflow: hidden;
	padding: 90px 0;
	position: relative;
}

.footer-widgets::before {
	aspect-ratio: 1 / 1;
	background: url(../images/flower.svg) no-repeat center;
	background-size: contain;
	content: '';
	display: block;
	height: 475px;
	left: -5px;
	opacity: .04;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: auto;
	z-index: 0;
}

.footer-widgets > .wrap {
	display: grid;
	gap: 50px 21%;
	grid-template-areas: 'info branding';
	grid-template-columns: 1fr 277px;
}

.footer-widgets > .wrap::before,
.footer-widgets > .wrap::after {
	display: none;
}

.footer-widget-area {
	float: none;
	margin: 0;
	padding: 0;
	width: 100%;
}

.footer-widgets .widget {
	margin-bottom: 20px;
}

.footer-widgets .widget-title {
	font-size: 32px;
	font-weight: 300;
}

.footer-widgets .widget-title .inline {
	display: inline-block;
}

.footer-widgets-1 {
	grid-area: info;
	margin-top: 30px;
}

.footer-widgets-1 a.button:focus,
.footer-widgets-1 a.button:hover {
	background-color: var(--light-green);
}

.footer-widgets-1 p {
	margin-bottom: 50px;
}

.footer-widgets-1 p:last-child {
	margin-bottom: 0;
}

.footer-widgets-1 .menu {
	display: flex;
	flex-wrap: wrap;
	grid-gap: 0 30px;
}

.footer-widgets-1 .menu li {
	margin: 0;
}

.footer-widgets-1 .menu a {
	color: var(--dark-green);
	font-size: 16px;
	font-weight: 500;
	position: relative;
	text-decoration: none;
}

.footer-widgets-1 .menu a::before {
	content: '\f178';
	font: var(--fa-font-solid);
	font-size: 14px;
	left: 0;
	margin-right: 5px;
	pointer-events: none;
	position: relative;
	top: 1px;
	transition: left .2s ease-in-out;
}

.footer-widgets-1 .menu a:focus::before,
.footer-widgets-1 .menu a:hover::before {
	left: 2px;
}

.footer-widgets-1 .menu a:focus,
.footer-widgets-1 .menu a:hover {
	color: var(--light-green);
}

.footer-widgets-2 {
	grid-area: branding;
	text-align: center;
}

.footer-widgets-2 img {
	margin-bottom: -5px;
	max-width: 100%;
	width: 277px;
}

.footer-widgets-2 a.phone,
.footer-widgets-2 a.email {
	color: var(--dark-green);
	line-height: 1.33;
	text-decoration: none;
}

.footer-widgets-2 a.phone {
	font-size: 36px;
	font-weight: 600;
}

.footer-widgets-2 a.email {
	font-size: 24px;
	font-weight: 300;
}

.footer-widgets-2 a.phone:focus,
.footer-widgets-2 a.phone:hover,
.footer-widgets-2 a.email:focus,
.footer-widgets-2 a.email:hover {
	color: var(--light-green);
}

.site-footer {
	background-color: #edeae6;
	color: #6d6e71;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.33;
	padding: 15px 0;
	text-align: left;
}

.site-footer > .wrap {
	display: grid;
	gap: 15px;
	grid-template-areas: 'credits legal';
	grid-template-columns: repeat(2, auto);
}

.site-footer a {
	color: #6d6e71;
	text-decoration: none;
}

.site-footer a:focus,
.site-footer a:hover {
	color: #111;
}

.site-footer .nav-secondary {
	grid-area: legal;
	justify-self: end;
	margin: 0;
}

.site-footer .nav-secondary > .wrap {
	max-width: none;
}

.site-footer .nav-secondary .genesis-nav-menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: end;
}

.site-footer .nav-secondary .genesis-nav-menu a {
	font-size: 14px;
	line-height: 1.33;
}

.site-footer .credits {
	grid-area: credits;
}


/* Media Queries
---------------------------------------------------------------------------- */

@media only screen and (min-width: 960px) {
	
	.site-header > .wrap {
		max-width: calc(100% - 60px);
	}
}

@media only screen and (min-width: 1024px) {
	
	.wrap,
	*.alignfull > div {
		max-width: 960px;
	}
	
}

@media only screen and (min-width: 1240px) {
	
	.wrap,
	*.alignfull > div {
		max-width: 1170px;
	}
	
}

@media only screen and (max-width: 959px) {
	
	.site-header > .wrap {
		grid-template-areas: 'logo toggle' 'nav nav';
	}
	
	.site-header .menu-toggle {
		align-self: center;
		font-size: 18px;
		justify-self: end;
		grid-area: toggle;
		margin: 0;
		padding: 15px 0;
	}
	
	.site-header .menu-toggle:focus,
	.site-header .menu-toggle:hover {
		color: var(--light-green);
	}
	
	.site-header .menu-toggle::after {
		display: none;
	}
	
	.nav-primary .genesis-nav-menu a {
		padding-left: 0;
		padding-right: 0;
	}
}

@media only screen and (max-width: 767px) {
	
	.footer-widgets > .wrap {
		grid-template-areas: 'info' 'branding';
		grid-template-columns: 100%;
	}
	
	.footer-widgets-1 {
		margin-top: 0;
		text-align: center;
	}
	
	.footer-widgets-1 .menu {
		justify-content: center;
	}
	
	.site-footer > .wrap {
		grid-template-areas: 'legal' 'credits';
		grid-template-columns: 100%;
		text-align: center;
	}
	
	.site-footer .nav-secondary {
		justify-self: center;
		margin-top: 10px;
	}
	
	.site-footer .nav-secondary .genesis-nav-menu {
		justify-content: center;
	}
	
}

@media only screen and (max-width: 600px) {
	
	.wp-block-media-text:not(.has-media-on-the-right)>.wp-block-media-text__content,
	.wp-block-media-text.has-media-on-the-right>.wp-block-media-text__content {
		padding-left: 0;
		padding-right: 0;
	}
	
	.wp-block-media-text.alignfull.is-image-fill-element:not(.has-media-on-the-right)>.wp-block-media-text__media img,
	.wp-block-media-text.alignfull.is-image-fill-element>.wp-block-media-text__media img,
	body.home .about .wp-block-media-text.alignfull.is-image-fill-element>.wp-block-media-text__media img  {
		left: 50%;
		right: auto;
		transform: translateX(-50%);
		width: 100vw
	}
	
	.hero .wp-block-media-text.is-stacked-on-mobile figure {
		margin: 0;
	}
	
	.hero .wp-block-media-text.is-image-fill-element > .wp-block-media-text__media img {
		left: 50%;
		transform: translateX(-50%);
	}
	
	.hero .wp-block-media-text .wp-block-media-text__content,
	.hero .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
		padding-left: 0;
		padding-right: 0;
	}
	
	.wp-block-group.cta .gb-layout-columns-2>.gb-layout-column-wrap {
		grid-template-columns: 100%;
		text-align: center;
	}
	
	.services .gb-layout-columns-3>.gb-layout-column-wrap {
		gap: 3em 0;
		grid-template-columns: 100%;
		grid-template-rows: auto;
	}
	
}

@media only screen and (max-width: 400px) {
	
	.site-header > .wrap {
		grid-template-areas: 'logo' 'toggle' 'nav';
		grid-template-columns: 100%;
	}
	
	.site-header .title-area {
		justify-self: center;
	}
	
	.site-header .menu-toggle {
		justify-self: center;
		margin-top: -10px;
	}
	
}