/** 
 * Theme Name: G.A. Rich
 * Author: Central States Marketing
 * Author URI: https://www.centralstatesmarketing.com/
 * Description: This site was built by Central States Marketing. For more information about the site or this custom WordPress theme, you can contact Central States Marketing at: info@csm.marketing or call us at: 309-693-2345.
 * Version: 1.0.0
 *
 * @package ga-rich
 * @charset "UTF-8"
 */



/* ----- CSS CUSTOM PROPERTIES ----- */
:root {
	--primary-base: 58.22% 0.226 26.85;
	--white-base: 100% 0 0;
	--grey-light-base: 93.1% 0 0;
	--grey-medium-base: 45.32% 0 0;
	--grey-dark-base: 30.12% 0 0;
	--black-base: 0% 0 0;

	--primary: oklch(var(--primary-base));
	--white: oklch(var(--white-base));
	--grey-light: oklch(var(--grey-light-base));
	--grey-medium: oklch(var(--grey-medium-base));
	--grey-dark: oklch(var(--grey-dark-base));
	--black: oklch(var(--black-base));

	--shadow-color: oklch(var(--black-base) / 0.25);
	--shadow-color-hover: oklch(var(--black-base) / 0.4);

	--shadow: 0 0 10px var(--shadow-color);
	--shadow-hover: 0 0 10px var(--shadow-color-hover);

	--gutter: 3rem;
	--page-max-width: 78rem;
	--max-w-text: 50rem;
	--row-spacing: 4rem;

	--ff-heading: 'Be Vietnam Pro', sans-serif;
	--ff-body: 'Be Vietnam Pro', sans-serif;

	--fs-sm: clamp(0.73rem, 0.11vi + 0.7rem, 0.8rem);
	--fs-base: clamp(0.88rem, 0.29vi + 0.8rem, 1.06rem);
	--fs-md: clamp(1rem, 0.45vi + 0.81rem, 1.2rem);
	--fs-lg: clamp(1.12rem, 0.60vi + 0.82rem, 1.56rem);
	--fs-xl: clamp(1.20rem, 0.76vi + 0.96rem, 1.86rem);
	--fs-2xl: clamp(1.36rem, 0.95vi + 1.02rem, 2.2rem);
	--fs-3xl: clamp(1.40rem, 1.3vi + 1.22rem, 2.75rem);
	--fs-4xl: clamp(1.81rem, 2.32vi + 1.31rem, 3.32rem);
	--fs-5xl: clamp(2rem, 2.4vi + 1.4rem, 3.75rem);

	--header-height: 131px;
	--admin-bar-height: 32px;
	--hero-min-height: 550px;

	--in: all 0.2s ease-in;
	--out: all 0.15s ease-out;
}
@media (width <= 1080px) {
	:root {
		--row-spacing: 2rem;
		--gutter: 3rem;
	}
}
@media (width <= 782px) {
	:root {
		--admin-bar-height: 46px;
		--gutter: 2rem;
	}
}



/* ----- RESET ----- */
*,
*::before,
*::after {
	box-sizing: inherit;
}
html {
	box-sizing: border-box;
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
}
body {
	margin: 0;
	font-family: var(--ff-body);
	font-size: var(--fs-base);
}
html,
body {
	scroll-behavior: smooth;
	overflow-x: clip;
}
[id] {
	scroll-margin-top: calc(var(--admin-bar-height) + var(--header-height) + 2rem);
}
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}
b,
strong {
	font-weight: bolder;
}
embed,
iframe,
object {
	max-width: 100%;
}
img {
	height: auto;
	max-width: 100%;
}
.wp-block-embed {
	margin: 0;
}
.wp-block-embed iframe {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}
@media (prefers-reduced-motion: reduce) {
	html:focus-within {
		scroll-behavior: auto;
	}
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}



/* ----- TEMPLATE SPECIFIC ----- */
.post-edit-link a {
	display: block;
	width: fit-content;
	color: var(--primary);
	text-transform: uppercase;
	padding: 0.5em 1em;
	margin: 1em;
	text-decoration: none;
	max-width: var(--page-max-width);
	margin: 0 auto;
	padding-inline: var(--gutter);
	transition: var(--in);
	&:hover {
		color: var(--white);
		background-color: var(--primary);
		transition: var(--out);
	}
}



/* ----- GLOBALS ----- */
::selection {
	background-color: var(--grey-light);
	color: var(--black);
  }
:where(h1, h2, h3, h4, h5, h6) {
	--heading-color: var(--grey-dark);
	color: var(--heading-color);
	font-family: var(--ff-heading);
	font-weight: 500;
	line-height: 1.2;
	margin: 0 0 0.83em 0;
}
h1 {
	font-size: var(--fs-4xl);
	margin: 0 0 0.67em 0;
}
h2 {
	font-size: var(--fs-3xl);
}
h3 {
	--heading-color: var(--primary);
	font-size: var(--fs-xl);
}
h4 {
	--heading-color: var(--primary);
	font-size: var(--fs-md);
}
h5 {
	font-size: var(--fs-base);
}
h6 {
	font-size: var(--fs-sm);
}
p {
	margin-bottom: 1.5rem;
	color: var(--grey-medium);
}
hr {
	width: 100%;
	height: 2px;
	border: none;
	margin: 2em 0;
	background-color: oklch(var(--black-base) / 25%);
}
svg {
	fill: currentColor;
}



