/*
	Theme Name: Beacon Transitions
	Theme URI: Beacon Transitions
	Description: Built off of HTML5 Blank theme. 
	Version: 1.4.3
	Author: 
	Author URI: 
	Tags: 

	


html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	font-family: 'Raleway', sans-serif;
}
/* HTML5 display-role reset for older browsers */


html,body
{
	
    width: 100%;
    height: 100%;
    margin: 0px;
    padding: 0px;
    overflow-x: hidden; 
}
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;	
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

h1 {
	font-size: 2.0em;
	color:#3a3a3c;
    font-weight:100;
margin:5px
	
	}

h1 a:visited {
	color: #818181;

}

h1 a:hover {

	color:#3D59AB;
	text-decoration:none;
	}
	
	
h2 {
	font-size: 1.6em;
        font-weight:100;
	margin-bottom:0px;
margin-top:0px;
line-height: 1.0;
	
	
	}

h2.top {
    color: #3a3a3c;
	font-weight:100;

}	
h2.middle {
    color: #c8baad;
	font-weight:100;

}	
h2.right {
	color: #b0af9b;
	font-weight:100;

}

h2.bottom {
	color: #FFF;
	font-weight:100;

}


h3 {

	font-size: 1.2em;
	font-family: 'Open Sans', sans-serif;
 	font-weight:100;
	margin:5px
	
    
}

p {
	font-family: open sans, sans-serif;
	color: #3a3a3c;
	font-size: 1.0 em;
	font-weight:100;
	line-height:150%;
	margin: 0px;
}
ul {
	font-family: open sans, sans-serif;
	font-size:1 em;
	list-style-type: none;
	color: #575757;
}
ul li {
	margin-bottom:1 em;
	}

ul.b {
    list-style-type: square;
}

a {
	font-family: open sans, sans-serif;
	text-decoration:none;
	color: #666;
	font-size:1 em;

	}
a:visited {
	font-family: open sans, sans-serif;
	color:#3D59AB;
	}
a:hover {
	text-decoration:none;
	color: #999;

}


table {
	border-collapse: collapse;
	border-spacing: 0;
}

.topcontact
{
	background-color: #fff;
	width: 100%;
	height: 30px;
	border-bottom: 2px solid  #3a3a3c; 
}

.bottomcontact
{
	background-color: #FFF;
	width: 100%;
	height: 40px;
	padding:10px;
	color: #3a3a3c;
	font-weight:100;
	font-size: 1.0em;
}

#maincontent
{
	background-color:#f6f6f6;
	width: auto;
	height: auto;
	display: flex;
}

#introcontent
{
	background-color:#FFF;
	width: auto;
	height: auto;
	display: flex;
}

#corecontent
{
	background-color:#FFF;
	width: auto;
	height: auto;
        display: flex;
}

#boxcontent
{
	background-color: #3a3a3c;
	width: auto;
	height: auto;
	display: flex;
}



.topheader
{
	background-color: #f6f6f6;
	width: 100%;
	height: 100px;
}

.logo
{
	float:left;
	background-color: #FFF;
	width:165px;
	height:100px;
	margin-right:5px;
	border-right: 2px solid  #3a3a3c; 
	
}
.description
{
	width: auto; 
	float: none;
	height:80px;
	color: #333;
	padding: 5px;
	color: #3a3a3c;
	font-weight:100;
	font-size: 1.6em;

	
}





.header
{
	width: 100%;
	height: 40px;
	background-color: #3a3a3c;

}



.banner
{
	cursor: default;
	margin:0;
}

.bannersub
{
	
	cursor: default;
	margin:0;
}

.responsive-menu-button
{
	float: right;
	padding: 3px 0px;
	margin-right:10px;
}
#mobile-header {
display: none;
}


.container
{
	width: 1080px;
	margin: 0 auto;
}


#pagewrap {
	
	padding: 5px;
	width: 1000px;
	margin: 10px auto;
}


