/*
 * Theme Name: 321 Base Theme
 * Theme URI: https://www.321webmarketing.com/
 * Author: 321 Web Marketing
 * Author URI: https://www.321webmarketing.com/
 * Description: 321 inspired theme for the Genesis Framework.
 * Version: 1.0.01
 * License: GPL-3.0-or-later
 * License URI: http://www.gnu.org/licenses/gpl-3.0.html
 * Text Domain: tto-base-theme
 * Domain Path: /languages
 * Template: genesis
 */

@charset 'UTF-8';

/* # Table of Contents

- Elements
- Structural
- Accessibility
- Header
- Footer
- Utility
- Blocks
- Custom CSS

*/

/* ## Elements
--------------------------------------------- */

html {
	line-height: 1.15;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	box-sizing: border-box;
	max-width: 100vw;
	font-size: 62.5%;
	overflow-x: hidden;
}

body {
	background-color: #111111;
	max-width: 100vw;
	color: #ffffff;
	font-family: 'Titillium Web', Helvetica, Arial, sans-serif;
	font-size: 2rem;
	font-weight: 400;
	line-height: 1.618;
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: grayscale;
	margin: 0;
	overflow-x: visible;
}

article,
aside,
footer,
header,
nav,
section,
figcaption,
figure,
main {
	display: block;
}

pre {
	font-family: monospace, monospace;
	font-size: 1.8rem;
}

*::-moz-selection {
	background-color: #a8232e;
	color: #ffffff;
}

*::selection {
	background-color: #a8232e;
	color: #ffffff;
}

h1 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 4.5rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 3rem;
}

h2 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 3.8rem;
	font-weight: 700;
	/* line-height: 1.3; */
	line-height: 1;
	margin: 0.5rem 0 3rem;
}

h3 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 2.8rem;
	font-weight: 500;
	line-height: 1.4;
	margin: 0.5rem 0 1.5rem;
}

h4 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 1.5;
	margin: 0.5rem 0 3rem;
}

h5 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.4;
	margin: 0.5rem 0 3rem;
}

h6 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.5;
	margin: 0.5rem 0 3rem;
	text-transform: uppercase;
}

p {
	margin: 0 0 4rem;
	padding: 0;
}

p:last-child {
	margin: 0;
}

a {
	color: #ffffff;
	word-wrap: break-word;
	pointer-events: all;
	cursor: pointer;
	text-decoration: none;
	transition: 0.25s ease-in-out all
}

a:hover,
a:focus {
	color: #9a9fa6;
}

button,
a.button,
input[type='submit'] {
	background-color: #a8232e;
	margin-top: 1rem;
	border: 0;
	border-radius: 0.3rem;
	color: #ffffff;
	cursor: pointer;
	font-family: 'Rajdhani', sans-serif;
	font-size: 15px;
	font-size: 1.5rem;
	font-weight: 500;
	padding: 1.1em 2.4em;
	text-decoration: none;
	display: inline-block;
	width: auto;
	height: auto;
	line-height: 1;
	box-shadow: 0 1rem 2rem -0.5rem rgba(17, 17, 17, 0.2);
	transition: 0.25s ease-in-out all;
}

button:hover,
button:focus,
a.button:hover,
a.button:focus,
input[type='submit']:hover,
input[type='submit']:focus {
	background-color: #9a9fa6;
	color: #111111;
	box-shadow: 0 1rem 2rem -0.5rem rgba(17, 17, 17, 0.2);
}

button.white,
a.button.white {
	background-color: #ffffff;
	color: #111111;
}

button.outline,
a.button.outline {
	border: 1px solid #9a9fa6;
	background: transparent;
	color: #ffffff;
	box-shadow: 0 1rem 2rem -0.5rem rgba(17, 17, 17, 0.1);
}

button.outline:hover,
button.outline:focus,
a.button.outline:hover,
a.button.outline:focus {
	background: #9a9fa6;
	color: #111111;
}

button.large,
a.button.large {
	font-size: 18px;
	font-size: 1.8rem;
}

ol,
ul {
	margin: 0 0 4rem 4rem;
	padding: 0;
}

ol ol,
ul ul,
ol ul,
ul ol {
	margin: 0 0 0 4rem;
	padding: 0;
}

ul li {
	list-style-type: disc;
}

li li {
	list-style-type: circle;
}

ol li {
	list-style-type: decimal;
}

ol li li {
	list-style-type: lower-alpha;
}


hr {
	border: 0;
	border-collapse: collapse;
	border-bottom: 1px solid #f0f1f2;
	clear: both;
	padding: 1em 0 0;
	margin: 0 0 2em;
}

b,
strong {
	font-weight: 600;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

small,
.secondary-text {
	font-weight: 300;
}

sub {
	bottom: -0.5rem;
}

sup {
	top: -1rem;
}

blockquote {}

table {}

thead,
tbody {}

tr,
th {}

img {
	display: block;
	max-width: 100%;
}

*:first-child {
	margin-top: 0;
	padding-top: 0;
}

*:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
}

/* ## Structural
--------------------------------------------- */

.wrap,
.basic-page .content-sidebar-wrap,
.entry-content>.wp-block-genesis-blocks-gb-columns>.gb-layout-column-wrap,
.entry-content>.gb-block-container>.gb-container-inside {
	width: var(--theme-wrap-width);
	max-width: var(--theme-wrap-max-width);
	margin: 0 auto;
}

.entry-content>.wp-block-genesis-blocks-gb-columns,
.entry-content>.gb-block-container {
	padding: var(--theme-section-padding) 0;
}

.entry-content>.wp-block-genesis-blocks-gb-columns.no-padding-top,
.entry-content>.gb-block-container.no-padding-top {
	padding-top: 0 !important;
}

.entry-content>.wp-block-genesis-blocks-gb-columns.no-padding-bottom,
.entry-content>.gb-block-container.no-padding-bottom {
	padding-bottom: 0 !important;
}

.entry-content>.wp-block-genesis-blocks-gb-columns.no-padding,
.entry-content>.gb-block-container.no-padding {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

@media (max-width: 767px) {

	.wrap,
	.basic-page .content-sidebar-wrap,
	.entry-content>.wp-block-genesis-blocks-gb-columns>.gb-layout-column-wrap,
	.entry-content>.gb-block-container>.gb-container-inside {
		width: 100%;
		max-width: 100%;
		margin: 0;
		padding: 0 var(--theme-wrap-padding-mobile);
	}

	.entry-content>.wp-block-genesis-blocks-gb-columns,
	.entry-content>.gb-block-container {
		padding: var(--theme-section-padding-mobile) 0;
	}
}



/* ## Accessibility
--------------------------------------------- */

.screen-reader-text,
.screen-reader-text span,
.screen-reader-shortcut,
.wp-custom-logo .site-title,
.wp-custom-logo .site-description {
	position: absolute !important;
	clip: rect(0, 0, 0, 0);
	height: 0.1rem;
	width: 0.1rem;
	background-color: #fff !important;
	color: #ffffff !important;
	border: 0;
	overflow: hidden;
}

.screen-reader-text:focus,
.screen-reader-shortcut:focus {
	clip: auto !important;
	height: auto;
	width: auto;
	display: block;
	padding: 10px 20px;
	padding: 1rem 2rem;
	z-index: 100000;
	text-decoration: none;
	box-shadow: 0 0 0.2rem 0.2rem rgba(57, 62, 75, 0.1);
}

.more-link {
	position: relative;
	font-style: normal;
}

.genesis-skip-link {
	margin: 0;
}

.genesis-skip-link li {
	height: 0;
	width: 0;
	list-style: none;
}



/* ## Header
--------------------------------------------- */



.site-header {
	background-color: #111111;
	position: sticky;
	width: 100%;
	top: 0;
	left: 0;
	box-shadow: 0 0 1rem rgba(17, 17, 17, 0.5);
	transition: 0.25s ease-in-out box-shadow;
	z-index: 100;
}

.site-header.shrink {
	box-shadow: 0 0 2rem rgba(57, 62, 75, 0.38);
}

.logged-in.admin-bar .site-header {
	top: 32px;
}

@media (max-width: 782px) {
	.logged-in.admin-bar .site-header {
		top: 46px;
	}
}

@media (max-width: 600px) {
	.logged-in.admin-bar .site-header {
		top: 0;
	}
}

.site-header>.wrap {
	display: flex;
	align-items: stretch;
	gap: 6rem;
	justify-content: space-between;
}

.title-area {
	display: flex;
	align-items: center;
	width: 25rem;
	margin: 0 25% 0 0;
	padding: 1rem 0;
}

.title-area a {
	position: relative;
	display: flex;
	width: 100%;
	height: fit-content;
	max-height: 60px;
}

.title-area a img {
	object-fit: contain;
	object-position: left center;
	width: 100%;
	height: 100%;
}

.title-area a img.primary {
	opacity: 1;
	transition: 0.25s ease-in-out opacity;
}

.title-area a img.secondary {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	opacity: 0;
	transition: 0.25s ease-in-out opacity;
}

.site-header.shrink .title-area a img.primary {
	opacity: 0;
}

.site-header.shrink .title-area a img.secondary {
	opacity: 1;
}

.nav-primary {
	display: flex;
	align-items: center;
	gap: 3rem;
	transition: none;
}

.nav-primary>.wrap {
	display: flex;
	align-items: center;
	gap: 3rem;
	width: 100%;
	max-width: 100%;
	height: 100%;
	margin: 0;
}

.nav-primary .menu {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 3rem;
	height: 100%;
	margin: 0;
	pointer-events: all;
	opacity: 1;
	transition: 0.25s ease-in-out opacity;
}

.nav-primary .menu.fade-out {
	pointer-events: none;
	opacity: 0;
}

.nav-primary .menu>.menu-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 3.75rem 0;
	transition: 0.25s ease-in-out all;
}

.site-header.shrink .nav-primary .menu>.menu-item {
	padding: 2.75rem 0;
}

.nav-primary .menu>.menu-item>a {
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 2.5rem;
}






.primary-menu-ctas .gb-layout-column-wrap {
	display: flex;
	align-items: center;
	gap: 3rem;
}

.primary-menu-ctas .gb-block-layout-column {
	flex: 1 1 fit-content;
}

.primary-menu-ctas a.button {
	margin: 0;
}

.mobile-menu-logo {
	display: none;
}

.site-header .progress-bar-container {
	position: absolute;
	background-color: transparent;
	display: block;
	width: 100%;
	height: 4px;
	top: auto;
	bottom: 0;
	left: 0;
}

.site-header .progress-bar {
	background-color: #a8232e;
	display: block;
	width: 0%;
	height: 100%;
	transition: none;
}

/* ## Footer
--------------------------------------------- */









.site-footer>.wrap {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
}

.site-footer-credits.standalone {
	background-color: #111111;
	padding: 1.5rem 0;
	border-top: 1px solid #9a9fa6;
}

.footer-credits p {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	font-size: 1.5rem;
	font-weight: 500;
}

.footer-credits p .separator {
	font-size: 2rem;
	line-height: 0;
	margin: 0 0 0.25rem;
}



/* ## Utility
--------------------------------------------- */













/* ## Blocks
--------------------------------------------- */

/* Breadcrumbs */

.custom-breadcrumbs .breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.8rem;
	margin: 0 0 6rem;
	padding: 0;
}

.custom-breadcrumbs .breadcrumb>span {
	display: flex;
	color: #ffffff;
	font-size: 1.5rem;
	font-weight: 500;
}

.custom-breadcrumbs .breadcrumb>a {
	display: flex;
}

/* Button */

.custom-button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: fit-content;
}

.custom-button.align-left {
	align-items: flex-start;
}

.custom-button.align-right {
	align-items: flex-end;
}

/* Client Logos */

/* Consultation Steps */

/* Custom Image */

/* Home Page Video */

/* Menu Widget */

/* Recent Articles */

/* Search Widget */

.search-widget {
	position: relative;
}

.search-widget[data-search-type="menu"] .search-widget--form {
	position: absolute;
	min-width: 300px;
	right: calc(100% + 3rem);
	pointer-events: none;
	opacity: 0;
	transition: 0.25s ease-in-out opacity;
	z-index: -99;
}

.search-widget[data-search-type="menu"][data-menu-active="true"] .search-widget--form {
	pointer-events: all;
	opacity: 1;
	z-index: 99;
}

.search-widget .search-widget--toggle {
	display: flex;
	width: 30px;
	height: 30px;
}

.search-widget .search-widget--toggle span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 2rem;
	pointer-events: all;
	cursor: pointer;
	opacity: 1;
	transition: 0.25s ease-in-out all;
}

.search-widget .search-widget--toggle span.hide {
	position: absolute;
	top: 0;
	left: 0;
	pointer-events: none;
	cursor: default;
	opacity: 0;
}

.search-widget[data-menu-active="true"] .search-widget--toggle span.show {
	pointer-events: none;
	cursor: default;
	opacity: 0;
}

.search-widget[data-menu-active="true"] .search-widget--toggle span.hide {
	pointer-events: all;
	cursor: pointer;
	opacity: 1;
}

.search-widget .search-form {
	display: flex;
	flex-wrap: wrap;
	row-gap: 1rem;
	width: fit-content;
}

.search-widget .search-form-label {
	flex: 1 1 100%;
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 1.2;
}

.search-widget .submit-container {
	background-color: #111111;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 4rem;
	height: 4rem;
}

.search-widget .submit-container .search-form-cta {
	display: flex;
}

.search-widget .submit-container svg {
	color: #fff;
	width: 1.6rem;
	height: 1.6rem;
}

.search-widget .submit-container input[type='submit'] {
	background-color: transparent;
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	padding: 0;
	border-radius: 0;
	box-shadow: none;
}

.search-widget input[type='submit'].hidden {
	display: none;
}

/* Socials */

.custom-socials {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 2rem;
	width: fit-content;
}

.custom-social--link {
	display: block;
	width: 100%;
	height: 100%;
	line-height: 1;
}

.custom-social--link svg {
	aspect-ratio: 1 / 1;
	color: #222;
	width: 2.4rem;
	height: 2.4rem;
	transition: 0.25s ease-in-out all;
}

.custom-social--link:hover svg {
	color: #555;
}

/* Team Members */

body.single,
body.blog {
	overflow-x: visible;
}

.single-post-container,
.blog-archive-container {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 6rem;
}

.single-post-container .content,
.blog-archive-container .content {
	flex: 1 1 calc(72.5% - 3rem);
	width: 100%;
}

.single-post-container .sidebar,
.blog-archive-container .sidebar {
	flex: 1 1 calc(27.5% - 3rem);
	width: 100%;
}

.single .entry {
	padding: 0;
}

.single .sidebar:not(.fixed) .widget:first-of-type,
.blog .sidebar:not(.fixed) .widget:first-of-type {
	position: sticky;
	top: 0;
	left: 0;
}

@media (max-width: 895px) {

	body.single,
	body.blog {
		overflow-x: hidden;
	}

	.single-post-container,
	.blog-archive-container {
		flex-direction: column;
	}

	.single-post-container .content,
	.single-post-container .sidebar,
	.blog-archive-container .content,
	.blog-archive-container .sidebar {
		flex: auto;
	}

	.single .sidebar:not(.fixed) .widget:first-of-type,
	.blog .sidebar:not(.fixed) .widget:first-of-type {
		position: unset;
	}
}


/* Single Team Member Page */
body.single-team-member {
	color: #ffffff;
	line-height: 1.6;
	font-size: 16px;
}

.team-member {
	display: flex;
	flex-wrap: wrap;
	max-width: 1200px;
	margin: 20px auto;
	padding: 20px;
	background-color: #fff;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

.team-headshot-area {
	flex: 1 1 300px;
	margin-right: 20px;
	text-align: center;
}

.team-headshot-area img {
	max-width: 100%;
	height: auto;
	border: solid 2px #9a9fa6;
	padding: 3rem;
}

.team-info {
	flex: 2 1 300px;
}

.team-member-name {
	font-size: 2em;
	font-weight: bold;
	margin-bottom: 10px;
	color: #ffffff;
}

.team-member-role {
	font-size: 1.2em;
	color: #ffffff;
	margin-bottom: 20px;
}

.team-member-bio {
	font-size: 1em;
	margin-bottom: 20px;
	color: #ffffff;
}

.team-contact-area {
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin: 20px 0 0 0;
}

div.team-contact-area .team-contact a {
	color: #ffffff;
	text-decoration: none;
	font-size: 1.4em;
	display: flex;
	gap: 1rem;
	align-items: center;
	transition: color 0.3s ease;
}

.team-contact a span {
	margin-left: 5px;
}

.team-contact a:hover {
	color: #333;
}

.team-socials-area {
	display: flex;
	justify-content: flex-start;
	margin-bottom: 20px;
}

.team-social {
	margin: 0 10px;
}

div.team-socials-area div.team-social a {
	color: #ffffff;
	font-size: 1.5em;
	transition: color 0.3s ease;
}

.team-social a:hover {
	color: #333;
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

@media (max-width: 800px) {
	.team-member {
		flex-direction: column;
		align-items: center;
	}

	.team-headshot-area {
		margin-right: 0;
		margin-bottom: 20px;
	}

	.team-info {
		text-align: center;
	}
}

/* Team Archive Page */
.team-member-archive {
	display: flex;
	flex-direction: column;
	gap: 5rem;
}

.team-member-items {
	order: 2;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 4rem;
}

.team-member-archive .team-member--link {
	display: flex;
	flex-direction: column;
	width: 100%;
	height: 100%;
}

.team-member-archive .team-member--link:hover {
	transform: translateY(-2px);
	box-shadow: none
}

.team-member-archive .team-member--content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding: 3rem;
}

.team-member-archive .team-member--content-name h2 {
	margin: 0 0 1rem;
	font-size: 2rem;
	letter-spacing: 0;
	word-spacing: 0;
	text-align: center;
	color: #ffffff;
}

.team-member-archive .team-member--content-role p {
	font-size: 1.7rem;
	line-height: 1.4;
	text-align: center;
	color: #ffffff;
}

.team-member-none {
	grid-column: 1 / span 4;
}

.team-member-filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	row-gap: 3rem;
	column-gap: 6rem;
	padding: 0 0 5rem;
	border-bottom: 1px solid var(--mfe-dark-grey);
}

.team-member-filter {
	flex: 1;
	max-width: 400px;
}

.team-member-filter.dept label {
	justify-content: flex-end;
}

.team-member-filter input,
.team-member-filter select {
	margin: 0;
}

@media (max-width: 767px) {
	.team-member-items {
		grid-template-columns: repeat(2, 1fr);
	}

	.team-member-none {
		grid-column: 1 / span 2;
	}

	.team-member-filters {
		flex-direction: column;
	}

	.team-member-filter.dept label {
		justify-content: flex-start;
	}
}

@media (max-width: 600px) {
	.team-member-items {
		grid-template-columns: auto;
	}

	.team-member {
		width: 100%;
		margin: 0 auto;
	}

	.team-member-archive .team-member--headshot img {
		object-fit: cover;
		width: 100%;
		max-height: 270px;
	}

	.team-member-none {
		grid-column: auto;
	}
}

/* Events Archive Page*/
.events-archive {
	position: relative;
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 12rem 0 10rem;
}

.at-content-archive:not(:first-of-type) {
	margin: 12rem 0 0;
}

.at-content-archive--wrapper {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 6rem;
	margin: 6rem 0 0;
}

