/*
Theme Name: Nifty 2021 Child
Template: twentytwentyone
Author: Nifty Dev Team
Author URI: https://niftymarketing.com/
Description: A lightweight theme for use of our clients.
Version: 2.0
*/

/*Theme Variables*/
:root{
	/*site colors*/
	--color-1: #fff;
	--color-2: #E18127;
		--orange: #E18127;
	--color-3: #000;
		--black: #000;
	--color-4: #c16e20;
	--color-5: #3c3d3d;
	--lt-gray: #eeeeee;
	
	/*font sizes*/
	--fsize-xl: 55px;
	--fsize-lg: 40px;
	--fsize-md: 30px;
	--fsize-sm: 20px;
	--fsize-default: 16px; /*ADA requires at least 16px*/
	
	/*font families*/
	--heading-font: 'Lexend_Deca',sans-serif;
	--text-font: 'Source_Sans_Pro',sans-serif;
}
@media(max-width: 1000px){
	:root{
		/*font sizes*/
		--fsize-xl: 40px;
		--fsize-lg: 30px;
		--fsize-md: 20px;
		--fsize-sm: 18px;
	}
}
@media(max-width: 750px){
	:root{
		/*font sizes*/
		--fsize-xl: 30px;
		--fsize-lg: 25px;
		--fsize-md: 20px;
		--fsize-sm: 18px;
	}
}

/*Default Overall Styles*/
html, body{scroll-behavior: smooth; font-size: var(--fsize-default); font-variant-ligatures: none; overflow-anchor: none;}
body{margin:0; -webkit-font-smoothing: antialiased;}
*{box-sizing: border-box; -webkit-appearance: none;}
/* lazy loading flow fixes */
img{max-width: 100%; height: auto;}
img[src=""]{visibility: hidden;}
img[data-url]:before{content: '';display: block;padding-top: 56.25%;}
a{text-decoration: none; color: var(--color-1);}

/*Font Defaults*/
h1, h2, h3, h4, h5, h6{font-family: var(--heading-font); }
body, p, ul, ol, li{font-family: var(--text-font); line-height: 1.5em;}
h1{font-size:var(--fsize-xl); font-family:var(--heading-font); font-weight:500; line-height: normal; margin:0;}
h2{font-size:var(--fsize-lg); text-transform: uppercase; line-height: normal; font-weight:300; margin:0 0 5px; padding-bottom:5px;}
h2 span, h1 span{color:var(--color-2);}
h3{font-size:var(--fsize-md); font-weight:300;}
h4{font-size:var(--fsize-sm);}
h5{font-size:20px;}

/*horizontal-line-wrapper*/
.horizontal-line-wrapper{fill:var(--color-2); }

/*Layout*/
.section-padding{padding: 5% 0;}
.content-width{width: 1425px; max-width: 100%; padding:50px; margin: 0 auto;}
.flex{display: flex; flex-wrap: wrap;}