#pagewrapboxes {
	
	width: 1000px;
	margin: 1px auto;
}



#sidebar {
	background:#9eb2aa;
	width: 280px;
	height:auto;
	float: left;
	padding: 10px;
}

#sidebar  p {
	color: #FFF;
	font-size: 0.875em;
	line-height: 120%;
	
}

#sidebar  h2 {
	color: #FFF;

}

#sidebarsub {
	width: 680px;
	height:auto;
	float: left;
	font-family: open sans, sans-serif;
	color: #3a3a3c;
	font-size: 1.0 em;
	font-weight:100;
	line-height:150%;
	margin: 0px;

}



#sidebarsub  h2 {
	color: #3a3a3c;

}

#content {
	width: 680px;
	float: right;
	padding: 5px;
}

#contentsub {
	background:#fff;
	width: 280px;
	float: right;
	padding: 5px;
	padding: 10px;
	border: 2px solid  #3a3a3c; 
}


#corearea {
	width: 280px;
	height:auto;
	float: left;
	padding: 10px;
}

#coreareaphoto {
	
	background:#9eb2aa url(http://beacontransitions.com/wp-content/uploads/2016/03/circlegraphic.gif) no-repeat;
	background-size:contain;
	width: 680px;
	padding-top:20%;
	float: right;
	font-size: 2.5em;
	color:#FFF;
    font-weight:200;
	text-align:right;
	
}
footer {
	clear: both;
	padding: 0 15px;
}

/************************************************************************************
MEDIA QUERIES
*************************************************************************************/
/* for 980px or less */
@media screen and (max-width: 980px) {
	
	#pagewrap {
		width: 94%;
	}
	#sidebar {
		width: 34%;
	
	}
	
	#contentsub {
		width: 34%;
	
	}
	#coreareaphoto {
		
	    width: 60%;
		margin: 0px 0px 5px 5px;
		float: right;
		
	}
	#corearea {
		width: 34%;
}
	
	#content {
		width: 60%;
		
		margin: 0px 0px 5px 5px;
		float: right;
	}
	#sidebarsub {
		width: 60%;
		
		margin: 0px 0px 5px 5px;
		float: left;
	}
	

	 footer {
		padding: 1% 4%;
	}
}



/* for 700px or less */
@media screen and (max-width: 600px) {

	#sidebar {
		width: auto;
		float: none;
	}	
	#sidebarsub {
		width: auto;
		float: none;
	}
	#middle {
		width: auto;
		float: none;

	}
	
	
	#coreareaphoto {
		
		width: auto;
		float: none;
		
	}
	#corearea {
		width: auto;
		float: none;
}
	#content {
		width: auto;
		float: none;
	}
	#contentsub {
		width: auto;
		float: none;
	}

}

/* for 480px or less */
@media screen and (max-width: 480px) {

	.col {  margin: 1% 0 1% 0%; }
	.span_1_of_5, .span_2_of_5, .span_3_of_5, .span_4_of_5, .span_5_of_5 { width: 100%; 
	}
	
	#sidebar {
		
	}

}



 #content, #middle, #sidebar {
	margin-bottom: 5px;
}






.top-button
{
	
	text-decoration: none;
	font-family: 'Raleway', sans-serif;
	font-weight: 600;
	font-size: 16px;
}


.professional {
	padding: 10px;
    border-style: solid;
    border-width: 5px;
	border-color:#9b7e8e;
		}
