@import url("https://use.typekit.net/ebr1eeq.css");
* {
	margin:0px;
	padding:0px;
	box-sizing:border-box;
}
body {
	font-family:  pt-sans, sans-serif;
	font-style: normal;
	font-weight: 300;
	font-size: 18px;
	color:#222222;
}
img {
	max-width:100%;
	height:auto;
}
.container {
	max-width: 1200px;
	margin:0px auto;
	padding:0px 10px;
}
.row:after,
.clear:after {
	content:'';
	display:block;
	clear:both; 
}
.left {
	float: left;
	width: 45%;
	margin-right: 2%;
}
.right {
	float: left;
	width: 53%;
}
h1 {
	color: #222222;
	font-size: 32px;
	padding: 0px 0px 10px;
	margin-bottom: 15px;
	text-align: center;
	border-bottom: 1px solid #153b46;
}
h2 {
	color: #163a46;
	font-size: 22px;
	margin-bottom: 15px;
}
h3 {
	color: #222;
	font-size: 22px;
	margin-bottom: 15px;
	border-bottom: 1px solid #222;
	padding-bottom: 10px;
}
.right h3 {
	border-bottom: 0px;
}
h4 {
	color: #222;
	font-size: 22px;
	padding-bottom: 5px;
}
p {
	margin-bottom: 15px;
}
strong {font-weight: bold;}
ul.none {
	list-style: none; 
}
a {
	color: #748b65;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}
a.Link {font-weight: bold;}
img.r-img {
	width: 300px;
	float: right;
	padding: 0px 0px 20px 20px;
}
header {
	position:fixed;
	top:0px;
	z-index:999;
	width:100%;
	background-color:#fff;
}

/* NAVIGATION */
header nav {
	background-color:#dae8d1;
	text-align:center;
}
header #nav > ul {
	list-style:none;
	width:100%;
	display:block;
	margin:0px auto;
    font-size: 0px; /*elimiates spacing between li*/
}
header #nav ul li {
	margin-bottom:0px;
}
header #nav > ul > li {
	display:inline-block;
}
header #nav ul li a {
	text-decoration:none;
	color:#163b44;
	text-transform:uppercase;
	display:block;
	padding:26px 14px;
	font-size:17px;
	font-weight: 400;
}
header #nav ul li:hover a {
	background-color:#b4beae;
	color:#163b44;
}
header #nav > ul > li ul  {
	display:none;
	position:absolute;
    text-align:left;
	margin-left:0px;
	background-color:#dbdbdb;
	z-index: 9;
}
header #nav > ul > li ul li {
	display:block;
}
header #nav > ul > li ul li a {
	padding:5px 20px;
	white-space: nowrap;
}
header #nav > ul > li > ul > li a:hover {
	background-color:#fff;
}
/* ^ NAVIGATION */
/* MOBILE */
#mobile-nav {
	display:none;
	text-transform:uppercase;
	color:#163a46;
	text-align:center;
	padding:7px 10px;
	height:37px;
	width:100px;
	font-family:Arial;
	margin:0px auto;
}
#mobile-nav > div {
	width:25px;
	float:right;
}
#mobile-nav div.bar {
	height:3px;
	background-color:#163a46;
	margin:3px 0px;
}
#mobile-nav span{
	float:right;
	display:block;
	padding:0px 5px;
	font-size:14px;
	line-height:22px;
}

#logo {
	width: 25%;
	float: left;
	text-align: center;
}
#logo img {
	max-width: 250px;
}
#header nav {
	width: 75%;
	float: left;
}
/* BANNERS */
#banners {
	max-height:640px;
	position:relative;
	z-index:1;
	overflow:hidden;
}
#banner-img {
	max-height:640px;
	overflow:hidden;
}
#banner-img .slide > img {
	display:block;
	width:100%;
	height:auto;
}
#banner-img .slide {
	max-height:640px;
	position:absolute;
	top:0px;
	max-width:100%;
	width:100%;
	opacity:0;
	z-index:0;
}
#banner-img .slide.active {
	position:relative;
	opacity:1;
	z-index:1;
}
#banner-img .slide.active .content{
	opacity:1;
}
#banner-img .slide.getActive {
	z-index:2;
}
#banner-img .slide .content {
	position:absolute;
	top:50%;
	left:10%;
	z-index:2;
	opacity:0;
	color:#fff;
    padding:40px 10px;
	font-size:44px;
	font-weight: bold;
	width:55%;
}
#banners #mask {
	background-color: rgba(255, 255, 255, 1.0);   /* use rgba for transparent effect */
	color: white;
	transform: translate(0, 0);            /* move the circle left 50% of it's own width and up 50% of it's own height */
	border-radius: 50%;
	padding-top: 20%;                           /* this gives us a responsive square */
	position: absolute;
	top:85%;                                     /* this vertically centers the circle */
	left:0;
	width:100%;
	min-width:700px;                              /* this is the miniimum dimensions to allow circle to fill smaller screens */
	height:200px;
	z-index:3;
}
/* ^ BANNERS */


