
/*********************
LOCATIONS PAGE
*********************/

#locations-banner.page-banner {
}
.projects-map {
	margin-top: -35px;
	max-width: 950px;
}

#project-map {
	overflow: visible;
}

#project-map .locations-grid {
	margin-top: -20px;
}

#project-map .acf-map-all {
	width: calc(100% + 30px);
	height: 550px;
	border: #fff solid 8px;
	margin: 0 -15px 0;
}

#content .project-info {
	width: 350px;
	cursor: text;
	padding: 0px 20px 0 10px;
}

#content .project-info h3 {
	font-size: 20px;
	margin: 12px 0 5px;
	line-height: 1.1;
}

#content .project-info h4 {
	font-size: 15px;
	line-height: 1.2;
}

#content .project-info h5 {
	margin: 0 0 0 1px;
	font-size: 12px;
	text-transform: uppercase;
}

#content .gm-style-iw {
	
}

#content .gm-style-iw > div {
	overflow: hidden !important;
	max-height: 230px !important;
	overflow-y: auto !important;
}

#content .gm-style-iw > div > div {
	overflow: hidden !important;
}

#content .project-cluster {
	max-height: 100%;
	overflow-y: hidden;
	overflow-x: hidden;
}

.project-info {
	border-bottom: 1px solid #ccc;
}

.projects-list h4.name,
.project-cluster .project-info h4 {
	cursor: pointer;
	padding-right: 20px;
	position: relative;
}

.projects-list h4.name::after,
.project-cluster .project-info h4::after {
	content: "+";
	position: absolute;
	top: 1px;
	right: 2px;
}

.projects-list .project-info.open h4.name::after,
.project-cluster .project-info.open h4::after {
	content: "-";
}

#content .project-expanded-info {
	display: none;
	overflow: hidden;
	transition: all 1s;
}

#content .project-info.open .project-expanded-info {
	
}




@media (min-width: 40em) {
	/*
	#project-map .acf-map-all .gm-style-iw > div {
		max-width: 200px;
	}

	#project-map .acf-map-all .gm-style-iw > div > div {
		max-width: 200px;
	}
	
	#project-map .acf-map-all .gm-style-iw > div > div .info-image img {
		max-width: 200px;
	}
	*/
}

@media (min-width: 64em) {
	#locations-banner.page-banner {
		padding-top: 135px;
	}

	#project-map .acf-map-all {
		width: calc(100% + 200px);
		width: calc(100% + 0px);
		height: 600px;
		margin: 0px -50px 0;
	}
}



@media (min-width: 64em) {
	
	#project-map .acf-map-hawaii {
		width: 300px;
		height: 300px;
		margin-top: -210px;
		margin-left: -90px;
		transition: all 0.1s;
	}
	
	#project-map .projects-map.active .acf-map-hawaii {
		width: 600px;
		height: 600px;
		margin-top: -570px;
	}
}


/* MAP CONTROLS */

.map-controls {
	position: absolute;
	z-index: 100;
	background: #fff;
	padding: 20px;
	top: -60px;
	box-shadow: 0 0 10px 0px rgba(0,0,0,.2);
	max-width: 255px;
	right: -125px;
	max-height: 800px;
	overflow: auto;
}

.map-control-group {
	
}

.map-control-group:not(:last-child) {
	border-bottom: 1px solid #eee;
	padding: 0 0 10px;
	margin: 0 0 10px;
}

.map-controls h4 {
	display: inline-block;
	font-size: 14px;
	margin: 0 5px 0 0;
	line-height: 1.1;
}

.map-control {
	cursor: pointer;
	display: inline-block;
	border: 1px solid #ccc;
	color: #666;
	padding: 4px 8px;
	line-height: 1.1;
	font-size: 12px;
	margin: 3px 5px 2px 0;
}

.map-control:hover {
	background-color: #939A9F;
	color: #fff;
}

.map-control.active {
	background-color: #91CA6A;
	color: #fff;
}

.map-control-filters {
}

.map-control-filter {
	
}




@media (min-width: 1450px) {
	#project-map .acf-map-all {
		margin-left: -95px;
	}
	#project-map .acf-map-hawaii {
		margin-left: -135px;
	}
	.map-controls {
		max-width: 345px;
		right: -170px;
	}
}




@media (max-width: 63.999em) {
	.map-controls {
		position: relative;
		top: -40px;
		right: auto;
		margin: 0;
		max-width: none;
		padding: 0;
		box-shadow: none;
	}
}

@media (max-width: 39.999em) {
	
}





/* Project List */

#content .projects-list {
	margin-top: -40px;
}


.projects-list .project-info:first-child {
	/*border-top: 1px solid #ccc;*/
}

#content .projects-list h2.city-name {
	cursor: pointer;
	margin: 2px 0 0;
	font-size: 22px;
	border-bottom: 1px solid #ccc;
	position: relative;
	padding: 5px 0;
}

.projects-list h2.city-name::after {
	width: 0;
	height: 0;
	border-left: 0.35em solid transparent;
	border-right: 0.35em solid transparent;
	border-bottom: 0.4em solid #666;
	display: block;
	content: " ";
	position: absolute;
	right: 5px;
	top: 50%;
	transform: rotate(180deg);
	margin-top: -0.2em;
	transition: transform 0.4s;
}

.projects-list .city-group.open h2.city-name::after {
	transform: rotate(0deg);
}

.projects-list .city-projects {
	display: none;
	overflow: hidden;
	transition: all 1s;
}

.projects-list .city-group.open .city-projects {
	
}

.projects-list .client-group {
	
}

#content .projects-list .client-name {
	margin: 12px 0 0;
	font-weight: 400;
	text-transform: uppercase;
	font-size: 12px;
	font-family: 'source_sans_prosemibold';
	cursor: pointer;
	letter-spacing: 0.025em;
}

.projects-list .client-projects {
	
}

#content .projects-list .project-info {
	width: 100%;
	padding-right: 6px;
}

#content .projects-list h4.name {
	font-weight: 400;
	font-size: 16px;
	margin: 4px 0 8px;
	font-family: "source_sans_proregular";
}