.parent {
    padding: 10px;
	border-style: solid;
    border-width: 5px;
	border-color:#9b7e8e;		}
		
.resident {
	padding: 10px;
	border-style: solid;
    border-width: 5px;
	border-color:#9b7e8e;
			
		}



    .wrap {
       overflow: hidden;
    }

.box {
       float: left;
       position: relative;
       width: 20%;
       padding-bottom: 42%;
    }

.boxabout {
	
       float: left;
       position: relative;
       width: 100%;
      padding-bottom: 23%;
	
    }

.boxInner {
		background: #fff;
       position: absolute;
       left: 2px;
       right: 2px;
       top: 2px;
       bottom: 2px;
	   padding:5px;

    }

.boxabouttext {

    background: url(http://beacontransitions.com/wp-content/uploads/2016/03/resident.jpg) no-repeat;
	background-size:contain;
    position: absolute;
	left:2px;
    right: 2px;
    top: 2px;
    bottom: 2px;
	padding:5px;
	padding-left:610px;
	color:#FFF;
	font-weight:100;
	font-size: 2.4em;
    overflow: hidden;
    }

.boxInner img {
       width: 100%;
    }

.boxInner .titleBox {
       position: absolute;
       bottom: 0;
       left: 0;
       right: 0;
       margin-bottom: -50px;
       background: #000;
       background: rgba(0, 0, 0, 0.5);
       color: #FFF;
       padding: 10px;
       text-align: center;
       -webkit-transition: all 0.3s ease-out;
       -moz-transition: all 0.3s ease-out;
       -o-transition: all 0.3s ease-out;
       transition: all 0.3s ease-out;
    }
    

body.no-touch .boxInner:hover .titleBox, body.touch .boxInner.touchFocus .titleBox {
       margin-bottom: 0;
    }
    @media only screen and (max-width : 480px) {
       /* Smartphone view: 1 tile */
       .box {
          width: 100%;
          padding-bottom: 120%;
       }
	    .boxabout {
          width: 100%;
          padding-bottom: 120%;
       }
	   .boxabouttext {
		   padding-left:2px;
		   padding-top:40%;
		   font-size: 1.2em;
		   
	   }
	
    }
    @media only screen and (max-width : 720px) and (min-width : 481px) {
       /* Tablet view: 2 tiles */
       .box {
          width: 50%;
          padding-bottom: 60%;
       }
	    .boxabout {
           width: 50%;
          padding-bottom: 60%;
       }
	     .boxabouttext {
		   padding-left:2px;
		   padding-top:40%;
		   font-size: 1.8em;		   
	   }
    }
    @media only screen and (max-width : 1050px) and (min-width : 721px) {
       /* Small desktop / ipad view: 3 tiles */
       .box {
          width: 33.3%;
       padding-bottom: 43%;
       }
	    .boxabout {
                width: 33.3%;
       padding-bottom: 43%;
       }
	   
	   .boxabouttext {
		   padding-left:2px;
		   padding-top:40%;
		   font-size: 1.8em;
		   
	   }
    }
 
 
 
 
 #cssmenu,
#cssmenu ul,
#cssmenu ul li,
#cssmenu ul li a,
#cssmenu #menu-button {
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none;
  line-height: 1;
  display: block;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
#cssmenu:after,
#cssmenu > ul:after {
  content: ".";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0;
}
#cssmenu #menu-button {
  display: none;
}
#cssmenu {
  font-family: Montserrat, sans-serif;

}
#cssmenu > ul > li {
  float: right;
}
#cssmenu.align-center > ul {
  font-size: 0;
  text-align: center;
}
#cssmenu.align-center > ul > li {
  display: inline-block;
  float: none;
}
#cssmenu.align-center ul ul {
  text-align: left;
}
#cssmenu.align-right > ul > li {
  float: right;
}
#cssmenu > ul > li > a {
  padding: 15px;
  font-size: 12px;
  letter-spacing: 1px;
  text-decoration: none;
  color: #FFF;
  font-weight: 700;
  text-transform: uppercase;
}
#cssmenu > ul > li:hover > a {
    color: #dddddd;
}
#cssmenu > ul > li.has-sub > a {
  padding-right: 30px;
}