@media (max-width: 1095px) {
	.at-content-archive .at-content-archive--wrapper {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.at-content-archive .at-content-archive--wrapper {
		grid-template-columns: none;
	}
}

.at-content-box {
	border: 1px solid #cdd9dc;
	box-shadow: -14px 14px 0px #f3f5f6;
	overflow: hidden;
}

.at-content-box {
	display: block;
	width: 100%;
	height: 100%;
	padding: 4rem;
}

.at-content-box .at-content-box--thumbnail {
	margin: -4rem -4rem 4rem;
	overflow: hidden;
}

.at-content-box .at-content-box--thumbnail img {
	aspect-ratio: 2 / 1;
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: 100%;
	transition: 0.25s ease-in-out all;
}

.at-content-box--inner {
	height: fit-content;
}

.at-content-box .at-content-box--title>* {
	transition: 0.25s ease-in-out all;
}

.at-content-box .at-content-box--date p {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 0.6rem;
	font-size: 1.4rem;
	font-weight: 600;
	margin: 0 0 1.5rem;
	color: #ffffff;
}

.at-content-box .at-content-box--cta {
	margin: 2rem 0 0;
}

div.at-content-box--title h3 {
	color: #ffffff;
}

div.at-content-box--description p {
	color: #ffffff;
}

div.at-content-box--cta a.read-more-button {
	color: #ffffff;
}

a.read-more-button {
	display: flex;
	align-items: center;
	gap: 1rem;
}

/* Single Post */
body.single.single-post .header-section {
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	position: relative;
	padding: 11rem 0;
	z-index: 1;
}

body.single.single-post .header-section:before {
	content: '';
	background-color: rgb(30 40 44 / 82%);
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 2;
}

body.single.single-post .header-section>.wrap {
	position: relative;
	width: 90%;
	max-width: 960px;
	margin: 0 auto;
	padding: 0;
	z-index: 3;
}

body.single.single-post .header-section h1 {
	color: #fff;
	font-size: 4.8rem;
	font-weight: 800;
	line-height: 1.12;
	margin: 0;
	text-align: center;
	text-transform: uppercase;
	text-shadow: 0 2px 5px rgba(0, 0, 0, 0.17);
}

body.single.single-post .header-section .entry-meta {
	margin: 1.2rem 0 2rem;
}

body.single.single-post .header-section .entry-meta p {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.8rem;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 500;
	margin: 0;
	text-align: center;
	text-shadow: 0 2px 5px rgba(0, 0, 0, 0.17);
}

body.single.single-post .header-section .entry-meta p>span.entry-meta--separator {
	font-size: 2.2rem;
	margin: 0 0 3px;
}

body.single.single-post .header-section .entry-tagline {
	padding: 0 3rem;
}

body.single.single-post .header-section .entry-tagline p {
	color: #fff;
	font-size: 1.9rem;
	font-weight: 500;
	margin: 0;
	text-align: center;
	text-shadow: 0 2px 5px rgba(0, 0, 0, 0.17);
}

body.single.single-post .content-sidebar-wrap {
	width: 90%;
	max-width: 960px;
	margin: 0 auto;
	padding: 10rem 0;
}

body.single.single-post .entry-content h2 {
	font-size: 3.5rem;
	margin: 0 0 1.2rem;
}

body.single.single-post .entry-content h3 {
	color: #ffffff;
	font-size: 2.6rem;
	line-height: 1;
	margin: 0 0 1rem;
}

body.single.single-post .entry-content h4 {
	color: #ffffff;
	font-size: 1.7rem;
	font-weight: 800;
	line-height: 1.4;
	margin: 0 0 0.8rem;
	padding: 0;
	text-transform: uppercase;
}

body.single.single-post .entry-content p {
	font-size: 1.9rem;
	line-height: 1.5;
}

body.single.single-post .entry-content li {
	font-size: 1.8rem;
	line-height: 1.7;
}

body.single.single-post .entry-content a:not(.button):not(.arrow-cta--link) {
	color: #ffffff;
	font-weight: 600;
	border-bottom: 1.5px solid;
}

body.single.single-post .entry-content p strong {
	font-weight: 700;
}

@media (max-width: 991px) {
	body.single.single-post .header-section h1 {
		font-size: 4.2rem;
	}

	body.single.single-post .entry-content h2 {
		font-size: 3.5rem;
	}
}

@media (max-width: 767px) {
	body.single.single-post .header-section {
		padding: 8rem 0;
	}

	body.single.single-post .header-section h1 {
		font-size: 3.5rem;
		text-align: left;
	}

	body.single.single-post .entry-content h3 {
		font-size: 2.4rem;
	}

	body.single.single-post .header-section h1>br {
		display: none;
	}

	body.single.single-post .header-section .entry-meta p {
		justify-content: flex-start;
		text-align: left;
	}
}

.at-event-flyer {
	width: 500px;
	max-width: 50%;
	margin: 0 0 3rem 3rem;
}

.single.has-toc .entry-content {
	display: flex;
	flex-wrap: wrap;
	column-gap: 4rem;
}

.single.has-toc .entry-content>.table-of-contents {
	flex: 1 1 calc(40% - 11rem);
	/* max-width: calc(40% - 2rem); */

	border: solid 1px #9a9fa6;
	background: #f1f1f1;
	padding: 2rem;
	margin: 2rem;
}

.single.has-toc .entry-content>.table-of-contents+p {
	order: -1;
	flex: 1 1 calc(60% - 2rem);
	/* max-width: calc(60% - 2rem); */
	word-break: break-word;
}

.single.has-toc .entry-content>.table-of-contents h2 {
	font-size: 2.5rem;
	text-align: center;
}

/* Blog CSS Overrides Removed for Layout Stability */

/* Recent Articles Block */

.recent-articles {
	width: 100%;
}

.recent-articles--items-wrapper {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3rem;
	margin: 0 auto;
	width: 90%;
	max-width: 1280px;
}

@media (max-width: 1095px) {
	.recent-articles--items-wrapper {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.recent-articles--items-wrapper {
		grid-template-columns: auto;
		gap: 5vw;
		max-width: 400px;
	}
}

.search-no-results .recent-articles--items-wrapper {
	grid-template-columns: auto;
}

.search-no-results .recent-articles--items-wrapper .wp-block-button {
	text-align: left;
}

.front-page .content .fp7-content .recent-articles .entry-header {
	padding: 4rem;
}

.recent-articles .entry-content p {
	display: none;
}

.recent-articles .entry-image-link {
	width: 100%;
	margin: 0;
	border-radius: 0;
}

div.recent-articles div.entry-content a.entry-image-link img {
	aspect-ratio: 2 / 1;
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: auto;
	border-radius: unset;
	margin-bottom: unset;
	box-shadow: unset;
}

.recent-articles .entry-header {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 4rem 4rem 4rem;
}

.recent-articles .entry-header .entry-title {
	margin: 0;
}

.recent-articles .entry-header .entry-title a {
	font-size: 2.4rem;
	line-height: 1.4;
}

.recent-articles .entry-header .entry-title a:hover {
	color: var(--mg-primary-blue);
}

.recent-articles .entry-content a {
	background-image: none;
	background-color: transparent;
	display: flex;
	align-items: center;
	gap: 1.25rem;
	max-width: 100%;
	color: var(--mg-primary-blue);
	font-weight: 600;
	text-align: left;
	padding: 0;
}

.recent-articles .entry-content a:hover {
	gap: 1.75rem;
	opacity: 0.88;
}

/* Recent Articles Container */

.recent-articles-container {
	text-align: center;
}

.recent-articles-container .wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	padding: 0;
}

.recent-articles-container .wrap:before,
.recent-articles-container .wrap:after {
	display: none;
}

.recent-articles-container .widget {
	width: 100%;
}

.recent-articles-container .pricing-table {
	margin-right: 5vw;
	margin-left: 5vw;
}

.recent-articles-container hr {
	max-width: 88vw;
	margin-right: auto;
	margin-left: auto;
}

.recent-articles-container ul blockquote {
	padding-right: calc(2em + 5vw);
	padding-left: calc(2em + 5vw);
}

/* Recent Articles Container (rac) Content */

.rac-content {
	margin: 6rem 0;
}

.home .content .rac-content .entry.post {
	display: flex;
	flex-direction: column-reverse;
	width: 100%;
	margin: 0;
	padding: 0;
	border: 1px solid #ddd;
	border-radius: 8px;
	box-shadow: 0px 6px 13px -4px rgba(0, 0, 0, 0.22);
	overflow: hidden;
}


/* Consultation Page */

body.consultation-page .site-inner {
	background-color: #fff;
	overflow-x: hidden;
}

body.consultation-page .content>article {
	background-color: #fff;
}

body.consultation-page .content-sidebar-wrap {
	background-color: #fff;
	padding: 7.6rem 0 10rem;
}

body.consultation-page .contact-form-wrapper {
	padding: 5rem 6rem;
	z-index: 1;
}

body.consultation-page .contact-form-wrapper:before {
	content: '';
	background-color: #015974;
	position: absolute;
	display: none;
	width: 200vw;
	height: 100%;
	top: 0;
	left: -100vw;
	z-index: 2;
}

body.consultation-page .contact-form--heading,
body.consultation-page .contact-form--content {
	position: relative;
	z-index: 3;
}

body.consultation-page .contact-form-section--steps {
	width: 100%;
	height: 100%;
	padding-top: 5rem;
}

body.consultation-page .contact-form-section--steps h2,
body.consultation-page .contact-form-section--content h1 {
	font-size: 2.5rem;
	font-weight: 800;
	margin-bottom: 2rem;
}

body.consultation-page .contact-form-section--content h1 {
	color: #ffffff;
	margin-bottom: 0;
}

body.consultation-page .contact-form-section--steps h2 {
	color: #3e4d56;
}

body.consultation-page .contact-form-section--steps .contact-steps--info p {
	color: #3e4d56;
	font-size: 1.9rem;
	line-height: 1.5;
	margin-bottom: 2rem;
}

body.consultation-page .contact-form-section--content {
	background-color: transparent;
	margin-left: 2rem;
}

body.consultation-page .gform_wrapper.gravity-theme {
	margin: 16px 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gform_fileupload_rules {
	font-size: 1.4rem;
}

body.consultation-page .ui-datepicker .ui-datepicker-title select {
	color: #ffffff;
	font-size: 1.5rem;
	font-weight: 600;
	padding: 0 3rem 0 0;
}

body.consultation-page .ui-datepicker .ui-datepicker-calendar span,
body.consultation-page .ui-datepicker .ui-datepicker-calendar a {
	font-size: 1rem !important;
}

body.consultation-page .gform_wrapper.gravity-theme .gform_footer {
	margin-top: 3.2rem;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield label[for*="gform_browse_button"] {
	transform: translateY(4px);
}

body.consultation-page .contact-steps {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}

body.consultation-page .contact-steps--items {
	width: 100%;
	height: 100%;
	padding: 5rem 0 5rem 4rem;
}

body.consultation-page .contact-steps--items-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: 1;
}

body.consultation-page .contact-steps--items-border {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 12px;
	left: -4rem;
	border-left: 2px solid #ddd;
	z-index: 2;
}

body.consultation-page .contact-steps--items-inner {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	height: 100%;
	padding-right: 2rem;
}

body.consultation-page .contact-step {
	position: relative;
	z-index: 3;
}

body.consultation-page .contact-step:before {
	content: '';
	position: absolute;
	display: block;
	top: 7px;
	left: calc(-4rem - 6px);
	width: 14px;
	height: 14px;
	background-color: #111111;
	border-radius: 50%;
	z-index: 9;
}

body.consultation-page .contact-step:last-of-type:after {
	content: '';
	position: absolute;
	display: block;
	top: 12px;
	left: -4rem;
	width: 100%;
	height: 100%;
	/* border-left: 2px solid #f5f5f5; */
	z-index: -1;
}

body.consultation-page .entry-content .contact-step--heading h3 {
	font-size: 2rem;
	font-weight: 700;
	padding: 0;
}

body.consultation-page .entry-content .contact-step--copy p {
	color: #3e4d56;
	font-size: 1.6rem;
	line-height: 1.5;
	margin-bottom: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gform_fields {
	row-gap: 1.5rem;
	column-gap: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield,
body.consultation-page .gform_wrapper.gravity-theme .gfield.static {
	margin: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield.field-spaced {
	margin: 3.5rem 0 7rem;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.ginput_container_select,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.gfield_time_ampm {
	position: relative;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.gfield_time_ampm {
	min-width: 77px;
	max-width: none;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.ginput_container_select select,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.gfield_time_ampm select {
	padding: 5px 12px !important;
	background-color: transparent;
	border-color: #c9cfd0;
	color: #fff;
	border-radius: 4px;
	height: auto;
	line-height: 1.5;
	margin-left: 1px;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.ginput_container_select select:focus,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.gfield_time_ampm select:focus {
	border-color: #fff;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.ginput_container_select:after,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.gfield_time_ampm:after {
	content: '\f078';
	position: absolute;
	display: block;
	top: 1.2rem;
	right: 1.5rem;
	color: #c9cfd0;
	font-size: 1.5rem;
	font-weight: 900;
	font-family: 'Font Awesome 6 Pro';
	pointer-events: none;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container input,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container textarea {
	margin: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container {
	margin-top: 8px;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container input,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container select,
body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container textarea {
	color: #fff;
	font-size: 2rem !important;
	padding: 5px 4px !important;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container input {
	height: 51px !important;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container textarea {
	height: 80px;
	margin-bottom: 2.25rem;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container span.gform_drop_instructions {
	color: #aaa;
	font-size: 2rem;
}

body.consultation-page .site-footer .static-page-cta.widget-area {
	display: none;
}

@media (min-width: 992px) {
	body.consultation-page .contact-main {
		padding: 0 6rem;
	}
}

@media (max-width: 991px) {
	body.consultation-page .content-sidebar-wrap {
		padding-top: 0;
		padding-left: 6rem;
		padding-right: 6rem;
	}

	body.consultation-page .content>article {
		padding-top: 0;
	}

	body.consultation-page .entry-content {
		padding: 0 3vw;
	}

	body.consultation-page .contact-form-wrapper {
		padding: 8rem 0;
	}

	body.consultation-page .contact-form-wrapper:before {
		display: block;
	}

	body.consultation-page .contact-form-section--steps {
		padding-top: 7rem;
	}

	body.consultation-page .contact-form-section--content {
		margin-left: 0;
	}

	body.consultation-page .contact-form-section--steps h2 br {
		display: none;
	}

	.contact-steps--items {
		width: 100%;
		height: 100%;
		padding: 2rem 0 2rem 5rem;
	}

	.contact-steps--items-inner {
		gap: 4rem;
	}
}

@media (max-width: 767px) {
	body.consultation-page .content-sidebar-wrap {
		padding-top: 0;
		padding-left: 6vw;
		padding-right: 6vw;
	}
}

body.consultation-page .gform_wrapper.gravity-theme .gfield_label {
	display: inline-block;
	font-size: 16px;
	font-weight: 700;
	margin: 1.2rem 0 !important;
	padding: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield.static .gfield_label {
	margin: 0 0 0.8rem !important;
}

body.consultation-page .gform_wrapper.gravity-theme .gsection {
	margin-bottom: 1rem;
	border-bottom: none;
}

body.consultation-page .entry-content .gform_wrapper.gravity-theme .gsection h3 {
	color: #fff;
	font-size: 2rem;
	font-weight: 600;
	margin: 0 0 1.5rem;
	padding: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gform_fileupload_rules {
	color: #fff;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield.field_description_below+.gsection {
	margin: 0;
	padding: 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield.contact-time-picker {
	font-size: 3rem;
}

body.consultation-page .gform_wrapper.gravity-theme .ginput_preview {
	display: flex;
	align-items: center;
	color: #fff;
	font-size: 1.5rem;
	margin: 0.8rem 0;
}

body.consultation-page .gform_wrapper.gravity-theme .gfield .ginput_container.ginput_container_select select option {
	color: #ffffff;
}

@media (min-width: 992px) {
	body.consultation-page .gform_wrapper.gravity-theme .gfield {
		padding-right: 16px;
	}
}

body .gform_wrapper input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]) {
	padding: 5px 12px;
	/* border-top-style: hidden !important;
	border-right-style: hidden !important;
	border-left-style: hidden !important;
	border-bottom-style: groove !important;
	border-radius: unset !important; */
	box-shadow: none !important;
}

body .gform_wrapper textarea {
	padding: 5px 12px;
	/* border-radius: unset !important;
	box-shadow: none !important; */
}

/* Home Page Video */

.video-background-block {
	position: relative;
	height: 100vh;
	width: 100%;
	overflow: hidden;
	background-color: inherit;
	opacity: inherit;
}

.video-background-block video {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	min-width: 100%;
	min-height: 100%;
	height: auto;
	transform: translate(-50%, -50%);
	z-index: 0;
	object-fit: cover;
}

.block-view .video-overlay {
	position: absolute;
	transform: translate(-50%, -50%);
	z-index: 2;
	text-align: center;
	color: inherit;
}

.block-view .center-center {
	top: 50%;
	left: 50%;
}

.block-view .center-right {
	top: 50%;
	right: 10%;
	left: auto;
	transform: translate(0, -50%);
	text-align: right;
}

.block-view .center-left {
	top: 50%;
	left: 10%;
	right: auto;
	transform: translate(0, -50%);
	text-align: left;
}

.block-view .center-top {
	top: 10%;
	left: 50%;
	transform: translate(-50%, 0);
	text-align: center;
}

.block-view .center-bottom {
	bottom: 10%;
	left: 50%;
	transform: translate(-50%, 0);
	text-align: center;
}

.block-view .top-left {
	top: 10%;
	left: 10%;
	transform: translate(0, 0);
	text-align: left;
}

.block-view .top-right {
	top: 10%;
	right: 10%;
	left: auto;
	transform: translate(0, 0);
	text-align: right;
}

.block-view .bottom-left {
	bottom: 10%;
	left: 10%;
	top: auto;
	transform: translate(0, 0);
	text-align: left;
}

.block-view .bottom-right {
	bottom: 10%;
	right: 10%;
	top: auto;
	left: auto;
	transform: translate(0, 0);
	text-align: right;
}

.video-overlay .cta-button {
	background-color: #64c64e;
	padding: 1rem 2rem;
	color: white;
	text-decoration: none;
	border-radius: 0.25rem;
	font-weight: bold;
}

.video-background-block h1[style],
.video-background-block p[style],
.video-background-block .cta-button[style] {
	font-size: inherit;
	color: inherit;
}

.full-width-content .alignfull {
	position: relative;
	left: 50%;
	width: 100vw;
	max-width: none;
	margin-left: -50vw;
}

.content-sidebar .full-width-content .alignfull,
.sidebar-content .full-width-content .alignfull {
	max-width: calc(100% + 12rem);
}

/* News */

.news-archive h1.entry-title {
	border-bottom: 2px solid #929baf;
	padding-bottom: 1.2rem;
	margin-bottom: 0.5rem;
}

.news-post .entry-content h2 {
	font-size: 1.5rem;
}

h2.news-post--header {
	font-weight: 900;
	margin-bottom: 0.3rem;
	line-height: 1.35;
}

.news-post--meta {
	display: block;
	margin: 0 0 1.5rem;
	padding: 0 2px;
}

time.news-post--date {
	font-weight: 600;
	font-size: 0.9rem;
	color: #444;
}

.news-archive article.ews-post {
	border-bottom: 1px solid #cccccc;
	padding: 2rem 0 1rem;
}

.news-archive article.news-post:last-of-type {
	border-bottom: none;
}

/* client logos block */

.client-logos-slider {
	position: relative;
	margin: 10rem 0;
	padding: 0 10rem;
}

.client-logos-slider .swiper {
	display: flex;
	position: relative;
	align-items: center;
}

.client-logos-slider .swiper-controls {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.client-logos-slider .swiper .swiper-wrapper {
	display: flex;
	align-items: center;
}

/* Swiper navigation buttons */
.client-logos-slider .swiper-button-next,
.client-logos-slider .swiper-button-prev {
	width: 44px;
	height: 44px;
	z-index: 10;
	cursor: pointer;
	opacity: 0.8;
	transition: opacity 0.3s ease;
	background-color: rgba(0, 0, 0, 0.5);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0
}

.client-logos-slider .swiper-button-next::after,
.client-logos-slider .swiper-button-prev::after {
	font-size: 20px;
	color: white;
}

.client-logos-slider .swiper-button-next {
	top: calc(50% - 22px);
	align-self: center;
}

.client-logos-slider .swiper-button-prev {
	top: calc(50% - 22px);
	align-self: center;
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
	opacity: 1;
}

@media (max-width: 768px) {

	.client-logos-slider .swiper-button-next,
	.client-logos-slider .swiper-button-prev {
		width: 35px;
		height: 35px;
	}

	.client-logos-slider .swiper-button-next::after,
	.client-logos-slider .swiper-button-prev::after {
		font-size: 16px;
	}

	.client-logos-slider .swiper-button-next {
		margin-right: 0;
		align-self: center;
	}

	.client-logos-slider .swiper-button-prev {
		margin-left: 0;
		align-self: center;
	}
}

.client-logos-slider .swiper .swiper-pagination-lock {
	display: unset;
}

.client-logos-slider .swiper-pagination-bullets.swiper-pagination-horizontal {
	bottom: unset;
	top: unset;
}

/* Custom image */

/** Blocks **/

.custom-image--wrapper {
	position: relative;
}

.custom-image {
	position: relative;
	display: block;
	border-radius: 16px;
	max-width: 100%;
	background: #fff;
	box-shadow: 0px 10px 28px -7px rgb(0 0 0 / 35%);
}

.custom-image.image-center {
	margin: 0 auto;
}

.custom-image.image-right {
	margin: 0 0 0 auto;
}

.custom-image.image-left {
	margin: 0 auto 0 0;
}

.custom-image img {
	object-fit: cover;
	object-position: center;
	width: 100%;
	opacity: 1;
}

img.custom-image--img-secondary {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
}

.custom-image--tagline {
	display: inline-block;
	position: absolute;
	right: -12.5%;
	top: 20px;
	background: #657d9f;
	color: #fff;
	text-align: center;
	z-index: 3;
	border-radius: 25px;
	padding: 3px 15px;
	font-size: 1.6rem;
	font-weight: 600;
	text-transform: uppercase;
}

.custom-image--tagline.left {
	left: -12.5%;
	right: auto;
}

.custom-image--graphic img {
	display: block;
	box-shadow: none;
}

.custom-image--graphic {
	display: block;
	position: absolute;
}

.custom-image--graphic.custom-image--graphic-left {
	bottom: 10%;
	left: -20%;
	z-index: 10;
}

.custom-image--graphic.custom-image--graphic-right {
	top: 10%;
	right: -20%;
	z-index: -1;
}

.custom-image--graphic svg {
	font-size: 15rem;
}

@media (max-width: 896) {
	.custom-image--tagline {
		display: none !important;
	}
}

/* Centered Copy Block */

section.browser-view {
	padding: 5rem 5rem 5rem 5rem;
	margin: 5rem;
	position: relative;
	border: 5px solid transparent;
	box-shadow: 0 4px 16px -2px rgba(0, 0, 0, 0.12);
	border-radius: 0;
	overflow: hidden;
}

.browser-view .cta-inner {
	text-align: center;
}

.browser-view .cta-section h2 {
	font-size: 2rem;
	margin-bottom: 1rem;
}

.browser-view .cta-section p {
	margin-bottom: 2rem;
	font-size: 1.125rem;
	line-height: 1.7;
}

section.browser-view .cta-inner h2 {
	margin: 1rem 0 3rem;
}

.browser-view .cta-image {
	max-width: 80px;
	height: auto;
	margin-bottom: 2rem;
	position: absolute;
}

.browser-view .bottom-right {
	top: auto;
	bottom: 3rem;
	left: auto;
	right: 3rem;
}

.browser-view .bottom-left {
	top: auto;
	bottom: 3rem;
	left: 3rem;
	right: auto;
}

.browser-view .top-left {
	top: 3rem;
	bottom: auto;
	left: 3rem;
	right: auto;
}

.browser-view .top-right {
	top: 3rem;
	bottom: auto;
	left: auto;
	right: 3rem;
}

/* Static Copy Left Right */

.two-column-content-block {
	padding: 8rem;
}

.block-container {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-between;
}

.column-left,
.column-right {
	flex-basis: 48%;
	box-sizing: border-box;
}

.align-left {
	text-align: left;
}

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

.align-right {
	text-align: right;
}

@media screen and (max-width: 768px) {

	.column-left,
	.column-right {
		flex-basis: 100%;
		text-align: center;
	}
}

.two-column-content-block {
	padding: 8rem;
	position: relative;
}

section.two-column-content-block:before {
	clip-path: polygon(0 0, 56% 0, 44% 100%, 0 100%);
	content: '';
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: -1;
}

section.two-column-content-block:after {
	content: '';
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: -2;
}

/* After content CTA */

.after-content-cta--section {
	background-color: #f7f9fc;
	padding: 40px;
	border-radius: 8px;
	max-width: 820px;
	margin: 30px auto;
	text-align: center;
}

.after-content-cta--title span {
	font-size: 1.8em;
	color: #333;
	font-weight: bold;
	margin-bottom: 20px;
	display: inline-block;
}

.after-content-cta--buttons-row {
	display: flex;
	justify-content: center;
	gap: 80px;
	flex-wrap: wrap;
	margin-top: 20px;
}

.after-content-cta--button-wrap {
	display: inline-block;
}

.after-content-cta--button {
	background-color: #007bff;
	color: white;
	font-size: 1.2em;
	font-weight: bold;
	padding: 12px 35px;
	border: none;
	border-radius: 4px;
	text-decoration: none;
	transition: background-color 0.3s ease, transform 0.3s ease;
}

.after-content-cta--button:hover {
	background-color: #0056b3;
	transform: translateY(-3px);
}

@media (max-width: 768px) {
	.after-content-cta--buttons-row {
		flex-direction: column;
		gap: 15px;
	}

	.after-content-cta--button {
		width: 100%;
	}
}

/* Mid Content CTA */

.mid-content-cta {
	background-color: #fff;
	border: 1px solid #e5e5e5;
	border-radius: 8px;
	padding: 40px 20px;
	margin: 0 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
	margin-bottom: 20px;
}

.mid-content-cta--inner {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: start;
}

.mid-content-cta--image {
	flex-shrink: 0;
}

.mid-content-cta--image img {
	max-width: 175px;
	height: auto;
	margin-right: 20px;
	border-radius: 4px;
}

.mid-content-cta--copy {
	flex-grow: 1;
	max-width: 50rem;
	text-align: center;
}

.mid-content-cta--copy p {
	margin: 0;
	font-size: 16px;
	color: #333;
	line-height: 1.5;
	padding-right: 20px;
}

.mid-content-cta--button {
	flex-shrink: 0;
}

.mid-content-cta--button a.button {
	display: inline-flex;
	align-items: center;
	gap: 1rem;
}

.mid-content-cta--button i.fa-solid {
	margin-left: 8px;
	font-size: 14px;
}

.mid-content-cta-container {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

@media (max-width: 536px) {
	.mid-content-cta {
		margin: 0 25px;
	}
}

/* Form CTA Block */

.form-cta-block {
	position: relative;
	padding: 50px;
	background-size: cover;
	background-position: center;
	color: #ffffff;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: left;
}

.form-cta-container {
	display: flex;
	max-width: 1200px;
	width: 100%;
}

@media (max-width: 867px) {
	.form-cta-container {
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 5rem;
	}
}

.form-cta-left {
	flex: 1;
	margin-right: 20px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.form-cta-left h2 {
	font-size: 2rem;
	color: #ffffff;
	margin-bottom: 20px;
}

.form-cta-image {
	margin-bottom: 20px;
}

.circular-image {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	object-fit: cover;
	border: 5px solid white;
	box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
}

.form-cta-right {
	flex: 1;
	padding-left: 20px;
	display: flex;
	align-items: start;
	justify-content: flex-start;
}

.form-cta-right form {
	width: 100%;
}

.form-cta-extra-info {
	color: #ffffff;
	text-align: center;
}

.form-cta-extra-info p {
	margin-bottom: 10px;
}

/* Phone Number CTA */

.phone-number-block {
	display: flex;
	align-items: center;
}

.phone-link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	color: inherit;
	font-size: 16px;
}

.phone-link i {
	margin-right: 8px;
	font-size: 18px;
	color: #ffffff;
}

.phone-link .phone-number {
	font-size: 16px;
	color: #ffffff;
}

/* Email CTA */

.email-cta-block {
	display: flex;
	align-items: center;
}

.email-link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	color: inherit;
	font-size: 16px;
}

.email-link i {
	margin-right: 8px;
	font-size: 18px;
	color: #ffffff;
}

.email-link .email-address {
	font-size: 16px;
	color: #ffffff;
}

/* Mega Menu */

@media (min-width: 896px) {
	li:not(.mega-menu) .menu-item {
		padding: 0.25em 0.6em;
		height: auto;
		list-style-type: none;
	}
}

.widget-area.footer-widget-area ul {
	display: -webkit-box !important;
	display: -ms-flexbox !important;
	display: flex !important;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

@media (min-width: 896px) {

	.mega-menu ul.sub-menu:first-of-type {
		width: 50vw;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.mega-menu ul.sub-menu:first-of-type>li {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-flex: 0;
		-ms-flex-positive: 0;
		flex-grow: 0;
		-ms-flex-preferred-size: 50%;
		flex-basis: 50%;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
	}

	.mega-menu ul.sub-menu:first-of-type ul.sub-menu {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		position: relative;
		margin: 0;
		padding: 0.5rem 0 0.5rem 4px;
		left: auto;
		top: auto;
		width: 100% !important;
		background-color: transparent;
		-webkit-box-shadow: none;
		box-shadow: none;
		border: none !important;
	}

	.mega-menu ul.sub-menu:first-of-type ul.sub-menu>li {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
		padding: 0;
		line-height: 1;
	}

	.mega-menu ul.sub-menu:first-of-type ul.sub-menu>li a {
		font-size: 1.4rem;
		font-weight: 400;
		padding: 4px 0;
		margin-left: 3px;
	}

	.mega-menu ul.sub-menu:first-of-type ul.sub-menu:before {
		display: none;
	}

	.mega-menu.menu-item.menu-item-has-children:hover>.sub-menu {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}

	.mega-menu ul.sub-menu:first-of-type>li>a:first-child {
		font-size: 1.5rem;
		font-weight: 800;
	}

	.is_ie .mega-menu.menu-item.menu-item-has-children:hover .sub-menu {
		display: block !important;
	}

	.is_ie .mega-menu>.sub-menu>li {
		max-width: 45% !important;
		width: 100% !important;
		display: inline-block !important;
	}
}

@media (min-width: 896px) {
	body .site-header>.wrap {
		position: relative;
	}

	body .site-header .nav-primary,
	body .site-header .nav-primary>.wrap,
	body .site-header .nav-primary ul.menu,
	body .site-header .nav-primary ul.menu>li.menu-item.mega-menu {
		position: initial;
		width: 100%;
	}

	body .site-header .nav-primary ul.menu li.menu-item.mega-menu>ul.sub-menu {
		min-width: 850px;
		max-width: 850px;
		/* left: calc(50% - 425px);
        right: calc(50% - 425px); */
	}

	body .site-header .nav-primary ul.menu li.menu-item.mega-menu>ul.sub-menu>li.menu-item {
		flex: 1 1 30%;
		/* max-width: calc(100% / 3); */
		max-width: calc(100% / 2);
	}

	/* body .site-header .nav-primary ul.menu li.menu-item.mega-menu>ul.sub-menu:before {
        left: 190px;
        transition: none;
    } */
}

/* @media (min-width: 1000px) {
    body .site-header .nav-primary ul.menu li.menu-item.mega-menu>ul.sub-menu {
        left: auto;
        right: 0;
    }
} */

/* @media (min-width: 1152px) {
    body .site-header .nav-primary ul.menu li.menu-item.mega-menu>ul.sub-menu:before {
        left: 120px;
    }
} */

/* Sub Menu */

.nav-primary .menu-item ul.sub-menu li a:before {
	display: none;
}

.nav-primary ul:not(.sub-menu) .menu-item.menu-item-has-children a:after {
	display: none;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f078";
}

.nav-primary ul:not(.sub-menu) .menu-item.menu-item-has-children a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.nav-primary ul:not(.sub-menu) .menu-item.menu-item-has-children a svg {
	width: .7em;
	margin-left: 0.5rem;
	-webkit-transform: translateY(1px);
	-ms-transform: translateY(1px);
	transform: translateY(1px);
}

.nav-primary ul.sub-menu .menu-item.menu-item-has-children a:after,
.nav-primary ul.sub-menu .menu-item a:after {
	display: none;
	content: "" !important;
}

.nav-primary .menu-item a:hover:before,
.nav-primary .menu-item a:focus:before,
.nav-primary .menu-item a:active:before {
	left: 0;
	right: 0;
}

.nav-primary .sub-menu a {
	font-weight: 700;
	font-size: 1.4rem;
	color: #3e3e3e;
}

.nav-primary .sub-menu a:hover {
	color: #333;
}


.sub-menu {
	display: none;
	clear: both;
}

.sub-menu:before,
.sub-menu:after {
	clear: both;
	display: block;
	content: '';
}

.sub-menu:before {
	content: '';
	position: absolute;
	top: -5px;
	top: -0.5rem;
	height: 10px;
	height: 1rem;
	width: 10px;
	width: 1rem;
	background-color: rgba(0, 0, 0, 0.97);
	border-top: 1px solid rgba(0, 0, 0, 0.97);
	border-left: 1px solid rgba(0, 0, 0, 0.97);
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	z-index: 98;
	opacity: 1;
	-webkit-transition-delay: 0.3s;
	-o-transition-delay: 0.3s;
	transition-delay: 0.3s;
	display: none;
}

.sub-menu .sub-menu:before {
	content: '';
	position: absolute;
	top: -5px;
	top: 2rem;
	left: 30px;
	left: -0.5rem;
	height: 10px;
	height: 1rem;
	width: 10px;
	width: 1rem;
	background-color: rgba(8, 52, 91, 0.97);
	border-top: none;
	border-bottom: 1px solid rgba(8, 52, 91, 0.97);
	border-left: 1px solid rgba(8, 52, 91, 0.97);
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	z-index: 98;
	opacity: 1;
	-webkit-transition-delay: 0.3s;
	-o-transition-delay: 0.3s;
	transition-delay: 0.3s;
}

.sub-menu .menu-item {
	width: 100%;
	height: auto;
	padding: 0.5em 0;
}

.sub-menu .menu-item:first-of-type {
	margin-top: 1em;
}

.sub-menu a {
	padding-left: 0.618em;
}

.sub-menu .sub-menu {
	padding-left: 1em;
}

.nav-secondary .sub-menu .menu-item {
	height: auto;
}

.sub-menu-toggle {
	position: absolute;
	right: 4em;
	height: auto;
	top: 0.1em;
	background: none;
	padding: 1em;
	margin: 0 -1em;
	-webkit-box-shadow: none;
	box-shadow: none;
}

.sub-menu-toggle:hover,
.sub-menu-toggle:focus {
	background: none;
	-webkit-box-shadow: none;
	box-shadow: none;
}


.sub-menu-toggle:before {
	content: '';
	display: block;
	/* display: none; */
	margin: 2px 0 -2px;
	margin: 0.2rem 0 -0.2rem;
	border: 4px solid transparent;
	border: 0.4rem solid transparent;
	border-top-color: #2a3139;
}

.sub-menu-toggle.activated:before {
	-webkit-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	transform: rotate(180deg);
	margin: -2px 0 2px;
	margin: -0.2rem 0 0.2rem;
}

.sub-menu-toggle svg {
	color: #ffffff;
}

.menu-item-has-children .sub-menu-toggle:focus {
	transform: rotate(180deg);
	transition: transform 0.3s ease;
}

@media (min-width: 896px) {
	.menu-item.menu-item-has-children:hover>.sub-menu {
		display: block;
	}
}

@media (min-width: 896px) {

	.menu-item-has-children .sub-menu-toggle:hover {
		transform: rotate(180deg);
		transition: transform 0.3s ease;
	}

	/* .sub-menu-toggle {
        position: relative;
        right: 0;
        height: auto;
        top: 0.1em;
        background: none;
        padding: 1em;
        margin: 0 -1em;
        -webkit-box-shadow: none;
        box-shadow: none;
    } */

	.sub-menu {
		background-color: rgba(255, 255, 255, 1);
		top: 100%;
		position: absolute;
		margin-left: -1em;
		width: 20rem;
		z-index: 99;
		padding: 1em 0;
		border: 1px solid rgba(1, 26, 77, 0.97) !important;
		border-radius: 3px;
		-webkit-box-shadow: 0px 10px 28px -7px rgba(0, 0, 0, 0.2);
		box-shadow: 0px 10px 28px -7px rgba(0, 0, 0, 0.2);
	}

	.nav-primary .sub-menu a {
		color: #ffffff;
	}

	.sub-menu:before {
		display: block;
	}

	.sub-menu .menu-item {
		padding: 0.5em 1em;
		height: auto;
	}

	li:not(.mega-menu) .menu-item {
		padding: 0.25em 0.6em;
		height: auto;
	}

	.sub-menu {
		display: flex;
		right: -9999px;
		pointer-events: none;
		opacity: 0;
		transition: 0.25s ease-in-out opacity, 0s 0.25s ease-in-out right;
	}

	.menu-item:hover>.sub-menu {
		right: 0;
		left: -3em;
		pointer-events: all;
		opacity: 1;
		transition: 0.25s ease-in-out opacity, 0s ease-in-out right;
	}

	.mega-menu:hover>.sub-menu {
		right: 0;
		left: unset;
		pointer-events: all;
		opacity: 1;
		transition: 0.25s ease-in-out opacity, 0s ease-in-out right;
	}

	.sub-menu .menu-item:first-of-type {
		margin-top: 0;
	}

	.sub-menu a {
		padding: 0;
		position: relative;
		word-wrap: break-word;
		color: #fff;
	}

	.sub-menu .sub-menu {
		margin: -0.1rem 0 0 19.9rem;
		padding-left: 0;
		left: -0.1rem;
		top: -0.5em;
		border: 1px solid #eceef1;
	}

	.sticky-header .shrink .nav-secondary ul ul.sub-menu .menu-item {
		height: auto;
	}

	.sub-menu-toggle {
		display: none;
	}

}

/* 
.menu-item.menu-item-has-children:hover>.sub-menu {
    -webkit-transition: 0.1s ease-in-out all;
    -o-transition: 0.1s ease-in-out all;
    transition: 0.1s ease-in-out all;
} */


.widget_nav_menu ul:not(.sub-menu) {
	display: block;
	margin-left: 0;
}

@media (max-width: 895px) {
	.nav-primary ul:not(.sub-menu) .menu-item.menu-item-has-children a svg {
		display: none;
	}
}

.nav-primary ul.menu>li.menu-item>ul.sub-menu:before {
	content: "";
	display: none;
	position: absolute;
	top: -10px;
	right: var(--submenu-before-right, 0);
	width: 10px;
	height: 10px;
	background: black;
	transform: rotate(45deg);
}

@media (min-width: 896px) {
	.nav-primary ul.menu.has-pseudo>li.menu-item>ul.sub-menu:before {
		display: block;
	}
}

/* Mobile only */

.nav-primary .mobile-only {
	display: none;
}

@media (max-width: 768px) {
	.nav-primary .mobile-only {
		display: block;
	}
}

/* Menu Toggle */

.menu-toggle {
	display: none;
	background: none;
	border: none;
	font-size: 2rem;
	cursor: pointer;
}

@media (max-width: 896px) {
	.menu-toggle {
		display: block;
		position: absolute;
		right: 20px;
		top: -15px;
		z-index: 1001;
	}

	.nav-primary {
		position: fixed;
		width: 80%;
		right: -100%;
		top: 0;
		height: 100vh;
		background-color: #fff;
		z-index: 999;
		overflow-y: auto;
		transition: right 0.3s ease;
	}

	.nav-primary.active {
		right: 0;
		margin-top: 0;
	}

	.nav-primary ul.menu {
		display: block;
		padding: 6em 0 0 0;
		position: relative;
		width: 100%;
	}

	.nav-primary .wrap .menu li {
		display: block;
		margin: 0;
		text-align: left;
	}

	.site-header .wrap .nav-primary .menu>.menu-item {
		padding: unset;
		padding-top: 1rem;
		padding-bottom: 1rem;
	}

	.menu-toggle {
		display: block;
		position: relative;
		z-index: 999;
		height: auto;
		margin-right: -0.5em;
		padding: 1em 0.5em;
		color: #2a3139;
		background: transparent;
		box-shadow: none;
		cursor: pointer;
	}

	.menu-toggle:hover,
	.menu-toggle:focus {
		color: #2a3139;
		background: none;
		box-shadow: none;
	}

	.menu-toggle.activated {
		position: fixed;
		right: 4vw;
	}

	.menu-toggle.activated,
	.shrink .menu-toggle {
		color: #2a3139;
	}

	.menu-toggle.activated span,
	.shrink .menu-toggle span {
		background: #2a3139;
	}

	.menu-toggle span {
		display: block;
		float: right;
		position: relative;
		width: 2rem;
		height: 2px;
		border-radius: 3px;
		background: #2a3139;
	}

	.menu-toggle span:before,
	.menu-toggle span:after {
		display: block;
		position: absolute;
		left: 0;
		width: 100%;
		height: 2px;
		border-radius: 3px;
		background-color: #2a3139;
		content: ' ';
	}

	.menu-toggle span:before {
		top: -0.5rem;
		transition: top 0.2s 0.2s, transform 0.2s 0s;
	}

	.menu-toggle span:after {
		bottom: -0.5rem;
		transition: bottom 0.2s 0.2s, transform 0.2s 0s;
	}

	.menu-toggle.activated span {
		background: none;
	}

	.menu-toggle.activated span:before {
		top: 0;
		transition: top 0.2s 0s, transform 0.2s 0.2s;
		transform: rotate(45deg);
	}

	.menu-toggle.activated span:after {
		bottom: 0;
		transition: bottom 0.2s 0s, transform 0.2s 0.2s;
		transform: rotate(-45deg);
	}

	.site-header .wrap .nav-primary>.wrap {
		display: flex;
		flex-direction: column;
		flex-flow: column;
		height: 100vh;
		padding: 0 3rem;
	}

	.primary-menu-ctas .gb-layout-column-wrap {
		flex-direction: column;
		margin-bottom: 25%;
	}

	.primary-menu-ctas .gb-block-layout-column {
		display: flex;
		align-items: center;
		justify-content: center;
	}

	.search-widget {
		display: none;
	}


	.menu-item-has-children {
		display: flex;
		justify-content: space-between;
		align-items: center;
		position: relative;
		padding-right: 2rem;
	}

	.menu-item-has-children .sub-menu {
		display: none;
		position: relative;
		padding-left: 0.5rem;
		background-color: #fff;
	}

	.menu-item-has-children .sub-menu.active {
		display: block;
	}

	.sub-menu-toggle {
		display: inline-flex;
		justify-content: center;
		align-items: center;
		width: 30px;
		height: 30px;
		border: 1px solid #9a9fa6;
		background: transparent;
		cursor: pointer;
		padding: 0;
		margin-left: auto;
		margin-right: 0;
	}

	.menu-item-has-children .sub-menu .menu-item {
		padding-left: 1.5rem;
	}

	.menu-item-has-children .sub-menu .menu-item-has-children {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding-right: 2rem;
	}

	.sub-menu-toggle:hover,
	.sub-menu-toggle:focus {
		background-color: #f0f0f0;
	}
}

@media (max-width: 767px) {

	.site-header .wrap,
	.basic-page .content-sidebar-wrap,
	.entry-content>.wp-block-genesis-blocks-gb-columns>.gb-layout-column-wrap,
	.entry-content>.gb-block-container>.gb-container-inside {
		width: 90%;
	}

}

.menu-toggle.active .hamburger-icon {
	transform: rotate(90deg);
	transition: 0.3s;
}


.menu-item-has-children {
	position: relative;
}



/* Confirmation block */

.confirmation-block {
	text-align: center;
}

.confirmation-block svg {
	font-size: 15rem;
	color: #008000;
}

.confirmation-page .custom-socials {
	margin: 0 auto;
	padding: 3rem;
}

/* Front Page Banner */

section.fp1 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	padding: 4rem 7%;
	overflow: hidden;
	min-height: 400px;
	background-size: cover;
	background-position: top;
	position: relative;
	z-index: 10;
	align-items: center;
}


.fp1-image::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: rgb(16 16 16 / 40%);
	z-index: 1;
}

.fp1-image img {
	opacity: 0;
	-webkit-transition: .4s all ease-in-out;
	-o-transition: .4s all ease-in-out;
	transition: .4s all ease-in-out;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.fp1-image {
	position: absolute;
	height: 100%;
	width: 100%;
	top: 0;
	left: 0;
}

.fp1-image.transitioning {
	-webkit-animation: kenburnsBig 15s infinite;
	animation: kenburnsBig 15s infinite;
}

.fp1-image.transitioning:not(.active) img {
	opacity: 0;
}

.fp1-image.active img {
	opacity: 1;
	z-index: 3;
}

.fp1-overlay {
	position: absolute;
	display: block;
	height: 100%;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 2;
	-webkit-transition: 0.24s ease-in-out all;
	-o-transition: 0.24s ease-in-out all;
	transition: 0.24s ease-in-out all;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='rgba(0, 0, 0, 0.9)', endColorstr='rgba(0, 0, 0, 0)');
	background-image: -ms-linear-gradient(left, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.85) 25%, rgba(0, 0, 0, 0.6) 35%, rgba(0, 0, 0, 0.01) 50%);
	background: -o-linear-gradient(left, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.85) 25%, rgba(0, 0, 0, 0.6) 35%, rgba(0, 0, 0, 0.01) 50%);
	background: linear-gradient(to right, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.85) 25%, rgba(0, 0, 0, 0.6) 35%, rgba(0, 0, 0, 0.01) 50%);
}

.fp1-overlay.is-active {
	background: -o-linear-gradient(left, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.85) 25%, rgba(0, 0, 0, 0.6) 35%, rgba(0, 0, 0, 0.01) 50%, rgba(0, 0, 0, 0.6) 65%, rgba(0, 0, 0, 0.85) 75%, rgba(0, 0, 0, 0.9) 100%);
	background: linear-gradient(to right, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.85) 25%, rgba(0, 0, 0, 0.6) 35%, rgba(0, 0, 0, 0.01) 50%, rgba(0, 0, 0, 0.6) 65%, rgba(0, 0, 0, 0.85) 75%, rgba(0, 0, 0, 0.9) 100%);
}

.fp1-content {
	color: #fff;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	z-index: 5;
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
	justify-content: flex-start;
}

.fp1-content__left {
	-webkit-box-flex: 1;
	-ms-flex: 1 50%;
	flex: 1 50%;
}

.fp1-content__right {
	max-width: 450px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	text-align: left;
	z-index: 9;
}

section.fp1.fp1-mobile {
	display: none;
	text-align: center;
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
	min-height: 400px;
	color: #fff;
	background-position: 91% 50%;
}

section.fp1-mobile.fp1>div {
	text-shadow: 0px 1px 2px rgba(255, 255, 255, 0.16);
}

@media (min-width: 992px) {
	section.fp1 {
		min-height: 450px;
	}
}

@media (min-width: 1200px) {
	.fp1-image {
		top: 0;
	}

	section.fp1 {
		min-height: 550px;
	}
}

@media (min-width: 1400px) {

	section.fp1 {
		min-height: 500px;
	}
}

@media (min-width: 1700px) {

	section.fp1 {
		min-height: 600px;
	}
}

.fp1-banner-container {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 1;
}

.fp1-banner-container .carousel,
.fp1-banner-container .carousel-inner,
.fp1-banner-container .carousel-item {
	width: 100%;
	height: 100%;
}

.fp1-banner-container .carousel-item>img {
	animation: tto-zoom 20s forwards;
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: 100%;
}


@keyframes tto-zoom {
	0% {
		transform: scale(1);
	}

	100% {
		transform: scale(1.3);
	}
}

.fp1 {
	position: relative;
	height: 100vh;
	width: 100%;
	overflow: hidden;
	background-color: inherit;
	opacity: inherit;
}

.overlay-content {
	position: absolute;
	transform: translate(-50%, -50%);
	z-index: 2;
	text-align: center;
	color: inherit;
}



.fp1 .center-center {
	top: 50%;
	left: 50%;
}

.fp1 .center-right {
	top: 50%;
	right: 10%;
	left: auto;
	transform: translate(0, -50%);
	text-align: right;
}

.fp1 .center-left {
	top: 50%;
	left: 10%;
	right: auto;
	transform: translate(0, -50%);
	text-align: left;
}

.fp1 .center-top {
	top: 10%;
	left: 50%;
	transform: translate(-50%, 0);
	text-align: center;
}

.fp1 .center-bottom {
	bottom: 10%;
	left: 50%;
	transform: translate(-50%, 0);
	text-align: center;
}

.fp1 .top-left {
	top: 10%;
	left: 10%;
	transform: translate(0, 0);
	text-align: left;
}

.fp1 .top-right {
	top: 10%;
	right: 10%;
	left: auto;
	transform: translate(0, 0);
	text-align: right;
}

.fp1 .bottom-left {
	bottom: 10%;
	left: 10%;
	top: auto;
	transform: translate(0, 0);
	text-align: left;
}

.fp1 .bottom-right {
	bottom: 10%;
	right: 10%;
	top: auto;
	left: auto;
	transform: translate(0, 0);
	text-align: right;
}

/*** Testimonials ***/

.testimonial-item {
	background-color: #ffffff;
	padding: 2em 2.2em 2em;
	border-radius: 4px;
	box-shadow: 0 2rem 2rem -1rem rgba(35, 44, 57, 0.05);
	clear: both;
	-webkit-transition: all 0.75s cubic-bezier(0, 1, 0.5, 1);
	transition: all 0.75s cubic-bezier(0, 1, 0.5, 1);
	border-top: 3px solid #03c3f2;
	position: relative;
	min-height: 250px;
}

.testimonial-item--copy {
	text-align: left;
	margin: 0 2rem 0 0;
}

.testimonial-item--copy p {
	margin: 0 0 1.5rem;
	font-size: 1.7rem;
}

.testimonial-item--name {
	display: block;
	padding-top: 1rem;
	font-weight: 600;
	text-align: left;
	font-size: 1.8rem;
}

.testimonial-item--icon {
	position: absolute;
	right: 1rem;
	top: 0.5rem;
	font-size: 3rem;
	color: #03c3f2;
}

.testimonial-item.testimonial-list-item {
	margin: 0 0 5rem;
	box-shadow: 0 0 2px rgba(0, 0, 0, 0.25), 0 2rem 2rem -1rem rgba(35, 44, 57, 0.05);
}

blockquote.testimonial-item--copy::before {
	font-size: 5rem;
	font-weight: 700;
	color: #03c3f2;
	left: -40px;
	top: -15px;
	display: none;
}

/*** Reviews ***/

.review-item {
	background-color: #ffffff;
	padding: 2em 2.2em 2em;
	border-radius: 4px;
	box-shadow: 0 2rem 2rem -1rem rgba(35, 44, 57, 0.05);
	clear: both;
	-webkit-transition: all 0.75s cubic-bezier(0, 1, 0.5, 1);
	transition: all 0.75s cubic-bezier(0, 1, 0.5, 1);
	border-top: 3px solid #03c3f2;
	position: relative;
	min-height: 250px;
}

.review-item--copy {
	text-align: left;
	margin: 0 2rem 0 0;
}

.review-item--copy p {
	margin: 0 0 1.5rem !important;
	font-size: 1.7rem;
}

.review-item--copy {
	margin-top: 2rem !important;
}

.review-item--name {
	display: block;
	padding-top: 1rem;
	font-weight: 600;
	text-align: left;
	font-size: 1.8rem;
}

.review-item--icon {
	position: absolute;
	right: 1rem;
	top: 0.5rem;
	font-size: 3rem;
	color: #03c3f2;
}

.review-item.review-list-item {
	margin: 0 0 5rem;
	box-shadow: 0 0 2px rgba(0, 0, 0, 0.25), 0 2rem 2rem -1rem rgba(35, 44, 57, 0.05);
}

blockquote.review-item--copy::before {
	font-size: 5rem;
	font-weight: 700;
	color: #03c3f2;
	left: -40px;
	top: -15px;
	display: none;
}

/* Sidebar .single pages */

.single.sidebar-content .content-sidebar-wrap {
	display: flex;
	flex-direction: row;
}

.single.sidebar-content .content {
	order: 1;
	width: 70%;
}

.single.content-sidebar .sidebar-primary {
	order: 2;
	width: 30%;
	padding-left: 2rem;
}

.single.sidebar-content .sidebar-primary {
	order: 1;
	width: 30%;
	padding-right: 2rem;
}

.single.sidebar-content .content {
	order: 2;
	width: 70%;
}

@media only screen and (max-width: 1024px) {
	.single .content-sidebar-wrap {
		flex-direction: column;
	}

	.single .content,
	.single .sidebar-primary {
		width: 100%;
		margin: 0;
		padding: 0;
	}

	.single .sidebar-primary {
		margin-top: 2rem;
	}
}

.sidebar-form {
	padding: 2rem;
	border: 1px solid #eceef1;
	border-radius: 0.5rem;
	box-shadow: 0px 3px 13px -2px rgba(0, 0, 0, 0.27);
}

.site-inner .content-sidebar-wrap .sidebar .sidebar-content .recent-articles .recent-articles--items .recent-articles--items-wrapper {
	display: grid;
	grid-template-columns: unset;
	grid-template-rows: repeat(3, 1fr);
	gap: 3rem;
	margin: 0;
	width: 100%;
	max-width: 1280px;
}

.sidebar-primary .sidebar-content .entry-before--time {
	display: none;
}

.sidebar-content .entry-image-link {
	border-bottom: unset;
}

body.single.single-post .site-container .site-inner .sidebar-content .entry-image-link {
	border-bottom: unset;
}

.sidebar .sidebar-content {
	padding: 2rem;
	margin-top: 2rem;
	border: 1px solid #eceef1;
	border-radius: 0.5rem;
	box-shadow: 0px 3px 13px -2px rgba(0, 0, 0, 0.27);
}

.entry-after h3:not(.sidebar-primary .sidebar-content .entry-after h3) {
	display: none;
}

.sidebar-primary .sidebar-content .entry-after .custom-button {
	display: none;
}

.sidebar-primary .sidebar-content .entry-after {
	text-align: center;
	margin-top: 2rem;
}



/* ## Custom CSS
--------------------------------------------- */

/* Variables (Edit First!) */

:root {
	--theme-wrap-width: 90%;
	--theme-wrap-max-width: 1300px;
	--theme-wrap-padding-mobile: 4vw;
	--theme-section-padding: 10rem;
	--theme-section-padding-mobile: 8rem;
}

/* =====================================================
   AION CUSTOM WORKS - Static Global CSS
   ===================================================== */

:root {
	--background: #1a1a1a;
	--foreground: #eaeaea;
	--card: #212121;
	--card-foreground: #eaeaea;
	--border: #3a3a3a;
	--steel: #7a8490;
	--steel-light: #a8b0ba;
	--forge-red: #a8232e;
	--forge-red-light: #c63040;
	--muted: #2d2d2d;
	--muted-foreground: #8a8a8a;

	--font-sans: 'Titillium Web', sans-serif;
	--font-heading: 'Rajdhani', sans-serif;

	--container: 1280px;
	--section-padding: 10rem;
	--header-height: 7.5rem;
}

.text-red {
	color: var(--forge-red);
}

.text-steel {
	color: var(--steel-light);
}

.bg-background {
	background-color: var(--background);
}

.bg-card {
	background-color: var(--card);
}

/* Icons */
.icon {
	width: 1rem;
	height: 1rem;
}

.icon-sm {
	width: 0.75rem;
	height: 0.75rem;
}

/* Buttons */
.btn,
.nav-primary .menu>.menu-item.menu-cta a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 1.4rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0.75rem 1.5rem;
	border: 1px solid transparent;
	transition: all 0.2s ease;
	cursor: pointer;
	border-radius: 2px;
}

.btn-primary,
.nav-primary .menu>.menu-item.menu-cta a {
	background-color: var(--forge-red);
	color: white;
	border-color: var(--forge-red);
}

.btn-primary:hover {
	background-color: var(--forge-red-light);
	border-color: var(--forge-red-light);
}

.nav-primary .menu>.menu-item.menu-cta {
	flex: 1;
	width: 100%;
	margin: 0 0 0 auto;
	text-align: right;
	justify-content: flex-end;
}


.nav-primary .menu>.menu-item.menu-cta a {
	font-size: 1.4rem;
}


.btn-outline {
	background-color: transparent;
	color: #fff;
	border-color: var(--steel);
}

.btn-outline:hover {
	background-color: rgba(122, 132, 144, 0.1);
	color: var(--foreground);
}

.btn-lg {
	padding: 1rem 2rem;
	font-size: 1.6rem;
}

.btn-full {
	width: 100%;
}

.btn-arrow {
	width: 1.25rem;
	height: 1.25rem;
	transition: transform 0.2s ease;
}

.btn:hover .btn-arrow {
	transform: translateX(4px);
}

.button-group {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

/* Sections */
.section {
	padding: var(--section-padding) 0;
}

.section-pattern {
	position: relative;
	overflow: hidden;
}

.section-pattern::before {
	content: '';
	position: absolute;
	inset: 0;
	opacity: 0.05;
	background-image: repeating-linear-gradient(45deg, transparent, transparent 2px, currentColor 2px, currentColor 3px);
}

.section-dots {
	position: relative;
	overflow: hidden;
}

.section-dots::before {
	content: '';
	position: absolute;
	inset: 0;
	opacity: 0.05;
	background-image: radial-gradient(circle at 1px 1px, currentColor 1px, transparent 1px);
	background-size: 40px 40px;
}

.section-header {
	margin-bottom: 4rem;
}

.section-header-split {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.section-header-split {
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
	}
}

.section-header-center {
	text-align: center;
	max-width: 650px;
	margin-left: auto;
	margin-right: auto;
}

.tagline-center {
	justify-content: center;
}

.section-title {
	font-size: clamp(2rem, 7vw, 5rem);
	letter-spacing: -0.02em;
}

h2.section-title {
	font-size: clamp(2rem, 12vw, 6rem);
}

.section-description {
	font-size: 1.8rem;
	line-height: 1.6;
	color: var(--steel-light);
	max-width: 400px;
}

.section-description-center {
	max-width: 650px;
	margin-left: auto;
	margin-right: auto;
}

/* Grid Layouts */
.grid-two-col {
	display: grid;
	gap: 3rem;
	align-items: center;
}

@media (min-width: 1024px) {
	.grid-two-col {
		grid-template-columns: repeat(2, 1fr);
	}
}

.order-1-mobile {
	order: 1;
}

.order-2-mobile {
	order: 2;
}

@media (min-width: 1024px) {

	.order-1-mobile,
	.order-2-mobile {
		order: unset;
	}

	.order-first-desktop {
		order: -1;
	}

	.order-last-desktop {
		order: 99;
	}
}

/* Content Blocks */
.content-block {
	position: relative;
	z-index: 10;
}

.content-block-padded {
	padding-left: 2rem;
}

@media (max-width: 1023px) {
	.content-block-padded {
		padding-left: 0;
	}
}

/* Image Blocks */
.image-block {
	position: relative;
}

.image-wrapper {
	position: relative;
	aspect-ratio: 4/3;
	overflow: hidden;
}

.image-wrapper.image-square {
	aspect-ratio: 1;
}

.image-wrapper img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.image-border {
	position: absolute;
	inset: 0;
	border: 1px solid var(--border);
	pointer-events: none;
}

.floating-badge {
	display: flex;
	position: absolute;
	bottom: -1rem;
	left: -1rem;
	background-color: var(--forge-red);
	padding: 0.75rem 1.5rem;
}



.floating-badge span {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.floating-stat {
	position: absolute;
	bottom: -2rem;
	left: -2rem;
	background-color: var(--card);
	padding: 1.5rem;
	border: 1px solid var(--border);
	display: none;
}



@media (min-width: 768px) {
	.floating-stat {
		display: block;
	}
}

@media (min-width: 1024px) {
	.floating-badge.badge-left {
		left: -1rem;
		right: auto;
	}

	.floating-badge.badge-right {
		left: auto;
		right: -1rem;
	}

	.floating-stat.badge-left {
		left: -2rem;
		right: auto;
	}

	.floating-stat.badge-right {
		left: auto;
		right: -2rem;
	}
}

/* ==========================================================================
   BLOCK STYLES
   ========================================================================== */

/* --- Local --- */
/* =====================================================
   IMAGE CTA SECTION
   ===================================================== */

.services-cta {
	position: relative;
	overflow: hidden;
	padding: 8rem 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.services-cta-bg {
	position: absolute;
	inset: 0;
}

.services-cta-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.services-cta-overlay {
	position: absolute;
	inset: 0;
	background: rgba(17, 17, 17, 0.9);
}

.services-cta-glow {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 600px;
	height: 256px;
	background: rgba(168, 35, 46, 0.2);
	filter: blur(100px);
}

.services-cta-content {
	position: relative;
	z-index: 10;
	text-align: center;
	max-width: 1280px;
	margin: 0 auto;
}

.services-cta-title {
	font-family: var(--font-heading);
	font-size: clamp(1.875rem, 5vw, 4.5rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--foreground);
	line-height: 1.2;
}

.services-cta-title .text-accent {
	color: var(--forge-red);
}

.services-cta-subtitle {
	margin-top: 1.5rem;
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--steel);
	max-width: 650px;
	margin-left: auto;
	margin-right: auto;
}

.steel-divider {
	width: 4rem;
	height: 2px;
	background-color: var(--steel);
	margin: 0 auto 2rem;
}

.btn-xl {
	padding: 1.25rem 2.5rem;
	font-size: 1.6rem;
	margin-top: 2rem;
}


/* --- Local --- */
/* =====================================================
   ABOUT HERO SECTION
   ===================================================== */

.about-hero {
	position: relative;
	min-height: 50vh;
	display: flex;
	align-items: center;
	padding-top: var(--header-height);
}

.about-hero-bg {
	position: absolute;
	inset: 0;
}

.about-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.about-hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, #111111, rgba(17, 17, 17, 0.9), transparent);
}

.about-hero-content {
	position: relative;
	z-index: 10;
	padding: 10rem 0 6rem;
}

.about-hero-text {
	max-width: 850px;
}

.about-hero-text h1 {
	font-size: clamp(2rem, 7vw, 5rem);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin-bottom: 1.5rem;
}

.about-hero-text p {
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--steel-light);
}

.section-label {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.label-line {
	width: 3rem;
	height: 1px;
	background-color: var(--forge-red);
}

.section-label span {
	font-size: 1.4rem;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	color: var(--forge-red);
}


/* --- Local --- */
/* =====================================================
   CTA SECTION BLOCK
   ===================================================== */

.cta-section {
	position: relative;
	overflow: hidden;
}

.cta-glow {
	position: absolute;
	width: 24rem;
	height: 24rem;
	border-radius: 50%;
	background-color: rgba(168, 35, 46, 0.05);
	filter: blur(60px);
}

.cta-glow-left {
	top: 0;
	left: 0;
}

.cta-glow-right {
	bottom: 0;
	right: 0;
}

.cta-content {
	position: relative;
	z-index: 10;
	max-width: 56rem;
	margin: 0 auto;
	text-align: center;
}

.cta-title {
	font-size: clamp(2rem, 10vw, 6rem);
	margin-bottom: 1.5rem;
}

.cta-description {
	font-size: 2rem;
	line-height: 1.6;
	color: var(--steel-light);
	max-width: 650px;
	margin: 0 auto 4rem;
}

.cta-buttons {
	display: flex;
	flex-direction: column;
	gap: 1.75rem;
	justify-content: center;
	margin-bottom: 6rem;
}

@media (min-width: 640px) {
	.cta-buttons {
		flex-direction: row;
	}
}

.cta-contact {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 3.5rem;
	padding-top: 4rem;
	border-top: 1px solid var(--border);
}

@media (min-width: 640px) {
	.cta-contact {
		flex-direction: row;
	}
}

.contact-item {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	color: var(--steel-light);
	transition: color 0.2s;
	width: 100%;
}

.contact-item:hover {
	color: var(--forge-red);
}

.contact-icon {
	width: 5rem;
	height: 5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--border);
	transition: border-color 0.2s;
}

.contact-item:hover .contact-icon {
	border-color: var(--forge-red);
}

.contact-icon svg {
	width: 2rem;
	height: 2rem;
}

.contact-item>div {
	text-align: left;
}

.contact-label {
	display: block;
	font-size: 1.25rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel);
	margin-bottom: 0.25rem;
}

.contact-value {
	display: block;
	font-weight: 600;
}


/* --- Local --- */
/* =====================================================
   RESOURCES HERO SECTION
   ===================================================== */

.resources-hero {
	border-bottom: 1px solid rgba(154, 159, 166, 0.1);
	padding: var(--section-padding) 0;
	padding-top: calc(var(--header-height) + 4rem);
	text-align: center;
}

.resources-hero-content {
	max-width: 650px;
	margin: 0 auto;
}

.resources-hero h1 {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 7vw, 3rem);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin-bottom: 1.5rem;
	font-weight: 700;
	line-height: 1.1;
}

.resources-hero p {
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--steel-light);
}

.section-label-center {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	margin-bottom: 2rem;
}

.label-line {
	width: 3rem;
	height: 1px;
	background-color: var(--forge-red);
}

.section-label-center span {
	font-size: 1.6rem;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	color: var(--forge-red);
}


/* --- Local --- */
/* =====================================================
   SERVICES GRID SECTION
   ===================================================== */

.services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	margin-top: 4rem;
}

@media (min-width: 768px) {
	.services-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.services-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}


.service-card {
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(154, 159, 166, 0.2);
	background: var(--card);
	transition: all 0.3s;
}

.service-card:hover {
	border-color: rgba(168, 35, 46, 0.5);
}

.service-card-image {
	position: relative;
	height: 16rem;
	overflow: hidden;
}

.service-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s;
}

.service-card:hover .service-card-image img {
	transform: scale(1.05);
}

.service-card-image-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, var(--card), transparent, transparent);
}

.service-card-icon {
	position: absolute;
	top: 1rem;
	right: 1rem;
	width: 4.5rem;
	height: 4.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(168, 35, 46, 0.5);
	background: rgba(17, 17, 17, 0.9);
}

.service-card-icon svg {
	color: var(--forge-red);
	width: 25px;
	height: 25px;
}

.service-card-content {
	padding: 1.5rem;
}

.service-card-title {
	font-family: var(--font-heading);
	font-size: 1.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--foreground);
}

h3.service-card-title {
	margin-bottom: 1rem;
}

.service-card-description {
	margin-top: 0.5rem;
	font-size: 1.4rem;
	color: var(--steel);
}

p.service-card-description {
	font-size: 1.5rem;
}

.service-card-features {
	margin-top: 1rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	list-style: none;
	margin-left: 0;
	margin-bottom: 1rem;
}

.service-card-features li {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 1.5rem;
	color: #9a9fa6;
}

.feature-dot {
	width: 4px;
	height: 4px;
	background: var(--forge-red);
	flex-shrink: 0;
}

.service-card-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 1.5rem;
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--forge-red);
	transition: color 0.2s;
}

.service-card-link:hover {
	color: rgba(168, 35, 46, 0.8);
}

.service-card-link svg {
	transition: transform 0.2s;
}

.service-card:hover .service-card-link svg {
	transform: translateX(4px);
}


/* --- Local --- */


/* --- Local --- */
/* =====================================================
   FAQ SECTION
   ===================================================== */

.contact-faq {
	background: var(--background);
	/* Fallback */
	background: #0d0d0d;
	padding: 5rem 0;
}

.faq-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

.faq-header h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.faq-header p {
	margin-top: 0.5rem;
	color: var(--steel-light);
}

.faq-list {
	max-width: 48rem;
	margin: 0 auto;
}

.faq-item {
	border: 1px solid rgba(154, 159, 166, 0.1);
	background: #111111;
	margin-bottom: 1rem;
}

.faq-question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.5rem;
	text-align: left;
	background: none;
	border: none;
	cursor: pointer;
}

