@charset "utf-8";
/* Mighty Clean | Desktop Stylesheet */
.group:after {
	display: block;
	content: "";
	clear: both;
}
.flex-fifth {
	width: 20%;
}
.flex-fourth, .service-bullets div {
	width: 25%;
}
.flex-third {
	width: 33.33%;
}
.flex-third.buffer {
	width: 31%;
}
.flex-half {
	width: 50%;
}
.flex-two-thirds {
	width: 66.66%;
}
.flex-three-fourths {
	width: 75%;
}
.flex-four-fifths {
	width: 80%;
}
.left {
	float: left;
}
.right {
	float: right;
}
.flex-start {
	justify-content: flex-start;
}
.flex-start {
	justify-content: center;
}
.flex-end {
	justify-content: flex-end;
}
.flex-middle {
	align-items: center;
}
.flex-reverse {
	flex-direction: row-reverse;
}
.no-wrap {
	flex-wrap: nowrap !important;
}
.team-detail-thumbnail, .team-detail-thumbnail.flex-third {
	width: 31%;
	margin-top: 72px;
}
.flex.service-bullets {
	justify-content: flex-start;
}
.service-bullets div {
	padding: 8px;
}
.hidenav-toggle {
	display: none;
}
#main-nav, #hidenav:checked ~ #main-nav {
	display: flex !important;
}
.mainnav li {
	width: auto;
}
.logo-container {
	position: relative;
	z-index: 100;
}
.logo {
	position: relative;
	z-index: 2;
}
.logo-container:after {
	position: absolute;
	display: block;
	content: "";
	width: 50px;
	height: 100%;
	background-color: #FFF;
	right: -30px;
	-webkit-transform: skewX(-16deg);
	-moz-transform: skewX(-16deg);
	transform: skewX(-16deg);
	z-index: 1;
}
.hero-image {
	position: relative;
	overflow: hidden;
	min-height: 500px;
}
.hero-image img {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: -1;
}
.overlay {
	margin: 120px 0;
}
.white-overflow, .white-overflow.overflow-right:after {
	background-color: rgba(255, 255, 255, 0.7);
}
.overlay h1:after, .overlay h2:after, .overflow-right:after, .line-title:before {
	position: absolute;
	display: block;
	content: "";
}
.overlay h1:after, .overlay h2:after {
	top: 0;
	left: -8%;
	bottom: 0;
	width: 120%;
	background-color: #FFF;
	transform: skewX(-24deg);
	z-index: -1;
}
.main-overflow.overflow-right:after {
	background-color: var(--main-color-trans);
}
.overflow-right h3 {
	display: inline-block;
	margin: 0 36px 0 0;
}
.page-title {
	font-size: 44px;
}
.line-title {
	display: table;
	margin: 36px auto;
	padding: 0 24px;
	background-color: #FFF;
}
.line-title::before {
	position: absolute;
	width: 4000px;
	height: 2px;
	top: 28px;
	left: -2000px;
	background-color: var(--secondary-color);
	z-index: -1;
}
.hide-overflow {
	overflow: hidden;
}
.skew {
	position: relative;
	background-color: rgba(0,0,0,0) !important;
}
.skew:after {
	position: absolute;
	display: block;
	content: "";
	width: 300%;
	height: 100%;
	top: 0;
	left: -200%;
	right: 0;
	bottom: 0;
	-webkit-transform: skewX(-16deg);
	-moz-transform: skewX(-16deg);
	transform: skewX(-16deg);
	z-index: 1;
}
.skew.reverse-skew:after {
	-webkit-transform: skewX(16deg);
	-moz-transform: skewX(16deg);
	transform: skewX(16deg);
}
.white-bg.skew:after {
	background-color: #FFF;
}
.main-bg-trans.skew:after {
	background-color: var(--main-color-trans);
}
.dark-bg.skew:after {
	background-color: var(--dark-color);
}
.flex-half.skew:after {
	left: -192%;
}
.skew-content {
	position: relative;
	padding: 72px 36px;
	z-index: 2;
}
.flex-overflow-image img {
	position: absolute;
	display: block;
	width: calc(50% + 16px);
	height: 100%;
	top: 0;
	right: 0;
	bottom: 0;
	object-fit: cover;
	object-position: center;
}
.foi-right {
	left: -16px;
	right: 0;
}
/* Site Unique */
.overflow {
	position: relative;
}
.overflow-right:after {
	width: 2000px;
	height: 100%;
	top: 0;
	right: -2000px;
	bottom: 0;
}
.overflow-block {
	width: 85%;
	padding-left: 24px;
	padding-right: 24px;
	margin: auto auto -32px;
}
.overflow-box {
	margin-bottom: 124px;
}
.overflow-box .overflow-block {
	position: relative;
	margin-bottom: -128px;
}
.overflow-box .overflow-block:after {
	position: absolute;
	display: block;
	content: "";
	margin: auto;
	top: 0;
	left: -12px;
	right: -12px;
	bottom: -12px;
	background-color: #1C4470;
	z-index: -1;
}
.team-thumbs {
	padding-top: 64px;
}
.header {
	min-height: 105px;
}
.dropdown.active ul {
	position: absolute !important;
	width: 240px !important;
	text-align: left !important;
	top: 100%;
	left: 0;
}
.flex-item {
	font-size: 16px;
	align-self: center;
	text-align: left !important;
	width: auto !important;
	margin-bottom: 0 !important;
}
#home-video {
	display: flex;
	align-content: center;
	margin: auto;
}
.bordered-image {
	display: block;
	position: relative;
	line-height: 0;
}
.bordered-image:after {
	display: block;
	position: absolute;
	content: "";
	border: solid 8px #1C4470;
	border-top: none;
	top: 16px;
	left: -8px;
	right: -8px;
	bottom: 8px;
	width: 100%;
	height: calc(100% - 16px);
}
.bg-box {
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}
.top-bar .button, .top-bar .button:visited {
	margin: 4px 0 4px 12px;
}
.service-thumb {
	margin: 16px;
}
.service-thumb, .button, .transitional {
	-webkit-transition: 0.2s all;
	-moz-transition: 0.2s all;
	transition: 0.2s all;
}
.gallery-content a, .gallery-content a:visited {
	width: 25%;
}
.gallery-content img {
	height: 200px;
}
.no-header {
	margin-top: 24px;
}
blockquote {
	font-size: 36px;
	letter-spacing: 4px;
}
.overlap-bg {
	padding: 24px 0;
}
.container.no-positioning {
	position: unset;
}
.service-details .overlap-content {
	min-height: 430px;
}
.contact-box {
	border-left: solid 4px #FFF;
	border-right: solid 4px #FFF;
	margin: -48px auto;
	padding-top: 48px;
	padding-bottom: 48px;
}
.contact-container > .flex-half:first-child {
	border-left: solid 4px #FFF;
}
.form-field, .form-field.requiredDiv {
	padding: 8px;
}
.isRequired, .isRequired:active, .isRequired:focus {
	background-color: #FFF !important;
}
.form-field label {
	display: none;
}
.button:hover {
	-moz-transform: scale(105%);
	-webkit-transform: scale(105%);
	transform: scale(105%);
	border-radius: 8px;
}
.button.outline-button:hover {
	border-color: #0046A4 !important;
}
.top-bar {
	padding: 12px;
}
.top-bar a:not(.button), .top-bar a:not(.button):visited {
	color: #000;
	text-decoration: none;
}
.top-bar > div {
	width: auto !important;
	margin: auto 0 auto 12px !important;
}
.overlap-box {
	position: relative;
}
.overlap-img {
	position: absolute;
	width: 29%;
	height: 100%;
	top: 0;
	left: 0;
	bottom: 0;
	z-index: 1;
}
.overlap-img img {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	object-fit: cover;
	object-position: right center;
}
.social a:hover {
	-webkit-transition: 0.4s all;
	-moz-transition: 0.4s all;
	transition: 0.4s all;
	-moz-transform: rotate(360deg);
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
	-webkit-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.75);
	-moz-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.75);
	box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.75);
	opacity: 1;
}