/* ---------------------------------------- 

		MEDIUM SCREEN CSS STYLES 

---------------------------------------- */


@media only screen and (max-width: 1023px) {

	/* HOMEPAGE */
	
		/* Tabs Content */
		
		.tabs-content {
			height: 525px;
		}
		
			.tab > div:first-of-type,
			.tab > div:nth-of-type(2) {
				width: 100%;
			}
			
			.tab > div:first-of-type {
				height: 215px;
			}
		
			.tab > div:nth-of-type(2) div {
				top: 0;
				width: 82.5%;
				margin: 0 auto;
				padding-top: 25px;
			}
			
	
		/* Body */
		
		.hp-top {
			height: 565px;
		}
		
		.hp-center-container h1 {
			width: 70%;
			font-size: 29px;
		}
		
	
		/* Service Bins */
		
		.hp-services h2 {
			font-size: 28px;
			line-height: 28px;
		}
		
		.hp-services p:first-of-type {
			display: none;
		}
		
		.hp-services div + p {
			display: block !important;
		}
		
		.hp-services ul {
			display: none;
		}


	/* PROJECTS */
	
	.featured-projects-links a {
		padding: 25px 0 35px;
		font-size: 33px;
		line-height: 33px;
	}
	

	/* FOOTER */
	
	.footer-container {
		width: 100%;
	}
		
		.footer-container > div:first-child {
			display: none;
		}
		
		.footer-container > div:nth-child(2),
		.footer-container > div:last-child {
  			-webkit-flex: 2 50%;
			-ms-flex: 2 50%;
			flex: 2 50%;
		}
				
		.footer-container div.footer-copyright {
			float: none;
			margin: 0 auto;
		}
		
			.footer-container div.footer-copyright p:first-of-type span {
				display: block;
			}
			
			.footer-container div.footer-copyright p:nth-of-type(2) {
				padding-top: 0;
			}
		
		.footer-container div.footer-join > img {
			margin-left: -300px;
			max-height: 120px !important;
			max-width: 600px !important;
			min-height: 120px;
			min-width: 600px;
		}
}


@media only screen and (max-width: 950px) {
	
	/* UNIVERSAL STYLES */
	
	h1,
	h2,
	h3,
	.searchresults h2.moduletitle, 
	.sitemappage h2.moduletitle {
		font-size: 40px;
		line-height: 40px;
	}
	
	/* SUBPAGE */
	
		/* Accordion */
		
		.expand span.expand-text span {
			font-size: 22px;
			line-height: 22px;
		}
		
	
	/* PROJECTS */
	
	.featured-projects-links a {
		font-size: 30px;
		line-height: 30px;
	}
	
		.featured-projects-links a i {
			top: 7px;
			margin-left: 10px;
			font-size: 35px;
		}	
		
		.featured-projects-links div:first-of-type a i {
			margin-right: 10px;
		}

}


@media only screen and (max-width: 850px) {
	
	/* UNIVERSAL STYLES */
	
	body {
		font-size: 17px;
		line-height: 22px;
	}
	
	h1,
	h2,
	h3,
	.searchresults h2.moduletitle, 
	.sitemappage h2.moduletitle {
		font-size: 35px;
		line-height: 35px;
	}
	
	
	/* HOMEPAGE */
	
		/* Body */
		
		.hp-center-container h1 {
			width: 75%;
			font-size: 27px;
		}
		
	
		/* Service Bins */
		
		.hp-services h2 {
			font-size: 24px;
			line-height: 24px;
		}
		
		.hp-services p + p > a, 
		.hp-services div + p > a {
			font-size: 18px;
			line-height: 18px;
		}
			
			.hp-services p + p > a > i, 
			.hp-services div + p > a > i {
				font-size: 25px;
			}
			
	
	/* CALLOUT BINS */
	
	.cta-bin h3 {
		font-size: 40px;
		line-height: 40px;
	}
	
	.cta-bin p {
		font-size: 17px;
		line-height: 24px;
	}
	
	.cta-bin a {
		font-size: 32px;
		line-height: 32px;
	}
	
		.cta-bin a i {
			font-size: 36px;
		}
			
	
	/* SUBPAGE */
	
	.sp-center-container {
	  padding: 35px 0 50px;
	}
	
		.sp-center-content-container {
			margin-top: 15px;
		}
	
	ol li,
	ul li {
		font-size: 17px;
		line-height: 22px;
	}

		/* Accordion */
		
		.expand span.icon-arrow-accordion {
			top: 2px;
			font-size: 32px;
			line-height: 32px;
		}
		
		.expand span.expand-text span {
			font-size: 20px;
			line-height: 20px;
		}
		
	
	/* PROJECTS */
	
	img.align-right.featured-project-full,
	img.align-right.featured-project-full {
		float: none;
		display: block;
		margin: 25px auto;
	}
	
	.featured-projects-links div {
		width: 100%;
	}
	
	.featured-projects-links div:last-of-type {
		margin-top: 0;
	}
	
		.featured-projects-links a {
			padding: 15px 0 25px;
		}

	.filter-container {
		text-align: center;
	}

		.filter-container .filter-title {
			display: block;
			margin-bottom: 0;
			margin-right: 0;
		}

		div.cs-select {
			margin: 10px 0;
		}
	
			
	/* FOOTER */
		
	.footer-container div.footer-join > img {
		margin-left: -223px;
		max-height: 89px !important;
		min-height: 89px;
		max-width: 446px !important;
		min-width: 446px;
	}	

}


