* {
	box-sizing: border-box;
}
html, body {
	padding: 0;
	margin: 0;
	background: #000033
}

#header {
	background: #fff;
	background-color: #FFF;
}
#header {
	padding: 15px 0;
}

#main {
	background: #f6feff;
	display: block;
}
.body, .footer-content, .site-header-inner, .lead {
	width: 100%; /* 9/17/2017 new */
	max-width: 1120px; /* 9/17/2017 was 800 */
	min-width: 330px; /* 9/17/2017 was 300 */
	padding-left: 30px;
	padding-right: 30px;
	margin: 0 auto;
}
@media screen and (max-width: 550px) {
	.site-header-inner {
		padding-left: 15px;
		padding-right: 15px;
	}
}
.body {
	padding: 20px 20px;
}
#footer, .body {
	clear: both;
}
#footer {
	padding: 30px 0
}
img {
	max-width: 100%;
	height: auto;
	border: none;
}
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}
.sr-only {
  position: absolute;
  overflow: hidden;
  clip: rect(0 0 0 0);
  height: 1px; width: 1px;
  margin: -1px; padding: 0; border: 0;
}
.js .no-js {
	display: none;
}
.no-js .js {
	display: block;
}
/* =========================================
   TYPOGRAPHY
============================================ */
body, /*.bh-sl-container, */.bh-sl-container .form-input input, .bh-sl-container .form-input select, .bh-sl-container button {
	font-family: 'Karla', 'HelveticaNeue', 'Helvetica Neue', Arial, Helvetica, sans-serif;
}
.bh-sl-container { font-family: Gotham, "Helvetica Neue", Helvetica, Arial, "sans-serif"}
body {
	font-size: 19px;/*17px;*/
	line-height: 1.5; /*24px;*/
	color: #454545;
	min-width: 300px; /* 9/16/2015 */
}
.body, .lead {
	font-family: Georgia, serif;
}
p.smallNotice {
	font-family: 'Karla', sans-serif; 
	line-height: 1.3; 
	padding-top: 15px; 
	margin-bottom: -10px; /*-22px;*/	
}
h1, h2, h3, h4, h5 {
	line-height: 1.3;
}
p, ol, li {
	margin: 0 0 23px;
}
/* =========================================
   HEADER
============================================ */
.site-header {
	background: #fff;
	background-color: #FFF;
}
.site-header, /*.site-header h1, */.site-header div.logo {
	margin: 0;
}
div.logo {
	line-height: 1.3;
}
.logo {
	float: left;
	line-height: 1.3;
}
.header-content {
	float: right;
	padding-top: 5px;
	margin: 0;
	color: #223270;
}
@media screen and (max-width: 550px) {
	.header-content {
		font-size: 14px; 
	}
}
.header-content .content {
	margin-right: 10px;
}
.header-content .content:last-child {
	margin-right: 0;
}
@media screen and (max-width: 745px) {
	.header-content .content {
		display: block;
		margin-right: 0;
	}
}
.home-link, .home-link .text {
	display: inline-block;
	line-height: 33px;
	height: 36px;
	text-decoration: none;
}
.home-link {
	text-decoration: none;
	padding: 3px 4px 0 1px;
	transition: all 0.1s ease-in-out;
	-webkit-border-radius: 4px; 
	-moz-border-radius: 4px;
	border-radius: 4px;
}
/*.home-link:hover, .home-link:focus {
	background: #C2E8F7;
}*/
.home-link .text {
	font-size: 20px;
	color: #223270;
}
.home-link .icon, .home-link .text {
	vertical-align: middle;
}
a:hover.home-link  .text,  a:focus.home-link .text {
	color: #9F2F14; /* rgba(203,61,25,100);*/
}
.header-content .icon {
	font-size: 20px;
	display: inline-block;
	color: #9F2F14; /* rgba(203,61,25,100);  = #cb3d19;  rgba(228,71,31,100) not AA/AAA color contrast approved #E4481F;*/
}
.header-content .icon-home {
	font-size: 33px;
	position: relative;
	top: -2px;
}
@media screen and (max-width: 550px) {
	.header-content .icon {
		font-size: 16px;
	}
	.header-content .icon.icon-home {
		font-size: 28px;
	}
	.home-link {
		overflow: hidden;
		width: 32px;
	}
}
.logo img {
	max-width: 200px;
	vertical-align: middle;
}
@media screen and (max-width: 550px) {
	.logo img {

	}
}