#main {
	position: relative;
	z-index: 99;
	text-align: left;
	padding-bottom: 35px;
}
#main .row {
	margin: -20px 5% 0;
}
#main ul {
	margin-bottom: 20px;
	margin-left: 16px;
}
#residential-services h1 {
	border-bottom: 0px;
}
#residential-services #main,
#home #main {
	text-align: center;
}
.focus {
	margin: 10px 20% 50px;
	font-weight: bold;
	width: 60%;
}
.focus .focus-it {
	border-top: 1px solid #153b46;
	border-bottom: 1px solid #153b46;
	padding: 20px 0;
}
.focus .left {
	width: 35%;
	font-size: 26px;
	text-align: center;
	float: left;
	margin-right: 5%;
	padding-top: 15px;
}
.focus .right {
	width: 60%;
	float: left;
}
.focus .bar {
	display: block;
	width: 70%;
	border-bottom: 8px solid #153b46;
	height: 3px;
	margin: 0 15%;
}
#main .focus ul {
	list-style: none;
	text-align: left;
	margin: 0;
}
#blocks {margin: 50px 0;}
#blocks .block {
	width: 29%;
	margin: 0 2%;
	float: left;
	padding: 30px;
	background: #163a46;
	color: #fff;
	height: 180px;
	text-align: center;
}
.block a {
	color: #fff;
}

#blocks .block:first-of-type {
	background: #dae8d1;
}
#blocks .block:last-of-type {
	background: #bfe9f5;
}
#blocks .block:first-of-type,
#blocks .block:last-of-type,
#blocks .block:last-of-type a,
#blocks .block:first-of-type a {
	color: #222;
}
#blocks .block .title {
	font-weight: bold;
	margin-bottom: 10px;
}
.left {
	width: 70%;
	margin-right: 5%;
	float: left;
}
.right {
	width: 25%;
	float: left;
}

#contact {
	margin: 0 0 30px;
}

#contact .left {
	width: 17%;
	float: left;
	margin-right: 3%;
}
#contact .right {
	width: 80%;
	float: left;
	text-align: left;
	color: #163a46;
	font-size: 20px;
	padding: 25px 0;
}
#announcement {
	margin-top: 20px;
	background: #dae8d1;
	padding: 40px 0;
}
#announcement .left {
	width: 25%;
	float: left;
	margin-right: 5%;
}
#announcement .right {
	width: 70%;
	float: left;
}
footer {
	background: #163a46;
	color: #fff;
	text-align: center;
	padding: 40px 0;
}

.grid {
	padding: 30px 0px;
}
.grid-item { 
	width:25%;
	padding:5px;
}
.grid-item img { 
	width: 100%;
	display:block;
}

.formField {
	padding: 5px 0px;
}
.formField label {
	display: block;
}
.GoodAlert {
	padding: 10px;
	border: 1px solid green;
	height: auto;
	background: #E2EFE0;
	border-radius: 5px;
	-moz-border-radius: 5px;
	margin-bottom: 10px;
}

input[type="text"] {
	width: 300px;
	padding: 10px;
	border-radius: 3px;
	border: 1px solid #dfdfdf;
}
textarea {
	padding: 10px;
	border-radius: 3px;
	border: 1px solid #dfdfdf;
	width: 300px;
}
input[type="submit"] {
	padding: 10px 20px;
	background: #163A46;
	color: #fff;
	font-weight: bold;
}
.team {
	margin-bottom: 40px;
}
@media (max-width:1185px) {
	header #nav ul li a {
		padding: 26px 10px;
	}
}
@media (max-width:1000px) {
	#logo {
		width: 100%;
		margin: 0;
		padding: 10px 0;
	}
	#header nav {
		width: 100%;
		margin: 0;
	}
	#header.container {
		padding: 0;
	}
	img.r-img {
		width: 100%;
		padding: 20px 0px;
	}
	#mobile-nav {
		display:block;
	}
	header #nav > ul {
		display:none;
		position:absolute;
		background-color:#798e91;
		color: #fff;
		padding-left:0px;
		z-index:999;
	}
	header #nav ul  li {
		display:block;
		width:100%;
		border-top:1px solid #ccc;
		text-align:left;
	}
	header #nav ul li a {
		padding: 10px 10px;
	}
	header #nav > ul > li ul {
		position:relative;
	}
	header #nav ul li:hover a {
		background-color: #999;
	}
	#blocks .block {
		height: 250px;
	}
}
@media (max-width:990px) {

	#mask {display: none;}
	#main .row {margin: 10px 0;}
	#blocks .block {
		height: 200px;
	}
	.container {
		padding: 0px 25px;
	}
	#contact .left,
	#contact .right,
	#announcement .left,
	#announcement .right,
	.left,
	.right {
		width: 100%;
		margin: 10px 0;
	}
	#announcement .left img {
		width: 100%;
	}
	#contact .right {
		padding: 5px 0;
	}
	#blocks .block {
		width: 100%;
		margin: 10px 0;
	}

}