.faq-question span {
	padding-right: 1rem;
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.faq-icon {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	color: var(--forge-red);
	transition: transform 0.3s;
}

.faq-item.active .faq-icon {
	transform: rotate(180deg);
}

.faq-answer {
	display: none;
	padding: 0 1.5rem 1.5rem;
	border-top: 1px solid rgba(154, 159, 166, 0.1);
}

.faq-item.active .faq-answer {
	display: block;
}

.faq-answer p {
	padding-top: 1rem;
	line-height: 1.7;
	color: var(--steel-light);
	margin: 0;
}


/* --- Local --- */
/* =====================================================
   GUIDES SECTION
   ===================================================== */

.guides-section {
	padding: 4rem 0;
	background-color: var(--background);
}

.section-header-with-icon {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 2rem;
}

.section-header-with-icon svg {
	color: var(--forge-red);
}

.section-header-with-icon h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.guides-grid {
	display: grid;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.guides-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.guide-card {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.5rem;
	border: 1px solid rgba(154, 159, 166, 0.1);
	background: #0d0d0d;
	transition: all 0.3s;
	text-decoration: none;
}

.guide-card:hover {
	border-color: var(--forge-red);
}

.guide-icon {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	margin-top: 0.25rem;
	color: var(--forge-red);
}

.guide-content h3 {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin-bottom: 0.5rem;
	transition: color 0.3s;
}

.guide-card:hover .guide-content h3 {
	color: var(--forge-red);
}

.guide-content p {
	font-family: var(--font-sans);
	font-size: 1.4rem;
	color: var(--steel-light);
	line-height: 1.6;
}

.guide-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 0.75rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--forge-red);
}

