/* --------------- IMPORT FONTS --------------- */
@font-face{
  font-family: OVO;
  src: url('../fonts/Ovo-Regular.ttf');
  font-weight: normal;
  font-style: normal;
}

@font-face{
  font-family: CHUNK;
  src: url('../fonts/Chunkfive.otf');
  font-weight: normal;
  font-style: normal;
}

*, body {
	font-family: 'Bitter', serif;
	margin: 0;
}

*:focus {
	outline: 0;
	outline: none;
}

a.anchor {
	display: block;
	position: relative;
	top: -200px;
	visibility: hidden;
}

/* Scroll Top Assist Button */
#upScroll {
	display: none;
	position: fixed;
	bottom: 35px;
	right: 30px;
	z-index: 1313;
	border: none;
	outline: none;
	background-color: rgba(236,29,54,1);
	color: white;
	cursor: pointer;
	padding: 15px;
	border-radius: 10px;
}

#upScroll:hover {
	background-color: rgba(33,34,34,1);
}

/* ---------------- */
/* -----  Nav  ---- */
/* ---------------- */
nav {
	background-color:  #212222;
	width: 100%;
	padding: 15px 0px 5px 0px;
	position: fixed;
  	top: 0;
	z-index: 1;
	transition: .6s ease;
}

a {
	text-decoration: none;
}

#hamToggle {
	display: none;
	position: relative;
	z-index: 1;
}

#hamToggle input {
	display: block;
	width: 40px;
	height: 32px;
	position: absolute;
	cursor: pointer;
	opacity: 0;
	z-index: 2;
	
	-webkit-touch-callout: none;
}

/* ----- Hamburger ---- */
#hamToggle span {
	display: block;
	width: 33px;
	height: 4px;
	margin-bottom: 5px;
	position: relative;
	
	background: white;
	border-radius: 3px;
	
	z-index: 1;
	
	transform-origin: 4px 0px;
	
	transition: transform 0.5s cubic-bezier(0.77,0.2,0.05,1.0), background 0.5s cubic-bezier(0.77,0.2,0.05,1.0), opacity 0.55s ease;
}

#hamToggle span:first-child {
	transform-origin: 0% 0%;
}

#hamToggle span:nth-last-child(2) {
	transform-origin: 0% 100%;
}

/* Create Cross */
#hamToggle input:checked ~ span {
	transform: rotate(45deg) translate(-2px, -1px);
}

#hamToggle input:checked ~ span:nth-last-child(2) {
	transform: rotate(-45deg) translate(0, -1px);
}

/* Hide Middle */
#hamToggle input:checked ~ span:nth-last-child(3) {
	opacity: 0;
	transform: rotate(0deg) scale(0.2, 0.2);
}

#menu {
	display: none;
	z-index: 3;
	padding-top: 15px;
	text-align: center;
	list-style-type: none;

	transition: all .7s ease;
	
}

#menu li {
	transition: all .7s ease;
}

#navMain {
	height: 49px;
	margin-top: 20px;
}

.phone {
	color: white;
}

.phone a {
	text-decoration: none;
	color: white;
	padding-right: 5px;
}

.phone:hover, .phone a:hover {
	color: rgba(236,29,54,1);
}

nav ul {
	list-style: none;
}

nav ul li {
	margin: 0 4px;
	padding: 0 5px;
	font-size: 1.2rem;
}

.active {
	border-bottom: 3px solid rgba(236,29,54,1);
}

nav ul li a {
  	text-decoration:none;
	color: white;
	text-transform: uppercase;
}

nav ul li a:hover {
	border-bottom: 3px solid rgba(236,29,54,1);
}

/* ------ Responsive Elements ------*/
/* everythin smaller than 768 */
@media only screen and (max-width: 768px) {
	#logo {
		display: flex;
		justify-content: space-around;
		width: 100%;
		align-items: center;
	}
	#navMain {
		display: none;
	}
	
	#hamToggle {
		display: block;
	}
	
	#phoneTop {
		display: none;
	}
}

/* ---------------- */
header {
	background-image: url('../images/su_img/westView_done_one.JPG');
	background-color: #cccccc;
	height: 600px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.contact-button a {
	text-decoration: none;
	color: white;
}

.contact-button:hover, .contact-button a:hover {
	color: #212222;
}

/* ---------------- */
section#about {
	background-color: white;
	height: auto;
	padding: 40px;
}

/* ------ Responsive Elements ------*/
/* everythin smaller than 768 */
@media only screen and (max-width: 768px) {
	#holder {
		display: none;
	}

}
/* ---------------- */
section#hero2 {
	background-image: url('../images/sasha.png');
	background-color: #cccccc;
	height: 500px;
	background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.hero {
	height: 400px;
	margin: 0;
	margin-top: 55px;
}

.hero-shade {
	background: rgba(0, 0, 0, 0.5);
	padding: 15px;
	color: white;
	text-transform: uppercase;
	font-size: 2.5rem;
}
/* ---------------- */

.mb15 {
	margin-bottom: 15px;
}

.mtb15 {
	margin: 15 0 15 0;
}

.ma {
	margin: 15px;
}

.gal {
	position: relative;
}

.gal .middle a {
	text-decoration: none;
}

.gal img {
	opacity: 1;
}