@media only screen and (max-width: 750px) {
	
	/* UNIVERSAL STYLES */
	
	blockquote,
	blockquote.block-single {
		background-size: 40px 39px;
		padding: 40px 55px;	
	}
	
	blockquote {
		padding: 40px 55px 12px;
	}
	
	
	/* HEADER */
	
	.header-container img {
		width: 300px;
	}
	
	.search-bar {
		margin: 17px 20px 0 0;
	}
	
		.search-bar input[type="text"], 
		.searchcontrols input[type="text"] {
			width: 150px;
			height: 35px;
			padding: 0 0 0 15px;
			font-size: 15px;
		}

		.searchcontrols #ctl00_mainContent_txtSearchInput {
			height: 33px;
		}
		
		.search-bar input[type="submit"], 
		.searchcontrols input[type="submit"] {
			width: 35px;
			height: 35px;
		}

		.searchresultsummary {
			text-align: left;
			font-size: 13.5px;
		}
		
	
	/* HOMEPAGE */
	
		/* Tabs */
		
		.tabs-nav a {
			font-size: 15px;
			line-height: 15px;
		}
		
		
		/* Tabs Content */
		
		.tabs-content {
			height: 500px;
		}
		
			.tab > div:first-of-type {
				height: 200px;
			}
			
				.tab > div p {
					font-size: 15px;
					line-height: 20px;
				}
				
				
		/* Body */
		
		.hp-top {
			height: 550px;
		}
		
	
	/* SUBPAGE */
	
	.two-column-lists > ol:last-of-type, 
	.two-column-lists > ul:last-of-type {
		border-left: 0;
	}
	
	
	/* PROJECTS */
	
	.project div:last-of-type {
		height: 100px;
	}
	
		
	/* CONTACT FORM */
	
	.tr-checkbox td:first-child span {
		width: 65%;
	}	
	
}


@media only screen and (max-width: 700px) {
	
	/* UNIVERSAL STYLES */
	
	h1,
	h2,
	h3,
	.searchresults h2.moduletitle, 
	.sitemappage h2.moduletitle {
		padding: 5px 0;
		font-size: 30px;
		line-height: 30px;
	}
	
	.caption-left,
	.caption-right {
		float: none;
		margin: 25px auto;
	}
	
	img.align-left, 
	img.align-right {
		display: none;
	}

	
	
	/* HOMEPAGE */
	
		/* Body */
		
		.hp-center-container h1 {
			width: 85%;
			margin-bottom: -10px;
			font-size: 26px;
		}
		
		
		/* Service Bins */
		
		.hp-services {
			background: transparent;
			margin: 30px 0 0;
			padding: 0;
		}
		
			.hp-services h2 {
				font-size: 34px;
				padding-bottom: 20px;
			}
			
			.hp-services p + p > a, 
			.hp-services div + p > a {
				position: absolute;
				bottom: 25px;
				right: 20px;
				font-size: 20px;
				line-height: 20px;
				color: #fff;
			}
			
				.hp-services p + p > a > i,
				.hp-services div + p > a > i {
					font-size: 27px;
				}
			
			.hp-services .service-bin {
				-webkit-flex: 1 1 100%;
				-ms-flex: 1 1 100%;
				flex: 1 1 100%;
				position: relative;
				overflow: hidden !important;
				padding-top: 50px;
			}
			
			.hp-services .service-bin:first-of-type {
				padding-top: 10px;
			}
			
				.hp-services .service-bin > a:first-of-type {
					display: none;
				}
				
				.hp-services .service-bin > a:nth-of-type(2) {
					display: block;
				}
				
					.hp-services .service-bin > a:nth-of-type(2) img {
						display: block;
						position: relative;
						left: 50%;
						margin-left: -350px;
						margin-right: auto;
						max-height: 209px !important;
						min-height: 209px;
						max-width: 700px !important;
						min-width: 700px;
					}
					
					
	/* SUBPAGE */
	
		/* Accordion */
	
		.expand span.icon-arrow-accordion {
			top: 3px;
			font-size: 25px;
			line-height: 25px;
		}	
		
		.expand span.expand-text span {
			font-size: 15px;
			line-height: 15px;
		}
		
		.expand-content {
			padding-left: 0;
		}
		
			.expand-content img.align-right {
    			float: none;
    			margin: 25px auto;
			}
		
		
	/* BLOG */
	
	.blogitem .morelink {
		font-size: 25px;
		line-height: 25px;
	}
				
}