.guide-link svg {
	transition: transform 0.3s;
}

.guide-card:hover .guide-link svg {
	transform: translateX(4px);
}

.guides-cta {
	margin-top: 2rem;
	text-align: center;
}

.btn-outline {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--font-heading);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0.75rem 1.5rem;
	border: 1px solid transparent;
	transition: all 0.2s ease;
	cursor: pointer;
	background-color: transparent;
	color: #fff;
	border-color: var(--steel);
}

.btn-outline:hover {
	background-color: rgba(122, 132, 144, 0.1);
	color: var(--foreground);
}




/* --- Local --- */


/* --- Local --- */
/* =====================================================
   FEATURES GRID (Cards)
   ===================================================== */
.features-grid {
	display: grid;
	gap: 1.5rem;
	margin-bottom: 4rem;
}

@media (min-width: 640px) {
	.features-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.feature-card {
	padding: 1rem;
	border: 1px solid var(--border);
	background-color: rgba(26, 26, 26, 0.5);
}

.feature-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	color: var(--forge-red);
	margin-bottom: 1.25rem;
}

.feature-icon svg {
	width: 100%;
	height: 100%;
}

.feature-card h4 {
	font-size: 1.6rem;
	font-weight: 600;
	margin-bottom: 0.25rem;
}

.feature-card p {
	font-size: 1.4rem;
	color: var(--steel);
}

