
/* 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');}
a{cursor:pointer;}
input[type="submit"]{cursor:pointer;}

/* 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: relative;
    display: inline-block;
    text-decoration: none;
    line-height: 0;
    top: 15px;
    left: 15px;
    width: 138px;              /* default/header size */
    filter: drop-shadow(3px 3px 3px rgba(0,0,0,.35));
}

.logo img,
.logo svg{
    display: block;
    width: 100%;
    height: auto;
}

/* BIG CENTER VERSION */
.logo.big{
    width: 591px;   /* 197 x 3 */
    top: 40px;
    left: 50%;
    transform: translateX(-50%);
}

/* FOOTER VERSION */
.logo.foot{
    width: 111px;
    top: 0;
    filter: grayscale(1) contrast(.55) opacity(.85);
}

.logo.foot:hover{
    filter: grayscale(1) contrast(.7) opacity(1) brightness(1.05);
}

/* 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>a{display:none;}
#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);}
#phone div{color:var(--accent);font-size:16px;font-weight:bold;letter-spacing: .23em;}
#phone a{font-family:impact;font-size:36px;color:#fff;text-decoration:none;}




/* HERO SLIDESHOW */
#hero{position:relative;display:block;height:70vw;width:100%;max-height:720px;} /*background-image:url(../img/sys/tmc11.jpg);background-size:100% 100%;background-repeat:no-repeat;}*/
#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/tmchome.jpg);animation:zoomin 20s;animation-delay:0s;animation-iteration-count: infinite;}
#hero .preload:nth-of-type(2){background-image:url(../img/rf1/1522468801.jpg);animation:zoomout 20s;animation-delay:5s;animation-iteration-count: infinite;}
#hero .preload:nth-of-type(3){background-image:url(../img/rm1/1608254564.jpg);animation:zoomin 20s;animation-delay:10s;animation-iteration-count: infinite;}
#hero .preload:nth-of-type(4){background-image:url(../img/rf1/1527739213.jpg);animation:zoomout 20s;animation-delay:15s;animation-iteration-count: infinite;}
#hero .banner{position:absolute;top:440px;width:100%;text-align:center;color:#ccc;font-size:24px;font-weight:bold;line-height:27px;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;}
}

/* SPECIAL FEATURES */
#video{width:calc(100% - 40px);margin:0 20px;object-fit: cover;}
.video{position:relative;width:calc(100% - 40px);height:0;margin:0 20px;padding-bottom:54.5%;}
.video iframe{position:absolute;width:100%;height:100%;top:0;left:0;border-radius:12px;}
.company{background:url('../img/bio/company.jpg');background-size:cover;background-position:center;padding-top:calc(50px + 17vw);}


.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 140px 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-size:contain;
	background-repeat:no-repeat;
	background-position:center;
}

.roofing .wall::before{background-image:url(../img/sys/roof.svg);}
/*.roofing h1{padding:0 140px 10px 20px;}*/
.roofing h1::before{display:inline-block;position:relative;content:'';width:75px;height:40px;background:url(../img/sys/roof.svg);margin-right:10px;background-size:110px;}
.roofing .platinum{position:absolute;top:-50px;right:20px;width:130px;}


.painting .wall::before{background-image:url(../img/sys/paint.svg);}
.painting h1::before{display:inline-block;position:relative;content:'';margin-bottom:-16px;width:49px;height:60px;background:url(../img/sys/paint.svg);margin-right:10px;background-size:60px;}
.painting .exclusive{position:absolute;top:20px;right:20px;width:110px;}

.remodeling .wall::before{background-image:url(../img/sys/remodel.svg);}
.remodeling h1::before{display:inline-block;position:relative;content:'';margin-bottom:-10px;width:55px;height:60px;background:url(../img/sys/remodel.svg);margin-right:10px;background-size:contain;background-repeat:no-repeat;}
.remodeling .certified{position:absolute;top:22px;right:20px;width:70px;}


a.more{font-size:inherit;color:var(--accent);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:var(--accent);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:var(--accent);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/sys/stars.svg);background-size:100px;background-repeat:no-repeat;background-position:20px 2px;}
#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;}



.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:var(--accent);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);z-index:-1;
	background-size:contain;
	background-repeat:no-repeat;
	background-position:center;
}


.bio{position:relative;padding:40px 20px;width:100%;    display:flex;flex-flow:row wrap;    }
.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;}


