
html {
	font-family: sans-serif;
	text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	/*overflow-y:scroll; from hc.. why? 
	height:100%;*/
	/* Fix for webkit rendering. Subpixel-antialiased makes text a bit thicker. */
	-webkit-font-smoothing: antialiased; margin:0;padding:0; }
body {
	font:1.1em/1.3 "Roboto", sans-serif;/* 2 sizes defined in font tag.. short hand for size/lineheight */
	color: #000;
	margin:0 /*auto*/;
	padding:0;
	width:100%;
	min-width:200px;/* Not essential but keeps stuff getting stupid thin and bursting words out of divs etc.*/
	background:#fdfdfd;
	
	/* bg img that always fill screen
	background: url(/images/room-painting1.jpg) no-repeat center center fixed; 
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;*/
  }
  div, img, h1, h2, h3, h4{
		box-sizing:border-box;
	}
h1{
	font-size:1.6em;
	margin:30px 0;
	padding:0px 0 10px;
	font-family: 'Roboto', sans-serif;
	font-weight:700;
	border-bottom:1px solid #000;
	text-align:center;}
h2{
	font-size:1.5em;
	margin: 1.2em 0;
	padding-bottom:1em;
	color:#000;
	border-bottom:1px solid #000;
	font-family: 'Roboto', sans-serif;
	font-weight:600;
	text-transform:uppercase;
}
h3{
	font-size:1.3em;
	margin:1.1em 0;
	color:#000;
	font-weight:bold;}

.big{
	font-weight:bold;
	font-size:1.4em;}
.center{
	text-align:center;
}
p{
	margin:10px 0 30px 0;}
ul{
	margin:15px 0 30px 0;
	padding:0 0 0 20px;
	list-style-position:outside;}
li{
	margin:2px 0;
	padding:0;}

a{
	color:#40837D; /*EBB03F;*/
	background: transparent;
	transition: all ease-in-out .3s;
	}
a:hover{
	opacity:0.8;
}
	
img{
	max-width:100%;
	height:auto;
	zoom:1;}
	 
/*.sitewrapper{
	text-align:center;
	margin:0 auto;
	width:100%;}*/
header{
	max-width:1200px;
	margin:0 auto;}
a.logo{
	text-decoration:none;
	display:block;/*block;*/
	float:left;
	max-width:65%;
}
.rhp-logo{
	vertical-align:top;
	display:inline-block;
	margin-top:20px;
	max-width:300px;
	text-align:center;
}

header img{
	display:inline-block;
	margin:10px;
	/*float:left;*/
	
	max-width:300px;}
header .phone{
	float:right;
	max-width:55%;
	padding:20px 10px; 
	font-size:1em;
	}
@media only screen and (max-width:870px){
	.rhp-logo{
		visibility:hidden;
		height:1px;
		width:1px;
		overflow:hidden;
	}
	a.logo{
		max-width:44%;
	}
	header .phone{
		max-width:53%;
	}
}

h1.wide{
	padding:45px 10px;
	color:#fff;
	background: #40837D; /*#72BCA8; /*#EBB03F;*/
	border:0 none;
	margin:0;
	font-size:2.2em;
}
.wrapper{
	max-width:1420px;
	margin:0 auto;
	padding:0.5% 1.5%;
	clear:both;
	margin-bottom:0px;
	/*border-radius:10px;
	-webkit-border-radius:10px;
	-moz-border-radius:10px;
	-o-border-radius:10px;*/}
.inner{
	margin:20px;}
.col img{
	border:1px solid #ccc;
	padding:4px;}	

.accent-color{
	color:#40837D;
}
.banner{
	max-height:300px;
	height:300px;
	overflow:hidden;
	background-color:#ccc;
	background-image: url(/images/room-painting2.jpg);
	background-position: center 60%;
	background-size:cover;
	/*background-attachment: fixed;*//*overrides size */
}
	
	.contact.banner{
		background-image: url(/images/painting-wallpaper-2.jpg);
	}
	.mural.banner{
		background-image: url(/images/mural-ilgirasole_3762.jpg);
	}

.center-align{
	text-align:center;
}

.section{
	min-width:100%;
	padding-top:1%;
	padding-bottom:1%;
	margin-top:2%;
	background-color:#333;
	background-position: center center;
	background-size:cover;
	background-attachment: fixed;/*overrides size */
	}
.section .wrapper{
	background: rgba(255, 255, 255, 0.9);
	min-height:500px;
	}
.roofing{
	background-image: url(/images/roof-ridge1-1500.jpg); }
.painting{
	background-image: url(/images/room-painting2.jpg); }

