@charset "utf-8";
/* CSS Document */

/* !!!!!!!!!!!!!! DO NOT USE CAROUSELS INSIDE A TEMPLATE AREA ON MOBILE or you must give them a max-width !!!!!!!!!!!!!!!
If you must, use it on larger devices but on <660 hide it and show the testimonials above or below the template area */

/* --- START Main Layout --- */

	#banner {
		grid-area: banner;
		background-color: rgba(239,219,162,1.00);
	}
	#layout_content-main {
	grid-area: layout_content-main;
	/* [disabled]background-color: rgba(215,250,215,1.00); */
	}
	#layout_content-sub {
		grid-area: layout_content-sub;
		/* [disabled]background-color: rgba(136,197,136,1.00); */
	}
	#layout_highlights {
		grid-area: layout_highlights;
		max-width: 500px;
		margin: auto;
	}
	#layout_services-main {
		grid-area: layout_services-main;
	}
	#layout_layout_mission {
		grid-area: layout_layout_mission;
	}
	#layout_benefits-main {
		grid-area: layout_benefits-main;
	}
	#layout_benefits-sub {
	grid-area: layout_benefits-sub;
	}
	#layout_news { /* carousels are messing up the layout. By limiting the width it works so likely a sizing issues within the container */
	grid-area: layout_news;
	}
	#layout_sidebar {
		grid-area: layout_sidebar;
	}

	#layout_testimonials { /* carousels are messing up the layout. By limiting the width it works so likely a sizing issues within the container */
	grid-area: layout_testimonials;
	border-radius: 8px;
	border: 1px solid #333333;
	background-color: rgba(45,45,45,0.72);
	margin-top: auto;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 60px;
	max-width: 400px;
	}
	#layout_logos {
		grid-area: layout_logos;
		background-color: rgba(180,214,221,1.00);
	}

	
	@media (min-width: 660px) {
		#layout_testimonials {
			max-width: 100%;
		}
	}

/* --- END Main Layout ---- */


/* START other Layouts */


/* 2 column layout */

/* SET UP LAYOUTS USING GRID TEMPLATES! */

	#layout_sidebar-left {
	grid-area: layout_sidebar-left;
	padding-top: 10px;
	}
	#layout_main_sidebar-left {
		grid-area: layout_main_sidebar-left;
	}

	.grid_2-equal-cols {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
		gap: 1rem;
		margin-right: auto;
		margin-left: auto;
	}	

	.grid_2-equal-cols_narrow {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
		gap: 1rem;
		margin-right: auto;
		margin-left: auto;
		/* [disabled]background-color: #FF5700; */
	}
	
	.grid_2cols-w-rightSidebar {
	max-width: 460px;
	margin: auto;
	display: grid;
	grid-template-columns: minmax(15%) 1fr;
	gap: 2em;
	width: auto;
	}	
	
	.grid_2cols-w-leftSidebar {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	grid-gap: 2rem;
	}

	.grid_2cols-w-leftSidebar_narrow {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
		gap: 1rem;
		margin-right: auto;
		margin-left: auto;
		grid-gap: 2rem;
	}

/* Masonry Layout */
	.masonryWrapper {
	columns: 300px;
	/* [disabled]background-color: #2EB457; */
	padding-right: 28px;
	padding-left: 28px;
	padding-top: 0rem;
		/*column-gap: 20px;*/ 
	}
	.masonryHeader {
	background-color: #2EB457;
	z-index: 1000;

	}
	.masonryHeader h2 {
	font-size: 2rem;
	color: #fff;
	margin: 0;
	padding-top: 0.4em;
	padding-right: 0;
	padding-left: 0;
	padding-bottom: 0.4rem;
	text-align: center;
	font-weight: normal;
	line-height: 2rem;
	}
	.masonryContainer img {
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 8px;
	max-width: 60%;

	}
	.masonryContainer {
	border: 1px solid #8E8E8E;
	background-color: #F3F3F3;
	}
	.masonryContainer {
    page-break-inside: avoid;
	break-inside: avoid-column; /* keeps containers from spilling into the column to the right */
	-webkit-column-break-inside: avoid;
    -moz-break-inside: avoid-column;
    margin-bottom: 1rem; 
	}
	.masonryContTitle {
	padding-top: 0.6rem;
	padding-right: 0.6rem;
	padding-left: 0.6rem;
	padding-bottom: 0.6rem;
	background-color: #8E8E8E;
	}
	.masonryContent {
	padding-top: 1rem;
	padding-right: 1rem;
	padding-left: 1rem;
	padding-bottom: 1rem;
	}
	.masonryContent p {
	font-size: 1.1rem;
	line-height: 1.4;
	padding: 0;
	margin-bottom: 1rem;
	}
	.masonryAccordion p {
		color: #fff;
	}
	.masonryContTitle h3 {
	color: #fff;
	font-size: 1.1rem;
	margin-right: auto;
	margin-left: auto;
	line-height: 1.2;
	margin-top: 0px;
	margin-bottom: 0px;
	}
	.masonryContent h5 {
	font-size: 1rem;
	line-height: 1.2;
	margin-bottom: 1rem;
	padding: 0;
	color: #585858;
	font-weight: normal;
	/* [disabled]letter-spacing: 1px; */
	text-align: right;
	}

/* Image next to text - no float */
.wrapper_image-text-side-by-side {
	width: 96%;
	max-width: 460px;
	margin: auto;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.layout_image-text-side-by-side {
	display: flex;
	gap: 20px;
	flex-direction: column;
}
.layout_image-text-side-by-side .image-column {

}
.layout_image-text-side-by-side .text-column {
	
}
.reverse-order-on-mobile {
	flex-direction: column-reverse;
}


/* ---------------- MEDIA QUERIES -------------------- */
	
@media (min-width: 660px) {	
/* Image next to text - no float */
	.wrapper_image-text-side-by-side {
	max-width: 1100px;
	}	
	.layout_image-text-side-by-side, .reverse-order-on-mobile {
		flex-direction: row;
	}
	.layout_image-text-side-by-side .image-column {
		max-width: 200px;
		min-width: 20%
	}
	.layout_image-text-side-by-side .text-column {

	}
}

@media (min-width: 700px) {
	
	.grid_2-equal-cols {

	}	
	
	.grid_2-equal-cols_narrow {
		max-width: 600px;
	}	
	
	.grid_2cols-w-rightSidebar {
	margin: auto;
	display: grid;
	grid-template-columns: 1fr minmax(120px, 30%);
	gap: 3em;
	max-width: 1100px;
	}	

	.grid_2cols-w-leftSidebar {
	/* [disabled]margin: auto; */
	display: grid;
	grid-template-columns: 1fr minmax(300px, 60%);
	gap: 2em;
	}
	
	.grid_2cols-w-leftSidebar_narrow {
		margin: auto;
		display: grid;
		grid-template-columns: 1fr minmax(240px, 70%);
		gap: 2em;
	}		
	
}