/* =====================================================
   MATERIALS TAGS
   ===================================================== */
.materials-section {
	margin-bottom: 2.5rem;
}

.materials-label {
	display: block;
	font-size: 1.4rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel);
	margin-bottom: 1rem;
}

.materials-section {
	border-top: 1px solid rgba(154, 159, 166, 0.1);
	border-bottom: 1px solid rgba(154, 159, 166, 0.1);
	background: var(--background);
	padding: var(--section-padding) 0;
}

.materials-grid {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 1rem;
}

@media (min-width: 768px) {
	.materials-grid {
		gap: 1.5rem;
	}
}

.material-tag {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1.25rem 2.25rem;
	border: 1px solid rgba(154, 159, 166, 0.2);
	background: var(--bg-primary);
	transition: all 0.3s;
}

.material-tag:hover {
	border-color: rgba(154, 159, 166, 0.5);
}

.material-tag i {
	color: rgba(154, 159, 166, 0.5);
	font-size: 1.2rem;
	transition: color 0.3s;
}

.material-tag:hover i {
	color: var(--forge-red);
}

.material-tag img.material-finish-img {
	width: 20px;
	height: 20px;
	border-radius: 4px;
	object-fit: cover;
	flex-shrink: 0;
}

.material-tag span {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	/* adjusted for scaling: 1.4rem usually equals 14px */
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel);
	transition: color 0.3s;
}

.material-tag:hover span {
	color: var(--foreground);
}

.materials-note {
	margin-top: 3rem;
	max-width: 650px;
	;
	margin-left: auto;
	margin-right: auto;
	padding: 1rem 1.5rem;
	border-left: 2px solid var(--forge-red);
	background: var(--bg-primary);
}

.materials-note p {
	font-size: 1.4rem;
	line-height: 1.7;
	color: var(--steel);
	margin: 0;
}

/* =====================================================
   BENEFITS LIST
   ===================================================== */
.benefits-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-bottom: 2.5rem;
	padding: 0;
	list-style: none;
	margin-bottom: 4rem;
}

.benefits-list li {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.benefits-list svg {
	width: 2rem;
	height: 2rem;
	color: var(--forge-red);
	flex-shrink: 0;
	margin-right: 0.5rem;
}

/* =====================================================
   SERVICE LINKS
   ===================================================== */
.service-links {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-bottom: 4rem;
}

.service-link {
	display: flex;
	align-items: flex-start;
	gap: 1.5rem;
	line-height: 1;
	padding: 2rem;
	border: 1px solid var(--border);
	background-color: rgba(26, 26, 26, 0.5);
	transition: border-color 0.2s;
}

.service-link:hover {
	border-color: rgba(168, 35, 46, 0.5);
}

.service-link svg {
	width: 2rem;
	height: 2rem;
	color: var(--forge-red);
	flex-shrink: 0;
	margin-top: 0.125rem;
}

.service-link h4 {
	font-size: 1.8rem;
	font-weight: 600;
	margin-bottom: 0.25rem;
	transition: color 0.2s;
	line-height: 1;
}

.service-link:hover h4 {
	color: var(--forge-red);
}

.service-link p {
	font-size: 1.4rem;
	color: var(--steel);
	margin: 0;
}



/* --- Local --- */


/* --- Local --- */
/* Admin View */

.admin-preview .video-overlay {
	position: absolute;
	transform: translate(-50%, -50%);
	z-index: 2;
	text-align: center;
	color: inherit;
}

.admin-preview .center-center {
	top: 50%;
	left: 50%;
}

.admin-preview .center-right {
	top: 50%;
	right: 10%;
	left: auto;
	transform: translate(0, -50%);
	text-align: right;
}

.admin-preview .center-left {
	top: 50%;
	left: 10%;
	right: auto;
	transform: translate(0, -50%);
	text-align: left;
}

.admin-preview .center-top {
	top: 10%;
	left: 50%;
	transform: translate(-50%, 0);
	text-align: center;
}

.admin-preview .center-bottom {
	bottom: 10%;
	left: 50%;
	transform: translate(-50%, 0);
	text-align: center;
}

.admin-preview .top-left {
	top: 10%;
	left: 10%;
	transform: translate(0, 0);
	text-align: left;
}

.admin-preview .top-right {
	top: 10%;
	right: 10%;
	left: auto;
	transform: translate(0, 0);
	text-align: right;
}

.admin-preview .bottom-left {
	bottom: 10%;
	left: 10%;
	top: auto;
	transform: translate(0, 0);
	text-align: left;
}

.admin-preview .bottom-right {
	bottom: 10%;
	right: 10%;
	top: auto;
	left: auto;
	transform: translate(0, 0);
	text-align: right;
}

.custom-button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: fit-content;
}

.custom-button.align-left {
	align-items: flex-start;
}

.custom-button.align-right {
	align-items: flex-end;
}

/* --- Local --- */


/* --- Local --- */
/* =====================================================
   PORTFOLIO GALLERY BLOCK
   ===================================================== */

.portfolio-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

@media (min-width: 768px) {
	.portfolio-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.portfolio-item {
	position: relative;
	aspect-ratio: 1;
	overflow: hidden;
	cursor: pointer;
	border: none;
	padding: 0;
}

.portfolio-item:focus {
	outline: 2px solid var(--forge-red);
	outline-offset: 2px;
}

.portfolio-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.portfolio-item:hover img {
	transform: scale(1.1);
}

.portfolio-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: rgba(26, 26, 26, 0.8);
	opacity: 0;
	transition: opacity 0.3s ease;
}

.portfolio-item:hover .portfolio-overlay {
	opacity: 1;
}

.portfolio-category {
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--forge-red);
	margin-bottom: 0.5rem;
}

.portfolio-title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 600;
	color: #fff;
}

.portfolio-item::after {
	content: '';
	position: absolute;
	inset: 0;
	border: 1px solid transparent;
	transition: border-color 0.2s;
	pointer-events: none;
}

.portfolio-item:hover::after {
	border-color: var(--forge-red);
}


/* --- Local --- */


/* --- Local --- */
/* =====================================================
   SERVICES HERO
   ===================================================== */

.services-hero {
	position: relative;
	/* min-height: 80vh; */
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	padding-top: 7.5rem;
}

.services-hero-bg {
	position: absolute;
	inset: 0;
}

.services-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.services-hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, #111111, rgba(17, 17, 17, 0.9), rgba(17, 17, 17, 0.6));
}

.services-hero-overlay-bottom {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, #111111, transparent, rgba(17, 17, 17, 0.4));
}

.services-hero-content {
	position: relative;
	z-index: 10;
	text-align: center;
	padding: 10rem 0;
}

p.services-hero-subtitle {
	font-size: 1.8rem;
}

.services-hero-title {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 7vw, 5.5rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--foreground);
	line-height: 1.2;
}

.services-hero-title span {
	display: block;
}

.services-hero-subtitle {
	margin-top: 1.5rem;
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--steel);
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.services-hero-buttons {
	margin-top: 2.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
}

@media (min-width: 640px) {
	.services-hero-buttons {
		flex-direction: row;
		justify-content: center;
	}
}

.services-hero-edge {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(to right, transparent, rgba(154, 159, 166, 0.3), transparent);
}


/* --- Local --- */
/* =====================================================
   PROCESS STEPS BLOCK
   ===================================================== */

.process-grid {
	display: grid;
	gap: 2rem;
	padding-top: 2rem;
}

@media (min-width: 768px) {
	.process-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.process-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.process-step {
	position: relative;
	padding: 2.25rem;
	border: 1px solid var(--border);
	background-color: var(--card);
	transition: border-color 0.2s;
}

.process-step:hover {
	border-color: rgba(168, 35, 46, 0.5);
}

.step-number {
	position: absolute;
	top: 1rem;
	right: 1rem;
	font-family: var(--font-heading);
	font-size: 3.5rem;
	font-weight: 700;
	color: var(--muted);
	line-height: 1;
	transition: color 0.2s;
}

.process-step:hover .step-number {
	color: rgba(168, 35, 46, 0.2);
}

.step-icon {
	width: 4.5rem;
	height: 4.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: rgba(168, 35, 46, 0.1);
	margin-bottom: 1.5rem;
}

.step-icon svg {
	width: 2.5rem;
	height: 2.5rem;
	color: #cb2a37;
}

.process-step h3 {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
}

.process-step p {
	font-size: 1.4rem;
	line-height: 1.6;
	color: var(--steel);
}


/* --- Local --- */
/* =====================================================
   QUALITY SECTION
   ===================================================== */

.quality-section {
	background: var(--background);
	padding: var(--section-padding) 0;
}

.quality-grid {
	display: grid;
	gap: 3rem;
	align-items: center;
}

@media (min-width: 1024px) {
	.quality-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.quality-divider {
	width: 4rem;
	height: 1px;
	margin-bottom: 1.5rem;
	background: linear-gradient(to right, var(--forge-red), transparent);
}

.quality-title {
	font-family: var(--font-heading);
	font-size: clamp(1.875rem, 4vw, 2.5rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--foreground);
	line-height: 1.2;
}

.quality-title .text-accent {
	color: var(--forge-red);
}

.quality-description {
	margin-top: 1.5rem;
	max-width: 32rem;
	line-height: 1.7;
	color: var(--steel);
}

.quality-points {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.quality-point {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.5rem;
	border-left: 2px solid rgba(154, 159, 166, 0.2);
	background: #0d0d0d;
	transition: all 0.3s;
}

.quality-point:hover {
	border-left-color: var(--forge-red);
}

.quality-point-icon {
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(154, 159, 166, 0.3);
	transition: all 0.3s;
}

.quality-point:hover .quality-point-icon {
	border-color: var(--forge-red);
	background: rgba(168, 35, 46, 0.1);
}

.quality-point-icon svg {
	color: var(--steel);
	transition: color 0.3s;
}

.quality-point:hover .quality-point-icon svg {
	color: var(--forge-red);
}

.quality-point span {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel);
	transition: color 0.3s;
}

.quality-point:hover span {
	color: var(--foreground);
}

.quality-divider-full {
	width: 100%;
	height: 1px;
	background: linear-gradient(to right, transparent, rgba(154, 159, 166, 0.2), transparent);
	margin-top: 4rem;
}


/* --- Local --- */
/* =====================================================
   BLOG SECTION
   ===================================================== */

.blog-section {
	border-top: 1px solid rgba(154, 159, 166, 0.1);
	background: #0d0d0d;
	padding: 4rem 0;
}



.blog-grid {
	display: grid;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.blog-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.blog-card {
	padding: 1.5rem;
	border: 1px solid rgba(154, 159, 166, 0.1);
	background: #111111;
	transition: all 0.3s;
	text-decoration: none;
	display: block;
}

.blog-card:hover {
	border-color: var(--forge-red);
}

.blog-card h3 {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin-bottom: 0.5rem;
	transition: color 0.3s;
	margin-top: 0;
}

.blog-card:hover h3 {
	color: var(--forge-red);
}

.blog-card p {
	font-family: var(--font-sans);
	font-size: 1.4rem;
	color: var(--steel-light);
	line-height: 1.6;
	margin-bottom: 0;
}

.blog-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 0.75rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--forge-red);
}

.blog-link svg {
	transition: transform 0.3s;
}

.blog-card:hover .blog-link svg {
	transform: translateX(4px);
}

.blog-cta {
	margin-top: 2rem;
	text-align: center;
}




/* --- Local --- */
/* =====================================================
   HERO SECTION BLOCK
   ===================================================== */

.hero {
	position: relative;
	/* min-height: 100vh; */
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.hero-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-gradient-right {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, var(--background), rgba(26, 26, 26, 0.9), rgba(26, 26, 26, 0.6));
}

.hero-gradient-top {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, var(--background), transparent, rgba(26, 26, 26, 0.4));
}