footer{
	background:#eee;
	margin:0;
	border-top:1px solid #ccc;
	margin-top:2em;
	padding-top:10px;
	text-align:center;
	overflow:hidden;
	clear:both;}
 
 .footer-base{
	 background:#333;
	 color:#eee;
	 text-align:center;
	 padding:10px;
	 font-weight:bold;
	 font-size:1.3em;
 }
 
 
 .cta{
	 text-align:center;
	 margin:40px 0 20px;
	 clear:both;}
 .cta.email a,
 .button{
	 padding:20px;
	 text-align:center;
	 font-size:1.2em;
	 margin:20px auto;
	 border:0px solid #333;
	 color:#fff;
	 background-color:#5A7386;
	 text-decoration:none;
	 text-transform:uppercase;
	 cursor:pointer;
	 display:inline-block;
	 border-radius:7px;
	}
	.button2{
	 padding:10px 13px;
	 text-align:center;
	 font-size:1.2em;
	 margin:1em auto;
	 border:2px solid #333;
	 color:#fff;
	 background-color:#EBB03F;
	 text-decoration:none;
	 text-transform:uppercase;
	 cursor:pointer;
	 display:inline-block;
	 -webkit-border-radius:5px;
	 border-radius:5px;
	}
 .cta.email a:hover,
 .cta.email a:active,
	 a.button:hover,
	 a.button:active,
	.button2:hover,
	.button2:active{
		opacity:0.8;
	}
 .cta.email a{
	 width:80%;
	 max-width:450px;
	 display:block;
	}
.cta.phone{
	font-size:1.5em;
	font-weight:bold;}
.phone span{
	display:inline-block;
	margin: 0 20px;}
	
/*ul{
	text-align:left;
	margin-left:10%;
}*/
.no-bullets {
	list-style-type:none;
	margin-left:0;
	padding-left:0;}

.rem{
	text-indent:-999999px;
	margin:0;
	padding:0;
	line-height:1em;
	font-size:0.5em;}

.clear{
	clear:both;}
	
.divider{
	height:1px ;
	border-top:2px solid #5A7386;
	margin:20px 0 50px;
}
	
.darker{
	background:#eee;
}
.darker2{
	border-top:1px solid #5A7386;
	padding:30px 0 20px;
	margin-top:30px;
	background:#CAE4E4; /*#EFDDC4;*/
}
.bgblue{
	background:#05396A;
	color:#fff;
	width:100%;
	padding: 40px 0;
}


.lighttext h1,
.lighttext h2,
.lighttext h3,
.lighttext h4,
.lighttext p
.lighttext li,
.lighttext{
	color:#fff;
}

.box1{
	background:#eee;
	padding:20px;
	margin:20px 10px;
	border-radius:20px;
}

.nav{
	width:100%;
	padding:10px 0;
	margin:0;
	text-align:center;
	background:#eee;
	border-top:1px solid #ccc;
}

.nav a{
	display:inline-block;
	margin:5px 20px;
	font-weight:bold;
	text-decoration:none;
}


.flex-container{
	display:flex;
	flex-wrap:wrap;
	
}
.flex-type-1{
	flex-direction:column;
}
.flex-type-1 > div{
	width:100%;
}
.flex-type-2 > div{
	width:50%;
}

.flex-container > div ul{
	margin-left:20px;
	margin-right:20px;
}


.services-images{
	margin-top:20px;
	margin-bottom:20px;
}
.services-images img{
	display:block;
	box-sizing:border-box;
	border:2px solid #fff;
}


.center{
	text-align:center;
}


@media only screen and (max-width:800px){
	body{
		font-size:1em;}
		
header img{
	max-width:80%;
	margin:10px;
	float:left;}
.banner{
	height:200px;}
		
	.section{
		padding-top:150px;
		padding-bottom:0;
		background-position: center 0;
		background-size: 100% auto;
		background-attachment: scroll;
		}
	.section .wrapper{
		background: rgba(255, 255, 255, 1);}
		
	h1.wide{
		padding:35px 10px;
		font-size:1.8em;
	}
		
}

@media only screen and (min-width:568px){
	
	.flex-type-1{
		flex-direction:row;
	}
	.flex-type-1 > div{
		width:50%;
	}
	.flex-type-2 > div{
		width:25%;
	}
}
@media only screen and (min-width:801px){
	.group{
		clear:both;
	}
	.group:after{
		content: "";
  	display: table;
  	clear: both;
	}
	.col{
		float:left;
		width:50%;}
	header .phone{
		font-size:1.2em;}
		
	.intro-text{
		max-width:900px;
		margin-left:auto;
		margin-right:auto;
	}
}
