body, p, li, a, span, input, textarea, select, button{
	font-size: 14px;
}

h1 {
	font-size: 2rem;
}

.frontpagetext {
	max-width: 100%;
	width: 100%;
}

.frontpagetext.prose {
	max-width: none !important;
}

.frontpagetext > .flex:first-of-type {
	display: flex;
	flex-wrap: nowrap;
	gap: 24px;
	align-items: center;
	overflow: visible;
	box-sizing: border-box;
}

.frontpagetext > .flex:first-of-type > div {
	flex: 0 1 45%;
	max-width: 45%;
	min-width: 0;
	box-sizing: border-box;
}

.frontpagetext > .flex:first-of-type > div:last-child {
	flex: 0 1 55%;
	max-width: 55%;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
}

.frontpagetext > .flex:first-of-type > div:first-child {
	background: #F3F1EE;
	border-radius: 12px;
	padding: 50px;
	box-sizing: border-box;
}

.frontpagetext > .flex:first-of-type img {
	width: 100%;
	max-width: 100%;
	height: auto;
	object-fit: cover;
	display: block;
	margin-left: auto;
	margin-right: auto;
	border-radius: 12px;
	box-sizing: border-box;
}

@media (max-width: 1200px) {
	.frontpagetext .flex {
		gap: 32px;
	}

	.frontpagetext .flex > div:first-child {
		padding: 40px;
	}
}

@media (max-width: 992px) {
	.frontpagetext > .flex:first-of-type {
		flex-direction: column;
		align-items: stretch;
		gap: 20px;
		overflow: visible;
	}

	.frontpagetext > .flex:first-of-type > div {
		flex: 1 1 auto;
		width: 100%;
		max-width: 100%;
	}

	.frontpagetext > .flex:first-of-type > div:first-child {
		padding: 32px;
	}

	.frontpagetext > .flex:first-of-type > div:last-child {
		justify-content: flex-start;
		align-items: flex-start;
		width: 100%;
		max-width: 100%;
		display: block;
	}

	.frontpagetext > .flex:first-of-type img {
		max-width: 100% !important;
		width: 100% !important;
		height: auto !important;
		display: block !important;
		object-fit: cover !important;
	}
}

@media (max-width: 640px) {
	.frontpagetext .flex {
		gap: 20px;
	}

	.frontpagetext .flex > div:first-child {
		padding: 24px;
	}

	.frontpagetext h1 {
		font-size: 1.6rem;
	}

	.frontpagetext p {
		font-size: 0.95rem;
	}

	.btn-buy-styled .btn-text-area span,
	.btn-variant-styled .btn-text-area span,
	.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy .btn-text-area span,
	.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy .btn-text-area span,
	.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy) .btn-text-area span,
	.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy) .btn-text-area span {
		font-size: 11px;
	}
}

.frontpagetext h1 {
	margin-bottom: 16px;
}

.frontpagetext p {
	margin-bottom: 12px;
	line-height: 1.6;
}

/* Button Styled Design - Buy Button (Green) */
.btn-buy-styled {
	display: flex;
	align-items: stretch;
	position: relative;
	overflow: hidden;
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	width: 100%;
	height: 45px;
	cursor: pointer;
	transition: box-shadow 0.2s ease;
	border-radius: 3px;
}

/* Allow flexible width for list buttons */
.btn-buy-styled.flex-1 {
	width: 100%;
	max-width: none;
}

.btn-buy-styled.w-full {
	width: 100%;
	max-width: none;
}

.btn-buy-styled::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 45px;
	right: 0;
	height: 4px;
	background-color: #325B22;
	border-radius: 0 0 3px 0;
	z-index: 3;
}

.btn-buy-styled::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 45px;
	height: 4px;
	background-color: #213C16;
	border-radius: 3px 0 0 0;
	z-index: 3;
}