.hero-content {
	position: relative;
	z-index: 10;
	padding-top: 15rem;
	padding-bottom: 8rem;
}

.hero-text {
	max-width: 650px
}

.tagline {
	display: flex;
	align-items: center;
	gap: 1.75rem;
	margin-bottom: 2.25rem;
}

.tagline-line {
	width: 3rem;
	height: 1px;
	background-color: var(--forge-red);
}

.tagline-text {
	font-size: 1.4rem;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	color: var(--forge-red);
}

.hero-title {
	font-size: clamp(3rem, 15vw, 10rem);
	font-weight: 700;
	line-height: 0.95;
	letter-spacing: -0.02em;
	margin-bottom: 1.5rem;
}

.hero-title span {
	display: block;
}

.hero-description {
	font-size: 2rem;
	line-height: 1.6;
	color: var(--steel-light);
	margin-bottom: 3.5rem;
}

.hero-buttons {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

@media (min-width: 640px) {
	.hero-buttons {
		flex-direction: row;
	}
}

.hero-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	margin-top: 5rem;
	padding-top: 4rem;
	border-top: 1px solid var(--border);
}

.stat-number {
	display: block;
	font-family: var(--font-heading);
	font-size: clamp(2rem, 7vw, 5rem);
	font-weight: 700;
	color: var(--foreground);
	line-height: 1;
}

.stat-label {
	display: block;
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel);
	margin-top: 0.25rem;
}

/* Scroll Indicator */
.scroll-indicator {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	animation: bounce 2s infinite;
}

.scroll-indicator span {
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--steel);
}

.scroll-line {
	width: 1px;
	height: 2rem;
	background: linear-gradient(to bottom, var(--forge-red), transparent);
}

@keyframes bounce {

	0%,
	100% {
		transform: translateX(-50%) translateY(0);
	}

	50% {
		transform: translateX(-50%) translateY(-10px);
	}
}

/* --- Local --- */
/* =====================================================
   FEATURED PRODUCTS BLOCK
   ===================================================== */

.products-grid {
	display: grid;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.products-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.product-card {
	position: relative;
	background-color: var(--muted);
	overflow: hidden;
	cursor: pointer;
}

.product-image {
	position: relative;
	aspect-ratio: 4/5;
	overflow: hidden;
}

.product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.7s ease;
}

.product-card:hover .product-image img {
	transform: scale(1.05);
}

.product-gradient {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, var(--background), rgba(26, 26, 26, 0.2), transparent);
	opacity: 0.8;
}

.product-content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 1.5rem;
}

.product-category {
	display: block;
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--forge-red);
	margin-bottom: 0.5rem;
}

.product-title {
	font-size: 3remrem;
	font-weight: 700;
	margin-bottom: 0.5rem;
	transition: color 0.2s;
	color: #fff;
}

.product-card:hover .product-title {
	color: var(--forge-red);
}

.product-description {
	font-size: 1.4rem;
	line-height: 1.5;
	color: var(--steel);
	margin-bottom: 1rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.product-link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--forge-red);
}

.product-link svg {
	width: 1.5rem;
	height: 1.5rem;
	transition: transform 0.2s;
}

.product-card:hover .product-link svg {
	transform: translate(4px, -4px);
}

.product-border {
	position: absolute;
	inset: 0;
	border: 1px solid transparent;
	transition: border-color 0.2s;
	pointer-events: none;
}

.product-card:hover .product-border {
	border-color: rgba(168, 35, 46, 0.5);
}

/* --- Local --- */


/* --- Local --- */
/* =====================================================
   VALUES GRID SECTION
   ===================================================== */

.values-section {
	border-top: 1px solid rgba(154, 159, 166, 0.1);
	border-bottom: 1px solid rgba(154, 159, 166, 0.1);
	background: var(--background);
	padding: var(--section-padding) 0;
}

.values-header {
	text-align: center;
	margin-bottom: 3rem;
}

.values-header h2 {
	font-family: var(--font-heading);
	font-size: clamp(1.875rem, 4vw, 2.5rem);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--foreground);
}

.values-divider {
	width: 6rem;
	height: 1px;
	background: var(--forge-red);
	margin: 1rem auto 0;
}

.values-grid {
	display: grid;
	gap: 2rem;
}

@media (min-width: 768px) {
	.values-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.values-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.value-card {
	text-align: center;
}

.value-icon {
	width: 6rem;
	height: 6rem;
	margin: 0 auto 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--forge-red);
	background: rgba(168, 35, 46, 0.1);
}

.value-icon svg {
	width: 3rem;
	height: 3rem;
	color: var(--forge-red);
}

.value-card h3 {
	font-family: var(--font-heading);
	font-size: 2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #fff;
	margin-bottom: 0.5rem;
	font-weight: 900;
}

.values-grid .value-card p {
	font-size: 1.6rem;
	line-height: 1.7;
	color: var(--steel-light);
}


/* --- Local --- */
/* =====================================================
   TESTIMONIALS BLOCK
   ===================================================== */

.testimonials-grid {
	display: grid;
	gap: 2rem;
}

@media (min-width: 768px) {
	.testimonials-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.testimonial-card {
	position: relative;
	padding: 2rem;
	border: 1px solid var(--border);
	background-color: var(--card);
	transition: border-color 0.2s;
}

.testimonial-card:hover {
	border-color: rgba(168, 35, 46, 0.5);
}

.quote-icon {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 2.5rem;
	height: 2.5rem;
	color: rgba(168, 35, 46, 0.2);
}

.stars {
	display: flex;
	gap: 0.25rem;
	margin-bottom: 1.5rem;
}

.stars svg {
	width: 1rem;
	height: 1rem;
	color: var(--forge-red);
}

.testimonial-card blockquote {
	font-size: 1.125rem;
	line-height: 1.6;
	margin-bottom: 2rem;
	color: var(--foreground);
}

.testimonial-author {
	padding-top: 1.5rem;
	border-top: 1px solid var(--border);
}

.testimonial-author strong {
	display: block;
	font-weight: 600;
	color: var(--foreground);
}

.testimonial-author span {
	font-size: 1.4rem;
	color: var(--steel);
}



/* =====================================================
   CONTACT FORM SECTION
   ===================================================== */

.contact-form-section {
	background: #111111;
	padding: 5rem 0;
}

.contact-grid {
	display: grid;
	gap: 3rem;
}

@media (min-width: 1024px) {
	.contact-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* Contact Info */
.contact-info h2 {
	font-family: var(--font-heading);
	font-size: 2.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.contact-info>p {
	margin-top: 1rem;
	color: var(--steel-light);
	font-size: 1.8rem;
	padding-bottom: 2rem;
}

.contact-methods {
	display: grid;
	gap: 1.5rem;
	margin-top: 2.5rem;
}

@media (min-width: 640px) {
	.contact-methods {
		grid-template-columns: repeat(2, 1fr);
	}
}

.contact-method {
	padding: 1.5rem;
	border: 1px solid rgba(154, 159, 166, 0.1);
	background: #0d0d0d;
	transition: border-color 0.3s;
}

.contact-method:hover {
	border-color: rgba(168, 35, 46, 0.3);
}

.contact-method-icon {
	width: 5rem;
	height: 5rem;
	margin-bottom: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(168, 35, 46, 0.3);
	background: rgba(168, 35, 46, 0.1);
}

.contact-method-icon svg {
	color: var(--forge-red);
}

.contact-method h3 {
	font-family: var(--font-heading);
	font-size: 1.6rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin: 0;
}

.contact-method a,
.contact-method p {
	margin-top: 0.25rem;
	margin-bottom: 0;
	color: var(--steel-light);
	transition: color 0.3s;
}

.contact-method a:hover {
	color: white;
}

.contact-method-note {
	margin-top: 0.5rem;
	font-size: 1.2rem;
	color: rgba(154, 159, 166, 0.6);
}

/* Social Links */
.contact-social {
	margin-top: 2.5rem;
}

.contact-social h3 {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.social-links {
	display: flex;
	gap: 1rem;
	margin-top: 1rem;
}

.social-link {
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(154, 159, 166, 0.2);
	font-size: 1.2rem;
	color: var(--steel-light);
	transition: all 0.3s;
}

.social-link:hover {
	border-color: var(--forge-red);
	color: white;
}

/* Contact Form Card */
.contact-form-card {
	padding: 2rem;
	/* border: 1px solid rgba(154, 159, 166, 0.1); */
	border: 1px solid rgb(154 159 166 / 20%);
	background: #111111;
}

.form-content h2 {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.form-content>p {
	margin-top: 0.5rem;
	font-size: 1.4rem;
	color: var(--steel-light);
}

.contact-form {
	margin-top: 2rem;
}

.form-row {
	display: grid;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

@media (min-width: 640px) {
	.form-row {
		grid-template-columns: repeat(2, 1fr);
	}
}

.form-group {
	margin-bottom: 1.5rem;
}

.form-row .form-group {
	margin-bottom: 0;
}

.form-group label {
	display: block;
	margin-bottom: 0.5rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel-light);
}

.form-group input,
.form-group select,
.form-group textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid rgba(154, 159, 166, 0.2);
	background: #111111;
	color: white;
	font-family: inherit;
	font-size: 1rem;
	transition: border-color 0.3s;
	box-sizing: border-box;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
	color: rgba(154, 159, 166, 0.4);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--forge-red);
}

.form-group select {
	cursor: pointer;
}

.form-group textarea {
	resize: vertical;
	min-height: 120px;
}

.btn-full {
	width: 100%;
	justify-content: center;
}

.btn-primary {
	background-color: var(--forge-red);
	color: white;
	border-color: var(--forge-red);
}

/* WPForms integration styles (if used) */
.wpforms-container .wpforms-field-label {
	font-family: var(--font-heading);
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel-light) !important;
}

.wpforms-container input[type=text],
.wpforms-container input[type=email],
.wpforms-container input[type=tel],
.wpforms-container select,
.wpforms-container textarea {
	background: #111111 !important;
	border: 1px solid rgba(154, 159, 166, 0.2) !important;
	color: white !important;
	border-radius: 0 !important;
}

.wpforms-submit {
	background-color: var(--forge-red) !important;
	color: white !important;
	border-radius: 0 !important;
	font-family: var(--font-heading) !important;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	width: 100%;
}


/* --- Local --- */
/* =====================================================
   MISSION STATS SECTION
   ===================================================== */

.mission-section {
	padding: var(--section-padding) 0;
}

.mission-grid {
	display: grid;
	gap: 3rem;
	align-items: center;
}

@media (min-width: 1024px) {
	.mission-grid {
		grid-template-columns: 1fr 1fr;
	}
}

.mission-content h2 {
	font-family: var(--font-heading);
	font-size: clamp(1.875rem, 4vw, 2.5rem);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--foreground);
	margin-bottom: 1.5rem;
}

.mission-content p {
	color: var(--steel-light);
	line-height: 1.7;
	margin-bottom: 1rem;
}

.mission-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2rem;
}

.mission-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

.stat-card {
	border: 1px solid rgba(154, 159, 166, 0.1);
	background: var(--background);
	padding: 2rem;
	text-align: center;
}

.stat-card .stat-number {
	font-family: var(--font-heading);
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--forge-red);
}

.stat-card .stat-label {
	margin-top: 0.5rem;
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel-light);
}




/* --- Local --- */

/* =====================================================
   HEADER & NAVIGATION STYLES
   ===================================================== */

.wrap {
	/* Let Genesis handle wrap padding and max-widths */
}

/* Header */
.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
}

body.admin-bar .header {
	top: 32px;
}

@media (max-width: 782px) {
	body.admin-bar .header {
		top: 46px;
	}
}

/* Top Bar */
.top-bar {
	border-bottom: 1px solid rgba(154, 159, 166, 0.1);
	background: #0a0a0a;
}

.top-bar-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 40px;
}

.top-bar-left {
	display: none;
	align-items: center;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.top-bar-left {
		display: flex;
	}
}

.top-bar-link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.2rem;
	color: #9a9fa6;
	text-decoration: none;
	transition: color 0.2s;
}

.top-bar-link:hover {
	color: white;
}

.top-bar-link svg {
	flex-shrink: 0;
}

.top-bar-center {
	flex: 1;
	text-align: center;
}

@media (min-width: 768px) {
	.top-bar-center {
		flex: none;
	}
}

.top-bar-promo {
	font-size: 1.2rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #a8232e;
}

.top-bar-right {
	display: none;
	align-items: center;
	gap: 1rem;
}

@media (min-width: 768px) {
	.top-bar-right {
		display: flex;
	}
}

.top-bar-menu {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.top-bar-menu li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}

.top-bar-menu a {
	font-size: 1.2rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #9a9fa6;
	text-decoration: none;
	transition: color 0.2s;
}

.top-bar-menu a:hover {
	color: white;
}

.social-icon {
	color: #9a9fa6;
	transition: color 0.2s;
}

.social-icon:hover {
	color: white;
}

/* Main Navigation */
.main-nav {
	border-bottom: 1px solid rgba(154, 159, 166, 0.1);
	background: rgba(17, 17, 17, 0.95);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.nav-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 80px;
}

/* Logo */
.logo {
	display: flex;
	align-items: center;
}

.logo img {
	height: 48px;
	width: auto;
}

/* Desktop Navigation */
.desktop-nav {
	display: none;
	align-items: center;
	gap: 0.25rem;
}

@media (min-width: 1024px) {
	.desktop-nav {
		display: flex;
	}
}

/* Nav Links */
.nav-link {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.5rem 1rem;
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #9a9fa6;
	text-decoration: none;
	transition: color 0.2s;
}

.nav-link:hover {
	color: white;
}

.nav-link .chevron {
	transition: transform 0.2s;
}

.nav-item:hover .nav-link .chevron {
	transform: rotate(180deg);
}

/* Nav CTA */
.nav-cta {
	display: none;
	margin-left: 1rem;
}

@media (min-width: 1024px) {
	.nav-cta {
		display: inline-flex;
	}
}

/* Nav Item Container */
.nav-item {
	position: relative;
	padding: 24px 0;
	/* Bridges hover gap */
}

/* Dropdown Menu (simple) */
.dropdown-menu,
.sub-menu:not(.mega-menu *) {
	position: absolute;
	/* top: 100%; */
	top: 92%;
	left: 0;
	min-width: 200px;
	padding-top: 0.5rem;
	opacity: 0;
	visibility: hidden;
	display: block !important;
	/* Defeat Genesis native display: none */
	transform: translateY(-10px);
	transition: all 0.2s;
	list-style: none;
	padding-left: 0;
	z-index: 1000;
}

.desktop-nav .dropdown-menu {
	background: transparent;
}

.nav-item:hover .dropdown-menu,
.nav-item:hover .sub-menu:not(.mega-menu *) {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.dropdown-menu>a,
.dropdown-section>a,
.sub-menu:not(.mega-menu *)>li>a {
	display: block;
	padding: 0.75rem 1.25rem;
	font-size: 1.4rem;
	color: #9a9fa6;
	text-decoration: none;
	background: #0d0d0d;
	border: 1px solid rgba(154, 159, 166, 0.1);
	border-top: none;
	transition: all 0.2s;
}

.dropdown-menu>a:first-child,
.sub-menu:not(.mega-menu *)>li:first-child>a {
	border-top: 1px solid rgba(154, 159, 166, 0.1);
}

.dropdown-menu>a:hover,
.dropdown-section>a:hover,
.sub-menu:not(.mega-menu *)>li>a:hover {
	color: white;
	opacity: 0.8;
}

.dropdown-menu-wide {
	width: 280px;
	padding: 1rem;
	background: #0d0d0d;
	border: 1px solid rgba(154, 159, 166, 0.1);
}

.dropdown-menu-wide>a {
	border: none;
	background: none;
}

.dropdown-section {
	margin-bottom: 1rem;
}

.dropdown-section:last-child {
	margin-bottom: 0;
}

.dropdown-section-title {
	display: block;
	margin-bottom: 0.5rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	text-decoration: none;
	transition: color 0.2s;
}

.dropdown-section-title:hover {
	color: #a8232e;
}

.dropdown-section>a:not(.dropdown-section-title) {
	padding: 0.25rem 0;
	border: none;
	background: none;
}

/* Mega Menu */
.mega-menu {
	position: absolute;
	top: 100%;
	left: 50%;
	padding-top: 0.5rem;
	opacity: 0;
	visibility: hidden;
	transform: translateX(-35%) translateY(-10px);
	transition: all 0.2s;
	width: 900px;
}

.nav-item:hover .mega-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-35%) translateY(0);
}



.mega-menu-inner {
	padding: 1.5rem;
	background: #0d0d0d;
	border: 1px solid rgba(154, 159, 166, 0.1);
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

.mega-menu-grid {
	display: flex;
	gap: 1.5rem;
}

.mega-menu-featured {
	flex: 0 0 250px;
	/* Fixed width for the featured column */
	padding-right: 1.5rem;
	border-right: 1px solid rgba(154, 159, 166, 0.1);
}

.mega-menu-columns-wrap {
	flex: 1;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
	gap: 1.5rem;
	align-items: start;
}

/* Featured Card in Mega Menu */

.featured-card {
	display: block;
	text-decoration: none;
}

.featured-card:hover .featured-image img {
	transform: scale(1.05);
}

.featured-image {
	position: relative;
	aspect-ratio: 1;
	overflow: hidden;
	margin-bottom: 0.75rem;
}

.featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}

.featured-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
}

.featured-content {
	position: absolute;
	bottom: 0.75rem;
	left: 0.75rem;
	right: 0.75rem;
}

.featured-label {
	display: block;
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #a8232e;
}

