/*----------------Core---------------------------*/
body{
	margin: 0px;
	background: #1B1464;
	font: 18px 'Poppins', Arial, sans-serif;
	line-height: 1.5em;
	color: #fff;
}
img, input[type=image] { border: 0px; vertical-align: middle; }
a:link, a:visited, a:active { color: #b7352b; }
a:focus {outline: 0; }
a:hover { color: #b7352b; text-decoration: none; opacity: 0.8; }
form { margin: 0px; padding: 0px; }

.container.withtext {
	max-width: 920px;
}

h1,h2,h3,h4,h5,h6 { font-family: 'Poppins', Arial, sans-serif; font-weight: 800; }

#footer { font-size: 12px; letter-spacing: 1px; color: #fff; padding: 20px 0; }


/*------------ Utilities ----------------------*/
.flex-row { display: flex; align-items: center; flex-wrap: nowrap; flex-direction: row; justify-content: center; }
.clear{ clear: both; height: 0px; margin: 0px; overflow: hidden; }

.form-group { border-radius: 4px; position: relative; text-align: left; border: 1px solid #000; box-shadow: 2px 2px 0 #000; background: rgba(255,255,255,0.1);padding-right: 5px; }
	.form-control { border-radius: 0; box-shadow:unset !important; font-size: 16px; padding: 27px 15px; border: 0px solid #ddd; border-radius: 0px; box-shadow: unset; background: transparent; color: #fff;}
	.form-control:focus { box-shadow: unset !important; border: 0; -webkit-box-shadow: unset;}
	.form-control::placeholder { color: #eee; }
	.form-control.active { padding: 36px 15px 18px;}
	select.form-control { padding: 0 15px; height: 39px; margin-top: 15px; }
	label { display:block; position: absolute; top: 10px; left:15px; font-size: 12px; text-shadow: 1px 1px 0 #000; font-weight: bold; line-height: 1em; text-transform: uppercase; color: #fff; }
	.checkbox, .radio { margin-top: 0; }
		.checkbox label, .radio label { position: static; color: #000; font-size: 14px; line-height: 1.5em; display: inline-block;}
	.form-control:-webkit-autofill,.form-control:-webkit-autofill:hover,.form-control:-webkit-autofill:focus,.form-control:-webkit-autofill:active {transition: color 5000s ease-in-out 0s, background-color 5000s ease-in-out 0s;}
	input:-internal-autofill-selected { background: rgba(255,255,255,0.1) !important; color: #fff !important; }

.small-padding { margin-left: -5px; margin-right: -5px; }
.small-padding .col-sm-1, .small-padding .col-sm-2, .small-padding .col-sm-3, .small-padding .col-sm-4, .small-padding .col-sm-5, .small-padding .col-sm-6, .small-padding .col-sm-7, .small-padding .col-sm-8, .small-padding .col-sm-9, .small-padding .col-sm-10, .small-padding .col-sm-11, .small-padding .col-sm-12,
.small-padding .col-xs-1, .small-padding .col-xs-2, .small-padding .col-xs-3, .small-padding .col-xs-4, .small-padding .col-xs-5, .small-padding .col-xs-6, .small-padding .col-xs-7, .small-padding .col-xs-8, .small-padding .col-xs-9, .small-padding .col-xs-10, .small-padding .col-xs-11, .small-padding .col-xs-12 { padding: 0 5px; }

.medium-padding { margin-left: -10px; margin-right: -10px; }
.medium-padding .col-sm-1, .medium-padding .col-sm-2, .medium-padding .col-sm-3, .medium-padding .col-sm-4, .medium-padding .col-sm-5, .medium-padding .col-sm-6, .medium-padding .col-sm-7, .medium-padding .col-sm-8, .medium-padding .col-sm-9, .medium-padding .col-sm-10, .medium-padding .col-sm-11, .medium-padding .col-sm-12,
.medium-padding .col-xs-1, .medium-padding .col-xs-2, .medium-padding .col-xs-3, .medium-padding .col-xs-4, .medium-padding .col-xs-5, .medium-padding .col-xs-6, .medium-padding .col-xs-7, .medium-padding .col-xs-8, .medium-padding .col-xs-9, .medium-padding .col-xs-10, .medium-padding .col-xs-11, .medium-padding .col-xs-12 { padding: 0 10px; }

.btn-primary, a.btn-primary { text-transform: uppercase; background-color: transparent; font-weight: bold; border: 0; padding: 10px 45px; color: #1B1464; border: 2px solid #1B1464; border-radius: 4px; }
	.btn-primary:hover, .btn-primary:active .btn-primary:focus, a.btn-primary:hover, a.btn-primary:active a.btn-primary:focus  { border-color: #1B1464; background: #eee; color: #1B1464; }

.btn-white, a.btn-white { text-transform: uppercase; font-weight: bold; background-color: transparent; border: 0; padding: 10px 45px; border: 2px solid #fff; color: #fff; border-radius: 4px; }
	.btn-white:hover, .btn-white:active .btn-white:focus, a.btn-white:hover, a.btn-white:active a.btn-white:focus  { background: rgba(255,255,255,0.1); color: #fff; }


.btn-black, a.btn-black { text-transform: uppercase; font-weight: bold; background-color: rgba(255,255,255,0.1); border: 0; margin-top: 15px; font-size: 18px; padding: 12px 45px; border: 2px solid #000; box-shadow: 2px 2px 0 #000; text-shadow: 2px 2px 0 #000; color: #fff; border-radius: 4px; }
	.btn-black:hover, .btn-black:active .btn-black:focus, a.btn-black:hover, a.btn-black:active a.btn-black:focus  { background: rgba(255,255,255,0.1); color: #fff; }



.img-frame { border-radius: 15px; overflow: hidden; }
.form-check label { font-weight: normal; }
	
/*------------ Header & Menu ----------------------*/
#top-border { padding: 8px 0; font-size: 14px; line-height: 1em; text-transform: uppercase; background: #222; color: #fff; position: relative; z-index: 999; }
	#top-border a { color: #fff; }
	#top-border .links { float: right; padding-left: 15px; border-left: 1px solid #555; margin: 0.25em 0 0.25em 15px; }
	.social-circle span { font-size: 14px; opacity: 0.8; line-height: 1.5em; margin-left: 3px; border-radius: 2px; display: inline-block; background: #fff; color: #222; padding: 0px; padding: 0 0.1em; height: 1.5em; text-align: center; }
		.social-circle span:hover { opacity: 1; }
#header { background: linear-gradient(rgba(0,0,0,1), rgba(0,0,0,0)); padding: 20px 0; position: absolute; top: 0; left: 0; width: 100%;  z-index: 999;}
	#header .flex-row { align-items: center; justify-content: space-between;  }
	#header .logo { flex-basis: 25%;   }
	#header .logo a { display: flex; align-items: center; justify-content: flex-start; color: #fff; font-size: 18px; font-weight: bold;   }
	#header .logo .img-responsive { max-height: 50px; margin-right: 12px;   }
	#header .desktop-menu { flex-grow: 1;  }
	#header .desktop-menu ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; justify-content: flex-end; }
	#header .desktop-menu li { display: block;  }
	#header .desktop-menu li a { display: block; color: #fff; font-size: 18px; padding: 5px 18px; font-weight: normal; text-decoration: none;  }

#banner { background: #000; max-width: 1920px; margin: 0 auto; position: relative; z-index: 10; box-shadow: 0 0 8px rgba(0,0,0,0.3); }



#copyright { padding: 20px 0;text-align: center; color: #fff; letter-spacing: 1px; font-size: 11px; line-height: 1.2em; text-transform: uppercase;  }

/*------------ CONTENT ----------------------*/
.content { padding: 45px 0; background: #fff; color: #1B1464; border-bottom: 6px solid #ddd; }
	.content h1 { font-size: 36px; margin: 0px 0px 15px;  }
	.content h2 { font-size: 36px; margin: 0px 0px 15px;  }
.content .flex-row { display: flex; align-items: center; flex-wrap: nowrap; flex-direction: row; justify-content: center; }
	.content .flex-row .graphic { flex-basis: 40%; min-width: 40%; padding-right: 30px; }
	.content .flex-row .graphic.right { padding-left: 30px; }
		.content .flex-row .graphic .img-responsive { position: relative; margin: -50px auto; }

.waves { overflow: hidden; position: relative; height: 8em; z-index: 11; }
	.waves svg { display: block; width: 100%; position: absolute; bottom: 0; left: 0; }
/*------------ HOMEPAGE ----------------------*/
#home-banner { padding: 120px 0 0px; position: relative; overflow: hidden; background: #0b0c10 url('../images/banner-bg.jpg') 50% 50% no-repeat; background-size: cover; min-height: 475px; }
	#microphone { position: absolute; bottom: 1em; left: 50%; width: 50%;  }
		#microphone img { margin: 0 auto; }
#headline, #subheadline { display: block; font-weight: 800; font-size: 76px; text-shadow: 1px 4px 0 #000, -2px -2px 18px #d99bc0, 0px 0px 25px #0b54b0; line-height: 1em; text-align: left; text-transform: uppercase; }
.banner-message { position: relative; z-index: 10; font-size: 1.7em; line-height: 1.3em; text-shadow: 1px 1px 0 rgba(0,0,0,0.7); margin: 45px 0; }
#home-banner .btn { background-color: #CC0000; box-shadow: 2px 2px 0 #000, 0 0 25px #d99bc0; text-shadow: 1px 1px 0 rgba(0,0,0,0.7); }

	#home-banner .calltoaction { display: flex; align-items: center; justify-content: flex-start;  }
	#home-banner .calltoaction .btn { margin: 8px 20px 8px 0;  }
	#home-banner .calltoaction a { color: #fff; text-shadow: 1px 1px 0 #000;  }

#expertise h2, #brands h2, #application h2 { display: block; font-size: 38px; text-transform: uppercase; width: fit-content; margin: 0 auto 15px; padding-bottom: 4px; border-bottom: 6px solid #ff0000; }

#brands { background: #eee linear-gradient(#eee, #ddd); color: #222; padding: 45px 0 0; text-align: center; }
	#brands .flex-row { align-items: stretch; justify-content: center; flex-wrap: wrap; }
		#brands .col { flex-basis: calc(20% - 30px); padding-top: 15%; margin: 8px 30px; filter: grayscale(100%); opacity: 0.4; background-size: contain; background-position: 50% 50%; background-repeat: no-repeat; }
			#brands .col:hover { filter: grayscale(0%); opacity: 1;  }


#expertise { background: #fff; color: #222; padding: 45px 0 0; text-align: center; }
	#expertise h2 { margin: 0 auto 80px;  }
	#expertise h3 { display: block; font-size: 22px; text-transform: uppercase; width: fit-content; margin: 0 auto 8px; padding-bottom: 8px; border-bottom: 2px solid #ddd; }
	#expertise .flex-row { align-items: center; justify-content: space-between; margin: 30px auto;  }
		#expertise .call-out { flex-basis: 50%;  }
		#expertise .graphic { flex-grow: 1;  }
		#expertise .graphic .img-responsive { max-width: 70%;  margin: 15px auto;  }


#application { padding: 45px 0 90px; text-align: center;  }
	#application .flex-row { align-items: flex-start; justify-content: space-between; }
		#application .contact-form { max-width: 600px; margin: 30px auto 0;  }


@media all AND (max-width: 767px) {
	.hide-mobile { display: none;  }
	.break-mobile { display: block; }

	.flex-row { flex-wrap: wrap !important; }


	#header { padding: 15px 0;  }
	#logo {}
	#home-banner { padding: 100px 0 0; background-position: 50% 100%; min-height: auto; }
		#home-banner .btn { display: block; text-align: center;  }
	.banner-message { margin: 15px 0; font-size: 18px;  }
	#microphone { display: none; }

	.waves { height: 4em; }

	#expertise h2, #brands h2, #application h2 { font-size: 24px;  }
	#brands .col { flex-basis: calc(100% / 3 - 30px); margin: 10px 15px;   }

	#expertise .call-out { flex-basis: 100%; order: 4; }
	#expertise .graphic { flex-basis: 100%; }
}