/* ----- LINK STYLING ----- */
.content .kt-inside-inner-col a:not(.kb-section-link-overlay),
body.search .content a {
	color: var(--primary);
	font-weight: 800;
	position: relative;
	transition: var(--in);
}
.content .kt-inside-inner-col a:hover,
body.search .content a:hover {
	color: var(--grey-light);
	transition: var(--out);
}
.center-align {
	text-align: center;
	justify-self: center;
	justify-items: center;
	align-items: center;
}
.left-align {
	text-align: left;
	justify-self: left;
}
@media (width <= 1080px) {
	h2.center-align,
	h2.left-align {
		margin-inline: 3rem;
	}
	h2.center-align:before,
	h2.left-align:before {
		left: -2.5rem;
	}
	h2.center-align:after {
		right: -2.5rem;
	}
}



/* ----- UTILS ----- */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.wrapper-max {
	max-width: var(--max-w-max);
	margin-inline: auto;
}
.wrapper-content {
	max-width: var(--max-w-content);
	margin-inline: auto;
	padding-inline: var(--gutter);
}
.wrapper-text {
	max-width: var(--max-w-text);
	margin-inline: auto;
}
.page-max-width {
	max-width: var(--page-max-width);
	margin-inline: auto;
	padding-inline: var(--gutter);
}
.fs-sm {
	font-size: var(--fs-sm) !important;
}
.fs-base {
	font-size: var(--fs-base) !important;
}
.fs-md {
	font-size: var(--fs-md) !important;
}
.fs-lg {
	font-size: var(--fs-lg) !important;
}
.fs-xl {
	font-size: var(--fs-xl) !important;
}
.fs-2xl {
	font-size: var(--fs-2xl) !important;
}
.fs-3xl {
	font-size: var(--fs-3xl) !important;
}
@media (width > 782px) {
	.mobile-only {
		display: none!important;
	}
}
@media (width <= 782px) {
	.desktop-only {
		display: none!important;
	}
}



/* ----- BUTTONS ----- */
.btn {
	display: flex;
}
.btn:hover {
	position: relative;
}
.btn, 
.entry-content .wp-block-kadence-advancedbtn .kb-button, 
input[type="submit"] {
	text-decoration: none;
	text-align: center;
	font-size: var(--fs-base);
	font-weight: 500;
	line-height: 1.2;
	color: var(--white);
	padding: 1rem 1.75rem;
	border-radius: 0.5rem;
	height: fit-content;
    cursor: pointer;
    display: inline-block;
	transform: translateY(0);
    transition: var(--in);
}
.entry-content .wp-block-kadence-advancedbtn .kb-button {
	margin: 0;
}
.entry-content .wp-block-kadence-advancedbtn {
	margin-top: 2rem;
	gap: 2rem;
}
.btn:hover, 
.entry-content .wp-block-kadence-advancedbtn .kb-button:hover, 
input[type="submit"]:hover {
	transition: var(--out);
}
.btn.primary, 
.entry-content .wp-block-kadence-advancedbtn .kb-button.primary, 
input[type="submit"] {
	background: var(--primary);
}
.btn.primary:hover, 
.entry-content .wp-block-kadence-advancedbtn .kb-button.primary:hover, 
input[type="submit"]:hover {
	background: var(--grey-medium);
}
.btn.light, 
.entry-content .wp-block-kadence-advancedbtn .kb-button.light {
	background: var(--white);
	color: var(--primary);
}
.btn.light:hover, 
.entry-content .wp-block-kadence-advancedbtn .kb-button.light:hover {
	background: var(--grey-medium);
	color: var(--white);
}
.btn.outline, 
.entry-content .wp-block-kadence-advancedbtn .kb-button.outline {
	outline: 1px solid var(--white);
	outline-offset: -1px;
	background: oklch(var(--black-base) / 75%);
}
.btn.outline:hover, 
.entry-content .wp-block-kadence-advancedbtn .kb-button.outline:hover {
	background: var(--grey-medium);
}
.btn.arrow:after {
	content: url('images/arrow-btn.svg');
	display: inline-block;
	margin-left: 1rem;
	transform: rotate(0) translate(0);
    transition: var(--in);
}
.btn.arrow:hover:after {
	transform: rotate(45deg) translate(0, 0);
    animation: moveArrow 0.4s ease-in-out infinite alternate;
    animation-delay: 0.15s;
    transition: var(--out);
}
@keyframes moveArrow {
  0% {
    transform: rotate(45deg) translate(0, 0);
  }
  100% {
    transform: rotate(45deg) translate(4px, -4px);
  }
}
input[type="submit"] {
	border: none;
	margin-top: 0; 
}
.btn-row {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap; 
}
.btn-row.centered {
	justify-content: center;
}
.btn-row.right-align {
	justify-content: flex-end;
}