.btn-buy-styled .btn-icon-box {
	width: 45px;
	height: 45px;
	background-color: #2F5620;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	position: relative;
	z-index: 2;
	border-radius: 3px 0 0 3px;
	transition: background-color 0.2s ease;
}

.btn-buy-styled .btn-icon-box img {
	width: 20px;
	height: 20px;
	object-fit: contain;
	filter: brightness(0) invert(1);
}

.btn-buy-styled .btn-icon-box svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

.btn-buy-styled .btn-text-area {
	flex: 1;
	background-color: #488331;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	position: relative;
	z-index: 2;
	color: white;
	font-weight: bold;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: 0 3px 3px 0;
	transition: background-color 0.2s ease;
}

.btn-buy-styled .btn-text-area span {
	font-weight: bold;
}

.btn-buy-styled:hover .btn-icon-box {
	background-color: #3d6d2a;
	transition: background-color 0.2s ease;
}

.btn-buy-styled:hover .btn-text-area {
	background-color: #5ba045;
	transition: background-color 0.2s ease;
}

/* Button Styled Design - Cart Button (Green, No Icon) */
.btn-cart-styled {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	background-color: #488331;
	border: none;
	padding: 0 12px;
	margin: 0;
	width: 100%;
	height: 45px;
	cursor: pointer;
	transition: background-color 0.2s ease;
	border-radius: 3px;
	color: white;
	font-weight: bold;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	text-decoration: none;
}

.btn-cart-styled.w-full {
	width: 100%;
	max-width: none;
}

.btn-cart-styled::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 4px;
	background-color: #325B22;
	border-radius: 0 0 3px 3px;
	z-index: 3;
}

.btn-cart-styled:hover {
	background-color: #5ba045;
	transition: background-color 0.2s ease;
}

/* BewisePlus Buy Button - styled with pseudo-elements */
.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy {
	display: flex;
	align-items: stretch;
	position: relative;
	overflow: hidden;
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	width: 100%;
	height: 45px;
	cursor: pointer;
	transition: box-shadow 0.2s ease;
	border-radius: 3px;
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy::before,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 45px;
	right: 0;
	height: 4px;
	background-color: #325B22;
	border-radius: 0 0 3px 0;
	z-index: 3;
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy::after,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 45px;
	height: 4px;
	background-color: #213C16;
	border-radius: 3px 0 0 0;
	z-index: 3;
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy .btn-icon-box,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy .btn-icon-box {
	width: 45px;
	height: 45px;
	background-color: #2F5620;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	position: relative;
	z-index: 2;
	border-radius: 3px 0 0 3px;
	transition: background-color 0.2s ease;
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy .btn-icon-box img,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy .btn-icon-box img {
	width: 20px;
	height: 20px;
	object-fit: contain;
	filter: brightness(0) invert(1);
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy .btn-text-area,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy .btn-text-area {
	flex: 1;
	background-color: #488331;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	position: relative;
	z-index: 2;
	color: white;
	font-weight: bold;
	font-size: 14px;
	transition: background-color 0.2s ease;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: 0 3px 3px 0;
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy:hover .btn-icon-box,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy:hover .btn-icon-box {
	background-color: #3d6d2a;
	transition: background-color 0.2s ease;
}

.bp_relatedproductsProductButton.design_224.bp_relatedproductsProductButtonBuy:hover .btn-text-area,
.bp_relatedproductsProductButton.design_231.bp_relatedproductsProductButtonBuy:hover .btn-text-area {
	background-color: #5ba045;
	transition: background-color 0.2s ease;
}

/* Button Styled Design - Variant Button (Gray) */
.btn-variant-styled {
	display: flex;
	align-items: stretch;
	position: relative;
	overflow: hidden;
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	width: 100%;
	height: 45px;
	cursor: pointer;
	transition: box-shadow 0.2s ease;
	border-radius: 3px;
}

/* Allow flexible width for list buttons */
.btn-variant-styled.w-full {
	width: 100%;
	max-width: none;
}

.btn-variant-styled::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 4px;
	background-color: #1A1A1A;
	border-radius: 0 0 3px 3px;
	z-index: 3;
}

.btn-variant-styled .btn-icon-box {
	width: 45px;
	height: 45px;
	background-color: #252525;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	position: relative;
	z-index: 2;
	border-radius: 3px 0 0 3px;
	transition: background-color 0.2s ease;
}

.btn-variant-styled .btn-icon-box img {
	width: 20px;
	height: 20px;
	object-fit: contain;
	filter: brightness(0) invert(1);
}

.btn-variant-styled .btn-icon-box svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

.btn-variant-styled .btn-text-area {
	flex: 1;
	background-color: #383838;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	position: relative;
	z-index: 2;
	color: white;
	font-weight: bold;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: 0 3px 3px 0;
	transition: background-color 0.2s ease;
}

.btn-variant-styled .btn-text-area span {
	font-weight: bold;
}

.btn-variant-styled:hover .btn-icon-box {
	background-color: #353535;
	transition: background-color 0.2s ease;
}

.btn-variant-styled:hover .btn-text-area {
	background-color: #4a4a4a;
	transition: background-color 0.2s ease;
}

/* BewisePlus Variant Button */
.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy),
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy) {
	display: flex;
	align-items: stretch;
	position: relative;
	overflow: hidden;
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	width: 100%;
	height: 45px;
	cursor: pointer;
	transition: box-shadow 0.2s ease;
	border-radius: 3px;
}

.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy)::before,
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy)::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 4px;
	background-color: #1A1A1A;
	border-radius: 0 0 3px 3px;
	z-index: 3;
}

