/* Theme Name: Barebones */
/* === Global === */
html {
	overflow-x: hidden;
}
html,
body {
	font-family: var(--font_body);
	font-size: 14px;
}
h2 {
	font-size: 50px;
}
h2 strong {
	font-weight: 800;
}
.nav-btn > a,
.btn,
body .gform_wrapper.gravity-theme .button {
	border-radius: 10px;
	background: var(--color-4);
	color: #fff;
	padding: 12px 40px;
	font-weight: 800;
	font-size: 16px;
	transition: all ease 0.3s;
	letter-spacing: 0;
	display: inline-block;
}
.nav-btn > a:hover,
.nav-btn > a:focus,
.btn:hover,
.btn:focus,
body .gform_wrapper.gravity-theme .button:hover,
body .gform_wrapper.gravity-theme .button:focus {
	background-color: var(--color-2);
	color: #fff;
}

/* === Header/Nav === */
.primary-header {
	position: fixed;
	top: 36px;
	left: 0;
	right: 0;
	z-index: 99;
	text-transform: uppercase;
	font-size: 16px;
	white-space: nowrap;
}
.primary-header .header-row {
	border-radius: 11px;
	background: var(--color-5);
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
	padding: 36px 19px;
	align-items: center;
	justify-content: space-between;
	position: relative;
}
.primary-header .logo-col {
	flex-basis: 188px;
}
.primary-header .nav-col {
	flex-grow: 0;
}
.primary-header a {
	font-weight: 800;
}
.primary-header .menu {
	align-items: center;
}
.main-nav .menu li a {
	padding: 5px 12px;
}
.main-nav .menu li.nav-btn > a {
	padding: 12px 30px;
	display: inline-block;
}
.menu-item-has-children .sub-menu {
	background-color: var(--color-5);
	border-bottom-left-radius: 11px;
	border-bottom-right-radius: 11px;
}

/* === Footer === */
.primary-footer {
	font-weight: 500;
}
.primary-footer .footer-row {
	column-gap: 30px;
	justify-content: space-between;
}
.primary-footer .logo-col {
	flex-basis: 140px;
	max-width: 180px;
}
.primary-footer h3 {
	font-weight: 800;
	font-style: italic;
	font-size: 14px;
}
.primary-footer h3 strong {
	font-weight: 800;
}
.primary-footer a {
	font-weight: 500;
}
.primary-footer a:hover,
.primary-footer a:focus {
	color: var(--color-4);
}
.primary-footer .locations {
	display: flex;
	flex-direction: column;
	row-gap: 20px;
}
.primary-footer .numbers a {
	text-decoration: underline;
}
.primary-footer .numbers .number {
	margin-bottom: 4px;
}
.primary-footer .copy-row {
	border-top: 1px solid var(--color-1);
	padding-top: 30px;
	margin-top: 30px;
	flex-wrap: wrap;
	column-gap: 50px;
	row-gap: 30px;
	justify-content: space-between;
	margin-bottom: 30px;
	align-items: center;
}
.primary-footer .copyright {
	font-style: italic;
}
.primary-footer .copyright a {
	font-weight: 800;
}
.primary-footer .social {
	column-gap: 0.75em;
	font-size: 24px;
}
.primary-footer .social .icon {
	width: 45px;
	height: 45px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-4);
	border-radius: 50%;
	color: #fff;
}
.primary-footer .social .icon:hover,
.primary-footer .social .icon:focus {
	background-color: var(--color-3);
}