/* 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/sys/facebook.svg');}
.yt_share{background-image:url('../img/sys/youtube.svg');}
.gplus_share{background-image:url('../img/sys/google.svg');}
.tw_share{background-image:url('../img/sys/twitter.svg');}
.pin_share{background-image:url('../img/sys/pinterest.svg');}
.in_share{background-image:url('../img/sys/linkedin.svg');}
.bbb_share{background-image:url('../img/sys/bbb.svg');}
.angies_share{background-image:url('../img/sys/angies.svg');}
.homeadvisor_share{background-image:url('../img/sys/homeadvisor.svg');}

#footbar{position:relative;text-align:center;font-size:12px;background:rgb(39, 39, 39);color:rgb(141,141,141);padding:14px 0px;}
#footbar a{position:absolute;left:0;bottom:0;font-size:12px;line-height:1.7em;padding:14px 10px;}
#footbar a:nth-of-type(2){left:50px;}
#footbar span{white-space:nowrap;line-height:1.7em;}
#footbar div{line-height:1.7em;padding:10px 130px;}
#footbar .link{display:inline-block;color:inherit;text-decoration:none;font-size:inherit;margin-left:10px;}


/* MODAL */

#modal{display:none;position:fixed; left:50%;top:10vw;max-width:1000px; min-width:350px; z-index:1000;transform:translateX(-50%);animation: modal 0.6s;}
#modal:before{content:' ';position:absolute;left:-2000px;top:-2000px;height:4000px;width:4000px;background:rgba(0,0,0,.52);z-index:-1;}
@keyframes modal{from{top:0;opacity:0;}to{top:10vw;opacity:1;}}

/* EXIT */
a.quit{font-size:0;position:absolute;top:2px;right:0;text-decoration:none;}
a.quit:before{content:'✕';position:absolute;right:4px;top:1px;font-size:24px;background:transparent;line-height:32px;width:32px;text-align:center;cursor:pointer;z-index:1;}


/* 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:var(--accent);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{position:relative;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:var(--accent);font-weight:normal;}
#contact div{max-height:20vh;overflow-y:hidden;}
#contact input[type='submit']{background:var(--accent);color:#fff;margin:20px auto 0 auto;border-radius:4px;max-width:500px;-webkit-appearance: none;}


/* PICK */
.pick{position:relative;top:80px;display:inline-flex;width:100%;justify-content: center;gap:40px;}
.pick a{display:inline-block;color:#fff;font-size:24px;border: 2px solid #fff; border-radius:8px; padding: 20px 40px; text-decoration: none;box-shadow:4px 4px 4px rgba(0,0,0,.5);}
.pick a:hover{background:#111;}

/* RESPONSIVE */
@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:var(--accent);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:var(--accent);transition:background 0.4s;}	
	#menu li:first-of-type a{border-radius:15px 0 0 0;}	/* only for curved first li */
	/*#menu:before{content:'☰';color:#fff;display:block;position:absolute;top:-65px;right:15px;cursor:pointer;text-align:center;font-size:48px;width:48px;line-height:48px;transform:scale(.9, .8);background:rgba(0,0,0,.35);}*/
	#menu>a{display:block;position:absolute;top:-65px;right:15px;cursor:pointer;text-align:center;color:#fff;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{width:90px;}
	#hero .banner{top:42vw;font-size:2.0vw;line-height:4vw;padding:1.5vw 10px;}
	/*.bio .card{padding: 30px 20px 25px 20px;}*/
}

@media screen and (max-width:900px){
	#hero .banner{font-size:2.2vw;}
	#footmenu a[href='tel:7709459007']{display:none;}
	#footmenu .link:nth-last-child(2){margin-right:0;}
}

@media screen and (max-width:800px){
	#hero .banner{font-size:2.4vw;}
	.roofing .platinum{top:0;width:110px;}
	.button{font-size:16px;padding:15px 20px;}
	#footer{text-align:center;height:215px}	
	#footmenu{position:relative;right:0;top:57px;display:flex;justify-content:center;}
	#footbar{padding-bottom:70px;}
	#footbar div{padding:10px 30px;}
	#footsocial{position:relative;right:0;top:100px;}
	.bio{display:block;}
}


@media screen and (max-width:700px){
	#header{height:80px;}
	#fixr{height:80px;}
	.logo{width:80px;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{width:500px;}
}


@media screen and (max-width:500px){
	.logo.big{width:450px;}
	.pick{flex-wrap:wrap;top:100px;}
	#hero .banner{font-size:2.6vw;}
	.services h1:before{display:none;}
	.roofing .platinum{position:absolute;top:93px;right:20px;width:110px;}
	.painting .exclusive{top:130px;}
	.remodeling .certified{top:17px;right:15px;width:68px;}
	/*#footbar div{padding:10px 30px 2px 30px;}*/
}


@keyframes slide{from{right:-100px;opacity:0}to{right:0; opacity:1}}