#cssmenu > ul > li.has-sub:hover > a:before {
  top: 23px;
  height: 0;
}
#cssmenu ul ul {
  position: absolute;
  left: -9999px;
}
#cssmenu.align-right ul ul {
  text-align: right;
}
#cssmenu ul ul li {
  height: 0;
  -webkit-transition: all .25s ease;
  -moz-transition: all .25s ease;
  -ms-transition: all .25s ease;
  -o-transition: all .25s ease;
  transition: all .25s ease;
}
#cssmenu li:hover > ul {
  left: auto;
}
#cssmenu.align-right li:hover > ul {
  left: auto;
  right: 0;
}
#cssmenu li:hover > ul > li {
  height: 35px;
}
#cssmenu ul ul ul {
  margin-left: 100%;
  top: 0;
}
#cssmenu.align-right ul ul ul {
  margin-left: 0;
  margin-right: 100%;
}
#cssmenu ul ul li a {
  border-bottom: 1px solid rgba(150, 150, 150, 0.15);
  padding: 11px 15px;
  width: 170px;
  font-size: 12px;
  text-decoration: none;
  color: #FFF;
  font-weight: 400;
  background: #333333;
}
#cssmenu ul ul li:last-child > a,
#cssmenu ul ul li.last-item > a {
  border-bottom: 0;
}
#cssmenu ul ul li:hover > a,
#cssmenu ul ul li a:hover {
    color: #dddddd;
}
#cssmenu ul ul li.has-sub > a:after {
  position: absolute;
  top: 16px;
  right: 11px;
  width: 8px;
  height: 2px;
  display: block;
  background: #dddddd;
  content: '';
}
#cssmenu.align-right ul ul li.has-sub > a:after {
  right: auto;
  left: 11px;
}
#cssmenu ul ul li.has-sub > a:before {
  position: absolute;
  top: 13px;
  right: 14px;
  display: block;
  width: 2px;
  height: 8px;
  background: #FFF;
  content: '';
  -webkit-transition: all .25s ease;
  -moz-transition: all .25s ease;
  -ms-transition: all .25s ease;
  -o-transition: all .25s ease;
  transition: all .25s ease;
}
#cssmenu.align-right ul ul li.has-sub > a:before {
  right: auto;
  left: 14px;
}
#cssmenu ul ul > li.has-sub:hover > a:before {
  top: 17px;
  height: 0;
}
@media all and (max-width: 768px), only screen and (-webkit-min-device-pixel-ratio: 2) and (max-width: 1024px), only screen and (min--moz-device-pixel-ratio: 2) and (max-width: 1024px), only screen and (-o-min-device-pixel-ratio: 2/1) and (max-width: 1024px), only screen and (min-device-pixel-ratio: 2) and (max-width: 1024px), only screen and (min-resolution: 192dpi) and (max-width: 1024px), only screen and (min-resolution: 2dppx) and (max-width: 1024px) {
  #cssmenu {
    width: 100%;
  }
  #cssmenu ul {
    width: 100%;
    display: none;
  }
  #cssmenu.align-center > ul {
    text-align: left;
  }
  #cssmenu ul li {
    width: 100%;
    border-top: 1px solid rgba(120, 120, 120, 0.2);
  }
  #cssmenu ul ul li,
  #cssmenu li:hover > ul > li {
    height: auto;
  }
  #cssmenu ul li a,
  #cssmenu ul ul li a {
    width: 100%;
    border-bottom: 0;