/* ------ NAVIGATION ----- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	width: 100%;
	background: var(--white);
	box-shadow: var(--shadow);
}
.site-header.is-locked {
	box-shadow: var(--shadow);
}
.site-header-wrapper {
	max-width: var(--page-max-width);
	margin: 0 auto;
	padding-inline: var(--gutter);
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.site-branding,
.site-logo {
	display: inline-block;
	height: 100%;
	position: relative;
    z-index: 11;
}
.site-header-wrapper .tagline {
	font-size: var(--fs-md);
}
.site-header .site-logo {
	max-height: 100%;
	padding-block: 1rem;
	transform: scale(1);
	transition: var(--in);
}
.site-header .site-logo:hover {
	transform: scale(1.1);
	transition: var(--out);
}
.site-header .site-logo img {
	height: 100%;
	max-height: 100%;
}
.site-header .site-logo,
.site-header .site-logo img {
	height: calc(99px + 2rem);
	width: auto;
	transition: var(--in);
}
.site-header.is-locked .site-logo,
.site-header.is-locked .site-logo img {
	height: calc(70px + 2rem);
	width: auto;
	transition: var(--out);
}
.site-header .menu-toggle, 
.site-header .search-toggle {
	padding: 0;
    border: none;
    background: none;
	cursor: pointer;
	line-height: 0;
}
.site-header .menu-toggle svg rect,
.site-header .search-toggle svg path {
	fill: var(--primary);
	transition: var(--in);
}
.site-header .menu-toggle:hover svg rect,
.site-header .search-toggle:hover svg path {
	fill: var(--primary);
	transition: var(--out);
}
.main-navigation {
	display: flex;
	align-items: center;
	gap: 2.5rem;
	justify-self: end;
}
.main-navigation .menu {
	display: flex;
	align-items: center;
	gap: 2rem;
}
:where(.menu, .sub-menu) {
	margin: 0;
	padding: 0;
	list-style: none;
}
.sub-menu {
	position: absolute;
	align-items: center;
}
.main-navigation .menu-item:has(.sub-menu):hover .sub-menu {
	display: flex;
	flex-direction: column;
}
@media (width > 1080px) {
	.menu-toggle {
		display: none;
	}
}
@media (width <= 1080px) {
	.main-navigation .menu-main-menu-container {
		display: none;
	}
}
@media (width <= 782px) {
	.site-header-wrapper {
		padding-inline: calc(var(--gutter) / 2);
	}
	.site-header .site-logo,
	.site-header .site-logo img {
		height: calc(46px + 2rem);
		width: auto;
		transition: var(--in);
	}
	.site-header.is-locked .site-logo,
	.site-header.is-locked .site-logo img {
		height: calc(46px + 2rem);
		width: auto;
		transition: var(--out);
	}
}
@media (width <= 525px) {
	.site-header-wrapper .tagline {
		display: none;
	}
}

/* MENU ITEM STYLING */
.menu-item {
	position: relative;
}
.menu-item a {
	color: var(--grey-medium);
	text-decoration: none;
	position: relative;
	display: inline-block;
	padding: 0.75rem;
	transition: var(--in);
}
.menu-item:hover a {
	color: var(--primary);
	transition: var(--out);
}
.menu-item.callout a {
	color: var(--white);
	background: var(--primary);
	padding: 0.75rem 2rem;
	border-radius: 0.5rem;
	display: flex;
	gap: 0.5rem;
}
.menu-item.callout a:hover {
	background: var(--grey-medium);
}
.main-navigation #primary-menu > .current-menu-item:not(.callout) > a,
.main-navigation #primary-menu > .current_page_ancestor:not(.callout) > a {
	color: var(--primary);
}
.main-navigation #primary-menu > .current-menu-item:not(.callout) > a:hover,
.main-navigation #primary-menu > .current_page_ancestor:not(.callout) > a:hover {
	color: var(--grey-medium);
}
.site-header .menu > .menu-item .sub-menu .menu-item a {
	display: block;
	padding: 0.5rem 1rem 0.2rem 1rem;
}
.site-header .menu > .menu-item, 
.site-header .menu > .menu-item > .sub-menu > .menu-item {
	position: relative;
}
.site-header .menu > .menu-item > .sub-menu {
	opacity: 0;
	visibility: hidden;
	background: var(--white);
	box-shadow: 0px 4px 16px 0px rgba(0, 0, 0, 0.3);
	position: absolute;
	z-index: 2;
	left: 0.5rem;
	width: max-content;
	transform: translateY(-1rem);
	align-items: flex-start;
	transition: var(--in);
}
.site-header .menu > .menu-item > .sub-menu > .menu-item {
	width: 100%;
}
.site-header .menu > .menu-item > .sub-menu a {
	color: var(--primary);
}
.site-header .menu > .menu-item > .sub-menu a:hover {
	color: var(--grey-medium);
}
.site-header .menu > .menu-item:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition: var(--out);
}
.site-header .menu > .menu-item > .sub-menu > .menu-item > .sub-menu {
	opacity: 0;
	visibility: hidden;
	background: var(--white);
	box-shadow: 0px 4px 16px 0px rgba(0, 0, 0, 0.3);
	position: absolute;
	left: 100%;
	top: 0;
	width: max-content;
	transform: translateX(-1rem);
	transition: var(--in);
}
.site-header .menu > .menu-item > .sub-menu > .menu-item:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(0);
	transition: var(--out);
}



