:root {
	color-scheme: light;
}

html {
	background: #fff;
	box-sizing: border-box;
	color: #0a0a0a;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

body.faith-origin-home {
	background: #fff !important;
	color: #0a0a0a;
	font-family: Arial, Helvetica, sans-serif;
	letter-spacing: 0;
	margin: 0;
	min-width: 320px;
}

.faith-origin-home a,
.faith-origin-home a:hover,
.faith-origin-home a:focus {
	color: #0a0a0a;
	text-decoration: none;
}

.faith-origin-home img {
	filter: none !important;
	mix-blend-mode: normal !important;
	max-width: 100%;
	opacity: 1 !important;
}

.fo-header {
	background: #fff !important;
	color: #0a0a0a;
	position: relative;
	width: 100%;
	z-index: 5;
}

.fo-header-inner {
	align-items: center;
	background: #fff;
	color: #0a0a0a;
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1240px;
	min-height: 136px;
	padding: 30px 32px;
	width: 100%;
}

.fo-logo-link {
	background: transparent;
	color: #0a0a0a;
	display: inline-flex;
	line-height: 0;
	width: 96px;
}

.fo-logo-link img {
	display: block;
	height: auto;
	width: 100%;
}

.fo-menu-button {
	display: none;
}

.fo-nav-links {
	align-items: center;
	background: #fff;
	color: #0a0a0a;
	display: flex;
	gap: clamp(30px, 4vw, 68px);
	justify-content: flex-end;
}

.fo-nav-links a,
.fo-footer-nav a,
.fo-category-links a {
	color: #0a0a0a;
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.2;
	text-transform: none;
}

.fo-banner {
	background: #fff;
	color: #0a0a0a;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 0;
	min-height: 320px;
	padding: 0;
	width: 100%;
}

.fo-banner-panel {
	align-items: center;
	color: #0a0a0a;
	display: flex;
	justify-content: center;
	min-height: 320px;
	overflow: hidden;
	position: relative;
}

.fo-banner-panel span {
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0;
	opacity: 0.58;
}

.fo-label-mobile {
	display: none;
}

.fo-banner-panel-dark {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.06) 0 25%, transparent 25% 50%, rgba(255, 255, 255, 0.06) 50% 75%, transparent 75%),
		#171717;
	color: #fff;
}

.fo-banner-panel-logo {
	background: #f3f3f0 !important;
	color: #0a0a0a;
}

.fo-banner-panel-logo img {
	display: block;
	height: auto;
	max-width: min(230px, 58%);
}

.fo-banner-panel-light {
	background:
		linear-gradient(90deg, rgba(0, 0, 0, 0.035) 1px, transparent 1px),
		#eeeeea;
	background-size: 34px 100%;
}

.fo-featured {
	background: #fff;
	color: #0a0a0a;
	margin: 0 auto;
	max-width: 1240px;
	padding: 48px 32px 0;
	width: 100%;
}

.fo-product-card {
	background: #fff;
	color: #0a0a0a;
	display: block;
	max-width: 320px;
}

.fo-product-image {
	align-items: center;
	background: #f7f7f5;
	display: flex;
	justify-content: center;
	min-height: 320px;
	padding: 10px;
	width: 100%;
}

.fo-product-image img {
	display: block;
	height: auto;
	width: 100%;
}

.fo-product-info {
	background: #fff;
	color: #0a0a0a;
	padding-top: 18px;
}

.fo-product-info h1 {
	color: #0a0a0a;
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.3;
	margin: 0 0 14px;
	text-transform: none;
}

.fo-product-info p,
.fo-brand-statement,
.fo-footer p,
.fo-footer-logo {
	color: #0a0a0a;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.55;
	margin: 0;
	text-transform: none;
}

.fo-brand-statement {
	margin-top: 52px;
	max-width: 430px;
}

.fo-category-links {
	background: #fff;
	color: #0a0a0a;
	display: flex;
	gap: 32px;
	margin: 0 auto;
	max-width: 1240px;
	padding: 52px 32px 82px;
	width: 100%;
}

.fo-category-links a {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 5px;
}

.fo-footer {
	background: #f4f4f4 !important;
	color: #0a0a0a;
	padding: 34px 32px;
}

.fo-footer-inner {
	align-items: center;
	background: #f4f4f4;
	color: #0a0a0a;
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(120px, 1fr) auto minmax(220px, 1fr);
	margin: 0 auto;
	max-width: 1240px;
	width: 100%;
}

.fo-footer-nav {
	display: flex;
	gap: 28px;
	justify-content: center;
}

.fo-footer p {
	font-size: 13px;
	justify-self: end;
}

@media (max-width: 767px) {
	.fo-header-inner {
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
		gap: 18px 24px;
		min-height: 0;
		padding: 24px 20px;
	}

	.fo-logo-link {
		width: 82px;
	}

	.fo-menu-button {
		align-items: center;
		background: transparent;
		border: 0;
		display: inline-flex;
		flex-direction: column;
		gap: 6px;
		height: 38px;
		justify-content: center;
		cursor: pointer;
		margin-left: auto;
		padding: 0;
		width: 38px;
	}

	.fo-menu-button span {
		background: #0a0a0a;
		display: block;
		height: 1px;
		width: 28px;
	}

	.fo-nav-links {
		border-top: 1px solid #e3e3e3;
		display: none;
		flex-basis: 100%;
		flex-direction: column;
		gap: 0;
		justify-content: flex-start;
		padding-top: 16px;
		width: 100%;
	}

	.fo-nav-links a {
		display: block;
		padding: 11px 0;
		width: 100%;
	}

	.fo-nav-links.is-open {
		display: flex;
	}

	.fo-banner {
		grid-template-columns: 1fr;
		min-height: 0;
		padding: 0;
	}

	.fo-banner-panel {
		min-height: 210px;
	}

	.fo-label-desktop {
		display: none;
	}

	.fo-label-mobile {
		display: inline;
	}

	.fo-banner-panel-logo img {
		max-width: 170px;
	}

	.fo-featured {
		padding: 48px 20px 0;
	}

	.fo-product-card {
		max-width: 330px;
	}

	.fo-category-links {
		flex-wrap: wrap;
		gap: 22px;
		padding: 44px 20px 64px;
	}

	.fo-footer {
		padding: 30px 20px;
	}

	.fo-footer-inner {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.fo-footer-nav {
		flex-wrap: wrap;
		justify-content: flex-start;
	}

	.fo-footer p {
		justify-self: start;
	}
}