background: #666;
  }
  #cssmenu > ul > li {
    float: none;
  }
  #cssmenu ul ul li a {
    padding-left: 25px;
  }
  #cssmenu ul ul ul li a {
    padding-left: 35px;
  }
  #cssmenu ul ul li a {
    color: #dddddd;
    background: none:
  }
  #cssmenu ul ul li:hover > a,
  #cssmenu ul ul li.active > a {
    color: #ffffff;
  }
  #cssmenu ul ul,
  #cssmenu ul ul ul,
  #cssmenu.align-right ul ul {
    position: relative;
    left: 0;
    width: 100%;
    margin: 0;
    text-align: left;
  }
  #cssmenu > ul > li.has-sub > a:after,
  #cssmenu > ul > li.has-sub > a:before,
  #cssmenu ul ul > li.has-sub > a:after,
  #cssmenu ul ul > li.has-sub > a:before {
    display: none;
  }
  #cssmenu #menu-button {
    display: block;
    padding: 17px;
    color: #dddddd;
    cursor: pointer;
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 700;
  }
  #cssmenu #menu-button:after {
    position: absolute;
    top: 22px;
    right: 17px;
    display: block;
    height: 4px;
    width: 20px;
    border-top: 2px solid #dddddd;
    border-bottom: 2px solid #dddddd;
    content: '';
  }
  #cssmenu #menu-button:before {
    position: absolute;
    top: 16px;
    right: 17px;
    display: block;
    height: 2px;
    width: 20px;
    background: #dddddd;
    content: '';
  }
  #cssmenu #menu-button.menu-opened:after {
    top: 23px;
    border: 0;
    height: 2px;
    width: 15px;
    background: #ffffff;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  #cssmenu #menu-button.menu-opened:before {
    top: 23px;
    background: #ffffff;
    width: 15px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  #cssmenu .submenu-button {
    position: absolute;
    z-index: 99;
    right: 0;
    top: 0;
    display: block;
    border-left: 1px solid rgba(120, 120, 120, 0.2);
    height: 46px;
    width: 46px;
    cursor: pointer;
  }
  #cssmenu .submenu-button.submenu-opened {
    background: #262626;
  }
  #cssmenu ul ul .submenu-button {
    height: 34px;
    width: 34px;
  }
  #cssmenu .submenu-button:after {
    position: absolute;
    top: 22px;
    right: 19px;
    width: 8px;
    height: 2px;
    display: block;
    background: #dddddd;
    content: '';
  }
  #cssmenu ul ul .submenu-button:after {
    top: 15px;
    right: 13px;
  }
  #cssmenu .submenu-button.submenu-opened:after {
    background: #ffffff;
  }
  #cssmenu .submenu-button:before {
    position: absolute;
    top: 19px;
    right: 22px;
    display: block;
    width: 2px;
    height: 8px;
    background: #dddddd;
    content: '';
  }
  #cssmenu ul ul .submenu-button:before {
    top: 12px;
    right: 16px;
  }
  #cssmenu .submenu-button.submenu-opened:before {
    display: none;
  }
}

.button-text
{
	background: #FFF;
	text-align:center;
	padding:10px;
}

.button-section ul li
{
	display: inline-block;
	color:#FFF;
	margin:30px 10px;
}

.button-section ul li a
{
	
	color:#FFF;
	
}
.top-button
{
	
	text-decoration: none;
	font-weight: 200;
	font-size: 12px;
	text-transform: uppercase;
}
.green
{	color: #fff;
	padding: 10px 20px;
	background-color: #996;
}