/* ----- ADMIN BAR FIXES ----- */
#wpadminbar {
	position: fixed!important;
}
body.admin-bar.no-scroll {
	height: calc(100vh - var(--admin-bar-height));
}
.admin-bar .site-header {
	top: var(--admin-bar-height);
}
.admin-bar .drawer {
	top: calc(var(--admin-bar-height) + var(--header-height));
}
.admin-bar .site-header.is-locked {
	top: var(--admin-bar-height)!important;
}
.admin-bar .hero .metaslider .flex-viewport,
.admin-bar .hero .metaslider .slides,
.admin-bar .hero .metaslider .slides li,
.admin-bar .hero .metaslider .flexslider img,
.admin-bar .hero .metaslider .video-js .vjs-tech {
	height: calc(100vh - 6rem - var(--admin-bar-height) - var(--header-height));
	max-height: calc(100vh - 6rem - var(--admin-bar-height) - var(--header-height));
	min-height: var(--hero-min-height);
}
@media (width <= 782px) {
	body.admin-bar.no-scroll {
		height: calc(100vh - var(--admin-bar-height));
	}
	.admin-bar .site-header,
	.admin-bar .drawer {
		top: var(--admin-bar-height);
	}
	.admin-bar .hero .metaslider .flex-viewport,
	.admin-bar .hero .metaslider .slides,
	.admin-bar .hero .metaslider .slides li,
	.admin-bar .hero .metaslider .flexslider img,
	.admin-bar .hero .metaslider .video-js .vjs-tech {
		height: calc(100vh -  var(--admin-bar-height));
		max-height: calc(100vh - var(--admin-bar-height));
	}	
}



/* ----- DRAWER ----- */
.drawer {
	position: fixed;
	top: var(--header-height);
	right: 0;
	bottom: 0;
	width: 100%;
	height: calc(100vh - var(--header-height));
	background-color: var(--primary);
	z-index: 99;
	transform: translateY(calc(-100% - var(--header-height)));
	transition: var(--in);
}
.drawer.is-open {
	transform: translateY(0px);
	transition: var(--out);
}
.drawer-wrapper {
	display: flex;
	align-items: start;
	justify-content: space-between;
	height: 100%;
	padding: var(--gutter);
}
.drawer .drawer__menu-toggle {
	fill: var(--white);
	cursor: pointer;
	order: 2;
}
.drawer-navigation {
	width: 100%;
	height: 100%;
	overflow-y: auto;
	order: 1;
}
.drawer .menu-main-menu-container {
	height: 100%;
}
.drawer .menu {
	display: flex;
	flex-direction: column;
	height: 100%;
	gap: 1rem;
}
.drawer .menu-item a {
	display: block;
	font-size: var(--fs-md);
	padding: 0 2rem;
	color: var(--white)!important;
}
.drawer .menu-item.callout a {
	width: fit-content;
	color: var(--primary)!important;
	background: var(--white);
	padding: 0.75rem 2rem;
	border-radius: 0.5rem;
	display: flex;
	gap: 0.5rem;
}
.drawer .sub-menu .menu-item a {
	padding: 0.5rem 0;
}
.drawer .sub-menu {
	display: none;
}
.drawer .sub-menu .menu-item a {
	font-size: var(--fs-md);
}
@media (width <= 782px) {

}



/* SEARCH WRAP */
.search-wrap {
    display: flex;
	justify-content: center;
	width: fit-content;
    grid-template-columns: 1fr auto;
    background: var(--primary);
    position: absolute;
    opacity: 0;
	pointer-events: none;
    visibility: hidden;
    width: 100%;
	padding-inline: var(--gutter);
	padding-block: 1rem;
    right: 0;
	top: 0;
    margin-inline: auto;
    z-index: 10;
    transform-origin: top;
    transition: var(--in);
}
.search-wrap.active {
	position: sticky;
	top: var(--header-height);
    opacity: 1;
    visibility: visible;
	pointer-events: all;
    transition: var(--out);
}
.search-form {
	display: flex;
    align-items: center;
	width: fit-content;
}
.search-wrap .search-box-wrapper {
	padding: 0.5rem 1rem;
    border-radius: 999rem;
	margin-right: 1rem;
	background: var(--white);
	display: inline-grid;
	grid-template-columns: auto auto;
	align-items: center;
	position: relative;
}
.search-wrap .search-box-wrapper:after,
.search-wrap .search-box-wrapper input,
.search-wrap .search-box-wrapper textarea {
	width: auto;
	min-width: 1em;
	font: inherit;
	padding: 0.25em;
	margin: 0;
	resize: none;
	background: none;
	appearance: none;
	border: none;
}
.search-wrap .search-box-wrapper:after {
	content: attr(data-value) ' ';
	visibility: hidden;
	white-space: nowrap;
	font: inherit;
	grid-column: 1;
	grid-row: 1;
	pointer-events: none;
}
.search-box-wrapper:focus-within textarea:focus,
.search-box-wrapper:focus-within input:focus {
	outline: none;
}
.search-box {
	width: 100%;
	grid-column: 1;
	grid-row: 1;
	position: relative;
	z-index: 2;
	border: none;
	background: none;
	color: var(--black);
	text-align: left;
	padding: 0.5rem;
	min-width: 100%;
    margin-right: 0.5rem;
}
.search-box::placeholder {
	color: var(--black);
	opacity: 1;
	transition: var(--in);
}
.search-box:focus::placeholder {
	color: var(--black);
	opacity: 0.5;
	transition: var(--out);
}
.search-wrap .search-form {
	background: none;
}
.search-icon {
	display: flex;
	grid-column: 2;
	grid-row: 1;
	position: relative;
	z-index: 2;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
}
.search-icon svg {
	transition: var(--in);
}
.search-exit {
	flex: 0 0 auto;
	cursor: pointer;
	fill: var(--white);
	transition: var(--in);
}
.search-icon:hover svg,
.search-exit:hover {
	fill: var(--grey-medium);
	transition: var(--out);
}
@media (width <= 1780px) {
	.search-wrap {
		max-width: calc(100vw - (var(--gutter) * 2) - 18.2rem - 225px);
	}
}
@media (width <= 1080px) {
	.search-wrap {
		right: 3.4rem;
		max-width: calc(100vw - (var(--gutter) * 2) - 2rem - 225px);
	}
}