.featured-title {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.featured-desc {
	font-size: 1.2rem;
	line-height: 1.5;
	color: #9a9fa6;
}

/* Mega Menu Columns */
.mega-menu-column {
	/* Column styles */
}

.column-title {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	text-decoration: none;
	transition: color 0.2s;
}

.column-title:hover {
	color: #a8232e;
}

.column-title svg {
	color: #a8232e;
}

.column-title-simple {
	display: block;
	margin-bottom: 0.75rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	text-decoration: none;
	transition: color 0.2s;
}

.column-title-simple:hover {
	color: #a8232e;
}

.column-links {
	list-style: none;
	padding: 0;
	margin: 0;
}

.column-links li {
	margin-bottom: 0.5rem;
}

.column-links a {
	font-size: 1.2rem;
	color: #9a9fa6;
	text-decoration: none;
	transition: color 0.2s;
}

.column-links a:hover {
	color: white;
}

/* Mega Menu Empty Column Cards */
.mega-menu-card {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	text-decoration: none;
	width: 100%;
}

.mega-menu-card-title h4 {
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	transition: color 0.2s;
	margin: 0;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.mega-menu-card:hover .mega-menu-card-title h4 {
	color: var(--forge-red);
}

.mega-menu-card-image {
	width: 100%;
	aspect-ratio: 4/3;
	overflow: hidden;
	border: 1px solid var(--border);
	background: var(--card);
}

.mega-menu-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.mega-menu-card:hover .mega-menu-card-image img {
	transform: scale(1.05);
}


/* Mega Menu Footer */
.mega-menu-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 1.5rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(154, 159, 166, 0.1);
}

.mega-menu-footer p {
	font-size: 1.4rem;
	color: #9a9fa6;
	margin: 0;
}

.mega-menu-cta {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #a8232e;
	text-decoration: none;
	transition: color 0.2s;
}

.mega-menu-cta:hover {
	color: white;
}

/* Mobile Toggle */
.mobile-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	padding: 0;
	background: none;
	border: none;
	color: white;
	cursor: pointer;
}

@media (min-width: 1024px) {
	.mobile-toggle {
		display: none;
	}
}

/* Mobile Menu */
.mobile-menu {
	display: none;
	position: fixed;
	top: 120px;
	left: 0;
	right: 0;
	bottom: 0;
	background: #0d0d0d;
	padding: 1.5rem;
	overflow-y: auto;
}

.mobile-menu.active {
	display: block;
}

@media (min-width: 1024px) {
	.mobile-menu {
		display: none !important;
	}
}

.mobile-nav {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-nav-link {
	display: block;
	padding: 1rem;
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #9a9fa6;
	text-decoration: none;
	border: 1px solid rgba(154, 159, 166, 0.1);
	transition: all 0.2s;
}

.mobile-nav-link:hover {
	color: white;
	border-color: #a8232e;
}

.mobile-cta {
	margin-top: 1rem;
	text-align: center;
}

/* =====================================================
   FOOTER STYLES
   ===================================================== */

.footer {
	border-top: 1px solid rgba(154, 159, 166, 0.1);
	background: #0a0a0a;
	padding: 4rem 0 0;
}

.footer-grid {
	display: grid;
	gap: 3rem;
}

@media (min-width: 768px) {
	.footer-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.footer-grid {
		grid-template-columns: 1.5fr 1fr 1fr 1fr;
	}
}

/* Footer Brand */
.footer-brand {
	/* Brand column */
}

.footer-logo {
	height: 96px;
	width: auto;
}

.footer-tagline {
	margin-top: 1rem;
	font-size: 1.4rem;
	line-height: 1.7;
	color: #9a9fa6;
	max-width: 300px;
}

.footer-contact {
	margin-top: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.footer-contact-link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 1.4rem;
	color: #9a9fa6;
	text-decoration: none;
	transition: color 0.2s;
}

.footer-contact-link:hover {
	color: white;
}

.footer-contact-link svg {
	color: #a8232e;
	flex-shrink: 0;
}

.footer-address {
	align-items: flex-start;
}

.footer-address svg {
	margin-top: 2px;
}

/* Footer Columns */
.footer-column {
	/* Column styles */
}

.footer-heading {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin-bottom: 1rem;
}

.footer-links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}


.footer-links li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}

.footer-links a {
	font-size: 1.4rem;
	color: #9a9fa6;
	text-decoration: none;
	transition: color 0.2s;
}

.footer-links a:hover {
	color: white;
}

/* Footer Bottom */
.footer-bottom {
	margin-top: 3rem;
	padding: 2rem 0;
	border-top: 1px solid rgba(154, 159, 166, 0.1);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

@media (min-width: 768px) {
	.footer-bottom {
		flex-direction: row;
	}
}

.footer-copyright,
.footer-slogan {
	font-size: 1.2rem;
	color: #9a9fa6;
	margin: 0;
}

/* ## WooCommerce Single Product
--------------------------------------------- */

/* ## WooCommerce Single Product
--------------------------------------------- */

.woocommerce div.product form.cart .variations select {
	color: #ffffff;
	background-color: #1a1a1a;
	border: 1px solid #333333;
	padding: 0.5rem 1rem;
	border-radius: 4px;
	line-height: 1.5;
}

.woocommerce div.product form.cart .variations select option {
	color: #ffffff;
	background-color: #1a1a1a;
}

.woocommerce-shop .content-sidebar-wrap {
	display: flex;
	flex-direction: column;
	gap: 3rem;
	padding: 12rem 0 4rem;
	width: 100%;
	max-width: 1250px;
	margin: 0 auto;
}

label.wapf-input-label {
	display: flex;
	align-items: center;
}

.wapf-field-input input[type=radio] {
	margin: 0;
}

.wapf-field-description {
	padding: 1rem 0 3rem;
	font-size: 1.4rem;
}

label.wapf-input-label {
	display: flex;
	align-items: center;
	font-size: 1.6rem;
}

span.wapf-label-text {
	font-size: 1.6rem;
}

label.wapf-checkbox-label {
	display: flex;
	align-items: center;
}

.wapf-field-input input[type=checkbox] {
	margin-top: 0;
}

/* Main Layout Grid */
.woocommerce div.product .product-main-grid {
	display: grid;
	gap: 4rem;
	padding-top: 10rem;
	padding-bottom: 4rem;
	box-sizing: border-box;
	width: 100%;
}

.woocommerce div.product .product-main-grid>* {
	min-width: 0;
}

@media (min-width: 1024px) {
	.woocommerce div.product .product-main-grid {
		grid-template-columns: 1.2fr 1fr;
		/* ~55/45 split */
		align-items: flex-start;
	}
}

/* Gallery Column */
.woocommerce div.product .product-gallery-column {
	width: 100%;
}

.woocommerce div.product div.images {
	width: 100% !important;
	float: none !important;
	margin-bottom: 0 !important;
}

.woocommerce div.product div.images img {
	border-radius: 0;
	box-shadow: none;
	border: 1px solid var(--border);
}

.woocommerce div.product div.images .flex-control-thumbs {
	margin-top: 1rem;
	display: flex;
	gap: 1rem;
}

.woocommerce div.product div.images .flex-control-thumbs li {
	width: calc(25% - 0.75rem);
	float: none;
}

.woocommerce div.product div.images .flex-control-thumbs li img {
	border: 1px solid var(--border);
	opacity: 0.6;
	transition: opacity 0.3s ease;
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li img:hover {
	opacity: 1;
	border-color: var(--forge-red);
}

/* Summary Column */
.woocommerce div.product .summary.entry-summary {
	width: 100% !important;
	float: none !important;
}

/* Typography Overrides */
.woocommerce div.product .product_title.product-hero-title {
	font-family: var(--font-heading);
	font-size: clamp(3rem, 5vw, 4.5rem);
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.1;
	color: white;
	margin-bottom: 1rem;
}

.woocommerce div.product p.price.product-hero-price {
	font-family: var(--font-heading);
	font-size: 2.4rem;
	font-weight: 700;
	color: var(--forge-red);
	margin-bottom: 2rem;
}

/* Subdued Meta */
.woocommerce div.product .product_meta.subdued-meta {
	border-top: 1px solid var(--border);
	padding-top: 2rem;
	margin-top: 3rem;
	font-size: 1.3rem;
	color: #9a9fa6;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.woocommerce div.product .product_meta.subdued-meta a {
	color: white;
	text-decoration: none;
	transition: color 0.3s ease;
}

.woocommerce div.product .product_meta.subdued-meta a:hover {
	color: var(--forge-red);
}

/* Add to Cart Area */
.woocommerce div.product form.cart {
	margin-top: 3rem;
	margin-bottom: 3rem;
	display: flex;
	gap: 1.5rem;
	align-items: stretch;
	flex-wrap: wrap;
}

.woocommerce div.product form.cart .quantity {
	background: var(--card);
	/* border: 1px solid var(--border); */
	display: flex;
	align-items: center;
	margin-right: 1rem !important;
}

.woocommerce div.product form.cart .quantity .qty {
	background: transparent;
	border: none;
	color: white;
	font-family: var(--font-body);
	font-size: 1.6rem;
	padding: 0 1rem;
	width: 60px;
	height: 50px;
	text-align: center;
}

.woocommerce div.product form.cart .button {
	background-color: var(--forge-red);
	color: white;
	font-family: var(--font-heading);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0 3rem;
	height: 52px;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.3s ease, transform 0.3s ease;
	cursor: pointer;
}

.woocommerce div.product form.cart .button:hover {
	background-color: #8a1d26;
	transform: translateY(-2px);
}

/* Product Tabs */
.woocommerce div.product .woocommerce-tabs {
	padding-top: 4rem;
	border-top: 1px solid var(--border);
	clear: both;
	max-width: 1250px;
	margin: 4rem auto;
	padding-bottom: 4rem;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	list-style: none;
	padding: 0;
	margin: 0 0 3rem 0;
	display: flex;
	gap: 3rem;
	border-bottom: 1px solid var(--border);
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0;
	border: none !important;
	background: transparent !important;
	border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 1rem 0;
	font-family: var(--font-heading);
	font-size: 1.6rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #9a9fa6 !important;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color 0.3s ease, border-color 0.3s ease;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: white !important;
	border-color: var(--forge-red);
}

.woocommerce div.product .woocommerce-tabs .panel {
	color: #9a9fa6;
	font-size: 1.6rem;
	line-height: 1.8;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-family: var(--font-heading);
	font-size: 2.4rem;
	color: white;
	margin-bottom: 2rem;
}

.woocommerce div.product .woocommerce-tabs .panel p {
	margin-bottom: 2rem;
}

.woocommerce div.product .woocommerce-tabs .panel ul,
.woocommerce div.product .woocommerce-tabs .panel ol {
	margin-bottom: 2rem;
	padding-left: 2rem;
}

.woocommerce div.product .woocommerce-tabs .panel li {
	margin-bottom: 1rem;
}

/* Attributes Table (Additional Information) */
.woocommerce table.shop_attributes {
	width: 100%;
	border: 1px solid var(--border);
	border-collapse: collapse;
	margin-bottom: 2rem;
	font-size: 1.6rem;
}

.woocommerce table.shop_attributes th,
.woocommerce table.shop_attributes td {
	padding: 1.5rem;
	border-bottom: 1px solid var(--border);
	vertical-align: top;
	background: transparent;
}

.woocommerce table.shop_attributes th {
	width: 200px;
	font-weight: 700;
	color: white;
	border-right: 1px solid var(--border);
}

.woocommerce table.shop_attributes td {
	color: #9a9fa6;
}

.woocommerce table.shop_attributes tr:last-child th,
.woocommerce table.shop_attributes tr:last-child td {
	border-bottom: none;
}

.woocommerce table.shop_attributes td p {
	margin: 0;
	padding: 0;
}

/* Related Products Grid */
.woocommerce .related.products {
	margin-top: 6rem;
	clear: both;
}

.woocommerce .related.products>h2 {
	font-family: var(--font-heading);
	font-size: 3rem;
	color: white;
	margin-bottom: 3rem;
	text-align: center;
}

/* Shop Loop Grid & Related Products */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 2rem;
	margin: 0 0 6rem 0 !important;
	padding: 0;
	clear: both;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none !important;
}

.woocommerce ul.products li.product {
	width: 100% !important;
	margin: 0 !important;
	float: none !important;
	background: #1a1a1a;
	border: 1px solid rgba(154, 159, 166, 0.2);
	text-align: left;
	transition: all 0.3s ease;
	display: flex;
	flex-direction: column;
	position: relative;
	overflow: hidden;
}

.woocommerce ul.products li.product:hover {
	border-color: rgba(168, 35, 46, 0.5);
	transform: translateY(-5px);
}

.woocommerce ul.products li.product .onsale {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: var(--forge-red);
	color: white;
	padding: 0.25rem 0.75rem;
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: 2px;
	z-index: 10;
	margin: 0;
	min-height: auto;
	min-width: auto;
	line-height: 1;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	text-decoration: none;
}

.woocommerce ul.products li.product img {
	width: 100%;
	height: 240px;
	object-fit: cover;
	margin: 0 0 1.5rem 0 !important;
	transition: transform 0.5s;
}

.woocommerce ul.products li.product:hover img {
	transform: scale(1.05);
	/* subtle zoom effect */
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	color: white;
	margin: 0 1.5rem 0.5rem 1.5rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	transition: color 0.3s;
}

.woocommerce ul.products li.product:hover .woocommerce-loop-product__title {
	color: var(--forge-red);
}

.woocommerce ul.products li.product .price {
	color: var(--steel-light);
	font-weight: 500;
	font-size: 1.4rem;
	margin: 0 1.5rem 1.5rem 1.5rem;
}

.woocommerce ul.products li.product .price ins {
	color: var(--forge-red);
	text-decoration: none;
	font-weight: 700;
}

.woocommerce ul.products li.product .button {
	margin: auto 1.5rem 1.5rem 1.5rem;
	display: inline-block;
	background: transparent;
	border: 1px solid rgba(154, 159, 166, 0.2);
	color: white;
	padding: 1rem 1.5rem;
	text-align: center;
	font-family: var(--font-heading);
	text-transform: uppercase;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	transition: all 0.3s ease;
	width: calc(100% - 3rem);
}

.woocommerce ul.products li.product .button:hover {
	background: var(--forge-red);
	border-color: var(--forge-red);
	color: white;
}

/* ## WooCommerce Shop Archive Header
--------------------------------------------- */
.woocommerce .woocommerce-products-header__title.page-title {
	font-family: var(--font-heading);
	font-size: clamp(3.5rem, 5vw, 5rem);
	text-transform: uppercase;
	font-weight: 700;
	color: white;
	margin-top: 4rem;
	margin-bottom: 2rem;
	text-align: center;
}

.woocommerce-result-count,
.woocommerce-ordering {
	margin-bottom: 3rem !important;
	color: var(--steel-light);
}

.woocommerce-ordering select {
	background: #111;
	color: white;
	border: 1px solid rgba(154, 159, 166, 0.2);
	padding: 0.75rem 3rem 0.75rem 1rem;
	font-family: var(--font-body);
	outline: none;
}

.woocommerce-ordering select:focus {
	border-color: var(--forge-red);
}

/* WooCommerce Pagination */
.woocommerce nav.woocommerce-pagination {
	margin-top: 4rem;
	margin-bottom: 6rem;
}

.woocommerce nav.woocommerce-pagination ul {
	border: none;
	display: flex;
	justify-content: center;
	gap: 1rem;
}

.woocommerce nav.woocommerce-pagination ul li {
	border: none;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span.current {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 4.5rem;
	height: 4.5rem;
	border: 1px solid var(--border);
	background: transparent;
	color: white;
	font-weight: 700;
	font-size: 1.6rem;
	transition: all 0.3s ease;
	padding: 0;
	text-decoration: none;
}

.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li a:focus {
	background: var(--forge-red);
	border-color: var(--forge-red);
	color: white;
}

/* ## Standard Theme Archives (Blog, Events, etc.)
--------------------------------------------- */

/* Shared Archive Loop Layouts */
.blog-archive--loop,
.events-archive--wrapper,
.team-member-archive {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 3rem;
	padding: 4rem 0;
}

/* Archive Cards */
article.post,
.at-content-archive,
.team-member-archive .team-member--link {
	background: var(--card);
	border: 1px solid var(--border);
	padding: 2.5rem;
	border-radius: 0;
	transition: border-color 0.3s ease, transform 0.3s ease;
	display: flex;
	flex-direction: column;
	text-decoration: none;
}

article.post:hover,
.at-content-archive:hover,
.team-member-archive .team-member--link:hover {
	border-color: var(--forge-red);
	transform: translateY(-5px);
}

/* Archive Images */
article.post .entry-image-link,
.at-content-archive img,
.team-member--headshot img {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	margin-bottom: 2rem;
	border: 1px solid var(--border);
}

.team-member--headshot img {
	aspect-ratio: 1;
	/* Square for headshots */
}

/* Archive Typography */
.entry-title,
.at-content-archive--heading h2,
.team-member--content-name h2 {
	font-family: var(--font-heading);
	font-size: 2.4rem;
	color: white;
	margin-bottom: 1rem;
	font-weight: 700;
	line-height: 1.2;
}

.entry-title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.3s ease;
}

.entry-title a:hover {
	color: var(--forge-red);
}

.entry-content p,
.at-content-archive--details,
.team-member--content-role p {
	color: #9a9fa6;
	font-size: 2rem;
	line-height: 1.6;
	margin-bottom: 2rem;
}

.entry-meta {
	font-size: 1.3rem;
	color: #9a9fa6;
	margin-bottom: 2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.entry-meta a {
	color: var(--forge-red);
	text-decoration: none;
}

/* Read More Buttons */
.more-link,
.event-link {
	margin-top: auto;
	display: inline-block;
	background: transparent;
	border: 1px solid var(--border);
	color: white;
	padding: 1.25rem 2.5rem;
	font-family: var(--font-heading);
	text-transform: uppercase;
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	transition: all 0.3s ease;
	text-align: center;
	text-decoration: none;
}

.more-link:hover,
.event-link:hover {
	background: var(--forge-red);
	border-color: var(--forge-red);
	color: white;
}

/* Standard Pagination */
.archive-pagination {
	margin-top: 4rem;
	margin-bottom: 6rem;
	display: flex;
	justify-content: center;
	gap: 1rem;
}

.archive-pagination li {
	list-style: none;
}

.archive-pagination li a,
.archive-pagination li.active a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 4.5rem;
	height: 4.5rem;
	border: 1px solid var(--border);
	background: transparent;
	color: white;
	font-weight: 700;
	font-size: 1.6rem;
	transition: all 0.3s ease;
	text-decoration: none;
}

.archive-pagination li.active a,
.archive-pagination li a:hover {
	background: var(--forge-red);
	border-color: var(--forge-red);
	color: white;
}

/* =====================================================
   INNER HERO (CONTACT / ABOUT)
   ===================================================== */
.contact-hero {
	position: relative;
	height: 40vh;
	min-height: 350px;
	overflow: hidden;
}

.contact-hero-bg {
	position: absolute;
	inset: 0;
}

.contact-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.contact-hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(17, 17, 17, 0.7), rgba(17, 17, 17, 0.5), var(--background));
}

.contact-hero-content {
	position: relative;
	z-index: 10;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding-top: var(--header-height);
}

