/* RESET */

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, font, 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{background: transparent; border: 0; margin: 0; padding: 0; list-style: none;} img{max-width: 100%; image-rendering: -webkit-optimize-contrast;}
.cf{zoom: 1;} .cf:before, .cf:after{content: ""; display: table;} .cf:after{clear: both;} .clear{clear: both;} *, *:before, *:after{box-sizing: border-box;}

html, body{font-family: 'Karla', sans-serif; line-height: 1.5; height: 100%; width: 100%;}
::-moz-selection{background: #C72E30; color: #fff; text-shadow: none} ::selection{background: #C72E30; color: #fff; text-shadow: none}

.main{padding: 100px 0;}
.wrap{max-width: 1240px; margin: 0 auto; padding: 0 20px;}

.flex-row{display: flex; flex-wrap: wrap;}
.flex-col{flex: 1; padding-right: 50px;}
.flex-col:last-child{padding-right: 0;}

.col-4{flex: none; width: 33.3333%;}
.col-5{flex: none; width: 41.6666%;}
.col-7{flex: none; width: 58.3333%;}
.col-8{flex: none; width: 66.6666%;}

/* TYPOGRAPHY */

h1, h2, h3, h4, h5, h6{font-weight: 700; line-height: 1;}
a{text-decoration: none; color: inherit; cursor: pointer; transition: all .2s ease-in-out;} a:hover{color: inherit;}

.red{color: #C72E30;}
.center{text-align: center;}
.underline{font-weight: 700; text-decoration: underline; color: #C72E30;}
.underline:hover{text-decoration: none;}

.bullet-list{margin-bottom: 25px;}
.bullet-list li{margin-left: 15px; list-style: disc;}

.block-btn{display: inline-flex; align-items: center; justify-content: center; background: #000; padding: 10px 35px; font-weight: 700; color: #fff; border-radius: 10px;}
.block-btn:hover{background: #333; color: #fff;}

/* HEADER */

.header{display: flex; flex-wrap: wrap; box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);}
.header .logo{display: flex; align-items: center; justify-content: center; position: relative; right: -21px; background: #fff; width: 200px; transform: skew(-21deg); z-index: 9;}
.header .logo img{display: block; position: relative; left: -21px; transform: skew(21deg);}
.header .header-right{flex: 1;}
.header .header-top{background: #eee; padding: 10px 50px;}
.header .header-top ul{display: flex;}
.header .header-top ul li a{display: flex; align-items: center; padding: 0 15px; font-weight: 700;}
.header .header-top ul li a i{color: #C72E30;}
.header .header-top ul li a span{margin-left: 5px;}
.header .header-top ul li a:hover{opacity: .75;}
.header .header-top .email-link{margin-left: auto;}
.header .header-bottom{background: #000; padding: 0 25px;}

/* NAVIGATION */

nav.primary{display: inline-block; position: relative; width: 100%; z-index: 999;}
nav.primary ul{display: flex; width: 100%; margin: 0; padding: 0;}
nav.primary ul li{display: inline-block; flex: 1; position: relative; height: 100%; transition: 0.3s;}
nav.primary ul li i{margin-left: 10px;}
nav.primary ul li a{display: block; padding: 12px 20px; font-size: 16px; font-weight: 700; text-transform: uppercase; text-align: center; color: #fff; transition: 0.2s ease-in;}
nav.primary ul li:hover > a{background: #333;}

/* BODY */

.hero{background: url(/siteart/hero.jpg) bottom center no-repeat; background-size: cover; padding: 200px 0 350px; text-align: center;}
.hero .wrap{max-width: 900px;}
.hero h1{font-size: 45px; font-weight: 800; text-transform: uppercase;}
.hero h1 span{color: #C72E30;}
.hero p{margin: 15px 0; font-size: 24px; font-weight: 500;}

.hero-icons{margin-top: -200px;}
.hero-icons .hero-icon{display: block; margin: auto; max-width: 300px; padding: 20px; text-align: center;}
.hero-icons .hero-icon p a{text-decoration: underline;}
.hero-icons .hero-icon p a:hover{text-decoration: none;}
.hero-icons .hero-icon h3{margin: 15px 0 5px; font-weight: 800; text-transform: uppercase;}
.hero-icons .hero-icon i{display: flex; align-items: center; justify-content: center; background: #C72E30; width: 80px; height: 80px; margin: auto; font-size: 32px; color: #fff; border-radius: 100px;}

/* SUB-PAGES */

.banner{background: url(/siteart/banner.jpg) top center no-repeat; background-size: cover; padding: 50px 0; text-align: center; box-shadow: inset 0px -5px 15px 0px rgba(0, 0, 0, 0.1);}
.banner h1{font-size: 45px; font-weight: 800; text-transform: uppercase;}

/* FORM */

.form{padding: 20px; box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);}
.form input[type="text"], .form input[type="email"], .form select, .form textarea{background: #fff; width: 100%; padding: 12px; font-family: 'Karla', sans-serif; border: 1px #ddd solid; border-radius: 5px;}
.form textarea{height: 120px;}
.form input[type="checkbox"], .form input[type="radio"]{position: relative; top: 2px; margin: 5px 10px 5px 0;}
.form input[type="submit"]{display: block; width: 100%; max-width: 250px; background: #C72E30; margin: 5px auto; padding: 15px; font-family: 'Karla', sans-serif; font-size: 16px; font-weight: 700; text-transform: uppercase; color: #fff; border-radius: 5px; border: none; transition: all .2s ease-in-out; cursor: pointer;}
.form input[type="submit"]:hover{background: #B62628;}

.form .form-row{display:block; margin-bottom: 15px;}
.form .form-row label span{padding-left: 5px; color: red;}

.CaptchaPanel{margin: 0 !important; padding: 0 !important; line-height: normal !important;}
.CaptchaAnswerPanel input{width: 250px; max-width: 100%; padding: 5px; margin: 5px 0;}
.CaptchaMessagePanel{padding: 0 !important; margin: 0 !important; font-weight: normal !important; font-size: 12px; line-height: 14px;}
.CaptchaAnswerPanel{margin: 0; padding: 2px 0px 2px 0px !important;}
.CaptchaWhatsThisPanel{line-height: 0; margin: 0; padding: 8px 0 8px 0 !important;}
.CaptchaWhatsThisPanel a{font-size: 12px; color: #000;} .CaptchaWhatsThisPanel a:hover{text-decoration: none;}

/* FOOTER */

.top-footer{display: flex; flex-wrap: wrap; border-radius: 20px 20px 0 0; box-shadow: 0px -5px 15px 0px rgba(0, 0, 0, 0.1); overflow: hidden;}
.top-footer .map-details{display: flex; align-items: center; justify-content: center; background: #C72E30; width: 25%; padding: 50px; text-align: center; color: #fff;}
.top-footer .map-details a:hover{opacity: .75;}
.top-footer .map-frame{width: 75%;}
.top-footer .map-frame iframe{display: block; width: 100%;}

.hours-table{width: 100%; max-width: 200px;}
.hours-table .hours-row{display: flex;}
.hours-table .hours-row div:last-child{margin-left: auto;}

.footer{background: #000; padding: 50px 0; color: #fff;}
.footer strong{display: block; margin-bottom: 15px; font-weight: 700; text-transform: uppercase;}
.footer a:hover{opacity: .75;}
.footer .block-btn{display: flex; background: #C72E30;}
.footer .block-btn:hover{background: #B62628; opacity: 1;}

/* RESPONSIVE */

#menu-button{display: none; position: relative; width: 100%; font-size: 18px; font-weight: 700; z-index: 1000;}
#menu-button a{display: block; padding: 12px 20px; text-align: center; color: #fff;}
#menu-button a:hover{background: #333;}

nav.mobile{display: none; position: fixed; top: 0; left: -250px; width: 250px; height: 100%; background: #000; color: #fff; z-index: 999999; overflow: auto; box-shadow: 5px 0px 10px 0px rgba(0, 0, 0, 0.1);}
nav.mobile .mobile-top{display: flex; align-items: center; justify-content: space-between; position: relative; padding: 10px 15px; border-bottom: 4px #C72E30 solid;}
nav.mobile .mobile-title{font-size: 14px; font-weight: 700; text-transform: uppercase;}
nav.mobile .menu-toggle{font-family: Arial, sans-serif; font-size: 18px; font-weight: 900; line-height: 1; color: #fff; padding: 5px;}
nav.mobile .menu-toggle:hover{opacity: .5;}
nav.mobile .nav-footer{margin-top: 20px; font-size: 12px; text-align: center; opacity: .5;}

nav.mobile ul{list-style: none; font-weight: 400; margin: 0; padding: 0;}
nav.mobile ul li{position: relative; border-bottom: 1px solid #444;}
nav.mobile ul li i{position: absolute; right: 15px;}
nav.mobile ul li a.active-mobile i{transform: rotate(180deg);}
nav.mobile ul li a{display: flex; align-items: center; position: relative; font-size: 12px; padding: 15px; font-weight: 700; text-transform: uppercase; color: #fff;}
nav.mobile ul li a:hover{background: #333;}

@media screen and (max-width: 1100px){
	nav.primary ul li a{padding: 12px 15px; font-size: 14px;}
}
@media screen and (max-width: 980px){
	nav.primary{display: none;}
	nav.mobile, #menu-button{display: block;}

	.header .header-top ul li a{padding: 0 10px; font-size: 14px;}

	.top-footer .map-details{width: 100%; padding: 30px;}
	.top-footer .map-frame{width: 100%;}
}
@media screen and (max-width: 768px){
	.header .logo{width: 100%; right: 0; padding: 65px 20px 20px; transform: none;}
	.header .logo img{transform: none; left: 0;}
	.header .header-right{flex: none; width: 100%;}
	.header .header-top{position: absolute; top: 0; left: 0; width: 100%; padding: 10px; z-index: 9;}
	.header .header-top ul{justify-content: space-between;}
	.header .header-top .email-link{margin-left: 0;}
	.header .header-bottom{padding: 0;}

	.main{padding: 50px 0;}
	.flex-col{flex: none; width: 100%; margin-bottom: 15px; padding: 0;}
	.flex-col:last-child{margin-bottom: 0;}

	.hero{padding: 75px 0 150px;}
	.hero h1{font-size: 36px;}
	.hero p{font-size: 20px;}
	.hero-icons{margin-top: -100px;}
	.hero-icons .hero-icon{max-width: 100%; padding: 10px 0;}
	
	.banner{padding: 35px 0;}
	.banner h1{font-size: 36px;}

	.footer{text-align: center;}
	.footer strong{margin-bottom: 5px;}
	.hours-table{margin: 0 auto 15px;}
}
@media screen and (max-width: 480px){
	.header .header-top ul{justify-content: center;}
	.header .header-top ul li a{padding: 5px 15px; font-size: 18px;}
	.header .header-top ul li a span{display: none;}

	.block-btn{display: flex;}

	.banner{padding: 30px 0;}
	.banner h1{font-size: 28px;}
}