/* ----- CONTENT ----- */
.content .swiper-wrapper {
	box-sizing: border-box !important;
}
.content .swiper {
	max-width: 100%;
	min-width: 0;
	width: 100%;
}
.content .row-inner > .col,
.content .swiper-container {
	min-width: 0;
    width: 100%;
}
.content .swiper ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.content .swiper ul li.swiper-slide {
	min-width: 0;
}
.content .swiper ul li img {
	display: block;
	width: 100%;
	height: auto;
}
.swiper .swiper-button-prev,
.swiper .swiper-button-next {
    user-select: none;
}
.content .page > .entry-footer,
.content .post > .entry-footer {
	display: none;
}
.content .entry-content > .wp-block-kadence-rowlayout > .kt-row-column-wrap {
	max-width: var(--page-max-width);
	margin: 0 auto;
	padding-inline: var(--gutter);
}
.content span.post-edit-link {
	display: block;
}
.template-part .row,
.content .row {
	display: grid;
	padding-top: var(--row-spacing);
	padding-bottom: var(--row-spacing);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 3rem;
}
.template-part .row.no-btm-padding,
.content .row.no-btm-padding {
	padding-bottom: 0;
}
.template-part > section > .row:last-child,
.content > section > .row:last-child {
	padding-bottom: var(--row-spacing);
}
.template-part .row .row-inner,
.content .row .row-inner {
	width: 100%;
	max-width: var(--page-max-width);
	padding-inline: var(--gutter);
	justify-self: center;
	display: grid;
	grid-template-columns: 1fr;
	grid-gap: 4rem;
	position: relative;
}
.template-part .row .center-v-align,
.content .row .center-v-align {
	align-self: center;
}
.template-part .row .two-col,
.content .row .two-col {
	grid-template-columns: 1fr 1fr;
}
.template-part .row .three-col,
.content .row .three-col {
	grid-template-columns: 1fr 1fr 1fr;
}
.template-part .row .four-col,
.content .row .four-col {
	grid-template-columns: 1fr 1fr 1fr 1fr;
}
.template-part .row .five-col,
.content .row .five-col {
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}
.template-part .row .six-col,
.content .row .six-col {
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
}
.template-part .content .row .seven-col,
.content .row .seven-col {
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
}
.template-part .row .eight-col,
.content .row .eight-col {
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
}
.content .kt-inside-inner-col *:first-child:not(figure):not(div) {
	margin-top: 0;
}
@media (width <= 1080px) {
	.template-part .row .five-col,
	.content .row .five-col {
		grid-template-columns: 1fr 1fr 1fr!important;
	}
}
@media (width <= 1024px) {
	.template-part .row .four-col,
	.content .row .four-col {
		grid-template-columns: 1fr 1fr!important;
	}
	.template-part .row .six-col,
	.content .row .six-col {
		grid-template-columns: 1fr 1fr 1fr!important;
	}
	.template-part .row .eight-col
	.content .row .eight-col {
		grid-template-columns: 1fr 1fr 1fr 1fr!important;
	}
}
@media (width <= 782px) {
	.template-part .row .row-inner,
	.content .row .row-inner {
		grid-gap: 2rem;
	}
	.template-part .row .row-inner,
	.content .row .row-inner,
	.content .kb-row-layout-wrap .kt-row-column-wrap {
		grid-template-columns: auto!important;
	}
	.template-part .row .five-col
	.content .row .five-col {
		grid-template-columns: 1fr 1fr!important;
	}
	.template-part .two-col > .text,
	.content .kb-row-layout-wrap .kt-row-column-wrap > .text,
	.content .two-col > .text {
		order: 1;
	}
	.template-part .two-col > .image,
	.content .kb-row-layout-wrap .kt-row-column-wrap > .image,
	.content .two-col > .image {
		order: 2;
	}
	.content .kt-inner-column-height-full {
		grid-auto-rows: minmax(0, auto)!important;
	}
}



/* ----- FRONT PAGE ----- */