.contact-hero h1 {
	font-size: clamp(2rem, 6vw, 6rem);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.contact-hero p {
	margin-top: 1rem;
	font-size: 1.6rem;
	color: var(--steel-light);
	max-width: 650px;
	;
}

/* =====================================================
   CONTACT FORM SECTION
   ===================================================== */
.contact-form-section {
	background: var(--background);
	padding: 5rem 0;
}

.contact-grid {
	display: grid;
	gap: 3rem;
}

@media (min-width: 1024px) {
	.contact-grid {
		grid-template-columns: 1fr 1fr;
	}
}

.contact-info h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.contact-info>p {
	margin-top: 1rem;
	color: var(--steel-light);
}

.contact-methods {
	display: grid;
	gap: 1.5rem;
	margin-top: 2.5rem;
}

@media (min-width: 640px) {
	.contact-methods {
		grid-template-columns: repeat(2, 1fr);
	}
}

.contact-method {
	padding: 1.5rem;
	border: 1px solid rgb(154 159 166 / 20%);
	background: #111;
	transition: border-color 0.3s;
}

.contact-method:hover {
	border-color: rgba(168, 35, 46, 0.3);
}

.contact-method-icon {
	width: 5rem;
	height: 5rem;
	margin-bottom: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(168, 35, 46, 0.3);
	background: rgba(168, 35, 46, 0.1);
}

.contact-method-icon svg,
.contact-method-icon i {
	color: var(--forge-red);
	font-size: 2.5rem;
}

.contact-method h3 {
	font-family: var(--font-heading);
	font-size: 1.6rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
	margin-bottom: 0.25rem;
}

.contact-method a,
.contact-method p.contact-method-primary {
	margin-top: 0.25rem;
	color: var(--steel-light);
	transition: color 0.3s;
	font-size: 1.6rem;
}

.contact-method a:hover {
	color: white;
}

.contact-method-note {
	margin-top: 0.5rem;
	font-size: 1.2rem;
	color: rgba(154, 159, 166, 0.6);
}

.contact-form-card {
	padding: 2rem;
	background: #111;
	border: 1px solid rgb(154 159 166 / 20%);
}

.form-content h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.form-content>p {
	margin-top: 0.5rem;
	font-size: 1.4rem;
	color: var(--steel-light);
}

.contact-form {
	margin-top: 2rem;
}

.form-row {
	display: grid;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

@media (min-width: 640px) {
	.form-row {
		grid-template-columns: repeat(2, 1fr);
	}
}

.form-group {
	margin-bottom: 1.5rem;
}

.form-row .form-group {
	margin-bottom: 0;
}

.form-group label {
	display: block;
	margin-bottom: 0.5rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--steel-light);
}

.form-group input,
.form-group select,
.form-group textarea {
	width: 100%;
	padding: 1rem 1.5rem;
	border: 1px solid rgba(154, 159, 166, 0.2);
	background: var(--background);
	color: white;
	font-family: inherit;
	font-size: 1.4rem;
	transition: border-color 0.3s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--forge-red);
}

/* =====================================================
   FAQ SECTION
   ===================================================== */
.contact-faq {
	background: var(--card);
	padding: 5rem 0;
}

.faq-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

.faq-header h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.faq-header p {
	margin-top: 0.5rem;
	color: var(--steel-light);
}

.faq-list {
	max-width: 68rem;
	margin: 0 auto;
}

.faq-item {
	border: 1px solid rgba(154, 159, 166, 0.1);
	background: var(--background);
	margin-bottom: 1rem;
}

.faq-question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.5rem;
	text-align: left;
	background: none;
	border: none;
	cursor: pointer;
}

.faq-question span {
	padding-right: 1rem;
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: white;
}

.faq-icon {
	flex-shrink: 0;
	font-size: 1.25rem;
	color: var(--forge-red);
	transition: transform 0.3s;
}

.faq-item.active .faq-icon {
	transform: rotate(180deg);
}

.faq-answer {
	display: none;
	padding: 0 1.5rem 1.5rem;
	border-top: 1px solid rgba(154, 159, 166, 0.1);
}

.faq-item.active .faq-answer {
	display: block;
}

.faq-answer p {
	padding-top: 1rem;
	line-height: 1.7;
	color: var(--steel-light);
	font-size: 1.4rem;
}

p.service-card-description {
	font-size: 1.6rem;
}

.materials-note p {
	font-size: 1.6rem;
}

section.materials-section .section-header {
	text-align: center;
}

.materials-grid {
	padding: 2rem 0;
	max-width: 800px;
	margin: 0 auto;
}

p+h2,
p+h3,
p+h4,
p+h5 {

	padding-top: 4rem;
}

h2.wp-block-heading+h3.wp-block-heading {
	padding-top: 1rem;
}

.entry-content strong {
	color: #fff;
}

.entry-content>.wp-block-genesis-blocks-gb-columns:last-child,
.entry-content>.wp-block-genesis-blocks-gb-columns:last-of-type {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

/* =====================================================
   SINGLE BLOG POSTS (GENESIS)
   ===================================================== */

/* Disable Comments & Discussions Globally */
#comments,
#respond,
#reply-title,
.comment-respond,
.comment-list,
.entry-comments-link {
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	height: 0 !important;
	pointer-events: none !important;
}

.single-post .content,
.single-post .entry {
	max-width: 800px;
	margin: 0 auto;
	padding: 4rem 2rem;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
}

.single-post .entry-header {
	margin-bottom: 3rem;
	text-align: center;
	border-bottom: 1px solid rgba(154, 159, 166, 0.2);
	padding-bottom: 3rem;
}

.single-post .entry-title {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 7vw, 3.5rem);
	line-height: 1.1;
	margin-bottom: 1rem;
	color: #fff;
}

.single-post .entry-meta {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--steel);
	margin-bottom: 0;
}

.single-post .entry-meta a {
	color: var(--steel-light);
	text-decoration: none;
	transition: color 0.2s;
}

.single-post .entry-meta a:hover {
	color: var(--forge-red);
}

.single-post .entry-content p {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--steel-light);
	margin-bottom: 2rem;
}

.single-post .entry-content h2,
.single-post .entry-content h3 {
	font-family: var(--font-heading);
	color: #fff;
	margin-top: 4rem;
	margin-bottom: 1.5rem;
}

.single-post .entry-content ul,
.single-post .entry-content ol {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--steel-light);
	margin-bottom: 2rem;
	padding-left: 2rem;
}

.single-post .entry-content li {
	margin-bottom: 0.5rem;
}

.single-post .entry-content blockquote {
	margin: 3rem 0;
	padding: 2rem 2rem 2rem 3rem;
	border-left: 4px solid var(--forge-red);
	background: var(--card);
	font-size: 1.25rem;
	font-style: italic;
	color: #fff;
	border-radius: 0 4px 4px 0;
}

.single-post .entry-content img {
	border-radius: 8px;
	margin: 2rem 0;
	border: 1px solid rgba(154, 159, 166, 0.2);
}

.single-post .entry-footer {
	margin-top: 4rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(154, 159, 166, 0.2);
}

.single-post .entry-categories {
	display: inline-block;
	background: rgba(168, 35, 46, 0.1);
	border: 1px solid rgba(168, 35, 46, 0.3);
	padding: 0.5rem 1rem;
	border-radius: 4px;
	font-size: 1.4rem;
	color: var(--steel-light);
}

.single-post .entry-categories a {
	color: #fff;
	font-weight: 500;
}

.single-post .entry-categories a:hover {
	color: var(--forge-red);
}

/* ==========================================================================
   GRAVITY FORMS DARK MODE INTEGRATION
   ========================================================================== */

/* Wrapper & Layout */
.gform_wrapper.gravity-theme {
	margin: 2rem 0;
}

.gform_wrapper.gravity-theme .gform_fields {
	grid-row-gap: 1.5rem !important;
}

/* Labels & Descriptions */
.gform_wrapper.gravity-theme .gfield_label {
	color: var(--steel-light) !important;
	font-family: var(--font-heading) !important;
	font-size: 1.4rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	margin-bottom: 0.5rem !important;
	display: block !important;
}

.gform_wrapper.gravity-theme .gfield_description {
	color: #666 !important;
	font-size: 1.4rem !important;
	margin-top: 0.5rem !important;
}

/* Standard Global Form Element Borders */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="search"],
textarea,
select {
	border: 1px solid rgb(154 159 166 / 20%);
}

/* Inputs, Textareas, & Selects */
.gform_wrapper.gravity-theme input[type="text"],
.gform_wrapper.gravity-theme input[type="email"],
.gform_wrapper.gravity-theme input[type="tel"],
.gform_wrapper.gravity-theme input[type="url"],
.gform_wrapper.gravity-theme input[type="number"],
.gform_wrapper.gravity-theme textarea,
.gform_wrapper.gravity-theme select {
	background: #0d0d0d !important;
	border: 1px solid rgb(154 159 166 / 20%) !important;
	color: #fff !important;
	border-radius: 4px !important;
	padding: 1rem 1.25rem !important;
	width: 100% !important;
	max-width: 100% !important;
	font-size: 1.5rem !important;
	transition: all 0.3s ease !important;
	font-family: var(--font-body) !important;
	box-shadow: none !important;
}

/* Focus States */
.gform_wrapper.gravity-theme input[type="text"]:focus,
.gform_wrapper.gravity-theme input[type="email"]:focus,
.gform_wrapper.gravity-theme input[type="tel"]:focus,
.gform_wrapper.gravity-theme textarea:focus,
.gform_wrapper.gravity-theme select:focus {
	border-color: var(--forge-red) !important;
	outline: none !important;
	box-shadow: 0 0 10px rgba(168, 35, 46, 0.15) !important;
}

/* Submit Button */
.gform_wrapper.gravity-theme .gform_footer input[type="submit"] {
	background: transparent !important;
	color: var(--forge-red) !important;
	border: 1px solid var(--forge-red) !important;
	padding: 1rem 2rem !important;
	font-family: var(--font-heading) !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	font-size: 1.8rem !important;
	border-radius: 0 !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 200px !important;
	margin-top: 0 !important;
}

.gform_wrapper.gravity-theme .gform_footer input[type="submit"]:hover {
	background: var(--forge-red) !important;
	color: #fff !important;
	box-shadow: 0 0 20px rgba(168, 35, 46, 0.4) !important;
}

/* Error States */
.gform_wrapper.gravity-theme .gfield_error input,
.gform_wrapper.gravity-theme .gfield_error textarea {
	border-color: #ff3333 !important;
	background: rgba(255, 51, 51, 0.05) !important;
}

.gform_wrapper.gravity-theme .validation_message {
	color: #ff3333 !important;
	font-size: 1.4rem !important;
	margin-top: 0.5rem !important;
	font-weight: 500 !important;
}

.gform_wrapper.gravity-theme .gform_validation_errors {
	background: rgba(255, 51, 51, 0.1) !important;
	border: 1px solid #ff3333 !important;
	border-radius: 4px !important;
	padding: 1.5rem !important;
	margin-bottom: 2rem !important;
}

.gform_wrapper.gravity-theme .gform_validation_errors>h2 {
	color: #fff !important;
	font-size: 1.125rem !important;
	margin-bottom: 0 !important;
}

/* File Upload & Drop Zone */
.gform_wrapper.gravity-theme .ginput_container_fileupload {
	background: #0d0d0d !important;
	border: 1px dashed rgb(154 159 166 / 30%) !important;
	border-radius: 4px !important;
	padding: 2rem !important;
	text-align: center !important;
	transition: all 0.3s ease !important;
	margin-top: 0.5rem !important;
}

.gform_wrapper.gravity-theme .ginput_container_fileupload:hover {
	border-color: var(--forge-red) !important;
	background: rgba(168, 35, 46, 0.05) !important;
}

.gform_wrapper.gravity-theme .gform_drop_instructions {
	color: var(--steel-light) !important;
	display: block !important;
	margin-bottom: 1rem !important;
	font-size: 1.4rem !important;
}

/* Select Files Button */
.gform_wrapper.gravity-theme .ginput_container_fileupload input[type="button"],
.gform_wrapper.gravity-theme .gform_button_select_files,
.gform_wrapper.gravity-theme input[type="file"]::-webkit-file-upload-button {
	background: transparent !important;
	color: #fff !important;
	border: 1px solid rgb(154 159 166 / 50%) !important;
	padding: 0.75rem 1.5rem !important;
	font-family: var(--font-heading) !important;
	font-weight: 500 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	font-size: 1.4rem !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	border-radius: 4px !important;
	display: inline-block !important;
}

.gform_wrapper.gravity-theme .ginput_container_fileupload input[type="button"]:hover,
.gform_wrapper.gravity-theme .gform_button_select_files:hover,
.gform_wrapper.gravity-theme input[type="file"]::-webkit-file-upload-button:hover {
	border-color: white !important;
	color: white !important;
	background: rgba(255, 255, 255, 0.05) !important;
}

/* File List Preview */
.gform_wrapper.gravity-theme .ginput_preview {
	color: #9a9fa6 !important;
	font-size: 1.4rem !important;
	margin-top: 1rem !important;
	padding: 0.5rem !important;
	background: rgba(255, 255, 255, 0.02) !important;
	border-radius: 4px !important;
}

.gform_wrapper.gravity-theme .ginput_delete {
	filter: invert(1) brightness(2);
	/* Makes the native red delete X visible on black bg */
}

.request-form_wrapper {
	background: #151515;
	padding: 3rem 4rem;
	border: 1px solid rgb(154 159 166 / 20%);
}

p.gform_required_legend {
	font-size: 1.2rem;
}

.gfield {
	padding: 1rem 0;
}

/* ==========================================================================
   BLOG ARCHIVE & CUSTOM POST TYPE GRIDS
   ========================================================================== */

/* Blog Archive Header */

.blog .content-sidebar-wrap {
	padding: 10rem 0 0;
}

.blog-archive-header {
	max-width: 1250px;
	margin: 5rem auto 0;
	padding: 0;
	border-bottom: 2px solid var(--forge-red);
}

.blog-archive-title {
	font-family: var(--font-heading);
	font-size: 5rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #fff;
	margin: 0 0 1rem 0;
}

@media (max-width: 768px) {
	.blog-archive-title {
		font-size: 3.5rem;
	}
}

/* Main Archive Layout */
.blog-archive {
	display: flex;
	flex-direction: column;
	gap: 3rem;
	padding: 4rem 0;
	width: 100%;
	max-width: 1250px;
	margin: 0 auto;
}

@media (min-width: 1024px) {
	.blog-archive {
		flex-direction: row;
		align-items: flex-start;
		gap: 5rem;
	}

	.blog-archive--sidebar {
		width: 320px;
		flex-shrink: 0;
		position: sticky;
		top: 120px;
	}

	.blog-archive--loop {
		flex: 1;
		min-width: 0;
	}
}

/* Article Grid */
.blog-articles {
	display: grid;
	gap: 2.5rem;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

@media (min-width: 1200px) {
	.blog-articles.blog-articles--three-column {
		grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
	}
}

/* Featured Header */
.featured-articles h2 {
	font-family: var(--font-heading);
	font-size: 2.4rem;
	color: #fff;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: 2rem;
	border-bottom: 1px solid rgb(154 159 166 / 20%);
	padding-bottom: 1rem;
}

.featured-articles .blog-article {
	margin-bottom: 3rem;
}

/* Individual Post Card */
.blog-article {
	background: #0d0d0d;
	border: 1px solid rgb(154 159 166 / 20%);
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: border-color 0.4s ease, transform 0.4s ease;
	text-decoration: none;
}

.blog-article a {
	text-decoration: none;
}

.blog-article:hover {
	border-color: var(--forge-red);
	transform: translateY(-4px);
}

.blog-article--image {
	position: relative;
	width: 100%;
	height: 260px;
	overflow: hidden;
}

.blog-article--image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.blog-article:hover .blog-article--image img {
	transform: scale(1.05);
}

.blog-article--image span {
	position: absolute;
	top: 1.5rem;
	left: 1.5rem;
	background: var(--forge-red);
	color: #fff;
	font-family: var(--font-heading);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0.35rem 1rem;
	font-size: 1.2rem;
	border-radius: 4px;
	z-index: 2;
}

.blog-article--content {
	padding: 2.5rem 2rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.blog-article--content-info {
	flex: 1;
}

.blog-article--content-info-title h2,
.blog-article--content-info-title h3 {
	font-family: var(--font-heading);
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.25;
	margin: 0 0 1rem 0;
}

.blog-article--content-info-title a {
	color: #fff;
	transition: color 0.3s ease;
}

.blog-article--content-info-title a:hover {
	color: var(--forge-red);
}

.blog-article--content-info-description p {
	color: var(--steel-light);
	font-size: 1.6rem;
	line-height: 1.6;
	margin: 0 0 2rem 0;
}

/* Card Read More Link */
.blog-article--content-cta a {
	display: inline-flex;
	align-items: center;
	color: var(--forge-red);
	font-family: var(--font-heading);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 1.4rem;
	transition: color 0.3s ease;
	gap: 0.75rem;
}

.blog-article--content-cta a:hover {
	color: var(--forge-red-light);
}

.blog-article--content-cta i {
	transition: transform 0.3s ease;
}

.blog-article:hover .blog-article--content-cta i {
	transform: translateX(5px);
}

/* Sidebar Filtering Menu */
.blog-filter {
	margin-bottom: 2rem;
	background: #111111;
	border: 1px solid rgb(154 159 166 / 20%);
	padding: 2.5rem;
	border-radius: 8px;
}

.blog-filter h3 {
	font-family: var(--font-heading);
	color: #fff;
	font-size: 2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0 0 1.5rem 0;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgb(154 159 166 / 20%);
}

.blog-filter span {
	display: flex;
	align-items: center;
	color: var(--steel-light);
	font-size: 1.6rem;
	margin-bottom: 1.25rem;
	cursor: pointer;
	transition: color 0.3s ease;
	gap: 1rem;
}

.blog-filter span i {
	color: var(--forge-red);
	width: 20px;
	text-align: center;
}

.blog-filter span:last-child {
	margin-bottom: 0;
}

.blog-filter span:hover {
	color: var(--forge-red);
}

.blog-filter span.active {
	color: #fff;
	font-weight: 600;
}

/* Advanced Pagination */
.blog-pagination {
	margin-top: 5rem;
	padding-top: 3rem;
	border-top: 1px solid rgb(154 159 166 / 20%);
	display: flex;
	justify-content: center;
}

.blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	border: 1px solid rgb(154 159 166 / 20%);
	color: #fff;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.6rem;
	margin: 0 0.25rem;
	transition: all 0.3s ease;
	border-radius: 4px;
	text-decoration: none;
}

.blog-pagination .page-numbers:hover {
	border-color: var(--forge-red);
	color: #fff;
	background: rgba(168, 35, 46, 0.1);
}

.blog-pagination .page-numbers.current {
	background: var(--forge-red);
	border-color: var(--forge-red);
	color: #fff;
}

.blog-pagination .page-numbers.prev,
.blog-pagination .page-numbers.next {
	width: auto;
	padding: 0 1.5rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

/* Empty State */
.error-message {
	text-align: center;
	padding: 4rem 2rem;
	background: #111111;
	border: 1px solid rgb(154 159 166 / 20%);
	border-radius: 8px;
}

.error-message p {
	font-size: 1.8rem;
	color: var(--steel-light);
	margin-bottom: 2rem;
}

@media (max-width: 896px) {
	.container {
		padding-right: 3rem;
		padding-left: 3rem;
	}

	.button-group {
		margin-top: 2rem;
	}

	.blog .content-sidebar-wrap {
		padding: 10rem 0 0;
		margin: 0 3rem;
	}

	.hero-content {
		padding-top: 8rem;
	}

	section.section {
		padding: 5rem 0 6rem;
	}

	footer.footer .wrap {
		padding: 0 4rem;
	}

	.mobile-nav-link {
		font-size: 1.6rem;
		color: #fff;
	}

	a.mobile-cta {
		font-size: 1.8rem;
	}
}

@media (max-width: 767px) {
	.entry-content>.wp-block-genesis-blocks-gb-columns>.gb-layout-column-wrap {
		width: 100%;
	}
}

.aion-hidden {
	display: none !important;
}

/* FPD Conditional Views */
body.fpd-hide-back-view .fpd-views-selection,
body.fpd-hide-back-view .fpd-views-wrapper .fpd-item:nth-child(2) {
	display: none !important;
}

/* Prevent Mobile Overflow from Fancy Product Designer and Form */
html,
body {
	overflow-x: hidden;
	width: 100%;
}

.woocommerce div.product {
	max-width: 100vw;
	overflow-x: hidden;
}

h1.product_title {
	word-break: break-word;
	overflow-wrap: break-word;
	white-space: normal !important;
}

.woocommerce div.product .product-gallery-column,
.woocommerce div.product .woocommerce-product-gallery__wrapper,
.woocommerce div.product .woocommerce-product-gallery,
.fpd-container {
	max-width: 100% !important;
	box-sizing: border-box;
}

.woocommerce div.product form.cart {
	max-width: 100%;
}

/* WooCommerce Mobile Specific Layout */
@media (max-width: 1023px) {
	.aion-hide-on-mobile {
		display: none !important;
	}

	.woocommerce-breadcrumb {
		display: none !important;
	}

	.woocommerce div.product .woocommerce-tabs {
		padding: 4rem 3rem;
	}

	.woocommerce div.product .woocommerce-tabs .panel ul {
		padding-left: 1rem;
		margin-left: 2rem;
	}
}

@media (min-width: 1024px) {
	.aion-hide-on-desktop {
		display: none !important;
	}
}