/* ADA header */
.masthead{background: rgba(0,0,0,.7); padding: 0px 15px; box-shadow: 0 0 6px rgba(0,0,0,.5);}
.masthead .skip-bar{position: absolute; display: block; width: 100%; text-align: center; height: 0; overflow: hidden; background: #2b2b2b; top: 0; left: 0; z-index: 10;}
.masthead .skip-bar:focus{height: auto; padding: 20px;}
.masthead .inner-masthead{justify-content: space-between; align-items: stretch;}
.masthead .logo-container{width: 130px; margin-left:25px;}
	.masthead .logo-container img{height:75px; width:auto; display: block;}
.masthead .menus{width: calc(100% - 160px); justify-content: flex-end; position: relative;}

.masthead .menu-main-container{width:calc(100% - 200px);}
.masthead .menus .button{background-color:var(--color-2); letter-spacing: 1px; padding:10px 15px; margin:0 25px; color:white; text-transform: uppercase; width:200px; text-align:center; font-size:14px;}
	.masthead .menus .button:hover{background-color:var(--color-1); color:var(--color-2); }
.masthead .menus .main-nav{width:calc(100% - 250px); display: flex;align-self:center; justify-content: flex-end;}
.masthead .estimate-call{width:240px; display: flex; align-self: stretch; justify-content: center; flex-direction: column; position: relative;}
.masthead .estimate-call .vertical-line-wrapper{position: absolute; top:0; left:0; max-height:100%; }
	/*text*/
	.masthead .estimate-call .text{text-transform: uppercase; font-weight:600; font-size:15px; position: relative; top:8px;}
	.masthead .estimate-call span{display: block; text-align: center;}
	/*phone*/
	.masthead .estimate-call .phone{font-size:36px; line-height: normal; color:var(--color-2);}
	.masthead .estimate-call .phone:hover{color:var(--color-1);}
.mobile-nav-input{display: none;}
.masthead #menu-main{list-style: none; padding: 0; font-weight:800; text-transform: uppercase; }
	.masthead #menu-main > li.menu-item-has-children:before{content:'▾'; position: absolute; right:-5px; bottom:5px; color:var(--color-2);}
	.masthead #menu-main li:hover > a{color:var(--color-2);}
#menu-main .sub-menu > li:focus-within > .sub-menu, #menu-main li{list-style-type: none; padding-bottom:5px;}

/*button - animations are ni animations.css */
.button-wrapper{position: relative;}
.button{background-color: var(--color-2); padding:20px 60px; letter-spacing: 3px; position: relative; right: 0px; z-index:10; text-transform: uppercase;}
.button span{font-weight:600;}
	/*overall SVG styles*/
	.button svg{display: none; position: absolute; bottom:0; fill:#000; max-height:100%;}
	.button .triangle-wrapper .cls-1{fill:var(--color-2);}
		.button .triangle-wrapper:nth-of-type(1) .cls-1{fill:transparent;}
	.button .triangle-wrapper .cls-2{fill:var(--color-3);}

@media (min-width: 1001px){
	.masthead {position: fixed; left: 0; width: 100%; z-index: 10000000; top: 0;}
	body.admin-bar .masthead {top: 32px;}
	.mobile-nav{display: none;}
	.masthead #menu-main{display: flex; margin: 5px 0 0 0; flex-wrap: wrap; justify-content: flex-end;}
	.masthead #menu-main > li{padding: 5px 7px; position: relative; margin-bottom: 0!important; font-weight:600; margin: 0 20px}
	.masthead #menu-main > li > .sub-menu{position: absolute; top: 100%; left: 0; background: rgba(0, 0, 0,.95); backdrop-filter: blur(5px); height: 0; overflow: hidden; z-index: 1000; list-style: none; box-shadow: 0 2px 7px rgba(0,0,0,.4);}
.masthead #menu-main > li:hover > .sub-menu, .masthead #menu-main > li > a:focus + .sub-menu, .masthead #menu-main > li:focus-within > .sub-menu{height: auto; padding: 15px 0 15px 15px; min-width: 225px; overflow: initial;}
.masthead #menu-main > li > .sub-menu > li{position: relative; padding-right: 15px; padding-bottom:5px;}
	.masthead #menu-main > li > .sub-menu > li:last-child{padding-bottom:0;}
.masthead #menu-main > li > .sub-menu .sub-menu{position: absolute; left: 99%; top: 0; background: rgba(37,37,37,.95); backdrop-filter: blur(5px); height: 0; width: 0; overflow: hidden; padding: 15px;}
.masthead #menu-main .sub-menu > li > .sub-menu{position: absolute; left: 99%; top: 0; background: rgba(37,37,37,.95); backdrop-filter: blur(5px); height: 0; width: 0; overflow: hidden; padding: 0;}
.masthead #menu-main .sub-menu > li:hover > .sub-menu, .masthead #menu-main .sub-menu > li > a:focus + .sub-menu, .masthead #menu-main .sub-menu > li:focus-within > .sub-menu{padding: 15px; width: initial; height: initial; min-width: 225px; list-style: none; border:none;}
}
@media all and (max-width:1425px){
	.content-width{max-width:100%;}
}
@media(max-width: 1350px){
	.masthead .menus .button{width:150px;padding:10px;}
	.masthead .menus .main-nav{width:calc(100% - 185px);}
	.masthead .estimate-call{width:185px;}
	.masthead .estimate-call .phone{font-size:25px;}
	.masthead .estimate-call .text{font-size:13px;}
}
@media(max-width: 1250px){
	.masthead .menus{width:calc(100% - 115px);}
	.masthead .menus .main-nav{width:calc(100% - 165px);}
	.masthead .menu-main-container{width:calc(100% - 50px);}
	.masthead .menus .button{font-size:12px; padding:10px;}
	.masthead #menu-main > li{font-size:12px;}
	.masthead .logo-container{margin:0; width:110px;}
	.masthead .estimate-call{width:160px;}
	.masthead .estimate-call .vertical-line-wrapper{margin-left:-10px;}
}
@media(max-width: 1100px){
	.masthead #menu-main{margin:0;}
	.masthead .menus .main-nav{width:calc(100% - 125px); display: flex; align-self: center; justify-content: center; flex-wrap: wrap;}
	.masthead .estimate-call{width:125px; height:74px;}
	.masthead .estimate-call .text{display: none;}
	.masthead .estimate-call .phone{font-size:18px;}
	.masthead .menus .button{background-color: transparent; padding:0; font-weight:900; color:var(--color-2); margin-left:5px; display: flex; align-self: center; justify-content: center; flex-wrap:wrap; position: absolute; top:5px; right:-40px;}
		.masthead .menus .button:hover{background-color: transparent; color:white;}
}
@media(max-width: 1000px){
	.masthead{position: relative; background-color: black; padding:0;}
	.masthead .logo-container img{margin-left:25px;}
	.masthead .logo-container{width: 50%;}
	.masthead .menus{width: 100%; position: absolute;}
	.masthead .estimate-call{width:150px;}
	.mobile-nav{font-size: 22px; transform: scaleX(1.75); outline-color: var(--color-3);color: var(--color-1); margin-right:25px; margin-top:28px;}
	.main-nav{position: absolute; top: 100%; width: 100%; left: 0; background: black; border-top: none; box-shadow: 0 5px 10px rgba(0,0,0,.3); padding: 0 25px; height: 0; overflow: hidden; transition: padding .25s;}
	.menu-main-container{width:100%;}
	.admin-bar #mobile-nav-input:checked + * + .main-nav{top:74px;}
	.masthead .menus .button{margin:0 0 15px 0; display: block; width:200px; font-size:15px; padding-bottom:14px; position: relative; text-align:center; background-color: rgba(255,255,255,1); padding:5px;  align-items: flex-end; justify-content: flex-end; overflow: hidden; right:0; left:auto;} 
	#mobile-nav-input:checked + * + .main-nav{height: auto; padding: 10px 25px; top:80px; z-index:10000; width:100%;}
	#menu-main .sub-menu{display: none;}
	.masthead #menu-main{padding-top:20px;}
	#menu-main li a{outline-color: var(--color-1);}
	#menu-main > li:hover > .sub-menu,
	#menu-main > li:focus-within > .sub-menu,
	#menu-main > li:hover > .sub-menu > li:hover > .sub-menu,
	#menu-main > li:focus-within > .sub-menu > li:focus-within > .sub-menu{display: block;}
	.masthead #menu-main > li{
		padding-bottom:10px;
		position: relative;
		font-size:15px;
		margin-bottom: 0!important;
		font-weight:600;}
	.masthead #menu-main>li.menu-item-has-children:before{
		content: "▾";
		position: absolute;
		left: 100%;
		top: 1px;
		color: var(--color-2);

	}
	.content-width{padding:25px;}
}
@media(max-width: 750px){
	.masthead{padding: 0px;}
}
@media all and (max-width:690px){
	.button{padding:20px;}
}
@media(max-width: 480px){
	.masthead .estimate-call{width:125px;}
}