/* === Home Page === */
.banner-section .item .image {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
.banner-section .item .image:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(270deg, rgba(173, 173, 173, 0) 0%, rgba(35, 35, 35, 0.65) 81.25%);
}
.banner-section .item .acf-media {
	height: 100%;
}
.banner-section .item video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.banner-section .content {
	position: relative;
	min-height: 56.25vw;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding-top: calc(var(--headerHeight) + 36px + 8vw);
	padding-bottom: 8vw;
	font-size: 30px;
	font-weight: 500;
}
.banner-section .content .inner {
	border-radius: 30px;
	background: rgba(173, 173, 173, 0.56);
	padding: 20px 35px;
	margin: 0px 15px;
	max-width: 860px;
}
.banner-section .content h1 {
	color: #fff;
	font-size: 56px;
}
.banner-section .content h1 strong {
	font-weight: 900;
}
.bg-wrap {
	position: relative;
	background-color: var(--color-1);
	overflow: hidden;
	padding: 100px 0;
}
.bg-wrap .bg-overlay-1 {
	position: absolute;
	top: 250px;
	left: 0;
	transform: translateX(-100%);
	width: 20vw;
	height: 20vw;
	border-radius: 20vw;
	background: #f5f5f5;
	filter: blur(128.64999px);
}
.bg-wrap .bg-overlay-2 {
	position: absolute;
	bottom: 0;
	left: 0;
	transform: translate(-35%, 90%);
	width: 106vw;
	height: 106vw;
	border-radius: 106vw;
	background: #f5f5f5;
	filter: blur(128.64999px);
}
.bg-wrap .bg-overlay-3 {
	position: absolute;
	bottom: 150px;
	right: 0;
	transform: translate(106%, 0%);
	width: 59vw;
	height: 59vw;
	border-radius: 59vw;
	background: #f5f5f5;
	filter: blur(128.64999px);
}
.map-section {
	color: #fff;
	margin-bottom: 100px;
}
.map-section p:last-child {
	margin-bottom: 0;
}
.map-section h2 {
	position: relative;
}
.map-section h2:after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	right: 0;
	height: 2px;
	background-color: var(--color-4);
	z-index: 1;
}
.map-section h2 .heading {
	position: relative;
	display: inline-block;
	background-color: var(--color-1);
	z-index: 2;
	padding-right: 23px;
}
.ip-map-section {
	color: var(--color-1);
	margin-bottom: 100px;
}
.ip-map-section p:last-child {
	margin-bottom: 0;
}
.ip-map-section h2 {
	position: relative;
}
.ip-map-section h2:after {
	content: none;
}
.ip-map-section h2 .heading {
	position: relative;
	display: inline-block;
	z-index: 2;
	padding-right: 23px;
}
.feature-section h2 {
	margin-bottom: 60px;
}
.feature-section .inner {
	padding: 60px 100px;
	color: var(--color-1);
	background-color: #fff;
	border-radius: 40px;
}
.feature-section .features {
	flex-wrap: wrap;
	gap: 60px;
}
.feature-section .features .feature {
	flex: 1 1 calc(33.33% - 40px);
	padding: 30px;
	border-radius: 25px;
	border: 0.5px solid #cfcfcf;
	box-shadow: 5px 5px 10px 0 rgba(218, 218, 218, 0.6);
	position: relative;
}
.feature-section .features .feature .image {
	position: absolute;
	top: 0;
	right: 0;
	font-size: 50px;
	color: var(--color-3);
	transform: translate(40%, -50%);
	width: 50px;
}
.background-section {
	padding: 200px 0 150px;
	background-size: cover;
	background-attachment: fixed;
	background-position: 50% 50%;
}
.background-section .bg-row {
	position: relative;
}
.background-section .bg-row .content {
	width: 72%;
	margin-left: auto;
	border-radius: 40px;
	background: rgba(245, 245, 245, 0.85);
	padding: 70px 140px;
}
.background-section .bg-row .image {
	position: absolute;
	width: 34%;
	top: 50%;
	transform: translateY(-50%);
	border-radius: 40px;
	border: 0.25px solid var(--color-3);
	overflow: hidden;
}
.reviews-section {
	padding: 80px 0;
	background-color: var(--color-1);
	color: #fff;
}
.reviews-section .reviews {
	background-color: var(--color-2);
	color: #fff;
	padding: 40px 60px 40px 60px;
	border-radius: 40px;
}
.reviews-section .owl-carousel {
	overflow: hidden;
}
.reviews-section .owl-carousel .owl-item {
	background-color: var(--color-3);
	padding: 60px 30px 40px 30px;
	border-radius: 30px;
	transition: all ease 0.3s;
	z-index: 3;
	position: relative;
	margin-top: 95px;
	margin-bottom: 70px;
	font-size: 16px;
}
.reviews-section .owl-carousel .owl-item.active.center {
	transform: scale(1.3);
	background-color: var(--color-4);
	z-index: 4;
}
.reviews-section .owl-carousel .owl-item .heading {
	text-align: center;
}
.reviews-section .owl-carousel .owl-item .content {
	text-transform: uppercase;
	font-size: 14px;
}
.reviews-section .owl-carousel .owl-item .quote-icon {
	color: var(--color-4);
	font-size: 90px;
	position: absolute;
	top: -50px;
	right: 40%;
}
.reviews-section .owl-carousel .owl-item.active.center .quote-icon {
	color: var(--color-3);
}
.reviews-section .owl-carousel .owl-dots {
	display: flex;
	justify-content: center;
	column-gap: 0.5em;
	margin-top: 40px;
}
.reviews-section .owl-carousel .owl-dots .owl-dot {
	border: 1px solid var(--color-3);
	border-radius: 50%;
	width: 13px;
	height: 13px;
}
.reviews-section .owl-carousel .owl-dots .owl-dot.active {
	background-color: var(--color-3);
}
.form-section {
	padding: 128px 0 30px;
	background: linear-gradient(0deg, rgba(255, 255, 255, 0) 29.92%, #232323 100%);
}
.form-section .gfield_radio {
	display: flex;
	gap: 1em;
}
.form-section .gform_wrapper.gravity-theme .gfield_label {
	border: none;
	font-size: 14px;
	font-weight: 800;
}
.form-section .gsection_title {
	font-weight: 800;
	font-size: 24px;
}
.form-section .form {
	border-radius: 11px 11px 0 0;
	background-color: #fff;
	padding: 60px 120px;
}
.form-section .form h2 {
	font-size: 87px;
}
.form-section .gsection_title {
	margin: 30px 0 0 0;
	text-transform: uppercase;
}
.form-section .gform_wrapper.gravity-theme .gsection {
	border-bottom: none;
}
.form-section input,
.form-section textarea,
.form-section select {
	border-radius: 10px;
	background: #f5f5f5;
	border: none;
	padding: 20px !important;
	text-transform: uppercase;
}
.form-section input::placeholder,
.form-section textarea::placeholder,
.form-section option,
.form-section option::placeholder {
	text-transform: uppercase;
}
.form-section .gform_button {
	text-transform: uppercase;
	background-color: var(--color-1);
	color: #fff;
	font-weight: 600;
	transition: all ease 0.3s;
	padding: 10px 14px !important;
}
.form-section .gform_button:hover,
.form-section .gform_button:focus {
	color: var(--color-1);
	background-color: var(--color-3);
}
.form-section .gform_wrapper {
	max-width: 700px;
	margin: 0 auto;
}
.form-section .select2-container--default .select2-selection--single {
	border: none;
	background: var(--color-5);
	padding: 20px;
	height: auto;
	border-radius: 10px;
}
.form-section
.select2-container--default
.select2-selection--single
.select2-selection__arrow {
	height: 100%;
	right: 15px;
}

/* === Interior Pages === */
/* === Media Queries === */
.mobile-nav-toggle {
	display: none;
}
.page-overlay {
	position: relative;
}
.page-overlay .page-overlay-inner {
	overflow-x: hidden;
}
.text-blue {
	color: var(--color-4);
}
.gal-section {
	background-color: var(--color-5);
	margin-bottom: 20px;
}
.gal-section .content-row {
	flex-wrap: wrap;
	align-items: center;
}
.gal-section .image-col {
	flex: 1 1 60%;
	max-width: 60%;
	align-self: stretch;
	border-bottom: 8px solid var(--color-5);
}
.gal-section .image-col .owl-carousel,
.gal-section .image-col .owl-carousel .owl-stage-outer,
.gal-section .image-col .owl-carousel .owl-stage,
.gal-section .image-col .owl-carousel .owl-item,
.gal-section .image-col .owl-carousel .item,
.gal-section .image-col .owl-carousel .item img {
	height: 100%;
}
.gal-section .image-col img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	max-height: 400px;
	min-height: 100%;
}
.gal-section .content-col {
	flex: 1 1 40%;
	padding: 50px;
}
.gal-section .owl-carousel .owl-dots {
	display: flex;
	position: absolute;
	bottom: -8px;
	left: 0;
	right: 0;
	z-index: 3;
}
.gal-section .owl-carousel .owl-dot {
	flex: 1 1 auto;
	height: 8px;
	background-color: var(--color-5);
	border-right: 8px solid #000;
	position: relative;
}
.gal-section .owl-carousel .owl-dot:last-child {
	border-right: none;
}
.gal-section .owl-carousel .owl-dot.active {
	background-color: var(--color-6);
}
.gal-section .owl-carousel .owl-dot.active:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 0;
	background-color: var(--color-5);
	animation: progressBar 5s linear;
}
.gal-section .owl-carousel .owl-dot.active ~ .owl-dot {
	background-color: var(--color-6);
}
.gal-section .owl-carousel .owl-nav button {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background-color: #000;
	color: #fff;
	width: 34px;
	height: 34px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
}
.gal-section .owl-carousel .owl-nav button.owl-prev {
	left: 10%;
}
.gal-section .owl-carousel .owl-nav button.owl-next {
	right: 10%;
}
.ip-banner {
	position: relative;
}
.ip-banner .background {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 515px;
	background: linear-gradient(0deg, #fff -37.25%, #066e9a 100%);
	z-index: -1;
}
.ip-banner .content {
	margin-top: 160px;
	padding-top: 65px;
}
.ip-banner h1 {
	font-size: 75px;
	color: #fff;
}
.ip-banner h1 strong {
	font-weight: 800;
}
.content-section {
	margin-top: 65px;
	margin-bottom: 35px;
}
.gallery-section {
	margin-bottom: 70px;
}
.gallery-section .heading {
	font-weight: 800;
	font-style: italic;
}
.gal-section h3 {
	font-size: 28px;
}
.gal-section h3 strong {
	font-weight: 800;
}
.gal-section .links {
	flex-wrap: wrap;
	gap: 25px;
	justify-content: space-between;
}
.gal-section .content-col {
	display: flex;
	align-items: center;
	justify-content: center;
}
.content-section.limit-width .content {
	max-width: 670px;
}
.gal-section {
	flex-wrap: wrap;
}
.gal-section .videos {
	flex-wrap: wrap;
	flex: 1 1 100%;
	gap: 10px;
	padding: 10px;
}
.gal-section .videos .col {
	flex: 1 1 calc(33.33% - 6.66px);
}
.gallery-section .coming_soon {
	flex: 1 1 auto;
	text-align: center;
	padding: 20px;
}
.toggle-item {
	border-top: 1px solid #fff;
	margin-bottom: 5px;
}
.toggle-item .toggle-heading {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 15px;
	cursor: pointer;
}
.toggle-item .icon {
	transition: transform ease-in-out 0.4s;
	font-size: 18px;
}
.toggle-item > .toggle-content {
	display: none;
	padding: 5px 30px;
}
.toggle-item.active > .toggle-content {
	display: block;
}
.toggle-item .toggle-content p {
	margin: 10px 0;
}
.toggle-item .icon.active .fas:before {
	content: "\f068";
}
.content-section {
	font-size: 16px;
}
.content-section .content-row {
	gap: 30px;
}
.content-section .image-col {
	flex: 1 1 calc(40% - 15px);
}
.content-section .content-col {
	flex: 1 1 calc(60% - 15px);
}


span.location-data{
	display:inline-block;
	width:100%; 
	font-size: 16px;
	font-weight:700; 
	margin:5px 0px;

}
.hover-boxes {
	background-color: var(--color-7);
}
.hover-boxes .services {
	flex-wrap: wrap;
}
.hover-boxes .service {
	flex: 0 1 25%;
	background-color: var(--color-8);
	color: var(--color-text);
	position: relative;
	min-height: 19vw;
	z-index: 2;
	overflow: hidden;
	background-size: cover;
	background-position: 50% 50%;
	border: 1px solid var(--color-7);
	min-height: 300px;
}
.hover-boxes .service .link-inner {
	height: 100%;
	padding: 30px 20px;
	display: flex;
	flex-direction: column;
}
.hover-boxes .service:after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 53.37%, #002054 100%), linear-gradient(0deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.3) 100%);
	z-index: 0;
	display: none;
	transition: all ease 0.3s;
	height: 100%;
}
.hover-boxes .service:before {
	overflow: hidden;
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: var(--color-4);
	transition: all ease 0.3s;
	height: 0;
	z-index: 1;
}
.hover-boxes .service:hover {
	color: #fff;
}
.hover-boxes .service:hover a {
	color: #fff;
}
.hover-boxes .service:hover:before {
	height: 100%;
}
.hover-boxes .service .content {
	max-height: 0;
	overflow: hidden;
	transition: all ease 0.3s 0s;
	opacity: 0;
}
.hover-boxes .service:hover .content {
	max-height: 400px;
	opacity: 1;
	transition: all ease 0.6s;
}
.hover-boxes .service .content p:last-child {
	margin-bottom: 0;
}
.hover-boxes .service .inner {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	flex-direction: column;
}
.hover-boxes .service a {
	color: var(--color-text);
	font-weight: 400;
	height: 100%;
}
.hover-boxes .service .content-wrap {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}
.hover-boxes .service .heading {
	font-weight: 700;
	font-size: 28px;
}
.hover-boxes .service .link-icon {
	margin-top: 20px;
	border-radius: 50%;
	border: 3px solid var(--color-text);
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hover-boxes .service:hover .link-icon {
	border-color: #fff;
	color: #fff;
}
.text-banner {
	padding: 160px 0;
	background-size: cover;
	background-position: 50% 50%;
	color: #fff;
}
.text-banner h2 {
	font-size: 40px;
}
.feat-section {
	background-color: var(--color-8);
	padding: 20px 0;
}
.feat-section .sec-content {
	margin-bottom: 30px;
	max-width: 950px;
	margin: 0 auto 50px;
}
.feat-section h2 {
	font-size: 34px;
}
.feat-section .features {
	gap: 30px 60px;
}
.feat-section .feature {
	flex: 0 1 calc(33.33% - 43.33px);
	font-size: 16px;
}
.feat-section .feature .image {
	margin-bottom: 55px;
}
.feat-section .feature .image img {
	max-height: 100px;
	width: auto;
}
.feat-section .feature h3 {
	font-size: 24px;
}
.feat-section .feature h3 strong {
	font-weight: 800;
}
.feat-section .feature p:last-child {
	margin-bottom: 0;
}
.faq-section {
	padding: 55px 0;
	background-color: var(--color-9);
	color: #fff;
}
.faq-section h2 {
	font-size: 32px;
}
.faq-section .toggle-item {
	font-size: 20px;
}
.faq-section .toggle-item h3 {
	margin-bottom: 0;
	font-size: 25px;
}
.gradient-banner {
	padding: 100px 0;
	background-image: linear-gradient(90deg, var(--color-3) 0%, var(--color-4) 100%);
	color: #fff;
	font-size: 18px;
}
.gradient-banner p {
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}
.gradient-banner p:last-child {
	margin-bottom: 0;
}
.gradient-banner .shortcode_row {
	row-gap: 0;
	max-width: 850px;
	margin: 0 auto;
}
.gradient-banner .shortcode_row .shortcode_col {
	flex-grow: 1;
}
.gradient-banner .shortcode_row ul {
	margin: 0;
	padding: 0;
	list-style: none;
	margin-top: 20px;
}
.gradient-banner .shortcode_row ul li {
	margin-bottom: 20px;
	padding-left: 30px;
	position: relative;
}
.gradient-banner .shortcode_row ul li:before {
	content: "\f00c";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	position: absolute;
	left: 0;
	color: #fff;
	top: 1px;
	width: 20px;
	height: 20px;
	border: 1px solid #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
}
.content-section.img_pos-right .content-row {
	flex-direction: row-reverse;
}
.faq-section + .faq-section {
	padding-top: 0;
}
.team-section {
	background-color: var(--color-7);
	padding: 60px 0;
}
.team-section .content {
	margin-bottom: 50px;
}
.team-section .content p{
	font-size: 16px;
}
.team-section .members {
	flex-wrap: wrap;
	column-gap: 100px;
	row-gap: 75px;
}
.team-section .member {
	flex: 1 1 calc(50% - 75px);
}
.team-section .member .image {
	margin-bottom: 30px;
}
.team-section .member .image img {
	width: 100%;
	box-shadow: 4px 4px 4px 0px rgba(0, 0, 0, 0.25);
}
.team-section .member h3 {
	font-size: 25px;
	color: var(--color-1);
	letter-spacing: 2.5px;
	margin-bottom: 5px;
}
.team-section .member h4 {
	letter-spacing: 2px;
	font-weight: 700;
}
.team-section .member .content {
	margin-top: 30px;
	margin-bottom: 0;
}
.team-section .member .content p:last-child {
	margin-bottom: 0;
}
.tabs-sections {
	margin: 75px 0;
}
.toggle-nav {
	justify-content: center;
	width: fit-content;
	margin: 0 auto 75px;
	column-gap: 6px;
	flex-wrap: wrap;
	row-gap: 6px;
}
.toggle-nav .nav-item {
	background-color: var(--color-4);
	color: #252525;
	padding: .5em 1.5em;
	min-width: 270px;
	text-align: center;
	font-size: 18px;
	cursor: pointer;
	transition: all ease .3s;
	border-bottom: 2px solid var(--color-4);
}
.toggle-nav .nav-item.active {
	border-color: var(--color-3);
}
.toggle-nav .nav-item:nth-child(even) {
	background-color: var(--color-5);
	border-color: var(--color-5);
}
.toggle-nav .nav-item.active:nth-child(even) {
	border-color: var(--color-3);
}
.toggle-nav .nav-item:hover {
	border-color: var(--color-3);
}
.toggle-nav .nav-item.active:hover {
	border-color: var(--color-3);
}
.toggle-section {
	display: none;
}
.toggle-section.active {
	display: block;
}
.toggle-section .section-heading {
	text-align: center;
	background: var(--color-4);
	margin: 0 0 6px;
	padding: 10px 0;
	font-weight: 700;
}
.toggle-section:nth-child(even) .section-heading {
	background-color: var(--color-5);
}
.tabs-section .service {
	background-color: var(--color-5);
	margin: 0;
	flex-wrap: wrap;
	border-bottom: 6px solid #fff;
}
.tabs-section .service:last-child {
	margin-bottom: 0;
}
.tabs-section .service:nth-child(even) {
	flex-direction: row-reverse;
	background-color: var(--color-4);
}
.tabs-section .service:nth-child(even) .image-col,
.tabs-section .service:nth-child(even) .content-col {
	border: none;
}
.tabs-section .service .image-col {
	flex: 1 1 50%;
	position: relative;
	border-right: calc(6px / 2) solid #fff;
}
.tabs-section .service .content-col {
	flex: 1 1 50%;
	padding: 50px;
	align-self: center;
	border-left: calc(6px / 2) solid #fff;
}
.tabs-section .service .content-col p:last-child {
	margin-bottom: 0;
}
.tabs-section .service.img-cover .image-col .image {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.tabs-section .service.img-cover .image-col .image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}
.tabs-section:nth-child(even) .service {
	background-color: var(--color-4);
	flex-direction: row-reverse;
}
.tabs-section:nth-child(even) .service .image-col {
	border-right: none;
	border-left: calc(6px / 2) solid #fff;
}
.tabs-section:nth-child(even) .service .content-col {
	border-left: none;
	border-right: calc(6px / 2) solid #fff;
}
.tabs-section:nth-child(even) .service:nth-child(even) {
	background-color: var(--color-5);
	flex-direction: row;
}
.tabs-section:nth-child(even) .service:nth-child(even) .image-col,
.tabs-section:nth-child(even) .service:nth-child(even) .content-col {
	border: none;
}
.tabs-sections .nav-item:has(.sub-menu){
	position: relative;
}
.tabs-sections .nav-item>.sub-menu{
	display: none;
    background-color: var(--color-5);
    position: absolute;
    top: 105%;
    left: 50%;
    transform: translateX(-50%);
    padding: 10px;
    z-index: 1;
    white-space: nowrap;
    border-radius: 11px;
}
.tabs-sections .nav-item:hover>.sub-menu{
	display: flex;
	flex-direction: column;
	width: 100%;
}
.tabs-sections .nav-item:hover>.sub-menu a{
	padding: 6px;
}
.tabs-sections .nav-item:has(.sub-menu){
	position: relative;
	padding-right: 18px;
	border-radius: 11px;
}
.tabs-sections .nav-item:has(.sub-menu):after {
	content: '\f105';
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	position: absolute;
	top: 51%;
	transform: translate(-100%, -50%);
	right: 0;
	transition: transform 0.3s ease;
}
.tabs-sections .nav-item:has(.sub-menu):hover:after,
.tabs-sections .nav-item:has(.sub-menu):hover:after{
	transform: translate(-100%, -50%) rotate(90deg);
}
.page-template-default,
.page-template-page-sitemap {
	margin-top: calc(36px + var(--headerHeight, 86px));
}
.main-section {
	padding: 50px 0;
}


.galvid.video-section .flex-2-col-sm{padding: 10px;}
.galvid video{max-width: 100%; max-height: 100%;}



@media screen and (min-width: 1200px) {
	.primary-header .main-nav {
		display: block !important;
	}
	.reviews-section .owl-carousel .owl-item {
		margin-top: 140px;
		margin-bottom: 110px;
	}
}
@media screen and (max-width: 1299px) {
	.hover-boxes .service {
		flex-basis: 33.33%;
	}
}
@media screen and (max-width: 1199px) {
	.mobile-nav-toggle {
		display: block;
		font-size: 36px;
		cursor: pointer;
		text-align: right;
	}
	.primary-header .header-row {
		flex-wrap: wrap;
		justify-content: space-between;
		padding: 20px 20px 0;
	}
	.primary-header .mobile-nav-toggle,
  .primary-header .logo-col {
		padding-bottom: 20px;
	}
	.primary-header .nav-col {
		flex-basis: 100%;
	}
	.primary-header .main-nav {
		display: none;
		flex-direction: column;
		transform: none;
		background-color: var(--color-5);
		border-bottom-left-radius: 11px;
		border-bottom-right-radius: 11px;
		text-align: center;
		padding-top: 11px;
		border-top: 2px solid var(--color-4);
		padding: 20px;
		margin-left: -20px;
		margin-right: -20px;
		max-height: calc(100vh - 36px - var(--headerHeight));
		overflow-y: auto;
	}
	.primary-header .main-nav .menu li.nav-btn > a,
  .primary-header .menu {
		font-size: 22px;
	}
	.primary-header .menu {
		text-align: right;
		flex-direction: column;
		row-gap: 10px;
	}
	.banner-section .content h1 {
		font-size: 82px;
	}
	.banner-section .content {
		font-size: 26px;
	}
	.feature-section .inner {
		padding: 60px;
	}
	.feature-section .features {
		gap: 30px;
	}
	.reviews-section .reviews {
		padding: 40px;
	}
	.reviews-section .owl-carousel .owl-item {
		margin-top: 165px;
		margin-bottom: 135px;
		padding: 60px 20px 40px;
	}
	.ip-banner .background {
		height: 475px;
	}
	.ip-banner .content {
		margin-top: 90px;
	}
	.team-section .members {
		gap: 50px;
	}
	.feat-section .features {
		flex-wrap: wrap;
		gap: 30px;
	}
	.feat-section.columns-4 .feature {
		flex-basis: calc(50% - 15px);
	}
	.primary-header .menu {
		text-align: center;
	}
	.primary-header .menu li {
		margin: 0;
		display: block;
	}
	.primary-header .menu li a {
		display: block;
	}
	.menu-item-has-children .sub-menu {
		display: block;
		position: static;
		transform: none;
		padding: 0;
		margin-top: 8px;
	}
}
@media screen and (max-width: 991px) {
	body {
		margin-top: 0;
	}
	.primary-header {
		display: block;
	}
	.mobile-header {
		display: none;
	}
	.banner-section .content {
		font-size: 20px;
	}
	.banner-section .content h1 {
		font-size: 64px;
	}
	.feature-section .features .feature {
		flex-basis: calc(50% - 15px);
	}
	.background-section .bg-row .image {
		position: static;
		width: calc(100% - 140px);
		margin: 0 auto -40px;
		transform: none;
	}
	.background-section .bg-row .content {
		width: 100%;
		padding: 70px;
	}
	.reviews-section .owl-carousel .owl-item .content {
		font-size: 16px;
	}
	.reviews-section .owl-carousel .owl-item {
		margin: 0;
		margin-top: 30px;
	}
	.reviews-section .owl-carousel .owl-item.active.center {
		transform: none;
	}
	.form-section .form {
		padding: 60px;
	}
	.form-section .form h2 {
		font-size: 60px;
	}
	.gal-section {
		flex-wrap: wrap;
	}
	.gal-section > .col {
		flex-basis: 100%;
		max-width: 100%;
	}
	.gal-section .image-col img {
		max-height: none;
	}
	.gal-section .content-col {
		padding: 50px 15px;
	}
	.gal-section .links {
		justify-content: flex-start;
	}
	.ip-banner .background {
		height: 445px;
	}
	.gal-section .videos .col {
		flex: 0 1 calc(50% - 5px);
	}
	.feat-section .feature {
		flex-basis: calc(50% - 15px);
	}
	.hover-boxes .service {
		flex-basis: 50%;
	}
	.reviews-section .reviews {
		padding: 15px;
	}
}
@media screen and (max-width: 767px) {
	.primary-header .main-nav .menu li.nav-btn > a,
  .primary-header .menu {
		font-size: 16px;
	}
	.primary-header .main-nav {
		padding: 20px 10px;
	}
	.banner-section .content {
		font-size: 18px;
	}
	.banner-section .content h1 {
		font-size: 48px;
	}
	.banner-section .content .inner {
		padding: 30px 20px;
	}
	h2 {
		font-size: 42px;
	}
	.feature-section .inner {
		padding: 60px 25px;
	}
	.feature-section .features .feature {
		padding: 30px 15px;
	}
	.background-section .bg-row .image {
		width: 100%;
		margin-bottom: 20px;
	}
	.background-section .bg-row .content {
		padding: 40px 25px;
	}
	.reviews-section .reviews {
		background: none;
	}
	.form-section .form {
		padding: 60px 25px;
	}
	.form-section .form h2 {
		font-size: 44px;
	}
	.primary-footer .container {
		padding-left: 10px;
		padding-right: 10px;
	}
	.primary-footer .footer-row {
		flex-wrap: wrap;
		row-gap: 20px;
		column-gap: 15px;
	}
	.primary-footer .footer-row .logo-col {
		flex-basis: 100%;
		order: 1;
		margin-bottom: 20px;
	}
	.primary-footer .footer-row .hours-col {
		order: 4;
		flex: 1 1 calc(50% - 7.5px);
	}
	.primary-footer .footer-row .numbers-col {
		order: 3;
		flex: 1 1 calc(50% - 7.5px);
	}
	.primary-footer .footer-row .locations-col {
		order: 2;
		flex-basis: 100%;
	}
	.primary-footer .locations {
		flex-direction: row;
		column-gap: 10px;
	}
	.primary-footer .location {
		flex: 1 1 calc(50% - 5px);
	}
	.reviews-section .owl-carousel .owl-item .quote-icon {
		top: -45px;
	}
	.reviews-section .owl-carousel .owl-item {
		margin-top: 58px;
	}
	.primary-header .menu {
		row-gap: 5px;
	}
	.feature-section .features .feature {
		flex-basis: 100%;
	}
	.background-section,
  .bg-wrap,
  .reviews-section {
		padding: 50px 0;
	}
	.map-section {
		margin-bottom: 50px;
	}
	.form-section {
		padding: 50px 0 30px;
	}
	.primary-footer .logo-col {
		flex-basis: auto;
	}
	.ip-banner .background {
		height: calc(100% - 14vw);
	}
	.ip-banner h1 {
		font-size: 52px;
	}
	.gal-section .videos .col {
		flex: 1 1 100%;
	}
	.team-section .member {
		flex-basis: 100%;
	}
	.content-section .content-row {
		flex-wrap: wrap;
	}
	.content-section .content-row > .col {
		flex-basis: 100%;
	}
}
@media screen and (max-width: 599px) {
	.feat-section .feature:nth-child(n) {
		flex-basis: 100%;
	}
	.hover-boxes .service {
		flex-basis: 100%;
	}
	.hover-boxes .service .content {
		max-height: 300px;
		opacity: 1;
	}
	.hover-boxes .service:before {
		height: 100%;
	}
	.hover-boxes .service a {
		color: #fff;
	}
	.hover-boxes .service .link-icon {
		border-color: #fff;
	}
}
@media screen and (max-width: 389px) {
	.primary-footer .locations {
		flex-direction: column;
	}
	.primary-footer .footer-row .hours-col,
  .primary-footer .footer-row .numbers-col {
		flex-basis: 100%;
	}
}
@media screen and (max-width: 499px) {
	.primary-footer .copy-row {
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-start;
	}
}
@media screen and (min-width: 1300px) {
	.primary-header .container,
	.banner-section .content .container {
		width: 1270px;
	}
}
@keyframes progressBar {
	0% {
		width: 0;
	}
	100% {
		width: 100%;
	}
}