.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy) .btn-icon-box,
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy) .btn-icon-box {
	width: 45px;
	height: 45px;
	background-color: #252525;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	position: relative;
	z-index: 2;
	border-radius: 3px 0 0 3px;
	transition: background-color 0.2s ease;
}

.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy) .btn-icon-box img,
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy) .btn-icon-box img {
	width: 20px;
	height: 20px;
	object-fit: contain;
	filter: brightness(0) invert(1);
}

.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy) .btn-text-area,
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy) .btn-text-area {
	flex: 1;
	background-color: #383838;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	position: relative;
	z-index: 2;
	color: white;
	font-weight: bold;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: 0 3px 3px 0;
	transition: background-color 0.2s ease;
}

.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy):hover .btn-icon-box,
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy):hover .btn-icon-box {
	background-color: #353535;
	transition: background-color 0.2s ease;
}

.bp_relatedproductsProductButton.design_224:not(.bp_relatedproductsProductButtonBuy):hover .btn-text-area,
.bp_relatedproductsProductButton.design_231:not(.bp_relatedproductsProductButtonBuy):hover .btn-text-area {
	background-color: #4a4a4a;
	transition: background-color 0.2s ease;
}

/* Button Image Hover Overlay Effect */
.btn-image {
	position: relative;
}

/* Ensure background image fits perfectly on product list buttons */
.angular-productlist .btn-image {
	background-size: 100% 100% !important;
	background-position: center !important;
}

.btn-image::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: rgba(255, 255, 255, 0);
	transition: background-color 0.2s ease;
	pointer-events: none;
	z-index: 1;
}

.btn-image:hover::before {
	background-color: rgba(255, 255, 255, 0.3);
}

.btn-image:disabled::before,
.btn-image[disabled]::before {
	display: none;
}

/* Hide related products container on mobile and tablet, show on desktop */
.bp_relatedproductsContainer.design_224,
.bp_relatedproductsContainer.design_231 {
	display: none;
}

@media (min-width: 1024px) {
	.bp_relatedproductsContainer.design_224,
	.bp_relatedproductsContainer.design_231 {
		display: block;
	}
}

/* Injected product carousel overrides; buttons/controls can be overridden here */
#bp_ProductCarousel_708,
#bp_ProductCarousel_769 {
	margin-top: 32px;
	margin-bottom: 32px;
}