/* Hero */
.hero {
	padding-block: calc(var(--row-spacing) * 1.5);
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero .text {
	width: 100%;
	max-width: var(--page-max-width);
	padding-inline: var(--gutter);
	margin: 0 auto;
	position: relative;
	z-index: 3;
}
.hero .text * {
	color: var(--white);
	max-width: 38rem;
}
.hero .text h4 {
	font-size: var(--fs-lg);
	font-weight: 400;
}
.hero .text h2 {
	font-size: var(--fs-4xl);
	margin-bottom: 1rem;
}
.hero .text p {
	font-size: var(--fs-md);
}
.hero .text .btn.primary:hover {
	background: var(--grey-medium);
}
.hero .bg {
	position: absolute;
	inset: 0;
	z-index: 1;
	height: 100%;
	width: 100%;
}
.hero .bg:before {
	content: '';
	height: 100%;
	width: 100%;
	position: absolute;
	inset: 0;
	z-index: 2;
	background: linear-gradient(to right, oklch(var(--black-base) / 90%) 0%, oklch(var(--black-base) / 10%) 100%);
}
.hero .bg img,
.hero .bg video,
.hero .bg video img {
	height: 100%;
	width: 100%;
	object-fit: cover;
}
.hero .metaslider .flex-viewport,
.hero .metaslider .slides,
.hero .metaslider .slides li,
.hero .metaslider .flexslider img,
.hero .metaslider .video-js .vjs-tech {
	height: calc(100vh - 6rem - var(--header-height));
	max-height: calc(100vh - 6rem - var(--header-height));
	min-height: var(--hero-min-height);
}
.hero .metaslider .flexslider {
	margin-bottom: 0;
}
.hero .metaslider .flexslider img,
.hero .metaslider .video-js .vjs-tech {
	object-fit: cover;
	min-height: var(--hero-min-height);
}
.hero .metaslider .ms-external-video div.video-js {
	padding-bottom: 0!important;
	height: 100%!important;
}
.hero .metaslider .flexslider .slides > ul {
	position: relative;
}
.hero .metaslider .flexslider .slides > li {
	overflow: hidden;
	height: 100%;
}
.hero .metaslider .flexslider .caption-wrap {
	opacity: 1!important;
	background: transparent!important;
}
@media (width <= 782px) {
	.hero .metaslider .flex-viewport,
	.hero .metaslider .slides,
	.hero .metaslider .slides li,
	.hero .metaslider .flexslider img {
		height: calc(100vh - var(--header-height));
		min-height: var(--hero-min-height);
		max-height: 800px!important;
	}	
}

/* Intro */
.content > .intro {
	position: relative;
	margin-bottom: 2rem;
}
.content > .intro:after {
	content: '';
	display: block;
	background: var(--grey-medium);
	width: calc(100% - var(--gutter) * 2);
	max-width: calc(var(--page-max-width) - var(--gutter) * 2);
	height: 1px;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
}
.content > .intro .row-inner {
	grid-template-columns: 1.35fr 1fr;
}
.content > .intro .col {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.content > .intro h2,
.content > .intro p {
	margin: 0;
}
@media (width <= 782px) {
	.content > .intro {
		margin-bottom: 1rem;
	}
}

/* Services */
.content .services .row {
	padding-bottom: calc(var(--row-spacing) * 1.5)!important;
}
.content .services .row-inner {
	grid-auto-rows: 1fr;
}
.content .service-card {
	position: relative;
	border-radius: 0.5rem;
	overflow: clip;
	padding-top: 2rem;
	background: var(--grey-medium);
}
.content .service-card .card-bg {
	position: relative;
	z-index: 1;
	top: -2rem;
	left: 0;
	height: 100%;
	width: 100%;
	object-fit: cover;
	transform: translateY(0);
	transition: var(--in);
}
.content .service-card:hover > .card-bg {
	transform: translateY(-35%);
	transition: var(--out);
}
.content .service-card .card-content {
	position: absolute;
	z-index: 2;
	bottom: 0;
	width: 100%;
	background: var(--grey-medium);
	padding: 1.25rem 2rem;
	transform: translateY(calc(100% - (40px + var(--service-card-title-height))));
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	transition: var(--in);
}
.content .service-card:hover > .card-content {
	transform: translateY(0);
	transition: var(--out);
}
.content .service-card .card-content * {
	color: var(--white);
	margin: 0;
}
.content .service-card .card-content h3 {
	font-size: var(--fs-lg);
}
.content .service-card .card-content .btn {
	width: fit-content;
}
.content .service-card .card-content .btn:hover {
	background: var(--grey-light);
}
.content .service-card .card-content p,
.content .service-card .card-content .btn {
	opacity: 0;
	transform: translateY(2rem);
	transition: var(--in);
}
.content .service-card:hover > .card-content p,
.content .service-card:hover > .card-content .btn {
	opacity: 1;
	transform: translateY(0);
	transition: var(--out);
	transition-delay: 0.1s;
}
@media (width <= 1080px) {
	.content .services .row-inner {
		grid-gap: 5vw;
	}
	.content .service-card {
		padding-top: 0;
		display: flex;
    	flex-direction: column;
	}
	.content .service-card .card-bg {
		display: block;
		border-radius: 0.5rem 0.5rem 0 0;
		aspect-ratio: 16 / 9;
		inset: auto;
		height: auto;
	}
	.content .service-card:hover > .card-bg {
		transform: translateY(0);
		transition: var(--out);
	}
	.content .service-card .card-content {
		padding: 1.25rem;
		inset: auto;
		position: static;
		flex-grow: 1;
	}
	.content .service-card .card-content p {
		flex-grow: 1;
	}
	.content .service-card .card-content,
	.content .service-card .card-content p,
	.content .service-card .card-content .btn {
		opacity: 1!important;
		transform: none!important;
	}
}
@media (width <= 782px) {
	.content .services .row-inner {
		grid-auto-rows: auto;
	}
}

/* Services */
.content .core-values {
	position: relative;
}
.content .core-values .row {
	padding-block: calc(var(--row-spacing) * 1.5)!important;
}
.content .core-values .row-inner {
	position: relative;
	z-index: 2;
}
.content .core-values .row-inner:first-of-type {
	display: flex;
    flex-direction: column;
    align-items: center;
}
.content .core-values h2 {
	margin-bottom: 0;
}
.content .core-values p {
	margin-bottom: 1rem;
}
.content .core-values h2,
.content .core-values p {
	color: var(--white);
}
.content .core-values h4,
.content .core-values h2,
.content .core-values p {
	text-align: center;
}
.content .core-values h2,
.content .core-values p {
	max-width: 34rem;
}
.content .core-values .three-col {
	grid-gap: 2rem!important;
}
.content .core-value-card {
	background: var(--white);
	padding: 2rem;
	border-radius: 0.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2rem;
	box-shadow: 0 0 20px 5px oklch(var(--black-base) / 10%);
}
.content .core-value-card * {
	margin: 0;
}
.content .core-value-card h3 {
	text-transform: uppercase;
	font-weight: 700;
}
.content .core-value-card ul {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.content .core-value-card ul,
.content .core-value-card li {
	color: var(--grey-medium);
}
.content .core-values .core-values-bg {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: var(--black);
	height: calc(100% - 14rem);
}
.content .core-values .core-values-bg img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	opacity: 0.3;
}

@media (width <= 782px) {
	.content .core-values .row {
		gap: 2rem;
	}
}

/* About */
.content .about .col {
	align-content: center;
}
.content .about h2 {
	max-width: 30rem;
	margin-bottom: 1.5rem;
}
.content .about .btn {
	margin-top: 2rem;
}
.content .about .combined {
	position: relative;
	margin-bottom: 15%;
}
.content .about .main-image {
	border-radius: 0.5rem;
	width: 87%;
	margin-left: 13%;
}
.content .about .logo {
	position: absolute;
	bottom: -20%;
	left: 0;
	width: 45%;
	outline: 0.5rem solid var(--white);
	border-radius: 0.75rem;
}
@media (width <= 782px) {
	.content .about .btn {
		margin-top: 0;
		margin-bottom: 1rem;
	}
}

/* Logos */
.content .logos {
	background: var(--grey-light);
	margin-top: var(--row-spacing);
}
.content .logos .row-inner {
	max-width: 100%;
}
.content .logos .row-inner a {
	display: flex;
	justify-content: center;
	opacity: 0.5;
	transform: scale(1);
	transition: var(--in);
}
.content .logos .row-inner a:hover {
	opacity: 1;
	transform: scale(1.1);
	transition: var(--out);
}
.content .logos .row-inner a img {
	object-fit: contain;
	max-width: 180px;
}
@media (width <= 782px) {
	.content .logos {
		margin-top: 0;
	}
	.content .logos .row-inner {
		width: fit-content;
		grid-template-columns: repeat(3, 1fr)!important;
	}
	.content .logos .row-inner a img {
		max-width: 4rem;
	}
	.content .about .combined {
		margin-bottom: 12%;
	}
}


/* ----- FOOTER ----- */
.site-footer {
	background: var(--grey-dark);
	padding-block: calc(var(--row-spacing) * 1.5);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: 100%;
}
.site-footer .top,
.site-footer .bottom {
	width: 100%;
	max-width: var(--page-max-width);
	padding-inline: var(--gutter);
	display: flex;
	gap: 3rem;
	align-items: center;
	justify-content: space-between;
}
.site-footer .top {
	position: relative;
	padding-bottom: 3rem;
}
.site-footer .top:after {
	content: '';
	display: block;
	height: 1px;
	width: calc(100% - (var(--gutter) * 2));
	background: oklch(var(--white-base) / 18%);
	position: absolute;
	bottom: 0;
	left: var(--gutter);
}
.site-footer .logo-link {
	transform: scale(1);
	transition: var(--in);
}
.site-footer .logo-link:hover {
	transform: scale(1.1);
	transition: var(--out);
}
#footer-menu {
	display: flex;
	flex-direction: row;
	gap: 1rem;
}
#footer-menu li a {
	color: oklch(var(--white-base) / 70%);
}
#footer-menu li a:hover {
	color: oklch(var(--white-base) / 100%);
}
#footer-menu .callout a {
	color: oklch(var(--white-base) / 70%)!important;
	background: none!important;
	padding: 0.75rem!important;
}
#footer-menu .callout a:hover {
	color: oklch(var(--white-base) / 100%)!important;
}
#footer-menu > .current-menu-item > a, 
#footer-menu > .current_page_ancestor > a {
	color: oklch(var(--white-base) / 100%)!important;
}
.footer-socials {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
}
.footer-socials a {
	padding: 0.85rem;
	height: 3rem;
	width: 3rem;
	display: flex;
	justify-content: center;
	border-radius: 99rem;
	border: 1px solid var(--white);
	background: transparent;
	opacity: 0.7;
	transition: var(--in);
}
.footer-socials a:hover {
	border: 1px solid var(--primary);
	background: var(--primary);
	opacity: 1;
	transition: var(--out);
}
.footer-socials .callout {
	background: transparent;
	border: 1px solid var(--white)!important;
}
.footer-socials .callout:hover {
	border: 1px solid var(--primary)!important;
}
.site-footer .bottom {
	padding-top: 3rem;
}
.site-footer .contact {
	display: flex;
	gap: 3rem;
	flex-wrap: wrap;
}
.site-footer .contact-single {
	display: flex;
	align-items: center;
	text-decoration: none;
	gap: 0.5rem;
}
.site-footer .contact-single .icon {
	padding: 0.85rem;
	height: 3rem;
	width: 3rem;
	display: flex;
	justify-content: center;
	border-radius: 99rem;
	background: oklch(var(--white-base) / 10%);
	transition: var(--in);
}
.site-footer .contact-single:hover .icon {
	background: var(--primary);
	transition: var(--out);
}
.site-footer .contact-single .content {
	display: flex;
	flex-direction: column;
	text-align: left;
}
.site-footer .contact-single .title {
	color: oklch(var(--white-base) / 75%);
	font-size: var(--fs-sm);
}
.site-footer .contact-single .copy {
	color: var(--white);
	font-size: var(--fs-md);
	font-weight: 500;
}
.footer-copyright p {
	margin: 0;
	font-size: var(--fs-sm);
	color: oklch(var(--white-base) / 60%);
}
.footer-copyright p a {
	text-decoration: none;
	color: oklch(var(--white-base) / 60%);
	transition: var(--in);
}
.footer-copyright p a:hover {
	color: oklch(var(--white-base) / 100%);
	transition: var(--out);
}
@media (width <= 1080px) {
	.site-footer .top {
		display: grid;
		grid-template-columns: auto auto;
	}
	.site-footer .top .logo-link {
		grid-column: span 2;
		justify-self: left;
	}
	.site-footer .top .footer-navigation {
		order: 2;
		align-self: start;
	}
	.site-footer .top .footer-socials {
		order: 3;
	}
	.site-footer .bottom {
		display: grid;
        grid-template-columns: 1fr 80px;
	}
	.footer-copyright {
		text-align: right;
		grid-column: span 2;
		justify-self: end;
	}
}
@media (width <= 782px) {
	.site-footer {
		padding-block: calc(var(--gutter) * 0.6);
	}
	.site-footer .top {
		display: grid;
		grid-template-columns: 1fr 48px;
		gap: 2rem;
	}
	.site-footer .top .logo-link {
		grid-column: span 2;
		justify-self: left;
	}
	.site-footer .top .footer-socials {
		flex-direction: column;
		align-self: start;
	}
	#footer-menu {
		flex-direction: column;
		margin-left: -0.75rem;
		margin-top: -0.75rem;
		gap: 0.5rem;
	}
	#footer-menu li {
		width: fit-content;
	}
	.site-footer .bottom {
		gap: 1.5rem;
	}
	.site-footer .contact {
		gap: 1.5rem;
	}
	.site-footer .bottom .logo-link {
		align-self: end;
	}
}