/* =========================================
   MAIN BODY
============================================ */
.lead-container {
	color: #fff;
	padding: 2px 0 12px;/*22px 0 44px;*/
	background: #9F2F14; /*rgba(203,61,25,100);  = #cb3d19;  rgba(228,71,31,100) not AA/AAA color contrast approved #E4481F;*/
	overflow: hidden;
	position: relative;
}
.lead {
	position: relative;
	z-index: 10;
}
.lead p {
	color: #fff;
	font-family: Georgia, serif;
}
h1, .lead h1, .lead h2 {
	color: #fff;
	font-family: Georgia, serif;
	font-size: 42px;/*55px;*/
	font-weight: normal;
	margin-bottom: 12px; /*22px;*/
}
.lead p {
	font-size: 26px; /*28px*/
	line-height: 1.5
}
@media screen and (max-width: 550px) {
	.lead-container {
		padding-bottom: 23px;
	}
	.lead h1, .lead h2 {/*24px = 18pt is minimum for accessibility with white text on orange background */
		font-size: 29px; /* 33px; */
	}
	.lead p {/*19px bold = 14pt bold is minimum for accessibility with white text on orange background */
		font-size: 21px; /*22px*/
	}
}
.houses {
	position: absolute;
	z-index: 5;
	width: 100%;
	top: 0;
	bottom: 0;
	background: url(/hope/assets/img/hero-background.png) no-repeat left bottom;
}
@media screen and (max-width: 900px) {
	.houses {
		background-size: 100%;
	}
}
.clouds {
	position: absolute;
	width: 100%;
	top: 0;
	opacity: 0.2;
	z-index: 3;
}
@media screen and (max-width: 550px) {
	.clouds {
		top: 44px;
	}
}
/* --- Make the Clouds --- */
.cloud {
	width: 200px; height: 60px;
	background: #fff;
	-webkit-border-radius: 200px;
	-moz-border-radius: 200px;
	border-radius: 200px;
	position: relative;
}
.cloud:before, .cloud:after {
	content: '';
	position: absolute;
	background: #fff;
	width: 100px; height: 80px;
	position: absolute; top: -15px; left: 10px;
	-webkit-border-radius: 100px;
	-moz-border-radius: 100px;
	border-radius: 100px;
	transform: rotate(30deg);
	-webkit-transform: rotate(30deg);
	-moz-transform: rotate(30deg);
}
.cloud:after {
	width: 120px; 
	height: 120px;
	top: -55px; 
	left: auto; 
	right: 15px;
}
/* --- Animate the Clouds --- */
.x1, .x2, .x3, .x4, .x5 {
	/* Let's use computer's GPU to smooth things out; */
   -webkit-transform: translate3d(0, 0, 0);

   -moz-transform: translate3d(0, 0, 0);
   -ms-transform: translate3d(0, 0, 0);
   transform: translate3d(0, 0, 0);

   -webkit-backface-visibility: hidden;
   -moz-backface-visibility: hidden;
   -ms-backface-visibility: hidden;
   backface-visibility: hidden;

   -webkit-perspective: 1000;
   -moz-perspective: 1000;
   -ms-perspective: 1000;
   perspective: 1000;
}
.x1 {
	-webkit-animation: animateCloud 55s linear infinite;
	-moz-animation: animateCloud 55s linear infinite;
	animation: animateCloud 55s linear infinite;
}
/*variable speed, opacity, and position of clouds for realistic effect*/
.x2 {
	-webkit-transform: scale(0.6);
	-moz-transform: scale(0.6);
	transform: scale(0.6);
	opacity: 0.6; /*opacity proportional to the size*/
	/*Speed will also be proportional to the size and opacity*/
	/*More the speed. Less the time in 's' = seconds*/
	-webkit-animation: animateCloud 40s linear infinite;
	-moz-animation: animateCloud 40s linear infinite;
	animation: animateCloud 40s linear infinite;
}
.x3 {
	-webkit-transform: scale(0.8);
	-moz-transform: scale(0.8);
	transform: scale(0.8);
	opacity: 0.8; /*opacity proportional to the size*/
	-webkit-animation: animateCloud 50s linear infinite;
	-moz-animation: animateCloud 50s linear infinite;
	animation: animateCloud 50s linear infinite;
}
.x4 {
	-webkit-transform: scale(0.75);
	-moz-transform: scale(0.75);
	transform: scale(0.75);
	opacity: 0.75; /*opacity proportional to the size*/
	-webkit-animation: animateCloud 38s linear infinite;
	-moz-animation: animateCloud 38s linear infinite;
	animation: animateCloud 38s linear infinite;
}
.x5 {
	-webkit-transform: scale(0.8);
	-moz-transform: scale(0.8);
	transform: scale(0.8);
	opacity: 0.8; /*opacity proportional to the size*/

	-webkit-animation: animateCloud 45s linear infinite;
	-moz-animation: animateCloud 45s linear infinite;
	animation: animateCloud 45s linear infinite;
}
@-webkit-keyframes animateCloud {
	0% { margin-left: -500px; }
	100% { margin-left: 100%; }
}
@-moz-keyframes animateCloud {
	0% { margin-left: -500px; }
	100% { margin-left: 100%; }
}
@keyframes animateCloud {
	0% { margin-left: -500px; }
	100% { margin-left: 100%; }
}
/* =========================================
   LOCATION FINDER
============================================ */
.location-finder-header {
	font-size: 24px; /*30px;*/
	text-align: center;
	text-transform: uppercase;
	color: #fff;
	padding: 20px 20px 50px;
	margin: 0 -20px;
	background:  rgba(0,0,51,0.6);
	position: relative;
}
.location-finder-header2 {
	font-size: 24px; /*30px;*/
	text-align: center;
	text-transform: uppercase;
	color: #fff;
	padding: 20px 20px 34px;
	margin: 0 -20px;
	background:  rgba(0,0,51,0.6);
	position: relative;
}
.location-finder-header .icon {
	font-size: 115%;
	margin-right: -4px;
	color: #FFFFFF; /*rgba(203,61,25,100);  = #cb3d19;  rgba(228,71,31,100) not AA/AAA color contrast approved #E4481F;*/
	position: relative;
	top: 4px;
}
@media screen and (max-width: 660px) {
	.location-finder-header {
		font-size: 20px; /*20px;*/
	}
	.location-finder-header:after {
		border-width: 15px;
		margin-left: -15px;
	}
}
.location-finder--container {
	padding: 0 20px;
	background: url(/hope/assets/img/pa-map_large.png) no-repeat #B0D7F6 center;
	background-size: cover;
}
@media screen and (max-width: 1060px) {
	.location-finder--container {
		background-image: url(/hope/assets/img/pa-map_medium.png)
	}   
}
@media screen and (max-width: 600px) {
	.location-finder--container {
		background-size: cover;
	}   
}
.bh-sl-container {
	margin: 0 auto 44px; /*  margin: 0 auto 44px; 9/16/2015 */
	float: none;
}
@media screen and (max-width: 935px) {
	.bh-sl-container {
		width: auto;
	}
}
@media screen and (max-width: 767px) { /*660  9/16/2015*/
	div#map-container {
		height: auto;
	}
	.bh-sl-container .bh-sl-loc-list {
		float: none;
		width: 100%;
		height: auto;
		overflow-x: scroll;
		overflow-y: hidden;
		white-space: nowrap;
	}
	.bh-sl-container .bh-sl-loc-list ul {
		float: none;
		width: auto;
	}
	.bh-sl-container .bh-sl-loc-list ul li {
		display: inline-block;
		width: 230px !important; /* 200px 9/17/2015 */
		margin: 0;
		float: none;
		vertical-align: top;
		white-space: normal;
		background: none !important;
	}
	.bh-sl-container .bh-sl-map {
		width: 100%;
		height: 300px;
	}
}
/* --- Form --- */
.bh-sl-container .bh-sl-form-container {
	padding-top: 0;
	margin-top: -36px;
}
form#bh-sl-user-location {
	display: block;
	position: relative;
	max-width: 750px;
	margin-left: auto;
	margin-right: auto;
}
.bh-sl-container .form-input {
	float: none;
	position: relative;
}
.bh-sl-container .form-input label {
	display: block;
	font-size: 20px;
	text-align: center;
	margin-top: -10px;
	margin-bottom: 33px;
	position: absolute;
	left: 15px;
	top: 50%;
	transition: all 0.1s ease-in-out;
	color: #333;
	font-weight: normal;
}
.bh-sl-container .form-input label.has-value {
	font-size: 14px;
	line-height: 22px;
	height: 20px;
	padding-top: 2px;
	text-transform: uppercase;
	color: #fff;
	top: 100%;
	padding: 0 10px;
	margin-top: 0;
	left: 0;
	background: #075D92;
	-webkit-border-radius: 0 0 3px 3px; 
	-moz-border-radius: 0 0 3px 3px;
	border-radius: 0 0 3px 3px;
	z-index: 5;
}
@media screen and (max-width: 660px) {
	.bh-sl-container .form-input label {
		font-size: 18px; 
	}
}
@media screen and (max-width: 450px) {
	.bh-sl-container .form-input label {
		font-size: 16px; /* 15px; */
		left: 10px;
	}
	.bh-sl-container .form-input label.has-value {
		font-size: 14px; /*13px;*/
		font-weight: 400;
	}
}
.bh-sl-container .form-input input {
	font-size: 30px;
	color: #666;
	display: block;
	width: 100%;
	padding: 10px 100px 10px 15px;
	margin-left: 0;
	border: 4px solid transparent;
	box-shadow: 0 0 10px 0 rgba(55,55,55,0.1);
	outline: none;
	transition: all 0.1s ease-in-out;
}
.bh-sl-container .form-input input.has-value {
	border-bottom-left-radius: 0;
	
}
@media screen and (max-width: 600px) {
	.bh-sl-container .form-input input {
		font-size: 20px;  /*18px;*/
	}
}
.bh-sl-container .form-input input:focus {
	border-color: #06649F;
	border-bottom-left-radius: 0;
}
.bh-sl-container button {
	font-size: 20px;
	padding: 0 20px;
	/*line-height: 40px;*/
	height: 40px;
	text-transform: uppercase;
	background: #9F2F14;/* rgba(203,61,25,100); = #cb3d19;  rgba(228,71,31,100) not AA/AAA color contrast approved #E4481F;*/
	position: absolute;
	margin-top: -20px;
	z-index: 2;
	right: 11px;
	top: 50%;
	border: 2px solid transparent;
	outline: none;
	transition: all 0.1s ease-in-out;
	-webkit-transition-duration: 0.1s; /* Safari */
    transition-duration: 0.1s;
}
.bh-sl-container button:hover,
.bh-sl-container button:focus {
	border-color: #000000; /*#bf3c18;*/
}
.bh-sl-container button:active {
	/*bottom: 8px;*/
	border-color: #EF947B;
}
/*EF947B sd 9/16/2015 */
@media screen and (max-width: 450px) {
	.bh-sl-container button {
		font-size: 16px;
		padding: 0 15px;
	}
}
@media screen and (max-width: 600px) {
	.bh-sl-container button {
		right: 8px;
		/*line-height: 34px;
		height: 34px;
		margin-top: -17px;*/
	}
	.bh-sl-container button:active {
		bottom: 8px;
	}
}
/* --- Map & Listing --- */
.bh-sl-container .bh-sl-map-container {
	background: #fff;
	margin-bottom: 44px;
	height: 550px;
	border: 10px solid #fff;
	box-shadow: 0 0 10px 0 rgba(55,55,55,0.1);
	position: relative;
}
.bh-sl-container .bh-sl-map-container:after {
	bottom: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(13, 124, 193, 0);
	border-bottom-color: #fff;
	border-width: 25px;
	margin-left: -25px;
}
@media screen and (max-width: 935px) {
	.bh-sl-container .bh-sl-map-container {
		width: 100%;
	}
}
.bh-sl-container .bh-sl-loc-list ul li {
	width: 100%;
	margin-left: 0;
	margin-right: 5px;
}
.bh-sl-container .bh-sl-loc-list .list-label {
	text-align: center;
	line-height: 25px;
	width: 25px;
	height: 25px;
	padding: 0;
	background: #9F2F14; /* rgba(203,61,25,100); = #cb3d19;  rgba(228,71,31,100) not AA/AAA color contrast approved #E4481F;*/
	-webkit-border-radius: 50%; 
	-moz-border-radius: 50%;
	border-radius: 50%;
}
.bh-sl-container .bh-sl-map-container a {
	-ms-word-break: break-all;
	word-break: break-all;
	word-break: break-word;
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	hyphens: auto;
}
/* =========================================
	ADD ON CSS
============================================ */	
.bh-sl-container .bh-sl-loc-list .list-details .agency-name {
	
  color: #006;
}
.bh-sl-container .bh-sl-loc-list .list-details .agency-name, .bh-sl-container .bh-sl-loc-list .list-details .appt-only {
	font-weight: bold;	
}
.bh-sl-container .bh-sl-loc-list .list-details .appt-only/*, .bh-sl-container .bh-sl-loc-list .list-details .loc-dist*/ {
  font-style: italic;
  color: #333;
}
.bh-sl-container .bh-sl-loc-list .list-details .loc-dist {
  color: #666; /* #069; #8e8e8e;*/
}

