
/* MAIN */
:root{--dull:#555;--accent:rgb(161,29,41);}
html{height:100%;width:100%;box-sizing: border-box;overflow: auto;}
body{margin:0;padding:0;font-family: open-sans, verdana, sans-serif;background:rgb(35, 35, 35);	color:#555;}
*{font-family:inherit;box-sizing:inherit}
.wall{position:relative;max-width:1100px;margin:0 auto;}
@font-face{font-family:impact;	src:url('../font/impact.ttf') format('truetype');}


/* CUSTOM SCROLLBAR*/ 
::-webkit-scrollbar{width: 3px;display:none;}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);}


#header{position:fixed;top:0;left:0;width:100%;height:150px;background:#000;z-index:100;}
#fixr{height:150px;}

/* LOGO */
.logo{position:absolute;top:40px;left:20px;padding-top:30px;border-top:2px solid rgb(55,55,55);border-bottom:2px solid rgb(55,55,55); width:197px;text-decoration:none;}
.logo div{position:relative;top:-3px;font-family:impact;color:#fff;font-size:42px;line-height:34px;margin:-3px 0; text-shadow:3px 3px 3px rgba(0,0,0,.95);transform:scaleX(.5) translate(-50%);white-space: nowrap;}
.logo span{position:relative;top:-2px;font-size:36px;display:inline-block;line-height:35px;}
.logo::before{content:'';position:absolute;top:-19px;left:0;width:0;height:0;border:99px solid transparent;border-bottom:41px solid rgb(161, 29, 41);border-top:none;filter:drop-shadow(2px 3px 3px rgba(0,0,0,.7));}
.logo::after{content:'';position:absolute;top:-26px;left:44px;width:106px;height:106px;border-radius:60px;z-index:-1;border:2px solid rgb(55,55,55);}
.logo p{position:absolute;margin:0;padding:0;  padding-top:5px;      color:#fff;letter-spacing: 1.4em;font-size:10px;font-family:arial; text-shadow:1px 1px 2px rgba(0,0,0,.95);}
.logo p::before{content:'';position:absolute;top:-82px;left:54px;width:86px;height:20px;border-left:2px solid rgb(55,55,55);border-right:2px solid rgb(55,55,55);z-index:-1;}
.logo p::after{content:'';position:absolute;top:0;left:54px;width:86px;height:20px;border-left:2px solid rgb(55,55,55);border-right:2px solid rgb(55,55,55);z-index:-1;}	
.logo.big{transform:scale(3.0) translate(-16.7%);left:50%;top:220px;}
.logo.big, .logo.big::after, .logo.big p::before, .logo.big p::after{border-color:rgba(170,170,170,.3);/*#aaa*/}
.logo.foot{transform:scale(.8);left:35px;top:15px;filter:contrast(50%) grayscale(1) opacity(.8);} 
.logo.foot:hover{filter:contrast(60%) grayscale(1) opacity(1) brightness(1.1);}


/* MENU */	
#menu{position:absolute;z-index:2;right:30px;top:30px;display:block;list-style:none;margin:0;padding:0;color:rgb(77,77,77);font-family:verdana, sans-serif;font-size:14px;font-weight:normal;text-align:left;}
#menu li{position:relative;display:inline;padding:0;margin:0;}
#menu li:after{content:'|';}
#menu li:last-child:after, #menu li li:after {content:'';}
#menu li a{color:rgb(150, 150, 150);text-decoration:none;padding:10px;outline:none;white-space:nowrap;margin-top:10px;}
#menu li a:hover{color:#fff;}

/* PHONE */
#phone{position:absolute;right:38px;top:70px;width:200px;overflow:hidden;white-space: nowrap;background:rgba(0,0,0,.35);        display:none;        }
#phone div{color:rgb(161, 29, 41);font-size:16px;font-weight:bold;letter-spacing: .23em;}
#phone a{font-family:impact;font-size:36px;color:#fff;text-decoration:none;}


#hero{position:relative;display:block;height:70vw;width:100%;max-height:720px;}
#hero .filter{position:absolute;width:100%;height:100%;background-size:cover;background-image:linear-gradient(rgba(230,230,230,0) 0%, rgba(230,230,230,0) 65%, rgba(230,230,230,1) 100%),linear-gradient(rgba(0,0,0,.3), rgba(0,0,0,.3));}
#hero:before{position:absolute;content:'';width:100%;height:100%;background-size:cover;background-image:linear-gradient(rgba(230,230,230,0) 0%, rgba(230,230,230,0) 65%, rgba(230,230,230,1) 100%),linear-gradient(rgba(0,0,0,.3), rgba(0,0,0,.3));}

#hero .preload{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;background-position:center;}
#hero .preload:nth-of-type(1){background-image:url(../img/sys/insulation.jpg);/*background-size:110% 110%;*/animation:zoomin 40s;animation-delay:0s;animation-iteration-count: infinite;}
#hero .preload:nth-of-type(2){background-image:url(../img/sys/framing.jpg);/*background-size:100% 100%;*/animation:zoomout 40s;animation-delay:10s;animation-iteration-count: infinite;}
#hero .preload:nth-of-type(3){background-image:url(../img/sys/insulation2.jpg);/*background-size:110% 110%;*/animation:zoomin 40s;animation-delay:20s;animation-iteration-count: infinite;}
#hero .preload:nth-of-type(4){background-image:url(../img/sys/framing2.jpg);/*background-size:100% 100%;*/animation:zoomout 40s;animation-delay:30s;animation-iteration-count: infinite;}
#hero .banner{position:absolute;top:440px;width:100%;text-align:center;color:#fff;font-size:24px;font-weight:bold;line-height:20px;padding:20px;text-shadow:2px 2px 2px rgba(0,0,0,.5);}

@keyframes zoomin{
	0%{background-size:100% 100%;opacity:0;}
	17%{opacity:1;}
	35%{background-size:110% 110%;opacity:0;}
	100%{background-size:100% 100%;opacity:0;}
}
@keyframes zoomout{	
	0%{background-size:110% 110%;opacity:0;}
	17%{opacity:1;}
	35%{background-size:100% 100%;opacity:0;}
	100%{background-size:110% 110%;opacity:0;}
}

.services{position:relative;background:linear-gradient(rgb(230,230,230), rgb(255,255,255));}
.services h1{position:relative;font-family:impact;color:#222;margin:0;padding:30px 20px 10px 20px;font-size:48px;font-weight:normal;}
.services p{position:relative;font-size:16px; color:#555;line-height:1.7em;margin:0;padding:20px;}
.services .wall::before{position:absolute;content:'';width:100%;height:80%;top:10%;left:0;opacity:.05;filter:grayscale(1);
	/*background:url(../img/roof.png);*/
	background-size:contain;
	background-repeat:no-repeat;
	background-position:center;
}

.roofing h1{padding:0 20px 10px 20px;}
.roofing .wall::before{background-image:url(../img/roof.svg);}
.insulation .wall::before{background-image:url(../img/paint.svg);}
.drywall .wall::before{background-image:url(../img/remodel.svg);}



a.more{font-size:inherit;color:rgb(161, 29, 41);text-decoration:none;font-weight:bold;padding:10px;}
a.more::after{display:inline;content:'›';color:inherit;font-size:28px;position:relative;top:3px;left:2px;}

.more-wrapper{position:relative;text-align:right;padding:0 20px}
.button-wrapper{position:relative;display:flex;justify-content:center;padding:40px 0 80px 0;}

.button{font-size:16px;color:#fff;background:rgb(161, 29, 41);text-decoration:none;padding:20px 40px;text-align:center;border-radius:5px;}

.reviews{position:relative;background:linear-gradient(rgb(239,239,239), rgb(255,255,255));padding:40px 0 0 0;overflow-x:hidden;width:100vw;}
.reviews .card{position:relative;/*background:#fff;*/box-shadow:0 8px 15px rgba(0,0,0,0.15);padding: 50px 20px 20px 20px;max-width:700px;border-radius:12px;margin:0 auto;white-space: normal;}
.reviews h1{text-align:center;position:relative;font-family:impact;color:rgb(161, 29, 41);margin:0;padding:20px 20px 20px 20px;font-size:48px;font-weight:normal;}
.reviews p{position:relative;font-size:16px; color:#555;line-height:1.7em;margin:0;padding:20px;font-style:italic;text-align:center;}
.reviews p::before, .reviews p::after{content:'"';color:inherit;}
.reviews img{position:absolute;left:50%;transform:translate(-50%,-100%);width:100px;box-shadow: 0 8px 15px rgba(0,0,0,0.15); border-radius: 50%; border: 2px solid white;}
.reviews .signature{display:flex;justify-content: flex-end;font-weight:bold;color:#555;font-size:16px;padding:0 20px 20px 20px;background:url(../img/stars.svg);background-size:100px;background-repeat:no-repeat;background-position:20px 2px;}

.reviews.partners{padding:40px 0 60px 0;}
.reviews.partners .card{box-shadow:none;}
.reviews.partners img{/*width:auto;height:60px;*/ width:100%; height:100%; object-fit:contain;box-shadow:none;border-radius:0;border:none;}

#slider{position:relative;padding:50px 0 15px 0;white-space: nowrap;left:0vw; transition: left .8s ;transition-timing-function: cubic-bezier(0.4, 0, 0.1, 1);font-size:0;}
#slider:empty{height:295px;}
.slide{position:relative;display:inline-block;width:100vw;padding:0 20px;}
#slider.p1{left:-100vw;}
#slider.p2{left:-200vw;}
#slider.p3{left:-300vw;}
#slider.p4{left:-400vw;}
#slider.p5{left:-500vw;}
#slider.p6{left:-600vw;}
#slider.p7{left:-700vw;}
#slider.p8{left:-800vw;}
#slider.p9{left:-900vw;}
#slider.p10{left:-1000vw;}
#slider.p11{left:-1100vw;}
#slider.p12{left:-1200vw;}
#slider.p13{left:-1300vw;}
#slider.p14{left:-1400vw;}
#slider.p15{left:-1500vw;}
#slider.p16{left:-1600vw;}
#slider.p17{left:-1700vw;}


.specialty{position:relative;background:linear-gradient(rgb(230,230,230), rgb(255,255,255));padding:0 0 40px 0;}
.specialty h1{position:relative;font-family:impact;color:#222;margin:0;padding:60px 20px 10px 20px;font-size:42px;font-weight:normal;}
.specialty h2{position:relative;color:rgb(161, 29, 41);margin:0;padding:0 20px; font-size:20px;}
.specialty  p{position:relative;font-size:16px; color:#555;line-height:1.7em;margin:0;padding:20px;}
.specialty li{position:relative;font-size:16px; color:#555;line-height:1.7em;margin:0;padding:0 0 20px 0;}
.specialty li b{display:block;}
.specialty .wall::before{position:absolute;content:'';width:100%;height:80%;top:10%;left:0;opacity:.05;filter:grayscale(1);
	background-size:contain;
	background-repeat:no-repeat;
	background-position:center;
	z-index:-1;
}


/* FOOTER */
#footer{position:relative;display:block;width:100%;height:135px;padding:20px;background:#000;color:rgb(155,155,155);}

#footmenu{position:absolute;top:0;right:50px;}
#footmenu .link{display:inline-block;color:rgb(120,120,120);text-decoration:none;margin-right:30px;font-size:14px;}
#footmenu .link:hover{color:#fff;}
#footmenu .link:last-child{margin-right:0;}

#footsocial{position:absolute;right:50px;top:46px;}
#footsocial *{display:inline-block;margin-left:10px;width:25px;height:25px;padding:10px;background-position:center;background-repeat:no-repeat;background-size:25px 25px;
	filter:grayscale(1) contrast(0) opacity(.8);}
#footsocial *:hover{filter:grayscale(0);}
#footsocial a:first-child{margin-left:0;}
.fb_share{background-image:url('../img/facebook.svg');}
.gplus_share{background-image:url('../img/google.svg');}
.tw_share{background-image:url('../img/twitter.svg');}
.pin_share{background-image:url('../img/pinterest.svg');}
.in_share{background-image:url('../img/linkedin.svg');}
.bbb_share{background-image:url('../img/bbb.svg');}
.angies_share{background-image:url('../img/angies.svg');}
.homeadvisor_share{background-image:url('../img/homeadvisor.svg');}

#footbar{text-align:center;font-size:12px;background:rgb(39, 39, 39);color:rgb(141,141,141);padding:14px;}
#footbar span{white-space:nowrap;line-height:1.7em;}


/* BIO 
.bio{position:relative;padding:40px 20px;width:100%;    display:flex;flex-flow:row wrap;cursor:pointer;    }
.bio .card{position:relative;background:#fff;box-shadow:0 8px 15px rgba(0,0,0,0.15);padding: 0;border-radius:12px;margin:0 auto 40px auto;white-space: normal;min-width:48%;}

.bio img{position:relative;     width:calc(100px + 8%);float:left;border-radius: 50%;margin:0;background:rgba(0,0,0,.0);padding:20px;shape-outside: circle();	
}
.bio h2{color: var(--accent);margin:0;padding:30px 30px 0 30px;font-size:20px;}
.bio .title{font-size:14px; font-weight:bold; color:#777;;margin:0;padding:4px 30px;}
.bio a{text-decoration:none;color: rgb(161, 29, 41);font-weight:bold;}
.bio p{position:relative;font-size:16px; color:#555;line-height:1.7em;margin:0;padding:0px 30px 30px 30px;text-align:left;}
.bio > br{clear:both;}
*/

.bio{position:relative;padding:40px 20px;width:100%;    display:flex;flex-flow:row wrap;  cursor:pointer;  }
.bio .card{position:relative;background:#fff;box-shadow:0 8px 15px rgba(0,0,0,0.15);padding: 0;border-radius:12px;margin:0 auto 40px auto;white-space: normal;min-width:48%;}
.bio img{position:relative;     width:calc(100px + 15%);float:right;border-radius: 50%;margin:0;background:rgba(0,0,0,.0);padding:20px;shape-outside: circle();/*clip-path: circle();*/	
	}
.bio h2{color: var(--accent);margin:0;padding:30px 30px 0 30px;font-size:20px;}
.bio .title{font-size:14px; font-weight:bold; color:#777;;margin:0;padding:4px 30px;}
.bio p{position:relative;font-size:16px; color:#555;line-height:1.7em;margin:0;padding:25px 30px 30px 30px;text-align:left;}
.bio .card:after{content:' ';display:block;height:0;clear:both;}







/* MODAL */ 
#modal{display:none;position:fixed; left:50%;top:10vw; /*top:110px;top:40%;*/ max-width:600px; min-width:350px; z-index:1000; animation: modal 0.6s;  
/*-webkit-transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1,1);*/
transform:translateX(-50%) /*translateY(-50%);*/
}
#modal:before{content:' ';position:absolute;left:-2000px;top:-2000px;height:4000px;width:4000px;background:rgba(0,0,0,.2);z-index:-1;}
@keyframes modal{from{top:0;opacity:0}to{top:10vw;/*110px;/*top:40%*/ opacity:1}}

/* EXIT */
q.quit{font-size:0;position:absolute;top:2px;right:0;}
q.quit:before{content:'✕';position:absolute;right:4px;top:1px;font-size:24px;background:transparent;line-height:32px;width:32px;text-align:center;cursor:pointer;}


/* CONTACT HOVER DOT */
#hovdot{display:block;position:fixed;bottom:20px;right:20px;color:#fff;text-decoration:none;width:85px;height:47px;line-height:47px;text-align:center;z-index:1000;font-size:12px;letter-spacing: .2em;animation: hovdot 0.8s;}
#hovdot:before{position:absolute;content:''; background:rgba(161, 29, 41, 1);width:85px;height:47px;border-radius:25px 25px 0 25px; z-index:-1;    left:0; bottom:0; border:2px solid #fff;left:-4px;bottom:-2px;}
#hovdot:hover:before{filter:drop-shadow(0 0 20px #fff);}
@keyframes hovdot{from{opacity:0}to{opacity:1}}


/* CONTACT FORM */
#contact{display:block;background:#fff;padding:20px;border-radius:6px;box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2), 0 6px 20px 0 rgba(0,0,0,0.19);}
#contact input, #contact textarea{position:static;display:block;margin:0 0 2px 0;padding:12px;border:1px solid #ccc;width:100%;font-size:14px;}
#contact h2{margin:0 0 20px 0;font-family: impact;color:rgb(161, 29, 41);font-weight:normal;}
#contact div{max-height:20vh;overflow-y:hidden;}
#contact input[type='submit']{background:rgb(161,29,41);color:#fff;margin-top:20px;border-radius:4px;}


/* RERSPONSIVE */
@media screen and (max-width:974px){
	#header{height:100px;}
	#fixr{height:100px;}
	#menu{position:absolute;top:80px;right:0;/*animation: slide 0.6s;*/filter:drop-shadow(-5px 5px 6px rgba(0,0,0,.5));}
	#menu li{display:block;animation: slide 0.6s;}
	#menu.hide li{display:none;}
	#menu li:after{content:'';}
	#menu li a{display:block;background:rgb(161, 29, 41);color:#fff;text-decoration:none;margin:0;outline:none;padding:20px 40px;border-bottom:1px solid rgba(255,255,255,.1);}
	#menu li a:hover{background:#fff;color:rgb(161, 29, 41);transition:background 0.4s;}	
	#menu li:first-child a{border-radius:15px 0 0 0;}	/* only for curved first li */
	#menu:before{content:'☰';display:block;position:fixed;top:-65px;right:15px;color:#fff;cursor:pointer;text-align:center;font-size:48px;width:48px;line-height:48px;transform:scale(.9, .8);background:rgba(0,0,0,.35);}	
	#phone{left:50vw;top:18px;transform:translate(calc(-50% + 30px));}
	.logo{transform:scale(.7);left:-10px;top:18px}
	.logo.big{transform:scale(2.5) translate(-20%);top:18vw;}
	#hero .banner{top:42vw;font-size:2.0vw;line-height:4vw;padding:1.5vw 10px;}
	
}

@media screen and (max-width:900px){
	.logo{transform:scale(.7);left:-10px;}
	.logo.big{transform:scale(2.0) translate(-25%);}
	#hero .banner{font-size:2.2vw;}
}

@media screen and (max-width:800px){
	.logo.big{transform:scale(1.6) translate(-31.25%);}
	#hero .banner{font-size:2.4vw;}
	.button{font-size:16px;padding:15px 20px;}
	.bio{display:block;}	
}


@media screen and (max-width:700px){
	#header{height:80px;}
	#fixr{height:80px;}
	.logo{transform:scale(.5);left:-30px;top:10px;}
	.logo, .logo::after, .logo p::before, .logo p::after{border-color:#555;}
	#phone{top:10px;transform:scale(.8) translate(calc(-50% + 5px));}	
	.logo.big{transform:scale(1.2) translate(-41.7%);}
	/*.reviews{padding:40px 0 0 0;}*/
	#footer{text-align:center;height:215px}	
	.logo.foot{transform:translate(-50%);left:50%;top:-44px;} /*.logo.foot{transform:scale(.6) translate(-83%);left:50%;top:-47px;}*/
	#footmenu{position:relative;right:0;top:57px}
	#footsocial{position:relative;right:0;top:100px;}
}



@media screen and (max-width:500px){
	.logo.big{transform:scale(1) translate(-50%);}
	#hero .banner{font-size:2.6vw;}
	.services h1:before{display:none;}
	.roofing .platinum{position:absolute;top:-42px;right:20px;width:110px;}
	.remodeling .certified{top:22px;right:3px;width:60px;}
}


@keyframes slide{from{right:-100px;opacity:0}to{right:0; opacity:1}}