/* ----- INSIDE PAGES ----- */
.wp-block-kadence-image img {
	display: block;
}

/* Featured Image */
.site > .featured {
	width: 100%;
	position: relative;
}
.featured .featured-image {
	height: 100%;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: var(--grey-dark);
}
.featured .featured-image img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	object-position: 50% 50%;
	opacity: 20%;
}
.featured .featured-title {
	height: 100%;
    width: 100%;
    position: relative;
    display: flex;
    align-items: center;
    padding: 6rem 0 14rem 0;
    justify-content: center;
    color: var(--white);
}
.featured .featured-title h1 {
	width: fit-content;
	color: var(--white);
}

/* Sticky Elements */
.content .kb-section-is-sticky > .kt-inside-inner-col {
	top: calc(var(--header-height) + var(--gutter));
}
.admin-bar .content .kb-section-is-sticky > .kt-inside-inner-col {
	top: calc(var(--header-height) + var(--admin-bar-height) + var(--gutter));
}

/* First Row Styling */
.content .kb-row-layout-wrap:first-of-type {
	margin-top: -14rem;
}
.content .kb-row-layout-wrap:first-of-type .kt-row-column-wrap .kt-inside-inner-col {
	padding-inline: var(--gutter);
	background: var(--white);
	box-shadow: 0 5px 20px oklch(var(--black-base) / 10%);
	border-radius: 0.5rem;
	overflow: clip;
}