.bh-sl-container .bh-sl-loc-list .list-details .loc-addr2 {
  font-style: italic;
  /*font-weight: bold;
  color: #8e8e8e;*/
  white-space:nowrap;
}

/* =========================================
   FOOTER
============================================ */
#footer {
	color: #fff
}
#footer .text-block {
	float: left;
	margin: 0 30px 0 0;
}
#footer .social__footer {
	float: right;
}
@media screen and (max-width: 700px) {
	#footer .social__footer {
		float: none;
		padding-top: 22px;
		clear: both;
	}
}
/* =========================================
   SOCIAL ICONS
============================================ */
.social__footer .social--link {
	font-size: 44px;
	text-decoration: none;
	color: rgba(255,255,255,0.9);
	position: relative;
	top: 0;
	transition: all 0.15s ease-in-out;
}
.social__footer .social--link:hover {
	top: -5px;
}
.social__footer .social--link:focus {
	opacity: 0.7;
}


/* =========================================
	ADD ON CSS
============================================ */	
.bh-sl-container .bh-sl-loc-list .list-details .agency-name {
  color: #006;
}
.bh-sl-container .bh-sl-loc-list .list-details .agency-name, .bh-sl-container .bh-sl-loc-list .list-details .appt-only {
	font-weight: bold;	
}
.bh-sl-container .bh-sl-loc-list .list-details .appt-only/*, .bh-sl-container .bh-sl-loc-list .list-details .loc-dist*/ {
  font-style: italic;
  color: #333;
}
.bh-sl-container .bh-sl-loc-list .list-details .loc-dist {
  color: #666; /* #069; #8e8e8e;*/
}

.bh-sl-container .bh-sl-loc-list .list-details .loc-addr2 {
  font-style: italic;
  /*font-weight: bold;
  color: #8e8e8e;*/
  white-space:nowrap;
}
.smallFont {
	font-size: 16px;	
}