.gal:hover img {
	opacity: 0.3;
}

.gal:hover .middle {
	opacity: 1;
}

.middle {
	z-index: 100;
	opacity: 0;
	transition: .5s ease;
	position: absolute;
	top: 35%;
    left: 15%;
    width: 75%;
	color: black;
}

section#gallery {
	background-color: white;
	height: auto;
}

h4 {
	text-transform: uppercase;
	font-size: 2.5rem;
}

h3 {
	text-transform: uppercase;
	font-size: 1.0rem;
}

.gallery {
	justify-content: space-between;
}

.gallery-img:hover, .gallery-img-last:hover, .gallery-mobile:hover {
	opacity: .4;
}

.gallery-img {
	padding-right: 20px;
	padding-bottom: 20px;
}

.gallery-mobile {
	padding: 10px;
}

.gallery-img-last {
	padding-right: 0px;
	padding-bottom: 20px;
}

.sml {
	display: none;
}

/* ------ Responsive Elements ------*/
@media (max-width: 995px) {
	.sml {
		display: block;
	}
	
	.lg {
		display: none;
	}
}
/* everythin smaller than 768 */
@media (max-width: 768px) {
	
	.middle {
		display: none;
	}
	
	h3 {
		font-size: .75rem;
	}
	
	.hero-shade {
		font-size: 1.0rem;
	}
	
	.contact-button {
		padding: 10px 50px;
		font-size: 0.6rem;
		border-radius: 6px;
	}
	

	
	h4 {
		font-size: 1.5rem;
	}
}

/* ---------------- */
section#hero3 {
	background-image: url('../images/patrick.png');
	background-color: #cccccc;
	height: 500px;
	background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
/* ---------------- */
section#testomonials {
	background-color: white;
}

/* ---- Slider ---- */

#slider, #slider ul {
	height: 200px;
}

#slider{
	margin: auto;
	overflow: hidden;
	padding: 20px;
	margin-top: 50px;
	border-radius: 10px;
	position: relative;
	width: 600px;
}

#slider li {
	float: left;
	position: relative;
	width: 600px;
	display: inline-block;
	height: 200px;
}

#slider ul {
	list-style: none;
	position: absolute;
	left: 0px;
	top: 0px;
	width: 9000px;
	transition: left .3s linear;
	margin-left: -25px;
	color: #666;
}

.slider-container {
	margin: 0 auto;
	padding: 0;
	width: 550px;
	min-height: 180px;
	border-bottom: 1px solid #ccc;
}

.slider-container h4{
 	color: #0A7FAD;
	text-shadow: -1px 0px 0px rgba(0, 0, 0, 0.50);
}

.slider-container  p {
	margin: 10px 25px;
	font-weight: bold;
	line-height: 150%;
	text-align: justify;
}

#slider ul {
	-webkit-animation: slide-animation 25s infinite;
}

/* Paused on mouse over */

#slider ul:hover {
	-moz-animation-play-state: paused;
	-webkit-animation-play-state: paused;
}
/* ---------------- */
section#contact {
	background-image: url('../images/su_utah.png');
	background-color: #cccccc;
	height: 475px;
    background-position: center;
    background-size: cover;
}

#contact #contact-form {
	margin: 50px 0 0 0;
	background-color: #212222;
	color: white;
	width: 100%;
}

#contact #contact-form h1 {
	padding-top: 20px;
	color: white;
}

#contact-left {
	width: 50%;
	padding: 15px;
}

#contact-right {
	width: 50%;
	padding: 15px;
}

.contact-label {
	color: #ffffff;
	font-size: 0.875rem;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.contact-input {
	background-color: rgba(0, 0, 0, 0);
	border: 1px solid #434140;
	color: #ffffff;
	border-radius: 8px;
	font-size: 1.0rem;
	height: 40px;
	width: 100%;
	margin-bottom: 25px;
}

.contact-input:focus {
    outline: none !important;
    border:1px solid rgba(236,29,54,1);
    box-shadow: 0 0 10px rgba(236,29,54,1);
}

textarea.contact-input {
	background-color: #212222; 
}

#name_alert {
	color: #730707;
	font-size: 0.8rem;
	text-transform: uppercase;
	margin-top: 5px;
}

#phone_alert {
	color: #730707;
	font-size: 0.8rem;
	text-transform: uppercase;
	margin-top: 5px;
}

#email_alert {
	color: #730707;
	font-size: 0.8rem;
	text-transform: uppercase;
	margin-top: 5px;
}

#submit_alert {
	color: #730707;
	font-size: 0.8rem;
	text-transform: uppercase;
	margin-top: 5px;
	margin-bottom: 5px;
	text-align: center;
}

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

.contact-button {
	background-color: rgba(236,29,54,1);
	color: #ffffff;
	border: none;
	padding: 20px 100px;
	font-size: 0.875rem;
	border-radius: 8px;
	margin: 0 0 15px 0;
	text-decoration: none;
}

.contact-button:hover {
	color: rgba(33,34,34,1);
}
/* ---------------- */
footer {
	background-color:  #212222;
	width: 100%;
	height: 50px;
	bottom:0;
}

footer  p {
	color: white;
	font-size: 0.75rem;
	text-transform: uppercase;
}