/* ----- Search Page ----- */
body.search .content article {
	margin-bottom: 4rem;
}
body.search .content article:last-of-type {
	margin-bottom: 0;
}
body.search .content article a {
	text-decoration: none;
}
body.search .content article p {
	width: var(--max-w-text);
	margin-bottom: 0;
}



/* ----- Search Bar ----- */
.content .search-box-wrapper {
	background: var(--light-gray);
	padding: 0.5rem 1rem;
    border-radius: 999rem;
	display: inline-grid;
	gap: 0.5rem;
    grid-template-columns: auto auto;
	align-items: center;
	position: relative;
}
.content .search-box-wrapper:after,
.content .search-box-wrapper input,
.content .search-box-wrapper textarea {
	width: auto;
	min-width: 1em;
	font: inherit;
	padding: 0.25em;
	margin: 0;
	resize: none;
	background: none;
	appearance: none;
	border: none;
}
.content .search-box-wrapper:after {
	content: attr(data-value) ' ';
	visibility: hidden;
	white-space: pre-wrap;
	font: inherit;
	grid-column: 1;
	grid-row: 1;
	pointer-events: none;
}



/* ----- 404 ERROR PAGE ----- */
body.error404 .content .error-options {
	margin-top: 0;
}
body.error404 .content .error-options {
	margin-top: 0;
}
body.error404 .content .error-message,
body.error404 .content .error-options,
body.error404 .content .error-search {
	text-align: center;
	justify-self: center;
}
body.error404 .content .search-exit {
	display: none;
}


/* ----- KEYFRAMES ----- */



/* ----- LIVE FIXES ----- */