@media (min-width: 1080px) and (max-width: 1200px)
{
	.container
	{
		width: 1040px;
		margin: 0 auto;
		padding: 0px 20px;
	}
	.features-section ul li
	{
		width: 346px;
	}
	.stories-section ul li
	{
		width: 304px;
	}
	.story-img img
	{
		width: 304px;
		height: 195px;
	}
	.description
    {
		
	padding-right: 250px;
	}
	

}
@media (min-width: 768px) and (max-width: 1080px)
{
	.container
	{
		width: 728px;
		margin: 0 auto;
	}
	.banner
	{
	
	}

	
	.description
    {
	font-weight:100;
	font-size: 1.4em;
	padding-right: 120px
	}

	.desc h2 {
    	font-size: 25px;
	}
	.desc p {
    	font-size: 16px;
	}
	.features-section ul li {
    	width: 242px;
	}
	.features-section ul li p {
   
    	font-size: 14px;
    	width: 95%;
	}
	.contact-section
	{
	width: 80%;
	margin: 0 auto;
	font-family: 'Open Sans', sans-serif;
	}
	


}
@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) 
and (orientation : landscape) 
{
	.container
	{
		width: 728px;
		margin: 0 auto;
	}
	.banner
	{
		padding: 140px 0px;
	}
	.description
    {
	font-weight:100;
	font-size: 1.3em;
	}
	.desc h2 {
    	font-size: 25px;
	}
	.desc p {
    	font-size: 16px;
	}
	.features-section ul li {
    	width: 242px;
	}
	.features-section ul li p {
   
    	font-size: 14px;
    	width: 95%;
	}
	.contact-section
	{
	width: 80%;
	margin: 0 auto;
	font-family: 'Open Sans', sans-serif;
	}
	

	#pagewrap {
		width: 94%;
	}
	#sidebar{
		width: 34%;
	
	}
	#sidebarsub{
		width: 34%;
	
	}
	
	#content {
		width: 60%;
		
		margin: 0px 0px 5px 5px;
		float: right;
	}
	
	#contentsub {
		width: 60%;
		
		margin: 0px 0px 5px 5px;
		float: right;
	}

	 footer {
		padding: 1% 4%;
	}
	

}
@media (min-width: 600px) and (max-width: 768px)
{
	.container
	{
		width: 600px;
		margin: 0 auto;
	}
	.banner
		{
			
		}
		.description
    {
	font-weight:100;
	font-size: 1.2em;
	}
		.desc {
    		padding: 60px 0px;
		}
		.desc h2 {
    		font-size: 22px;
		}
		.desc p {
    		font-size: 14px;
		}
		.features-section ul li {
    		display: block;
    		float: none;
    		width: 80%;
    		margin: 40px auto;
		}
		p.box-desc {
   	 		line-height: 30px;
		}
		.stories-section ul li {
   	 		float: none;;
   	 		margin: 40px auto;
		}	
		.features {
    		padding: 140px 0px;
		}
		.stories {
    		padding: 140px 0px;
		}
		.contact {
    		padding: 140px 0px;
    
		}
}
@media (min-width: 480px) and (max-width: 600px)
{
	.container
	{
		width: 440px;
		margin: 0 auto;
		padding: 0px 20px;
	}
	.banner
		{
			
		}
		.description
    {
	font-weight:100;
	font-size: 1.0em;
	}

		.contact {
    		padding: 140px 0px;
    
		}
		#sidebar {
		width: auto;
		float: none;
	}
	
		#sidebarsub {
		width: auto;
		float: none;
	}
	
	#middle {
		width: auto;
		float: none;

	}
	
	#content {
		width: auto;
		float: none;
	}
	
		
	#contentsub {
		width: auto;
		float: none;
	}
	
#coreareaphoto {
	
	padding-top:30%;
	font-size: 2.0em;
	
}
	
	
}
@media (min-width: 20px) and (max-width: 480px)
{
	.container
	{
		width: 280px;
		margin: 0 auto;
		padding: 0px 20px;
	}
	.banner
		{
			
		}
	.description
    {
	font-family: open sans, sans-serif;
	color: #666;
	font-size: 0.875em;
	font-weight:100;
	
	}
	
	
		.desc {
    		padding: 60px 0px;
		}
		.desc h2 {
    		font-size: 22px;
		}
		.desc p {
    		font-size: 14px;
			width: 100%;
		}
		.features
		{
			padding: 140px 0px;
		}
		.features-section ul li {
    		display: block;
    		float: none;
    		width: 90%;
    		margin: 40px auto;
		}
		.features-section ul li p
		{
			width: 100%;
		}
		p.box-desc {
   	 		line-height: 30px;
			font-size: 14px;
		}
		
		
		.button-section ul li {
    		margin: 30px 12px;
		}
		

		h3.text-head {
    		font-size: 20px;
		}
		.menu {
   			 display: none;
		}
		
		
#coreareaphoto {
	
	padding-top:30%;
	font-size: 2.0em;
	
}
		
	
		

}

@media only screen and (max-width: 767px){
#mobile-header {
display: block;
}

.banner {
    
}

.menu
{
	display: none;
}


}